.background-contrast {
  background-color: #fff;
}

.fl-section--bg-contrast {
  background: #eee;
}

body {
  font-family: "libre-franklin", sans-serif;
  font-weight: 400;
}

h1 {
  font-family: "libre-franklin", sans-serif;
  font-weight: 700;
}

h2, h3 {
  font-family: "castoro", serif;
}

a {
  -webkit-transition-duration: 0.2s; /* Safari */
  transition-duration: 0.2s;
  transition-timing-function: ease-in-out;
}

/*-----Forms-----*/
.gform_wrapper textarea, .gform_wrapper input:not([type=submit]):not([type=checkbox]):not([type=radio]) {
  font-family: "libre-franklin", sans-serif !important;
  display: block !important;
  padding: 1rem !important;
  width: 100% !important;
  border-radius: 0 !important;
  border: 0 solid #171717;
  margin: 0 !important;
  box-shadow: none !important;
  color: #171717;
}

.fl-search__heading {
  color: #d11930;
}
.fl-search__form * {
  font-family: "libre-franklin", sans-serif !important;
}
.button, input.button.gform_button, .fl-header__cta a {
  padding: 1rem 3rem;
  color: #fff;
  background-color: #d11930;
  border-radius: 0 10px 0 10px;
  border: solid #d11930 0;
  font-size: 18px;
  -webkit-transition-duration: 0.2s; /* Safari */
  transition-duration: 0.2s;
  transition-timing-function: ease-in-out;
}
.button:hover, input.button.gform_button:hover, .fl-header__cta a:hover {
  color: #fff;
  border: solid #d11930 0;
  border-radius: 10px 0 10px 0;
}

.fl-location__year {
  color: #d11930;
}

html {
  scroll-padding: calc(128px + 6rem);
}
@media (max-width: 1024px) {
  html {
    scroll-padding: calc(120px + 6rem);
  }
}

.fl-header {
  z-index: 50;
  background-color: #272727;
}
.fl-header__alert {
  background-color: #eee;
}
.fl-header__logo {
  height: 6rem;
}
.fl-header__aux {
  padding: 1rem 0 0.8rem;
  border-bottom: 2px solid #343434;
}
.fl-header__aux * {
  line-height: 1;
}
.fl-header__aux a {
  color: #fff;
  font-size: 1.2rem;
  text-decoration: none;
}
.fl-header__aux a:hover {
  color: #d11930;
}
.fl-header__aux svg * {
  fill: #d11930 !important;
}
.fl-header__nav .menu li a {
  color: #fff;
  font-size: 1.7rem;
}
.fl-header__nav .menu li a:hover {
  color: #d11930;
}
.fl-header__nav .menu li .sub-menu {
  background-color: #fff;
}
.fl-header__nav .menu li .sub-menu li a {
  font-size: 1.6rem;
  color: #171717;
}
.fl-header__nav .menu li .sub-menu li a:hover {
  color: #d11930;
}
.fl-header__cta > a {
  color: #fff !important;
  background-color: #d11930;
  display: block;
  padding-inline: 2rem !important;
  border-top-right-radius: 6px;
  border-bottom-left-radius: 6px;
}
.fl-header__cta > a:hover {
  color: #fff !important;
}
.fl-header__ctas {
  align-items: center;
}
.fl-header__ctas span {
  font-size: 1.2rem;
}
.fl-header__ctas * {
  color: #fff;
}
.fl-header__toggle span {
  background-color: #fff;
}
.fl-header__cta--mobile {
  font-size: 1.4rem;
  color: #fff;
}
.fl-header__phone-cta {
  display: flex;
  align-items: center;
  gap: 10px;
}
.fl-header__phone-cta span {
  display: block;
  line-height: 1;
  font-size: 1.2rem;
  color: #eee;
  transform: translateY(-1px);
}
.fl-header__phone-button {
  background: #fff;
  color: #d11930 !important;
  padding: 0.5rem 1.5rem;
}
@media (min-width: 1200px) {
  .fl-header__inner {
    padding: 1.3rem 5%;
  }
  .fl-header__shim {
    height: 128px;
  }
  .fl-header__mobile-wrap {
    display: none;
  }
}
@media (max-width: 1199px) {
  .fl-header__inner {
    padding: 9px 0;
  }
  .fl-header__nav {
    top: 120px;
    min-height: calc(100vh - 120px);
  }
  .fl-header__nav .menu li a {
    color: #171717;
  }
  .fl-header__shim {
    height: 120px;
  }
  .fl-header__mobile-wrap {
    display: flex;
    gap: 30px;
  }
}

@media (max-width: 480px) {
  .fl-header__shim {
    height: 78px;
  }
  .fl-header__aux {
    position: fixed;
    width: 100%;
    bottom: 0;
    background: #171717;
  }
  .fl-header__aux .site-container {
    justify-content: center;
  }
  .fl-header__nav {
    top: 78px;
    min-height: calc(100vh - 116.2px);
  }
  .fl-header__phone-cta {
    gap: 10px;
  }
  .fl-header__ctas * {
    color: #fff;
  }
  .fl-header__ctas a {
    background-color: #d11930;
  }
  .fl-header__ctas a svg, .fl-header__ctas a svg * {
    fill: #fff !important;
  }
}
.fl-footer {
  background-color: #272727;
  padding: 3rem 0;
}
.fl-footer * {
  color: #fff;
}
.fl-footer__grid {
  display: grid;
  gap: 3rem;
}
.fl-footer__logo {
  height: 60px;
}
.fl-footer .fl-list--unstyled {
  margin: 0;
  column-count: 2;
}
.fl-footer .fl-list--unstyled a {
  text-decoration: none;
}
.fl-footer .fl-list--unstyled a:hover {
  text-decoration: underline;
}
.fl-footer__social {
  margin: 0;
}
.fl-footer__social h3 {
  display: none;
}
.fl-footer__social svg * {
  fill: #fff;
}
.fl-footer__social a:hover svg * {
  fill: #d11930;
}
.fl-footer__social a.fl-footer__X path:nth-of-type(2) {
  fill: #272727;
}
.fl-footer__social a:hover .fl-footer__X path:nth-of-type(2) {
  fill: #d11930;
}
.fl-footer__copyright {
  font-size: 1.2rem;
  color: #a7a7a7;
  margin: 0;
}

@media (min-width: 1025px) {
  .fl-footer__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 7.5rem;
  }
  .fl-footer__grid > * {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    justify-content: center;
  }
  .fl-footer__grid > div:nth-of-type(2) {
    align-items: center;
  }
  .fl-footer__grid > div:last-of-type {
    align-items: end;
  }
}
@media (max-width: 480px) {
  .fl-footer {
    padding-bottom: 8rem;
  }
}
.fl-blog .fl-vertical-accent {
  width: 10px;
  height: 70px;
  background: linear-gradient(to bottom, #d11930 0%, #8d1120 100%);
}
.fl-blog__item h3 {
  font-size: clamp(1.8rem, 2.2vw, 2.4rem);
}
.fl-post__banner {
  padding: 5rem 0;
  background-position: center;
  background-size: cover;
  -webkit-box-shadow: inset 1px 1px 1px 9999px rgba(0, 0, 0, 0.5);
  box-shadow: inset 1px 1px 1px 9999px rgba(0, 0, 0, 0.5);
}
.fl-post__banner h1 {
  margin: 0;
  color: #fff;
}
.fl-post h2 {
  margin-top: 5rem;
}

@media (min-width: 769px) {
  .fl-blog__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 3rem;
  }
}
@media (min-width: 1361px) {
  .fl-blog__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 4rem;
  }
}
@media (max-width: 1024px) {
  .fl-blog__grid {
    gap: 3rem;
  }
}
.fl-contact .col__form {
  background: #d11930;
}
.fl-contact .col__form h3 {
  color: #fff;
}
.fl-contact .col__form p {
  color: #fff;
}
.fl-contact .col__form input[type=submit] {
  background-color: #d11930;
  color: #fff;
}
.fl-content-list__heading {
  color: #d11930;
}
.fl-content-list__list ul {
  font-family: "castoro", serif;
  font-weight: 400;
}

.fl-cta {
  color: #fff;
}
.fl-cta .button {
  background-color: #d11930;
  color: #fff;
}
.fl-cta .button:hover {
  background-color: #d11930;
  color: #fff;
}
.fl-cta--has-bg {
  background-position: center;
  background-size: cover;
  -webkit-box-shadow: inset 1px 1px 1px 9999px rgba(23, 23, 23, 0.65);
  box-shadow: inset 1px 1px 1px 9999px rgba(23, 23, 23, 0.65);
}
.fl-cta--has-gradient {
  background: linear-gradient(to right, #d11930 0%, #171717 100%);
}
.fl-cta:not(.fl-cta--has-bg-image) {
  background-color: #d11930;
}
.fl-cta--default .button {
  background-color: #171717;
}
.fl-cta--default .button:hover {
  background-color: #171717;
}

.fl-green-perks .fl-gp__cta--1 .button {
  background: #171717;
}
.fl-green-perks .fl-gp__cta--1 .button:hover {
  background: black;
}

.fl-hero__form {
  place-self: center;
}
.fl-hero__form .gform_wrapper ::placeholder {
  font-size: 1.2rem;
}
.fl-hero__form .gform_wrapper .gform_button {
  background-color: #171717;
}
.fl-hero__offer {
  background: rgba(255, 255, 255, 0.75);
}
.fl-hero--default .fl-hero__form {
  border-top-left-radius: 0;
  border-bottom-right-radius: 0;
}
.fl-hero--content-bg {
  padding: 3rem;
}
.fl-hero--content-bg .fl-hero__content {
  background: rgba(209, 25, 48, 0.8);
  padding: 3rem;
}
.fl-hero--content-bg .fl-hero__content hr {
  background: linear-gradient(to right, #a6a6a6 0%, #d9d9d9 100%);
}
.fl-hero hr {
  background: linear-gradient(to right, #d11930 0%, #8d1120 100%);
}
.fl-hero .fl-hero__form {
  border-top-left-radius: 0;
  border-bottom-right-radius: 0;
}
.fl-hero__cta {
  background: #d11930;
}
.fl-hero__cta--phone .fl-hero__icon {
  background: #33312E;
}
.fl-hero__cta:hover .fl-hero__icon {
  background: #a31426;
}
.fl-hero__flyout, .fl-hero .flyout-inner {
  min-height: calc(100vh - 128px);
  background: #fff;
}
@media (max-width: 1360px) {
  .fl-hero__flyout, .fl-hero .flyout-inner {
    min-height: calc(100vh - 120px);
  }
}
@media (max-width: 480px) {
  .fl-hero__flyout, .fl-hero .flyout-inner {
    min-height: calc(100vh - 78px);
  }
}

@media (min-width: 1025px) {
  .fl-hero--content-bg {
    padding: 5rem;
  }
  .fl-hero--content-bg .fl-hero__content {
    padding: 5rem;
  }
}
.fl-split-hero__form {
  background: #d11930;
}
.fl-split-hero__content {
  padding: 3rem 0;
}
.fl-split-hero__content h3 {
  color: #d11930;
}
.fl-split-hero__bottom {
  background-color: #eee;
}

@media (min-width: 1025px) {
  .fl-split-hero__content {
    padding: 7.5rem 0;
  }
}
.fl-list-section__list {
  font-size: 2.2rem;
  font-family: "castoro", serif;
}
.fl-list-section__list li {
  gap: 1.5rem;
  display: flex;
  align-items: center;
}
.fl-list-section__list li img {
  height: 20px;
}
.fl-list-section span {
  display: inline-block;
  padding: 1rem;
  border-bottom: 2px solid #eee;
}
.fl-service-steps.circle {
  border-color: #d11930;
}
.fl-service-steps.circle .fl-service-steps__item * {
  color: #fff;
}
.fl-service-steps.circle .fl-service-steps__number {
  border-color: #d11930;
}
.fl-service-steps.accent .fl-service-steps__line {
  background: linear-gradient(to bottom, #d11930 0%, #8d1120 100%);
}

.fl-stats__item h2 {
  color: #d11930;
}

.fl-text-editor--bg-contrast {
  background: #eee;
}

.fl-testimonial-carousel__icon svg * {
  fill: #d11930;
}

.careers-content hr {
  margin: 3rem 0;
}
.careers-content small {
  font-size: 1.3rem;
  color: #999;
}

.fl-ty__content .button {
  color: #fff !important;
}
.fl-ty__content .button--deeplawn {
  background: #171717;
}
.fl-ty__step.complete .fl-ty__icon span {
  background: #fff;
}
.fl-ty__step.complete svg {
  fill: #d11930;
}

@media (max-width: 1024px) {
  .last-p-margin p:last-of-type {
    margin-bottom: 0;
  }
}