/*
File: styles.scss
This should only contain @import statements from other files
*/
/*
File: _variables.scss
This should contain variable declarations. Actual usage should occur elsewhere
*/
/*
COLORS
*/
/*
TYPOGRAPHY
*/
/*
SIZING
*/
/*
BREAKPOINTS
*/
/*
File: _mixins.scss
This should contain mixins that would work throughout the site
TODO: Find a better place for these mixins
*/
/*
File: _layout.scss
This should contain site-wide layout overrides for Divi and Wordpress
*/
/*
DIVI LAYOUT OVERRIDES
*/
*:focus {
  outline: 0 !important;
}
body {
  overflow-x: hidden;
}
.et_pb_section:not(.et_pb_fullwidth_section) {
  padding: 3rem 0;
}
.et_pb_row {
  width: 90.09%;
  max-width: 1920px;
  padding: 1.5rem 0;
}
.et_pb_module {
  margin-bottom: 1.5rem;
}
.et_pb_module.et-last-child, .et_pb_module:last-child {
  margin-bottom: 0;
}
.rf-centered--row {
  display: flex;
}
.rf-centered--row .et_pb_column {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media (max-width: 980px) {
  .rf-centered--row {
    flex-direction: column;
  }
  .rf-centered--row .et_pb_image {
    max-width: 500px;
  }
  .rf-centered--row .et_pb_column:first-child {
    margin-bottom: 3rem;
  }
  .rf-flip {
    display: flex;
    flex-direction: column-reverse;
  }
  .rf-flip .et_pb_column:last-child {
    margin-bottom: 3rem !important;
  }
  .rf-flip .et_pb_column:first-child {
    margin-bottom: 0px !important;
  }
}
.et_pb_gallery_image a {
  line-height: 0 !important;
}
@media (max-width: 980px) {
  #rf-body .rf-contact--blurb .et_pb_blurb_content {
    margin: 0;
  }
}
/*
File: _animation.scss
This should contain site-wide animation styles
*/
/*
DELAYED BLURB ENTRY
This progressively delays the animation start of images in later columns
to create a cool effect
*/
#rf-body img {
  animation-fill-mode: both;
}
@media only screen and (min-width: 980.02px) {
  #rf-body .et_pb_column:nth-child(2) img {
    animation-delay: 0.25s;
  }
  #rf-body .et_pb_column:nth-child(3) img {
    animation-delay: 0.5s;
  }
  #rf-body .et_pb_column:nth-child(4) img {
    animation-delay: 0.75s;
  }
  #rf-body .et_pb_column:nth-child(5) img {
    animation-delay: 1s;
  }
  #rf-body .et_pb_column:nth-child(6) img {
    animation-delay: 1.25s;
  }
}
/*
File: _typography.scss
This should contain sizing and font choices for typography
*/
body.et_divi_theme h1, body.et_divi_theme .h1 {
  font-family: "Telex", "Open Sans", "Arial", "Helvetica Neue", sans-serif;
  min-height: 0vw;
  font-size: 4rem;
  font-size: clamp(3rem, calc(3rem + ((1vw - 0.48rem) * 1.3889)), 4rem);
}
body.et_divi_theme h1 span, body.et_divi_theme .h1 span {
  display: block;
}
body.et_divi_theme h2, body.et_divi_theme .h2 {
  font-family: "Telex", "Open Sans", "Arial", "Helvetica Neue", sans-serif;
  min-height: 0vw;
  font-size: 3rem;
  font-size: clamp(2rem, calc(2rem + ((1vw - 0.48rem) * 1.3889)), 3rem);
}
body.et_divi_theme h2 span, body.et_divi_theme .h2 span {
  display: block;
}
body.et_divi_theme h3, body.et_divi_theme .h3 {
  font-family: "Telex", "Open Sans", "Arial", "Helvetica Neue", sans-serif;
  min-height: 0vw;
  font-size: 2.25rem;
  font-size: clamp(1.5rem, calc(1.5rem + ((1vw - 0.48rem) * 1.0417)), 2.25rem);
}
body.et_divi_theme h3 span, body.et_divi_theme .h3 span {
  display: block;
}
body.et_divi_theme h4, body.et_divi_theme .h4 {
  font-family: "Telex", "Open Sans", "Arial", "Helvetica Neue", sans-serif;
  min-height: 0vw;
  font-size: 1.5rem;
  font-size: clamp(1.25rem, calc(1.25rem + ((1vw - 0.48rem) * 0.3472)), 1.5rem);
}
body.et_divi_theme h4 span, body.et_divi_theme .h4 span {
  display: block;
}
body.et_divi_theme h5, body.et_divi_theme .h5 {
  font-family: "Telex", "Open Sans", "Arial", "Helvetica Neue", sans-serif;
  min-height: 0vw;
  font-size: 1.25rem;
  font-size: clamp(1rem, calc(1rem + ((1vw - 0.48rem) * 0.3472)), 1.25rem);
}
body.et_divi_theme h5 span, body.et_divi_theme .h5 span {
  display: block;
}
body.et_divi_theme h6, body.et_divi_theme .h6 {
  font-family: "Telex", "Open Sans", "Arial", "Helvetica Neue", sans-serif;
  min-height: 0vw;
  font-size: 1rem;
  font-size: clamp(0.85rem, calc(0.85rem + ((1vw - 0.48rem) * 0.2083)), 1rem);
  line-height: 1.5rem;
}
body.et_divi_theme h6 span, body.et_divi_theme .h6 span {
  display: block;
}
body.et_divi_theme #rf-body, body.et_divi_theme a #rf-body, body.et_divi_theme li #rf-body {
  font-family: "Geologica", "Open Sans", "Arial", "Helvetica Neue", sans-serif;
  line-height: 1.5rem;
  font-weight: 400;
  font-size: 1rem;
}
body.et_divi_theme a {
  transition: all 0.3s ease;
}
body.et_divi_theme h1 a, body.et_divi_theme h2 a, body.et_divi_theme h3 a, body.et_divi_theme h4 a, body.et_divi_theme h5 a, body.et_divi_theme h6 a, body.et_divi_theme p a {
  color: inherit !important;
  font-weight: 700;
}
body.et_divi_theme h1 a:hover, body.et_divi_theme h2 a:hover, body.et_divi_theme h3 a:hover, body.et_divi_theme h4 a:hover, body.et_divi_theme h5 a:hover, body.et_divi_theme h6 a:hover, body.et_divi_theme p a:hover {
  color: #6b879c !important;
}
body.et_divi_theme .rf-paragraph--large #rf-body, body.et_divi_theme .rf-paragraph--large a #rf-body {
  font-family: "Geologica", "Open Sans", "Arial", "Helvetica Neue", sans-serif;
  line-height: 1.5rem;
  font-weight: 400;
  font-size: 1.3125rem;
  font-size: clamp(1rem, calc(1rem + ((1vw - 0.3rem) * 0.5435)), 1.3125rem);
}
body.et_divi_theme .rf-paragraph--small #rf-body, body.et_divi_theme .rf-paragraph--small a #rf-body {
  font-family: "Geologica", "Open Sans", "Arial", "Helvetica Neue", sans-serif;
  line-height: 1.5rem;
  font-weight: 400;
  font-size: 0.875rem;
  line-height: 1.3125rem;
}
body.et_divi_theme .et_pb_layout_dark {
  color: #fff;
}
/*
File: _buttons.scss
This should contain overrides for buttons
*/
#rf-body .et_pb_button, #rf-body .rf-news a.more-link, #rf-body .gform_button, #rf-body [type=submit] {
  display: inline-flex;
  justify-content: center;
  position: relative;
  border: none;
  font-size: 1rem;
  font-size: clamp(0.85rem, calc(0.85rem + ((1vw - 0.48rem) * 0.2083)), 1rem);
  font-weight: 400;
  letter-spacing: 1px;
  padding: 0.75rem 1.5rem !important;
  text-transform: capitalize;
  border-radius: 5px;
  transition: all 0.3s ease;
  font-family: "Geologica", "Open Sans", "Arial", "Helvetica Neue", sans-serif;
  transition: all 0.3s ease;
  line-height: 1.5rem !important;
  text-align: center;
  text-shadow: none;
  cursor: pointer;
}
#rf-body .et_pb_button:hover, #rf-body .rf-news a.more-link:hover, #rf-body .gform_button:hover, #rf-body [type=submit]:hover {
  color: #6b879c;
}
#rf-body .rf-button--primary, #rf-body .et_pb_button, #rf-body .rf-news a.more-link, #rf-body .gform_button, #rf-body [type=submit], #rf-body #main-header li.btn a, #main-header li.btn #rf-body a, #rf-body .rf-home--slider .et_pb_button, #rf-body .rf-home--slider .rf-news a.more-link, #rf-body .rf-news .rf-home--slider a.more-link, #rf-body .service-page-blurb .df_ab_blurb_button {
  transition: 0.25s all ease-in-out;
  color: #fff;
  background: #274156;
  background: linear-gradient(90deg, #274156 0%, #6b879c 100%);
}
#rf-body .rf-button--primary:hover, #rf-body .et_pb_button:hover, #rf-body .rf-news a.more-link:hover, #rf-body .gform_button:hover, #rf-body [type=submit]:hover, #rf-body #main-header li.btn a:hover, #main-header li.btn #rf-body a:hover, #rf-body .rf-home--slider .et_pb_button:hover, #rf-body .rf-home--slider .rf-news a.more-link:hover, #rf-body .rf-news .rf-home--slider a.more-link:hover, #rf-body .service-page-blurb .df_ab_blurb_button:hover {
  background-color: #6b879c !important;
  color: #fff !important;
  opacity: 80%;
  transform: translateY(-0.25rem);
}
#rf-body .rf-button--outline, #rf-body .rf-news a.more-link {
  color: #274156 !important;
  background-color: transparent;
  height: fit-content;
  box-shadow: 0 0 0 0.125rem inset #274156;
}
#rf-body .rf-button--outline:hover, #rf-body .rf-news a.more-link:hover {
  background-color: #274156 !important;
  color: #fff !important;
  opacity: 1 !important;
}
#rf-body .rf-button--secondary, #rf-body .df-menu-button {
  color: #fff;
  background-color: #6b879c;
}
#rf-body .rf-button--secondary:hover, #rf-body .df-menu-button:hover {
  background-color: transparent !important;
  color: #6b879c !important;
  opacity: 80%;
}
#rf-body .rf-button--secondary-outline {
  color: #6b879c;
  background-color: #fff;
  box-shadow: 0 0 0 0.125rem inset #6b879c;
}
#rf-body .rf-button--secondary-outline:hover {
  background-color: #6b879c !important;
  color: #fff !important;
  box-shadow: 0 0 0 0.125rem inset #6b879c;
}
#rf-body .rf-button--inverse {
  color: #6b879c !important;
  background-color: #fff;
  height: fit-content;
  box-shadow: 0 0 0 0.125rem inset #fff;
}
#rf-body .rf-button--inverse:hover {
  background-color: transparent;
  color: #fff !important;
  opacity: 1 !important;
  box-shadow: 0 0 0 0.125rem inset #fff;
}
#rf-body .rf-button--inverse-outline, #rf-body .rf-cta--secondary .et_pb_button, #rf-body .rf-cta--secondary .rf-news a.more-link, #rf-body .rf-news .rf-cta--secondary a.more-link {
  color: #fff !important;
  background-color: transparent;
  height: fit-content;
  box-shadow: 0 0 0 0.125rem inset #fff;
}
#rf-body .rf-button--inverse-outline:hover, #rf-body .rf-cta--secondary .et_pb_button:hover, #rf-body .rf-cta--secondary .rf-news a.more-link:hover, #rf-body .rf-news .rf-cta--secondary a.more-link:hover {
  background-color: #fff !important;
  color: #ffffff !important;
  opacity: 1 !important;
  opacity: 80%;
}
#rf-body .rf-button--newsletter, #rf-body #et-main-area .gform_wrapper .gf_simple_horizontal #gform_submit_button_2, #et-main-area .gform_wrapper .gf_simple_horizontal #rf-body #gform_submit_button_2 {
  color: #fff !important;
  background-color: transparent;
  height: fit-content;
}
#rf-body .rf-button--newsletter:hover, #rf-body #et-main-area .gform_wrapper .gf_simple_horizontal #gform_submit_button_2:hover, #et-main-area .gform_wrapper .gf_simple_horizontal #rf-body #gform_submit_button_2:hover {
  background-color: #fff !important;
  color: #000000 !important;
  opacity: 1 !important;
  box-shadow: 0 0 0 0.0625rem inset #fff;
}
/* 
  MULTI-BUTTON LAYOUTS
  */
#rf-body .et_pb_button + .et_pb_button, #rf-body .rf-news a.more-link + .et_pb_button, #rf-body .rf-news .et_pb_button + a.more-link, #rf-body .rf-news a.more-link + a.more-link {
  margin-left: 1.5rem;
}
/*
File: _header.scss
This should contain overrides for the main header
*/
#rf-body .rf-centered-inline--menu .et_pb_menu__logo a:hover, #rf-body .rf-left-aligned--menu .et_pb_menu__logo a:hover {
  opacity: 1;
}
#rf-body .rf-centered-inline--menu li a, #rf-body .rf-left-aligned--menu li a {
  font-size: 1.3125rem;
  font-size: clamp(0.75rem, calc(0.75rem + ((1vw - 0.48rem) * 0.6944)), 1.25rem);
}
#rf-body .rf-centered-inline--menu .et_pb_menu__logo-wrap, #rf-body .rf-left-aligned--menu .et_pb_menu__logo-wrap {
  margin-bottom: 0px;
}
#rf-body .rf-centered-inline--menu .et_pb_menu_inner_container, #rf-body .rf-left-aligned--menu .et_pb_menu_inner_container {
  display: flex;
}
@media screen and (max-width: 980px) {
  #rf-body .rf-centered-inline--menu .et_pb_menu__wrap, #rf-body .rf-left-aligned--menu .et_pb_menu__wrap {
    justify-content: flex-end;
  }
}
#rf-body .mobile_nav.opened .mobile_menu_bar::before {
  content: "M";
}
@media (min-width: 980px) {
  #rf-body li.btn {
    display: flex;
    align-items: center;
  }
  #rf-body li.btn a {
    color: #274156 !important;
    background-color: transparent;
    height: fit-content;
    padding: 1.5rem 1.5rem !important;
    box-shadow: 0 0 0 0.0625rem inset #274156;
  }
  #rf-body li.btn a:hover {
    background-color: #274156 !important;
    color: #fff !important;
    opacity: 1 !important;
  }
}
#main-header .container, #top-header .container {
  max-width: 1400px;
  width: 90.09%;
}
/* 
Auto width for nav dropdowns
*/
@media only screen and (min-width: 981px) {
  .nav li ul {
    width: fit-content;
    display: flex;
    flex-direction: column;
  }
  .nav li li {
    white-space: nowrap;
  }
  .nav li li a {
    width: auto !important;
  }
}
/*
TOP HEADER
*/
#top-header .container {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
#top-header #et-info-phone a {
  font-weight: 500;
  transition: all 0.3s ease;
}
#top-header #et-info-phone a:hover {
  opacity: 0.7;
}
#top-header a {
  font-size: 15px !important;
}
#top-header #et-secondary-menu {
  float: none;
}
/*
  MAIN HEADER
  */
#main-header .et_pb_menu__wrap {
  display: flex;
  justify-content: flex-end;
}
#main-header #menu-top-menu {
  display: flex;
  align-items: center;
}
@media (min-width: 980px) {
  #main-header li.btn a {
    color: #fff !important;
    height: fit-content;
  }
  #main-header li.btn a:hover {
    color: #fff !important;
    opacity: 1 !important;
  }
}
#main-header #logo {
  max-width: 25%;
}
@media (max-width: 767px) {
  #main-header #logo {
    max-width: 100%;
  }
}
#et-top-navigation {
  padding-top: 42px;
}
/*
  MAIN MENU
  */
#main-header #top-menu {
  display: flex;
  align-items: center;
}
#main-header #top-menu li a {
  font-size: clamp(0.75rem, calc(0.75rem + ((1vw - 0.48rem) * 0.6944)), 1.25rem);
}
#main-header #top-menu li ul {
  width: auto;
}
#main-header #top-menu li ul a {
  width: auto;
  white-space: nowrap;
}
@media (max-width: 980px) {
  #main-header .container {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 0;
  }
  #main-header .logo_container {
    position: static;
  }
  #main-header #et-top-navigation {
    padding-left: 0px !important;
  }
  #main-header .logo_container #logo {
    max-width: unset;
    max-height: 100px;
  }
  #main-header .et_header_style_split #logo {
    max-width: unset;
  }
  #main-header #et_search_icon, #main-header .select_page {
    display: none;
  }
  #main-header .mobile_menu_bar::before {
    color: rgba(0, 0, 0, 0.6);
    font-size: 3rem;
    position: absolute;
    transform: translate(-50px, -22px);
  }
  #main-header .mobile_nav.opened .mobile_menu_bar::before {
    content: "M";
  }
  #main-header .mobile_nav {
    padding: 0 !important;
  }
  #main-header #et_mobile_nav_menu {
    margin: 0;
  }
  .et_header_style_centered #main-header .container {
    display: block;
    text-align: left;
  }
  .et_header_style_centered #main-header div#et-top-navigation {
    position: absolute;
    bottom: auto;
    top: 0;
    padding-top: 0;
  }
  .et_header_style_centered #main-header #et_mobile_nav_menu {
    margin-top: 0;
  }
  .et_header_style_centered #main-header #et_mobile_nav_menu .mobile_nav {
    padding: 0;
  }
}
/*
File: _fullwidth-header.scss
This should only contain fullwidth-header css
*/
#rf-body .et_pb_fullwidth_header_container {
  margin: auto;
  max-width: 1920px;
  width: 90.09%;
}
@media screen and (max-width: 400px) {
  #rf-body .et_pb_fullwidth_header_container {
    margin-left: auto;
    margin-right: auto;
  }
  #rf-body .et_pb_fullwidth_header {
    padding-top: 0px;
    padding-bottom: 0px;
  }
}
/*
File: _footer.scss
This should contain overrides for the footer
*/
/*
MAIN FOOTER AREA
*/
#main-footer #footer-widgets {
  display: block;
  justify-content: center;
}
@media screen and (min-width: 980px) {
  #main-footer #footer-widgets {
    display: flex;
  }
}
@media screen and (max-width: 980px) {
  #main-footer #footer-widgets {
    flex-wrap: wrap;
    justify-content: flex-start;
  }
}
#main-footer .footer-widget {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}
#main-footer .footer-widget li {
  padding-left: 0;
}
#main-footer .footer-widget li::before {
  display: none;
}
#main-footer .footer-widget .widget_media_image {
  padding-bottom: 0;
  margin-bottom: 20px;
}
/*
BOTTOM BAR
*/
#footer-info {
  float: none;
  padding: 0.75rem 0;
  text-align: center;
}
#footer-info #rf-body {
  font-family: "Geologica", "Open Sans", "Arial", "Helvetica Neue", sans-serif;
  line-height: 1.5rem;
  font-weight: 400;
  font-size: 0.875rem;
  line-height: 1.3125rem;
}
#footer-info a {
  font-size: 14px;
}
/*
File: _forms.scss
This should contain overrides for forms
*/
.recaptcha {
  font-size: 0.8rem !important;
  opacity: 0.7;
}
.recaptcha * {
  font-size: 0.8rem !important;
}
/*
GENERAL FORM OVERRIDES
*/
.gform_validation_errors {
  text-transform: none;
}
/*
GRAVITY FORMS
*/
.gform_wrapper {
  background-color: #ffffff;
  padding: 2rem;
  border-radius: 15px;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}
.gform_wrapper input {
  border-radius: 5px;
  border: 1px solid #bbb !important;
  background-color: 210 20% 98%;
}
#et-main-area .gform_wrapper .gform_submission_error #rf-body {
  font-family: "Geologica", "Open Sans", "Arial", "Helvetica Neue", sans-serif;
  line-height: 1.5rem;
  font-weight: 400;
  font-size: 1rem;
}
#et-main-area .gform_wrapper input[type="number"], #et-main-area .gform_wrapper input[type="text"], #et-main-area .gform_wrapper input[type="tel"], #et-main-area .gform_wrapper input[type="email"], #et-main-area .gform_wrapper input[type="date"], #et-main-area .gform_wrapper textarea {
  border: 1px solid #bbb !important;
}
.gform_heading {
  display: none;
}
/*rwe
MAILCHIMP NEWSLETTER SIGNUP
*/
.gform_heading {
  display: none;
}
#et-main-area .gform_wrapper .gf_simple_horizontal {
  position: relative;
  display: flex;
  justify-content: center;
}
#et-main-area .gform_wrapper .gf_simple_horizontal, #et-main-area .gform_wrapper .gf_simple_horizontal * {
  margin: 0 auto;
  max-width: 838px;
  width: 100%;
  height: 3rem;
}
#et-main-area .gform_wrapper .gf_simple_horizontal .gfield {
  padding: 0;
}
#et-main-area .gform_wrapper .gf_simple_horizontal input {
  padding: 0.75rem 1.5rem;
  background-color: transparent;
  border: 1px solid white;
  color: white;
}
#et-main-area .gform_wrapper .gf_simple_horizontal input::placeholder {
  color: rgba(255, 255, 255, 0.7);
}
#et-main-area .gform_wrapper .gf_simple_horizontal .gform_footer {
  position: absolute;
  width: 25%;
  right: 0;
}
#et-main-area .gform_wrapper .gf_simple_horizontal #gform_submit_button_2 {
  border-left: 1px solid white;
}
/*
File: _social-icons.scss
This file is just for the inline social icon styles from the [rf_social_media] shortcode
*/
.rf-social-icons-inline .ul-social-et {
  display: flex;
  list-style-type: none;
  padding: 0;
}
.rf-social-icons-inline .ul-social-et .et-social-icon {
  margin: 0 1.5rem 0 0;
}
.rf-social-icons-inline .ul-social-et .et-social-icon:last-child {
  margin: 0;
}
.rf-social-icons-inline .ul-social-et .et-social-icon a {
  font-size: 1.5rem;
  width: 2.75rem;
  height: 2.75rem;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 999px;
  border-style: solid;
  border-width: 0.125rem;
}
.rf-social-icons-inline .ul-social-et .et-social-icon a::before {
  position: relative;
}
.rf-social-icons-inline .ul-social-et .et-social-icon span {
  position: absolute;
  left: -10000px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
/*
File: _news.scss
This should contain overrides for news pages
*/
#rf-body .rf-news--header .header-content .et_pb_module_header {
  font-size: 3rem;
  font-size: clamp(2rem, calc(2rem + ((1vw - 0.48rem) * 1.3889)), 3rem) !important;
}
#rf-body .rf-news .entry-featured-image-url {
  max-width: 550px;
}
#rf-body .rf-news .entry-title {
  line-height: 0.5em;
}
#rf-body .rf-news .entry-title a {
  font-weight: 700;
  line-height: 1em;
  letter-spacing: 0px;
  text-transform: none;
  font-size: 1.5rem !important;
  font-family: "Telex", "Open Sans", "Arial", "Helvetica Neue", sans-serif;
}
#rf-body .rf-news a.more-link {
  letter-spacing: 2px;
  box-shadow: none !important;
  color: white !important;
  margin-top: 1.5rem;
  text-transform: capitalize;
  font-size: 1rem;
  font-size: clamp(0.875rem, calc(.875rem + ((1vw - 0.48rem) * 0.2083)), 1rem);
}
#rf-body .rf-news a.more-link:hover {
  opacity: 80% !important;
}
#rf-body .et_pb_post_content h1, #rf-body .et_pb_post_content h2, #rf-body .et_pb_post_content h3, #rf-body .et_pb_post_content h4, #rf-body .et_pb_post_content h5, #rf-body .et_pb_post_content h6 {
  text-transform: capitalize;
}
/*
File: _home.scss
This should contain overrides for home page
*/
#rf-body .rf-home--slider .et_pb_container {
  max-width: 1400px;
}
#rf-body .help-blurb {
  display: flex;
  flex-direction: row;
  align-items: center;
}
#rf-body .help-blurb h4 {
  display: inline-block;
  position: relative;
}
#rf-body .help-blurb h4::after {
  content: "";
  position: absolute;
  width: 100%;
  transform: scaleX(0);
  height: 2px;
  bottom: 0;
  left: 0;
  background-color: #274156;
  transform-origin: bottom right;
  transition: transform 0.25s ease-out;
}
#rf-body .help-blurb h4:hover::after {
  transform: scaleX(1);
  transform-origin: bottom left;
}
#rf-body .df-menu-button {
  border-radius: 5px;
  padding: 0.75rem 1.5rem;
}
#rf-body .df-menu-button:hover {
  box-shadow: 0 0 0 0.125rem inset #6b879c;
}
#rf-body .rf-contact--blurb {
  display: flex;
  justify-content: start;
  background-color: #ffffff !important;
  padding: 2rem;
  border-radius: 15px;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}
#rf-body .rf-contact--blurb .et_pb_blurb_content {
  margin: 0 !important;
}
#rf-body .service-page-blurb {
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  border-radius: 10px;
  padding: 2rem;
  height: 100%;
  justify-content: space-between;
}
#rf-body .service-page-blurb .df_ab_blurb_title {
  color: #6b879c;
}
#rf-body .service-page-blurb li::marker {
  color: #6b879c;
}
#rf-body .service-page-blurb .et_pb_module_inner {
  height: 100%;
}
#rf-body .service-page-blurb .df_ab_blurb_container {
  height: 100%;
}
#rf-body .service-page-blurb .df_ab_blurb_content_container {
  height: 100%;
  justify-content: space-between;
}
#rf-body .service-page-blurb .df_ab_blurb_button {
  margin-top: 2rem;
  border-radius: 5px;
  padding: 0.75rem 1.5rem;
  width: 100%;
  justify-content: center;
}
#rf-body .service-page-blurb .df-blurb-icon {
  padding: 1rem;
  border-radius: 100%;
  background: linear-gradient(#274156 0%, #6b879c 100%);
  margin-bottom: 2rem;
  transition: 0.25s all ease-in-out;
}
#rf-body .service-page-blurb .df-blurb-icon:hover {
  transform: scale(1.1);
}

/* ============================================================
   4K / LARGE DISPLAY ADDITIONS
   Everything above this line is the original styles.css
   verbatim. Nothing below affects screens under 2000px wide.
   ============================================================ */

@media (min-width: 2000px) {

  /* GLOBAL ROWS */
  .et_pb_row:not(.et_pb_row_0_tb_header) {
    max-width: min(3200px, 90vw) !important;
    width: 90% !important;
  }
  .et_pb_section:not(.et_pb_fullwidth_section):not(.et_pb_section_0_tb_header):not(.et_pb_section_2) {
    padding: 5rem 0 !important;
  }
  .et_pb_fullwidth_header:not(.et_pb_fullscreen) .et_pb_fullwidth_header_container {
    max-width: min(3000px, 90vw) !important;
    width: 90% !important;
  }

  /* HERO — full bleed, no padding bleed-in */
  .et_pb_section_0.et_pb_section {
    padding: 0 !important;
  }
  .et_pb_row_0.et_pb_row {
    padding: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }
  .et_pb_fullwidth_header_0.et_pb_fullscreen {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  .et_pb_fullwidth_header_0 .et_pb_fullwidth_header_container .header-content {
    max-width: clamp(800px, 50vw, 1400px) !important;
    width: 60% !important;
  }
  .et_pb_fullwidth_header_0 .et_pb_fullwidth_header_container h1.et_pb_module_header {
    font-size: clamp(3rem, 3.5vw, 6rem) !important;
    line-height: 1.15 !important;
  }
  .et_pb_fullwidth_header_0 .et_pb_button {
    font-size: clamp(1rem, 1vw, 1.6rem) !important;
    padding: 1rem 2.5rem !important;
    margin-top: 1.5rem !important;
  }

  /* HELP ME WITH SECTION — full bleed bg */
  .et_pb_section_2.et_pb_section {
    padding: 0 !important;
  }
  .et_pb_row_2.et_pb_row {
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
  }
  .et_pb_column_3.et_pb_column {
    padding-top: 4rem !important;
    padding-bottom: 4rem !important;
    padding-right: 5% !important;
  }

  /* HELP BLURB ITEMS */
  .et_pb_blurb_0 .et-pb-icon,
  .et_pb_blurb_1 .et-pb-icon,
  .et_pb_blurb_2 .et-pb-icon,
  .et_pb_blurb_3 .et-pb-icon,
  .et_pb_blurb_4 .et-pb-icon,
  .et_pb_blurb_5 .et-pb-icon {
    font-size: clamp(25px, 2.5vw, 48px) !important;
  }
  .et_pb_blurb_0 .et_pb_module_header,
  .et_pb_blurb_1 .et_pb_module_header,
  .et_pb_blurb_2 .et_pb_module_header,
  .et_pb_blurb_3 .et_pb_module_header,
  .et_pb_blurb_4 .et_pb_module_header,
  .et_pb_blurb_5 .et_pb_module_header {
    font-size: clamp(1.2rem, 1.3vw, 2rem) !important;
    line-height: 1.3 !important;
  }
  .et_pb_blurb_0,
  .et_pb_blurb_1,
  .et_pb_blurb_2,
  .et_pb_blurb_3,
  .et_pb_blurb_4,
  .et_pb_blurb_5 {
    padding-top: 2.5rem !important;
    padding-bottom: 2.5rem !important;
  }

  /* DEDICATED SECTION */
  .et_pb_section_3 .et_pb_column_4 .et_pb_image_0 .et_pb_image_wrap {
    width: 100% !important;
    max-width: 100% !important;
  }
  .et_pb_section_3 .et_pb_column_4 .et_pb_image_0 .et_pb_image_wrap img {
    width: 100% !important;
    height: auto !important;
    max-width: 100% !important;
  }
  .et_pb_column_5 {
    padding: 6% 8% !important;
  }
  .et_pb_cta_0 .et_pb_module_header {
    font-size: clamp(2rem, 2.5vw, 4rem) !important;
    line-height: 1.2 !important;
  }
  .et_pb_cta_0 h3 {
    font-size: clamp(1rem, 1.2vw, 1.8rem) !important;
  }
  .et_pb_cta_0 .et_pb_promo_content p {
    font-size: clamp(1rem, 1vw, 1.5rem) !important;
    line-height: 1.75 !important;
  }
  .et_pb_cta_0 .et_pb_promo_button {
    font-size: clamp(1rem, 1vw, 1.5rem) !important;
    padding: 1rem 2.5rem !important;
  }

  /* SERVICE BLURBS — centered icons, scaled */
  .difl_advanced_blurb_0 .df_ab_blurb_container,
  .difl_advanced_blurb_1 .df_ab_blurb_container,
  .difl_advanced_blurb_2 .df_ab_blurb_container,
  .difl_advanced_blurb_3 .df_ab_blurb_container,
  .difl_advanced_blurb_4 .df_ab_blurb_container,
  .difl_advanced_blurb_5 .df_ab_blurb_container,
  .difl_advanced_blurb_6 .df_ab_blurb_container,
  .difl_advanced_blurb_7 .df_ab_blurb_container {
    flex-direction: column !important;
    align-items: center !important;
    max-width: 100% !important;
    width: 100% !important;
  }
  .difl_advanced_blurb_0 .df_ab_blurb_image,
  .difl_advanced_blurb_1 .df_ab_blurb_image,
  .difl_advanced_blurb_2 .df_ab_blurb_image,
  .difl_advanced_blurb_3 .df_ab_blurb_image,
  .difl_advanced_blurb_4 .df_ab_blurb_image,
  .difl_advanced_blurb_5 .df_ab_blurb_image,
  .difl_advanced_blurb_6 .df_ab_blurb_image,
  .difl_advanced_blurb_7 .df_ab_blurb_image {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
    text-align: center !important;
  }
  .difl_advanced_blurb_0 .df-blurb-icon,
  .difl_advanced_blurb_1 .df-blurb-icon,
  .difl_advanced_blurb_2 .df-blurb-icon,
  .difl_advanced_blurb_3 .df-blurb-icon,
  .difl_advanced_blurb_4 .df-blurb-icon,
  .difl_advanced_blurb_5 .df-blurb-icon,
  .difl_advanced_blurb_6 .df-blurb-icon,
  .difl_advanced_blurb_7 .df-blurb-icon {
    font-size: clamp(25px, 2.8vw, 55px) !important;
    padding: clamp(1rem, 1.5vw, 2rem) !important;
    margin-bottom: clamp(1.5rem, 2vw, 3rem) !important;
  }
  .difl_advanced_blurb_0 .df_ab_blurb_title,
  .difl_advanced_blurb_1 .df_ab_blurb_title,
  .difl_advanced_blurb_2 .df_ab_blurb_title,
  .difl_advanced_blurb_3 .df_ab_blurb_title,
  .difl_advanced_blurb_4 .df_ab_blurb_title,
  .difl_advanced_blurb_5 .df_ab_blurb_title,
  .difl_advanced_blurb_6 .df_ab_blurb_title,
  .difl_advanced_blurb_7 .df_ab_blurb_title {
    font-size: clamp(1rem, 1.2vw, 2rem) !important;
    line-height: 1.3 !important;
    text-align: center !important;
    width: 100% !important;
  }
  .service-page-blurb {
    padding: clamp(2rem, 2.5vw, 4rem) !important;
  }

  /* ART OF BEAUTIFUL SMILES */
  .et_pb_cta_1 .et_pb_module_header {
    font-size: clamp(2rem, 2.5vw, 4rem) !important;
    line-height: 1.2 !important;
  }
  .et_pb_cta_1 h3 {
    font-size: clamp(1rem, 1.2vw, 1.8rem) !important;
  }
  .et_pb_cta_1 .et_pb_promo_content p {
    font-size: clamp(1rem, 1vw, 1.5rem) !important;
    line-height: 1.75 !important;
  }
  .et_pb_cta_1 .et_pb_promo_button {
    font-size: clamp(1rem, 1vw, 1.5rem) !important;
    padding: 1rem 2.5rem !important;
  }
  .et_pb_image_1 .et_pb_image_wrap {
    width: 100% !important;
    max-width: 100% !important;
  }
  .et_pb_image_1 .et_pb_image_wrap img {
    width: 100% !important;
    height: auto !important;
  }

  /* LOGOS CAROUSEL */
  .dica_divi_carousel_0 .dica_divi_carouselitem .dica-image-container img {
    width: 100% !important;
    height: auto !important;
    max-width: 100% !important;
    object-fit: contain !important;
  }
  .dica_divi_carousel_0 .dica_divi_carouselitem .dica-image-container {
    min-height: clamp(80px, 8vw, 160px) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }

  /* TESTIMONIALS HEADING */
  .et_pb_text_0 .et_pb_text_inner h3 {
    font-size: clamp(2rem, 2.5vw, 4rem) !important;
    padding-bottom: 2rem !important;
  }

  /* HEADER — logo + nav */
  .difl_advancedmenuitem_2_tb_header.df-am-item {
    width: clamp(150px, 12vw, 320px) !important;
  }
  .difl_advancedmenuitem_2_tb_header img.df-site-logo {
    width: 100% !important;
    height: auto !important;
    max-width: none !important;
  }
  .difl_advancedmenuitem_1_tb_header .df-normal-menu-wrap .df-menu-nav > li.menu-item > a {
    font-size: clamp(1rem, 1.1vw, 1.8rem) !important;
  }
  .difl_advancedmenuitem_1_tb_header .df-normal-menu-wrap .df-menu-nav {
    gap: clamp(10px, 1.5vw, 35px) !important;
  }
  .difl_advancedmenuitem_3_tb_header.df-am-item {
    font-size: clamp(0.85rem, 0.85vw, 1.4rem) !important;
    padding: 0.85rem 1.75rem !important;
    width: auto !important;
  }
  .difl_advancedmenuitem_0_tb_header h6,
  .difl_advancedmenuitem_0_tb_header h6 a {
    font-size: clamp(0.85rem, 0.8vw, 1.25rem) !important;
  }

  /* FOOTER */
  #main-footer .container,
  #footer-bottom .container {
    max-width: min(3200px, 90vw) !important;
    width: 90% !important;
  }
  #main-footer .footer-widget .widget_media_image img {
    width: clamp(200px, 12vw, 400px) !important;
    height: auto !important;
    max-width: none !important;
  }
  .footer-widget,
  .footer-widget li,
  .footer-widget li a {
    font-size: clamp(14px, 0.85vw, 22px) !important;
    line-height: 1.8 !important;
  }
  #main-footer .footer-widget h4.title {
    font-size: clamp(18px, 1.1vw, 28px) !important;
  }
  #footer-info,
  #footer-info a {
    font-size: clamp(12px, 0.7vw, 18px) !important;
  }
  #footer-widgets {
    padding: 5% 0 !important;
  }

  /* GENERAL TEXT */
  .et_pb_text_inner p,
  .et_pb_text_inner li {
    font-size: clamp(1rem, 1vw, 1.6rem) !important;
    line-height: 1.75 !important;
  }
  .et_pb_text_inner h2 {
    font-size: clamp(2rem, 2.5vw, 4rem) !important;
  }
  .et_pb_text_inner h3 {
    font-size: clamp(1.5rem, 1.8vw, 3rem) !important;
  }
  .et_pb_module {
    margin-bottom: clamp(1.5rem, 2vw, 3rem) !important;
  }
  .et_pb_module.et-last-child,
  .et_pb_module:last-child {
    margin-bottom: 0 !important;
  }
}

@media (min-width: 3200px) {
  .et_pb_row:not(.et_pb_row_0_tb_header) {
    max-width: min(3800px, 88vw) !important;
    width: 88% !important;
  }
  .difl_advancedmenuitem_2_tb_header.df-am-item {
    width: clamp(200px, 10vw, 380px) !important;
  }
  .difl_advancedmenuitem_1_tb_header .df-normal-menu-wrap .df-menu-nav > li.menu-item > a {
    font-size: clamp(1.2rem, 0.9vw, 2rem) !important;
  }
  .et_pb_fullwidth_header_0 .et_pb_fullwidth_header_container h1.et_pb_module_header {
    font-size: clamp(4rem, 4vw, 8rem) !important;
  }
  .difl_advanced_blurb_0 .df-blurb-icon,
  .difl_advanced_blurb_1 .df-blurb-icon,
  .difl_advanced_blurb_2 .df-blurb-icon,
  .difl_advanced_blurb_3 .df-blurb-icon,
  .difl_advanced_blurb_4 .df-blurb-icon,
  .difl_advanced_blurb_5 .df-blurb-icon,
  .difl_advanced_blurb_6 .df-blurb-icon,
  .difl_advanced_blurb_7 .df-blurb-icon {
    font-size: clamp(40px, 3vw, 70px) !important;
  }
  #main-footer .container,
  #footer-bottom .container {
    max-width: min(3800px, 88vw) !important;
    width: 88% !important;
  }
}
/* ============================================================
   HERO FULL-WIDTH FIX
   Add at the very bottom of styles-complete.css, after all
   existing rules. Fixes the white margins left/right on hero.
   Applies at ALL screen sizes — the hero should always be
   full bleed edge-to-edge.
   ============================================================ */

/* The section wrapping the fullscreen hero */
.et_pb_section_0.et_pb_section {
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
}

/* The row inside that section */
.et_pb_row_0.et_pb_row {
  padding: 0 !important;
  margin: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
}

/* The column inside the row */
.et_pb_section_0 .et_pb_column_0 {
  width: 100% !important;
  max-width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* The fullscreen header module itself */
.et_pb_fullwidth_header_0.et_pb_fullscreen {
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  left: 0 !important;
  right: 0 !important;
  position: relative !important;
}
