/* ═══════════════════════════════════════════════════════════════
   ComparePower Help Me Choose Guide — v2 Redesign
   Loaded conditionally via ?design=v2 query param
   ALL rules scoped to section.cpg-active (the guide wrapper)
   or .page-id-31585:has(section.cpg-active) for parent overrides
   ═══════════════════════════════════════════════════════════════ */

/* ── TOKENS ── */
section.cpg-active {
  --cpg-brand: #0091BF;
  --cpg-brand-light: #33BEE8;
  --cpg-brand-dark: #005B77;
  --cpg-brand-bg: #e8f7fc;
  --cpg-cta: #EC694B;
  --cpg-cta-hover: #d95a3e;
  --cpg-text: #2d2d44;
  --cpg-text-mid: #5E5E5E;
  --cpg-text-light: #8e8ea0;
  --cpg-border: #e4e5ea;
  --cpg-bg-light: #f5f6f8;
  --cpg-white: #fff;
  --cpg-radius: 14px;
  --cpg-radius-sm: 8px;
  --cpg-shadow: 0 2px 16px rgba(0,0,0,0.07);
  --cpg-ease: 0.18s ease;
  --cpg-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --cpg-width: 780px;
  --cpg-green: #16a34a;
  --cpg-green-bg: #f0fdf4;
}

/* ── PARENT LAYOUT — scoped to THIS page only ── */
.page-id-31585:has(section.cpg-active) #main {
  padding-top: 0 !important;
}
.page-id-31585:has(section.cpg-active) .main-holder {
  margin: 0 auto !important;
  max-width: var(--cpg-width, 780px) !important;
  width: 100% !important;
  padding: 0 20px !important;
  display: block !important;
}
.page-id-31585:has(section.cpg-active) .main-holder > #content {
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  float: none !important;
}
.page-id-31585:has(section.cpg-active) .main-holder .entry {
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  float: none !important;
}
/* ── COMPACT HEADER BANNER ── */
/* Restyle the WP blue banner: smaller, left-justified, with tagline */
.page-id-31585:has(section.cpg-active) .top-info-block.inner {
  padding: 28px 0 24px !important;
  margin-bottom: 0 !important;
}
.page-id-31585:has(section.cpg-active) .top-info-block.inner .container {
  max-width: 780px !important;
  margin: 0 auto !important;
  padding: 0 20px !important;
  position: relative;
}
.page-id-31585:has(section.cpg-active) .top-info-block.inner h1 {
  text-align: left !important;
  font-size: 28px !important;
  font-weight: 800 !important;
  margin: 0 0 4px !important;
  line-height: 1.2 !important;
}
/* Add tagline under h1 via pseudo-element */
.page-id-31585:has(section.cpg-active) .top-info-block.inner h1::after {
  content: 'Find your best electric plan in minutes.' !important;
  display: block !important;
  font-size: 15px !important;
  font-weight: 400 !important;
  opacity: 0.85;
  margin-top: 6px;
  letter-spacing: 0;
  line-height: 1.4;
}
/* Hide the separate <h2> tagline that sits outside the banner */
.page-id-31585:has(section.cpg-active) .entry > h2:first-child {
  display: none !important;
}

/* ── HIDE UNUSED ELEMENTS ── */
section.cpg-active ~ .find_best_rates_headings,
.page-id-31585:has(section.cpg-active) .find_best_rates_headings {
  display: none !important;
}
.page-id-31585:has(section.cpg-active) .completed_actions {
  display: none !important;
}

/* ── SECTION ROOT ── */
section.find_best_rates.cpg-active {
  visibility: visible !important;
  font-family: var(--cpg-font) !important;
  color: var(--cpg-text);
  max-width: var(--cpg-width) !important;
  width: 100% !important;
  margin: 12px auto 48px !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
  float: none !important;
  position: static !important;
  left: auto !important;
  transform: none !important;
}
section.cpg-active *,
section.cpg-active *::before,
section.cpg-active *::after {
  box-sizing: border-box;
}

/* ── STEP CARD ── */
section.cpg-active .step-content {
  background: var(--cpg-white) !important;
  border-radius: var(--cpg-radius) !important;
  box-shadow: var(--cpg-shadow) !important;
  border: 1px solid var(--cpg-border) !important;
  overflow: hidden;
  min-height: auto !important;
  width: 100% !important;
  position: relative;
}

/* ── STEP HEADER ── */
section.cpg-active .step-header {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  padding: 16px 24px !important;
  background: linear-gradient(135deg, var(--cpg-brand) 0%, var(--cpg-brand-light) 100%) !important;
  border: none !important;
  border-radius: 0 !important;
  margin: 0 !important;
  font-size: inherit !important;
}
section.cpg-active h5.dark_header {
  display: flex !important;
  align-items: center;
  gap: 10px;
  color: var(--cpg-white) !important;
  font-family: var(--cpg-font) !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
  margin: 0 !important;
  padding: 0 !important;
  background: none !important;
  border: none !important;
}
/* Step icon becomes numbered circle — kill all background-images from original CSS */
section.cpg-active .step-header .step-icon,
section.cpg-active .step-header .step-icon.step-icon1,
section.cpg-active .step-header .step-icon.step-icon2,
section.cpg-active .step-header .step-icon.step-icon3,
section.cpg-active .step-header .step-icon.step-icon4,
section.cpg-active .step-header .step-icon.step-icon5 {
  width: 30px !important;
  height: 30px !important;
  min-width: 30px;
  background: rgba(255,255,255,0.2) !important;
  background-image: none !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  filter: none !important;
  opacity: 1 !important;
  margin: 0 !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  color: var(--cpg-white) !important;
  background-size: 0 !important;
}
/* Step numbers via CSS */
section.cpg-active #step1 .step-icon::after { content: '1'; }
section.cpg-active #step2 .step-icon::after { content: '2'; }
section.cpg-active #step3 .step-icon::after { content: '3'; }
section.cpg-active #step4 .step-icon::after { content: '4'; }
section.cpg-active #step5 .step-icon::after { content: '5'; }
section.cpg-active .step-header .step-number {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: rgba(255,255,255,0.8) !important;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  white-space: nowrap;
}

/* ── INNER CONTENT ── */
section.cpg-active .step .inner {
  max-width: none !important;
  margin: 0 !important;
}
section.cpg-active .step .inner .full_question {
  padding: 24px 24px 28px !important;
  position: relative;
}
section.cpg-active .step .full_question > p,
section.cpg-active .step .inner .full_question > p {
  font-family: var(--cpg-font) !important;
  font-weight: 500 !important;
  font-size: 15px !important;
  line-height: 1.55 !important;
  color: var(--cpg-text) !important;
  margin: 0 0 4px !important;
}
section.cpg-active .step .full_question > p strong {
  font-weight: 700;
}

/* ── CHOICE BUTTONS (Steps 1 & 2) ── */
section.cpg-active .step .inner .answers {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
  padding: 14px 0 0 !important;
  flex-wrap: nowrap !important;
}
section.cpg-active .step_btn {
  display: flex !important;
  align-items: center;
  gap: 12px;
  background: var(--cpg-white) !important;
  border: 2px solid var(--cpg-border) !important;
  border-radius: var(--cpg-radius-sm) !important;
  padding: 14px 16px !important;
  font-family: var(--cpg-font) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  color: var(--cpg-text) !important;
  cursor: pointer;
  transition: all var(--cpg-ease);
  margin: 0 0 8px !important;
  width: 100% !important;
  text-align: left !important;
  line-height: 1.4 !important;
  height: auto !important;
  min-height: 0 !important;
  float: none !important;
  position: relative;
  outline: none !important;
}
section.cpg-active .step_btn::before {
  content: '' !important;
  width: 20px !important;
  height: 20px !important;
  min-width: 20px;
  border-radius: 50% !important;
  border: 2px solid var(--cpg-border) !important;
  display: block !important;
  flex-shrink: 0;
  position: static !important;
  transform: none !important;
  transition: all var(--cpg-ease);
  background: var(--cpg-white) !important;
  top: auto !important;
  left: auto !important;
  margin: 0 !important;
}
section.cpg-active .step_btn::after {
  display: none !important;
}
section.cpg-active .step_btn:hover {
  border-color: var(--cpg-brand-light) !important;
  background: var(--cpg-bg-light) !important;
}
section.cpg-active .step_btn.selected {
  border-color: var(--cpg-brand) !important;
  background: var(--cpg-brand-bg) !important;
}
section.cpg-active .step_btn.selected::before {
  background: var(--cpg-brand) !important;
  border-color: var(--cpg-brand) !important;
  box-shadow: inset 0 0 0 3px var(--cpg-white) !important;
}

/* ── NAV BUTTONS ── */
section.cpg-active .next_btn_container {
  display: flex !important;
  justify-content: flex-end !important;
  align-items: center;
  gap: 10px;
  margin-top: 20px !important;
  padding: 0 !important;
  position: static !important;
  width: 100% !important;
  max-width: none !important;
  float: none !important;
  clear: both;
  bottom: auto !important;
  right: auto !important;
  left: auto !important;
  flex-wrap: nowrap !important;
}
section.cpg-active .next_btn {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  padding: 11px 28px !important;
  font-family: var(--cpg-font) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  border: none !important;
  border-radius: 50px !important;
  background: var(--cpg-cta) !important;
  color: var(--cpg-white) !important;
  cursor: pointer;
  transition: all var(--cpg-ease);
  height: auto !important;
  width: auto !important;
  min-width: 120px;
  line-height: 1.4 !important;
  margin: 0 !important;
  float: none !important;
}
section.cpg-active .next_btn:hover {
  background: var(--cpg-cta-hover) !important;
  box-shadow: 0 4px 12px rgba(236,105,75,0.3);
}
section.cpg-active .next_btn:disabled,
section.cpg-active .next_btn[disabled] {
  background: var(--cpg-bg-light) !important;
  color: var(--cpg-text-light) !important;
  cursor: not-allowed;
  box-shadow: none !important;
}
section.cpg-active .back_btn {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  padding: 11px 22px !important;
  font-family: var(--cpg-font) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  border: 2px solid var(--cpg-border) !important;
  border-radius: 50px !important;
  background: var(--cpg-white) !important;
  color: var(--cpg-text-mid) !important;
  cursor: pointer;
  transition: all var(--cpg-ease);
  height: auto !important;
  width: auto !important;
  margin: 0 !important;
  float: none !important;
  line-height: 1.4 !important;
}
section.cpg-active .back_btn:hover {
  border-color: var(--cpg-text-light) !important;
  color: var(--cpg-text) !important;
}

/* ── LIVE LINK CALLOUT ── */
section.cpg-active .cpg-livelink-callout {
  display: none;
  align-items: flex-start;
  gap: 14px;
  margin: 0 0 18px !important;
  padding: 16px 18px !important;
  background: var(--cpg-green-bg) !important;
  border: 2px solid var(--cpg-green) !important;
  border-radius: var(--cpg-radius-sm) !important;
  position: relative;
  overflow: visible;
}
section.cpg-active .cpg-livelink-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--cpg-green) !important;
  color: var(--cpg-white) !important;
  font-family: var(--cpg-font) !important;
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  padding: 4px 8px !important;
  border-radius: 4px !important;
  white-space: nowrap;
  flex-shrink: 0;
  margin-top: 2px;
  line-height: 1;
  animation: cpg-badgePulse 2s ease-in-out infinite;
}
@keyframes cpg-badgePulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(22,163,74,0.4); }
  50% { box-shadow: 0 0 0 6px rgba(22,163,74,0); }
}
section.cpg-active .cpg-livelink-body {
  flex: 1;
  min-width: 0;
}
section.cpg-active .cpg-livelink-body strong {
  font-family: var(--cpg-font) !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--cpg-text) !important;
  display: block;
  margin-bottom: 4px !important;
  line-height: 1.3;
}
section.cpg-active .cpg-livelink-body p {
  font-family: var(--cpg-font) !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  color: var(--cpg-text-mid) !important;
  line-height: 1.5 !important;
  margin: 0 !important;
}
section.cpg-active .cpg-livelink-body a {
  color: var(--cpg-green) !important;
  font-weight: 700 !important;
  text-decoration: underline !important;
  text-underline-offset: 2px;
}
section.cpg-active .cpg-livelink-body p a {
  color: var(--cpg-green) !important;
  font-weight: 700 !important;
  text-decoration: underline !important;
  text-underline-offset: 2px;
}
section.cpg-active .cpg-livelink-body p a:hover {
  color: #15803d !important;
}
/* Live Link CTA button — use brand-dark blue to contrast against green callout bg */
section.cpg-active .cpg-livelink-callout .cpg-livelink-body a.cpg-livelink-btn,
section.cpg-active .cpg-livelink-callout a.cpg-livelink-btn,
section.cpg-active a.cpg-livelink-btn,
.cpg-livelink-callout a.cpg-livelink-btn,
a.cpg-livelink-btn,
a#cpg-livelink-btn {
  display: inline-flex !important;
  align-items: center;
  gap: 4px;
  margin-top: 10px !important;
  padding: 10px 22px !important;
  background: var(--cpg-brand-dark, #005B77) !important;
  color: #fff !important;
  font-family: var(--cpg-font) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.3px;
  text-decoration: none !important;
  border-radius: 50px !important;
  border: none !important;
  cursor: pointer;
  transition: all var(--cpg-ease);
  line-height: 1.4;
  -webkit-text-fill-color: #fff !important;
}
section.cpg-active .cpg-livelink-callout .cpg-livelink-body a.cpg-livelink-btn:hover,
section.cpg-active .cpg-livelink-callout a.cpg-livelink-btn:hover,
section.cpg-active a.cpg-livelink-btn:hover,
.cpg-livelink-callout a.cpg-livelink-btn:hover,
a.cpg-livelink-btn:hover,
a#cpg-livelink-btn:hover {
  background: var(--cpg-brand, #0091BF) !important;
  box-shadow: 0 4px 12px rgba(0,91,119,0.3);
  color: #fff !important;
  text-decoration: none !important;
  -webkit-text-fill-color: #fff !important;
}
/* Inline variant — slightly smaller, more compact */
section.cpg-active .cpg-livelink-inline {
  margin: 0 0 14px !important;
  padding: 12px 14px !important;
  background: #f0f9ff !important;
  border-color: var(--cpg-brand-light) !important;
}

/* ── STEP 3: USAGE ── */
section.cpg-active #step3 .vc_row {
  display: block !important;
  margin-top: 12px !important;
  float: none !important;
  width: 100% !important;
  max-width: none !important;
}
section.cpg-active #step3 .vc_row .vc_col-lg-5,
section.cpg-active #step3 .vc_row .vc_col-lg-7 {
  float: none !important;
  width: 100% !important;
  padding: 0 !important;
}
section.cpg-active #step3 .usages {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  max-width: none !important;
  margin: 0 !important;
}
section.cpg-active #step3 .usages.with_inputs {
  grid-template-columns: 1fr;
  margin-top: 8px !important;
}
section.cpg-active #step3 .usages .usage {
  display: block !important;
  font-family: var(--cpg-font) !important;
  font-weight: 400;
  font-size: 13px;
  line-height: 1.45;
  color: var(--cpg-text-mid);
  cursor: pointer;
  margin: 0 !important;
  padding: 12px 14px 12px 38px !important;
  border: 2px solid var(--cpg-border) !important;
  border-radius: var(--cpg-radius-sm) !important;
  transition: all var(--cpg-ease);
  position: relative;
  background: var(--cpg-white) !important;
  width: auto !important;
  height: auto !important;
  float: none !important;
}
section.cpg-active #step3 .usages .usage::before {
  content: '' !important;
  width: 18px !important;
  height: 18px !important;
  border-radius: 50% !important;
  border: 2px solid var(--cpg-border) !important;
  display: block !important;
  position: absolute !important;
  left: 12px !important;
  top: 14px !important;
  transform: none !important;
  transition: all var(--cpg-ease);
  background: var(--cpg-white) !important;
}
section.cpg-active #step3 .usages .usage:hover {
  border-color: var(--cpg-brand-light) !important;
  background: var(--cpg-bg-light) !important;
}
section.cpg-active #step3 .usages .usage.selected {
  border-color: var(--cpg-brand) !important;
  background: var(--cpg-brand-bg) !important;
}
section.cpg-active #step3 .usages .usage.selected::before {
  background: var(--cpg-brand) !important;
  border-color: var(--cpg-brand) !important;
  box-shadow: inset 0 0 0 3px var(--cpg-white) !important;
}
section.cpg-active #step3 .usages .usage .notify {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--cpg-text) !important;
  display: block;
}
section.cpg-active #step3 .usages .usage .cpg-usage-tagline {
  display: block;
  font-size: 12px !important;
  font-weight: 400 !important;
  color: var(--cpg-text-mid) !important;
  line-height: 1.4;
  margin-top: 2px;
}
section.cpg-active #step3 .usages .usage .cpg-usage-tagline .use_value {
  font-weight: 600;
  color: var(--cpg-text);
}
section.cpg-active #step3 .usages .usage .use_value {
  font-size: 12px;
  color: var(--cpg-text-light);
}
/* Hide legacy <br> and loose text in usage buttons (replaced by taglines) */
section.cpg-active #step3 .usages .usage br {
  display: none;
}
/* Custom usage input */
section.cpg-active #step3 .custom_usage input[type=number] {
  border: none !important;
  border-bottom: 2px solid var(--cpg-brand-light) !important;
  font-size: 14px;
  font-weight: 600;
  color: var(--cpg-text);
  background: transparent !important;
  outline: none;
  border-radius: 0 !important;
  padding: 4px 0;
  width: 140px;
}
section.cpg-active #step3 .custom_usage input[type=number]:focus {
  border-bottom-color: var(--cpg-brand-dark) !important;
}
section.cpg-active #step3 input::-webkit-outer-spin-button,
section.cpg-active #step3 input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
/* Past usage history */
section.cpg-active #step3 .custom_usage_fields,
section.cpg-active #step3 .past_usage_fields {
  display: none;
}
section.cpg-active #step3 .past_usage_fields {
  margin-top: 16px;
  padding: 16px;
  background: var(--cpg-bg-light);
  border-radius: var(--cpg-radius-sm);
}
section.cpg-active #step3 .past_usage_fields p {
  font-size: 13px !important;
  line-height: 1.5 !important;
  color: var(--cpg-text-mid) !important;
  font-weight: 400 !important;
}
section.cpg-active #step3 .past_usage_fields p:first-child {
  font-weight: 700 !important;
  font-size: 14px !important;
  color: var(--cpg-text) !important;
  margin-bottom: 6px !important;
}
section.cpg-active #step3 .past_usage_fields .months {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-top: 10px;
}
section.cpg-active #step3 .past_usage_fields .month {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 8px 10px;
  background: var(--cpg-white);
  border-radius: 6px;
  border: 1px solid var(--cpg-border);
  font-size: 11px;
  color: var(--cpg-text-mid);
  opacity: 1 !important;
  margin: 0 !important;
  width: auto !important;
}
section.cpg-active #step3 .past_usage_fields .month span.month_name {
  font-weight: 700;
  font-size: 10px;
  color: var(--cpg-text);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
section.cpg-active #step3 .past_usage_fields .month input[type=number] {
  width: 100%;
  border: 0 !important;
  border-bottom: 2px solid var(--cpg-border) !important;
  outline: 0;
  border-radius: 0 !important;
  padding: 2px 0;
  font-weight: 600;
  font-size: 13px;
  color: var(--cpg-text);
  background: transparent !important;
  margin: 0 !important;
}
section.cpg-active #step3 .past_usage_fields .month input[type=number]:focus {
  border-bottom-color: var(--cpg-brand) !important;
}

/* ── STEP 4 & 5: RADIO OPTIONS ── */
section.cpg-active .step .full_question .options {
  margin: 12px 0 0 !important;
  display: flex;
  flex-direction: column;
  gap: 0;
}
section.cpg-active .step .full_question .options > span {
  display: block;
  margin-bottom: 8px;
}
section.cpg-active input[type=radio] {
  position: absolute !important;
  opacity: 0 !important;
  width: 0 !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}
section.cpg-active input[type=radio] + label,
section.cpg-active input[type=radio] ~ label {
  display: flex !important;
  align-items: center;
  gap: 10px;
  font-family: var(--cpg-font) !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  line-height: 1.4 !important;
  color: var(--cpg-text-mid) !important;
  cursor: pointer;
  margin: 0 !important;
  padding: 12px 14px !important;
  border: 2px solid var(--cpg-border) !important;
  border-radius: var(--cpg-radius-sm) !important;
  transition: all var(--cpg-ease);
  background: var(--cpg-white) !important;
}
section.cpg-active input[type=radio] + label::before,
section.cpg-active input[type=radio] ~ label::before {
  content: '' !important;
  width: 18px !important;
  height: 18px !important;
  min-width: 18px;
  border-radius: 50% !important;
  border: 2px solid var(--cpg-border) !important;
  display: block !important;
  flex-shrink: 0;
  position: static !important;
  transform: none !important;
  transition: all var(--cpg-ease);
  background: var(--cpg-white) !important;
}
section.cpg-active input[type=radio] + label:hover,
section.cpg-active input[type=radio] ~ label:hover {
  border-color: var(--cpg-brand-light) !important;
  background: var(--cpg-bg-light) !important;
}
section.cpg-active input[type=radio]:checked + label,
section.cpg-active input[type=radio]:checked ~ label {
  border-color: var(--cpg-brand) !important;
  background: var(--cpg-brand-bg) !important;
  color: var(--cpg-text) !important;
}
section.cpg-active input[type=radio]:checked + label::before,
section.cpg-active input[type=radio]:checked ~ label::before {
  background: var(--cpg-brand) !important;
  border-color: var(--cpg-brand) !important;
  box-shadow: inset 0 0 0 3px var(--cpg-white) !important;
}

/* ── IMPORTANT NOTE (Step 4) ── */
section.cpg-active p.notes {
  margin: 14px 0 !important;
  padding: 14px 16px !important;
  background: var(--cpg-brand-bg) !important;
  border-left: 4px solid var(--cpg-brand) !important;
  border-radius: 0 var(--cpg-radius-sm) var(--cpg-radius-sm) 0 !important;
  font-weight: 400 !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
  color: var(--cpg-text) !important;
  float: none !important;
  width: auto !important;
  max-width: 100% !important;
}
section.cpg-active p.notes strong {
  font-size: 13px;
  font-weight: 700;
  color: var(--cpg-brand-dark);
}
section.cpg-active .vc_row.xl {
  display: block !important;
  float: none !important;
  width: 100% !important;
  max-width: none !important;
}
section.cpg-active .vc_row.xl .options {
  width: 100% !important;
  float: none !important;
}

/* ── FAQS / ACCORDIONS (snappy) ── */
section.cpg-active .faqs {
  border: none !important;
  border-top: 1px solid var(--cpg-border) !important;
  padding: 14px 0 0 !important;
  margin: 18px 0 8px !important;
}
section.cpg-active .faqs p.intro {
  font-size: 11px !important;
  font-weight: 700 !important;
  color: var(--cpg-text-light) !important;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin-bottom: 6px !important;
}
section.cpg-active .collapse_question {
  display: flex !important;
  align-items: center;
  gap: 8px;
  text-decoration: none !important;
  font-family: var(--cpg-font) !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
  color: var(--cpg-brand-dark) !important;
  padding: 10px 0 !important;
  margin: 0 !important;
  border-bottom: 1px solid var(--cpg-border) !important;
  transition: color var(--cpg-ease);
}
section.cpg-active .collapse_question:hover {
  color: var(--cpg-brand) !important;
  text-decoration: none !important;
}
section.cpg-active .collapse_question i {
  font-size: 12px !important;
  margin-right: 0;
  font-weight: normal;
  flex-shrink: 0;
  line-height: 1;
  transition: transform var(--cpg-ease);
  width: 12px;
  text-align: center;
}
/* Rotate chevron when open */
section.cpg-active .collapse_question i.fa-angle-down {
  transform: rotate(90deg);
}
section.cpg-active .collapse_answer {
  display: none;
  padding: 10px 0 10px 20px !important;
  font-size: 13px !important;
  line-height: 1.6 !important;
  color: var(--cpg-text-mid) !important;
  /* Override jQuery slideToggle height transitions for snappier feel */
  overflow: hidden !important;
}
section.cpg-active .collapse_answer p {
  color: var(--cpg-text-mid) !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  line-height: 1.6 !important;
  margin-bottom: 6px !important;
}
section.cpg-active .collapse_answer a {
  color: var(--cpg-brand-dark) !important;
  font-size: 13px !important;
  font-weight: 600;
  text-decoration: underline !important;
}
section.cpg-active .collapse_answer span {
  font-weight: 700;
}
section.cpg-active .collapse_answer ul {
  padding-left: 18px;
  margin: 6px 0;
}
section.cpg-active .collapse_answer li {
  font-size: 13px;
  line-height: 1.6;
  color: var(--cpg-text-mid);
  margin-bottom: 2px;
}
section.cpg-active .collapse_answer li a {
  color: var(--cpg-brand-dark) !important;
  font-size: 13px !important;
}

/* ── ESTIMATION TOOL ── */
section.cpg-active .estimation_tool {
  display: none !important;
}
section.cpg-active .estimation_tool[style*="block"] {
  display: block !important;
  padding: 16px 0 0;
}
section.cpg-active .estimation_tool h3 {
  font-size: 16px;
  font-weight: 700;
  color: var(--cpg-text);
  margin-bottom: 12px;
}
section.cpg-active .estimation_tool .question {
  border: 1px solid var(--cpg-border) !important;
  border-radius: var(--cpg-radius-sm) !important;
  padding: 14px 16px !important;
  margin-bottom: 12px !important;
}
section.cpg-active .estimation_tool .question p {
  color: var(--cpg-brand-dark) !important;
  font-weight: 700 !important;
  font-size: 13px !important;
}
section.cpg-active .estimation_tool .question.results {
  text-align: center;
  background: var(--cpg-brand-bg) !important;
}
section.cpg-active .estimation_tool span.estimated_usage {
  font-size: 42px;
  font-weight: 800;
  color: var(--cpg-brand-dark);
  display: block;
  line-height: 1;
  margin: 12px auto 6px;
}
section.cpg-active .estimation_tool span.unit {
  font-size: 14px;
  color: var(--cpg-text-mid);
  font-weight: 600;
}
section.cpg-active .estimation_tool .disclaimer p {
  color: var(--cpg-text-light) !important;
  font-size: 11px !important;
}
section.cpg-active .estimation_tool select {
  padding: 5px 8px;
  border: 1px solid var(--cpg-border);
  border-radius: 6px;
  font-size: 13px;
  font-weight: 600;
  color: var(--cpg-text);
  background: var(--cpg-white);
}

/* Slider overrides */
section.cpg-active .ui-state-default,
section.cpg-active .ui-widget-content .ui-state-default,
section.cpg-active .ui-state-hover,
section.cpg-active .ui-widget-content .ui-state-hover {
  border: 2px solid var(--cpg-brand) !important;
  background: var(--cpg-brand) !important;
}
section.cpg-active .ui-slider-horizontal {
  height: 4px !important;
  background: var(--cpg-border) !important;
  border: none !important;
  border-radius: 4px !important;
}
section.cpg-active .ui-slider .ui-slider-handle {
  width: 18px !important;
  height: 18px !important;
  border-radius: 50% !important;
  top: -7px !important;
  cursor: grab;
}
section.cpg-active .ui-slider-labels span {
  font-size: 11px !important;
  color: var(--cpg-text-light) !important;
}

/* ── STEP VISIBILITY ── */
section.cpg-active .step:not(#step1) {
  display: none;
}

/* ── ANIMATION ── */
@keyframes cpg-fadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}
section.cpg-active .step {
  animation: cpg-fadeIn 0.2s ease-out;
}

/* ── RESPONSIVE ── */
@media (max-width: 768px) {
  .page-id-31585:has(section.cpg-active) .main-holder {
    padding: 0 12px !important;
  }
  section.find_best_rates.cpg-active {
    margin: 8px auto 32px !important;
  }
  section.cpg-active .step-header {
    padding: 14px 16px !important;
  }
  section.cpg-active h5.dark_header {
    font-size: 16px !important;
    gap: 8px;
  }
  section.cpg-active .step-header .step-icon {
    width: 26px !important;
    height: 26px !important;
    min-width: 26px;
    font-size: 12px !important;
  }
  section.cpg-active .step .inner .full_question {
    padding: 18px 16px 22px !important;
  }
  section.cpg-active .step .full_question > p,
  section.cpg-active .step .inner .full_question > p {
    font-size: 14px !important;
  }
  section.cpg-active .step_btn {
    font-size: 14px !important;
    padding: 12px 14px !important;
  }
  section.cpg-active .next_btn {
    padding: 10px 22px !important;
    font-size: 13px !important;
    min-width: 100px;
  }
  section.cpg-active .back_btn {
    padding: 10px 18px !important;
    font-size: 13px !important;
  }
  section.cpg-active #step3 .usages {
    grid-template-columns: 1fr;
  }
  section.cpg-active #step3 .past_usage_fields .months {
    grid-template-columns: repeat(3, 1fr);
    gap: 6px;
  }
  section.cpg-active input[type=radio] + label,
  section.cpg-active input[type=radio] ~ label {
    font-size: 13px !important;
    padding: 10px 12px !important;
  }
  section.cpg-active p.notes {
    font-size: 12px !important;
  }
  /* Compact header responsive */
  .page-id-31585:has(section.cpg-active) .top-info-block.inner {
    padding: 20px 0 18px !important;
  }
  .page-id-31585:has(section.cpg-active) .top-info-block.inner .container {
    padding: 0 16px !important;
  }
  .page-id-31585:has(section.cpg-active) .top-info-block.inner h1 {
    font-size: 22px !important;
  }
  .page-id-31585:has(section.cpg-active) .top-info-block.inner h1::after {
    font-size: 13px !important;
    margin-top: 4px;
  }
  /* Live Link callout responsive */
  section.cpg-active .cpg-livelink-callout {
    flex-direction: column !important;
    gap: 8px !important;
    padding: 14px !important;
  }
  section.cpg-active .cpg-livelink-badge {
    align-self: flex-start;
  }
}
@media (max-width: 374px) {
  section.cpg-active #step3 .past_usage_fields .months {
    grid-template-columns: repeat(2, 1fr);
  }
}
