@import url(https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap);

body {
    background: #f2f2f2;
    padding: 0;
    margin: 0;
    font-family: "Inter", sans-serif;
    font-optical-sizing: auto;
    font-style: normal
}

.align-middle {
    justify-content: center;
    align-self: center;
    z-index: 11
}

a {
    cursor: pointer
}

.desktop {
    display: block
}

.mobile {
    display: none
}

.full-width {
    width: 1900px;
    clear: both;
    position: relative;
    margin: 0 auto;
    background: #fff;
    display: flex;
    flex-wrap: wrap
}

@media (min-width:1200px) and (max-width:1699px) {
    .full-width {
        max-width: 100%
    }
}

@media (min-width:768px) and (max-width:1199px) {
    .full-width {
        max-width: 100%
    }
}

.section {
    width: 1350px;
    position: relative;
    margin: 0 auto;
    padding: 70px 0;
    display: flex
}

@media (min-width:1200px) and (max-width:1399px) {
    .section {
        max-width: calc(100% - 40px);
        padding-left: 20px !important;
        padding-right: 20px !important
    }
}

.section.no-padding {
    padding-top: 0 !important;
    margin-top: -20px
}

@media (min-width:768px) and (max-width:1199px) {
    .section {
        max-width: calc(100% - 40px);
        padding-left: 20px !important;
        padding-right: 20px !important
    }
}

.section.header {
    display: block;
    height: 30px
}

.header-wrapper {
    background: #fff;
    z-index: 2
}

.header-wrapper .section {
    padding: 0 50px;
    height: 50px;
    display: block
}

.header {
    position: fixed;
    top: 0;
    width: 100%;
    max-width: 1900px;
    z-index: 1;
    transition: all 0.5s ease;
    padding: 30px 0
}

.header.animated {
    padding: 20px 0 15px;
    z-index: 111;
    background-color: #F4F7F2
}

.one-half {
    width: 50%
}

.one-fourth {
    width: 25%
}

.one-third {
    width: 33.33%
}

.one-half,
.one-fourth,
.one-third {
    display: flex;
    flex-wrap: wrap
}

.fourty-percent{
    width: 40%;
}

.sixty-percent{
    width: 60%;
}

.clear {
    clear: both
}

p {
    font-size: 16px;
    line-height: 1.7;
    font-weight: 400;
    padding: 0;
    margin: 0 0 25px
}

p,
li,
a {
    font-size: 16px;
    line-height: 1.7
}

h1 {
    font-size: 60px;
    line-height: 1.1;
    font-weight: 400
}

h2 {
    font-size: 40px;
    line-height: 1.1;
    font-weight: 400
}

img {
    max-width: 100%;
    height: auto
}

.read-more,
a {
    color: #649c64;
    font-weight: 500
}

.read-more::after {
    content: ">";
    position: absolute;
    padding-left: 4px
}

.arr-cta,
.main-cta-arr {
    background: url(images/arr-cta.svg) no-repeat right center;
    padding-right: 50px;
    transition: all 0.5s ease;
    color: #649c64;
    text-decoration: none;
    font-size: 20px;
}

.arr-cta:hover,
.main-cta-arr:hover {
    padding-right: 60px;
    transition: all 0.5s ease
}

.arr-cta.bg-reverse,
.main-cta-arr.bg-reverse {
    background-color: #fff;
    padding-top: 15px;
    padding-bottom: 15px;
    padding-left: 30px;
    justify-content: flex-end
}

.flex-end {
    justify-content: flex-end
}

.flex-end a:hover {
    padding-right: 50px;
    background-color: #F4F7F2;
    color: #333;
    transition: all 0.5s ease
}

.no-flex {
    display: block
}

h1,
h2,
h3,
h4,
h5,
h6 {
    padding: 0;
    margin: 0 0 30px
}

h2 {
    font-size: 32px;
    line-height: 1.3
}

h3 {
    font-weight: 500;
    font-size: 24px
}

.logo {
    float: left;
    width: 250px;
    height: 50px
}

.logo img{
    max-width: 170px;
}

.navigation {
    float: left;
    margin-top: 20px;
    height: 25px
}

.navigation li {
    display: inline-block;
    margin: 0 0 0 15px;
    position: relative
}

.navigation a {
    color: #333;
    text-decoration: none
}

.header-ctas {
    float: right
}

.header-ctas ul li {
    display: inline-block;
    margin: 0 0 0 20px
}

.header-ctas ul li a {
    text-decoration: none
}

.header-ctas ul li a.tel {
    color: #333;
    background: url(images/tel.svg) no-repeat left center;
    padding-left: 40px
}

.header-ctas ul li a.main-cta {
    margin: 0;
    background-color: #000;
    border: 1px solid #fff;
    padding-left: 50px;
    padding-right: 50px;
    border-radius: 50px;
    transition: all 0.5s ease;
}
.header-ctas ul li a.main-cta:hover {
    border:1px solid #000;
    color: #000;
    transition: all 0.5s ease;
    background: transparent;
}
.intro-points {
    background: #273D3C;
    color: #fff;
    padding: 50px 0
}

.intro-points .ip-left-padding {
    padding-right: 100px
}

.intro-points .ip-left-padding h2 {
    font-size: 40px;
    line-height: 1.25;
    font-weight: 600
}

.intro-points .ip-left-padding p {
    padding-right: 100px
}

.intro-points .ip-img {
    max-width: 420px;
    height: auto;
    bottom: -80px;
    position: absolute;
    opacity: .05
}

.main-points {
    display: flex;
    flex-wrap: wrap
}

.main-points li {
    display: inline-block;
    margin-bottom: 50px;
    border-right: 1px solid #0C6460;
    width: calc(50% - 51px);
    padding-left: 50px
}

.main-points li:nth-child(even) {
    border: 0
}

.main-points li h3 {
    font-size: 50px;
    line-height: 1.1;
    margin-bottom: 0;
    font-weight: 300
}

.soft-bg-wrapper {
    background: #fff
}

.primary-bg-wrapper {
    background: #0C6460;
    color: #fff
}

.primary-bg-wrapper li {
    color: #333;
    border-radius: 10px;
    overflow: hidden
}



.hero-wrapper img {
    border-radius: 10px;
}

.hero {
    padding-top: 170px;
    padding-bottom: 70px
}

ul {
    padding: 0;
    margin: 0
}

.asb-half {
    position: absolute;
    top: 0;
    width: 50%;
    height: 100%
}

.asb-half.float-right {
    right: 0
}

.asb-half.float-left {
    left: 0
}

.asb-half img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.one-third {
    width: 33.33%
}

.two-third {
    width: 66.66%
}

@media only screen and (max-width:767px) {
    .two-third {
        width: 100%
    }
}

a.main-cta {
    background: #0C6460;
    display: inline-block;
    padding: 15px 80px;
    border-radius: 5px;
    color: #fff
}

.main-hero .hero-padding {
    padding: 0 100px 0 0
}

.main-hero h1 {
    font-size: 14px;
    text-transform: uppercase;
    display: block;
    color: #000;
    float: left;
    margin: 0 0 20px;
    font-weight: 400
}

.main-hero p {
    display: block;
    clear: both
}

.main-hero p:nth-of-type(1) {
    font-size: 42px;
    line-height: 45px;
    font-weight: 700
}

.main-hero a {
    text-decoration: none;
    transition: all 0.5s ease;
    border: 1px solid #fff0;
    border-radius: 25px;
    margin-top: 50px;
    background: #0C6460;
    display: block;
    max-width: 200px;
    text-align: center;
    color: #fff;
    padding: 5px 50px;
    border-radius: 50px;
    height: 40px;
    line-height: 40px
}

.main-hero a:hover {
    border: 1px solid #0C6460;
    background: #fff0;
    color: #000;
    transition: all 0.5s ease
}

.main-hero ul,
.main-post-content ul {
    padding: 0;
    margin: 20px 0 0 0
}

.main-hero ul li,
.main-post-content ul li {
    margin-bottom: 20px;
    display: block;
    position: relative;
    padding-left: 30px
}

.main-hero ul li:before,
.main-post-content ul li:before {
    position: absolute;
    top: 4px;
    left: 0;
    width: 20px;
    height: 20px;
    background: #649C61 url(images/tick-list.svg) no-repeat center center;
    background-size: 35px auto;
    content: "";
    border-radius: 50% 50%;
}

.main-post-content ul {
    margin-left: 20px;
    margin-bottom: 50px
}

.column-lists ul {
    display: flex;
    flex-wrap: wrap;
    width: 100%
}

.column-lists li {
    position: relative;
    display: block;
    margin: 0 2% 2% 0;
    background-color: #fff;
    display: flex;
    flex-wrap: wrap
}

.three-column li {
    width: 32%
}

.three-column li .home-services-intro {
    padding: 50px 30px;
    background-color: #F4F7F2;
    border-radius: 5px
}

.home-services-intro img{
    max-width: 70px;
    height: auto;
}

.three-column li:nth-child(3n) {
    margin-right: 0
}

.three-column li img,
.three-column li svg {
    margin-bottom: 20px
}
.two-column-wrapper{
    background: #F6F7F1;
    padding-top: 100px;
}
.two-column li {
    width: 49%;
    display: block;
    border-radius: 10px;
    overflow: hidden
}

.two-column-wrapper .home-services-intro{
    padding: 35px;
}

.two-column li:nth-child(2n) {
    margin-right: 0
}

.points-padding {
    padding: 0 30px 0 0
}

.points-padding h2 {
    font-size: 30px
}

.intro-top h2 {
    font-size: 32px;
    float: left;
    clear: both;
    font-weight: 600;
    margin-bottom: 10px
}

.intro-top h2 span{
    border-bottom: 5px solid #649C61;
}

.intro-top p:nth-of-type(1) {
    font-size: 16px;
    line-height: 1.1;
    font-weight: 400
}

.about-padding {
    padding: 50px 100px
}

.zz-padding {
    padding-bottom: 60px
}

.zz-blocks {
    padding-bottom: 0;
    margin-bottom:30px;
    margin-top: 0;
}

.zz-blocks img{
    border-radius: 10px !important;
}

.zz-blocks:nth-child(2n) .zz-image {
    order: 2
}

.zz-image {
    overflow: hidden
}

.zz-image img {
    object-fit: cover;
    border-radius: 35px 70px
}

.zz-image img.no-border {
    border-radius: 0 !important
}

.case-wrapper {
    border-radius: 5px
}

.case-wrapper .case-image {
    position: absolute;
    left: 0;
    top: 0;
    width: 40%;
    height: 100%
}

@media only screen and (max-width:767px) {
    .case-wrapper .case-image {
        width: 100%;
        height: 200px;
        position: relative
    }
}

.case-wrapper .case-image img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.case-wrapper .case-intro {
    margin-left: 40%
}

@media only screen and (max-width:767px) {
    .case-wrapper .case-intro {
        width: 100%;
        margin-left: 0
    }
}

.case-wrapper .ci-padding {
    padding: 30px 50px
}

.sticky {
    position: sticky;
    left: 0;
    top: 0
}


.faq-wrapper,
.contact-wrapper{
    background: #F6F7F1;
}
.all-faqs {
    width: 100%;
    padding: 0;
}

.all-faqs li {
    display: block;
    background: #fff;
    padding: 20px;
    border-radius: 5px;
    margin-bottom: 20px;
    position: relative;
    cursor: pointer
}

.all-faqs li span {
    display: none
}

.all-faqs li.active h2:after {
    transform: rotate(0deg);
    transition: all 0.15s ease
}

.all-faqs li.active span {
    display: block
}

.all-faqs li h2 {
    font-size: 20px;
    font-weight: 500;
    padding: 0 20px 0 0;
    margin: 0 0 15px
}

.all-faqs li h2:after {
    content: "";
    width: 40px;
    height: 40px;
    background: green;
    position: absolute;
    right: 10px;
    top: 10px;
    background: url(images/arr.png) no-repeat center center;
    background-size: 30px;
    transform: rotate(180deg);
    transition: all 0.15s ease
}

.all-faqs li p {
    font-size: 16px;
    font-weight: 400
}

.adjusted-padding-faq {
    padding-right: 100px;
    top: 100px
}

.adjusted-padding-faq h2 {
    font-weight: 500
}

.adjusted-padding-faq p {
    display: block;
    max-width: 500px;
    margin-top: 40px;
    font-size: 15px
}

.lead-form {
    padding: 30px 50px 30px;
    width: 100%
}

.lead-form h2 {
    font-weight: 600;
    margin-top: 50px;
    letter-spacing: -1px
}

.lead-form p {
    display: block;
    max-width: 500px;
    margin-top: 40px;
    font-size: 15px
}

.lead-form li {
    display: block
}

.lead-form a.lead-form-tel {
    color: #0C6460;
    background: url(images/tel.svg) no-repeat left center;
    padding-left: 40px;
    font-size: 26px;
    text-decoration: none
}

.lead-form ul {
    margin-bottom: 10px
}

.lead-form-wrapper {
    margin-bottom: -150px;
    margin-top: 100px;
    position: relative;
    z-index: 2;
    border-radius: 15px;
    overflow: hidden
}

@media (min-width:1200px) and (max-width:1399px) {
    .lead-form-wrapper {
        margin-left: 20px;
        margin-right: 20px;
        max-width: calc(100% - 80px)
    }

    .lead-form-wrapper .order-one img {
        margin-left: 20px
    }
}

.blog-lists .hero-image {
    width: 100%
}

.blog-lists img {
    height: 250px;
    width: 100%;
    object-fit: cover
}

.blog-lists li {
    display: block
}

.all-stories-wrapper {
    display: block;
    width: 100%;
    margin-top: 90px
}

.all-stories-wrapper li {
    position: relative;
    display: block;
    border-radius: 15px;
    overflow: hidden;
    margin: 0 0 60px;
    border: 1px solid #FCFAF8;
    box-shadow: 1px 2px #eee
}

.all-stories-wrapper .case-intro {
    display: flex;
    background-color: #FCFAF8
}

.all-stories-wrapper .case-intro h2 {
    font-size: 40px;
    font-weight: 400
}

.all-stories-wrapper .case-intro p {
    display: block;
    max-width: 90%
}

.author-bio {
    background: #f1f1f1;
    position: relative;
    padding: 20px;
    margin-top: 40px
}

.author-bio .author-pic {
    position: absolute;
    left: 20px;
    top: 20px;
    width: 100px;
    height: 100px
}

.author-bio .author-pic img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50% 50%
}



.author-bio .author-details h3 {
    padding: 0;
    margin: 0 0 10px;
    font-size: 20px
}

.author-bio .author-details p {
    margin-bottom: 0;
    line-height: 1.4;
    display: block;
    font-size: inherit !important;
}

.author-bio .author-details a {
    color: #649c64
}

.author-bio-header p {
    display: block;
    margin-top: 20px
}

.author-bio-header a {
    color: #649c64
}

.footer {
    padding-top: 200px;
    background: #000;
    color: #fff
}

.footer-about{
    width: 100%;
}

.footer .section {
    z-index: 1
}

.footer .footer-svg {
    opacity: .2
}

.footer .address {
    line-height: 30px
}

.footer .footer-logo {
    margin-bottom: 20px
}

.footer-logo{
    max-width: 150px;
    height: auto;
}
.footer h4 {
    font-size: 20px;
    font-weight: 400;
    margin-top: 22px
}

.footer .column {
    min-width: 25%;
    flex-wrap: wrap;
    display: flex
}

.footer p {
    font-size: 15px;
    font-weight: 400
}

.footer .footer-services {
    padding: 0 100px
}

.footer .footer-services ul {
    display: flex;
    flex-wrap: wrap
}

.footer .footer-services li {
    display: inline-block;
    width: 50%
}

.footer li {
    margin-bottom: 12px
}

.footer a {
    color: #fff;
    text-decoration: none
}

.contact-form .no-padding {
    padding-top: inherit;
    margin-top: 100px
}

@media only screen and (max-width:767px) {
    .contact-form .no-padding {
        margin-top: 80px
    }
}

.footer-contact-details {
    display: block;
    width: 100%;
    margin: 0;
    padding: 0
}

.footer-contact-details li {
    display: block;
    width: 100%
}

.footer-associations li {
    display: inline-block;
    width: 45%;
    margin-right: 5%
}

.footer-bottom {
    display: block;
    border-top: 1px solid #333;
    padding: 30px 0;
    font-size: 12px;
    font-weight: 400;
    color: #fff;
    margin-top: 10px
}

.footer-bottom .fb-left {
    float: left
}

.footer-bottom .fb-right {
    float: right
}

.footer-bottom a {
    text-decoration: underline;
    color: #fff;
    font-weight: 300;
    font-size: 12px
}

.pss p {
    font-size: 15px
}

.pss img {
    max-width: 100px
}

.small-paragraph p {
    font-size: 15px;
    line-height: 1.7
}

.featured-post-intro {
    padding: 10px 30px 40px
}

.featured-post-intro h3 {
    margin-top: 20px
}

.margin-fixed-top {
    margin-top: 100px
}

.margin-fixed-top h1 {
    margin-bottom: 0
}

.specific-service-intro {
    display: none;
    padding-bottom: 40px
}

.specific-service-intro:nth-child(1) {
    display: block
}

.specific-service-intro img {
    width: 100%;
    display: block;
    margin: 0 0 30px
}

.specific-service-intro h2 {
    padding: 0;
    margin: 0 0 20px;
    font-size: 30px
}

.services-list ul {
    width: calc(100% - 60px)
}

.services-list li {
    display: block;
    padding: 10px 0;
    font-size: 20px;
    border-bottom: 1px solid #dedede
}

.services-list li.active {
    text-indent: 25px
}

.cta-wrapper {
    padding: 50px 0
}

.cta-wrapper h2 {
    padding: 0;
    margin: 0 0 10px
}

.form-wrapper {
    width: calc(100% - 100px);
    padding-left: 100px
}

.main-service h2 {
    font-size: 30px;
    font-weight: 600;
    margin-top: 40px;
    margin-bottom: 15px
}

.main-service .section {
    max-width: 900px;
    display: block
}

.main-service .section img {
    width: 100%;
    height: auto
}

.main-service.adj-bg::before {
    background-color: #fff;
    height: 200px;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    content: ""
}

.blog-lists-wrapper .hero-image {
    width: 100%
}

.blog-lists-wrapper img {
    height: 300px;
    width: 100%;
    object-fit: cover
}

.blog-intro {
    padding-bottom: 0;
    padding-top: 100px
}

@media only screen and (max-width:767px) {
    .blog-intro {
        padding-top: 0
    }
}

.blog-intro .intro-wrapper {
    padding-right: 100px
}

@media only screen and (max-width:767px) {
    .blog-intro .intro-wrapper {
        padding-right: 0
    }

    .blog-intro .intro-wrapper h1 {
        font-size: 32px
    }
}

.blog-featured {
    margin-top: -200px;
    border-radius: 10px
}

.blog-post {
    flex-wrap: wrap
}

.blog-post .full-width {
    display: flex;
    flex-wrap: wrap
}

.blog-post .separator-post {
    display: block;
    width: 100%;
    padding-top: 60px;
    display: block;
    margin-top: -110px
}

.blog-post .toc-wrapper {
    width: 100%
}

.blog-post .toc-wrapper .sticky {
    top: 100px
}

.blog-post .toc-wrapper ul {
    background-color: #fafafa;
    padding: 20px;
    border-radius: 10px;
    top: 100px
}

.blog-post .toc-wrapper li {
    display: block;
    margin-bottom: 20px;
    border-bottom: 1px solid #dedede;
    padding-bottom: 10px
}

.blog-post .toc-wrapper li a {
    color: #333;
    text-decoration: none
}

.blog-post .toc-wrapper h4 {
    font-size: 24px;
    padding: 0;
    margin: 0 0 0;
    font-weight: 500;
    color: #0C6460
}

.blog-post .toc-wrapper .youtube {
    background: red;
    padding: 10px 20px;
    display: block;
    height: 40px;
    line-height: 40px;
    border-radius: 5px;
    margin-top: 30px;
    text-align: center;
    color: #fff;
    text-decoration: none
}

@media only screen and (max-width:767px) {
    .blog-post .toc-wrapper .youtube {
        display: none
    }
    .toc-wrapper{
        display: none;
    }
}

.blog-post .main-post-content {
    padding: 0 50px;
}

.blog-post .main-post-content p:nth-of-type(1){
    font-size: 22px;
}

@media only screen and (max-width:767px) {
    .blog-post .main-post-content {
        padding: 0
    }
}

.blog-post .main-post-content h2 {
    margin-top: 50px;
    display: block
}

.narrow-content {
    max-width: 900px;
    margin: 60px auto 0
}

.narrow-content h1 {
    font-size: 36px
}

.specific-page img {
    width: 100%;
    max-height: 600px;
    object-fit: cover
}

.specific-page h1 {
    margin-bottom: 40px
}

.menu-item-has-children {
    padding-bottom: 0;
    padding-right: 30px;
    padding-bottom: 20px
}

.menu-item-has-children .submenu-toggle {
    content: "";
    width: 40px;
    height: 40px;
    position: absolute;
    right: -2px;
    top: -5px;
    background: url(images/arr.png) no-repeat center center;
    background-size: 30px;
    transform: rotate(180deg)
}

.sub-menu {
    position: absolute;
    background: #f1f2f3;
    width: 300px;
    border-radius: 5px;
    left: -70px;
    z-index: 11;
    padding: 20px;
    top: 34px;
    display: none
}

.sub-menu li {
    display: block;
    padding: 2px 0 10px;
    margin-bottom: 5px
}

.menu li:hover .sub-menu {
    display: block
}

.main-level {
    width: 16%;
    float: left;
    display: block
}

.main-level .sub-menu {
    position: relative;
    top: 0;
    left: 0;
    padding: 0;
    margin: 0;
    border: 0
}

.main-level .sub-menu li {
    display: block;
    margin-left: 0
}

.main-level .sub-menu li a {
    font-size: 14px;
    font-weight: 300;
    padding: 10px 0 4px 0;
    display: block
}

.main-level .sub-menu li a:hover {
    text-decoration: underline
}

#nav-toggle,
.mobile-footer {
    display: none
}

.no-bg {
    background: #fff0
}

.specific-cta-wrapper {
    padding: 50px;
    border-radius: 20px;
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    box-shadow: 1px 1px #dedede;
    background: #fff;
    background-size: auto 100%
}

.specific-cta-wrapper h2 {
    padding: 0;
    margin: 0 0 15px
}

.specific-cta-wrapper a {
    background: #ff972e;
    border-radius: 100px;
    width: 100%;
    text-align: center;
    text-decoration: none;
    font-size: 20px;
    color: #fff;
    padding: 10px 5px;
    height: 40px;
    line-height: 40px
}

.cta-adjusted {
    padding: 0;
    margin-top: -100px;
    z-index: 2
}

@media only screen and (max-width:767px) {
    body {
        overflow-x: hidden
    }

    html,
    body {
        width: 100%
    }

    .section {
        padding: 40px 0
    }

    .main-points {
        margin-left: -40px;
        margin-top: 20px
    }

    .main-hero p:nth-of-type(1) {
        font-size: 32px !important
    }

    h2 {
        font-size: 30px !important
    }

    .intro-points {
        padding: 0
    }

    .intro-points p {
        padding-right: 0 !important
    }

    .sticky {
        position: relative;
        top: 0
    }

    .intro-top p {
        min-width: 85%
    }

    .intro-top p:nth-of-type(1) {
        line-height: 1.2
    }

    .all-faqs h2 {
        font-size: 20px !important
    }

    h3 {
        font-size: 24px !important
    }

    p {
        font-size: 16px !important
    }

    .lead-form {
        padding: 30px
    }

    .lead-form h2 {
        margin-top: 0;
        margin-bottom: 10px
    }

    .lead-form p {
        margin-top: 0
    }

    .footer-svg {
        position: absolute !important;
        z-index: 0
    }

    .hero-wrapper img {
        margin-top: 50px !important
    }

    .header-wrapper {
        padding: 5px 0 2px
    }

    .header-wrapper.animated {
        padding: 5px 0
    }

    .navigation,
    .flex-end {
        display: none
    }

    .adjusted-padding-faq {
        padding-right: 0
    }

    .navigation {
        width: 100%;
        height: 100vh
    }

    .navigation li {
        width: 100%;
        margin-bottom: 20px;
        border-bottom: 1px solid #dedede;
        padding-bottom: 10px !important
    }

    #menu-main-menu {
        width: calc(100% - 0px);
        margin-left: -14px
    }

    #menu-main-menu .menu-item-has-children {
        padding-right: 0
    }

    .logo {
        width: 90px
    }

    .one-half,
    .one-third,
    .one-fourth,
    .full-width,
    .fb-right,
    .fb-left {
        width: 100%
    }

    .section {
        max-width: 100%;
        flex-wrap: wrap
    }

    .section {
        max-width: 100%;
        flex-wrap: wrap;
        width: calc(100% - 40px);
        padding-left: 20px !important;
        padding-right: 20px !important
    }

    .three-column li,
    .two-column li {
        width: 100%;
        margin-right: 0;
        margin-bottom: 20px
    }

    .float-right {
        position: relative;
        width: 100%;
        order: 1
    }

    .float-right img {
        height: 300px
    }
}

@media only screen and (max-width:767px) and (max-width:767px) {
    .float-right {
        height: 300px
    }
}

@media only screen and (max-width:767px) {
    .hero-wrapper {
        display: flex;
        flex-wrap: wrap
    }

    .hero {
        order: 2;
        padding-top: 30px
    }

    .hero-padding,
    .ip-left-padding {
        padding-right: 0 !important;
        padding-top: 60px !important
    }

    .order-one {
        order: 1
    }

    .order-two {
        order: 2
    }

    .footer-services {
        padding: 0 !important;
        margin: 30px 0
    }

    .fb-right {
        margin-top: 20px
    }

    a.tel {
        color: #333;
        background: url(images/tel.svg) no-repeat left center;
        padding-left: 40px;
        width: 1px;
        height: 40px;
        display: block;
        font-size: 0;
        position: absolute;
        top: 5px;
        right: 60px
    }

    a.main-cta {
        font-size: 0;
        padding: 0 !important;
        width: 40px !important;
        height: 40px !important;
        border-radius: 50% 50% !important;
        position: absolute;
        top: 0;
        right: 60px;
        display: none
    }

    #nav-toggle {
        width: 40px !important;
        height: 40px !important;
        border-radius: 50% 50% !important;
        display: block;
        background: url(images/menu.svg) no-repeat center center;
        background-size: 30px auto;
        position: absolute;
        top: 5px;
        right: 5px;
        cursor: pointer
    }

    .about-padding {
        padding: 30px
    }

    .mobile-footer {
        position: fixed;
        bottom: 0;
        left: 0;
        background: #fff;
        z-index: 2;
        display: block;
        width: 100%;
        padding: 20px 15px 10px
    }

    .mobile-footer li {
        border: 0
    }

    .mobile-footer .mobile-half {
        width: 46%;
        padding: 0 2%;
        float: left;
        display: block;
        margin: 0
    }

    .mobile-footer .mobile-half a {
        text-align: center;
        padding: 10px 10px;
        display: block;
        background: #0C6460;
        color: #fff;
        border-radius: 5px
    }

    .mobile-footer .mobile-half a.contact {
        background: #FF972E !important
    }

    .navigation li:hover .sub-menu {
        display: none
    }

    .navigation li .sub-menu {
        display: none;
        position: relative !important;
        left: 0 !important;
        background: #FCFAF8 !important;
        width: 100% !important;
        padding-top: 5px !important;
        margin: -20px 0 10px !important
    }

    .navigation li .sub-menu li {
        margin: 0 !important;
        padding: 10px 0 !important
    }

    .lead-form-wrapper {
        padding: 0 !important
    }

    .desktop {
        display: none
    }

    .mobile {
        display: block
    }

    .ci-padding {
        padding: 30px !important
    }

    .blog-intro div {
        padding-right: 0
    }
}

.lead-form .gform_validation_errors {
    display: none !important
}

.lead-form input[type=text],
.lead-form input[type=email],
.lead-form input[type=tel] {
    height: 60px !important;
    border: 1px solid #dedede !important;
    border-radius: 10px !important;
    outline: none !important
}

.lead-form textarea {
    border: 1px solid #dedede !important;
    height: 50px !important;
    min-block-size: 8rem !important;
    border-radius: 10px !important;
    outline: none !important
}

.lead-form input[type=submit] {
    width: 100% !important;
    background: #649c64 !important;
    text-align: center;
    height: 60px !important;
    border-radius: 10px !important;
    border: 0 !important;
    font-size: 20px !important;
    font-weight: 600 !important
}

@media only screen and (min-width:768px) and (max-width:1099px) {
    body {
        overflow-x: hidden
    }

    .navigation,
    .flex-end {
        display: none
    }

    .adjusted-padding-faq {
        padding-right: 0
    }

    .navigation {
        width: 100%;
        height: 100vh
    }

    .navigation li {
        width: 100%;
        margin-bottom: 20px;
        border-bottom: 1px solid #dedede;
        padding-bottom: 10px !important
    }

    #menu-main-menu {
        width: calc(100% - 0px);
        margin-left: -14px
    }

    #menu-main-menu .menu-item-has-children {
        padding-right: 0
    }

    .header-ctas {
        right: 20px;
        position: absolute
    }

    .navigation li:hover .sub-menu {
        display: none
    }

    .navigation li .sub-menu {
        display: none;
        position: relative !important;
        left: 0 !important;
        background: #FCFAF8 !important;
        width: 100% !important;
        padding-top: 5px !important;
        margin: -20px 0 10px !important
    }

    .navigation li .sub-menu li {
        margin: 0 !important;
        padding: 10px 0 !important
    }

    #nav-toggle {
        width: 60px !important;
        height: 60px !important;
        border-radius: 50% 50% !important;
        display: block;
        background: url(images/menu.svg) no-repeat center center;
        background-size: 30px auto;
        position: absolute;
        top: -3px;
        right: 375px;
        cursor: pointer
    }
}

@media only screen and (min-width:768px) and (max-width:1099px) {
    body {
        overflow-x: hidden
    }

    .one-half,
    .one-third,
    .one-fourth,
    .full-width,
    .fb-right,
    .fb-left,
    .three-column li .home-services-intro {
        width: 100%
    }

    .section {
        max-width: 100%;
        flex-wrap: wrap
    }

    .section {
        max-width: 100%;
        flex-wrap: wrap;
        width: calc(100% - 40px);
        padding-left: 20px !important;
        padding-right: 20px !important
    }

    .three-column li,
    .two-column li {
        width: 100% !important;
        margin-right: 0;
        margin-bottom: 20px
    }

    .main-points {
        margin-top: 20px
    }

    .float-right {
        position: relative;
        width: 100%;
        order: 1
    }

    .float-right img {
        height: 500px
    }
}

@media only screen and (min-width:768px) and (max-width:1099px) and (max-width:767px) {
    .float-right {
        height: 300px
    }
}

@media only screen and (min-width:768px) and (max-width:1099px) {
    .hero-wrapper {
        display: flex;
        flex-wrap: wrap
    }

    .hero {
        order: 2;
        padding-top: 30px
    }

    .hero-padding,
    .ip-left-padding {
        padding-right: 0 !important;
        padding-top: 60px !important
    }

    .order-one {
        order: 1
    }

    .order-two {
        order: 2
    }

    .footer .footer-services {
        padding: 0;
        width: 100%
    }

    .sticky {
        position: relative
    }

    .lead-form-wrapper {
        padding: 0 !important
    }

    .lead-form-wrapper .float-right {
        height: 500px
    }

    .footer {
        position: relative
    }

    .footer .float-right img {
        height: 100%;
        position: absolute;
        bottom: 0
    }

    .footer .footer-svg {
        opacity: .2;
        position: absolute;
        right: 0;
        top: 0
    }
}

@media only screen and (min-width:768px) and (max-width:1199px) {
    .logo {
        width: 200px
    }

    .logo img {
        max-width: 190px
    }

    .header-ctas ul li a.main-cta {
        padding-left: 40px;
        padding-right: 40px
    }

    .navigation {
        margin-top: 18px
    }

    .header-ctas a {
        font-size: 15px
    }
}