.elementor-5666 .elementor-element.elementor-element-ed3bc8f{--display:flex;}.elementor-5666 .elementor-element.elementor-element-b688fe7{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--gap:0px 0px;--row-gap:0px;--column-gap:0px;}.elementor-5666 .elementor-element.elementor-element-1cf9289{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:15px;--margin-right:15px;}.elementor-5666 .elementor-element.elementor-element-4dd16af > .elementor-widget-container{background-color:transparent;padding:24px 18px 24px 18px;background-image:linear-gradient(180deg, #FFFFFF 0%, #FFFFFF 100%);}.elementor-5666 .elementor-element.elementor-element-4dd16af .elementor-field-group{padding-right:calc( 10px/2 );padding-left:calc( 10px/2 );margin-bottom:10px;}.elementor-5666 .elementor-element.elementor-element-4dd16af .elementor-form-fields-wrapper{margin-left:calc( -10px/2 );margin-right:calc( -10px/2 );margin-bottom:-10px;}.elementor-5666 .elementor-element.elementor-element-4dd16af .elementor-field-group.recaptcha_v3-bottomleft, .elementor-5666 .elementor-element.elementor-element-4dd16af .elementor-field-group.recaptcha_v3-bottomright{margin-bottom:0;}body.rtl .elementor-5666 .elementor-element.elementor-element-4dd16af .elementor-labels-inline .elementor-field-group > label{padding-left:0px;}body:not(.rtl) .elementor-5666 .elementor-element.elementor-element-4dd16af .elementor-labels-inline .elementor-field-group > label{padding-right:0px;}body .elementor-5666 .elementor-element.elementor-element-4dd16af .elementor-labels-above .elementor-field-group > label{padding-bottom:0px;}.elementor-5666 .elementor-element.elementor-element-4dd16af .elementor-field-type-html{padding-bottom:0px;}.elementor-5666 .elementor-element.elementor-element-4dd16af .elementor-field-group .elementor-field:not(.elementor-select-wrapper){background-color:#ffffff;}.elementor-5666 .elementor-element.elementor-element-4dd16af .elementor-field-group .elementor-select-wrapper select{background-color:#ffffff;}.elementor-5666 .elementor-element.elementor-element-4dd16af .e-form__buttons__wrapper__button-next{color:#ffffff;}.elementor-5666 .elementor-element.elementor-element-4dd16af .elementor-button[type="submit"]{color:#ffffff;}.elementor-5666 .elementor-element.elementor-element-4dd16af .elementor-button[type="submit"] svg *{fill:#ffffff;}.elementor-5666 .elementor-element.elementor-element-4dd16af .e-form__buttons__wrapper__button-previous{color:#ffffff;}.elementor-5666 .elementor-element.elementor-element-4dd16af .e-form__buttons__wrapper__button-next:hover{color:#ffffff;}.elementor-5666 .elementor-element.elementor-element-4dd16af .elementor-button[type="submit"]:hover{color:#ffffff;}.elementor-5666 .elementor-element.elementor-element-4dd16af .elementor-button[type="submit"]:hover svg *{fill:#ffffff;}.elementor-5666 .elementor-element.elementor-element-4dd16af .e-form__buttons__wrapper__button-previous:hover{color:#ffffff;}.elementor-5666 .elementor-element.elementor-element-4dd16af{--e-form-steps-indicators-spacing:20px;--e-form-steps-indicator-padding:30px;--e-form-steps-indicator-inactive-secondary-color:#ffffff;--e-form-steps-indicator-active-secondary-color:#ffffff;--e-form-steps-indicator-completed-secondary-color:#ffffff;--e-form-steps-divider-width:1px;--e-form-steps-divider-gap:10px;}.elementor-5666 .elementor-element.elementor-element-e9f4594{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-5666 .elementor-element.elementor-element-8bf2949{--display:flex;--justify-content:space-around;--margin-top:0px;--margin-bottom:0px;--margin-left:15px;--margin-right:15px;}.elementor-5666 .elementor-element.elementor-element-8bf2949:not(.elementor-motion-effects-element-type-background), .elementor-5666 .elementor-element.elementor-element-8bf2949 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:var( --e-global-color-4246e1d );}.elementor-5666 .elementor-element.elementor-element-79a2699 > .elementor-widget-container{background-color:var( --e-global-color-4246e1d );padding:31px 31px 31px 31px;}.elementor-5666 .elementor-element.elementor-element-79a2699{--icon-box-icon-margin:15px;}.elementor-5666 .elementor-element.elementor-element-79a2699.elementor-view-stacked .elementor-icon{background-color:var( --e-global-color-7708d39 );fill:var( --e-global-color-4246e1d );color:var( --e-global-color-4246e1d );}.elementor-5666 .elementor-element.elementor-element-79a2699.elementor-view-framed .elementor-icon, .elementor-5666 .elementor-element.elementor-element-79a2699.elementor-view-default .elementor-icon{fill:var( --e-global-color-7708d39 );color:var( --e-global-color-7708d39 );border-color:var( --e-global-color-7708d39 );}.elementor-5666 .elementor-element.elementor-element-79a2699.elementor-view-framed .elementor-icon{background-color:var( --e-global-color-4246e1d );}.elementor-5666 .elementor-element.elementor-element-79a2699 .elementor-icon{font-size:30px;}.elementor-5666 .elementor-element.elementor-element-d17943d > .elementor-widget-container{background-color:var( --e-global-color-4246e1d );padding:31px 31px 31px 31px;}.elementor-5666 .elementor-element.elementor-element-d17943d{--icon-box-icon-margin:15px;}.elementor-5666 .elementor-element.elementor-element-d17943d.elementor-view-stacked .elementor-icon{background-color:var( --e-global-color-7708d39 );fill:var( --e-global-color-4246e1d );color:var( --e-global-color-4246e1d );}.elementor-5666 .elementor-element.elementor-element-d17943d.elementor-view-framed .elementor-icon, .elementor-5666 .elementor-element.elementor-element-d17943d.elementor-view-default .elementor-icon{fill:var( --e-global-color-7708d39 );color:var( --e-global-color-7708d39 );border-color:var( --e-global-color-7708d39 );}.elementor-5666 .elementor-element.elementor-element-d17943d.elementor-view-framed .elementor-icon{background-color:var( --e-global-color-4246e1d );}.elementor-5666 .elementor-element.elementor-element-d17943d .elementor-icon{font-size:30px;}@media(max-width:1024px){.elementor-5666 .elementor-element.elementor-element-d17943d > .elementor-widget-container{margin:15px 0px 0px 0px;}}@media(min-width:768px){.elementor-5666 .elementor-element.elementor-element-1cf9289{--width:50%;}.elementor-5666 .elementor-element.elementor-element-e9f4594{--width:50%;}}/* Start custom CSS for html, class: .elementor-element-ff21560 *//* Scope everything so it doesn't fight your theme */
.cf-lvp{
  --cf-red:#d71920;         /* adjust to match your exact site red */
  --cf-dark:#101828;
  --cf-text:#111827;
  --cf-muted:#6b7280;
  --cf-line:#e5e7eb;
  --cf-soft:#f9fafb;
  --cf-radius:14px;
  font-family: inherit;
  color: var(--cf-text);
}

.cf-lvp .cf-wrap{
  max-width: 1140px;
  margin: 0 auto;
  padding: 28px 16px;
}

.cf-lvp .cf-hero{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 18px;
  align-items: start;
  padding: 22px;
  border: 1px solid var(--cf-line);
  border-radius: var(--cf-radius);
  background: #fff;
}

.cf-lvp .cf-eyebrow{
  margin:0 0 10px;
  color: var(--cf-muted);
  font-size: 13px;
  letter-spacing: .2px;
}

.cf-lvp h1{
  margin: 0 0 10px;
  font-size: clamp(26px, 3vw, 40px);
  line-height: 1.12;
}

.cf-lvp .cf-sub{
  margin: 0 0 14px;
  color: #374151;
  font-size: 16px;
}

.cf-lvp .cf-ctaRow{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  margin: 14px 0 8px;
}

.cf-lvp .cf-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 11px 14px;
  border-radius: 10px;
  border: 1px solid var(--cf-line);
  background: #fff;
  color: var(--cf-text);
  text-decoration:none;
  font-weight: 700;
  font-size: 14px;
  transition: transform .12s ease, border-color .12s ease, background .12s ease;
}
.cf-lvp .cf-btn:hover{ transform: translateY(-1px); border-color:#cfd4dc; background: var(--cf-soft);}

.cf-lvp .cf-btn--primary{
  background: var(--cf-red);
  border-color: var(--cf-red);
  color:#fff;
}
.cf-lvp .cf-btn--primary:hover{ background:#b8141a; border-color:#b8141a; }

.cf-lvp .cf-btn--ghost{
  background: #fff;
  border-color: var(--cf-red);
  color: var(--cf-red);
}
.cf-lvp .cf-btn--ghost:hover{ background: #fff5f5; }

.cf-lvp .cf-note{
  margin: 6px 0 0;
  font-size: 13px;
  color: var(--cf-muted);
}

.cf-lvp .cf-hero__card{
  border: 1px solid var(--cf-line);
  border-radius: var(--cf-radius);
  background: var(--cf-soft);
  padding: 16px;
}

.cf-lvp .cf-hero__card h3{
  margin: 0 0 10px;
  font-size: 16px;
}

.cf-lvp .cf-checklist{
  list-style:none;
  padding:0;
  margin: 0;
  display:grid;
  gap:10px;
}
.cf-lvp .cf-checklist li{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding: 10px;
  border-radius: 12px;
  border: 1px solid var(--cf-line);
  background: #fff;
}
.cf-lvp .cf-check{
  width:18px; height:18px;
  border-radius: 999px;
  background: var(--cf-red);
  position:relative;
  margin-top:2px;
  flex:0 0 18px;
}
.cf-lvp .cf-check:after{
  content:"";
  position:absolute;
  width:6px; height:10px;
  border-right:2px solid #fff;
  border-bottom:2px solid #fff;
  transform: rotate(45deg);
  left:6px; top:3px;
}

.cf-lvp .cf-miniCta{ margin-top: 12px; }
.cf-lvp .cf-btn--full{ width:100%; }
.cf-lvp .cf-miniText{
  margin: 8px 0 0;
  font-size: 12.5px;
  color: var(--cf-muted);
}

.cf-lvp .cf-trust{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.cf-lvp .cf-trust__item{
  border: 1px solid var(--cf-line);
  border-radius: var(--cf-radius);
  background: #fff;
  padding: 14px;
  display:flex;
  gap: 10px;
  align-items:flex-start;
}
.cf-lvp .cf-icon{
  width:34px; height:34px;
  border-radius: 10px;
  background: #fff5f5;
  color: var(--cf-red);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 900;
  border: 1px solid #ffd6d6;
}
.cf-lvp .cf-trust__title{ font-weight: 800; }
.cf-lvp .cf-trust__sub{ color: var(--cf-muted); font-size: 13px; margin-top:2px; }

.cf-lvp .cf-section{
  margin-top: 18px;
  padding: 18px;
  border: 1px solid var(--cf-line);
  border-radius: var(--cf-radius);
  background: #fff;
}

.cf-lvp .cf-section h2{
  margin: 0 0 8px;
  font-size: clamp(18px, 2.1vw, 26px);
  line-height: 1.2;
}

.cf-lvp .cf-lead{ color:#374151; margin: 0 0 10px; }
.cf-lvp .cf-small{ color: var(--cf-muted); font-size: 13px; margin-top: 4px; }

.cf-lvp .cf-grid2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 12px;
}

.cf-lvp .cf-card{
  border: 1px solid var(--cf-line);
  border-radius: var(--cf-radius);
  background: var(--cf-soft);
  padding: 14px;
}
.cf-lvp .cf-card h3{ margin:0 0 8px; font-size: 16px; }

.cf-lvp .cf-bullets{
  margin: 0;
  padding-left: 18px;
  color:#374151;
}
.cf-lvp .cf-bullets li{ margin: 6px 0; }

.cf-lvp .cf-callout{
  margin-top: 12px;
  padding: 12px 12px;
  border-radius: 12px;
  background: #fff;
  border: 1px solid #ffd6d6;
  color:#374151;
}
.cf-lvp .cf-callout--wide{ margin-top: 14px; }

.cf-lvp .cf-ctaBar{
  margin-top: 14px;
  padding: 14px;
  border-radius: var(--cf-radius);
  border: 1px solid var(--cf-line);
  background: #fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}
.cf-lvp .cf-ctaBar__title{ font-weight: 900; }
.cf-lvp .cf-ctaBar__sub{ color: var(--cf-muted); font-size: 13px; margin-top:3px; }

.cf-lvp .cf-tableWrap{
  margin-top: 10px;
  border: 1px solid var(--cf-line);
  border-radius: var(--cf-radius);
  overflow:hidden;
}
.cf-lvp .cf-table{
  width:100%;
  border-collapse: collapse;
  font-size: 14px;
}
.cf-lvp .cf-table th{
  text-align:left;
  padding: 12px;
  background: var(--cf-soft);
  border-bottom: 1px solid var(--cf-line);
  font-weight: 900;
}
.cf-lvp .cf-table td{
  padding: 12px;
  border-bottom: 1px solid var(--cf-line);
  vertical-align: top;
  color:#374151;
}

.cf-lvp .cf-final{
  margin-top: 18px;
  border-radius: var(--cf-radius);
  border: 1px solid var(--cf-line);
  background: linear-gradient(0deg, #fff, #fff), #fff;
}
.cf-lvp .cf-final__inner{
  padding: 18px;
}
.cf-lvp .cf-final h2{ margin:0 0 8px; }
.cf-lvp .cf-final p{ margin: 0 0 12px; color:#374151; }

@media (max-width: 980px){
  .cf-lvp .cf-hero{ grid-template-columns: 1fr; }
  .cf-lvp .cf-trust{ grid-template-columns: 1fr; }
  .cf-lvp .cf-grid2{ grid-template-columns: 1fr; }
  .cf-lvp .cf-ctaBar{ flex-direction: column; align-items: flex-start; }
}
/* =========================
   MOBILE HERO DECLUTTER
   Paste this at the END of your CSS
   ========================= */
@media (max-width: 767px){

  /* More breathing room in the hero */
  .cf-lvp .cf-hero{
    padding: 16px;
    gap: 14px;
  }

  /* Tighten type so it doesn't feel bulky */
  .cf-lvp h1{
    font-size: 26px;
    line-height: 1.15;
    margin-bottom: 8px;
  }
  .cf-lvp .cf-sub{
    font-size: 15px;
    margin-bottom: 12px;
  }

  /* Make the CTA area feel like "one decision" */
  .cf-lvp .cf-ctaRow{
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    margin: 12px 0 8px;
  }

  /* Primary CTA full width */
  .cf-lvp .cf-btn--primary{
    width: 100%;
  }

  /* Hide extra CTAs in the hero on mobile (declutter) */
  /* If you want CALL visible, remove this line for cf-btn--ghost */
  .cf-lvp .cf-ctaRow .cf-btn:not(.cf-btn--primary){
    display: none !important;
  }

  /* Move offer text down / soften it */
  .cf-lvp .cf-note{
    margin-top: 6px;
    font-size: 12.5px;
    color: #6b7280;
  }

  /* Hide the whole right-side hero card on mobile (big declutter) */
  .cf-lvp .cf-hero__card{
    display: none !important;
  }

  /* Add a small "secondary actions" strip UNDER hero (optional, cleaner) */
  .cf-lvp .cf-mobileActions{
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin-top: 12px;
  }
  .cf-lvp .cf-mobileActions a{
    width: 100%;
    text-align: center;
  }

  /* Trust section: stack + tighter padding */
  .cf-lvp .cf-trust{
    gap: 10px;
  }
  .cf-lvp .cf-trust__item{
    padding: 12px;
  }

  /* Reduce “boxy” feeling between sections */
  .cf-lvp .cf-section{
    padding: 14px;
    margin-top: 14px;
  }
}/* End custom CSS */
/* Start custom CSS for form, class: .elementor-element-4dd16af *//* ============== FORM SHELL (the "card") ============== */
.cf-formShell{
  padding: 22px !important;
  background: #fff !important;
  border: 1px solid #e5e7eb !important;
  border-radius: 14px !important;
  max-width: 760px;
  margin: 0 auto;
}

/* Mobile: keep it off the edges */
@media (max-width: 767px){
  .cf-formShell{
    padding: 16px !important;
    margin-left: 12px !important;
    margin-right: 12px !important;
  }
}

/* ============== FORM ITSELF ============== */
.cf-form .elementor-form{
  max-width: 640px;
  margin: 0 auto !important;
}

/* Make fields look consistent */
.cf-form .elementor-field-group .elementor-field,
.cf-form .elementor-field-group textarea.elementor-field,
.cf-form .elementor-field-group select.elementor-field{
  border-radius: 10px !important;
  border: 1px solid #d1d5db !important;
  padding: 12px 12px !important;
}

/* Better label spacing */
.cf-form .elementor-field-label{
  margin-bottom: 6px !important;
}

/* Fix the “funny” wide button: match input width + nicer height */
.cf-form .elementor-button{
  width: 100% !important;
  max-width: 640px !important;
  margin: 10px auto 0 !important;
  display: flex !important;
  justify-content: center !important;
  border-radius: 10px !important;
  padding: 14px 16px !important;
  font-weight: 900 !important;
}

/* Reduce excessive form whitespace if Elementor adds it */
.cf-form .elementor-form-fields-wrapper{
  row-gap: 12px;
}

/* Optional: add a small top heading feel to the form area */
.cf-formShell:before{
  content: "Quick Contact (or schedule your estimate above)";
  display: block;
  font-weight: 900;
  color: #111827;
  margin-bottom: 10px;
}

/* If you don’t want that heading, remove the entire :before block */
@media (max-width: 767px){
  .cf-formShell{
    margin-left: 12px !important;
    margin-right: 12px !important;
  }
}cf-form
cf-formblock/* End custom CSS */