:root {
    --lightgreen: #EDFAFA;
      --green: #1BC6C0;
      --font: #343F53;
  }
#masthead{
    background:#fff; 
    position: sticky !important; 
    top:0 !important;
}

main.site-main{
    overflow:hidden;
}
div#page{
    overflow:unset;
}

@media (max-width: 769px) {
    header#masthead { 
        max-height:unset !important;
        padding: 24px 0 !important;
    }
}

.hero-products{
    padding-top: 0;
    padding-bottom: 5vw;
    min-height:880px;
    height:50vh;
    position: relative;
    z-index: 1; 
    display: flex;
} 

@media (min-width: 1600px){
    .hero-products{
        height:90vh;
        max-height: 990px;
    }
}

.hero-products:before{
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: url('../assets/hero-bg-gradient.svg');
    background-size: cover;
    background-position: bottom;
    background-repeat: no-repeat;
    z-index: -1;
}

.bg-gradient-bottom:after{
    bottom: 0px;
    left: 0;
    width: 100%;
    height: 20vw;
    max-height: 240px;
    background-image: url('../assets/gradient-top.svg');
    background-size: cover;
    background-position: bottom;
    background-repeat: no-repeat;
    z-index: -1;
}

.hero-products .inner-row{
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.hero-products-content{
    flex-basis: 600px;
    margin: auto;
    text-align: center;
    display: flex;
    padding-bottom: 80px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.hero-products-content img{
    max-width: 230px;
    margin-bottom: 60px;
}

.hero-title-badge{
    font-weight: 700; 
    color:#000;
    font-size: 22px;
    background:#F2CD4A; 
    padding: 4px 16px;
    border-radius: 10px;
    display: inline-block;
    margin-bottom: 24px;
}

.hero-products-content h1{
    font-weight: 700;
    color: #fff;
    font-size: 48px;
    line-height: 1.2em;
    margin-bottom: 24px;
} 


.hero-products-content .hero-price-value{
    font-weight: 700;
    color: #FEDD69;
    font-size: 68px;
    line-height: 1.2em;
    margin-bottom: 0;
    margin-left: 12px;
    margin-right: 12px;
} 

.hero-price-prefix, 
.hero-price-suffix{
    font-weight: 500;
    color: #fff;
    font-size: 24px;
    line-height: 1.2em;
    margin-bottom: 0;
} 

.hero-images{
    display: flex; 
    justify-content: flex-start; 
    align-items: flex-start;
    margin-top: auto;
    margin-bottom:5vw;
} 

.hero-image-wrapper{
    position: relative; 
    flex-basis:auto;
}

.hero-image-wrapper:last-of-type{
    margin-left:-24%;
}

.hero-image-wrapper img{
    position: relative;
    z-index: 1;
}

.hero-image-wrapper .hero-image-label{
    position: absolute;
    top:-24px;
    left: 55%;
    transform: translateX(-50%);
    width: 210px;
    height: 210px;  
    aspect-ratio: 1/1;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #F2CD4A; 
    border-radius: 50%;
}

.hero-image-wrapper .hero-image-label p{
    font-weight: 700; 
    color: #000;
    font-size: 48px;
    line-height: 1.2em;
    margin-bottom: 0;
    text-align: center;
} 

.hero-logos{
    max-width: 1400px;
    width: calc(100% - 48px);
    margin-left: auto;
    margin-right: auto;
}

.hero-logos h2{
    font-weight: 700; 
    color: #fff; 
    font-size: 18px; 
    display: flex;
    width:max-content;
    margin-left: auto;
    background:#1BC6C0;
    padding: 4px 16px;
    border-radius: 10px;
    margin-bottom: 24px;
}

.hero-logos-list{
    display: flex; 
    justify-content:space-between; 
    align-items: center;
    gap: 12px; 
} 

.hero-logos-list img{
    max-height: 50px;
	max-width: 120px;
    width: auto;
    object-position: center;
    object-fit: contain;
}

.products-section .inner-row{ 
    padding-top:80px;
    padding-bottom:80px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.product-content h2{
 font-size: 42px;
 font-weight: 600;
}

.product-price-main{
    font-size: 28px;
    font-weight: 700;
}

.product-price-main .xl{
    font-size: 54px;
    color:#1BC6C0;
    font-weight: 700;
}

.product-content h3{
    font-size: 20px;
    font-weight: 700; 
    margin-top: 16px;
}

.product-content h3 span{
    font-size: 16px;
    color:#808080; 
    font-weight: 400;
}

.product-cargo-buttons,
.product-rental-period-buttons{
    display: flex;
    flex-wrap: wrap; 
    gap:12px 4px;
}

.product-content button{
    font-size: 16px;
    font-weight: 700; 
    padding: 12px 24px;
    border:1px solid #1bc6c0; 
    font-family: Poppins, sans-serif;
    background:#fff; 
    cursor:pointer; 
    letter-spacing: 0;
    transition: all 0.3s ease;
}

.product-content button:hover,
.product-content button.active{
    background:#1BC6C0;
    transition: all 0.3s ease;
}

.product-button-and-terms{
    display: flex; 
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 12px;
    max-width: 440px;
    margin-right: auto;
    margin-top:32px;
}

.product-button-and-terms button{
    background:#F2CD4A; 
    border:solid 2px #F2CD4A; 
    font-size: 20px;
    width:100%;
    padding: 32px 24px; 
    border-radius: 40px;
    cursor:pointer; 
    transition: all 0.3s ease;
}

.product-button-and-terms button:hover{
    background:#fff;
    color:#000;
    border:solid 2px #F2CD4A;
    transition: all 0.3s ease;
}

.product-terms{
    color:#000;
    text-decoration: underline;
    font-size: 16px;
    font-weight: 500;
    transition: all 0.3s ease;
}

.product-terms:hover{
    color:#1BC6C0;
    transition: all 0.3s ease;
}

.product-extra-features-list{
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.product-extra-features-list input{
    opacity: 0; 
    position: absolute;
}

.product-extra-features-list label{
    padding-left: 40px; 
    display: block;
    line-height: 32px;
    position: relative;
    cursor:pointer; 
    font-size: 16px;
    font-weight: 700;
    transition: all 0.3s ease;
}

.product-extra-features-list label span{
    font-weight: 400;
    color:#808080;
    margin-left: 4px;
}

.product-extra-features-list label:before{
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 30px;
    height: 30px;
    border-radius: 8px;
    border:1px solid #1BC6C0;
}

.product-extra-features-list label:after{
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    width: 30px;
    height: 30px;
    border-radius: 8px;
    background-image: url('../assets/check-icon.svg');
    background-size: 22px;
    background-position: center;
    background-repeat: no-repeat;
    opacity: 0;
    transition: all 0.3s ease;
}

.product-extra-features-list input:checked + label:after{
    opacity: 1;
}

.product-extra-features-list input:checked + label:before{
    background:#1BC6C0;
}

.info-banner .info-banner-content .title-top,
.info-banner .info-banner-content{
    color:#fff;
    text-align:center;
}

.info-banner{ 
    overflow:hidden;
    background: #36CDC8;
    background: linear-gradient(90deg, rgba(54, 205, 200, 1) 0%, rgba(41, 154, 150, 1) 50%, rgba(242, 205, 74, 1) 100%);
}


.info-banner .info-banner-content{
    padding-top: 80px;
    padding-bottom: 80px; 
    max-width:725px;
    margin-left: auto;
    margin-right: auto;
}

.info-banner .info-banner-content h2{
    font-size: 64px;
    font-weight: 600;
    line-height: 1.2em;
    margin-top: 12px;
}

.info-banner-features{ 
    margin-top: 40px; 
    margin-bottom: 50px;
    display: flex; 
    justify-content: space-between;
    align-items: center;
    gap: 20px;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
}

.info-banner-feature-item{
    flex-basis:calc(33.33% - 20px);
    text-align: center;
}

.info-banner-features h3{
    font-size: 16px;
    text-transform: uppercase; 
    font-weight: 600;
}

.info-banner-content p{
    max-width: 504px; 
    margin-left: auto;
    margin-right: auto;
}


.info-banner-forground-image{
    position: relative;
    width:100%; 
    text-align: center;
}
 

.info-banner-forground-image img{
    margin-left: auto;
    margin-right: auto; 
  
}

.forground-image-wrapper{
    width:100%;
    transform: rotate(-15deg) translatey(-13%); 
    text-align: center;
}

.forground-image-wrapper:after{
    content: '';
    position: absolute;
    bottom: -116%;
    left: -51px;
    width: 150%;
    height: 150%;
    background-color: #fff;
    z-index: -1;
}


.comparison-section{
    position: relative;
    z-index: 1; 
    margin-top: 0px;
    margin-bottom: 80px;
}

.comparison-section .inner-row{
    position: relative;
    z-index: 1;
}

.comparison-table{
    display: flex; 
    justify-content: space-between; 
    align-items: flex-start;  
    max-width: 874px;
    margin-left: auto;
    margin-right: auto; 
}

.left-column{
    flex-basis: 250px; 
    margin-top:54px;
}

.left-column ul li{ 
    position: relative; 
    padding-left: 40px;  
    margin-bottom: 24px;
}

.left-column ul li:last-child{
    margin-bottom: 0;
}

.left-column ul li:before{
    content: '';
    position: absolute;
    left: 0;
    top: 1px;
    width: 14px;
    height: 14px;
    border-radius: 50%;
}

.left-column ul li:nth-child(1):before{
    background:#F2CD4A;
}

.left-column ul li:nth-child(2):before{
    background:#2ED9D4;
}

.left-column ul li:nth-child(3):before{
    background:#12ADA9;
}

.left-column ul li p.legend-title{
    font-size: 18px;
    line-height: 1em;
    margin-bottom: 4px;
    font-weight: 700; 
    color:#000;
} 

.left-column ul li p.legend-description{
    font-size: 16px;
    font-weight: 400;
    color:#808080;
} 


.right-column{
    flex-basis:calc(100% - 270px); 
    position: relative;
}

.right-column:before{
    content: '';
    position: absolute;
    top: -40%;
    right: 0;
    width: 300px;
    height: 300px;
    background-size: contain;
    background-position: right top;
    background-repeat: no-repeat;
}

.right-column{
    display: flex; 
    justify-content: space-between; 
    align-items: flex-end; 
} 

.compare-item{
    display: flex; 
    flex-direction: column;  
    flex-basis:calc(33.33% - 8px);
}

.compare-item .top-image{
    max-width: 80px;
    margin-left: auto;
    margin-right: auto;
}

.compare-item  .bottom-imge-wrap{
    aspect-ratio: 14/12; 
    display: flex; 
    justify-content: center; 
    align-items: flex-end;
} 

.compare-item .compare-item-label{
    font-size: 18px;
    font-weight: 700;
    color:#000;
    text-align: center;
    margin-top: 12px;
}

@media (max-width: 1300px){
    .hero-title-badge{
        font-size: 18px;
    }
    .hero-products-content h1{
        font-size: 38px;
    }
    .hero-products-content .hero-price-value{
        font-size: 58px;
    }
    .hero-products-content .hero-price-suffix{
        font-size: 20px;
    }
    .hero-products-content .hero-price-prefix{
        font-size: 20px;
    } 

    .hero-image-wrapper .hero-image-label{
        width: 160px;
        height: 160px;
        top:-20px;
    } 

    .hero-image-wrapper .hero-image-label p{
        font-size: 38px;
    } 

    .hero-images{
        margin-bottom:7vw;
    }
}


@media (max-width: 1200px){
    .hero-images{
        margin-bottom:8vw;
    }
}

@media (max-width: 1080px){
    .hero-title-badge{
        font-size: 18px;
    }
    .hero-products-content h1{
        font-size: 32px;
    }
    .hero-products-content .hero-price-value{
        font-size: 48px;
    }
    .hero-products-content .hero-price-suffix{
        font-size: 18px;
    }
    .hero-products-content .hero-price-prefix{
        font-size: 18px;
    } 

    .hero-image-wrapper .hero-image-label{
        width: 140px;
        height: 140px;
        top:-20px;
    } 

    .hero-image-wrapper .hero-image-label p{
        font-size: 32px;
    } 

    .hero-images{
        margin-bottom:10vw;
    }
    .right-column:before{
        width: 220px;
        height: 220px;
        top: -20%;
    }

}



@media (max-width:880px){
    .hero-products .inner-row{ 
        flex-direction: column;
    }
    .hero-products-content{
        flex-basis:unset;
        padding-top:60px;
        padding-bottom:40px;
    }
    .hero-products-content img{
        max-width: 180px;
        margin-bottom: 32px;
    }
    .hero-images{
        width:80%;
    }
    .hero-title-badge {
        font-size: 22px;
    }
    .hero-products{
        height:auto;
        min-height:unset;
    } 
    .hero-products:before{
        background-position: left 25% bottom;
    }
    .hero-products-content h1{
        font-size: 44px; 
        margin-bottom: 8px;
    }
    .hero-products-content .hero-price-value{
        font-size: 64px;
    }
    .hero-products-content .hero-price-suffix{
        font-size: 24px;
    }
    .hero-products-content .hero-price-prefix{
        font-size: 24px;
    }
    .products-section .inner-row{
        flex-direction: column; 
        padding-top: 40px;
        padding-bottom: 40px;
    }
    .product-images,
    .product-content{
        width:100%;
    } 
    .info-banner .info-banner-content h2{
        font-size: 52px;
    }
}

@media (min-width: 671px){
    .compare-item .compare-item-label{
        display:none;
    }
}

@media (max-width: 670px){
    .comparison-table{
      flex-wrap: wrap;
    }
    .right-column{
        flex-direction:row-reverse;
        flex-basis:100%;
    }
    .right-column:before{
        display:none;
    }
    .left-column{
        margin-bottom:-15vw;
    } 
    .comparison-section .inner-row:before{
        content:'';
        width:calc(100vw - 48px);
        height:calc(100vw - 48px); 
        background-size: contain;
        background-position: center;
        background-repeat: no-repeat; 
        display:block; 
        margin-left:auto;
        margin-right:auto;
    }
    .compare-item .compare-item-label{
        margin-bottom:-24px;
    }
}


@media (max-width:620px){
    .hero-products-content img{
        max-width: 158px;
        margin-bottom: 32px;
    }
    .hero-images {
        width: 100%;
        margin-right: -5vw; 
        margin-bottom: 15vw;
    }
    .hero-image-wrapper:last-of-type{
        margin-left: -22%;
        margin-top: -4%;
    }
    .hero-image-wrapper:last-of-type img{
        max-width:110%;
    }
    .hero-products:before{
        background-position: left 25% bottom;
    }
    .hero-products-content h1{
        font-size: 42px; 
    }
    .hero-products-content .hero-price-value{
        font-size: 64px;
    }
    .hero-products-content .hero-price-suffix{
        font-size: 24px;
    }
    .hero-products-content .hero-price-prefix{
        font-size: 24px;
    }
    .hero-image-wrapper .hero-image-label p{
        font-size: 20px;
        margin-top: 24px;
    }
    .hero-image-wrapper .hero-image-label {
        width: 120px;
        height: 120px;
        top: 0; 
        align-items: flex-start;
    } 

    .hero-image-wrapper:last-of-type .hero-image-label{
        top: 5%;
    }


    .hero-logos-list{
        flex-wrap: wrap;
    } 
    .hero-logos-list img{
        flex-basis:calc(50% - 12px);
    }
    .info-banner .info-banner-content h2,
    .product-content h2{
        font-size: 32px;
    } 

    .info-banner-features{
        flex-wrap: wrap; 
        flex-direction: column;
        justify-content: center;
    } 
    .info-banner-feature-item{
        flex-basis:unset;
        display: flex;  
        width: 244px;
        margin-left:auto;
        margin-right:auto;
        align-items: center;  
        gap: 12px;
    } 
    .info-banner-feature-item img{
        width: 60px;
        height: 60px;
    }
}



.rental-form-overlay{
	position:fixed;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    background-color: #ffffff7a;
	width:100%;
	height:100%;
	z-index:111;
	top:0;
	left:0;
	opacity:0;
	visibility:hidden;
	transition:.4s; 
    backdrop-filter: blur(10px);
}

.terms-content,
.rental-form{ 
	position:fixed;
    opacity:0;
	visibility:hidden;
	top:50%;
	left:50%;
	background:#fff;
	z-index:11111;
	max-width:800px;
	width:calc(100% - 48px);
	transform:translate(-50%, -50%);
	padding:30px 32px 12px 32px;
	border-radius:24px;
	text-align:center;
	transition:.4s;
}
.terms-content{
    text-align:left; 
    max-height:calc(100vh - 180px);
    overflow:auto;
} 

.terms-content-inner h3{
    font-size:24px;
    font-weight:600;
    margin-bottom:12px; 
    line-height:1.2em;
}
.terms-content-inner p{
    font-size:16px;
    font-weight:400;
    margin-bottom:12px;
}

.terms-content-inner a{
    color:#000; 
    text-decoration: underline;
    font-size:16px;
    font-weight:500;
    transition: all 0.3s ease;
}

.terms-content-inner ul{
    list-style: disc;
    margin-left:24px;
    margin-bottom:24px;
}

.terms-visible .rental-form-overlay,
.popup-visible .rental-form-overlay{
    opacity:1;
	visibility:visible;
}

.terms-visible .terms-content{
	opacity:1;
	visibility:visible;
}

button.close-popup{
	position:absolute;
	cursor:pointer;
	right:24px;
	top:24px;
	background-image:url(/wp-content/themes/vokbikes/assets/close.svg);
	background-size:16px;
	background-repeat:no-repeat;
	background-position:center;
	background-color:transparent;
	border-radius:50%;
	border:solid 1px #bbb;
	padding:0;
	width:32px;
	height:32px;	
}

.terms-content-inner::-webkit-scrollbar-track,
.rental-form-inner::-webkit-scrollbar-track
{
	-webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0.3);
	background-color: #F5F5F5;
}

.terms-content-inner::-webkit-scrollbar,
.rental-form-inner::-webkit-scrollbar
{
	width: 6px;
	background-color: #F5F5F5;
}

.terms-content-inner::-webkit-scrollbar-thumb,
.rental-form-inner::-webkit-scrollbar-thumb
{
	background-color: #1BC6C0;
}

.popup-visible .rental-form{
	opacity:1;
	visibility:visible;
}

.form-header h2{
	font-size:38px;
	max-width:350px;
	font-weight:600;
	line-height:1.2em;
	margin-left:auto;
	margin-right:auto;
}

.form-header{
	margin-bottom:32px;
}

.form-header p{
	margin-top:.5em;
  font-size:16px;
	max-width:350px;
	margin-left:auto;
	margin-right:auto;
}

.rental-form-inner{
	margin:40px auto;
	padding-right:24px;
	padding-left:24px;
	overflow:auto;
	max-height:calc(100vh - 180px);
}

.form-header h2 b{
	color:#1BC6C0;
	font-weight:600;
}

.rental-form-inner form .success-message{
	width:100%;
	padding-top:80px;
	padding-bottom:80px;
	max-width:400px;
	margin-left:auto;
	margin-right:auto;
}

[data-status="invalid"]  .success-message,
[data-status="init"] .success-message{
	display:none;
}

[data-status="sent"] .form-no-sent{
	display:none;
}

.form-submit .form-header{
	display:none;
}

.rental-form-inner .wpcf7-response-output{
	display:none;
}

.form-close-popup{
	margin-top:24px;
	background: #F2CD4A;
  font-size: 16px;
  font-weight: 700;
  text-transform: uppercase;
	cursor:pointer;
}


.form-close-popup:hover{
	background: #F2CD4A;
}

.rental-form-inner form .success-message h2{
	margin-top:0;
	line-height:1.1em;
	margin-bottom:24px;
	font-size:38px;
	font-weight:600;
	text-align:center;
}

.rental-form-inner form .success-message p{
	text-align:center;
}


.success-message img{
	max-width:400px;
	width:100%;
}

.rental-form-inner form p{
	text-align:left;
	font-size:14px;
	margin-bottom:12px;
}

.rental-form-inner form{
	max-width:464px;
	margin-left:auto;
	margin-right:auto;
}

.rental-form-inner form input,
.rental-form-inner form select{
	border-radius:24px;
	outline:none;
	padding-left:16px;
	width:100%;
	margin-top:4px;
	background:#fff;
	color:#000;
	font-size:16px;
	border:solid 1px #CDD2D6;
	line-height:40px;
	height:40px;
}

.rental-form-inner form input[name="rental-period"]{
	pointer-events:none;
}

.rental-form-inner form input.wpcf7-submit{
	margin-top:20px;
	margin-left:auto;
	margin-right:auto;
	display:block;
	width:auto;
	padding:0 32px;
	background:#F2CD4A;
	font-weight:600;
	font-family: Poppins, sans-serif;
	text-transform:uppercase; 
	color:#1E2125;
	border-color:#F2CD4A;
}



@media (max-width:560px){
	.rental-form{
		width:100%;
		height:100%;
		border-radius:0;
		padding-left:0;
		padding-right:0;
	}
	
	.form-header h2{
		font-size:32px;
	} 

    .terms-content-inner{
        padding-top:24px;
    }
	
	.rental-form-inner{
		max-height:calc(100% - 32px);
		padding-left:24px;
		padding-right:24px;
	}

    .product-content button{
        padding: 8px 12px;
    }
    .product-extra-features-list{
        gap: 16px;
    }

    .product-button-and-terms button{
        padding: 32px 24px;
    } 
    .hero-products-content{
        padding-top:40px;
        padding-bottom:20px;
    }
    .hero-products-content h1 {
        font-size: 38px;
    }
    .hero-image-wrapper .hero-image-label{
        width: 100px;
        height: 100px; 
    }
    .hero-image-wrapper .hero-image-label p{
        font-size: 18px;
        margin-top: 20px;
    }
    .info-banner .info-banner-content h2, .product-content h2{
        font-size: 30px;
    }
}

@media (max-width:440px){
    main .inner-row{
        width:calc(100% - 32px);
    }
}


/* Page builder */ 
.section-title{
	padding-top:80px;
	padding-bottom:40px;
}

.section-title.mt-0{
	padding-top:0px;
}

.section-title.mb-0{
	padding-bottom:0px;
}

.step-number{
    background:#1BC6C0;
}

.section-title .section--title{
	font-size:50px;
	font-weight:500;
	line-height:1.1em;
	overflow:hidden;
}

.section--title span{
	display:block;
}

.section-title .section--title b{
	color:#1BC6C0;
	font-weight:500;
}

.section-title .centered{
	max-width:680px;
	text-align:center;
	margin-left:auto;
	margin-right:auto;
}

.section-title .section-content{
	font-size:18px;
	margin-top:16px;
	max-width:600px;
	margin-left:auto;
	margin-right:auto;
}

.section-title .section-content b{
	color:#1BC6C0;
	font-weight:500;
}

.scroll-to-top-wrapper{
    margin-top: 80px;
    margin-bottom: 80px;
    text-align: center;
}

.scroll-to-top{
    background: #F2CD4A;
    border: solid 2px #F2CD4A;
    font-size: 20px;
    display:inline-flex;
    align-items: center;
    justify-content: center;
    padding: 16px 40px;
    border-radius: 40px;
    cursor: pointer;
    transition: all 0.3s ease;
}

.scroll-to-top:hover{
    background: #fff;
    color: #000;
    border: solid 2px #F2CD4A;
    transition: all 0.3s ease;
}

@media (max-width: 600px){
    .scroll-to-top-wrapper{
        position: fixed; 
        bottom: 0;
        width:100%;
        left: 0;
        right: 0;
        z-index: 9999; 
        margin:0; 
        opacity: 0;
        visibility: hidden;
        transition: all 0.3s ease;
    }
    .scroll-button-visible .scroll-to-top-wrapper{
        opacity: 1;
        visibility: visible; 
        bottom: 24px;
        transition: all 0.3s ease;
    }
}