*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--blue-50: #eff6ff;--blue-100: #dbeafe;--blue-500: #3b82f6;--blue-600: #2563eb;--blue-700: #1d4ed8;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--color-pi: #3b82f6;--color-tax: #8b5cf6;--color-insurance: #06b6d4;--color-pmi: #f59e0b;--color-hoa: #ec4899;--radius: 10px;--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .06);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .1)}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--gray-50);color:var(--gray-800);line-height:1.5;min-height:100vh}.app-header{text-align:center;padding:2rem 1rem 1rem}.app-header h1{font-size:1.75rem;font-weight:700;color:var(--gray-900)}.subtitle{color:var(--gray-500);font-size:1rem;margin-top:.25rem}.reset-btn{margin-top:.5rem;padding:.3rem .75rem;font-size:.75rem;border:1px solid var(--gray-300);border-radius:6px;background:#fff;color:var(--gray-500);cursor:pointer;transition:all .15s}.reset-btn:hover{border-color:#dc2626;color:#dc2626}.layout{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;max-width:1200px;margin:0 auto;padding:1rem 1.5rem 3rem;align-items:start}.inputs-column{display:flex;flex-direction:column;gap:1.25rem}.results-column{display:flex;flex-direction:column;gap:1.25rem;position:sticky;top:1rem}.card{background:#fff;border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow)}.card h2{font-size:1.1rem;font-weight:600;color:var(--gray-900);margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--gray-100)}.card h3{font-size:1rem;font-weight:600;color:var(--gray-700);margin-bottom:1rem}.field{margin-bottom:1.25rem}.field:last-child{margin-bottom:0}.field label{display:block;font-size:.875rem;font-weight:500;color:var(--gray-600);margin-bottom:.375rem}.field-hint{font-size:.75rem;color:var(--gray-400);margin-top:.25rem}.input-with-prefix,.input-with-suffix{display:flex;align-items:center;border:1px solid var(--gray-300);border-radius:8px;overflow:hidden;transition:border-color .15s,box-shadow .15s}.input-with-prefix:focus-within,.input-with-suffix:focus-within{border-color:var(--blue-500);box-shadow:0 0 0 3px #3b82f626}.prefix,.suffix{padding:.5rem .75rem;background:var(--gray-50);color:var(--gray-500);font-size:.9rem;font-weight:500;-webkit-user-select:none;user-select:none;border-right:1px solid var(--gray-200)}.suffix{border-right:none;border-left:1px solid var(--gray-200)}.input-with-prefix input,.input-with-suffix input{border:none;outline:none;padding:.5rem .75rem;font-size:.95rem;width:100%;background:transparent}select{width:100%;padding:.5rem .75rem;font-size:.95rem;border:1px solid var(--gray-300);border-radius:8px;background:#fff;color:var(--gray-800);cursor:pointer;outline:none;transition:border-color .15s,box-shadow .15s}select:focus{border-color:var(--blue-500);box-shadow:0 0 0 3px #3b82f626}input[type=range]{width:100%;margin-top:.5rem;accent-color:var(--blue-600);cursor:pointer}.range-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--gray-400);margin-top:.125rem}.button-group{display:flex;gap:.375rem;flex-wrap:wrap}.button-group button{padding:.4rem .85rem;border:1px solid var(--gray-300);border-radius:6px;background:#fff;color:var(--gray-600);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s}.button-group button:hover{border-color:var(--blue-500);color:var(--blue-600)}.button-group button.active{background:var(--blue-600);border-color:var(--blue-600);color:#fff}.loan-type-info{font-size:.75rem;color:var(--gray-500);margin-top:.375rem;line-height:1.4;padding:.5rem .625rem;background:var(--blue-50);border-radius:6px;border:1px solid var(--blue-100)}.loan-type-info:empty{display:none}.dp-custom-row{margin-top:.5rem}.dp-custom-row .input-with-suffix{max-width:120px}.dp-amount{font-size:.8rem;color:var(--gray-500);margin-top:.375rem}.income-recommendation{background:var(--blue-50);border:1px solid var(--blue-100);border-radius:8px;padding:.875rem 1rem;margin-bottom:1.25rem}.income-rec-header{display:flex;align-items:center;gap:.375rem;font-size:.8rem;font-weight:500;color:var(--gray-500)}.income-rec-icon{font-size:1rem}.income-rec-amount{font-size:1.5rem;font-weight:700;color:var(--gray-900);margin:.25rem 0}.income-rec-detail{font-size:.8rem;color:var(--gray-500);line-height:1.4}.income-rec-detail .rec-over{color:#dc2626;font-weight:600}.income-rec-detail .rec-under{color:#16a34a;font-weight:600}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}.results-card{border-top:3px solid var(--blue-500)}.total-payment-label{font-size:.85rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.total-payment{font-size:2.75rem;font-weight:700;color:var(--gray-900);line-height:1.2;margin:.25rem 0 1.25rem}.breakdown-bar{display:flex;height:12px;border-radius:6px;overflow:hidden;background:var(--gray-100);margin-bottom:1rem}.bar-segment{transition:width .3s ease;min-width:0}.bar-pi{background:var(--color-pi)}.bar-tax{background:var(--color-tax)}.bar-insurance{background:var(--color-insurance)}.bar-pmi{background:var(--color-pmi)}.bar-hoa{background:var(--color-hoa)}.breakdown-legend{display:flex;flex-direction:column;gap:.5rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--gray-600)}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-value{margin-left:auto;font-weight:600;color:var(--gray-800)}.verdict-badge{display:inline-block;padding:.4rem 1rem;border-radius:999px;font-size:.95rem;font-weight:600;margin-bottom:.5rem}.verdict-description{font-size:.85rem;color:var(--gray-500);margin-bottom:1rem}.dti-display{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.dti-item{text-align:center;padding:.75rem;background:var(--gray-50);border-radius:8px}.dti-label{font-size:.75rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.03em}.dti-value{font-size:1.5rem;font-weight:700;color:var(--gray-900);margin:.125rem 0}.dti-sublabel{font-size:.7rem;color:var(--gray-400)}.warnings{display:flex;flex-direction:column;gap:.5rem}.warning-item{display:flex;align-items:flex-start;gap:.5rem;padding:.625rem .75rem;background:#fef3c7;border-radius:6px;font-size:.8rem;color:#92400e;line-height:1.4}.warning-icon{flex-shrink:0;font-size:.9rem}.budget-rows{display:flex;flex-direction:column;gap:.5rem}.budget-row{display:flex;justify-content:space-between;padding:.5rem 0;font-size:.9rem;border-bottom:1px solid var(--gray-100)}.budget-row:last-child{border-bottom:none}.budget-minus span:last-child{color:var(--gray-500)}.budget-remaining{font-weight:700;font-size:1rem;border-top:2px solid var(--gray-200);padding-top:.75rem;margin-top:.25rem}.budget-remaining.negative span:last-child{color:#dc2626}.budget-remaining.positive span:last-child{color:#16a34a}.scenario-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.scenario-card{padding:.875rem;border-radius:8px;border:1px solid var(--gray-200);text-align:center;transition:border-color .15s,box-shadow .15s}.scenario-card.active{border-color:var(--blue-500);box-shadow:0 0 0 2px #3b82f633}.scenario-dp{font-size:1.1rem;font-weight:700;color:var(--gray-900);margin-bottom:.125rem}.scenario-dp-amount{font-size:.7rem;color:var(--gray-400);margin-bottom:.5rem}.scenario-payment{font-size:1rem;font-weight:600;color:var(--gray-700)}.scenario-payment-label{font-size:.65rem;color:var(--gray-400);text-transform:uppercase;letter-spacing:.03em}.scenario-verdict{display:inline-block;margin-top:.375rem;padding:.15rem .5rem;border-radius:999px;font-size:.65rem;font-weight:600}.tooltip-trigger{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;border:1px solid var(--gray-300);background:var(--gray-50);color:var(--gray-400);font-size:.7rem;font-weight:700;cursor:pointer;position:relative;vertical-align:middle;margin-left:.25rem;transition:all .15s;padding:0;line-height:1}.tooltip-trigger:hover{border-color:var(--blue-500);color:var(--blue-600);background:var(--blue-50)}.tooltip-trigger-sm{width:16px;height:16px;font-size:.6rem}.tooltip-bubble{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--gray-800);color:#fff;padding:.625rem .875rem;border-radius:8px;font-size:.78rem;font-weight:400;line-height:1.5;width:280px;z-index:100;box-shadow:0 4px 12px #0003;pointer-events:none;animation:tooltipFadeIn .15s ease}.tooltip-bubble:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:var(--gray-800)}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.insight-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1rem}.insight-box{text-align:center;padding:.75rem;background:var(--gray-50);border-radius:8px}.insight-label{font-size:.7rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.03em}.insight-value{font-size:1.25rem;font-weight:700;color:var(--gray-900);margin:.125rem 0}.insight-sublabel{font-size:.7rem;color:var(--gray-400)}.insight-bar-container{margin-bottom:1rem}.insight-bar-label{font-size:.8rem;color:var(--gray-600);margin-bottom:.375rem}.insight-bar-label span{font-weight:700}.insight-bar{display:flex;height:10px;border-radius:5px;overflow:hidden;background:var(--gray-100)}.insight-bar-fill{transition:width .3s ease}.insight-bar-interest{background:#ef4444}.insight-bar-principal{background:#22c55e}.insight-bar-legend{display:flex;gap:1rem;margin-top:.375rem;font-size:.75rem;color:var(--gray-500)}.insight-bar-legend span{display:flex;align-items:center;gap:.25rem}.extra-payment-input{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}.extra-payment-input label{font-size:.8rem;font-weight:500;color:var(--gray-600);white-space:nowrap}.input-compact{max-width:120px}.insight-callout{padding:.75rem 1rem;border-radius:8px;font-size:.82rem;line-height:1.5}.insight-callout-blue{background:var(--blue-50);border:1px solid var(--blue-100);color:var(--gray-700)}.insight-callout-amber{background:#fffbeb;border:1px solid #fde68a;color:#92400e}.insight-callout strong{font-weight:700}.rate-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:.5rem}.rate-card{text-align:center;padding:.625rem .375rem;border-radius:8px;border:1px solid var(--gray-200)}.rate-card.rate-current{border-color:var(--blue-500);background:var(--blue-50)}.rate-card-rate{font-size:.85rem;font-weight:700;color:var(--gray-900)}.rate-card-payment{font-size:.8rem;font-weight:600;color:var(--gray-700);margin:.125rem 0}.rate-card-diff{font-size:.7rem;font-weight:600}.rate-card-diff.rate-savings{color:#16a34a}.rate-card-diff.rate-increase{color:#dc2626}.rate-card-label{font-size:.6rem;color:var(--gray-400);text-transform:uppercase}.tax-deductions{margin-bottom:.75rem}.tax-deductions .budget-row{font-size:.8rem}.tax-cap{font-size:.65rem;color:#ca8a04;font-weight:500}.tax-comparison{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:.5rem}.tax-scenario{padding:.625rem;border-radius:8px;border:1px solid var(--gray-200)}.tax-scenario.tax-benefit{border-color:#bbf7d0;background:#f0fdf4}.tax-scenario.tax-no-benefit{background:var(--gray-50)}.tax-filing{font-size:.75rem;font-weight:700;color:var(--gray-800);margin-bottom:.25rem}.tax-std{font-size:.7rem;color:var(--gray-500)}.tax-savings{font-size:.75rem;font-weight:600;color:#16a34a;margin-top:.25rem}.tax-effective{font-size:.7rem;color:var(--gray-600);margin-top:.125rem}.tax-no-save{font-size:.7rem;color:var(--gray-400);margin-top:.25rem;font-style:italic}.tax-note{font-size:.65rem;color:var(--gray-400);font-style:italic}.credit-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.credit-card{text-align:center;padding:.5rem .25rem;border-radius:8px;border:1px solid var(--gray-200)}.credit-card.credit-active{border-color:var(--blue-500);background:var(--blue-50)}.credit-score{font-size:.75rem;font-weight:700;color:var(--gray-900)}.credit-tier{font-size:.6rem;color:var(--gray-400);margin-bottom:.25rem}.credit-rate{font-size:.7rem;font-weight:600;color:var(--gray-700)}.credit-payment{font-size:.75rem;font-weight:600;color:var(--gray-800)}.credit-diff{font-size:.65rem;font-weight:600}.credit-save{color:#16a34a}.credit-extra{color:#dc2626}.credit-current-label{color:var(--blue-600);font-size:.6rem}.credit-total-int{font-size:.55rem;color:var(--gray-400);margin-top:.125rem}.true-cost-note{font-size:.75rem;color:var(--gray-500);margin-top:.75rem;padding:.625rem .75rem;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;line-height:1.5}.true-cost-note strong{color:var(--gray-700)}.closing-details{margin-top:.75rem}.closing-details summary{font-size:.8rem;color:var(--blue-600);cursor:pointer;font-weight:500}.closing-details summary:hover{color:var(--blue-700)}.closing-breakdown{margin-top:.5rem;display:flex;flex-direction:column;gap:.25rem}.closing-item{display:flex;justify-content:space-between;font-size:.75rem;color:var(--gray-600);padding:.25rem 0;border-bottom:1px solid var(--gray-50)}.closing-item span:last-child{font-weight:500;color:var(--gray-700)}.amort-chart{display:flex;flex-direction:column;gap:.375rem;margin-bottom:1rem}.amort-bar-row{display:flex;align-items:center;gap:.5rem}.amort-bar-year{font-size:.7rem;font-weight:600;color:var(--gray-500);width:32px;text-align:right;flex-shrink:0}.amort-bar-track{flex:1;height:8px;background:var(--gray-100);border-radius:4px;overflow:hidden}.amort-bar-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#22c55e);border-radius:4px;transition:width .3s ease}.amort-bar-pct{font-size:.7rem;font-weight:600;color:var(--gray-700);width:32px;flex-shrink:0}.amort-table-wrap{overflow-x:auto;max-height:240px;overflow-y:auto}.amort-table{width:100%;border-collapse:collapse;font-size:.75rem}.amort-table th{text-align:left;padding:.375rem .5rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.03em;font-size:.65rem;border-bottom:2px solid var(--gray-200);position:sticky;top:0;background:#fff}.amort-table td{padding:.375rem .5rem;color:var(--gray-700);border-bottom:1px solid var(--gray-100)}.amort-table tr:last-child td{font-weight:600}.rvb-monthly{display:flex;flex-direction:column;gap:.375rem;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--gray-100)}.rvb-monthly-row{display:flex;justify-content:space-between;font-size:.85rem;color:var(--gray-600)}.rvb-monthly-row span:last-child{font-weight:600;color:var(--gray-800)}.rvb-timeline-header{font-size:.75rem;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.5rem}.rvb-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:.75rem}.rvb-card{padding:.625rem;border-radius:8px;border:1px solid var(--gray-200)}.rvb-card.rvb-buy-wins{border-color:#bbf7d0;background:#f0fdf4}.rvb-card.rvb-rent-wins{border-color:#fde68a;background:#fffbeb}.rvb-years{font-size:.8rem;font-weight:700;color:var(--gray-900);margin-bottom:.375rem}.rvb-row{display:flex;justify-content:space-between;font-size:.7rem;color:var(--gray-500);margin-bottom:.125rem}.rvb-val{font-weight:600;color:var(--gray-700)}.rvb-winner{font-size:.7rem;font-weight:600;margin-top:.375rem;padding-top:.375rem;border-top:1px solid var(--gray-100)}.rvb-buy-wins .rvb-winner{color:#16a34a}.rvb-rent-wins .rvb-winner{color:#ca8a04}.rvb-assumptions{font-size:.65rem;color:var(--gray-400);font-style:italic}.afford-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.afford-card{text-align:center;padding:.875rem .5rem;border-radius:8px;border:1px solid var(--gray-200)}.afford-label{display:inline-block;padding:.15rem .6rem;border-radius:999px;font-size:.7rem;font-weight:600;margin-bottom:.25rem}.afford-sublabel{font-size:.65rem;color:var(--gray-400);margin-bottom:.5rem}.afford-price{font-size:1.15rem;font-weight:700;color:var(--gray-900)}.afford-payment{font-size:.75rem;color:var(--gray-500);margin-bottom:.375rem}.afford-over{font-size:.7rem;color:#dc2626;font-weight:500}.afford-under{font-size:.7rem;color:#16a34a;font-weight:500}.readiness-badge{display:inline-block;padding:.35rem .875rem;border-radius:999px;font-size:.85rem;font-weight:600;margin-bottom:.75rem}.readiness-checks{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.readiness-item{display:flex;gap:.5rem;align-items:flex-start}.readiness-icon{flex-shrink:0;width:20px;text-align:center;font-size:.85rem}.readiness-label{font-size:.8rem;font-weight:600;color:var(--gray-800)}.readiness-detail{font-size:.7rem;color:var(--gray-500);line-height:1.4}.readiness-docs{font-size:.7rem;color:var(--gray-500);padding:.5rem .625rem;background:var(--gray-50);border-radius:6px;line-height:1.5}.readiness-docs strong{color:var(--gray-700)}.disclaimer{font-size:.75rem;color:var(--gray-400);text-align:center;padding:.5rem 0;line-height:1.5}@media(max-width:860px){.layout{grid-template-columns:1fr;padding:1rem}.results-column{position:static}.total-payment{font-size:2.25rem}}@media(max-width:480px){.app-header h1{font-size:1.35rem}.card{padding:1.25rem}.button-group button{padding:.35rem .65rem;font-size:.8rem}.dti-display,.insight-grid{grid-template-columns:1fr}.rate-grid{grid-template-columns:repeat(3,1fr)}.credit-grid{grid-template-columns:repeat(2,1fr)}.afford-grid,.rvb-grid,.tax-comparison{grid-template-columns:1fr}}
