@import url('https://fonts.googleapis.com/css2?family=Nothing+You+Could+Do&display=swap');


:root {
    --ld-primary-color: #323232;
    --ld-main-bg-color:#F2EBE3;
    --ld-text-color:#323232;
    --ld-heading-font: "Nothing You Could Do", cursive;
    --ld-base-font: 'Helvetica Neue LT Std';
}

* {
    box-sizing: border-box;
}

.text-body-lg{
    font-size: 18px;
    letter-spacing: 0.01em;
}
.text-body-lg p {
    font-size: inherit;
}
.text-body-base{
    font-size: 16px;
}
.text-body-xl{
    font-size: 24px;
    letter-spacing: 0.01em;
}
.text-body-xl p {
    font-size: inherit;
}

body.page-template-template-landing-page{
    padding: 0;
    margin: 0;
    line-height: 1.5;
    font-weight: 400;
    color: var(--ld-text-color);
    background-color: var(--ld-main-bg-color);
}


.landing-page-content .button{
    border-color: #323232 !important;
    color: #323232 !important;
    font-weight: 400;
    padding-top: 15px;
    padding-bottom: 15px;
    padding-right: 80px;
    padding-left: 30px;
    background-color: transparent !important;
}
.landing-page-content .button.btn-link {
    border: none;
    padding: 0 40px 0 0;
    background: transparent !important;
    color: #323232 !important;
    font-weight: 400;
}

.page-template-template-landing-page .button.btn-link:after {
    left: auto;
    right: 0;
}

.page-template-template-landing-page p {
    margin-bottom: 24px !important;
    line-height: 1.44;
}

.page-template-template-landing-page h1 {
    font-size: 65px;
    margin-bottom: 30px !important;
    line-height: 1.11;
}

.page-template-template-landing-page h2 {
    font-size: 54px;
    margin-bottom: 20px !important;
    line-height: 1.11;
}
 .page-template-template-landing-page .heading-size-sm h2 {
    font-size: 50px;
 }
.page-template-template-landing-page h3 {
    font-size: 54px;
}
.page-template-template-landing-page h4 {
    font-size: 24px;
}
.page-template-template-landing-page h5 {
    font-size: 18px;
}
.page-template-template-landing-page h6 {
    font-size: 14px;
}

.page-template-template-landing-page :is(h1,h2,h3,h4) {
    font-family: var(--ld-heading-font) !important;
    color: var(--ld-primary-color);
    font-weight: 400;
}

.home-hero-banner.slider.landing-page-banner .home-hero-banner-slider {
     min-height: 100vh;
}

.landing-page-banner.home-hero-banner .home-hero-banner-slide {
    min-height: 100vh;
    position: relative;
    background-size: contain;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.landing-page-banner.home-hero-banner .home-hero-banner-slide::before{
    display: none;
}
.landing-page-banner.home-hero-banner:after,
.landing-page-banner.home-hero-banner:before {
    content: "" !important;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 0;
}
.landing-page-banner.home-hero-banner::before{
    background: linear-gradient(180deg, rgba(242, 235, 227, 0) 69.01%, #F2EBE3 97.81%);
}
.landing-page-banner.home-hero-banner:after{
    content: "";
    background-image: url('../images/bg.png');
    z-index: -1;
    background-size: cover;
    background-position: center center;
}
 
.landing-hero-banner-slider .slick-arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}
.landing-page-content .container {
    padding: 0 30px;
}

.landing-hero-banner-slider .slick-arrow.slick-next,
.slider-with-content .vc_images_carousel .vc_carousel-control.vc_right{
    left: auto;
    right: 0;
    transform: translateY(-50%) rotate(180deg);
}
.landing-hero-banner-slider .slick-arrow:focus{
    outline: none;
}
.slider-with-content .vc_images_carousel .vc_carousel-control span {
    display: none;
}
.slider-with-content .vc_images_carousel .vc_carousel-control,
.landing-hero-banner-slider .slick-arrow {
    background-color: #323232;
    width: 48px;
    height: 40px;
    color: #fff;
    border: none;
    font-size: 0;
    z-index: 99;
    opacity: 1;
    z-index: 1;
}
.slider-with-content .vc_images_carousel .vc_carousel-control:after,
.landing-hero-banner-slider .slick-arrow:after,
.design-post-slider .flex-direction-nav a:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    width: 12px;
    height: 12px;
    border-style: solid;
    border-width: 2px 2px 0 0;
    transform: rotate(-135deg) translateY(0);
    margin: 0 auto;
    transform-origin: 50% 18% 0;
}


.design-post-slider .wpb_gallery_slides ul.flex-direction-nav {
    position: absolute;
    top: 460px;
    left: auto;
    right: 0;
    display: flex;
}
.design-post-slider .flexslider:hover .flex-direction-nav .flex-prev{
    left: 0;
    opacity: 1;
}
.design-post-slider .flexslider:hover .flex-direction-nav .flex-next{
    right: 0;
    opacity: 1;
}
.design-post-slider .flex-direction-nav .flex-prev{
    left: 0;
}
.design-post-slider .flex-direction-nav .flex-next{
    left: auto;
    right: 0;
}
.design-post-slider .flex-direction-nav a {
    right: 0 !important;
    margin: 0;
    position: relative;
    opacity: 1;
    background-color: #323232;
    width: 48px;
    height: 40px;
    color: #fff;
    text-align: center;
    font-size: 0;
    top: 0;
}

.design-post-slider .flex-direction-nav a:before {
    font-size: 0;
    color: #fff;
}

.design-post-slider .flex-direction-nav a.flex-next {
    transform: rotate(180deg);
}



.landing-hero-banner-slider .slick-arrow {
    left: 8%;
}
.landing-hero-banner-slider .slick-arrow.slick-next {
    left: auto;
    right: 8%;
} 


.home-hero-banner.landing-page-banner .home-hero-slide-left {
    flex-direction: row;
    justify-content: center;
    align-items: flex-end;
    width: 100%;
    max-width: 100%;
    gap: 0 20px;
    padding-top: 0;
    padding-bottom: 0;
}
.home-hero-banner.landing-page-banner  .button.button-white{
    border-color: #323232;
    color: #323232;
    background-color: transparent !important;
    height: 50px;
    padding: 10px 80px 10px 30px;
    font-weight: 400;
}
.home-hero-banner.landing-page-banner  .home-hero-slide-cta2 .button.button-white{
    border: none;
    padding: 0;
    color: #323232;
}
.home-hero-banner.landing-page-banner  .home-hero-slide-cta2{
    margin-bottom: 0;
}

.home-hero-banner.landing-page-banner .home-hero-slide-cta2 .button.button-white:after {
    display: none;
}
/* .home-hero-banner.landing-page-banner .home-hero-banner-slide::before {
    background: linear-gradient(180deg, rgba(226, 211, 196, 0) 75.78%, #E2D3C4 100%);
    height: 100%;
} */

.home-hero-banner.landing-page-banner .slide-image img {
    max-width: 737px;
    max-height: clamp(400px,70vh,738px);
    margin-bottom: 4vh;
}

.home-hero-banner.landing-page-banner .slide-image {
    position: absolute;
    top: calc(50% - 20px);
    transform: translateY(-50%);
}
.home-hero-banner.landing-page-banner .home-hero-banner-container {
    position: absolute;
    top: auto;
    bottom: 7%;
}
.landing-page-content {
    position: relative;
}

/* .landing-page-content:before {
    content: "";
    background: linear-gradient(180deg, rgba(226, 211, 196, 0) 75.78%, #E2D3C4 100%);
    position: absolute;
    top: 0px;
    left: 0;
    width: 100%;
    height: 100px;
    transform: rotate(180deg);
} */
.landing-page-content .section {
    padding: 40px 0;
}
.landing-page-content .section.landing-section-1 {
    padding-top: 60px;
    padding-bottom: 90px;
}
.landing-page-content .section.landing-section-2 {
    padding-top: 70px;
    padding-bottom: 54px;
}
.landing-page-content .section.landing-section-3 {
    padding: 40px 0 100px 0;
}


.landing-page-content .section-head {
    max-width: 938px;
    margin: 0 auto 45px auto;
    float: none;
}
.landing-page-content .section-head p{
    font-size: 18px;
    letter-spacing: 0.01em;
}
.landing-page-content .section-head .text-body-base p{
    font-size: 16px;
}
.landing-page-content .section-head p:last-of-type{
    margin-bottom: 0 !important;
}
.slider-with-content {
    padding-top: 60px;
}
.slider-with-content .col-item h3 {
    font-size: 16px;
    font-family: var(--ld-base-font) !important;
    color: var(--ld-text-color);
    line-height: 1.2;
    padding: 0 40px;
    margin-bottom: 19px;
    font-weight: 500;
}
.slider-with-content .col-item h3 strong {
    font-weight: 500;
}
.slider-with-content .col-item .image {
    display: flex;
    align-items: center;
    gap: 0 15px;
    margin-bottom: 24px;
    padding-right: 15px;
    line-height: 1.2;
    font-weight: 500;
}
.slider-with-content .col-item .image img {
    max-width: 70px;
}
.slider-with-content .col-item .image strong {font-weight: 500;}
.slider-with-content .col-item p {
    font-size: 14px;
}

.slider-bottom-content{
    background-color: #fff;
    padding: 18px 20px;
    margin: 0 !important;
    display: flex;
    align-items: center;
}
.slider-bottom-content p {
    margin-bottom: 0 !important;
}
.slider-with-content .vc_images_carousel .vc_carousel-inner .vc_carousel-slideline .vc_carousel-slideline-inner>.vc_item img {
    width: 100%;
}
.tab-with-video .video-tab-buttons{
    margin-bottom: 24px !important;
}
.tab-with-video .video-tab-buttons li{
    padding: 24px 105px 24px 45px;
    position: relative;
    border-bottom: 1px solid #323232;
    margin: 0;
    background-color: transparent;
}
.tab-with-video .video-tab-buttons li p:last-of-type {
    margin-bottom: 0 !important;
}
.tab-with-video .video-tab-buttons li:after {
    content: "\62";
    font-family: "himmel" !important;
    font-size: 24px;
    position: absolute;
    left: auto;
    right: 50px;
    top: auto;
    bottom: 16px;
}
.tab-with-video .video-tab-buttons li h5{
    font-size: 18px;
    margin-bottom: 10px;
    font-weight: 500;
    line-height: 1.1;
}
.tab-with-video .video-tab-buttons li.active{
    background-color: var(--ld-primary-color);
    border-left-color: var(--ld-primary-color);
    color: #fff;
}
.tab-with-video .video-tab-buttons li.active h5 {
    color: #fff;
}

.bg-image-with-text{
    position: relative;
    z-index: 1;
}
.bg-image-with-text:after {
    content: "";
    background: linear-gradient(0deg, rgba(242, 235, 227, 0.266667) 72.55%, #F2EBE3 100%);
    position: absolute;
    top: 0;
    bottom: auto;
    width: 100% !important;
    height: 100% !important;
    z-index: 0;
    visibility: visible !important;
}

.section.section-landing-4 .btn-flex{
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: start;
    gap: 15px 0;
    margin-bottom: 30px;
    
}
.section.section-landing-4 .btn-flex br {
    display: none;
}
.section.section-landing-4 .btn-flex .btn-link{
    padding: 0 !important;
    color: #323232 !important;
    background-color: transparent !important;
}
.section.section-landing-4 .btn-flex .btn-link:after {
    display: none;
}

.slider-with-content .vc_images_carousel .vc_carousel-control {
    top: auto;
    bottom: 0;
    left: auto;
    right: 0;
    transform: translateY(0) rotate(0);
}

.slider-with-content .vc_images_carousel .vc_carousel-control.vc_left {
    right: 45px;
}

.slider-with-content .vc_images_carousel .vc_carousel-control.vc_right {
    transform: translateY(0) rotate(180deg);
}

.tab-with-video .video-tab-buttons li p {
    font-weight: 300;
    letter-spacing: 0.02em;
}


#DownloadBIM  .modal-dialog{
    border-radius: 0;
}
#DownloadBIM .modal-header .modal-title{
    color: #fff;
    font-size: 28px;
    font-family: 'Helvetica Neue LT Std' !important;
    margin: 0;
    font-weight: 400;
}
#DownloadBIM .modal-header{
	display: block;
	text-align: center;
	background-color: #323232;
	color: #fff;
    border-radius: 0;
}

#DownloadBIM .modal-footer{
	background-color: #323232;
	color: #fff;
    border-radius: 0;
}

#DownloadBIM .modal-footer .button{
	color: #fff;
	border: 1px solid #fff;
}

body #DownloadBIM .modal-body #cmApp_signupContainer #cmApp_signupForm div .cmApp_formSubmitButton{
	color: var(--charcoal) !important;
	background-color: transparent !important;
	padding: 13px;
}

#DownloadBIM .modal-body {
    padding: 32px 44px;
}
#DownloadBIM .submit-btn{
    position: relative;
    display: inline-block;
    max-width: 237px;
}
#DownloadBIM .submit-btn:after{
    content: "\62";
    font-family: "himmel" !important;
    font-weight: normal !important;
    font-variant: normal !important;
    text-transform: none !important;
    speak: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    position: absolute;
    left: auto;
    right: 35px;
    top: 14px;
    font-size: 20px;
    color: #B8653E;

}
#DownloadBIM input[type=submit] {
    border: 1px solid #B8653E;
    color: #B8653E;
    max-width: 237px;
    width: 100%;
    padding: 10px 76px 10px 23px;
}
#DownloadBIM .button, #DownloadBIM input[type=submit] {
    height: 50px;
    border-radius: 50px;
    background: transparent;
    border: 1px solid;
}
#DownloadBIM .submit-btn > p {
    display: inline-block;
    margin: 0 !important;
}
#DownloadBIM .submit-btn span.wpcf7-spinner {
    position: absolute;
    top: 12px;
    margin: 0 10px;
}
#DownloadBIM .modal-body form > .form-content > p {
    text-align: center;
    margin-bottom: 16px !important;
}

#DownloadBIM .modal-body form input[type=email]{
    border-color: #32323233;
    border-radius: 4px;
    font-size: 13px;
    font-weight: 400;
}
#DownloadBIM .modal-body form .div_field_input p {
    margin-bottom: 16px !important;
}
#DownloadBIM .modal-body form .div_field_input p br {
    display: none;
}
#DownloadBIM .modal-body form .div_field_input label{
    color: #000;
    display: block;
    margin-bottom: 10px;
}
#DownloadBIM .modal-body form  .wpcf7-list-item{
    margin-left: 0;
}
#DownloadBIM .modal-body form span.wpcf7-list-item-label {
    font-size: 14px;
    color: #323232;
    padding-left: 25px;
    position: relative;
    display: block;
}
#DownloadBIM .modal-body form span.wpcf7-list-item-label:after {
    content: "";
    border: 1px solid #767676;
    position: absolute;
    left: 0;
    top: 4px;
    width: 16px;
    height: 16px;
    border-radius: 3px;
}
#DownloadBIM .modal-body form span.wpcf7-list-item-label:before {
    content: "";
    border-bottom: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(45deg);
    position: absolute;
    left: 5px;
    z-index: 2;
    top: 5px;
    width: 6px;
    height: 11px;
}
#DownloadBIM input[type=submit] {
    font-size: 13px;
    letter-spacing: 0.04em;
    padding-top: 12px;
}
#DownloadBIM .modal-body form .div_field_input label input[type="checkbox"]:checked + span:after {
    background: #1A73E8;
}

#DownloadBIM .modal-body form .div_field_input label input[type="checkbox"] {
    display: none;
}

div#DownloadBIM:has(.wpcf7-form.sent) .modal-header, 
div#DownloadBIM:has(.wpcf7-form.sent) .modal-footer,
div#DownloadBIM:has(.wpcf7-form.sent) .modal-header,
div#DownloadBIM:has(.wpcf7-form.sent) .form-content {
    display: none;
}

.wpcf7-form.sent .wpcf7-response-output{
       position: relative;
    padding-top: 177px;
    max-width: 360px;
    margin: 0 auto;
    border: none;
    text-align: center;
}
.wpcf7-form.sent .wpcf7-response-output:before{
    content: "";
    background: url('../images/check-Circle.svg') no-repeat center center;
    background-size: contain;
    width: 146px;
    height: 146px;
    display: block;
    margin: 0 auto;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
}
div#DownloadBIM .modal-content{
    border-radius: 0;
}

.design-post-slider  .flexslider{
    border: none;
    border-radius: 0;
}

.design-post-slider .wpb_posts_slider .wpb_gallery_slides > ul > li > .link_image{
    display: block;
    background-color: #06402b0a;
}
.design-post-slider .wpb_posts_slider .wpb_gallery_slides > ul > li .link_image > img{
    object-fit: cover;
    min-height: 500px;
    max-height: 500px;
    width: 100% !important;
    object-position: center center;
}
.design-post-slider .flex-caption h2 {
    font-size: 16px;
    font-family: 'Helvetica Neue LT Std' !important;
}

.design-post-slider .flex-caption h2 a {
    color: #323232;
    font-weight: 500;
}

.page-template-template-landing-page .design-post-slider .flex-caption h2 {
    margin: 0 0 8px 0 !important;
}

.design-post-slider .flex-caption {
    background: #fff !important;
    padding: 18px 20px !important;
    font-size: 14px;
    margin: 0;
}
.video-display-container {
    position: relative;
    padding-bottom: 56.4%;
}
.video-display-container iframe {
    width: 100%;
    height: 100%;
    border: none;
    object-fit: cover;
    position: absolute;
    top: 0;
    left: 0;
}
.design-post-slider .flex-control-nav {
    display: none;
}

.video-player-wrapper .video-cover {
    position: relative;
}

.video-player-wrapper .video-cover .video-play-button {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 70px;
    border: 0;
    background: var(--ld-primary-color);
    padding: 0;
}
.video-player-wrapper video{
    object-fit: cover;
    height: 500px;
}

.page-template-template-landing-page .container .vc_row:last-of-type ,
.page-template-template-landing-page .container .vc_row:first-of-type {
    padding: 0px;
}

.page-template-template-landing-page .mobile-cta{
    display: block;
}
.page-template-template-landing-page .desktop-cta{
    display: none;
}

@media (min-width: 768px){
    .desktop-hide{
        display: none !important;
    }
    .page-template-template-landing-page .desktop-cta{
        display: block !important;
    }
    .page-template-template-landing-page .mobile-cta{
        display: none !important;
    }
}

@media (max-width: 1200px) {
    .page-template-template-landing-page h1{
        font-size: 55px;
    }
    .page-template-template-landing-page h2{
        font-size: 44px;
    }
    .page-template-template-landing-page .heading-size-sm h2 {
        font-size: 40px;
    }
    .landing-hero-banner-slider .slick-arrow{
        left: 20px;
    }
    .landing-hero-banner-slider .slick-arrow.slick-next{
        right: 20px;
    }
}

@media (max-width:1100px){
     .home-hero-banner.landing-page-banner .slide-image img{
        margin-bottom: 20px;
        max-height: clamp(400px,60vh,738px);
    }
}

@media (max-width:991px){
    .page-template-template-landing-page h1{
        font-size: 36px;
    }
    .page-template-template-landing-page h2{
        font-size: 36px;
    }
    .page-template-template-landing-page .heading-size-sm h2 {
        font-size: 36px;
    }
    .slider-with-content > div,
    .tab-with-video-row > div,
    .section-landing-4 .vc_row  > div {
        width: 100%;
        padding-top: 0 !important;
        padding-bottom: 0 !important;
    }
    .slider-with-content {
        padding-top: 15px;
    }
    .slider-with-content  h2,
    .tab-with-video-row h2 {
        text-align: center !important;
    }
    .landing-page-content .section.landing-section-1{
        padding-bottom: 45px;
    }
    .section-landing-4 .left-image-right-content-full-left{
        text-align: center !important;
    }
}

@media (max-width:767px){
    .video-player-wrapper .video-cover .video-play-button{
      width: 70px;
      height: 60px;
    }

    .section.section-landing-4 .btn-flex{
        align-items: center;
        justify-content: center;
        
    }
    .slider-bottom-content,
    .home-hero-banner.landing-page-banner .home-hero-slide-left {
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 10px 0;
    }
    .slider-bottom-content p{
        text-align: center;
    }
    .slider-with-content .vc_images_carousel .vc_carousel-control {
        right: 47px;
        top: auto;
        bottom: 0;
        left: auto;
    }

    .slider-with-content .vc_images_carousel .vc_carousel-control.vc_right {
        bottom: 0;
        transform: translateY(0) rotate(180deg);
    }
    .landing-page-content .section.landing-section-1{
        padding-bottom: 30px;
    }
    .landing-page-content .section.landing-section-2 {
        padding-top: 30px;
        padding-bottom: 30px;
    }
    .tab-with-video .video-tab-buttons li{
        padding: 24px 45px 24px 20px;
    }
    .tab-with-video .video-tab-buttons li:after{
        right: 30px;
    }
    .tab-with-video .video-tab-buttons li h5 + p {
        display: none;
    }
    .tab-with-video .video-tab-buttons li.active h5 + p {
        display: block;
    }
    .landing-section-5 {
        font-size: 18px;
    }
    .slider-with-content > div:first-of-type {
        margin-bottom: 40px;
    }
    .slider-with-content .col-item .image {
        font-size: 16px;
        padding-right: 100px;
    }

    #DownloadBIM.modal {
        padding: 20px 20px !important;
    }

    #DownloadBIM .modal-body {
        padding: 20px 20px;
    }

    #DownloadBIM .modal-header .modal-title{
        font-size: 18px;
    }
    .wpcf7-form.sent .wpcf7-response-output:before{
        width: 106px;
        height: 106px;
    }
    .wpcf7-form.sent .wpcf7-response-output{
        padding-top: 137px;
    }
    .text-body-xl{
        font-size: 18px;
    }
    .landing-section-5 p br,
    .section-landing-4 p br {
        display: none;
    }

    .home-hero-banner.landing-page-banner .slide-image img {
        max-width: 90%;
        margin: 0 auto 2vh auto;
    }

    .landing-hero-banner-slider .slick-arrow {
        top: 70%;
        left: 13px;
        width: 36px;
        height: 30px;
    }

    .landing-hero-banner-slider .slick-arrow.slick-next {
        right: 13px;
    }
}

@media (max-width: 480px){
    .home-hero-banner.landing-page-banner .slide-image img{
        max-width: 288px;
    }

    .design-post-slider .wpb_gallery_slides ul.flex-direction-nav{
        top: 320px;
    }

    .design-post-slider .wpb_posts_slider .wpb_gallery_slides > ul > li .link_image > img{
        min-height: 360px;
        max-height: 360px;
    }
}

@media (min-width:1100px) and (max-height: 900px){
    .home-hero-banner.landing-page-banner .slide-image img{
        margin-bottom: 4vh;
        max-height: clamp(400px,50vh,738px);
    }
}
@media (min-width:1200px) and (max-height: 1100px){
    .home-hero-banner.landing-page-banner .slide-image img{
        margin-bottom: 5vh;
        max-height: clamp(400px,60vh,738px);
    }
}
@media (min-width:1800px) and (max-height: 940px){
    .home-hero-banner.landing-page-banner .slide-image img{
        margin-bottom: 7vh;
        max-height: clamp(400px,60vh,738px);
    }
}

/* @media (min-width:1200px) and (max-height: 900px){
    .home-hero-banner.landing-page-banner .slide-image img{
        margin-bottom: 2vh;
    }
} */
/* @media (min-width:1200px) and (max-height: 800px){
    .home-hero-banner.landing-page-banner .slide-image img{
        margin-bottom: 2vh;
    }
} */
/* @media (min-width:1200px) and (max-height: 740px){
    .home-hero-banner.landing-page-banner .slide-image img{
        margin-bottom: 2vh;
    }
} */