.bill-forecaster{--bg:#fff;--text:#0f172a;--muted:#64748b;--border:#4b5563;--soft:#f8fafc;--accent:#5aa7c4;--accent-hover:#4b97b4;--focus:rgba(90,167,196,.28);color:var(--text);font-family:inherit;margin:56px auto;max-width:860px;padding:0 16px}.bill-forecaster .bf-card{background:var(--bg);border:1px solid var(--border);border-radius:18px;padding:32px}.bill-forecaster .bf-title{font-size:26px;letter-spacing:-.02em;line-height:1.3;margin:0 0 10px}.bill-forecaster .bf-subtitle{color:var(--muted);font-size:15px;line-height:1.7;margin:0 0 18px}.bill-forecaster .bf-progress{align-items:center;display:flex;gap:10px;margin:18px 0;user-select:none}.bill-forecaster .bf-progress-step{align-items:center;color:var(--muted);display:flex;font-size:13px;font-weight:650;gap:8px;white-space:nowrap}.bill-forecaster .bf-dot{background:#fff;border:2px solid var(--border);border-radius:999px;height:10px;width:10px}.bill-forecaster .bf-progress-line{background:rgba(75,85,99,.35);flex:1;height:1px;min-width:14px}.bill-forecaster .bf-progress-step.is-active .bf-dot,.bill-forecaster .bf-progress-step.is-complete .bf-dot{background:rgba(90,167,196,.1);border-color:rgba(90,167,196,.85)}.bill-forecaster .bf-progress-step.is-active,.bill-forecaster .bf-progress-step.is-complete{color:var(--text)}.bill-forecaster .bf-step-title{font-size:14px;font-weight:800;margin:22px 0 14px}.bill-forecaster .bf-alert{background:#fff;border:1px solid var(--border);border-radius:12px;font-size:14px;margin-top:10px;padding:12px}.bill-forecaster .bf-alert.is-error{background:rgba(185,28,28,.06);border-color:rgba(185,28,28,.7);color:#7f1d1d}.bill-forecaster .bf-form{display:grid;gap:18px;grid-template-columns:1fr}@media (min-width:720px){.bill-forecaster .bf-form.bf-one-col{gap:18px 20px;grid-template-columns:1fr 1fr}.bill-forecaster .bf-full{grid-column:1/-1}}.bill-forecaster .field{display:flex;flex-direction:column;gap:6px}.bill-forecaster label{font-size:13px;font-weight:650;line-height:1.4}.bill-forecaster input[type=email],.bill-forecaster input[type=number],.bill-forecaster input[type=text],.bill-forecaster select{background:#fff;border:1px solid var(--border);border-radius:12px;color:var(--text);font-size:15px;outline:none;padding:14px 16px;transition:border-color .14s ease,box-shadow .14s ease;width:100%}.bill-forecaster input:focus,.bill-forecaster select:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--focus)}.bill-forecaster select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,#64748b 0),linear-gradient(135deg,#64748b 50%,transparent 0);background-position:calc(100% - 18px) 52%,calc(100% - 12px) 52%;background-repeat:no-repeat;background-size:6px 6px;padding-right:42px}.bill-forecaster .bf-input-prefix{position:relative}.bill-forecaster .bf-prefix{color:#94a3b8;font-weight:700;left:14px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.bill-forecaster .bf-input-prefix input{padding-left:34px}.bill-forecaster #utility_provider_other_wrap{border-left:3px solid rgba(75,85,99,.45);margin-top:-8px;padding-left:12px}.bill-forecaster .bf-help{color:var(--muted);font-size:12px;line-height:1.5}.bill-forecaster .bf-pill-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}.bill-forecaster .bf-pill{align-items:center;background:#fff;border:1px solid var(--border);border-radius:999px;color:var(--text);cursor:pointer;display:inline-flex;font-size:14px;font-weight:650;gap:8px;justify-content:center;padding:10px 14px;transition:background .14s ease,border-color .14s ease,box-shadow .14s ease;user-select:none}.bill-forecaster .bf-pill input{margin:0}.bill-forecaster .bf-pill:hover{background:var(--soft)}.bill-forecaster .bf-pill.is-selected{background:rgba(90,167,196,.1);border-color:rgba(90,167,196,.9);box-shadow:0 0 0 4px var(--focus)}.bill-forecaster .bf-forecast-intro{color:var(--text);font-size:14px;line-height:1.6;margin:8px 0 14px}.bill-forecaster .bf-forecast-intro strong{font-weight:900}.bill-forecaster .bf-results{border-top:none;display:grid;gap:16px;grid-template-columns:repeat(2,minmax(0,1fr));margin-top:6px;padding-top:0}.bill-forecaster .bf-results-grid{display:contents}.bill-forecaster .bf-metric,.bill-forecaster .bf-total{background:#fff;border:1px solid var(--border);border-radius:14px;padding:18px}.bill-forecaster .bf-total{background:rgba(90,167,196,.06)}.bill-forecaster .bf-metric-label,.bill-forecaster .bf-total-label{color:var(--muted);font-size:12px;margin:0 0 6px}.bill-forecaster .bf-metric-value{font-size:20px;font-weight:900;letter-spacing:-.01em}.bill-forecaster .bf-total-value{font-size:22px;font-weight:950;letter-spacing:-.01em}.bill-forecaster .bf-note{color:var(--muted);font-size:12px;grid-column:1/-1;line-height:1.5;margin-top:2px}@media (max-width:560px){.bill-forecaster .bf-results{grid-template-columns:1fr}}.bill-forecaster .bf-pre-cta{color:var(--text);font-size:16px;font-weight:900;line-height:1.6;margin:14px 0 10px}.bill-forecaster .bf-actions{margin-top:18px}.bill-forecaster .bf-actions-split{display:flex;gap:12px}.bill-forecaster .bf-actions-split .bf-btn{width:100%}.bill-forecaster .bf-btn{align-items:center;background:var(--accent);border:none;border-radius:999px;color:#fff;cursor:pointer;display:inline-flex;font-size:15px;font-weight:350;justify-content:center;padding:16px 22px;transition:background .14s ease,transform 80ms ease,opacity .14s ease}.bill-forecaster .bf-btn:hover{background:var(--accent-hover)}.bill-forecaster .bf-btn:active{transform:translateY(1px)}.bill-forecaster .bf-btn:disabled{cursor:not-allowed;opacity:.6}.bill-forecaster .bf-btn-secondary{background:transparent;border:1px solid var(--border);color:var(--text)}.bill-forecaster .bf-btn-secondary:hover{background:rgba(15,23,42,.03)}.bill-forecaster .bf-success{background:rgba(22,163,74,.06);border:1px solid rgba(22,163,74,.35);border-radius:14px;margin-top:12px;padding:16px}.bill-forecaster .bf-success-title{font-weight:900;margin-bottom:6px}.bill-forecaster .bf-success-body{color:#14532d}.bill-forecaster #monthly_bill,.bill-forecaster #zip{width:10ch}.bill-forecaster #firstname,.bill-forecaster #lastname{width:22ch}.bill-forecaster #email{width:36ch}.bill-forecaster #email,.bill-forecaster #firstname,.bill-forecaster #lastname,.bill-forecaster #monthly_bill,.bill-forecaster #zip{max-width:100%}