body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.top-navigation{background:var(--color1);border-bottom:2px solid var(--color2);box-shadow:0 2px 4px var(--shadow-color);height:60px;left:0;position:fixed;right:0;top:0;z-index:1000}.nav-container{align-items:center;display:flex;height:100%;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 20px}.nav-left{flex-direction:column;gap:.1rem}.nav-brand,.nav-left{color:#fff;display:flex}.nav-brand{align-items:center;font-size:1.5rem;font-weight:700;gap:12px;text-decoration:none;transition:color .3s ease}.nav-logo{margin-right:4px}.nav-brand:hover{color:#fffc}.nav-link{border-radius:6px;color:var(--text-dark);font-weight:500;padding:.5rem 1rem;text-decoration:none;transition:all .3s ease}.nav-link:hover{background:var(--color4);color:#fff}.nav-link.active{background:var(--color1);color:#fff}.nav-right{justify-content:flex-end}.nav-right,.user-section{align-items:center;display:flex}.user-section{gap:1rem}.logout-btn,.user-name{color:#fff;font-weight:500}.logout-btn{background:var(--color1);border:none;border-radius:6px;cursor:pointer;padding:.5rem 1rem;transition:background .3s ease}.logout-btn:hover{background:var(--color2)}.login-section{align-items:center;display:flex}.login-btn{transition:background .3s ease}.login-btn:hover{background:var(--color2)}@media (max-width:768px){.nav-container{padding:0 15px}.brand-text{font-size:1.2rem}.nav-link{font-size:.9rem;padding:.4rem .8rem}.user-name{display:none}}.larry-landing-page{background:linear-gradient(135deg,var(--color1) 0,var(--color5) 100%);color:var(--text-light);display:flex;flex-direction:column;min-height:100vh}.hero-section{align-items:center;display:flex;flex:1 1;justify-content:center;padding:2rem;text-align:center}.hero-content{max-width:800px}.hero-content h1{font-size:3.5rem;font-weight:700;margin-bottom:1rem;text-shadow:0 2px 4px #0000004d}.hero-content p{font-size:1.5rem;margin-bottom:3rem;opacity:.9}.cta-section{margin-top:2rem}.cta-text{font-size:1.2rem;margin:0 auto 2rem;max-width:600px;opacity:.9}.tool-access-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.tool-access-btn{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid #ffffff4d;border-radius:8px;display:inline-flex;font-size:1.1rem;font-weight:600;gap:.5rem;padding:1rem 2rem;text-decoration:none;transition:all .3s ease}.tool-access-btn:hover{border-color:#fff9;text-decoration:none;transform:translateY(-2px)}.primary-btn{background:#f06543e6;color:#fff;font-size:1.3rem;padding:1.5rem 3rem}.primary-btn:hover{background:#f06543;box-shadow:0 8px 25px #f065434d;transform:translateY(-3px)}@media (max-width:768px){.hero-content h1{font-size:2.5rem}.hero-content p{font-size:1.2rem}.hero-features{gap:1rem;grid-template-columns:repeat(2,1fr)}.feature{padding:1rem}.feature-icon{font-size:2rem}}.larry-dashboard{background:#f8f9fa;min-height:100vh}.dashboard-header{background:#fff;border-bottom:1px solid #e9ecef;box-shadow:0 2px 4px #0000001a;padding:1rem 0}.header-content{max-width:1200px}.header-left p{margin:.25rem 0 0}.dashboard-main{margin:0 auto;max-width:1200px;padding:2rem}.dashboard-content{display:flex;flex-direction:column;gap:3rem}.welcome-section{margin-bottom:2rem;text-align:center}.welcome-section h2{color:#333;font-size:2.5rem;font-weight:700;margin-bottom:1rem}.welcome-section p{color:#6c757d;font-size:1.2rem;margin:0 auto;max-width:600px}.tools-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:3rem}.tool-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;padding:2rem;transition:transform .3s ease,box-shadow .3s ease}.tool-card:hover:not(.coming-soon){box-shadow:0 8px 25px #00000026;transform:translateY(-5px)}.tool-card.coming-soon{background:var(--color2);border-color:var(--color3);opacity:.6}.tool-icon{align-items:center;border-radius:12px;display:flex;font-size:2rem;height:60px;justify-content:center;margin-bottom:1.5rem;width:60px}.tool-content h3{color:#333;font-size:1.5rem;font-weight:700;margin-bottom:.5rem}.tool-content p{color:#6c757d;line-height:1.6;margin-bottom:1.5rem}.tool-link{align-self:flex-start;background:var(--color1);border-radius:8px;color:#fff;display:inline-block;font-weight:600;padding:.75rem 1.5rem;text-decoration:none;transition:background .3s ease}.tool-link:hover{background:var(--color5)}.coming-soon-badge{background:var(--color4);border-radius:20px;color:#fff;display:inline-block;font-size:.875rem;font-weight:600;padding:.5rem 1rem}.quick-actions{margin-top:2rem}.quick-actions h3{color:#333;font-size:1.8rem;font-weight:700;margin-bottom:1.5rem;text-align:center}.actions-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.action-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 4px #0000001a;padding:1.5rem;text-align:center}.action-card h4{color:#333;font-size:1.2rem;font-weight:600;margin-bottom:.5rem}.action-card p{color:#6c757d;font-size:.9rem;margin-bottom:1rem}.action-btn{background:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:600;padding:.5rem 1rem;transition:background .3s ease}.action-btn:hover{background:#5a6268}@media (max-width:768px){.header-content{flex-direction:column;gap:1rem;padding:0 1rem;text-align:center}.header-left h1{font-size:1.5rem}.dashboard-main{padding:1rem}.welcome-section h2{font-size:2rem}.tools-grid{gap:1rem;grid-template-columns:1fr}.tool-card{padding:1.5rem}.actions-grid{grid-template-columns:1fr}}.advanced-retirement-planner{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0 auto;max-width:1400px;padding:20px}.planner-header{background:linear-gradient(135deg,#1a1a1a,#2d2d2d);border-radius:10px;margin-bottom:2rem;padding:2rem;text-align:center}.planner-header h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#dc3545,#fd7e14);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:700;margin:0 0 .5rem}.planner-header p{font-size:1.1rem;margin:0;opacity:.9}.test-scenario-indicator{background:linear-gradient(135deg,#6f42c1,#5a32a3);border-radius:8px;box-shadow:0 4px 15px #6f42c14d;color:#fff;display:inline-block;font-size:1rem;font-weight:600;margin-top:1rem;padding:.75rem 1.5rem}.planner-container{display:flex;gap:30px;min-height:600px}.sidebar{background:#f8f9fa;border-radius:10px;box-shadow:0 2px 4px #0000001a;height:fit-content;padding:20px;position:sticky;top:20px;width:280px}.sidebar h3{border-bottom:2px solid #dc2626;color:#333;font-size:1.3rem;margin:0 0 20px;padding-bottom:10px}.section-nav{display:flex;flex-direction:column;gap:8px;margin-bottom:30px}.nav-button{background:#fff;border:none;border-left:4px solid #0000;border-radius:8px;color:#555;cursor:pointer;font-size:.95rem;padding:12px 16px;text-align:left;transition:all .3s ease}.nav-button:hover{background:#fef2f2;color:#dc2626;transform:translateX(5px)}.nav-button.active{background:#dc2626;border-left-color:#991b1b;box-shadow:0 2px 4px #dc26264d;color:#fff}.action-buttons{display:flex;flex-direction:column;gap:10px}.run-simulation-btn{background:linear-gradient(135deg,#dc2626,#991b1b);border:none;border-radius:8px;box-shadow:0 2px 4px #dc26264d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:15px 20px;transition:all .3s ease}.run-simulation-btn:hover:not(:disabled){box-shadow:0 4px 8px #dc262666;transform:translateY(-2px)}.run-simulation-btn:disabled{background:#ccc;box-shadow:none;cursor:not-allowed;transform:none}.main-content{background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;flex:1 1;padding:30px}.form-container{margin-bottom:30px}.form-section{animation:fadeIn .3s ease-in}.form-section h3{border-bottom:2px solid #dc2626;color:#333;font-size:1.5rem;margin:0 0 25px;padding-bottom:10px}.form-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.error-messages{background:#fef2f2;border:1px solid #dc2626;border-radius:8px;margin-bottom:30px;padding:20px}.error-messages h4{color:#dc2626;font-size:1.1rem;margin:0 0 15px}.error-messages ul{margin:0;padding-left:20px}.error-messages li{color:#dc2626;margin-bottom:5px}.results-section{border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-top:30px;padding:20px}.results-actions{align-items:center;display:flex;gap:15px;margin-bottom:20px}.view-account-details-btn{align-items:center;background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 20px;transition:background-color .2s}.view-account-details-btn:hover{background:#c82333}.results-grid{grid-gap:25px;display:grid;gap:25px;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.result-card{background:#f8f9fa;border-left:4px solid #dc2626;border-radius:10px;box-shadow:0 2px 4px #0000001a;padding:25px}.result-card h4{border-bottom:1px solid #dee2e6;color:#333;font-size:1.3rem;margin:0 0 20px;padding-bottom:10px}.result-card p{color:#555;font-size:.95rem;line-height:1.5;margin:0 0 10px}.result-card ul{margin:0;padding-left:20px}.result-card li{color:#555;line-height:1.5;margin-bottom:8px}.scenario-results{display:flex;flex-direction:column;gap:15px}.scenario-item{background:#f8f9fa;border-left:4px solid #dc2626;border-radius:8px;padding:15px}.scenario-item h5{color:#dc2626;font-size:1.1rem;font-weight:600;margin:0 0 10px}.scenario-item p{font-size:.95rem;margin:5px 0}.yearly-projection{display:flex;flex-direction:column;gap:10px}.year-data{background:#f8f9fa;border-left:3px solid #28a745;border-radius:6px;padding:12px}.year-data h6{color:#28a745;font-size:1rem;font-weight:600;margin:0 0 8px}.year-data p{font-size:.9rem;margin:4px 0}@media (max-width:1200px){.planner-container{flex-direction:column}.sidebar{position:static;width:100%}.section-nav{flex-direction:row;flex-wrap:wrap}.nav-button{flex:1 1;min-width:150px;text-align:center}}@media (max-width:768px){.advanced-retirement-planner{padding:10px}.planner-header h2{font-size:2rem}.main-content{padding:20px}.form-grid,.results-grid{grid-template-columns:1fr}.nav-button{font-size:.9rem;min-width:120px;padding:10px 12px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.loading{opacity:.6;pointer-events:none}.form-group input:valid,.form-group select:valid{border-color:#16a34a}.form-group input:invalid:not(:placeholder-shown),.form-group select:invalid:not(:placeholder-shown){border-color:#ea580c}.form-group input:focus,.form-group select:focus{box-shadow:0 4px 8px #dc262633;transform:translateY(-1px)}.form-group input:hover,.form-group select:hover{border-color:#dc2626}@media print{.action-buttons,.sidebar{display:none}.planner-container{flex-direction:column}.main-content{box-shadow:none}}.checkbox-group{align-items:center;display:flex;gap:8px;margin-top:4px}.checkbox-group input[type=checkbox]{margin:0;width:auto}.checkbox-group span{color:#333;font-size:14px}.optimization-info{background-color:#f8f9fa;border-left:3px solid #007bff;border-radius:4px;margin-top:8px;padding:8px 12px}.optimization-info small{color:#666;font-style:italic}.legacy-options{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;gap:12px;margin-top:8px;padding:12px}.legacy-option,.legacy-options{display:flex;flex-direction:column}.legacy-option{gap:4px}.legacy-option label{color:#666;font-size:12px;font-weight:500}.legacy-option select:disabled{background-color:#e9ecef;color:#6c757d;cursor:not-allowed}.optimization-results{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;margin-top:20px;padding:20px}.optimization-results h4{align-items:center;color:#007bff;display:flex;gap:8px;margin-bottom:16px}.optimization-results h4:before{content:"🎯";font-size:18px}.optimization-summary{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.optimization-card{background:#fff;border:1px solid #dee2e6;border-radius:6px;box-shadow:0 2px 4px #0000001a;padding:16px}.optimization-card h5{color:#495057;font-size:14px;font-weight:600;margin-bottom:8px}.optimization-card .best-age{color:#28a745;font-size:24px;font-weight:700;margin-bottom:4px}.optimization-card .score{color:#666;font-size:12px}.optimization-details{margin-top:16px}.optimization-details h6{color:#495057;font-size:13px;margin-bottom:8px}.percentile-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(5,1fr);margin-bottom:12px}.percentile-item{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;padding:8px;text-align:center}.percentile-label{color:#666;font-size:10px;margin-bottom:4px}.percentile-value{color:#495057;font-size:12px;font-weight:600}.optimize-button{align-items:center;background:linear-gradient(135deg,#007bff,#0056b3);border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-weight:600;gap:8px;margin-top:16px;padding:12px 24px;transition:all .3s ease}.optimize-button:hover{background:linear-gradient(135deg,#0056b3,#004085);box-shadow:0 4px 8px #0003;transform:translateY(-1px)}.optimize-button:disabled{background:#6c757d;box-shadow:none;cursor:not-allowed;transform:none}.optimize-button .spinner{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:#fff;height:16px;width:16px}.planner-logo{display:inline-block;height:48px;margin-right:16px;vertical-align:middle}.rrsp-calculator{background:#f8f9fa;min-height:100vh}.calculator-header{background:#fff;border-bottom:1px solid #e9ecef;box-shadow:0 2px 4px #0000001a;padding:1rem 0}.header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 2rem}.header-left{flex-direction:column;gap:.5rem}.back-link{color:var(--color1);font-size:.9rem;font-weight:600;text-decoration:none;transition:color .3s ease}.back-link:hover{color:var(--color5)}.header-left h1{color:#333;font-size:2rem;font-weight:700}.header-left p{color:#6c757d;font-size:1rem;margin:0}.header-right{gap:1rem}.user-info{color:#6c757d;font-size:.9rem}.login-btn{font-size:.9rem;font-weight:600;padding:.5rem 1rem;text-decoration:none}.login-btn:hover{color:#fff;text-decoration:none}.calculator-main{display:flex;gap:2rem;margin:0 auto;max-width:1400px;min-height:calc(100vh - 120px);padding:2rem}.calculator-sidebar{display:flex;flex-direction:column;flex-shrink:0;gap:2rem;width:300px}.sidebar-section{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 4px #0000001a;padding:1.5rem}.sidebar-section h3{color:#333;font-size:1.2rem;font-weight:600;margin-bottom:1rem}.sidebar-btn{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;margin-bottom:.5rem;padding:.75rem 1rem;transition:background .3s ease;width:100%}.sidebar-btn:hover{background:#5a6fd8}.sidebar-btn.test-btn{background:#ffc107;color:#333}.sidebar-btn.test-btn:hover{background:#e0a800}.scenario-list{min-height:100px}.no-scenarios{color:#6c757d;font-style:italic;margin:2rem 0;text-align:center}.calculator-content{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 4px #0000001a;flex:1 1;overflow:hidden}.planner-container{height:100%;overflow:auto}@media (max-width:1200px){.calculator-main{flex-direction:column}.calculator-sidebar{flex-direction:row;gap:1rem;width:100%}.sidebar-section{flex:1 1}}@media (max-width:768px){.header-content{flex-direction:column;gap:1rem;padding:0 1rem;text-align:center}.header-left h1{font-size:1.5rem}.calculator-main{padding:1rem}.calculator-main,.calculator-sidebar{flex-direction:column}.sidebar-section{padding:1rem}}.modal-overlay{align-items:center;background-color:#000000d9;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0000004d;max-height:90vh;max-width:90vw;overflow-y:auto;position:relative}.modal-header{align-items:center;border-bottom:1px solid #e5e5e5;display:flex;justify-content:space-between;padding:20px 24px 16px}.modal-title{color:#333;font-size:1.5rem;font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:4px;color:#666;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;transition:background-color .2s;width:30px}.modal-close:hover{background-color:#f5f5f5;color:#333}.modal-body{color:#333;line-height:1.6;padding:20px 24px}.modal-body p{font-size:1rem;margin:0 0 16px}.modal-body strong{color:#dc2626}.modal-body p:last-child{margin-bottom:0}.modal-footer{border-top:1px solid #e5e5e5;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px 20px}.modal-button{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;min-width:100px;padding:10px 20px;transition:all .2s}.modal-button-secondary{background-color:#f5f5f5;border:1px solid #ddd;color:#333}.modal-button-secondary:hover{background-color:#e5e5e5}.modal-button-primary{background-color:#dc2626;color:#fff}.modal-button-primary:hover{background-color:#b91c1c}@media (max-width:768px){.modal-content{margin:20px;max-height:calc(100vh - 40px)}.modal-body,.modal-footer,.modal-header{padding-left:20px;padding-right:20px}.modal-title{font-size:1.25rem}.modal-footer{flex-direction:column}.modal-button{width:100%}}.housing-calculator{background:#f8f9fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;font-size:16px;line-height:1.5;min-height:100vh}.calculator-container{margin:0 auto;max-width:1800px;min-height:calc(100vh - 120px)}.calculator-form{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:2rem;padding:2rem}.calculator-form h2{border-bottom:2px solid #28a745;color:#333;font-size:1.8rem;font-weight:600;margin-bottom:1.5rem;padding-bottom:.5rem}.calculator-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr}@media (min-width:1200px){.calculator-grid{grid-template-columns:1fr 1fr}}.form-actions{margin-top:2rem;text-align:center}.results-section{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-top:2rem;padding:2rem}.results-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.results-section h2{color:#333;font-size:1.8rem;font-weight:600;margin:0}.save-btn{background:#28a745;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.75rem 1.5rem;transition:all .3s ease}.save-btn:hover{background:#218838;transform:translateY(-1px)}.total-row{background:#f8f9fa;border-top:2px solid #28a745;font-weight:600}.total-row:hover{background:#e9ecef}.waterfall-chart{background:#fff;border:1px solid #e9ecef;border-radius:8px;margin-bottom:1rem;padding:1.5rem}.waterfall-toggle{display:flex;gap:.5rem;justify-content:center;margin-bottom:1rem}.waterfall-toggle .toggle-btn{background:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .2s ease}.waterfall-toggle .toggle-btn:hover{background:#e9ecef}.waterfall-toggle .toggle-btn.active{background:#007bff;border-color:#007bff;color:#fff}.waterfall-chart h3{color:#333;font-size:1.2rem;font-weight:600;margin-bottom:1rem;text-align:center}.waterfall-container{margin:0 auto;max-width:800px}.waterfall-bar{align-items:center;display:flex;height:40px;margin-bottom:.5rem}.bar-container-left{align-items:center;display:flex;flex:1 1;justify-content:flex-end;padding-right:1rem}.bar-container-right{align-items:center;display:flex;flex:1 1;justify-content:flex-start;padding-left:1rem}.waterfall-bar.positive{color:#28a745}.waterfall-bar.negative{color:#dc3545}.waterfall-bar.total{border-top:2px solid #dee2e6;font-weight:600;margin-top:.5rem;padding-top:.5rem}.bar-label{color:#333;flex:1 1;font-size:.9rem;text-align:center}.waterfall-header{align-items:center;color:#333;display:flex;font-weight:600;margin-bottom:1rem}.bar-value,.header-label{flex:1 1;font-size:.9rem;text-align:center}.bar-value{font-weight:600}.bar{border-radius:2px;height:20px;transition:all .2s ease}.bar:hover{opacity:.8;transform:scale(1.02)}.toggle-btn{background:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .2s ease}.toggle-btn:hover{background:#e9ecef}.toggle-btn.active{background:#007bff;border-color:#007bff;color:#fff}.big-result{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 15px #0000001a;color:#fff;margin-bottom:2rem;padding:2rem;text-align:center}.big-result h3{font-size:2rem;font-weight:700;margin:0 0 .5rem;text-shadow:0 2px 4px #0000001a}.big-result *{color:#fff;text-shadow:0 1px 2px #0000001a}.mode-selector{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:2rem;padding:2rem}.mode-buttons{align-items:center;display:flex;flex-direction:column;gap:1rem;justify-content:center}@media (min-width:768px){.mode-buttons{flex-direction:row;justify-content:center}}.mode-btn{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:.5rem;padding:1rem;text-align:left;transition:all .3s ease}.mode-btn:hover{background:#f0f8ff;border-color:#007bff}.mode-btn.active{background:#e3f2fd;border-color:#007bff}.mode-title{color:#333;font-size:1rem;font-weight:600}.mode-desc{color:#666;font-size:.9rem;line-height:1.4}.comparison-result{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 15px #0000001a;color:#fff;margin-bottom:2rem;padding:2rem;text-align:center}.comparison-result h3{font-size:2rem;font-weight:700;margin:0 0 .5rem;text-shadow:0 2px 4px #0000001a}.comparison-result h3 span{font-size:1.5rem}@media (max-width:768px){.calculator-form{padding:1.5rem}.calculator-form h2{font-size:1.5rem}.form-section{padding:1rem}.results-section{padding:1.5rem}.results-section h2{font-size:1.5rem}.waterfall-chart{padding:1rem}.waterfall-container{max-width:100%}.waterfall-header{flex-direction:column;gap:.5rem;text-align:center}.header-label{font-size:.8rem}.waterfall-bar{background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;flex-direction:column;gap:.25rem;height:auto;margin-bottom:1rem;padding:.5rem}.bar-container-left,.bar-container-right{flex:none;justify-content:center;padding:0;width:100%}.bar-label{font-size:.8rem;font-weight:600;margin-bottom:.25rem}.bar-value{font-size:.9rem;font-weight:700}.bar{height:12px;margin:.25rem 0}.waterfall-toggle{flex-direction:column;gap:.5rem}.waterfall-toggle .toggle-btn{font-size:.8rem;padding:.75rem}.big-result{padding:1.5rem}.big-result h3{font-size:1.5rem}.mode-selector{padding:1.5rem}.mode-btn{padding:.75rem}.mode-title{font-size:.9rem}.mode-desc{font-size:.8rem}.comparison-result{padding:1.5rem}.comparison-result h3{font-size:1.5rem}.comparison-result h3 span{font-size:1.2rem}}@media (max-width:480px){.calculator-form{padding:1rem}.calculator-form h2{font-size:1.3rem}.results-section{padding:1rem}.results-section h2{font-size:1.3rem}.waterfall-chart{padding:.75rem}.waterfall-bar{margin-bottom:.75rem;padding:.75rem}.bar-label{font-size:.75rem}.bar-value{font-size:.8rem}.big-result{padding:1rem}.big-result h3{font-size:1.3rem}.mode-selector{padding:1rem}.mode-btn{padding:.5rem}.mode-title{font-size:.85rem}.mode-desc{font-size:.75rem}.comparison-result{padding:1rem}.comparison-result h3{font-size:1.3rem}.comparison-result h3 span{font-size:1.1rem}}.detail-view-selector{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-top:2rem;padding:2rem}.detail-view-selector h3{border-bottom:2px solid #28a745;color:#333;font-size:1.5rem;font-weight:600;margin-bottom:1.5rem;padding-bottom:.5rem;text-align:center}.detail-cards{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin:0 auto;max-width:900px}.detail-card{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:2px solid #e9ecef;border-radius:12px;cursor:pointer;display:flex;flex:0 0 280px;flex-direction:column;gap:.75rem;max-width:280px;overflow:hidden;padding:1.5rem;position:relative;text-align:left;transition:all .3s ease}.detail-card:before{background:linear-gradient(90deg,#28a745,#20c997);content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s ease}.detail-card:hover{background:linear-gradient(135deg,#f0f8ff,#e3f2fd);border-color:#007bff;box-shadow:0 4px 15px #007bff26;transform:translateY(-2px)}.detail-card:hover:before{transform:scaleX(1)}.detail-card.active{background:linear-gradient(135deg,#e8f5e8,#d4edda);border-color:#28a745;box-shadow:0 4px 15px #28a74533}.detail-card.active:before{background:linear-gradient(90deg,#28a745,#20c997);transform:scaleX(1)}.card-icon{font-size:2rem;margin-bottom:.5rem;text-align:center}.card-title{color:#333;font-size:1.1rem;font-weight:600;margin-bottom:.25rem}.card-desc{color:#666;font-size:.9rem;line-height:1.4}@media (max-width:768px){.detail-view-selector{padding:1.5rem}.detail-view-selector h3{font-size:1.3rem}.detail-cards{gap:.75rem;grid-template-columns:1fr}.detail-card{padding:1.25rem}.card-icon{font-size:1.75rem}.card-title{font-size:1rem}.card-desc{font-size:.85rem}}@media (max-width:480px){.detail-view-selector{padding:1rem}.detail-view-selector h3{font-size:1.2rem}.detail-card{padding:1rem}.card-icon{font-size:1.5rem}.card-title{font-size:.95rem}.card-desc{font-size:.8rem}}:root{--color1:#f40000;--color2:#f44e3f;--color3:#f4796b;--color4:#f4998d;--color5:#090809;--primary-color:var(--color1);--secondary-color:var(--color2);--background-light:var(--color4);--background-warm:var(--color3);--text-dark:var(--color5);--text-light:var(--color4);--accent-color:var(--color1);--success-color:var(--color2);--warning-color:var(--color1);--error-color:var(--color1);--border-color:var(--color3);--shadow-color:#0908091a}.App{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh;text-align:center}.main-content{min-height:calc(100vh - 60px);padding-top:60px}*{text-decoration:none!important}.loading-screen{align-items:center;background:linear-gradient(135deg,var(--color4) 0,var(--color1) 100%);color:#fff;display:flex;flex-direction:column;justify-content:center;min-height:100vh}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f065434d;border-radius:50%;border-top:4px solid var(--color1);height:50px;margin-bottom:20px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.planner-container{background:#f8f9fa;min-height:100vh}.planner-header{background:linear-gradient(135deg,var(--color4) 0,var(--color1) 100%);box-shadow:0 2px 4px #0000001a;color:#fff;padding:20px 0}.planner-header .header-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1400px;padding:0 20px}.header-left{align-items:center;display:flex;gap:20px}.back-button{padding:10px 20px}.header-left h1{font-size:1.8rem;font-weight:600;margin:0}.header-right{align-items:center;display:flex;gap:20px}.guest-info,.user-info{align-items:center;display:flex;gap:15px}.guest-info span,.user-info span{color:#e5e5e5;font-size:1rem}.login-btn,.logout-btn{background:var(--color1);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:8px 16px;transition:all .3s ease}.login-btn:hover,.logout-btn:hover{background:var(--color5);transform:translateY(-1px)}@media (max-width:768px){.planner-header .header-content{flex-direction:column;gap:15px;text-align:center}.header-left{flex-direction:column;gap:10px}.header-left h1{font-size:1.5rem}.guest-info,.header-right,.user-info{flex-direction:column;gap:10px}}@media (max-width:480px){.planner-header{padding:15px 0}.planner-header .header-content{padding:0 15px}.back-button{font-size:.9rem;padding:8px 16px}.header-left h1{font-size:1.3rem}}.planner-vertical-container{background:#f8f9fa;display:flex;flex-direction:column;min-height:100vh}.planner-topbar.sticky{background:linear-gradient(135deg,#1a1a1a,#2d2d2d);box-shadow:0 2px 8px #00000014;color:#fff;padding:0;position:sticky;top:0;z-index:100}.planner-topbar-content{align-items:center;display:flex;gap:24px;justify-content:space-between;margin:0 auto;max-width:1400px;padding:18px 24px}.scenario-title{color:#fff;flex:1 1;font-size:2rem;font-weight:700;margin:0;text-align:center}.planner-topbar-actions{align-items:center;display:flex;gap:16px}.guest-info,.user-info{color:#e5e5e5;font-size:1rem}.login-btn{background:var(--color1);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:10px 18px;transition:all .3s ease}.login-btn:hover{background:var(--color5);transform:translateY(-1px)}.back-button{background:#0000;border:2px solid var(--color1);border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:10px 18px;text-decoration:none;transition:all .3s ease}.back-button:hover{background:var(--color1);transform:translateY(-2px)}.planner-main-content{flex:1 1;margin:0 auto;max-width:1400px;padding:0 0 40px;width:100%}@media (max-width:900px){.planner-topbar-content{flex-direction:column;gap:10px;padding:14px 8px}.scenario-title{font-size:1.3rem}}@media (max-width:600px){.planner-main-content{padding:0 0 20px}.planner-topbar-content{padding:10px 2px}.back-button,.login-btn{font-size:.9rem;padding:7px 10px}}.sticky-footer{background:var(--color4);border-top:2px solid var(--color1);bottom:0;box-shadow:0 -2px 8px #00000014;color:#fff;font-size:1rem;font-weight:600;left:0;letter-spacing:.5px;padding:12px 0 10px;position:fixed;right:0;text-align:center;z-index:200}.auth-section,.dashboard-main,.planner-main-content{padding-bottom:60px}.form-group{grid-gap:1rem;align-items:start;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem}.form-group label{align-items:center;color:var(--text-dark);display:flex;flex-direction:column;font-weight:400;gap:.25rem;line-height:1.4}.housing-calculator .form-group label{align-items:center;color:#333;display:flex;font-weight:500;margin-bottom:.5rem}.form-group label b{color:#333;font-weight:700}.form-group label i{color:#666;font-size:.8rem;font-weight:400}.form-group input[type=email],.form-group input[type=number],.form-group input[type=password],.form-group input[type=text],.form-group select,.form-group textarea{background:#fff;border:1px solid #e1e5e9;border-radius:6px;box-sizing:border-box;font-size:1rem;padding:.75rem;transition:border-color .3s ease;width:100%}.form-group input[type=email]:focus,.form-group input[type=number]:focus,.form-group input[type=password]:focus,.form-group input[type=text]:focus,.form-group select:focus,.form-group textarea:focus{border-color:#007bff;outline:none}.form-group input[type=email]:disabled,.form-group input[type=number]:disabled,.form-group input[type=password]:disabled,.form-group input[type=text]:disabled,.form-group select:disabled,.form-group textarea:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.form-group input[type=radio]{margin-right:.5rem}.form-group input[type=checkbox]{margin-right:.5rem;transform:scale(1.2)}.form-group.radio-group{grid-template-columns:1fr}.form-group.radio-group label{align-items:center;cursor:pointer;display:flex;gap:.5rem}.downpayment-type-select,.form-group select{background:#fff;border:1px solid #e1e5e9;border-radius:6px;box-sizing:border-box;cursor:pointer;font-size:1rem;padding:.75rem;transition:border-color .3s ease;width:100%}.downpayment-type-select:focus,.form-group select:focus{border-color:#007bff;outline:none}.downpayment-type-select option,.form-group select option{padding:.5rem}.hero-features{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:3rem}.feature{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;color:var(--text-light)!important;display:flex;flex-direction:column;min-width:120px;padding:1.5rem;transition:transform .3s ease,background .3s ease}.disabled .feature,.disabled>.feature{background:#ffffff80;color:#fff!important;opacity:.6}.feature:hover{background:#ffffff26;transform:translateY(-5px)}.feature-icon{font-size:2.5rem;margin-bottom:.5rem}.feature span:last-child{font-size:1.1rem;font-weight:600;text-align:center}.calculate-btn,.primary-btn,.quickstart-button{align-items:center;background:var(--color1);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:1.1rem;font-weight:600;justify-content:center;padding:1rem 2rem;text-decoration:none;transition:all .3s ease}.calculate-btn:hover,.primary-btn:hover,.quickstart-button:hover{background:var(--color2);transform:translateY(-2px)}.housing-calculator .calculate-btn{box-shadow:0 2px 4px #0000001a}.housing-calculator .calculate-btn:hover{background:var(--color5);box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.secondary-btn,.tool-access-btn{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;color:var(--text-light);display:inline-flex;gap:.5rem;padding:1rem 2rem;text-decoration:none;transition:all .3s ease}.secondary-btn:hover,.tool-access-btn:hover{background:#fff3;transform:translateY(-2px)}.calculator-form h2,.form-section h3{border-bottom:2px solid var(--color1);color:#333;font-size:1.3rem;font-weight:600;margin-bottom:1.5rem;padding-bottom:.5rem}.form-section{border-left:3px solid var(--color1);margin-bottom:2rem;padding:0 5%}.housing-calculator .form-section{background:#fff;border:1px solid #e9ecef;border-left:none;border-radius:8px;margin-bottom:1rem;padding:1.5rem}.housing-calculator .form-section h3{border-bottom:2px solid #28a745;color:#333;font-size:1.2rem;font-weight:600;margin-bottom:1rem;padding-bottom:.5rem}@media (max-width:768px){.form-group{gap:.5rem;grid-template-columns:1fr}.form-group label{font-size:.9rem}.form-group input[type=email],.form-group input[type=number],.form-group input[type=password],.form-group input[type=text],.form-group select,.form-group textarea{font-size:.9rem;padding:.6rem}.hero-features{gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.feature{min-width:100px;padding:1rem}.feature-icon{font-size:2rem}.feature span:last-child{font-size:.9rem}.calculate-btn,.primary-btn,.quickstart-button{font-size:1rem;padding:.8rem 1.5rem}}@media (max-width:480px){.form-section{padding:0 3%}.hero-features{gap:.8rem;grid-template-columns:1fr}.feature{padding:.8rem}}
/*# sourceMappingURL=main.ade1e9a2.css.map*/