/*
 Theme Name:   Ion Child
 Theme URI:    https://gentex.com
 Description:  Child theme for the Ion theme
 Author:       
 Author URI:   https://gentex.com
 Template:     ion
 Version:      1.0.0
*/

body {
  font-family: "Oswald", sans-serif;
  background-color: #ffffff;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "Oswald", sans-serif !important;
}

.elementor-element.elementor-element-8f067ae.e-flex.e-con-boxed.e-con.e-parent.e-lazyloaded {
  background-color: #f2f2f2;
  padding-top: 13px !important;
  padding-bottom: 26px !important;
  line-height: 0;

  .header-section-1 {
    .e-con-inner {
      gap: 50px !important;
    }
    img {
      height: 156px;
    }
  }

  .header-section-2 {
    margin-top: 100px;
    text-align: right;

    .tel {
      p {
        font-size: 35px;
        font-weight: 500;

        a {
          color: #003366 !important;
          margin: 0;
          padding: 0;
        }
      }
    }
  }
}

.elementor-element.elementor-element-3c4a7bd.section-1.e-flex.e-con-boxed.e-con.e-parent.e-lazyloaded {
  background-color: #003366;
  padding-top: 35px !important;
  padding-left: 90px;
  padding-right: 90px;
  padding-bottom: 0px;

  .section-1-a {
    padding-top: 54px;
    position: relative;

    h2 {
      color: #ffffff;
      font-size: 55px;
      margin-bottom: 31px;
      line-height: 4rem;

      span {
        color: #ff6600;
      }
    }

    p {
      font-size: 35px;
      color: #ffffff;
      line-height: 1.3;
    }

    .section-1-a-image {
      position: relative;
      top: 42px;
      z-index: 10;

      img {
        right: 20px;
      }
    }
  }

  .section-1-b {
    margin-left: 100px;
  }
}

.section-2 {
  background-color: #ff6600;
  padding-top: 50px !important;
  padding-bottom: 40px !important;

  h2 {
    text-align: center;
    color: #ffffff;
    font-size: 42px;
    margin-bottom: 7px;
  }

  p {
    text-align: center;
    color: #ffffff;
    font-size: 30px;
    font-weight: 300;
  }
}

.elementor-element.elementor-element-05cb6fb.section-3.e-flex.e-con-boxed.e-con.e-parent.e-lazyloaded {
  padding-top: 105px;
  padding-bottom: 60px !important;

  .section-3-a {
    h3 {
      color: #292929;
      font-size: 40px;
      line-height: 1.4;
      margin-bottom: 10px;
    }

    p {
      color: #292929;
      font-size: 30px;
      line-height: 1.4;
      font-weight: 400;
    }
  }

  .section-3-b {
    p {
      color: #292929;
      font-family: "Open Sans";
      font-size: 20px;
      margin-top: 20px;
    }
  }
}

.elementor-element.elementor-element-5426739.section-4.e-flex.e-con-boxed.e-con.e-parent.e-lazyloaded {
  margin-top: 50px;

  .section-4-a,
  .section-4-b,
  .section-4-c,
  .section-4-d {
    background-color: #003366;
    padding-left: 20px;
    padding-right: 20px;
    padding-bottom: 35px;
    border-radius: 10px;

    div:first-child {
      position: relative;
      width: 92px;
      height: 92px;
      margin-bottom: -20px;
      img {
        position: relative;
        bottom: 25px;
      }
    }

    h3 {
      font-size: 25px;
      color: #ffffff;
      font-weight: 400;
    }

    p {
      font-size: 18px;
      font-family: "Open Sans";
      color: #ffffff;
      font-weight: 100;
    }
  }
}

.section-4 > div:first-of-type {
  gap: 10px !important;
}

.section-5 {
  margin-top: 85px !important;
  margin-bottom: 60px !important;
  h3 {
    text-align: center;
    color: #292929;
    font-size: 35px;
  }
}

.section-6,
.section-7 {
  .section-6-a,
  .section-6-b,
  .section-7-a,
  .section-7-b {
    background-color: #f2f2f2;
    border-radius: 10px;
    padding: 51px 25px 65px;

    h3 {
      color: #ff6600;
      font-size: 23px;
      font-weight: 400;
      margin-bottom: 18px;
    }

    p {
      color: #292929;
      font-family: "Open Sans";
      font-size: 18px;
      font-weight: 400;
    }
  }
}

.section-6 > div:first-of-type,
.section-7 > div:first-of-type {
  gap: 18px !important;
}

.elementor-element.elementor-element-0d73826.section-7.e-flex.e-con-boxed.e-con.e-parent.e-lazyloaded {
  padding-top: 30px;
  margin-bottom: 40px;
}

@media (min-width: 768px) {
  .section-8-mobile-image,
  .section-8-mobile-text,
  .section-8-mobile-inner-text {
    display: none !important;
  }
}

.section-8 {
  padding-left: 115px !important;
  padding-right: 115px !important;
  padding-bottom: 30px;
  height: auto !important;

  .section-8-b {
    background-color: #ff6600;
    color: #ffffff;
    margin-left: 30px;
    margin-top: 30px;
    border-radius: 10px;
    padding-left: 32px;
    padding-top: 20px;
    padding-right: 32px;

    h2 {
      font-size: 40px;
      font-weight: 500;
    }

    p {
      font-size: 30px !important;
      font-weight: 300;
      margin-top: 12px;
      line-height: 40px;
    }

    .section-8-button {
      margin-top: 30px;
      margin-bottom: 30px !important;
      a {
        background-color: #003366;
        font-size: 16px;
        border-radius: 12px;
        padding-top: 12px;
        padding-bottom: 12px;
        padding-left: 30px;
        padding-right: 30px;
      }
    }
  }
}

.section-9 {
  .section-9-a {
    padding-right: 45px;
    padding-top: 60px;

    .section-9-a-h3-1 {
      h3 {
        font-size: 20px;
        font-weight: 400;
        color: #003366;
      }
    }

    .section-9-a-h3-2 {
      h3 {
        font-size: 32px;
        color: #292929;
        margin-top: 30px;
        span {
          color: #ff6600;
        }
      }
    }

    p {
      font-family: "Open Sans";
      margin-top: 28px;
      font-size: 14px;
    }

    .section-9-a-h3-3 {
      h3 {
        font-size: 30px;
        color: #003366;
        font-weight: 400;
        margin-top: 40px;
        span {
          color: #ff6600;
        }
      }
    }

    h4 {
      color: #003366;
      font-size: 23px;
      font-weight: 400;
      margin-top: 14px;
    }

    ul {
      color: #292929;
      font-family: "Open Sans";
      line-height: 18px;
      padding-left: 18px;

      li {
        font-size: 16px;
      }

      li::marker {
        font-size: 0.8em;
      }
    }
  }
  .section-9-b {
    background-color: #003366;
    color: #ffffff;
    padding-left: 35px;
    padding-bottom: 112px;
    padding-top: 60px;
    padding-right: 50px;

    .section-9-b-h3-1 {
      h3 {
        font-size: 30px;
        font-weight: 600;
        line-height: 1.4;
        margin-bottom: 5px;
      }
    }

    ul {
      padding-left: 25px;
      line-height: 25px;
      margin-top: 20px;

      li {
        font-size: 20px;
      }

      li::marker {
        font-size: 0.8em;
      }
    }

    .section-9-b-h3-2 {
      h3 {
        font-size: 30px;
        font-weight: 600;
        line-height: 1.4;
        margin-bottom: 5px;
        margin-top: 60px;
      }
    }

    p {
      font-size: 26px;
      font-weight: 300;
      line-height: 1.3;
      margin-top: 14px;
    }

    a {
      background-color: #ff6600;
      font-size: 14px;
      border-radius: 12px;
      padding-top: 12px;
      padding-bottom: 12px;
      padding-left: 16px;
      padding-right: 16px;
      margin-top: 36px;
    }
  }
}

.section-10 {
  position: relative;

  .section-10-quote {
    position: absolute;
    margin-left: 67px;
    top: 65px;
    img {
      width: 229px !important;
      height: 160px !important;
    }
  }

  h3 {
    text-align: center;
    color: #003366;
    font-size: 30px;
    margin-top: 120px;
    margin-bottom: 65px;
    font-family: "Poppins";
    position: relative;
    z-index: 10;
  }
}

.elementor-element.elementor-element-c9e4ff5.section-11.e-flex.e-con-boxed.e-con.e-parent.e-lazyloaded {
  margin-bottom: 90px !important;

  .section-11-a,
  .section-11-b,
  .section-11-c,
  .section-11-d {
    background-color: #e6f2ff;
    padding-top: 40px;
    padding-left: 32px;
    padding-bottom: 50px;
    padding-right: 32px;
    border-radius: 16px;
  }
  .rating {
    text-align: left;
    img {
      width: 170px;
    }
  }

  h4 {
    font-size: 23px;
    color: #003366;
    font-weight: 400;
    margin-top: 30px;
  }

  p {
    font-family: "Open Sans";
    font-style: italic;
    font-size: 20px;
    margin-top: 22px;
  }

  .section-11-name p {
    font-style: normal;
    font-size: 18px;
  }
}

.section-11 > div:first-of-type {
  gap: 12px !important;
}

@media (min-width: 768px) {
  .section-13-mobile-image,
  .section-13-mobile-text {
    display: none !important;
  }
}

.elementor-element.elementor-element-6ec6547.section-13.section-13-desktop.e-flex.e-con-boxed.e-con.e-parent.e-lazyloaded {
  background-color: #003366;
  .e-con-inner {
    gap: 0 !important;
  }
  .section-13-a {
    background-color: #003366;
    color: #ffffff;
    padding-top: 80px;
    padding-bottom: 16px;
    font-size: 40px !important;

    h3 {
      font-size: 40px !important;
      margin-bottom: 5px;
    }

    p {
      font-size: 30px !important;
      margin-top: 18px;
    }

    .section-13-contact {
      margin-top: 35px;
      margin-bottom: 45px;
      flex-direction: row;
    }

    .section-13-button {
      margin-right: 20px;
    }

    .section-13-button a {
      color: #ffffff;
      background-color: #ff6600;
      font-size: 16px !important;
      border-radius: 12px;
      padding-top: 12px;
      padding-bottom: 12px;
      padding-left: 30px;
      padding-right: 30px;
    }

    .section-13-tel {
      margin-top: 5px;
      margin-left: 16px;
      p {
        margin-top: 16px;
      }
      a {
        color: #ffffff;
        font-size: 30px;
        padding-top: 5px;
      }
    }
  }
  .section-13-b {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    z-index: 0;
  }
}

.footer {
  margin-top: 16px !important;
  background-color: #000000;
  padding-top: 22px;
  padding-bottom: 34px;

  .footer-image > div {
    text-align: left;
  }

  .footer-tel {
    text-align: right;
    display: flex;
    justify-content: center;
    margin-top: 15px;
    a {
      color: #ffffff;
      font-size: 30px;
    }
  }
}

.header,
.section-1,
.section-2,
.section-3,
.section-4,
.section-5,
.section-6,
.section-7,
.section-8,
.section-9,
.section-10,
.section-11,
.section-13,
.footer {
  padding-left: 50px !important;
  padding-right: 50px !important;
  .e-con-inner {
    max-width: 1150px !important;
    width: 100%;
  }
}

#contactForm {
  background-color: #FFF;
  padding: 50px 30px;
}

#contactForm p {
  text-align: center;
  font-size: 27px;
  font-weight: 500;
  line-height: 1.3;
  margin: 0 0 20px;
  color: #003366;
}

#contactForm .elementor-form .elementor-field:not(#contactForm .elementor-form .elementor-field.elementor-select-wrapper, #contactForm .elementor-form .elementor-field.elementor-acceptance-field),
#contactForm .elementor-field-group .elementor-select-wrapper select {
  color: #666 !important;
  font-size: 16px !important;
  padding: 14px 13px !important;
  border-radius: 12px;
  border: 1px solid #808080 !important;
  transition: all 0.3s;
}

#contactForm .elementor-form .elementor-field:not(#contactForm .elementor-form .elementor-field.elementor-select-wrapper, #contactForm .elementor-form .elementor-field.elementor-acceptance-field):hover,
#contactForm .elementor-form .elementor-field:not(#contactForm .elementor-form .elementor-field.elementor-select-wrapper, #contactForm .elementor-form .elementor-field.elementor-acceptance-field):focus,
#contactForm .elementor-field-group .elementor-select-wrapper select:hover,
#contactForm .elementor-field-group .elementor-select-wrapper select:focus {
  border: 1px solid #f26522 !important;
  transition: all 0.3s;
}

#contactForm .e-form__buttons {
  display: flex;
  justify-content: center;
  align-items: center;
}

#contactForm .e-form__buttons button {
  display: block;
  width: max-content;
  flex-basis: max-content;
  background-color: #f26522;
  color: #FFF;
  font-size: 14px;
  font-weight: 400;
  padding: 13px 40px;
  border-radius: 12px;
  margin: 10px 0 0;
  transition: all 0.3s;
}

#contactForm .e-form__buttons button:hover,
#contactForm .e-form__buttons button:focus {
  background-color: #292929;
  color: #FFF;
  transition: all 0.3s;
}
