.sidebar{position:fixed;left:0;top:0;bottom:0;width:250px;background:var(--bg-secondary);border-right:1px solid var(--bg-tertiary);display:flex;flex-direction:column;z-index:100}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--bg-tertiary)}.sidebar-logo{display:flex;align-items:center;gap:.75rem}.logo-icon{color:var(--primary)}.logo-text{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.sidebar-nav{flex:1;padding:1rem;display:flex;flex-direction:column;gap:.5rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);font-size:.9375rem;font-weight:500;transition:all var(--transition-fast);width:100%;text-align:left}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item-active{background:var(--primary);color:#fff}.nav-item-active:hover{background:var(--primary-dark);color:#fff}.nav-icon{flex-shrink:0}.sync-status{display:flex;align-items:center;gap:.5rem;margin:0 1rem .75rem;padding:.625rem .875rem;background:var(--bg-tertiary);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.8125rem;transition:all var(--transition-fast);width:calc(100% - 2rem);text-align:left}.sync-status:hover{background:var(--bg-primary);color:var(--text-primary)}.sync-status.sync-connected{color:var(--success)}.sync-status.sync-error{color:var(--danger)}.sync-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-footer{padding:1rem 1.5rem;border-top:1px solid var(--bg-tertiary)}.sidebar-tagline{font-size:.8125rem;font-style:italic;color:var(--text-secondary);margin-bottom:.25rem}.sidebar-version{font-size:.75rem;color:var(--text-muted)}.sidebar-copilot{width:120px;height:auto;display:block;margin:0 auto .75rem;opacity:.85;transition:opacity .3s ease,transform .3s ease}.sidebar-copilot:hover{opacity:1;transform:scale(1.05)}.mobile-menu-btn{display:none;position:fixed;top:1rem;left:1rem;z-index:200;background:var(--bg-secondary);color:var(--text-primary);padding:.5rem;border-radius:var(--radius-md);box-shadow:var(--shadow-md)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:50}@media (max-width: 768px){.sidebar{transform:translate(-100%);transition:transform var(--transition-normal)}.sidebar-open{transform:translate(0)}.mobile-menu-btn,.sidebar-overlay{display:block}}.dashboard{max-width:1400px;margin:0 auto}.summary-card-value.positive{color:var(--success)}.summary-card-value.negative{color:var(--danger)}.monthly-overview{display:flex;align-items:center;justify-content:center;gap:2rem;background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem 2rem;margin-bottom:2rem;flex-wrap:wrap}.overview-item{display:flex;flex-direction:column;align-items:center;gap:.25rem}.overview-label{font-size:.875rem;color:var(--text-secondary)}.overview-value{font-size:1.5rem;font-weight:700}.overview-value.income{color:var(--success)}.overview-value.expenses{color:var(--danger)}.overview-value.positive{color:var(--success)}.overview-value.negative{color:var(--danger)}.overview-divider{font-size:1.5rem;color:var(--text-muted);font-weight:300}.monthly-actual{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg-tertiary);border-radius:var(--radius-md);margin-bottom:1.5rem;font-size:.875rem}.actual-label{color:var(--text-secondary)}.actual-spent{font-weight:600;color:var(--text-primary)}.actual-remaining{color:var(--text-muted)}.actual-remaining.positive{color:#22c55e}.actual-remaining.negative{color:#ef4444}.monthly-overview.future-month{border:2px dashed var(--primary);position:relative}.projected-banner{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:var(--primary);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:.375rem}.funding-summary{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:2rem}.funding-summary-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.funding-summary-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.funding-summary-total{font-size:.875rem;color:#22c55e;font-weight:600}.funding-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:.75rem}.funding-summary-card{display:flex;align-items:center;gap:.75rem;padding:.875rem;background:var(--bg-tertiary);border-radius:var(--radius-md);border-left:3px solid var(--primary)}.funding-summary-card.emergency{border-left-color:#dc2626}.funding-summary-icon{width:36px;height:36px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#dc262626;color:#dc2626}.funding-summary-card.goal .funding-summary-icon{background:#6366f126;color:var(--primary)}.funding-summary-info{flex:1;min-width:0}.funding-summary-name{display:block;font-size:.8125rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.25rem}.funding-summary-progress .progress-bar{height:4px;max-width:100%}.funding-summary-amounts{text-align:right;flex-shrink:0}.funding-summary-funded{display:block;font-size:.9375rem;font-weight:700;color:#22c55e}.funding-summary-funded.unfunded{color:var(--text-muted)}.funding-summary-needed{display:block;font-size:.6875rem;color:var(--text-muted)}.dashboard .charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.chart-card-wide{grid-column:span 2}@media (max-width: 1024px){.dashboard .charts-grid{grid-template-columns:1fr}.chart-card-wide{grid-column:span 1}}@media (max-width: 768px){.monthly-overview{gap:1rem;padding:1rem}.overview-value,.overview-divider{font-size:1.25rem}}.category-manager{max-width:1000px;margin:0 auto}.budget-summary-card{background:linear-gradient(135deg,#6366f1,#4f46e5);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;margin-bottom:1.5rem;color:#fff}.budget-summary-main{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.budget-summary-icon{opacity:.9}.budget-summary-label{display:block;font-size:.8125rem;opacity:.85;margin-bottom:.125rem}.budget-summary-value{font-size:1.75rem;font-weight:700}.budget-summary-groups{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.2)}.budget-group-summary{display:flex;flex-direction:column;gap:.125rem}.budget-group-name{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.budget-group-amount{font-size:1rem;font-weight:600}.category-groups{display:flex;flex-direction:column;gap:.75rem}.category-group{background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden}.category-group-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.5rem .75rem;background:var(--bg-tertiary);border:none;color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast)}.category-group-header:hover{background:#3d4a5e}.category-group-header-wrapper{display:flex;align-items:center;background:var(--bg-tertiary)}.category-group-header-wrapper .category-group-header{flex:1}.category-group-actions{display:flex;gap:.25rem;padding-right:.5rem;opacity:0;transition:opacity var(--transition-fast)}.category-group-header-wrapper:hover .category-group-actions{opacity:1}.category-group-actions .btn-icon{padding:.375rem}.category-group-title{display:flex;align-items:center;gap:.5rem;font-size:.9375rem;font-weight:600}.category-group-indicator{width:4px;height:20px;border-radius:2px}.category-group-count{font-size:.8125rem;font-weight:400;color:var(--text-muted)}.category-group-meta{display:flex;align-items:center;gap:.75rem;color:var(--text-secondary)}.category-group-budget{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.category-list{padding:.25rem .5rem;display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:.25rem}.category-empty{padding:1rem;text-align:center;color:var(--text-muted);font-size:.8125rem;grid-column:1 / -1}.category-item{display:flex;align-items:center;gap:.5rem;padding:.375rem .5rem;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.category-item:hover{background:var(--bg-tertiary)}.category-item-icon{width:24px;height:24px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 1px 4px #0000004d,inset 0 1px #ffffff1a;position:relative}.category-item-icon:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;box-shadow:inset 0 -1px 2px #0003;pointer-events:none}.category-item-icon svg{width:12px;height:12px;filter:drop-shadow(0 1px 1px rgba(0,0,0,.3))}.category-item-info{flex:1;min-width:0;display:flex;align-items:center;gap:.5rem}.category-item-name{font-size:.75rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.category-item-progress{display:flex;align-items:center;gap:.375rem}.progress-bar.small{flex:1;height:3px;max-width:60px}.category-item-spent{font-size:.625rem;color:var(--text-muted);white-space:nowrap;display:flex;align-items:center;gap:.25rem}.budget-inline{background:none;border:none;padding:0 .125rem;font-size:.625rem;font-weight:600;color:var(--text-primary);cursor:pointer;border-radius:2px}.budget-inline:hover{background:var(--bg-tertiary)}.budget-input-inline{width:50px;padding:0 .25rem;background:var(--bg-tertiary);border:1px solid var(--primary);border-radius:2px;color:var(--text-primary);font-size:.625rem;font-weight:600;text-align:center}.budget-input-inline:focus{outline:none}.monthly-contribution{color:var(--primary);font-size:.5625rem}.category-item-budget{width:70px;text-align:right}.budget-display{background:none;border:1px solid transparent;padding:.25rem .375rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);width:100%;text-align:right}.budget-display:hover{background:var(--bg-tertiary);border-color:var(--bg-tertiary)}.budget-input{width:100%;padding:.25rem .375rem;background:var(--bg-tertiary);border:1px solid var(--primary);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.75rem;font-weight:600;text-align:right}.budget-input:focus{outline:none;box-shadow:0 0 0 3px #6366f133}.category-item-actions{display:flex;gap:.125rem;opacity:0;transition:opacity var(--transition-fast)}.category-item-actions .btn-icon{padding:.25rem}.category-item:hover .category-item-actions{opacity:1}.modal-lg{max-width:560px}.icon-picker-trigger,.color-picker-trigger{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:var(--bg-tertiary);border:1px solid transparent;border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.icon-picker-trigger:hover,.color-picker-trigger:hover{border-color:var(--primary)}.icon-picker{position:absolute;top:100%;left:0;right:0;margin-top:.5rem;padding:1rem;background:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:var(--radius-md);display:grid;grid-template-columns:repeat(8,1fr);gap:.5rem;max-height:200px;overflow-y:auto;z-index:10}.icon-option{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--bg-tertiary);border:2px solid transparent;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.icon-option:hover{background:var(--primary);color:#fff}.icon-option.selected{border-color:var(--primary);color:var(--primary)}.color-preview{width:20px;height:20px;border-radius:4px}.color-picker{position:absolute;top:100%;left:0;right:0;margin-top:.5rem;padding:1rem;background:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:var(--radius-md);display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem;z-index:10}.color-option{width:36px;height:36px;border:3px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:#fff;box-shadow:0 0 0 2px var(--primary)}.form-group{position:relative}.category-preview{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--bg-tertiary)}.category-preview-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-tertiary);border-radius:var(--radius-md);margin-top:.5rem}.category-preview-budget{margin-left:auto;font-size:.875rem;font-weight:600;color:var(--text-secondary)}.group-preview-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-tertiary);border-radius:var(--radius-md);margin-top:.5rem;font-weight:600;color:var(--text-primary)}.category-item-name-row{display:flex;align-items:center;gap:.375rem}.rollover-badge{display:inline-flex;align-items:center;justify-content:center;color:var(--primary);opacity:.8}.rollover-toggle{color:var(--text-muted);transition:all var(--transition-fast)}.rollover-toggle:hover{color:var(--primary)}.rollover-toggle.active{color:var(--primary);background:#6366f126}.rollover-amount{font-size:.625rem}.rollover-amount.positive{color:var(--success)}.rollover-amount.negative{color:var(--danger)}.rollover-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9375rem;color:var(--text-primary)}.rollover-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer}.rollover-checkbox svg{color:var(--primary)}.form-hint{font-size:.75rem;color:var(--text-muted);margin-top:.375rem;line-height:1.4}.savings-funding-section{background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:.75rem}.savings-positive{color:#22c55e!important}.savings-content{padding:1rem}.savings-summary{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:1rem;margin-bottom:1rem}.savings-row{display:flex;justify-content:space-between;align-items:center;padding:.375rem 0}.savings-row.total{border-top:1px solid var(--bg-secondary);margin-top:.5rem;padding-top:.75rem}.savings-label{font-size:.875rem;color:var(--text-secondary)}.savings-value{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.savings-value.positive{color:#22c55e}.savings-value.negative{color:#ef4444}.funding-card{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:1rem;margin-bottom:.75rem}.funding-card.emergency{border-left:3px solid #dc2626}.funding-card.emergency.fully-funded{border-left:3px solid #22c55e}.funding-card.goal{border-left:3px solid var(--primary)}.funding-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.funding-priority{font-size:.75rem;font-weight:700;color:var(--text-muted);min-width:24px}.funding-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.funding-icon.emergency{background:#dc262626;color:#dc2626}.funding-icon.funded{background:#22c55e26;color:#22c55e}.funding-icon.goal{background:#6366f126;color:var(--primary)}.funding-info{flex:1;min-width:0}.funding-name{display:block;font-size:.9375rem;font-weight:600;color:var(--text-primary)}.funding-status{display:block;font-size:.75rem;margin-top:.125rem}.status-funded{color:#22c55e;display:inline-flex;align-items:center;gap:.25rem}.status-partial{color:#f59e0b;display:inline-flex;align-items:center;gap:.25rem}.status-unfunded{color:var(--text-muted);display:inline-flex;align-items:center;gap:.25rem}.funding-amount{text-align:right}.funding-monthly{display:block;font-size:1rem;font-weight:700;color:#22c55e}.funding-monthly.unfunded{color:var(--text-muted)}.funding-monthly.partial{color:#f59e0b}.funding-needed{display:block;font-size:.6875rem;color:var(--text-muted)}.funding-recovery{display:block;font-size:.625rem;color:var(--primary);font-weight:500}.funding-progress{display:flex;align-items:center;gap:.75rem}.funding-progress .progress-bar{flex:1;height:6px}.progress-bar-fill.emergency{background:linear-gradient(90deg,#dc2626,#ef4444)}.progress-bar-fill.funded{background:linear-gradient(90deg,#22c55e,#4ade80)}.progress-bar-fill.goal{background:linear-gradient(90deg,var(--primary),#818cf8)}.funding-saved{font-size:.75rem;color:var(--text-secondary);white-space:nowrap}.funding-target-date{color:var(--text-muted)}.funding-goals{margin-top:1rem}.funding-section-title{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--bg-tertiary)}.projected-label{font-size:.75rem;font-weight:500;color:var(--primary);margin-left:.5rem}.funding-unallocated{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#22c55e1a;border-radius:var(--radius-md);margin-top:.5rem}.funding-unallocated span:first-child{font-size:.875rem;color:var(--text-secondary)}.unallocated-amount{font-size:1rem;font-weight:700;color:#22c55e}.header-actions{display:flex;align-items:center;gap:.75rem}.month-selector{position:relative}.month-selector .form-select{padding-right:2rem;min-width:180px}.month-selector .select-icon{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text-muted)}.funding-recovery-warning{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#f59e0b26;border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-md);margin-bottom:.75rem;font-size:.8125rem;color:#f59e0b}.funding-recovery-warning svg{flex-shrink:0}.funding-card.fixed-spending{border-left:3px solid #8b5cf6}.funding-icon.fixed{background:#8b5cf626!important;color:#8b5cf6!important}.status-fixed-spending{color:#8b5cf6;font-size:.75rem}.funding-balance{font-size:1.125rem;font-weight:700;color:#22c55e}.funding-label{font-size:.6875rem;color:var(--text-muted);display:block}.fixed-spending-stats{padding-top:.5rem;border-top:1px solid var(--bg-secondary);margin-top:.5rem}.spent-amount{font-size:.8125rem;color:var(--text-secondary)}@media (max-width: 768px){.budget-summary-groups{grid-template-columns:repeat(2,1fr)}.category-list{grid-template-columns:1fr}.category-item{flex-wrap:wrap}.category-item-budget{width:auto;margin-left:auto}.category-item-actions{opacity:1;width:100%;justify-content:flex-end;margin-top:.5rem}.form-row{grid-template-columns:1fr}.icon-picker{grid-template-columns:repeat(6,1fr)}}.csv-import-modal{width:95vw;max-width:1000px;max-height:90vh;display:flex;flex-direction:column}.csv-import-modal .modal-body{flex:1;overflow:hidden;display:flex;flex-direction:column}.upload-zone{border:2px dashed var(--bg-tertiary);border-radius:var(--radius-lg);padding:3rem 2rem;text-align:center;cursor:pointer;transition:all var(--transition-fast);background:var(--bg-tertiary)}.upload-zone:hover,.upload-zone.drag-active{border-color:var(--primary);background:#6366f11a}.upload-icon{color:var(--text-muted);margin-bottom:1rem}.upload-zone:hover .upload-icon,.upload-zone.drag-active .upload-icon{color:var(--primary)}.upload-text{font-size:1rem;color:var(--text-primary);margin:0 0 .5rem}.upload-hint{font-size:.8125rem;color:var(--text-muted);margin:0}.file-input{display:none}.import-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#ef444426;color:#ef4444;border-radius:var(--radius-md);font-size:.875rem;margin-top:1rem}.import-tips{margin-top:1.5rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-md)}.import-tips h4{font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.import-tips ul{margin:0;padding-left:1.25rem}.import-tips li{font-size:.8125rem;color:var(--text-secondary);margin:.25rem 0}.preview-body{padding:0!important}.preview-summary{display:flex;gap:1rem;padding:1rem 1.5rem;background:var(--bg-tertiary);border-bottom:1px solid var(--bg-card);flex-wrap:wrap}.summary-stat{display:flex;flex-direction:column;min-width:100px}.stat-value{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.preview-table-wrapper{flex:1;overflow:auto;padding:0 1.5rem 1.5rem}.preview-table{width:100%;border-collapse:collapse;font-size:.8125rem}.preview-table th{position:sticky;top:0;background:var(--bg-card);padding:.75rem .5rem;text-align:left;font-weight:600;color:var(--text-muted);text-transform:uppercase;font-size:.6875rem;letter-spacing:.05em;border-bottom:1px solid var(--bg-tertiary);z-index:1}.preview-table td{padding:.625rem .5rem;border-bottom:1px solid var(--bg-tertiary);vertical-align:middle}.preview-table tr:hover{background:#6366f10d}.preview-table tr.selected{background:#6366f11a}.preview-table tr.refund{opacity:.7}.col-select{width:40px;text-align:center}.col-date{width:100px;white-space:nowrap}.col-desc{min-width:200px}.col-amount{width:100px;text-align:right;white-space:nowrap}.col-category{width:180px}.col-actions{width:40px;text-align:center}.desc-text{display:block;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary)}.refund-badge{display:inline-block;font-size:.625rem;padding:.125rem .375rem;background:#22c55e33;color:#22c55e;border-radius:var(--radius-sm);margin-left:.5rem;text-transform:uppercase;font-weight:600}.amount-refund{color:#22c55e}.check-all,.checked{color:var(--primary)}.category-select{width:100%;padding:.375rem .5rem;font-size:.8125rem;background:var(--bg-tertiary);border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer}.category-select:focus{outline:none;border-color:var(--primary)}.category-select.high{border-color:#22c55e80;background:#22c55e1a}.category-select.medium{border-color:#eab30880;background:#eab3081a}.category-select.user{border-color:#6366f180;background:#6366f11a}.confidence-icon{position:absolute;right:.25rem;top:50%;transform:translateY(-50%)}.confidence-icon.high{color:#22c55e}.col-category{position:relative}.importing-body{display:flex;align-items:center;justify-content:center;min-height:200px}.import-progress{width:100%;max-width:400px;text-align:center}.import-progress .progress-bar{height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden;margin-bottom:1rem}.import-progress .progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),#818cf8);border-radius:4px;transition:width .1s ease}.progress-text{font-size:.875rem;color:var(--text-secondary)}@media (max-width: 768px){.csv-import-modal{width:100vw;max-width:100vw;height:100vh;max-height:100vh;border-radius:0}.preview-summary{gap:.75rem}.summary-stat{min-width:80px}.stat-value{font-size:1rem}.col-desc{min-width:150px}.desc-text{max-width:150px}}.apply-similar-dialog{position:absolute;bottom:0;left:0;right:0;background:var(--bg-card);border-top:1px solid var(--bg-tertiary);padding:1rem 1.5rem;animation:slideUp .2s ease;z-index:10}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.apply-similar-content{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.apply-similar-text{margin:0;font-size:.875rem;color:var(--text-secondary)}.apply-similar-text strong{color:var(--primary)}.apply-similar-actions{display:flex;gap:.5rem}.category-card{padding:.625rem .75rem;background:var(--bg-tertiary);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.category-card.clickable{cursor:pointer}.category-card.clickable:hover{background:#3d4a5e;transform:translateY(-1px)}.category-card.selected{background:#6366f126;outline:2px solid var(--primary);outline-offset:-2px}.category-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.375rem}.category-info{display:flex;align-items:center;gap:.5rem}.category-icon{width:26px;height:26px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.category-icon svg{width:14px;height:14px}.category-name{display:block;font-size:.8125rem;font-weight:500;color:var(--text-primary)}.category-count{display:block;font-size:.6875rem;color:var(--text-muted)}.category-amount{text-align:right}.amount-value{display:block;font-size:.8125rem;font-weight:600;color:var(--text-primary)}.amount-percent{display:block;font-size:.6875rem;color:var(--text-muted)}.amount-budget{display:block;font-size:.75rem;color:var(--text-muted)}.amount-budget.near-budget{color:var(--warning)}.amount-budget.over-budget{color:var(--danger)}.category-card.near-budget{background:#eab3081a;border:1px solid rgba(234,179,8,.3)}.category-card.over-budget{background:#ef44441a;border:1px solid rgba(239,68,68,.3)}.amount-value.near-budget{color:var(--warning)}.amount-value.over-budget{color:var(--danger)}.progress-bar{position:relative;overflow:visible}.progress-bar-overage{position:absolute;height:100%;background:var(--danger);border-radius:0 4px 4px 0;opacity:.6}.expense-tracker{max-width:1200px;margin:0 auto}.header-actions{display:flex;align-items:center;gap:1rem}.month-selector{position:relative;display:inline-flex;align-items:center}.month-selector .form-select{padding-right:2.5rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;min-width:180px}.month-selector .select-icon{position:absolute;right:1rem;color:var(--text-muted);pointer-events:none}.expense-total-card{background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:var(--radius-lg);padding:1.5rem 2rem;margin-bottom:2rem}.expense-total-label{display:block;font-size:.875rem;color:#fffc;margin-bottom:.5rem}.expense-total-value{font-size:2rem;font-weight:700;color:#fff}.expense-total-card.future-month{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.expense-total-note{display:block;font-size:.75rem;color:#ffffffb3;margin-top:.5rem}.spending-chart-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem}.spending-chart-card .section-title{margin-bottom:1rem}.spending-chart{height:220px;position:relative}.chart-note{text-align:center;font-size:.75rem;color:var(--text-muted);margin-top:.75rem}.uncategorized-alert{background:linear-gradient(135deg,#f59e0b26,#d977061a);border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:2rem}.uncategorized-alert-header{display:flex;align-items:center;gap:.75rem;color:#f59e0b;margin-bottom:.5rem}.uncategorized-alert-title{font-size:1rem;font-weight:600}.uncategorized-alert-description{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem}.uncategorized-list{display:flex;flex-direction:column;gap:.5rem}.uncategorized-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem;background:var(--bg-tertiary);border-radius:var(--radius-md)}.uncategorized-item-info{flex:1;min-width:0}.uncategorized-item-description{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.uncategorized-item-meta{display:block;font-size:.75rem;color:var(--text-muted)}.uncategorized-category-select{padding:.5rem .75rem;background:var(--bg-secondary);border:1px solid var(--bg-tertiary);border-radius:var(--radius-md);color:var(--text-primary);font-size:.8125rem;min-width:150px;cursor:pointer}.uncategorized-category-select:focus{outline:none;border-color:var(--primary)}.uncategorized-more{text-align:center;padding:.5rem;font-size:.8125rem;color:var(--text-muted)}.uncategorized-item-actions{display:flex;align-items:center;gap:.5rem}.suggestion-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:999px;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;white-space:nowrap}.suggestion-badge.suggestion-learned{background:#22c55e26;color:#22c55e}.suggestion-badge.suggestion-vacation_mode{background:#f59e0b26;color:#f59e0b}.suggestion-badge.suggestion-claude{background:#8b5cf626;color:#8b5cf6}.suggestion-badge.suggestion-loading{background:#8b5cf61a;color:#8b5cf6;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.uncategorized-category-select.has-suggestion{border-color:#22c55e80;background:#22c55e0d}.btn-confirm-suggestion{display:flex;align-items:center;justify-content:center;padding:.375rem;background:#22c55e;color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.btn-confirm-suggestion:hover{background:#16a34a}.btn-transfer{display:flex;align-items:center;justify-content:center;padding:.375rem;background:#6b7280;color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.btn-transfer:hover{background:#4b5563}.rollover-section{margin-bottom:2rem}.rollover-section .section-title{display:flex;align-items:center;gap:.5rem}.rollover-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}.rollover-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:1rem;border:1px solid var(--bg-tertiary)}.rollover-card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--bg-tertiary)}.rollover-icon{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.rollover-name{font-size:.875rem;font-weight:600;color:var(--text-primary)}.rollover-amounts{display:flex;flex-direction:column;gap:.375rem}.rollover-row{display:flex;justify-content:space-between;align-items:center}.rollover-row.total{margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--bg-tertiary)}.rollover-label{font-size:.75rem;color:var(--text-muted)}.rollover-row.total .rollover-label{font-weight:600;color:var(--text-primary)}.rollover-value{font-size:.875rem;font-weight:500;color:var(--text-primary)}.rollover-value.positive{color:var(--success)}.rollover-value.negative{color:var(--danger)}.rollover-row.total .rollover-value{font-size:1rem;font-weight:700}.section-title{font-size:1rem;font-weight:600;color:var(--text-secondary);margin-bottom:1rem;text-transform:uppercase;letter-spacing:.05em}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-header .section-title{margin-bottom:0;display:flex;align-items:center;gap:.75rem}.filter-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .5rem .25rem .75rem;border-radius:999px;font-size:.75rem;font-weight:600;color:#fff;text-transform:none;letter-spacing:0}.filter-clear{display:flex;align-items:center;justify-content:center;background:#fff3;border:none;border-radius:50%;width:18px;height:18px;cursor:pointer;color:#fff;transition:background var(--transition-fast)}.filter-clear:hover{background:#fff6}.category-breakdown{margin-bottom:2rem}.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.5rem}.expenses-list-section{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem}.expenses-list{display:flex;flex-direction:column;gap:.25rem}.expense-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:var(--bg-tertiary);border-radius:var(--radius-sm);transition:background var(--transition-fast)}.expense-item:hover{background:#3d4a5e}.expense-icon{width:28px;height:28px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.expense-icon svg{width:14px;height:14px}.expense-details{flex:1;min-width:0;display:flex;align-items:center;gap:.5rem}.expense-description{font-size:.8125rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.expense-category{font-size:.6875rem;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.expense-meta{text-align:right;flex-shrink:0}.expense-amount{display:block;font-size:.8125rem;font-weight:600;color:var(--danger)}.expense-date{display:block;font-size:.6875rem;color:var(--text-muted)}.expense-actions{display:flex;gap:.25rem;opacity:0;transition:opacity var(--transition-fast)}.expense-item:hover .expense-actions{opacity:1}@media (max-width: 768px){.header-actions{flex-direction:column;align-items:stretch;width:100%}.page-header{flex-direction:column;align-items:stretch;gap:1rem}.expense-item{flex-wrap:wrap}.expense-actions{opacity:1;width:100%;justify-content:flex-end;margin-top:.5rem}.uncategorized-item{flex-direction:column;align-items:stretch;gap:.75rem}.uncategorized-item-info{width:100%}.uncategorized-item-description{white-space:normal;word-break:break-word;margin-bottom:.25rem}.uncategorized-item-actions{flex-wrap:wrap;gap:.5rem}.uncategorized-category-select{flex:1;min-width:0;font-size:16px}.suggestion-badge{display:none}.btn-confirm-suggestion,.btn-transfer{flex-shrink:0;width:40px;height:40px;min-width:40px}}.income-tracker{max-width:1200px;margin:0 auto}.income-total-card{background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:var(--radius-lg);padding:1.5rem 2rem;margin-bottom:2rem}.income-total-label{display:block;font-size:.875rem;color:#fffc;margin-bottom:.5rem}.income-total-value{display:block;font-size:2rem;font-weight:700;color:#fff}.income-total-average{display:block;font-size:.875rem;color:#ffffffb3;margin-top:.5rem}.income-months{display:flex;flex-direction:column;gap:1.5rem}.income-month-card{background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden}.income-month-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--bg-tertiary)}.income-month-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.income-month-total{font-size:1.125rem;font-weight:600;color:var(--success)}.income-list{padding:.25rem}.income-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.income-item:hover{background:var(--bg-tertiary)}.income-icon{width:28px;height:28px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0}.income-icon svg{width:14px;height:14px}.income-details{flex:1;min-width:0;display:flex;align-items:center;gap:.5rem}.income-description{font-size:.8125rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.income-source{font-size:.6875rem;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.income-meta{text-align:right;flex-shrink:0}.income-amount{display:block;font-size:.8125rem;font-weight:600;color:var(--success)}.income-date{display:block;font-size:.6875rem;color:var(--text-muted)}.income-actions{display:flex;gap:.25rem;opacity:0;transition:opacity var(--transition-fast)}.income-item:hover .income-actions{opacity:1}.salary-settings-card{background:var(--bg-card);border-radius:var(--radius-lg);margin-bottom:1.5rem;overflow:hidden}.salary-settings-header{padding:1rem 1.5rem;background:var(--bg-tertiary);border-bottom:1px solid var(--bg-card)}.salary-settings-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.salary-settings-header p{margin:.25rem 0 0;font-size:.8125rem;color:var(--text-muted)}.salary-settings-body{padding:1.5rem}.salary-toggle{margin-bottom:1.5rem}.toggle-label{display:flex;align-items:center;gap:.75rem;cursor:pointer}.toggle-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary)}.toggle-text{font-size:.9375rem;color:var(--text-primary)}.salary-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.salary-summary{display:flex;gap:1.5rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-md);flex-wrap:wrap}.salary-stat{display:flex;flex-direction:column;min-width:120px}.salary-stat .stat-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.salary-stat .stat-value{font-size:1.125rem;font-weight:600;color:var(--success)}.salary-settings-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--bg-tertiary);border-bottom:1px solid var(--bg-card)}.salaries-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.salary-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-md);transition:background var(--transition-fast)}.salary-item:hover{background:var(--bg-secondary)}.salary-item-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;background:var(--primary-light);color:var(--primary);flex-shrink:0}.salary-item-info{flex:1;min-width:0}.salary-item-name{display:block;font-size:.9375rem;font-weight:500;color:var(--text-primary)}.salary-item-type{display:block;font-size:.75rem;color:var(--text-muted);margin-top:.125rem}.salary-item-monthly{text-align:right;flex-shrink:0}.salary-item-monthly .monthly-label{display:block;font-size:.6875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.salary-item-monthly .monthly-value{display:block;font-size:1rem;font-weight:600;color:var(--success)}.salary-item-actions{display:flex;gap:.25rem;flex-shrink:0}.no-salaries{text-align:center;padding:2rem 1rem;color:var(--text-muted)}.no-salaries .empty-icon{color:var(--text-muted);opacity:.5;margin-bottom:.75rem}.no-salaries p{margin:0;font-size:.9375rem}.no-salaries .empty-hint{font-size:.8125rem;margin-top:.25rem;opacity:.8}.salary-modal{max-width:480px}.salary-modal .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.salary-preview{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:1rem;text-align:center;margin-bottom:1.5rem}.salary-preview .preview-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.salary-preview .preview-value{font-size:1.5rem;font-weight:700;color:var(--success)}.salary-preview .preview-yearly{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}@media (max-width: 768px){.income-item{flex-wrap:wrap}.income-actions{opacity:1;width:100%;justify-content:flex-end;margin-top:.5rem}.salary-item{flex-wrap:wrap}.salary-item-monthly{order:3;width:100%;text-align:left;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--bg-card)}.salary-item-actions{order:4}.salary-modal .form-row{grid-template-columns:1fr}.salary-settings-header{flex-direction:column;gap:1rem;align-items:flex-start}}.uncategorized-income-alert{background:linear-gradient(135deg,#22c55e26,#16a34a1a);border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:2rem}.uncategorized-income-alert .uncategorized-alert-header{display:flex;align-items:center;gap:.75rem;color:#22c55e;margin-bottom:.5rem}.uncategorized-income-alert .uncategorized-alert-title{font-size:1rem;font-weight:600}.uncategorized-income-alert .uncategorized-alert-description{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem}.uncategorized-income-alert .uncategorized-list{display:flex;flex-direction:column;gap:.5rem}.uncategorized-income-alert .uncategorized-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem;background:var(--bg-tertiary);border-radius:var(--radius-md)}.uncategorized-income-alert .uncategorized-item-info{flex:1;min-width:0}.uncategorized-income-alert .uncategorized-item-description{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.uncategorized-income-alert .uncategorized-item-meta{display:block;font-size:.75rem;color:var(--text-muted)}.uncategorized-income-alert .uncategorized-item-actions{display:flex;align-items:center;gap:.5rem}.uncategorized-income-alert .uncategorized-more{text-align:center;padding:.5rem;font-size:.8125rem;color:var(--text-muted)}.btn-confirm-income{display:flex;align-items:center;justify-content:center;padding:.375rem;background:#22c55e;color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.btn-confirm-income:hover{background:#16a34a}.goals-tracker{max-width:1200px;margin:0 auto}.goals-grid{display:grid;grid-template-columns:400px 1fr;gap:1.5rem}.emergency-fund-card,.future-goals-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem}.card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:1.5rem}.card-title-group{display:flex;align-items:flex-start;gap:.75rem}.card-icon{color:var(--success);flex-shrink:0;margin-top:.125rem}.card-icon.goals{color:var(--primary)}.card-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.card-subtitle{font-size:.8125rem;color:var(--text-muted);margin:.25rem 0 0}.target-selector{margin-bottom:1.5rem}.target-buttons{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.5rem}.target-btn{padding:.5rem .875rem;background:var(--bg-tertiary);border:2px solid transparent;border-radius:var(--radius-md);color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.target-btn:hover{border-color:var(--primary);color:var(--text-primary)}.target-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.target-value-display{display:flex;align-items:baseline;gap:.75rem;margin-bottom:1.25rem}.target-value-display .target-value{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.target-value-display .target-label{font-size:.875rem;color:var(--text-secondary)}.target-slider-container{position:relative;padding:.5rem 4px 2.75rem}.target-slider{width:100%;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-tertiary);border-radius:3px;outline:none;cursor:pointer}.target-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:22px;height:22px;background:var(--primary);border-radius:50%;cursor:pointer;box-shadow:0 2px 8px #6366f166;transition:transform .15s ease,box-shadow .15s ease;border:3px solid var(--bg-primary)}.target-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 2px 12px #6366f199}.target-slider::-moz-range-thumb{width:22px;height:22px;background:var(--primary);border:3px solid var(--bg-primary);border-radius:50%;cursor:pointer;box-shadow:0 2px 8px #6366f166}.slider-markers{position:absolute;left:10px;right:10px;top:calc(.5rem + 16px);pointer-events:none}.slider-marker{position:absolute;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:.25rem;background:none;border:none;padding:.25rem;cursor:pointer;pointer-events:auto}.slider-marker:first-child{transform:translate(0)}.slider-marker:last-child{transform:translate(-100%)}.slider-marker .marker-dot{width:6px;height:6px;background:var(--border-color);border-radius:50%;transition:all .15s ease}.slider-marker:hover .marker-dot{background:var(--primary);transform:scale(1.3)}.slider-marker.active .marker-dot{background:var(--primary);width:8px;height:8px;box-shadow:0 0 0 3px #6366f133}.slider-marker .marker-label{font-size:.625rem;font-weight:500;color:#9ca3af;text-transform:uppercase;letter-spacing:0;transition:color .15s ease;white-space:nowrap}.slider-marker:hover .marker-label{color:#d1d5db}.slider-marker.active .marker-label{color:var(--primary);font-weight:600}.thermometer-container{display:flex;gap:1.5rem}.thermometer{width:80px;flex-shrink:0}.thermometer-track{position:relative;height:300px;width:40px;margin:0 auto;background:var(--bg-tertiary);border-radius:20px;overflow:visible}.thermometer-fill{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,#22c55e,#4ade80);border-radius:20px;transition:height .5s ease}.thermometer-marker{position:absolute;left:100%;transform:translateY(50%);padding-left:.75rem;display:flex;flex-direction:column;white-space:nowrap}.thermometer-marker:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:8px;height:2px;background:var(--text-muted)}.thermometer-marker.active:before{background:var(--primary);width:12px}.thermometer-marker.reached .marker-amount{color:var(--success)}.marker-label{font-size:.6875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.02em}.marker-amount{font-size:.8125rem;font-weight:600;color:var(--text-secondary)}.thermometer-marker.active .marker-label,.thermometer-marker.active .marker-amount{color:var(--primary)}.thermometer-current{position:absolute;right:100%;transform:translateY(50%);padding-right:.75rem;text-align:right;display:flex;flex-direction:column}.thermometer-current:after{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:0;height:0;border-top:6px solid transparent;border-bottom:6px solid transparent;border-left:8px solid var(--success)}.current-label{font-size:.6875rem;color:var(--text-muted);text-transform:uppercase}.current-amount{font-size:.875rem;font-weight:700;color:var(--success)}.emergency-summary{flex:1;display:flex;flex-direction:column;gap:.75rem}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:.625rem .875rem;background:var(--bg-tertiary);border-radius:var(--radius-md)}.summary-label{font-size:.8125rem;color:var(--text-secondary)}.summary-value{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.summary-value.complete{color:var(--success)}.summary-value.negative{color:var(--danger)}.summary-item.spent{background:#ef44441a;border:1px solid rgba(239,68,68,.2)}.recovery-settings{margin-top:1.5rem;padding:1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md)}.recovery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.recovery-title{font-size:.875rem;font-weight:600;color:#ef4444}.recovery-content{padding-top:.75rem;border-top:1px solid rgba(239,68,68,.2)}.recovery-field{margin-bottom:1rem}.recovery-field .form-select{background:var(--bg-card)}.recovery-summary{display:flex;gap:1.5rem;margin-bottom:.75rem}.recovery-stat{display:flex;flex-direction:column}.recovery-stat .stat-label{font-size:.6875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.recovery-stat .stat-value{font-size:1rem;font-weight:600;color:var(--text-primary)}.recovery-stat .stat-value.negative{color:#ef4444}.recovery-hint{margin:0;font-size:.75rem;color:var(--text-muted);font-style:italic}.replenish-section{margin-top:1.5rem;padding:1rem;background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-md);text-align:center}.replenish-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:var(--radius-md);color:#fff;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.replenish-btn:hover{background:linear-gradient(135deg,#16a34a,#15803d);transform:translateY(-1px)}.replenish-hint{margin:.75rem 0 0;font-size:.75rem;color:var(--text-muted)}.empty-goals{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.empty-icon{opacity:.3;margin-bottom:1rem}.empty-hint{font-size:.8125rem;color:var(--text-muted);margin:.5rem 0 1.5rem}.goals-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.goal-item{display:flex;align-items:center;gap:.875rem;padding:.875rem 1rem;background:var(--bg-tertiary);border-radius:var(--radius-md);transition:background var(--transition-fast)}.goal-item:hover{background:#3d4a5e}.goal-icon{width:40px;height:40px;border-radius:var(--radius-md);background:#6366f126;color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.goal-info{flex:1;min-width:0}.goal-name{display:block;font-size:.9375rem;font-weight:500;color:var(--text-primary)}.goal-target{display:block;font-size:.75rem;color:var(--text-muted)}.goal-progress-section{flex:1;min-width:120px;max-width:200px}.goal-progress-bar{position:relative;height:8px;background:var(--bg-card);border-radius:4px;overflow:hidden}.goal-progress-bar .progress-projected{position:absolute;top:0;left:0;height:100%;border-radius:4px;transition:width .3s ease}.goal-progress-bar .progress-projected.on-track{background:repeating-linear-gradient(45deg,#22c55e4d,#22c55e4d 4px,#22c55e26 4px,#22c55e26 8px)}.goal-progress-bar .progress-projected.behind{background:repeating-linear-gradient(45deg,#eab3084d,#eab3084d 4px,#eab30826 4px,#eab30826 8px)}.goal-progress-bar .progress-current{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,#22c55e,#4ade80);border-radius:4px;transition:width .3s ease}.goal-progress-labels{display:flex;justify-content:space-between;margin-top:.25rem;font-size:.625rem}.goal-progress-labels .current-label{color:#22c55e}.goal-progress-labels .projected-label{color:var(--text-muted)}.goal-progress-labels .projected-label.on-track{color:#22c55e}.goal-progress-labels .projected-label.behind{color:#eab308}.goal-progress-labels .projected-label.partial{color:#f97316}.goal-amount{text-align:right;min-width:100px}.goal-value{display:block;font-size:.9375rem;font-weight:600;color:var(--text-primary)}.goal-monthly{display:block;font-size:.6875rem;color:var(--text-muted)}.goal-monthly.funded{color:#22c55e}.goal-monthly.partial{color:#f97316}.goal-monthly.unfunded{color:#ef4444}.goal-monthly-needed{display:block;font-size:.625rem;color:var(--text-muted)}.goal-actions{display:flex;gap:.25rem;opacity:0;transition:opacity var(--transition-fast)}.goal-item:hover .goal-actions{opacity:1}.goals-overview{padding-top:1.5rem;border-top:1px solid var(--bg-tertiary)}.goals-progress-bar{margin-bottom:1rem}.progress-header{display:flex;justify-content:space-between;font-size:.8125rem;color:var(--text-secondary);margin-bottom:.5rem}.progress-track{height:24px;display:flex;background:var(--bg-tertiary);border-radius:var(--radius-md);overflow:hidden}.progress-section{position:relative;height:100%}.progress-section.emergency{background:#22c55e33}.progress-section.goals{background:#6366f133}.progress-section .progress-fill{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;transition:width .5s ease}.progress-section.emergency .progress-fill{background:linear-gradient(to right,#22c55e,#4ade80)}.progress-section.goals .progress-fill{background:linear-gradient(to right,#6366f1,#818cf8)}.progress-labels{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em}.progress-labels .label{color:var(--text-muted)}.progress-labels .label.emergency{color:var(--success)}.progress-labels .label.goals{color:var(--primary)}.progress-labels .label.complete{color:var(--text-muted)}.goals-status{margin-top:1rem}.status-message{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border-radius:var(--radius-md);font-size:.875rem}.status-message.success{background:#22c55e26;color:var(--success)}.status-message.info{background:#6366f126;color:var(--text-primary)}.status-message.info svg{color:var(--primary);flex-shrink:0}.status-message.warning{background:#eab30826;color:var(--warning)}.icon-selector{display:flex;gap:.5rem;flex-wrap:wrap}.icon-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:2px solid transparent;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.icon-btn:hover{border-color:var(--primary);color:var(--primary)}.icon-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.target-date-selectors{display:flex;gap:.75rem}.target-date-selectors .form-select{flex:1}.target-date-selectors .form-select:first-child{flex:1.2}.projection-section{margin-top:1.5rem;background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem}.projection-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;flex-wrap:wrap;gap:1rem}.projection-title-group .section-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.projection-title-group .section-subtitle{font-size:.8125rem;color:var(--text-muted);margin:.25rem 0 0}.projection-actions{display:flex;gap:.5rem}.projection-actions .btn{display:flex;align-items:center;gap:.375rem}.projection-settings{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:1rem;margin-bottom:1rem}.settings-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.setting-field{display:flex;flex-direction:column;gap:.375rem}.setting-field .form-input{background:var(--bg-card)}.settings-hint{margin:.75rem 0 0;font-size:.75rem;color:var(--text-muted)}.savings-summary-bar{display:flex;gap:2rem;padding:1rem 1.5rem;background:linear-gradient(135deg,var(--bg-card) 0%,var(--bg-tertiary) 100%);border-radius:var(--radius-lg);margin-bottom:1rem;flex-wrap:wrap}.savings-summary-bar .savings-stat{display:flex;flex-direction:column;min-width:150px}.savings-summary-bar .stat-label{font-size:.6875rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.savings-summary-bar .stat-value{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.savings-summary-bar .stat-value.positive{color:#22c55e}.savings-summary-bar .stat-value.negative{color:#ef4444}.projection-scroll-container{overflow-x:auto;margin:0 -1.5rem;padding:0 1.5rem}.projection-chart-wrapper{min-width:max-content}.projection-chart{height:200px;margin-bottom:0;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.projection-grid-wrapper{min-width:max-content}.projection-grid{display:flex;gap:0;min-width:max-content}.projection-column{flex:0 0 200px;border-right:1px solid var(--bg-tertiary);display:flex;flex-direction:column}.projection-column:last-child{border-right:none}.projection-column.today{background:#6366f10d}.column-header{padding:.75rem 1rem;background:var(--bg-tertiary);text-align:center}.projection-column.today .column-header{background:var(--primary)}.year-label{font-size:.875rem;font-weight:600;color:var(--text-primary)}.projection-column.today .year-label{color:#fff}.column-section{flex:1;padding:.75rem;display:flex;flex-direction:column}.column-section.expenses{background:#ef44440d;border-bottom:1px solid var(--bg-tertiary)}.column-section.income{background:#22c55e0d}.section-label{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.5rem}.column-section.expenses .section-label{color:#ef4444}.column-section.income .section-label{color:#22c55e}.section-items{flex:1;display:flex;flex-direction:column;gap:.375rem;min-height:80px}.projection-item{display:flex;align-items:center;gap:.5rem;font-size:.75rem;padding:.25rem 0}.projection-item.empty{color:var(--text-muted);font-style:italic}.projection-item .item-icon{flex-shrink:0;opacity:.7}.projection-item.expense .item-icon{color:#ef4444}.projection-item .item-name{flex:1;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.projection-item .item-amount{font-weight:500;color:var(--text-primary);white-space:nowrap}.projection-item.income.carryover .item-name,.projection-item.income.carryover .item-amount{color:var(--text-muted);font-style:italic}.projection-item.income.custom{position:relative}.projection-item .item-actions{display:flex;gap:.125rem;opacity:0;transition:opacity var(--transition-fast)}.projection-item:hover .item-actions{opacity:1}.btn-xs{padding:.125rem;min-width:auto}.section-total{display:flex;justify-content:space-between;padding-top:.5rem;margin-top:auto;border-top:1px solid var(--bg-tertiary);font-size:.75rem;font-weight:600}.section-total span:first-child{color:var(--text-muted)}.section-total span:last-child{color:var(--text-primary)}.column-section.expenses .section-total span:last-child{color:#ef4444}.column-section.income .section-total span:last-child{color:#22c55e}.column-section.net-total{flex:0;padding:.75rem;background:var(--bg-tertiary);border-top:2px solid var(--bg-card)}.column-section.net-total.positive{background:#22c55e1a}.column-section.net-total.negative{background:#ef44441a}.section-total.net{border-top:none;padding-top:0;font-size:.875rem}.section-total.net span:first-child{font-weight:500}.section-total.net span.positive{color:#22c55e}.section-total.net span.negative{color:#ef4444}.column-difference{padding:.75rem;background:var(--bg-tertiary);text-align:center}.difference-label{display:flex;align-items:center;justify-content:center;gap:.25rem;font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.column-difference.positive .difference-label{color:#22c55e}.column-difference.negative .difference-label{color:#ef4444}.difference-value{font-size:.9375rem;font-weight:700}.column-difference.positive .difference-value{color:#22c55e}.column-difference.negative .difference-value{color:#ef4444}.goals-analysis{margin-top:1.5rem;padding:1.25rem;border-radius:var(--radius-md)}.goals-analysis.on-track{background:#22c55e1a;border:1px solid rgba(34,197,94,.3)}.goals-analysis.needs-attention{background:#ef44441a;border:1px solid rgba(239,68,68,.3)}.analysis-content{display:flex;align-items:flex-start;gap:1rem;flex-wrap:wrap}.analysis-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.analysis-icon.success{background:#22c55e33;color:#22c55e}.analysis-icon.warning{background:#ef444433;color:#ef4444}.analysis-text{flex:1;min-width:200px}.analysis-text h4{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.analysis-text p{margin:.25rem 0;font-size:.875rem;color:var(--text-secondary)}.analysis-text strong{color:var(--text-primary)}.analysis-text .shortfall{color:#ef4444}.analysis-text .total-needed{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--bg-tertiary)}.analysis-details{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;padding-top:.75rem;border-top:1px solid var(--bg-tertiary);width:100%}.detail-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.shortfall-year{font-size:.75rem;padding:.25rem .5rem;background:#ef444426;color:#ef4444;border-radius:var(--radius-sm)}.goal-modal{max-width:500px}.tracking-mode-selector{display:flex;flex-direction:column;gap:.5rem}.mode-btn{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg-tertiary);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:all var(--transition-fast)}.mode-btn:hover{border-color:var(--primary)}.mode-btn.active{border-color:var(--primary);background:#6366f11a}.mode-btn svg{color:var(--text-muted);flex-shrink:0}.mode-btn.active svg{color:var(--primary)}.mode-btn span{font-size:.9375rem;font-weight:500;color:var(--text-primary)}.mode-btn small{width:100%;font-size:.75rem;color:var(--text-muted);margin-top:.125rem}.goal-item.budget-mode .goal-progress-bar .progress-current{background:linear-gradient(90deg,#6366f1,#818cf8)}.goal-item.savings-spending-mode .goal-progress-section{max-width:300px}.dual-progress-bars{display:flex;flex-direction:column;gap:.5rem}.dual-progress-bar{position:relative}.dual-progress-bar .bar-label{font-size:.625rem;color:var(--text-muted);margin-bottom:.125rem}.dual-progress-bar .progress-track{height:6px;background:var(--bg-card);border-radius:3px;overflow:hidden}.dual-progress-bar .progress-fill{height:100%;border-radius:3px;transition:width .3s ease}.dual-progress-bar.saved .progress-fill{background:linear-gradient(90deg,#22c55e,#4ade80)}.dual-progress-bar.spent .progress-fill{background:linear-gradient(90deg,#f97316,#fb923c)}.dual-progress-bar .bar-amount{font-size:.625rem;margin-top:.125rem}.dual-progress-bar.saved .bar-amount{color:#22c55e}.dual-progress-bar.spent .bar-amount{color:#f97316}.priority-badge{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background:var(--bg-card);border-radius:50%;font-size:.75rem;font-weight:600;color:var(--text-muted);flex-shrink:0}.priority-badge.priority-1{background:#eab30833;color:#eab308}.priority-badge.priority-2{background:#9ca3af33;color:#9ca3af}.priority-badge.priority-3{background:#b4530933;color:#b45309}.goal-quick-actions{display:flex;gap:.25rem;margin-left:auto}.goal-quick-actions .btn-sm{padding:.25rem .5rem;font-size:.6875rem}.budget-remaining{display:flex;flex-direction:column;align-items:flex-end}.budget-remaining .remaining-label{font-size:.6875rem;color:var(--text-muted)}.budget-remaining .remaining-value{font-size:.9375rem;font-weight:600}.budget-remaining .remaining-value.positive{color:#22c55e}.budget-remaining .remaining-value.negative{color:#ef4444}.tracking-mode-badge{font-size:.625rem;color:var(--primary);font-weight:500}.quick-add-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.quick-add-modal{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem;width:90%;max-width:320px}.quick-add-modal h3{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.quick-add-actions{display:flex;gap:.75rem;margin-top:1.5rem;justify-content:flex-end}.tricolor-progress-container{width:100%}.tricolor-progress{position:relative;height:12px;background:var(--bg-tertiary);border-radius:6px;overflow:hidden}.tricolor-progress .tricolor-saved{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,#22c55e,#4ade80);border-radius:6px;transition:width .3s ease}.tricolor-progress .tricolor-spent{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,#ef4444,#f87171);border-radius:6px;transition:width .3s ease}.tricolor-legend{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:.375rem;font-size:.625rem}.tricolor-legend .legend-item{display:flex;align-items:center;gap:.25rem;color:var(--text-secondary)}.tricolor-legend .legend-item.saved{color:#22c55e}.tricolor-legend .legend-item.spent{color:#ef4444}.tricolor-legend .legend-item.remaining{color:var(--text-muted)}.tricolor-legend .legend-dot{width:6px;height:6px;border-radius:50%}.tricolor-legend .legend-item.saved .legend-dot{background:#22c55e}.tricolor-legend .legend-item.spent .legend-dot{background:#ef4444}.fixed-spending-display{display:flex;flex-direction:column;gap:.25rem}.fixed-balance{display:flex;flex-direction:column}.fixed-balance .balance-label{font-size:.625rem;color:var(--text-muted);text-transform:uppercase}.fixed-balance .balance-value{font-size:1rem;font-weight:700}.fixed-balance .balance-value.positive{color:#22c55e}.fixed-balance .balance-value.zero{color:var(--text-muted)}.fixed-progress-bar{height:6px;background:var(--bg-tertiary);border-radius:3px;overflow:hidden}.fixed-progress-bar .progress-fill{height:100%;background:linear-gradient(90deg,#8b5cf6,#a78bfa);border-radius:3px;transition:width .3s ease}.fixed-spent-note{font-size:.625rem;color:var(--text-muted)}.fixed-spending-amount{display:flex;flex-direction:column;align-items:flex-end;gap:.125rem}.fixed-spending-amount .goal-value{font-size:.875rem;font-weight:600;color:var(--text-primary)}.fixed-spending-amount .fixed-spending-note{font-size:.625rem;color:var(--text-muted)}.fixed-spending-amount .monthly-contribution{font-size:.625rem;color:#22c55e}.priority-badge.fixed-spending{background:#8b5cf633;color:#8b5cf6}.spend-save-net{font-size:.6875rem;color:var(--text-secondary)}.spend-save-progress-container{width:100%}.spend-save-savings-bar,.spend-save-spending-bar{margin-bottom:.375rem}.spend-save-savings-bar .bar-label,.spend-save-spending-bar .bar-label{font-size:.5625rem;color:var(--text-muted);margin-bottom:.125rem;text-transform:uppercase;letter-spacing:.03em}.spend-save-spending-bar .bar-label{color:#f97316}.spending-progress-bar{position:relative;height:6px;background:var(--bg-card);border-radius:3px;overflow:hidden}.spending-progress-bar .spending-fill{position:absolute;top:0;left:0;height:100%;background:linear-gradient(90deg,#f97316,#fb923c);border-radius:3px;transition:width .3s ease}.spend-save-legend{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.375rem;font-size:.5625rem}.spend-save-legend .legend-item{display:flex;align-items:center;gap:.25rem;color:var(--text-secondary)}.spend-save-legend .legend-item.saved{color:#22c55e}.spend-save-legend .legend-item.spent{color:#f97316}.spend-save-legend .legend-item.available{color:#3b82f6;font-weight:600}.spend-save-legend .legend-dot{width:5px;height:5px;border-radius:50%}.spend-save-legend .legend-item.saved .legend-dot{background:#22c55e}.spend-save-legend .legend-item.spent .legend-dot{background:#f97316}.recovery-indicator{display:inline-flex;margin-left:.375rem;color:#f97316}.goal-item.standard-mode .goal-icon{background:#22c55e26;color:#22c55e}.goal-item.spend-and-save-mode .goal-icon{background:#3b82f626;color:#3b82f6}.goal-item.fixed-spending-mode .goal-icon{background:#8b5cf626;color:#8b5cf6}.available-for-goals-card{background:linear-gradient(135deg,#22c55e1a,#8b5cf61a);border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1.5rem}.available-for-goals-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.available-for-goals-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.available-for-goals-amount{font-size:1.5rem;font-weight:700;color:#22c55e}.available-for-goals-breakdown{display:flex;flex-direction:column;gap:.5rem;padding-top:1rem;border-top:1px solid var(--bg-tertiary)}.breakdown-row{display:flex;justify-content:space-between;font-size:.8125rem}.breakdown-row .label{color:var(--text-secondary)}.breakdown-row .value{color:var(--text-primary);font-weight:500}.breakdown-row .value.negative{color:#ef4444}.breakdown-row.total{padding-top:.5rem;border-top:1px dashed var(--bg-tertiary);font-weight:600}.breakdown-row.total .value{color:#22c55e}.monthly-savings-section{display:flex;flex-direction:column;gap:.5rem;padding-top:1rem;margin-top:.5rem;border-top:1px solid var(--bg-tertiary)}.monthly-savings-section .breakdown-row.total .label{color:var(--text-primary)}.monthly-savings-section .breakdown-row.total .value{color:#8b5cf6}.auto-allocate-btn{width:100%;margin-top:1rem;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:linear-gradient(135deg,#8b5cf6,#6366f1);border:none;border-radius:var(--radius-md);color:#fff;font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.auto-allocate-btn:hover:not(:disabled){background:linear-gradient(135deg,#7c3aed,#4f46e5);transform:translateY(-1px)}.auto-allocate-btn:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed}.recovery-mode-banner{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#f59e0b26;border:1px solid rgba(245,158,11,.4);border-radius:var(--radius-md);margin-bottom:1rem}.recovery-mode-banner .banner-icon{color:#f59e0b;flex-shrink:0}.recovery-mode-banner .banner-content{flex:1}.recovery-mode-banner .banner-title{font-size:.875rem;font-weight:600;color:#f59e0b;margin-bottom:.25rem}.recovery-mode-banner .banner-text{font-size:.75rem;color:var(--text-secondary)}.recovery-mode-banner .banner-stat{text-align:right}.recovery-mode-banner .stat-value{font-size:1rem;font-weight:700;color:#f59e0b}.recovery-mode-banner .stat-label{font-size:.625rem;color:var(--text-muted);text-transform:uppercase}.form-hint{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.form-error{font-size:.75rem;color:var(--danger, #ef4444);margin-top:.25rem}.input-error{border-color:var(--danger, #ef4444)!important}.available-funds-info{background:linear-gradient(135deg,#22c55e1a,#3b82f61a);border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-md);padding:1rem;margin-bottom:1rem}.available-funds-header{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;font-weight:600;color:var(--text-secondary);margin-bottom:.25rem}.available-funds-amount{font-size:1.5rem;font-weight:700;color:#22c55e}.available-funds-note{font-size:.75rem;color:var(--text-muted);margin-top:.5rem;margin-bottom:0}.fund-from-goal-section{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:1rem;margin-bottom:1rem}.fund-from-goal-row{display:flex;gap:.5rem;margin-top:.5rem}.fund-from-goal-row .form-select{flex:2}.fund-amount-input{flex:1;min-width:100px}.fund-now-section{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:1rem;margin-bottom:1rem}.fund-now-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.fund-now-header .form-label{margin-bottom:0}.available-funds-badge{display:flex;align-items:center;gap:.375rem;padding:.25rem .625rem;background:#22c55e26;border-radius:var(--radius-full);color:var(--success);font-size:.8125rem;font-weight:500}.fund-now-options{display:flex;flex-direction:column;gap:.75rem}.fund-option .form-label.small{font-size:.75rem;color:var(--text-secondary);margin-bottom:.25rem}.fund-remaining-info{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-secondary);border-radius:var(--radius-sm);flex-wrap:wrap}.remaining-label{font-size:.8125rem;color:var(--text-secondary)}.remaining-amount{font-size:.875rem;font-weight:600;color:var(--text-primary)}.remaining-note{font-size:.75rem;color:var(--text-tertiary)}.fund-now-section .fund-from-goal-section{margin-top:1rem;border-top:1px solid var(--bg-secondary);background:transparent;padding:0;padding-top:1rem;margin-bottom:0}.fund-now-section .fund-from-goal-section .form-label.small{font-size:.75rem;color:var(--text-secondary);margin-bottom:.25rem}@media (max-width: 900px){.goals-grid{grid-template-columns:1fr}.thermometer-container{flex-direction:column;align-items:center}.thermometer{width:100%;max-width:300px}.thermometer-track{height:250px}}@media (max-width: 768px){.goal-item{flex-wrap:wrap}.goal-actions{opacity:1;width:100%;justify-content:flex-end;margin-top:.5rem}}.past-due-badge{display:inline-flex;align-items:center;gap:.25rem;margin-left:.5rem;padding:.125rem .5rem;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-full);font-size:.625rem;font-weight:600;color:#ef4444;text-transform:uppercase;letter-spacing:.03em}.past-due-note{color:#ef4444;font-weight:500}.goal-item.past-due-item{border-left:3px solid #ef4444}.archived-goals-section{margin-top:1.5rem;border-top:1px solid var(--bg-tertiary);padding-top:1rem}.archived-goals-toggle{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;background:var(--bg-tertiary);border:none;border-radius:var(--radius-md);color:var(--text-muted);font-size:.875rem;cursor:pointer;transition:all var(--transition-fast)}.archived-goals-toggle:hover{background:#3d4a5e;color:var(--text-secondary)}.archived-goals-toggle svg:last-child{margin-left:auto}.archived-goals-list{margin-top:.5rem;display:flex;flex-direction:column;gap:.5rem}.goal-item.archived{opacity:.7;background:var(--bg-tertiary);border-left:3px solid var(--text-muted)}.goal-item.archived:hover{opacity:1}.archived-label{display:block;font-size:.625rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.retirement-tracker{max-width:1200px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.page-header .btn{display:flex;align-items:center;gap:.5rem}.page-header .btn.active{background:var(--primary);color:#fff}.settings-panel{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem;border:1px solid var(--bg-tertiary)}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.setting-item{display:flex;flex-direction:column;gap:.5rem}.settings-note{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--bg-tertiary);font-size:.8125rem;color:var(--text-muted)}.setting-item.full-width{grid-column:1 / -1}.slider-container{display:flex;align-items:center;gap:.75rem}.slider-label{font-size:.75rem;color:var(--text-muted);min-width:2.5rem;text-align:center}.form-slider{flex:1;height:6px;border-radius:3px;background:var(--bg-tertiary);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--primary);cursor:pointer;box-shadow:0 2px 6px #3b82f666;transition:transform .15s ease}.form-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.form-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--primary);cursor:pointer;border:none;box-shadow:0 2px 6px #3b82f666}.setting-hint{font-size:.75rem;color:var(--text-muted);margin:0}.retirement-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem;margin-bottom:1.5rem}.retirement-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem}.retirement-card .card-header{margin-bottom:1.5rem}.retirement-card .card-title-group{display:flex;align-items:flex-start;gap:.75rem}.retirement-card .card-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.retirement-card .card-icon.fire{background:linear-gradient(135deg,#f97316,#ef4444);color:#fff;box-shadow:0 4px 12px #f973164d}.retirement-card .card-icon.coast{background:linear-gradient(135deg,#06b6d4,#3b82f6);color:#fff;box-shadow:0 4px 12px #06b6d44d}.retirement-card .card-icon.income{background:linear-gradient(135deg,#22c55e,#10b981);color:#fff;box-shadow:0 4px 12px #22c55e4d}.retirement-card .card-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.retirement-card .card-subtitle{font-size:.8125rem;color:var(--text-muted);margin:.25rem 0 0}.fire-number,.coast-number{text-align:center;margin-bottom:1.5rem}.fire-number .label,.coast-number .label{display:block;font-size:.8125rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.fire-number .value,.coast-number .value{display:block;font-size:2rem;font-weight:700;color:var(--text-primary)}.fire-card .fire-number .value{background:linear-gradient(135deg,#f97316,#ef4444);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.coast-card .coast-number .value{background:linear-gradient(135deg,#06b6d4,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.fire-number .explanation,.coast-number .explanation{display:block;font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.progress-section{margin-bottom:1.5rem}.progress-section .progress-header{display:flex;justify-content:space-between;font-size:.8125rem;color:var(--text-secondary);margin-bottom:.5rem}.retirement-tracker .progress-section .progress-bar{height:6px!important;background:var(--bg-tertiary)!important;border-radius:3px!important;overflow:hidden!important;position:relative}.retirement-tracker .progress-section .progress-fill{height:6px!important;border-radius:3px!important;transition:width .5s ease;position:absolute;top:0;left:0}.retirement-tracker .fire-card .progress-fill.fire-gradient{background:linear-gradient(90deg,#f97316,#ef4444)!important}.retirement-tracker .coast-card .progress-fill.coast-gradient{background:linear-gradient(90deg,#06b6d4,#3b82f6)!important}.progress-section .progress-values{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-muted);margin-top:.5rem}.result-box{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border-radius:var(--radius-md)}.result-box svg{flex-shrink:0;margin-top:.125rem}.result-box.success{background:#22c55e26;color:var(--success)}.result-box.info{background:#6366f126}.result-box.info svg{color:var(--primary)}.result-box.warning{background:#eab30826;color:var(--warning)}.result-label{display:block;font-size:.875rem;color:var(--text-secondary)}.result-box.success .result-label{color:var(--success)}.result-value{display:block;font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:.25rem 0}.result-detail{display:block;font-size:.75rem;color:var(--text-muted)}.income-projection{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:1rem;margin-bottom:1.5rem}.projection-item .label{display:block;font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.projection-item .value{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.projection-item .value.large{font-size:1.5rem;color:var(--success)}.income-divider{height:1px;background:var(--bg-card);margin:1rem 0}.projection-row{display:flex;gap:1.5rem}.projection-row .projection-item{flex:1}.income-comparison{padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-md)}.comparison-header{font-size:.8125rem;color:var(--text-secondary);margin-bottom:.75rem}.comparison-bar{position:relative;height:24px;background:#ef444433;border-radius:var(--radius-md);overflow:visible}.comparison-fill{height:100%;background:linear-gradient(90deg,#22c55e,#10b981);border-radius:var(--radius-md);transition:width .5s ease}.comparison-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:2px;height:32px;background:var(--text-muted)}.comparison-marker span{position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:.625rem;color:var(--text-muted);white-space:nowrap}.comparison-values{display:flex;justify-content:space-between;font-size:.75rem;margin-top:.5rem}.comparison-values .projected{color:var(--success)}.comparison-values .current{color:var(--text-muted)}.comparison-status{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;font-size:.8125rem}.comparison-status.success{color:var(--success)}.comparison-status.warning{color:var(--warning)}.inflation-adjusted .comparison-header{display:flex;flex-direction:column;gap:.25rem}.inflation-note{font-size:.6875rem;color:var(--text-muted);font-weight:400}.percent-of-budget{display:flex;align-items:baseline;gap:.5rem;margin-bottom:.75rem}.percent-value{font-size:2.5rem;font-weight:700;line-height:1}.percent-label{font-size:.875rem;color:var(--text-muted)}.income-comparison .comparison-bar{height:6px;border-radius:3px}.projection-timeline{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem}.timeline-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.timeline-title svg{color:var(--primary)}.timeline-subtitle{font-size:.75rem;font-weight:400;color:var(--text-muted);margin-left:auto}.timeline-table{overflow-x:auto}.timeline-header,.timeline-row{display:grid;grid-template-columns:100px 1fr 140px 130px;gap:1rem;padding:.75rem 1rem;align-items:center}.timeline-header{background:var(--bg-tertiary);border-radius:var(--radius-md);font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.timeline-row{border-bottom:1px solid var(--bg-tertiary);font-size:.875rem}.timeline-row:last-child{border-bottom:none}.timeline-row.highlight{background:#6366f11a;border-radius:var(--radius-md);border-bottom:none}.timeline-row.can-retire{color:var(--success)}.timeline-row .age{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--text-primary)}.timeline-row .badge{font-size:.625rem;padding:.125rem .375rem;background:var(--bg-tertiary);color:var(--text-muted);border-radius:var(--radius-sm);text-transform:uppercase}.timeline-row .badge.target{background:var(--primary);color:#fff}.timeline-row .portfolio{color:var(--text-primary)}.timeline-row .monthly-income{color:var(--text-secondary);font-size:.8125rem}.timeline-row .status{display:flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:500}.timeline-row .status.fire,.timeline-row .status.fire-ready{color:#f97316}.timeline-row .status.building{color:var(--text-muted)}.timeline-row .status.retired{color:#22c55e}.timeline-row .status.depleted{color:#ef4444}.timeline-row.retired{background:#22c55e0d}.timeline-row.depleted{background:#ef44441a;color:var(--text-muted)}.timeline-row .portfolio.withdrawing{color:var(--text-secondary)}@media (max-width: 900px){.retirement-grid{grid-template-columns:1fr}.timeline-header,.timeline-row{grid-template-columns:70px 1fr 100px 100px;gap:.5rem;font-size:.8125rem}}@media (max-width: 600px){.settings-grid{grid-template-columns:1fr 1fr}.projection-row{flex-direction:column;gap:1rem}.timeline-header,.timeline-row{grid-template-columns:60px 1fr 90px}.timeline-header span:nth-child(4),.timeline-row .status{display:none}}.networth-tracker{max-width:1200px;margin:0 auto}.networth-summary{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.networth-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem;display:flex;align-items:center;gap:1rem}.networth-card.main{background:linear-gradient(135deg,#6366f1,#4f46e5)}.networth-card.main .networth-label,.networth-card.main .networth-value{color:#fff}.networth-card.main .networth-icon{color:#ffffffe6}.networth-breakdown{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.networth-icon{flex-shrink:0}.networth-icon.positive{color:var(--success)}.networth-icon.negative{color:var(--danger)}.networth-label{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}.networth-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.networth-value.small{font-size:1.25rem}.networth-value.positive{color:var(--success)}.networth-value.negative,.networth-value.liability{color:var(--danger)}.asset-breakdown-section{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem}.asset-breakdown-section .section-header{margin-bottom:1rem}.asset-breakdown-section .section-title{display:flex;align-items:center;gap:.5rem}.breakdown-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-bottom:1.5rem}.breakdown-card{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:1rem;display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto auto;gap:.5rem .75rem;align-items:center}.breakdown-card.highlight{background:#8b5cf61a;border:1px solid rgba(139,92,246,.3)}.breakdown-icon{width:40px;height:40px;border-radius:var(--radius-md);background:#6366f126;color:var(--primary);display:flex;align-items:center;justify-content:center;grid-row:span 2}.breakdown-card.highlight .breakdown-icon{background:#8b5cf633;color:#8b5cf6}.breakdown-info{display:flex;flex-direction:column}.breakdown-name{font-size:.875rem;font-weight:500;color:var(--text-primary)}.breakdown-value{font-size:1.125rem;font-weight:700;color:var(--text-primary)}.breakdown-percent{text-align:right;display:flex;flex-direction:column}.percent-value{font-size:1.25rem;font-weight:700;color:var(--primary)}.breakdown-card.highlight .percent-value{color:#8b5cf6}.percent-label{font-size:.6875rem;color:var(--text-muted);text-transform:uppercase}.breakdown-bar{grid-column:2 / 4;height:6px;background:var(--bg-secondary);border-radius:3px;overflow:hidden}.breakdown-bar-fill{height:100%;background:var(--primary);border-radius:3px;transition:width .3s ease}.breakdown-card.highlight .breakdown-bar-fill{background:#8b5cf6}.retirement-summary{background:linear-gradient(135deg,#8b5cf626,#7c3aed1a);border:1px solid rgba(139,92,246,.3);border-radius:var(--radius-lg);padding:1.25rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}.retirement-stat{display:flex;flex-direction:column}.retirement-label{font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}.retirement-value{font-size:1.5rem;font-weight:700;color:#8b5cf6}.retirement-percentages{display:flex;gap:2rem}.retirement-pct{display:flex;flex-direction:column;align-items:center;padding:.5rem 1rem;background:#8b5cf61a;border-radius:var(--radius-md)}.pct-value{font-size:1.25rem;font-weight:700;color:#8b5cf6}.pct-label{font-size:.6875rem;color:var(--text-muted);text-transform:uppercase}.networth-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;align-items:start}.networth-section{background:var(--bg-card);border-radius:var(--radius-lg);padding:1rem}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.section-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0;text-transform:none;letter-spacing:normal}.btn-sm{padding:.5rem 1rem;font-size:.8125rem}.account-group{margin-bottom:.75rem}.account-group:last-child{margin-bottom:0}.account-group-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;background:var(--bg-tertiary);border-radius:var(--radius-sm);margin-bottom:.25rem}.account-group-title{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.account-group-total{font-size:.8125rem;font-weight:600;color:var(--success)}.account-group-total.liability{color:var(--danger)}.account-group-title-with-icon{display:flex;align-items:center;gap:.5rem}.group-icon{color:var(--text-tertiary)}.group-icon.liability{color:var(--danger);opacity:.7}.liability-total-summary{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);margin-top:1rem}.liability-total-summary .total-label{font-size:.875rem;font-weight:600;color:var(--text-primary)}.liability-total-summary .total-value{font-size:1rem;font-weight:700}.liability-total-summary .total-value.liability{color:var(--danger)}.account-list{display:flex;flex-direction:column;gap:.25rem}.account-item{display:flex;align-items:center;gap:.5rem;padding:.375rem .625rem;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.account-item:hover{background:var(--bg-tertiary)}.account-icon{width:26px;height:26px;border-radius:var(--radius-sm);background:#6366f126;color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.account-icon svg{width:14px;height:14px}.account-icon.liability{background:#ef444426;color:var(--danger)}.account-details{flex:1;min-width:0;display:flex;align-items:center;gap:.5rem}.account-name{font-size:.8125rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.account-type{font-size:.6875rem;color:var(--text-muted);white-space:nowrap}.account-value{font-size:.8125rem;font-weight:600;color:var(--text-primary);flex-shrink:0}.account-value.liability{color:var(--danger)}.account-actions{display:flex;gap:.25rem;opacity:0;transition:opacity var(--transition-fast)}.account-item:hover .account-actions{opacity:1}.empty-state-small{text-align:center;padding:2rem 1rem;color:var(--text-secondary)}.empty-state-small p{margin-bottom:1rem}.checkbox-label{display:flex;align-items:center;gap:.75rem;cursor:pointer}.checkbox-input{width:18px;height:18px;accent-color:var(--primary)}.checkbox-text{font-size:.875rem;color:var(--text-secondary)}.retirement-breakdown-section{margin-top:2rem;background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem}.retirement-breakdown-section .section-header{margin-bottom:1.5rem}.retirement-breakdown-section .section-title{display:flex;align-items:center;gap:.5rem}.breakdown-grid-full{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.breakdown-panel{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:1.25rem}.breakdown-panel-title{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.breakdown-bars{display:flex;flex-direction:column;gap:.75rem}.breakdown-bar-item{display:flex;flex-direction:column;gap:.25rem}.bar-header{display:flex;justify-content:space-between;align-items:center}.bar-label{font-size:.8125rem;color:var(--text-primary)}.bar-value{font-size:.8125rem;font-weight:600;color:var(--text-primary)}.bar-track{height:8px;background:var(--bg-secondary);border-radius:4px;overflow:hidden}.bar-fill{height:100%;border-radius:4px;transition:width .3s ease}.bar-fill.roth{background:linear-gradient(90deg,#22c55e,#4ade80)}.bar-fill.traditional{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.bar-percent{font-size:.6875rem;color:var(--text-muted)}.dual-bar-display{display:flex;flex-direction:column;gap:.75rem}.dual-bar{display:flex;height:24px;background:var(--bg-secondary);border-radius:12px;overflow:hidden}.dual-bar-fill{height:100%;transition:width .3s ease}.dual-bar-fill.stocks{background:linear-gradient(90deg,#22c55e,#4ade80)}.dual-bar-fill.bonds{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.dual-bar-fill.us{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.dual-bar-fill.international{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.dual-bar-fill.tech{background:linear-gradient(90deg,#06b6d4,#22d3ee)}.dual-bar-fill.non-tech{background:linear-gradient(90deg,#6b7280,#9ca3af)}.dual-bar-legend{display:flex;flex-direction:column;gap:.75rem}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-dot.stocks{background:#22c55e}.legend-dot.bonds{background:#f59e0b}.legend-dot.us{background:#3b82f6}.legend-dot.international{background:#8b5cf6}.legend-dot.tech{background:#06b6d4}.legend-dot.non-tech{background:#6b7280}.legend-label{font-size:.8125rem;color:var(--text-secondary);min-width:80px}.legend-value{font-size:.8125rem;font-weight:600;color:var(--text-primary)}.legend-pct{font-size:.75rem;color:var(--text-muted)}.legend-group{display:flex;flex-direction:column;gap:.25rem}.fund-list{display:flex;flex-direction:column;gap:.125rem;padding-left:1.25rem;margin-top:.125rem}.fund-item{display:flex;justify-content:space-between;align-items:center;font-size:.6875rem;color:var(--text-muted)}.fund-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-right:.5rem}.fund-value{flex-shrink:0;font-weight:500}.available-for-goals-summary{margin-top:1.5rem;padding:1.25rem;background:linear-gradient(135deg,#22c55e14,#8b5cf614);border:1px solid rgba(34,197,94,.2);border-radius:var(--radius-lg)}.available-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.available-label{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.available-value{font-size:1.25rem;font-weight:700;color:#22c55e}.available-formula{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.75rem;color:var(--text-muted)}.available-formula span{white-space:nowrap}@media (max-width: 1024px){.networth-grid,.breakdown-grid-full{grid-template-columns:1fr}}@media (max-width: 768px){.networth-breakdown{grid-template-columns:1fr}.account-item{flex-wrap:wrap}.account-actions{opacity:1;width:100%;justify-content:flex-end;margin-top:.5rem}.breakdown-grid{grid-template-columns:1fr}.retirement-summary{flex-direction:column;align-items:stretch;text-align:center}.retirement-percentages{justify-content:center}}.simplefin-settings{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem}.simplefin-header{margin-bottom:1.25rem}.simplefin-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.simplefin-title{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.simplefin-description{font-size:.875rem;color:var(--text-secondary);margin:0}.simplefin-help{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:1rem;margin-bottom:1rem}.simplefin-help h3{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin:0 0 .75rem}.simplefin-help ol{margin:0;padding-left:1.25rem;font-size:.875rem;color:var(--text-secondary)}.simplefin-help li{margin-bottom:.5rem}.simplefin-help a{color:var(--primary);text-decoration:none;display:inline-flex;align-items:center;gap:.25rem}.simplefin-help a:hover{text-decoration:underline}.simplefin-help-note{font-size:.8125rem;color:var(--text-muted);margin:.75rem 0 0;padding-top:.75rem;border-top:1px solid var(--bg-secondary)}.simplefin-alert{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;border-radius:var(--radius-md);margin-bottom:1rem;font-size:.875rem}.simplefin-alert.error{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.simplefin-alert.success{background:#22c55e1a;color:#22c55e;border:1px solid rgba(34,197,94,.2)}.simplefin-alert span{flex:1}.simplefin-alert svg:first-child{flex-shrink:0;margin-top:.125rem}.simplefin-connect{display:flex;flex-direction:column;gap:1rem}.simplefin-token-input{font-family:monospace;font-size:.8125rem;resize:vertical;min-height:80px}.simplefin-connected{display:flex;flex-direction:column;gap:1rem}.simplefin-status{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:999px;font-size:.8125rem;font-weight:600}.status-badge.connected{background:#22c55e26;color:#22c55e}.last-sync{font-size:.8125rem;color:var(--text-muted)}.simplefin-actions{display:flex;gap:.75rem;flex-wrap:wrap}.btn-danger{color:#ef4444}.btn-danger:hover{background:#ef44441a}.simplefin-import-info{background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-md);padding:.875rem 1rem}.simplefin-import-info p{margin:0;font-size:.8125rem;color:var(--text-secondary);line-height:1.5}.simplefin-import-info strong{color:var(--text-primary)}.simplefin-accounts{background:var(--bg-tertiary);border-radius:var(--radius-md);overflow:hidden}.accounts-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.875rem 1rem;background:transparent;border:none;color:var(--text-primary);font-size:.875rem;font-weight:600;cursor:pointer;transition:background var(--transition-fast)}.accounts-header:hover{background:var(--bg-secondary)}.accounts-header span{display:flex;align-items:center;gap:.5rem}.accounts-list{border-top:1px solid var(--bg-secondary);padding:.5rem}.account-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:var(--radius-md);transition:background var(--transition-fast)}.account-item:hover{background:var(--bg-secondary)}.account-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#6366f126;color:var(--primary);border-radius:var(--radius-md);flex-shrink:0}.account-info{flex:1;min-width:0}.account-name{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.account-institution{display:block;font-size:.75rem;color:var(--text-muted)}.account-balance{text-align:right;flex-shrink:0}.balance-amount{display:block;font-size:.9375rem;font-weight:600}.balance-amount.positive{color:var(--text-primary)}.balance-amount.negative{color:#ef4444}.balance-date{display:block;font-size:.6875rem;color:var(--text-muted)}@media (max-width: 768px){.simplefin-settings{padding:1rem}.simplefin-actions{flex-direction:column}.simplefin-actions .btn{width:100%;justify-content:center}.account-item{flex-wrap:wrap}.account-balance{width:100%;text-align:left;margin-top:.5rem;padding-left:calc(36px + .75rem)}}.settings-page{max-width:800px;margin:0 auto}.settings-page .page-title{display:flex;align-items:center;gap:.5rem}.settings-section{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem}.settings-section-title{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0 0 1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--bg-tertiary)}.settings-actions{display:flex;flex-direction:column;gap:1rem}.settings-action{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-md);gap:1rem}.settings-action.danger{border:1px solid rgba(239,68,68,.3)}.action-info{flex:1}.action-info h3{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin:0 0 .25rem}.action-info p{font-size:.8125rem;color:var(--text-secondary);margin:0}.confirm-buttons{display:flex;gap:.5rem}.btn-danger{background:#ef4444;color:#fff}.btn-ghost.btn-danger{background:transparent;color:#ef4444}.btn-ghost.btn-danger:hover{background:#ef44441a}.about-info{font-size:.875rem;color:var(--text-secondary)}.about-info p{margin:0 0 .5rem}.about-info strong{color:var(--text-primary)}.about-links{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--bg-tertiary)}.about-links a{color:var(--primary);text-decoration:none}.about-links a:hover{text-decoration:underline}.toggle-switch{position:relative;display:inline-block;width:48px;height:26px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--bg-tertiary);transition:.3s;border-radius:26px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:var(--primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}.vacation-ranges{padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-md)}.vacation-ranges-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0 0 .75rem}.vacation-empty{font-size:.8125rem;color:var(--text-secondary);font-style:italic;margin:0 0 1rem}.vacation-range-item{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px solid var(--bg-secondary)}.vacation-range-item:last-of-type{border-bottom:none}.vacation-range-name{font-weight:500;color:var(--text-primary);min-width:100px}.vacation-range-dates{flex:1;font-size:.8125rem;color:var(--text-secondary)}.vacation-add-form{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--bg-secondary);flex-wrap:wrap}.vacation-name-input{flex:1;min-width:120px}.vacation-date-input{width:140px}.vacation-date-separator{color:var(--text-secondary);font-size:.875rem}.api-key-input-group{display:flex;align-items:center;gap:.5rem}.api-key-input-wrapper{position:relative;display:flex;align-items:center}.api-key-input{width:200px;padding-right:2.5rem}.api-key-toggle{position:absolute;right:.25rem}.usage-bar{height:6px;background:var(--bg-secondary);border-radius:3px;margin-top:.5rem;overflow:hidden}.usage-bar-fill{height:100%;background:var(--primary);border-radius:3px;transition:width .3s ease}.learning-actions{display:flex;gap:.5rem}.api-key-configured{display:flex;align-items:center;gap:.5rem}.status-badge{display:inline-flex;align-items:center;padding:.25rem .5rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-transform:uppercase}.status-badge.success{background:#22c55e26;color:#22c55e}.import-toast{position:fixed;bottom:2rem;right:2rem;display:flex;align-items:flex-start;gap:.75rem;background:var(--bg-card);border:1px solid var(--success);border-radius:var(--radius-lg);padding:1rem 1.25rem;box-shadow:0 4px 20px #0000004d;z-index:1000;animation:slideIn .3s ease;max-width:400px}.import-toast svg{color:var(--success);flex-shrink:0;margin-top:.125rem}.import-toast strong{display:block;color:var(--text-primary);margin-bottom:.25rem}.import-toast p{margin:0;font-size:.875rem;color:var(--text-secondary)}.import-toast-hint{margin-top:.5rem!important;font-size:.8125rem!important;color:var(--text-muted)!important}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.settings-action{flex-direction:column;align-items:flex-start}.settings-action .btn{width:100%;justify-content:center}.confirm-buttons{width:100%;flex-direction:column}.vacation-add-form{flex-direction:column;align-items:stretch}.vacation-name-input,.vacation-date-input{width:100%}.vacation-date-separator{text-align:center}.api-key-input-group{flex-direction:column;align-items:stretch;width:100%;gap:.75rem}.api-key-input-wrapper{width:100%}.api-key-input{width:100%;padding-right:3rem;font-size:16px}.api-key-toggle{right:.5rem;width:36px;height:36px;min-width:36px}.learning-actions{width:100%}.learning-actions .btn{flex:1;justify-content:center}}.welcome-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.welcome-modal{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-primary) 100%);border-radius:var(--radius-xl);padding:2.5rem;max-width:420px;width:100%;text-align:center;position:relative;border:1px solid var(--bg-tertiary);box-shadow:0 25px 50px -12px #00000080;animation:slideUp .3s ease}.welcome-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:var(--text-muted);cursor:pointer;padding:.5rem;border-radius:var(--radius-md);transition:all var(--transition-fast)}.welcome-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.welcome-icon{width:64px;height:64px;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-light) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;color:#fff}.welcome-title{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:1rem}.welcome-message{color:var(--text-secondary);font-size:1rem;line-height:1.6;margin-bottom:1rem}.welcome-tip{color:var(--text-secondary);font-size:.9375rem;line-height:1.6;margin-bottom:1.5rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-md)}.welcome-tip strong{color:var(--primary-light)}.welcome-btn{width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:600}.auto-fetch-notification{position:fixed;bottom:1.5rem;right:1.5rem;display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;border-radius:var(--radius-lg);font-size:.875rem;font-weight:500;box-shadow:0 10px 25px #0000004d;z-index:1000;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auto-fetch-notification.fetching{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--bg-tertiary)}.auto-fetch-notification.success{background:linear-gradient(135deg,#22c55e26,#16a34a26);color:#22c55e;border:1px solid rgba(34,197,94,.3)}.auto-fetch-notification.error{background:linear-gradient(135deg,#ef444426,#dc262626);color:#ef4444;border:1px solid rgba(239,68,68,.3)}.auto-fetch-notification .spin{animation:spin 1s linear infinite}.notification-close{background:transparent;border:none;color:inherit;opacity:.7;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;margin-left:.5rem;transition:opacity .2s}.notification-close:hover{opacity:1}.auth-modal{max-width:420px}.auth-header-content{display:flex;align-items:center;gap:.75rem}.auth-icon{color:var(--primary)}.auth-description{font-size:.875rem;color:var(--text-secondary);line-height:1.6;margin-bottom:1.5rem}.auth-modal .form-label{display:flex;align-items:center;gap:.5rem}.auth-modal .form-label svg{color:var(--text-muted)}.auth-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:var(--danger);font-size:.875rem;margin-top:1rem}.security-note{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#22c55e1a;border:1px solid rgba(34,197,94,.2);border-radius:var(--radius-md);color:var(--success);font-size:.8125rem;margin-top:1rem}.auth-modal .modal-footer{flex-direction:column;gap:.75rem}.auth-modal .modal-footer .btn-link{font-size:.8125rem;color:var(--text-secondary)}.auth-modal .modal-footer .btn-link:hover{color:var(--primary)}.auth-modal .modal-footer .btn-primary{width:100%}.app{display:flex;min-height:100vh}.main-content{flex:1;margin-left:250px;padding:2rem;min-height:100vh;overflow-x:auto;min-width:0}.card{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow-md)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.card-title{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.card-subtitle{font-size:.875rem;color:var(--text-secondary)}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.summary-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem;display:flex;flex-direction:column;gap:.5rem}.summary-card-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:.5rem}.summary-card-label{font-size:.875rem;color:var(--text-secondary)}.summary-card-value{font-size:1.75rem;font-weight:700;color:var(--text-primary)}.summary-card-change{font-size:.875rem;display:flex;align-items:center;gap:.25rem}.summary-card-change.positive{color:var(--success)}.summary-card-change.negative{color:var(--danger)}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;margin-bottom:2rem}.chart-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:1.5rem}.chart-container{height:300px;position:relative}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;transition:all var(--transition-fast)}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary)}.btn-secondary:hover{background:var(--text-muted)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-icon{padding:.5rem;border-radius:var(--radius-md)}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:.5rem}.form-input,.form-select{width:100%;padding:.75rem 1rem;background:var(--bg-tertiary);border:1px solid transparent;border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;transition:all var(--transition-fast)}.form-input:focus,.form-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f133}.form-input::placeholder{color:var(--text-muted)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:var(--bg-secondary);border-radius:var(--radius-xl);width:100%;max-width:480px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--bg-tertiary)}.modal-title{font-size:1.25rem;font-weight:600}.modal-body{padding:1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--bg-tertiary)}.convert-section{margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--bg-tertiary)}.convert-toggle{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.875rem;padding:.5rem;width:100%;justify-content:center;background:transparent;border:none;cursor:pointer;transition:color var(--transition-fast)}.convert-toggle:hover{color:var(--text-primary)}.convert-panel{background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);padding:1rem}.convert-title{font-size:.9375rem;font-weight:600;color:var(--danger);margin:0 0 .5rem}.convert-description{font-size:.8125rem;color:var(--text-secondary);margin:0 0 1rem}.convert-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}.apply-similar-prompt{text-align:center;padding:1rem 0}.apply-similar-prompt p{margin:.5rem 0;color:var(--text-secondary)}.apply-similar-prompt p:first-child{font-size:1rem;color:var(--text-primary)}.similar-list{margin:1rem 0;padding:.75rem;background:var(--bg-tertiary);border-radius:var(--radius-md);max-height:150px;overflow-y:auto}.similar-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--bg-card);font-size:.875rem}.similar-item:last-child{border-bottom:none}.similar-item span:first-child{color:var(--text-primary);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.similar-item span:last-child{color:var(--text-muted)}.similar-more{text-align:center;padding:.5rem;color:var(--text-muted);font-size:.8125rem}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--bg-tertiary)}.table th{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg-secondary)}.table td{font-size:.875rem;color:var(--text-primary)}.table tr:hover td{background:var(--bg-tertiary)}.category-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.progress-bar{height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:4px;transition:width var(--transition-normal)}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.empty-state-icon{margin-bottom:1rem;opacity:.5}.empty-state-title{font-size:1.125rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.empty-state-description{font-size:.875rem;margin-bottom:1.5rem}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem}.page-title{font-size:1.5rem;font-weight:700}.btn-zillow,.btn-zillow-link{flex-shrink:0;padding:.5rem}.form-error{color:var(--danger);font-size:.75rem;margin-top:.25rem}.form-hint{color:var(--text-muted);font-size:.75rem;margin-top:.25rem}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.main-content{margin-left:0;padding:4rem 1rem 1rem}.charts-grid,.summary-grid{grid-template-columns:1fr}}.retirement-breakdown-section{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--bg-tertiary)}.breakdown-title{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.zillow-input-group{display:flex;gap:.5rem}.zillow-input-group .form-input{flex:1}.btn-zillow{flex-shrink:0;padding:.5rem .75rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.holdings-section{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--bg-tertiary)}.holdings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.holdings-title{font-size:.875rem;font-weight:600;color:var(--text-primary);margin:0}.holdings-list{display:flex;flex-direction:column;gap:.75rem}.holding-item{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:.75rem}.holding-main{display:flex;gap:.5rem;align-items:center;margin-bottom:.5rem}.holding-name{flex:1;min-width:0}.holding-value{width:100px;flex-shrink:0}.holding-type{display:flex;flex-direction:column;gap:.5rem}.holding-type .form-select-sm{padding:.375rem .5rem;font-size:.75rem}.holding-custom-pcts{display:flex;gap:.75rem;flex-wrap:wrap}.pct-group{display:flex;align-items:center;gap:.25rem}.pct-group label{font-size:.6875rem;color:var(--text-muted)}.form-input-xs{width:50px;padding:.25rem .375rem;font-size:.75rem}.holdings-total{display:flex;justify-content:space-between;align-items:center;margin-top:.75rem;padding-top:.5rem;border-top:1px dashed var(--bg-tertiary);font-size:.8125rem;color:var(--text-secondary)}.holdings-total .mismatch{color:var(--warning)}.holdings-total .mismatch-note{font-size:.6875rem}.holdings-empty{font-size:.8125rem;color:var(--text-muted);text-align:center;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-md)}.fallback-title{font-size:.8125rem;font-weight:500;color:var(--text-secondary);margin:1rem 0 .75rem}:root{--primary: #6366f1;--primary-dark: #4f46e5;--primary-light: #818cf8;--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-card: #1e293b;--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-muted: #64748b;--category-mortgage: #3b82f6;--category-food: #f97316;--category-transport: #22c55e;--category-utilities: #eab308;--category-entertainment: #a855f7;--category-shopping: #ec4899;--category-healthcare: #ef4444;--category-subscriptions: #14b8a6;--category-other: #6b7280;--success: #22c55e;--warning: #eab308;--danger: #ef4444;--info: #3b82f6;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--transition-fast: .15s ease;--transition-normal: .25s ease}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh}#root{min-height:100vh}button{cursor:pointer;border:none;font-family:inherit}input,select,textarea{font-family:inherit}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}
