*,*:before,*:after{box-sizing:border-box}:root{font-family:system-ui,-apple-system,sans-serif;line-height:1.5;color:#1e293b;background-color:#fff}body{margin:0;min-width:320px}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{opacity:1}.app{max-width:860px;margin:0 auto;padding:1rem 1.5rem 3rem;font-family:system-ui,-apple-system,sans-serif;color:#1e293b}.app-header{text-align:center;margin-bottom:2rem}.app-header h1{font-size:2rem;margin-bottom:.5rem}.subtitle{color:#475569;font-size:1.05rem;line-height:1.6;max-width:640px;margin:0 auto .5rem}.subtitle-secondary{color:#64748b;font-size:.95rem;line-height:1.55;max-width:580px;margin:0 auto}.section-divider{margin:2.5rem 0 1.5rem;padding-top:1.5rem;border-top:1px solid #e2e8f0}.section-divider h2{font-size:1.4rem;margin:0 0 .25rem}.section-divider p{color:#64748b;font-size:.95rem;margin:0}.guidance-section{margin-bottom:0}.guidance-heading{font-size:1.4rem;margin-bottom:.25rem}.guidance-intro{color:#64748b;margin-bottom:1rem;font-size:.95rem}.guidance-card{border:1px solid #e2e8f0;border-radius:10px;margin-bottom:.6rem;overflow:hidden;background:#fafbfc}.guidance-card-header{display:flex;align-items:center;width:100%;padding:.85rem 1.1rem;border:none;background:none;cursor:pointer;font-size:1rem;font-weight:600;color:#1e293b;text-align:left;gap:.6rem;transition:background .15s}.guidance-card-header:hover{background:#f1f5f9}.guidance-card-header.open{background:#f1f5f9;border-bottom:1px solid #e2e8f0}.guidance-card-emoji{font-size:1.3rem}.guidance-card-title{flex:1}.guidance-chevron{color:#94a3b8;font-size:.9rem}.guidance-card-body{padding:1rem 1.25rem 1.25rem}.guidance-card-intro{color:#475569;font-size:.9rem;margin-bottom:.75rem;font-style:italic}.guidance-list{list-style:none;padding:0;margin:0}.guidance-list li{padding:.6rem 0;border-bottom:1px solid #f1f5f9;line-height:1.5}.guidance-list li:last-child{border-bottom:none}.guidance-list li strong{display:block;font-size:.92rem;color:#1e293b;margin-bottom:.15rem}.guidance-detail{font-size:.85rem;color:#64748b;line-height:1.5}.app-footer{text-align:center;margin-top:3rem;color:#94a3b8;font-size:.85rem}.runway-form fieldset{border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:1.25rem}.runway-form legend{font-weight:600;font-size:1.05rem;padding:0 .5rem}.field{margin-bottom:.85rem}.field label{display:block;font-size:.9rem;font-weight:500;margin-bottom:.25rem}.input-wrapper{display:flex;align-items:center;border:1px solid #cbd5e1;border-radius:8px;overflow:hidden;background:#fff}.input-wrapper:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.input-wrapper .prefix,.input-wrapper .suffix{padding:.5rem .6rem;color:#64748b;font-size:.9rem;background:#f1f5f9;-webkit-user-select:none;user-select:none}.input-wrapper input{flex:1;border:none;outline:none;padding:.55rem .75rem;font-size:1rem;min-width:0}.help{display:block;font-size:.78rem;color:#94a3b8;margin-top:.2rem}.toggle-field label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.expense-total{text-align:right;padding-top:.5rem;border-top:1px solid #e2e8f0;font-size:.95rem;color:#334155}.expense-note{text-align:right;font-size:.82rem;color:#94a3b8;margin-top:.25rem}.state-select{flex:1;border:none;outline:none;padding:.55rem .75rem;font-size:1rem;background:#fff;min-width:0;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.estimate-note{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:.6rem .85rem;font-size:.85rem;color:#1e40af;margin-bottom:.85rem;line-height:1.45}.btn-calculate{display:block;width:100%;padding:.85rem;font-size:1.1rem;font-weight:600;color:#fff;background:#2563eb;border:none;border-radius:10px;cursor:pointer;transition:background .2s}.btn-calculate:hover:not(:disabled){background:#1d4ed8}.btn-calculate:disabled{opacity:.5;cursor:not-allowed}.error-banner{background:#fef2f2;color:#991b1b;border:1px solid #fecaca;border-radius:8px;padding:.75rem 1rem;margin:1rem 0}.runway-result{margin-top:2rem}.result-hero{display:flex;flex-direction:column;align-items:center;border:3px solid;border-radius:16px;padding:2rem;margin-bottom:1.5rem;background:#fafbfc}.hero-emoji{font-size:2.5rem;margin-bottom:.5rem}.hero-months{display:flex;align-items:baseline;gap:.5rem}.hero-number{font-size:4rem;font-weight:800;line-height:1}.hero-label{font-size:1.3rem;color:#475569}.hero-severity{margin-top:.5rem;font-weight:600;font-size:1.05rem}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}.card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:1rem 1.25rem;text-align:center}.card-value{font-size:1.5rem;font-weight:700;color:#1e293b}.card-label{font-size:.85rem;color:#64748b;margin-top:.25rem}.tips-section{background:#fffbeb;border:1px solid #fde68a;border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:1.5rem}.tips-section h3{margin:0 0 .75rem;font-size:1.1rem}.tips-section ul{margin:0;padding-left:1.25rem}.tips-section li{margin-bottom:.4rem;line-height:1.5}.timeline-section{margin-bottom:1.5rem}.timeline-section h3{margin-bottom:.75rem}.timeline-table-wrapper{overflow-x:auto}.timeline-table{width:100%;border-collapse:collapse;font-size:.9rem}.timeline-table th,.timeline-table td{padding:.5rem .75rem;text-align:right;border-bottom:1px solid #e2e8f0}.timeline-table th{background:#f1f5f9;font-weight:600;position:sticky;top:0}.timeline-table td:first-child,.timeline-table th:first-child{text-align:left}.timeline-table .positive{color:#16a34a}.timeline-table .negative{color:#dc2626}.timeline-table tr.depleted{background:#fef2f2}.chart-section{margin-bottom:1.5rem}.chart-section h3{margin-bottom:.75rem}.bar-chart{display:flex;align-items:flex-end;gap:4px;height:180px;border-bottom:2px solid #e2e8f0;padding-bottom:.25rem}.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}.bar{width:100%;min-width:6px;border-radius:4px 4px 0 0;transition:height .3s}.bar-label{font-size:.65rem;color:#94a3b8;margin-top:.2rem}.progress-bar{display:flex;align-items:flex-start;justify-content:space-between;position:relative;margin-bottom:2rem;padding:0 .5rem}.progress-step{display:flex;flex-direction:column;align-items:center;z-index:1;flex:0 0 auto;min-width:60px}.progress-step.clickable{cursor:pointer}.progress-step.clickable:hover .progress-dot{transform:scale(1.1)}.progress-step.clickable:hover .progress-label{color:#1e293b}.progress-dot{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;border:2px solid #cbd5e1;background:#fff;color:#94a3b8;transition:all .25s;-webkit-user-select:none;user-select:none}.progress-step.active .progress-dot{border-color:#2563eb;background:#2563eb;color:#fff;box-shadow:0 0 0 4px #2563eb26}.progress-step.done .progress-dot{border-color:#16a34a;background:#16a34a;color:#fff}.progress-label{margin-top:.4rem;font-size:.75rem;color:#94a3b8;text-align:center;white-space:nowrap}.progress-step.active .progress-label{color:#2563eb;font-weight:600}.progress-step.done .progress-label{color:#16a34a}.progress-line-container{position:absolute;top:16px;left:30px;right:30px;height:3px;background:#e2e8f0;border-radius:2px;z-index:0}.progress-line-fill{height:100%;background:#16a34a;border-radius:2px;transition:width .35s ease}.runway-wizard{border:1px solid #e2e8f0;border-radius:14px;padding:2rem 2rem 1.5rem;background:#fff}.wizard-body{min-height:300px}.situation-choices{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1rem}.situation-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem 1.25rem;border:2px solid #e2e8f0;border-radius:12px;background:#f8fafc;cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s;text-align:center}.situation-card:hover{border-color:#93c5fd;background:#f0f7ff}.situation-card.selected{border-color:#3b82f6;background:#eff6ff;box-shadow:0 0 0 3px #3b82f626}.situation-emoji{font-size:2rem;line-height:1}.situation-title{font-size:1.05rem;font-weight:600;color:#1e293b}.situation-desc{font-size:.85rem;color:#64748b;line-height:1.45}@media (max-width: 600px){.situation-choices{grid-template-columns:1fr}}.wizard-step h3{font-size:1.2rem;margin:0 0 .25rem}.step-desc{color:#64748b;font-size:.9rem;line-height:1.55;margin-bottom:1.25rem}.info-box{background:#f0f9ff;border:1px solid #bae6fd;border-radius:10px;padding:1rem 1.25rem;margin-bottom:1.25rem}.info-box h4{margin:0 0 .6rem;font-size:1rem;color:#0c4a6e}.info-box ul{list-style:none;padding:0;margin:0}.info-box li{padding:.45rem 0;border-bottom:1px solid #e0f2fe;font-size:.88rem;color:#334155;line-height:1.55}.info-box li:last-child{border-bottom:none}.info-box li strong{color:#0c4a6e}.wizard-nav{display:flex;align-items:center;margin-top:1.75rem;padding-top:1.25rem;border-top:1px solid #e2e8f0}.wizard-nav-spacer{flex:1}.btn-back{padding:.6rem 1.4rem;font-size:.95rem;font-weight:500;color:#475569;background:#f1f5f9;border:1px solid #cbd5e1;border-radius:8px;cursor:pointer;transition:background .15s}.btn-back:hover{background:#e2e8f0}.btn-next{padding:.6rem 1.8rem;font-size:.95rem;font-weight:600;color:#fff;background:#2563eb;border:none;border-radius:8px;cursor:pointer;transition:background .15s}.btn-next:hover{background:#1d4ed8}.email-capture{margin-top:2rem;padding:1.5rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;text-align:center}.email-capture h4{margin:0 0 .35rem;font-size:1.05rem}.email-capture p{color:#64748b;font-size:.9rem;margin:0 0 1rem}.email-form{display:flex;gap:.5rem;max-width:420px;margin:0 auto}.email-form input{flex:1;padding:.6rem .85rem;font-size:.95rem;border:1px solid #cbd5e1;border-radius:8px;outline:none}.email-form input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.email-form button{padding:.6rem 1.25rem;font-size:.95rem;font-weight:600;color:#fff;background:#2563eb;border:none;border-radius:8px;cursor:pointer;white-space:nowrap}.email-form button:hover{background:#1d4ed8}.email-success{color:#16a34a;font-size:.9rem;margin-top:.5rem}.email-skip{background:none;border:none;color:#94a3b8;font-size:.85rem;cursor:pointer;margin-top:.5rem;text-decoration:underline}.email-skip:hover,.card-value-muted{color:#64748b}.info-box-small{padding:.75rem 1rem}.info-box-small p{margin:0;font-size:.85rem;color:#334155;line-height:1.55}.export-section{margin-top:2rem;padding:1.5rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px}.export-section h3{margin:0 0 .25rem;font-size:1.1rem}.export-desc{color:#64748b;font-size:.9rem;margin:0 0 1rem}.export-actions{display:flex;gap:.75rem;flex-wrap:wrap}.btn-export{padding:.6rem 1.3rem;font-size:.9rem;font-weight:600;color:#fff;background:#2563eb;border:none;border-radius:8px;cursor:pointer;transition:background .15s;min-width:140px}.btn-export:hover{background:#1d4ed8}.btn-export-secondary{background:#f1f5f9;color:#475569;border:1px solid #cbd5e1}.btn-export-secondary:hover{background:#e2e8f0}.user-bar{display:flex;justify-content:flex-end;align-items:center;gap:.75rem;margin-bottom:1rem;font-size:.85rem;color:#64748b}.user-bar-cta{color:#64748b}.user-bar-buttons{display:flex;gap:.5rem}.btn-login{display:inline-block;padding:.35rem .85rem;border:1px solid #cbd5e1;border-radius:6px;background:#fff;color:#334155;font-size:.82rem;font-weight:500;cursor:pointer;text-decoration:none;transition:border-color .15s,background .15s}.btn-login:hover{border-color:#94a3b8;background:#f8fafc}.btn-login-secondary{background:transparent;border-color:transparent;color:#94a3b8}.btn-login-secondary:hover{color:#64748b;background:#f1f5f9}.scenario-manager{margin:1.5rem 0;padding:1.25rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px}.scenario-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.scenario-header h4{margin:0;font-size:1rem;font-weight:600;color:#334155}.scenario-save-form{display:flex;gap:.5rem;margin-bottom:.75rem}.scenario-save-form input{flex:1;padding:.45rem .75rem;border:1px solid #cbd5e1;border-radius:6px;font-size:.88rem}.scenario-save-form input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f626}.scenario-save-form button{padding:.45rem 1rem;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-size:.88rem;font-weight:500;cursor:pointer;transition:background .15s}.scenario-save-form button:hover:not(:disabled){background:#2563eb}.scenario-save-form button:disabled{opacity:.5;cursor:not-allowed}.scenario-list{list-style:none;padding:0;margin:0}.scenario-list li{display:flex;flex-direction:column;gap:.35rem;padding:.5rem .25rem;border-bottom:1px solid #e2e8f0}.scenario-list li:last-child{border-bottom:none}.scenario-row{display:flex;align-items:center;gap:.5rem;width:100%}.scenario-list li.active{background:#eff6ff;border-radius:8px;padding:.6rem .65rem;border:2px solid #3b82f6}.scenario-active-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#fff;background:#3b82f6;padding:.15rem .45rem;border-radius:4px;white-space:nowrap}.scenario-active-actions{display:flex;gap:.5rem;padding-top:.25rem}.scenario-name{flex:1;background:none;border:none;font-size:.9rem;color:#3b82f6;cursor:pointer;text-align:left;padding:0;font-weight:500}.scenario-name:hover{color:#1d4ed8;text-decoration:underline}.scenario-date{font-size:.78rem;color:#94a3b8;white-space:nowrap}.scenario-delete{background:none;border:none;font-size:1.1rem;color:#cbd5e1;cursor:pointer;padding:0 .25rem;line-height:1}.scenario-delete:hover{color:#ef4444}.scenario-empty{color:#94a3b8;font-size:.85rem;margin:.5rem 0 0}.active-scenario-label{font-size:.85rem;color:#3b82f6;font-weight:500;margin-top:.35rem}@media print{.app-header,.guidance-section,.section-divider,.runway-wizard,.email-capture,.export-section,.app-footer,.error-banner,.user-bar,.scenario-manager{display:none!important}.app{max-width:100%;padding:0}.runway-result{margin-top:0}.result-hero,.summary-cards,.tips-section{break-inside:avoid}.timeline-table-wrapper{overflow:visible}.bar-chart{break-inside:avoid;-webkit-print-color-adjust:exact;print-color-adjust:exact}.chart-section{break-inside:avoid}.bar{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.whatif-panel{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:1.5rem;margin-top:1.5rem}.whatif-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none}.whatif-header h3{margin:0;font-size:1.15rem}.whatif-toggle{font-size:.9rem;color:#64748b}.whatif-teaser{margin:.5rem 0 0;color:#64748b;font-size:.9rem}.whatif-summary{display:flex;gap:1.5rem;flex-wrap:wrap;background:#dcfce7;border-radius:8px;padding:.75rem 1rem;margin:1rem 0}.whatif-summary-item{display:flex;flex-direction:column;gap:.15rem}.whatif-summary-label{font-size:.75rem;color:#475569;text-transform:uppercase;letter-spacing:.02em}.whatif-summary-value{font-size:1.1rem;font-weight:700;color:#1e293b}.whatif-positive{color:#16a34a}.whatif-muted{color:#94a3b8;text-decoration:line-through}.whatif-categories{display:flex;flex-direction:column;gap:1rem;margin:1rem 0}.whatif-category{background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:.75rem 1rem;transition:border-color .2s}.whatif-category-changed{border-color:#86efac;background:#f0fdf4}.whatif-category-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.whatif-category-label{font-weight:600;font-size:.95rem;color:#1e293b}.whatif-category-values{display:flex;align-items:center;gap:.5rem}.whatif-original-value{font-size:.85rem;color:#94a3b8;text-decoration:line-through}.whatif-current-value{font-weight:700;font-size:1rem}.whatif-savings-badge{font-size:.75rem;font-weight:600;color:#16a34a;background:#dcfce7;padding:.1rem .4rem;border-radius:4px}.whatif-slider{width:100%;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#e2e8f0;border-radius:3px;outline:none;cursor:pointer}.whatif-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#16a34a;cursor:pointer;border:2px solid #fff;box-shadow:0 1px 3px #0003}.whatif-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#16a34a;cursor:pointer;border:2px solid #fff;box-shadow:0 1px 3px #0003}.whatif-presets{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.5rem}.whatif-preset-btn{font-size:.75rem;padding:.2rem .5rem;border:1px solid #d1d5db;border-radius:4px;background:#fff;color:#475569;cursor:pointer;transition:all .15s}.whatif-preset-btn:hover{background:#f0fdf4;border-color:#86efac;color:#16a34a}.whatif-actions{display:flex;gap:.75rem;margin-top:1rem}.btn-whatif-calculate{flex:1;padding:.7rem 1.25rem;background:#16a34a;color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.95rem;cursor:pointer;transition:background .15s}.btn-whatif-calculate:hover:not(:disabled){background:#15803d}.btn-whatif-calculate:disabled{opacity:.5;cursor:not-allowed}.btn-whatif-reset{padding:.7rem 1.25rem;background:transparent;color:#64748b;border:1px solid #d1d5db;border-radius:8px;font-weight:500;cursor:pointer;transition:all .15s}.btn-whatif-reset:hover{background:#f1f5f9;color:#1e293b}.comparison-section{margin-top:1.5rem;margin-bottom:1.5rem}.comparison-section h3{margin-bottom:1rem}.comparison-hero{display:flex;flex-direction:column;align-items:center;gap:.25rem;margin-bottom:1.25rem}.comparison-delta-positive{font-size:2rem;font-weight:800;color:#16a34a}.comparison-delta-label{font-size:1rem;color:#475569}.comparison-cards{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:1.5rem}.comparison-card{flex:1;max-width:240px;text-align:center;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem;background:#fafbfc}.comparison-card-original{opacity:.7}.comparison-card-reduced{border-color:#86efac;background:#f0fdf4}.comparison-card-tag{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:#64748b;font-weight:600;margin-bottom:.5rem}.comparison-card-months{font-size:2.5rem;font-weight:800;line-height:1}.comparison-card-label{font-size:.9rem;color:#64748b;margin-bottom:.5rem}.comparison-card-detail{font-size:.8rem;color:#94a3b8}.comparison-card-severity{font-size:.85rem;font-weight:600;margin-top:.4rem}.comparison-arrow{font-size:1.5rem;color:#16a34a;font-weight:700}.comparison-chart-section{margin-top:1.5rem}.comparison-chart-section h4{margin-bottom:.75rem;font-size:.95rem;color:#475569}.comparison-chart{display:flex;align-items:flex-end;gap:3px;height:160px;border-bottom:2px solid #e2e8f0;padding-bottom:.25rem}.comparison-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end}.comparison-bar-pair{display:flex;gap:1px;align-items:flex-end;width:100%;height:100%}.comparison-bar{flex:1;min-width:3px;border-radius:2px 2px 0 0;transition:height .3s}.comparison-bar-label{font-size:.6rem;color:#94a3b8;margin-top:.15rem}.comparison-legend{display:flex;gap:1.25rem;justify-content:center;margin-top:.75rem}.comparison-legend-item{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:#475569}.comparison-legend-dot{width:12px;height:12px;border-radius:2px;display:inline-block}
