.narrative-container{max-width:960px;margin:0 auto;padding:16px 32px 24px;font-family:Roboto,-apple-system,BlinkMacSystemFont,sans-serif;color:#1a1a1a;line-height:1.7}html{scroll-behavior:smooth}.narrative-hero{margin-bottom:32px;padding-bottom:0}.narrative-hero h1{font-size:2.25rem;font-weight:700;line-height:1.2;margin:0 0 20px;padding-bottom:20px;border-bottom:1px solid #e2e8f0;color:#1a1a1a;letter-spacing:-.02em}.narrative-lead{font-size:1.2rem;line-height:1.5;color:#64748b;margin:0;font-weight:400}.narrative-lead strong{color:#319795;font-weight:600}.controls-panel{margin:0 0 48px;padding:32px;background:#fff;border-radius:16px;border:1px solid #e2e8f0;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;position:relative}.controls-intro{font-size:1.05rem;color:#64748b;margin:0 0 16px}.controls-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;align-items:start}@media (max-width: 1000px){.controls-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 700px){.controls-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.controls-grid{grid-template-columns:1fr}}.control-item{display:flex;flex-direction:column;gap:8px}.control-item>label:first-child{font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.control-item select,.control-item .salary-input-wrapper,.control-item .age-input,.control-item .checkbox-label{height:48px;box-sizing:border-box}.control-item select{padding:0 14px;border:1px solid #e2e8f0;border-radius:8px;font-size:.95rem;font-weight:500;background:#fff;color:#1e293b;cursor:pointer;transition:all .15s ease}.control-item select.salary-select{text-align:left}.control-item select:hover{border-color:#cbd5e1}.control-item select:focus{outline:none;border-color:#319795;box-shadow:0 0 0 3px #3197951a}.salary-input-wrapper{display:flex;align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;transition:all .15s ease}.salary-input-wrapper:hover{border-color:#cbd5e1}.salary-input-wrapper:focus-within{border-color:#319795;box-shadow:0 0 0 3px #3197951a}.currency-symbol{padding:0 14px;height:100%;display:flex;align-items:center;background:#f1f5f9;color:#64748b;font-weight:600;font-size:.95rem;border-right:1px solid #e2e8f0}.salary-input-wrapper input{flex:1;padding:0 14px;height:100%;border:none;font-size:.95rem;font-weight:500;color:#1e293b;background:transparent;outline:none;min-width:0}.control-hint{font-size:.72rem;color:#94a3b8;line-height:1.3;margin-top:4px}.household-expand-section{margin-top:24px;padding-top:20px;border-top:1px solid #e2e8f0}.household-expand-button{display:flex;align-items:center;justify-content:space-between;width:100%;padding:8px 0;background:transparent;border:none;font-size:.9rem;font-weight:500;color:#475569;cursor:pointer;transition:all .15s ease}.household-expand-button:hover{color:#319795}.expand-arrow{font-size:.7rem;transition:transform .2s ease}.expand-arrow.expanded{transform:rotate(180deg)}.household-controls-expanded{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:16px}@media (max-width: 900px){.household-controls-expanded{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.household-controls-expanded{grid-template-columns:1fr}}.label-with-info{display:flex;align-items:center;gap:6px}.info-icon-wrapper{position:relative;display:inline-flex}.info-icon{width:14px;height:14px;border-radius:50%;background:#e2e8f0;color:#64748b;font-size:9px;font-weight:600;font-style:italic;display:inline-flex;align-items:center;justify-content:center;cursor:help;transition:all .15s ease;font-family:Georgia,serif;text-transform:lowercase}.info-icon:hover{background:#319795;color:#fff}.info-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);width:260px;padding:12px 14px;background:#1e293b;color:#f1f5f9;font-size:.8rem;font-weight:400;line-height:1.5;border-radius:8px;box-shadow:0 10px 25px -5px #0003;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;z-index:100;text-transform:none;letter-spacing:normal}.info-tooltip strong{color:#fff;font-weight:600}.info-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#1e293b}.info-icon-wrapper:hover .info-tooltip{opacity:1;visibility:visible}.info-icon.light{background:#ffffff4d;color:#fff}.info-icon.light:hover{background:#ffffff80;color:#fff}.checkbox-label{display:flex;align-items:center;justify-content:flex-start;gap:10px;cursor:pointer;padding:0 14px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;transition:all .15s ease;font-weight:500;font-size:.9rem;color:#64748b}.checkbox-label:hover{border-color:#cbd5e1;background:#f8fafc}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:#319795;cursor:pointer;margin:0}.checkbox-label input[type=checkbox]:checked~span{color:#319795;font-weight:600}.checkbox-label span{white-space:nowrap}.age-input{width:100%;padding:0 14px;border:1px solid #e2e8f0;border-radius:8px;font-size:.95rem;font-weight:500;background:#fff;color:#1e293b;text-align:left;transition:all .15s ease}.age-input:hover{border-color:#cbd5e1}.age-input:focus{outline:none;border-color:#319795;box-shadow:0 0 0 3px #3197951a}.narrative-section{margin-bottom:48px;padding-bottom:48px;border-bottom:1px solid #e5e5e5;scroll-margin-top:24px}.narrative-section:last-of-type{border-bottom:none;padding-bottom:0}.narrative-section#overview{border-bottom:none;padding-bottom:0;margin-bottom:32px}.narrative-section h2{font-size:1.5rem;font-weight:600;margin:0 0 20px;color:#1a1a1a;letter-spacing:-.01em}.narrative-section p{font-size:1.1rem;margin:0 0 20px;color:#333}.narrative-section p:last-child{margin-bottom:0}.api-loading{padding:12px 16px;background:#e6fffa;border-left:4px solid #319795;color:#234e52;font-size:.95rem;margin-bottom:16px;border-radius:4px}.api-error{padding:12px 16px;background:#fff5f5;border-left:4px solid #e53e3e;color:#742a2a;font-size:.95rem;margin-bottom:16px;border-radius:4px}.chart-controls-box{display:flex;gap:24px;padding:16px 20px;background:#f1f5f9;border-radius:8px;margin-bottom:16px;flex-wrap:wrap}.chart-control{display:flex;flex-direction:column;gap:6px}.chart-control label{font-size:.85rem;font-weight:600;color:#475569}.chart-control input,.chart-control select{padding:8px 12px;border:1px solid #cbd5e1;border-radius:6px;font-size:.95rem;background:#fff;min-width:120px}.chart-control input:focus,.chart-control select:focus{outline:none;border-color:#319795;box-shadow:0 0 0 2px #31979533}.chart-control .control-value{padding:8px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;font-size:.95rem;font-weight:600;color:#319795}@media (max-width: 600px){.chart-controls-box{flex-direction:column;gap:12px}.chart-control input,.chart-control select{width:100%}}.toggle-switch{display:flex;background:#fff;border:1px solid #cbd5e1;border-radius:6px;overflow:hidden}.toggle-switch button{padding:8px 16px;border:none;background:#fff;font-size:.9rem;font-weight:500;color:#64748b;cursor:pointer;transition:all .15s ease}.toggle-switch button:first-child{border-right:1px solid #cbd5e1}.toggle-switch button:hover{background:#f1f5f9}.toggle-switch button.active{background:#319795;color:#fff}.toggle-switch button.active:hover{background:#2c7a7b}.expandable-section{margin-top:8px}.expandable-section summary{font-size:1.1rem;font-weight:600;color:#319795;cursor:pointer;list-style:none;display:inline-flex;align-items:center;gap:6px}.expandable-section summary::-webkit-details-marker{display:none}.expandable-section summary:before{content:"▸";font-size:.75rem;transition:transform .2s ease}.expandable-section[open] summary:before{transform:rotate(90deg)}.expandable-section summary:hover{text-decoration:underline}.expandable-section.inline-details{display:inline}.expandable-section.inline-details summary{display:inline;font-size:inherit}.expandable-section.inline-details .plan-list{display:block;margin-top:12px}.expandable-section p{margin:8px 0 0;font-size:1.1rem;color:#333;line-height:1.7}.expandable-section .plan-list{margin:12px 0 0;padding-left:20px;font-size:1rem;color:#333;line-height:1.7}.expandable-section .plan-list li{margin-bottom:8px}.narrative-section p strong{font-weight:600;color:#1a1a1a}.narrative-chart-container{margin:24px -32px;padding:20px 24px 16px;background:#fafafa;border-radius:8px}@media (min-width: 768px){.narrative-chart-container{margin:24px -60px;padding:24px 60px 16px}}@media (min-width: 1024px){.narrative-chart-container{margin:24px -80px;padding:24px 80px 16px}}.narrative-chart{width:100%;min-height:400px}.chart-legend{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-top:8px}.legend-item{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:500;color:#64748b}.legend-color{width:10px;height:10px;border-radius:2px}.legend-line{width:20px;height:3px;background:#344054}.legend-line.solid{background:#344054}.legend-line.dashed{background:repeating-linear-gradient(to right,#344054 0px,#344054 4px,transparent 4px,transparent 7px)}.chart-toggle{display:flex;justify-content:center;gap:4px;margin-bottom:16px}.toggle-btn{padding:6px 16px;font-size:.85rem;font-weight:500;border:1px solid #e2e8f0;background:#f8fafc;color:#64748b;cursor:pointer;transition:all .15s ease}.toggle-btn:first-child{border-radius:6px 0 0 6px}.toggle-btn:last-child{border-radius:0 6px 6px 0}.toggle-btn:hover{background:#f1f5f9}.toggle-btn.active{background:#319795;border-color:#319795;color:#fff}.tax-position-box{margin:24px 0 0;padding:24px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 1px 3px #0000000a}.marginal-rate-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.marginal-rate-item{text-align:center;padding:20px 16px;background:#f8fafc;border-radius:10px}.marginal-rate-item.highlight{background:#319795;color:#fff}.marginal-rate-value{font-size:2.25rem;font-weight:700;line-height:1;margin-bottom:8px;color:#1e293b;font-variant-numeric:tabular-nums}.marginal-rate-item.highlight .marginal-rate-value{color:#fff}.marginal-rate-label{font-size:.8rem;color:#64748b;line-height:1.3;display:flex;align-items:center;justify-content:center;gap:6px}.marginal-rate-item.highlight .marginal-rate-label{color:#ffffffe6}.deductions-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding:24px 0;border-top:1px solid #f1f5f9;border-bottom:1px solid #f1f5f9}.deductions-column h4{font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px}.deduction-item{display:flex;justify-content:space-between;padding:6px 0;font-size:.9rem;color:#475569}.deduction-item span:first-child{font-weight:500}.deduction-item span:last-child{font-weight:600;color:#1e293b;font-variant-numeric:tabular-nums}.deduction-item.total{margin-top:8px;padding-top:12px;border-top:1px solid #e2e8f0;font-weight:600}.deduction-item.net{margin-top:8px;padding:10px 12px;background:#f0fdfa;border-radius:6px}.deduction-item.net span:first-child{font-weight:600;color:#1e293b}.deduction-item .net-value{font-size:1.1rem;font-weight:700;color:#319795}.summary-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:20px}.summary-stat{text-align:center}.summary-stat-label{display:flex;align-items:center;justify-content:center;gap:4px;font-size:.7rem;font-weight:500;color:#64748b;text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px}.summary-stat-value{font-size:1.25rem;font-weight:700;color:#1e293b;font-variant-numeric:tabular-nums}@media (max-width: 768px){.marginal-rate-row{grid-template-columns:1fr;gap:12px}.deductions-row{grid-template-columns:1fr;gap:20px}.summary-row{grid-template-columns:repeat(2,1fr)}}@media (max-width: 500px){.tax-position-box{padding:20px 16px}.marginal-rate-value{font-size:1.75rem}.summary-row{grid-template-columns:1fr 1fr}}.narrative-footer{margin-top:48px;padding-top:24px}.narrative-footer h3{font-size:1rem;font-weight:600;margin:0 0 12px;color:#1a1a1a}.narrative-footer p{font-size:.9rem;color:#666;line-height:1.6;margin:0 0 12px}.narrative-footer .source-link{margin-top:16px}.narrative-footer a{color:#319795;text-decoration:none}.narrative-footer a:hover{text-decoration:underline}.learn-more-section{margin-top:48px;padding:28px;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.learn-more-section h3{font-size:1.1rem;font-weight:600;color:#1e293b;margin:0 0 20px}.learn-more-content{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}@media (max-width: 900px){.learn-more-content{grid-template-columns:1fr;gap:20px}}.learn-more-item{padding:0}.learn-more-item h4{font-size:.85rem;font-weight:600;color:#475569;margin:0 0 8px}.learn-more-item p{font-size:.9rem;color:#64748b;line-height:1.6;margin:0}.learn-more-item a{color:#319795;text-decoration:none}.learn-more-item a:hover{text-decoration:underline}.narrative-chart svg{overflow:visible}.narrative-chart .grid line{stroke:#e5e5e5;stroke-dasharray:4,4}.narrative-chart .grid .domain{display:none}.narrative-chart .axis text{fill:#666;font-size:11px}.narrative-chart .axis path,.narrative-chart .axis line{stroke:#d4d4d4}.lifecycle-tooltip{position:fixed;pointer-events:none;background:#fffffffa;border:1px solid #e2e8f0;border-radius:8px;padding:12px;font-size:.85rem;box-shadow:0 10px 25px -5px #0000001a,0 4px 6px -2px #0000000d;opacity:0;transition:opacity .15s;z-index:1000;max-width:280px}.tooltip-title{font-weight:600;color:#1e293b;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid #f1f5f9}.tooltip-row{display:flex;justify-content:space-between;gap:16px;padding:3px 0}.tooltip-section{margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid #f1f5f9}.tooltip-total{margin-top:4px;padding-top:4px}.deductions-comparison{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:24px 0}@media (max-width: 768px){.deductions-comparison{grid-template-columns:1fr}}.deductions-box{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:20px 24px;box-shadow:0 1px 3px #0000000a}.deductions-box.no-loan{background:#f8fafc;border-color:#e2e8f0}.deductions-box h4{font-size:.75rem;font-weight:600;margin:0 0 16px;color:#64748b;text-transform:uppercase;letter-spacing:.5px;padding-bottom:12px;border-bottom:1px solid #e2e8f0}.deductions-grid{display:flex;flex-direction:column;gap:8px}.deduction-row{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;padding:4px 0}.deduction-label{color:#64748b;font-weight:500}.deduction-value{font-weight:600;color:#1e293b;font-variant-numeric:tabular-nums}.deduction-row.total{margin-top:8px;padding-top:12px;border-top:1px solid #e2e8f0}.deduction-row.total .deduction-label,.deduction-row.total .deduction-value{font-weight:600;color:#1e293b}.deduction-row.net{margin-top:8px;padding:12px;background:#f0fdfa;border-radius:8px;border:1px solid #99f6e4}.deduction-row.net .deduction-label{font-weight:600;color:#1e293b}.deduction-value.highlight{font-size:1.2rem;font-weight:700;color:#319795}.deductions-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:16px}@media (max-width: 900px){.deductions-summary{grid-template-columns:repeat(2,1fr)}}@media (max-width: 500px){.deductions-summary{grid-template-columns:1fr 1fr}}.summary-item{display:flex;flex-direction:column;gap:6px;text-align:center;padding:16px 12px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 1px 3px #0000000a}.summary-label{font-size:.7rem;font-weight:500;color:#64748b;line-height:1.3;text-transform:uppercase;letter-spacing:.3px}.summary-value{font-size:1.35rem;font-weight:700;color:#1e293b;font-variant-numeric:tabular-nums}.scroll-spy{position:fixed;right:24px;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;gap:16px;z-index:100}.scroll-spy-item{display:flex;align-items:center;gap:10px;background:none;border:none;cursor:pointer;padding:0}.scroll-spy-label{font-size:.85rem;font-weight:500;color:#9ca3af;text-align:right;transition:all .2s ease;white-space:nowrap;min-width:100px}.scroll-spy-dot{width:14px;height:14px;border-radius:50%;background:#d1d5db;transition:all .2s ease;flex-shrink:0}.scroll-spy-item:hover .scroll-spy-label{color:#64748b}.scroll-spy-item:hover .scroll-spy-dot{background:#9ca3af;transform:scale(1.2)}.scroll-spy-item.active .scroll-spy-label{color:#319795;font-weight:600}.scroll-spy-item.active .scroll-spy-dot{background:#319795;transform:scale(1.3)}@media (max-width: 1200px){.scroll-spy{right:12px}.scroll-spy-label{display:none}}@media (max-width: 900px){.scroll-spy{display:none}}@media (max-width: 600px){.narrative-container{padding:24px 16px 16px}.narrative-hero h1{font-size:1.75rem}.narrative-lead{font-size:1.1rem}.narrative-section h2{font-size:1.25rem}.narrative-section p{font-size:1rem}.callout-number{font-size:2rem}.narrative-chart{min-height:300px}.deductions-box{padding:16px}.summary-value{font-size:1.25rem}}.lifetime-summary,.interest-summary,.combined-summary,.policy-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:24px 0;padding:20px;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.interest-summary{grid-template-columns:repeat(2,1fr)}@media (max-width: 768px){.lifetime-summary,.interest-summary,.combined-summary,.policy-summary{grid-template-columns:repeat(2,1fr)}}@media (max-width: 500px){.lifetime-summary,.interest-summary,.policy-summary{grid-template-columns:1fr}}.plan2-notice{padding:24px;background:#fef3c7;border-radius:12px;border:1px solid #f59e0b;text-align:left}.plan2-notice p{margin:0 0 8px;font-size:1rem;color:#92400e;line-height:1.6}.plan2-notice p:last-child{margin-bottom:0}.plan2-notice strong{color:#78350f}.chart-view-toggle{display:inline-flex;gap:0;background:#f1f5f9;border-radius:6px;padding:2px}.toggle-btn{padding:4px 10px;border:none;background:transparent;font-size:.75rem;font-weight:500;color:#64748b;cursor:pointer;border-radius:4px;transition:all .15s ease}.toggle-btn:hover{color:#334155}.toggle-btn.active{background:#fff;color:#1e293b;box-shadow:0 1px 3px #0000001a}.chart-legend{display:flex;flex-wrap:wrap;gap:16px}.uc-controls{display:flex;gap:24px;margin:20px 0;padding:20px;background:#fef3c7;border-radius:12px;border:1px solid #f59e0b}.uc-controls .control-item{display:flex;flex-direction:column;gap:6px}.uc-controls select{padding:8px 12px;border:1px solid #d97706;border-radius:6px;font-size:.9rem;background:#fff;min-width:150px}@media (max-width: 600px){.uc-controls{flex-direction:column;gap:16px}}.mtr-summary{display:flex;gap:24px;margin:20px 0;padding:16px 20px;background:#fef2f2;border-radius:10px;border:1px solid #fecaca}.mtr-summary .summary-stat{display:flex;flex-direction:column;gap:4px}.mtr-summary .summary-stat-label{font-size:.75rem;font-weight:500;color:#64748b;text-transform:uppercase;letter-spacing:.3px}.mtr-summary .summary-stat-value{font-size:1.5rem;font-weight:700}@media (max-width: 600px){.mtr-summary{flex-wrap:wrap;gap:16px}.mtr-summary .summary-stat{flex:1 1 45%}}.summary-section{margin:32px 0 48px}.summary-section h2{font-size:1.5rem;font-weight:600;margin:0 0 20px;color:#1a1a1a;letter-spacing:-.01em}.summary-cards{display:flex;gap:16px}.summary-card{flex:1;background:#f1f5f9;border-radius:10px;padding:20px 16px;text-align:center}.summary-number{font-size:2.25rem;font-weight:700;color:#1e293b;line-height:1.1}.summary-label{font-size:.75rem;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-top:8px}.summary-sublabel{font-size:.8rem;color:#94a3b8;margin-top:4px}.summary-card.highlight-card{background:#4d9a98}.summary-card.highlight-card .summary-number{color:#fff}.summary-card.highlight-card .summary-label{color:#ffffffe6}.summary-card.highlight-card .summary-sublabel{color:#ffffffbf}@media (max-width: 700px){.summary-cards{flex-direction:column}.summary-card{padding:24px 20px}.summary-number{font-size:2.5rem}.summary-label{font-size:.9rem}}.app{max-width:1400px;margin:0 auto;padding:24px}@media (max-width: 768px){.app{padding:16px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Roboto,-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8fafc;color:#374151;line-height:1.5}#root{min-height:100vh}
