@focus () {
    outline-style: solid;
    outline-color: blue;
    outline-width: 2px;
    outline-offset: 1px
} * {
      -webkit-box-sizing: border-box;
      -ms-box-sizing: border-box;
      box-sizing: border-box
  }

body {
    color: #353535
}

body.admin-bar .site-wrapper {
    height: calc(100vh - 32px)
}

.mobile-view {
    display: none
}

.thanks-view {
    display: none
}

.row {
    max-width: 1790px
}

.row.row-flip-column > .column, .row.row-flip-column > .columns {
    float: right
}

button, a, input[type="submit"] {
    cursor: pointer;
    -webkit-transition: all 250ms ease;
    -moz-transition: all 250ms ease;
    -ms-transition: all 250ms ease;
    -o-transition: all 250ms ease;
    transition: all 250ms ease
}

button:hover, a:hover, input[type="submit"]:hover {
    opacity: 0.8
}

div, li, p, a, span, h1, h2, h3, h4, h5, h6, button, input, button {
    font-family: 'Heebo', sans-serif;
    line-height: 1.2;
    outline: none
}

h1 {
    font-size: 55px;
    font-weight: 700;
    color: #353535;
    line-height: 1.1;
    margin-bottom: 0
}

h2 {
    font-size: 42px;
    font-weight: 700;
    color: #353535;
    line-height: 1.1
}

h3 {
    font-size: 32px;
    font-weight: 700;
    color: #353535;
    line-height: 1.1
}

.site-wrapper {
    position: relative;
    height: 100vh;
    background-position: top right;
    background-repeat: no-repeat
}

.site-wrapper > .fixed-site-wrapper {
    display: none;
    position: fixed;
    width: 100%;
    height: 341px;
    background-size: cover;
    right: 0;
    background-position: top right;
    background-repeat: no-repeat;
    top: 0
}

.main-overlay {
    position: absolute;
    display: block;
    width: 65.1%;
    height: 100%;
    left: 0;
    top: 0;
    padding: 22px 235px 0 100px;
    background-image: url("../../assets/images/site-desktop-overlay.png");
    background-repeat: no-repeat;
    background-position: top right;
    z-index: 9
}

.main-overlay header .logo-wrapper {
    text-align: center;
    margin-bottom: 40px
}

.main-overlay header .logo-wrapper.style2 {
    margin-bottom: 25px
}

.main-overlay header .header-title {
    position: relative
}

.main-overlay header .header-title .arrow-down {
    position: absolute;
    display: none;
    width: 0;
    height: 0;
    bottom: -25px;
    left: 0;
    right: 0;
    margin: auto;
    border-left: 25px solid transparent;
    border-right: 25px solid transparent;
    border-top: 25px solid #2e7f94;
    animation: upAndDown 0.8s linear 10
}

.site-container {
    max-width: 745px;
    margin: auto
}

.site-container .main-content {
    position: relative;
    padding: 25px 0;
    margin-top: 40px;
    border-top: 2px solid #2e7f94;
    border-bottom: 2px solid #2e7f94;
    font-size: 25px;
    font-weight: 700
}

.site-container .main-content p:last-child {
    margin-bottom: 0
}

.site-container .main-content.style2 {
    padding: 8px 0;
    margin-top: 30px
}

.about-me-mobile {
    position: absolute;
    width: 100%;
    top: 0;
    right: 0;
    z-index: 999;
    height: 0
}

.about-me-mobile .btn {
    margin-top: 16px
}

.about-me-mobile .entry-content {
    position: absolute;
    display: none;
    top: 0;
    background-color: #f7aa00;
    height: 100%;
    z-index: 9;
    padding: 15px 20px
}

.about-me-mobile .entry-content .inner {
    padding-top: 40px;
    display: block;
    max-width: 80%
}

.about-me-mobile .entry-content .inner h4 {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 25px
}

.about-me-mobile .entry-content .close {
    position: absolute;
    font-size: 45px;
    top: 5px;
    left: 18px;
    color: #353535
}

.about-me-mobile .entry-content .close span {
    font-weight: 600
}

.about-me-mobile.active {
    height: 100%
}

.about-me-mobile.active .entry-content {
    display: block
}

footer {
    position: absolute;
    width: 100%;
    height: 124px;
    padding: 0 2.81%;
    bottom: 0;
    left: 0
}

footer .footer-top {
    z-index: 8
}

footer .footer-top .about-me-wrapper {
    position: absolute;
    bottom: 141px;
    right: 0;
    background-color: #f7aa00;
    margin-right: 2.81%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: flex;
    align-items: flex-end;
    -webkit-align-items: flex-end;
    -moz-align-items: flex-end;
    -webkit-box-align: end;
    -ms-flex-align: end
}

footer .footer-top .about-me-wrapper .btn {
    display: block;
    width: 112px;
    height: 100px;
    font-size: 22px;
    text-align: center;
    color: #353535;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: flex;
    justify-content: center;
    -webkit-justify-content: center;
    -moz-justify-content: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    align-items: center;
    -webkit-align-items: center;
    -moz-align-items: center;
    -webkit-box-align: center;
    -ms-flex-align: center
}

footer .footer-top .about-me-wrapper .btn span {
    display: block;
    font-weight: 600
}

footer .footer-top .about-me-wrapper .btn span:first-child {
    font-size: 43px
}

footer .footer-top .about-me-wrapper .entry-content {
    display: none;
    max-width: 40%;
    padding: 30px 35px 0 0;
    font-size: 25px
}

footer .footer-top .about-me-wrapper .entry-content p {
    margin-bottom: 5%
}

footer .footer-top .about-me-wrapper.active .entry-content {
    display: block
}

footer .footer-bottom {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: flex;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    height: 100%;
    z-index: 99
}

footer .footer-bottom .footer-form {
    flex: 0 1 1570px;
    -webkit-flex: 0 1 1570px;
    -ms-flex: 0 1 1570px;
    -webkit-box-flex: 0 1 1570px;
    -moz-box-flex: 0 1 1570px;
    -moz-flex: 0 1 1570px;
    padding: 0 2.21%;
    height: 100%;
    background-color: #f7aa00;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: flex;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    align-items: center;
    -webkit-align-items: center;
    -moz-align-items: center;
    -webkit-box-align: center;
    -ms-flex-align: center
}

footer .footer-bottom .footer-phone {
    flex: 0 0 218px;
    -webkit-flex: 0 0 218px;
    -ms-flex: 0 0 218px;
    -webkit-box-flex: 0 0 218px;
    -moz-box-flex: 0 0 218px;
    -moz-flex: 0 0 218px;
    height: 100%;
    background-color: #2e7f94;
    -webkit-transition: all 250ms ease;
    -moz-transition: all 250ms ease;
    -ms-transition: all 250ms ease;
    -o-transition: all 250ms ease;
    transition: all 250ms ease
}

footer .footer-bottom .footer-phone a {
    position: relative;
    display: block;
    height: 100%;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: flex;
    justify-content: center;
    -webkit-justify-content: center;
    -moz-justify-content: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    align-items: center;
    -webkit-align-items: center;
    -moz-align-items: center;
    -webkit-box-align: center;
    -ms-flex-align: center
}

footer .footer-bottom .footer-phone a .icon {
    padding-top: 5px;
    text-align: center
}

footer .footer-bottom .footer-phone a .icon img {
    position: absolute;
    display: block;
    max-width: 85px;
    left: 0;
    right: 0;
    top: 10px;
    margin: auto
}

footer .footer-bottom .footer-phone a .text {
    font-size: 28px;
    color: #fff;
    font-weight: 500;
    margin-top: 75px
}

footer .footer-bottom .footer-phone a:hover .icon .animate-wrench {
    animation-iteration-count: infinite
}

footer .footer-bottom .footer-form {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: flex;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    align-items: center;
    -webkit-align-items: center;
    -moz-align-items: center;
    -webkit-box-align: center;
    -ms-flex-align: center
}

footer .footer-bottom .footer-form .form-title {
    flex: 0 1 385px;
    -webkit-flex: 0 1 385px;
    -ms-flex: 0 1 385px;
    -webkit-box-flex: 0 1 385px;
    -moz-box-flex: 0 1 385px;
    -moz-flex: 0 1 385px;
    margin-left: 23px
}

footer .footer-bottom .footer-form .entry-form {
    flex: 1;
    -webkit-flex: 1;
    -ms-flex: 1;
    -webkit-box-flex: 1;
    -moz-box-flex: 1;
    -moz-flex: 1
}

footer .footer-bottom .footer-form .entry-form form {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: flex;
    justify-content: space-between;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    align-items: center;
    -webkit-align-items: center;
    -moz-align-items: center;
    -webkit-box-align: center;
    -ms-flex-align: center
}

footer .footer-bottom .footer-form .entry-form form label {
    position: relative;
    flex: 0 1 230px;
    -webkit-flex: 0 1 230px;
    -ms-flex: 0 1 230px;
    -webkit-box-flex: 0 1 230px;
    -moz-box-flex: 0 1 230px;
    -moz-flex: 0 1 230px
}

footer .footer-bottom .footer-form .entry-form form label.label-checkbox {
    position: absolute;
    display: block;
    bottom: -28px;
    right: 0;
    width: 100%
}

footer .footer-bottom .footer-form .entry-form form label.label-checkbox span.wpcf7-list-item {
    margin: 0
}

footer .footer-bottom .footer-form .entry-form form input {
    position: relative;
    display: block;
    height: 55px;
    padding: 0 25px;
    border: 0;
    color: #353535;
    margin-bottom: 0;
    text-align: center;
    font-size: 18px;
    font-weight: 500;
    -webkit-box-shadow: 0;
    -moz-box-shadow: 0;
    box-shadow: 0
}

footer .footer-bottom .footer-form .entry-form form input::-webkit-input-placeholder {
    color: #353535;
    opacity: 1
}

footer .footer-bottom .footer-form .entry-form form input:-moz-placeholder {
    color: #353535;
    opacity: 1
}

footer .footer-bottom .footer-form .entry-form form input::-moz-placeholder {
    color: #353535;
    opacity: 1
}

footer .footer-bottom .footer-form .entry-form form input:-ms-input-placeholder {
    color: #353535;
    opacity: 1
}

footer .footer-bottom .footer-form .entry-form form input[type=submit] {
    background-color: #2e7f94;
    color: #fff;
    font-size: 22px;
    font-weight: 600;
    cursor: pointer;
    flex: 0 1 348px;
    -webkit-flex: 0 1 348px;
    -ms-flex: 0 1 348px;
    -webkit-box-flex: 0 1 348px;
    -moz-box-flex: 0 1 348px;
    -moz-flex: 0 1 348px
}

footer .footer-bottom .footer-form .entry-form form input[type="checkbox"] {
    display: inline-block;
    height: auto;
    vertical-align: middle;
    opacity: 0
}

footer .footer-bottom .footer-form .entry-form form input[type="checkbox"] + .wpcf7-list-item-label {
    padding-right: 6px;
    font-weight: 500
}

footer .footer-bottom .footer-form .entry-form form input[type="checkbox"] + .wpcf7-list-item-label:before {
    position: absolute;
    display: block;
    width: 12px;
    height: 12px;
    top: 4px;
    right: 0;
    background-color: #fff;
    border: 2px solid #fff
}

footer .footer-bottom .footer-form .entry-form form input[type="checkbox"]:checked + .wpcf7-list-item-label:before {
    background-color: #07292e
}

footer .footer-bottom .footer-form .entry-form .submit-warpper {
    position: relative
}

footer .footer-bottom .footer-form .entry-form div.wpcf7-validation-errors, footer .footer-bottom .footer-form .entry-form div.wpcf7-acceptance-missing, footer .footer-bottom .footer-form .entry-form div.wpcf7-mail-sent-ok {
    position: absolute;
    right: 0;
    top: -25px;
    border: 0;
    margin: 0;
    padding: 0
}

footer .footer-bottom .footer-form .entry-form div.wpcf7-validation-errors.wpcf7-mail-sent-ok, footer .footer-bottom .footer-form .entry-form div.wpcf7-acceptance-missing.wpcf7-mail-sent-ok, footer .footer-bottom .footer-form .entry-form div.wpcf7-mail-sent-ok.wpcf7-mail-sent-ok {
    color: green
}

footer .footer-bottom .footer-form .entry-form div.wpcf7 .wpcf7-form-control-wrap {
    position: initial
}

footer .footer-bottom .footer-form .entry-form div.wpcf7 span.wpcf7-not-valid-tip {
    position: absolute;
    right: 0;
    display: block;
    width: 100%
}

footer .footer-bottom .footer-form .entry-form div.wpcf7 .ajax-loader {
    position: absolute;
    left: 0;
    bottom: 0
}

.fixed-mobile-footer {
    position: fixed;
    width: 100%;
    background-color: #fff;
    padding-bottom: 16px;
    bottom: 0
}

.fixed-mobile-footer .contact-us-button {
    position: absolute;
    width: 192px;
    height: 64px;
    background-color: #f7aa00;
    top: 0;
    left: 12%;
    padding: 7px 15px 0;
    text-align: center
}

.fixed-mobile-footer .contact-us-button a {
    cursor: pointer;
    display: block
}

.fixed-mobile-footer .contact-us-button span {
    font-size: 22px;
    color: #555555;
    font-weight: 600
}

.fixed-mobile-footer:after {
    content: '';
    position: absolute;
    display: block;
    width: 100%;
    height: 25px;
    top: -25px;
    left: 0;
    background: #f8f8f8;
    background: -moz-linear-gradient(0deg, #f8f8f8 0%, rgba(255, 255, 255, 0) 100%);
    background: -webkit-linear-gradient(0deg, #f8f8f8 0%, rgba(255, 255, 255, 0) 100%);
    background: linear-gradient(0deg, #f8f8f8 0%, rgba(255, 255, 255, 0) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#f8f8f8", endColorstr="#ffffff", GradientType=1)
}

button.slick-arrow {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 18px;
    background-repeat: no-repeat;
    background-size: contain;
    background-image: url("../../assets/images/arrow-slider-right.png");
    background-position: center;
    text-indent: -9999999px;
    z-index: 99
}

button.slick-arrow.slick-prev {
    left: 0;
    background-image: url("../../assets/images/arrow-slider-left.png")
}

.main-tab-wrapper .tabs-trigger {
    position: relative;
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flexbox;
    display: flex;
    justify-content: space-around;
    -webkit-justify-content: space-around;
    -moz-justify-content: space-around;
    -ms-flex-pack: distribute;
    align-items: center;
    -webkit-align-items: center;
    -moz-align-items: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    margin-bottom: 30px
}

.main-tab-wrapper .tabs-trigger .title {
    flex: 0 1 205px;
    -webkit-flex: 0 1 205px;
    -ms-flex: 0 1 205px;
    -webkit-box-flex: 0 1 205px;
    -moz-box-flex: 0 1 205px;
    -moz-flex: 0 1 205px;
    background-color: #96bfc9
}

.main-tab-wrapper .tabs-trigger .title.active {
    background-color: #2e7f94
}

.main-tab-wrapper .tab-wrapper .content {
    display: none
}

.main-tab-wrapper .tab-wrapper .content.active {
    display: block
}

.main-tab-wrapper .title {
    position: relative;
    font-size: 20px;
    color: #fff;
    padding: 12px;
    text-align: center
}

.main-tab-wrapper .title span {
    line-height: 1
}

.main-tab-wrapper .title.mobile-view {
    width: 100%;
    background-color: #2e7f94;
    text-align: right;
    padding-right: 65px
}

.main-tab-wrapper .title.mobile-view span:after {
    content: '+';
    position: absolute;
    display: block;
    top: 10px;
    left: 12px;
    font-size: 30px;
    font-weight: 400
}

.main-tab-wrapper .title.mobile-view:before {
    content: '';
    position: absolute;
    display: block;
    width: 500%;
    height: 2px;
    top: 0;
    right: -50%;
    background-color: #2e7f94
}

.main-tab-wrapper .title.mobile-view.active span:after {
    content: '-'
}

.main-tab-wrapper .content {
    font-size: 17px;
    font-weight: 600;
    height: 130px
}

.main-slider-wrapper {
    margin-top: 15px
}

.main-slider-wrapper .slide-main-wrapper {
    text-align: center
}

.main-slider-wrapper .slide-main-wrapper .image {
    padding-top: 35px;
    min-height: 130px
}

.main-slider-wrapper .slide-main-wrapper .image img {
    margin: auto
}

.main-slider-wrapper .slide-main-wrapper .title {
    font-size: 18px;
    font-weight: 600
}

.main-slider-wrapper .slide-main-wrapper:first-child .image {
    padding-top: 25px
}

.main-slider-wrapper.style2 .slide-main-wrapper {
    text-align: center
}

.main-slider-wrapper.style2 .slide-main-wrapper .image {
    padding-top: 25px;
    min-height: 90px
}

.main-slider-wrapper.style2 .slide-main-wrapper .image img {
    max-width: 55px
}

.main-slider-wrapper.style2 .slide-main-wrapper:first-child .image {
    padding-top: 20px
}

.main-slider-wrapper.style2 button.slick-arrow {
    background-image: url("../../assets/images/arrow-slider-right2.png");
    right: 10px
}

.main-slider-wrapper.style2 button.slick-arrow.slick-prev {
    background-image: url("../../assets/images/arrow-slider-left2.png");
    left: 10px;
    right: auto
}

.page-template-tpl-thanks .site-container .main-content {
    border-top: 0;
    border-bottom: 0;
    padding-top: 40px
}

.page-template-tpl-thanks .site-container .main-content h1 {
    position: relative;
    font-size: 155px;
    padding-bottom: 20px
}

.page-template-tpl-thanks .site-container .main-content h1:after {
    content: '';
    position: absolute;
    display: block;
    width: 91px;
    height: 2px;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #2e7f94;
    margin: auto
}

.page-template-tpl-thanks .site-container .main-content h2 {
    padding-top: 50px
}

@keyframes spin {
    0% {
        transform: rotate(0deg)
    }
    100% {
        transform: rotate(360deg)
    }
}

.animate-wrench {
    -webkit-transform-origin: center;
    transform-origin: center;
    animation-duration: .75s;
    animation-timing-function: ease-out;
    animation-iteration-count: 5;
    animation-name: wrench
}

@keyframes wrench {
    0% {
        transform: rotate(0deg)
    }
    20% {
        transform: rotate(15deg)
    }
    60% {
        transform: rotate(-15deg)
    }
    100% {
        transform: rotate(0deg)
    }
}

@keyframes upAndDown {
    0%, 100% {
        margin-bottom: 0
    }
    50% {
        margin-bottom: 5px
    }
}

@media (max-width: 1400px) {
    footer .footer-bottom .footer-form {
        flex-wrap: wrap !important;
    }

    footer .footer-bottom .footer-form .form-title {
        flex: unset !important;
    }
}