/* ---- Fonts ---- */

@font-face {
	font-family: 'Montserrat';
	src: url('../font/Montserrat/Montserrat-Regular.ttf') format('truetype');
    font-style: normal;
    font-display: swap;
}

@font-face {
	font-family: 'Montserrat-Medium';
	src: url('../font/Montserrat/Montserrat-Medium.ttf') format('truetype');
    font-style: normal;
    font-display: swap;
}

@font-face {
	font-family: 'Montserrat-SemiBold';
	src: url('../font/Montserrat/Montserrat-SemiBold.ttf') format('truetype');
    font-style: normal;
    font-display: swap;
}

@font-face {
	font-family: 'Montserrat-Bold';
	src: url('../font/Montserrat/Montserrat-Bold.ttf') format('truetype');
    font-style: normal;
    font-display: swap;
}


/* ---- Base ---- */

*, *::before, *::after {
  box-sizing: border-box;
}

* {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  text-shadow: none;
}

html {
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -ms-touch-action: manipulation;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  font-size: 16px;
  line-height: 1.15;
}

body {
  margin: 0;
  font-size: 16px;
  line-height: 26px;
  color: #000;
  font-family: 'Montserrat';
  background: #f5f5f5;
}

body.popup-active{
  overflow: hidden;
}

body.popup-active main,
body.popup-active header{
  filter: blur(3px);
}

img {
  width: 100%;
  height: auto;
}

a {
  text-decoration: none;
  transition: 0.25s;
  color: #000;
}

a:hover {
  color: #40b93c;
}

ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

ul.disc-bullet{
  padding-left: 25px;
  list-style: disc;
}

/* main {
  padding-top: 65px;
}

@media (min-width: 1024px) {
  main {
    padding-top: 98px;
  }
} */

footer{
  background: #000000;
  padding: 25px 0;
  margin-top: 50px;
}

.footer{
  color: #fff;
  text-align: center;
  font-size: 14px;
  line-height: 18px;
}

.footer ul li{
  margin: 0 10px;
}

.footer ul li a{
  color: #fff;
  text-decoration: underline;
}

.footer ul.footer__social li{
  display: inline-flex;
}

.footer ul.footer__social li a{
  width: 30px;
}

.footer ul.footer__links{
  margin: 25px 0;
}

.footer ul.footer__links li{
  margin: 10px 0;
}

@media (min-width: 1024px) {
  footer{
    text-align: left;
  }

  .footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  .footer ul li{
    display: inline-flex;
  }

  .footer ul.footer__links{
    margin: 0;
  }
  
  .footer ul.footer__links li{
    margin: 0 15px;
  }
}

strong {
  font-family: "Montserrat-Bold";
}

.relative{
  position: relative;
}


/* ---- Fonts ---- */

h1 {
  font-family: "Montserrat";
  font-size: 26px;
  line-height: 32px;
  font-weight: normal;
}

.m-font{
  font-size: 20px;
  line-height: 24px;
  font-weight: normal;
}

.lg-font{
  font-size: 24px;
  line-height: 30px;
  font-weight: normal;
}

.xl-font{
  font-size: 26px;
  line-height: 32px;
  font-weight: normal;
}

@media (min-width: 768px) {
  h1 {
    font-size: 32px;
    line-height: 38px;
  }

  .m-font{
    font-size: 22px;
    line-height: 26px;
    font-weight: normal;
  }

  .lg-font{
    font-size: 26px;
    line-height: 32px;
    font-weight: normal;
  }

  .xl-font{
    font-size: 32px;
    line-height: 38px;
  }
}

@media (min-width: 1024px) {
  h1 {
    font-size: 40px;
    line-height: 46px;
  }

  .m-font{
    font-size: 24px;
    line-height: 28px;
    font-weight: normal;
  }

  .lg-font{
    font-size: 32px;
    line-height: 38px;
    font-weight: normal;
  }

  .xl-font{
    font-size: 40px;
    line-height: 46px;
  }
}

.bold{
  font-family: 'Montserrat-Bold';
}

.semi-bold{
  font-family: 'Montserrat-SemiBold';
}

.text-uppercase{
  text-transform: uppercase;
}

.text-center{
  text-align: center;
}

.font-14{
  font-size: 14px;
  line-height: 20px;
}

.opacity-50{
  opacity: .5;
}

/* ---- Colors ---- */

.green{
  color: #40b93c;
}

.violet{
  color: #AE51FD;
}

/* ---- Buttons ---- */

.vlc-btn{
  max-width: 260px;
  border-radius: 25px;
  outline: none;
  font-size: 12px;
  text-align: center;
  text-transform: uppercase;
  transition: all 0.25s;
  font-family: "Montserrat-Bold";
  cursor: pointer;
  line-height: 1;
  display: block;
  padding: 12px 16px;
  border: 2px solid #40B93C;
  background: #40B93C;
  color: #ffffff;
}

.vlc-btn:hover{
  color: #40B93C;
  background: transparent;
}

.vlc-btn--white{
  border: 2px solid #40B93C;
  background: transparent;
  color: #40B93C;
}

.vlc-btn--white:hover{
  color: #fff;
  background: #40B93C;
}

/* ---- Icons size ---- */

.icon-40{
  width: 40px;
}

.icon-35{
  width: 35px;
}

.icon-25{
  width: 25px;
}

.info-icon{
  position: relative;
  display: block;
  font-family: "Montserrat-SemiBold";
  color: #AE51FD;
  padding-left: 25px;
  line-height: 22px;
}

.info-icon::before{
  content: 'i';
  position: absolute;
  left: 0;
  top: 2px;
  border-radius: 50px;
  width: 18px;
  height: 18px;
  padding: 4px;
  border: 2px solid #AE51FD;
  font-size: 12px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* ---- Flex ---- */

.flex{
  display: flex;
}

@media (min-width: 375px) {
  .s-flex{
    display: flex;
  }  
}

@media(min-width: 768px){
  .m-flex{
    display: flex;
  }  
}

@media(min-width: 1024px){
  .lg-flex{
    display: flex;
  }  
}

@media(min-width: 1440px){
  .xl-flex{
    display: flex;
  }  
}

.space-between{
  justify-content: space-between;
}

.align-items-center{
  align-items: center;
}

.flex-v-center{
  display: flex;
  align-items: center;
}

.flex-h-center{
  display: flex;
  justify-content: center;
}

.flex-h-v-center{
  display: flex;
  justify-content: center;
  align-items: center;
}

.flex-space-between{
  display: flex;
  justify-content: space-between;
}

/* ---- Form ---- */

fieldset{
  border: 0;
}

.field{
  position: relative;
  margin-bottom: 20px;
}

.date-field::after{
  content: url('../img/icons/calendar.svg');
  position: absolute;
  right: 15px;
  bottom: 0px;
}

.form-navigation {
  display: flex;
  justify-content: space-between;
  margin-bottom: 20px;
  padding-top: 40px;
  position: relative;
}

.step-indicator {
  padding: 10px;
  width: 40px;
  height: 40px;
  flex: 0 0 40px;
  border: 4px solid #40B93C;
  color: #40B93C;
  border-radius: 50%;
  cursor: pointer;
  font-family: "Montserrat-SemiBold";
  font-size: 22px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: linear-gradient(180deg, #FFFFFF 15.93%, #E9E9E9 54%, #FFFFFF 92.25%);
  position: relative;
  z-index: 1;
}

.step-indicator.current,
.step-indicator.valid {
  background: #40B93C;
  color: #fff;
}

.step-line{
  position: relative;
  background: #40B93C;
  width: 50%;
  height: 2px;
  top: 20px;
}

.step-line.active{
  height: 4px;
  top: 19px;
}

@media(min-width: 768px){
  .step-indicator {
    width: 50px;
    height: 50px;
    flex: 0 0 50px;
    font-size: 38px;
  }

  .step-line{
    top: 24px;
  }

  .step-line.active{
    height: 4px;
    top: 23px;
  }
}

label{
  font-family: 'Montserrat-Bold';
  font-size: 16px;
  line-height: 20px;
}

input{
  font-family: 'Montserrat';
  border-radius: 15px;
  background: #F5F5F5;
  border: 1px solid #AAAAAA;
  font-size: 14px;
  padding: 12px 16px;
  width: 100%;
  outline: none;
}

input:active,
input:focus{
  border: 1px solid #40B93C;
}

input.error{
  border: 1px solid red;
}

.error-message{
  position: absolute;
  bottom: -15px;
  left: 10px;
  font-size: 12px;
  color: red;
  line-height: 1;
  font-family: 'Montserrat-SemiBold';
}

input[type=checkbox] {
  position: relative;
  -webkit-appearance: none;
  appearance: none;
  background-color: transparent;
  margin: 0;
  font: inherit;
  color: #E6E6E6;
  border-radius: 4px;
  width: 16px;
  height: 16px;
  flex: 0 0 16px;
  border: 1px solid #000000;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  visibility: visible;
  left: 0;
  padding: 0;
}

input[type=checkbox]::before {
  content: "";
  position: absolute;
  display: block;
  width: 20px;
  height: 20px;
  transform: scale(0);
  transition: 120ms transform ease-in-out;
  visibility: visible;
  border-radius: 2px;
}

input[type=checkbox]:checked {
  border: 1px solid #40B93C;
  transition: 120ms transform ease-in-out;
  background: #40B93C;
}

input[type=checkbox]:checked::before {
  transform: scale(1);
  background-image: url("../img/icons/check-white.svg");
  background-size: 16px;
  background-position: center;
  background-repeat: no-repeat;
}

input[type=checkbox] + label {
  font-size: 16px;
  font-family: "Montserrat";
  padding-left: 10px;
  margin-bottom: 0;
}

input[type=checkbox] + label::before, input[type=checkbox] + label::after {
  display: none;
}

input[type=checkbox].rounded {
  border-radius: 50%;
}

input[type=radio] {
  -webkit-appearance: none;
  appearance: none;
  background-color: transparent;
  margin: 0;
  font: inherit;
  color: #E6E6E6;
  width: 24px;
  height: 24px;
  flex: 0 0 24px;
  border: 2px solid #E6E6E6;
  border-radius: 50%;
  display: grid;
  place-content: center;
  visibility: visible;
  left: unset;
  position: relative;
  padding: 0;
}

input[type=radio]::before {
  content: "";
  width: 16px;
  height: 16px;
  border-radius: 50%;
  transform: scale(0);
  transition: 120ms transform ease-in-out;
  background-color: #40B93C;
}

input[type=radio]:checked {
  border: 2px solid #40B93C;
  transition: 120ms transform ease-in-out;
}

input[type=radio]:checked::before {
  transform: scale(1);
}

input[type=radio] + label {
  font-size: 16px;
  font-family: "Montserrat";
  padding-left: 5px;
  margin-bottom: 0;
}

input[type=radio] + label::before, input[type=radio] + label::after {
  display: none;
}

.vlc-r-c {
  margin-bottom: 10px;
}

.vlc-r-c__wrapper {
  display: flex;
  align-items: center;
  margin-bottom: 10px;
}

.vlc-r-c__wrapper:last-of-type{
  margin-bottom: 0;
}

.vlc-r-c--horizontal {
  display: flex;
  flex-wrap: wrap;
}

.vlc-r-c--horizontal .vlc-r-c__wrapper {
  margin-right: 20px;
}

.search-input{
  position: relative;
  display: flex;
  align-items: center;
}

.search-input img{
  position: absolute;
  width: 18px;
  left: 15px;
}

.search-input input{
  padding-left: 45px;
}

/* ---- Multistep form ---- */

form.multistep fieldset{
  padding: 0;
}

.step {
  display: none;
}

.step.active {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.form-control-buttons{
  display: flex;
  justify-content: space-between;
  margin-top: 30px;
  padding-bottom: 50px;
}

.form-control-buttons button{
  width: 100%;
}

.form-control-buttons button:first-of-type{
  margin-left: 0;
  margin-right: 10px;
}

.form-control-buttons button:last-of-type{
  margin-left: 10px;
  margin-right: 0;
}

@media(min-width: 768px){
  .form-control-buttons{
    justify-content: flex-end;
  }

  .form-control-buttons button:first-of-type{
    margin-right: 20px;
  }
  
  .form-control-buttons button:last-of-type{
    margin: 0;
  }
}

/* ---- Margins ---- */

.vlc-reset-margin {
  margin: 0 auto;
}

.m-auto {
  margin-left: auto;
  margin-right: auto;
}

.m-0 {
  margin: 0;
}

.m-v-10{
  margin-top: 10px;
  margin-bottom: 10px;
}

.m-v-20{
  margin-top: 20px;
  margin-bottom: 20px;
}

.m-top-0 {
  margin-top: 0;
}

.m-top-10 {
  margin-top: 10px;
}

.m-top-20{
  margin-top: 20px;
}

.m-top-30 {
  margin-top: 30px;
}

.m-top-40 {
  margin-top: 40px;
}

.m-top-50 {
  margin-top: 50px;
}

.m-bottom-0 {
  margin-bottom: 0;
}

.m-bottom-10 {
  margin-bottom: 10px;
}

.m-bottom-20 {
  margin-bottom: 20px;
}

.m-bottom-30 {
  margin-bottom: 30px;
}

.m-bottom-40 {
  margin-bottom: 40px;
}

.m-bottom-50 {
  margin-bottom: 50px;
}

/* ---- Grid ---- */

.vlc-container {
  max-width: 1367px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: 10px;
  padding-right: 10px;
}

.vlc-row {
  display: flex;
  flex-wrap: wrap;
  margin-left: -10px;
  margin-right: -10px;
}

.vlc-col {
  flex: 0 0 100%;
  max-width: 100%;
  padding-left: 10px;
  padding-right: 10px;
}

.vlc-col.auto {
  flex: auto;
  max-width: 100%;
}

.vlc-col.xs-1 {
  flex: 0 0 8.33333%;
  max-width: 100%;
}

.vlc-col.xs-2 {
  flex: 0 0 16.66667%;
  max-width: 16.66667%;
}

.vlc-col.xs-3 {
  flex: 0 0 25%;
  max-width: 25%;
}

.vlc-col.xs-4 {
  flex: 0 0 33.33333333%;
  max-width: 33.33333333%;
}

.vlc-col.xs-5 {
  flex: 0 0 41.66667%;
  max-width: 41.66667%;
}

.vlc-col.xs-6 {
  flex: 0 0 50%;
  max-width: 50%;
}

.vlc-col.xs-7 {
  flex: 0 0 58.33333%;
  max-width: 58.33333%;
}

.vlc-col.xs-8 {
  flex: 0 0 66.66667%;
  max-width: 66.66667%;
}

.vlc-col.xs-9 {
  flex: 0 0 75%;
  max-width: 75%;
}

.vlc-col.xs-10 {
  flex: 0 0 83.33333%;
  max-width: 83.33333%;
}

.vlc-col.xs-11 {
  flex: 0 0 91.66667%;
  max-width: 91.66667%;
}

.vlc-col.xs-12 {
  flex: 0 0 100%;
  max-width: 100%;
}

@media (min-width: 375px) {

  .vlc-col.s-1 {
    flex: 0 0 8.33333%;
    max-width: 100%;
  }

  .vlc-col.s-2 {
    flex: 0 0 16.66667%;
    max-width: 16.66667%;
  }

  .vlc-col.s-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }

  .vlc-col.s-4 {
    flex: 0 0 33.33333333%;
    max-width: 33.33333333%;
  }

  .vlc-col.s-5 {
    flex: 0 0 41.66667%;
    max-width: 41.66667%;
  }

  .vlc-col.s-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }

  .vlc-col.s-7 {
    flex: 0 0 58.33333%;
    max-width: 58.33333%;
  }

  .vlc-col.s-8 {
    flex: 0 0 66.66667%;
    max-width: 66.66667%;
  }

  .vlc-col.s-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }

  .vlc-col.s-10 {
    flex: 0 0 83.33333%;
    max-width: 83.33333%;
  }

  .vlc-col.s-11 {
    flex: 0 0 91.66667%;
    max-width: 91.66667%;
  }

  .vlc-col.s-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }

}
@media (min-width: 768px) {

  .vlc-col.md-1 {
    flex: 0 0 8.33333%;
    max-width: 100%;
  }
  
  .vlc-col.md-2 {
    flex: 0 0 16.66667%;
    max-width: 16.66667%;
  }

  .vlc-col.md-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }

  .vlc-col.md-4 {
    flex: 0 0 33.33333333%;
    max-width: 33.33333333%;
  }

  .vlc-col.md-5 {
    flex: 0 0 41.66667%;
    max-width: 41.66667%;
  }

  .vlc-col.md-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }

  .vlc-col.md-7 {
    flex: 0 0 58.33333%;
    max-width: 58.33333%;
  }

  .vlc-col.md-8 {
    flex: 0 0 66.66667%;
    max-width: 66.66667%;
  }

  .vlc-col.md-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }

  .vlc-col.md-10 {
    flex: 0 0 83.33333%;
    max-width: 83.33333%;
  }

  .vlc-col.md-11 {
    flex: 0 0 91.66667%;
    max-width: 91.66667%;
  }

  .vlc-col.md-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }

}

@media (min-width: 1024px) {

  .vlc-col.lg-1 {
    flex: 0 0 8.33333%;
    max-width: 8.33333%;
  }

  .vlc-col.lg-2 {
    flex: 0 0 16.66667%;
    max-width: 16.66667%;
  }

  .vlc-col.lg-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }

  .vlc-col.lg-4 {
    flex: 0 0 33.33333333%;
    max-width: 33.33333333%;
  }

  .vlc-col.lg-5 {
    flex: 0 0 41.66667%;
    max-width: 41.66667%;
  }

  .vlc-col.lg-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }

  .vlc-col.lg-7 {
    flex: 0 0 58.33333%;
    max-width: 58.33333%;
  }

  .vlc-col.lg-8 {
    flex: 0 0 66.66667%;
    max-width: 66.66667%;
  }

  .vlc-col.lg-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }

  .vlc-col.lg-10 {
    flex: 0 0 83.33333%;
    max-width: 83.33333%;
  }

  .vlc-col.lg-11 {
    flex: 0 0 91.66667%;
    max-width: 91.66667%;
  }

  .vlc-col.lg-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }


  .vlc-col.lg-offset-1 {
    margin-left: 8.33333%;
  }

  .vlc-col.lg-offset-2 {
    margin-left: 16.66667%;
  }

  .vlc-col.lg-offset-3 {
    margin-left: 25%;
  }

  .vlc-col.lg-offset-4 {
    margin-left: 33.33333333%;
  }

  .vlc-col.lg-offset-5 {
    margin-left: 41.66667%;
  }

  .vlc-col.lg-offset-6 {
    margin-left: 50%;
  }

  .vlc-col.lg-offset-7 {
    margin-left: 58.33333%;
  }

  .vlc-col.lg-offset-8 {
    margin-left: 66.66667%;
  }

  .vlc-col.lg-offset-9 {
    margin-left: 75%;
  }

  .vlc-col.lg-offset-10 {
    margin-left: 83.33333%;
  }

  .vlc-col.lg-offset-11 {
    margin-left: 91.66667%;
  }

  .vlc-col.lg-offset-12 {
    margin-left: 100%;
  }

}
@media (min-width: 1440px) {

  .vlc-col.xl-1 {
    flex: 0 0 8.33333%;
    max-width: 100%;
  }
  
  .vlc-col.xl-2 {
    flex: 0 0 16.66667%;
    max-width: 16.66667%;
  }

  .vlc-col.xl-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
  
  .vlc-col.xl-4 {
    flex: 0 0 33.33333333%;
    max-width: 33.33333333%;
  }

  .vlc-col.xl-5 {
    flex: 0 0 41.66667%;
    max-width: 41.66667%;
  }

  .vlc-col.xl-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }

  .vlc-col.xl-7 {
    flex: 0 0 58.33333%;
    max-width: 58.33333%;
  }

  .vlc-col.xl-8 {
    flex: 0 0 66.66667%;
    max-width: 66.66667%;
  }

  .vlc-col.xl-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }

  .vlc-col.xl-10 {
    flex: 0 0 83.33333%;
    max-width: 83.33333%;
  }

  .vlc-col.xl-11 {
    flex: 0 0 91.66667%;
    max-width: 91.66667%;
  }

  .vlc-col.xl-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }

}

.vlc-col.flex-1{
  flex: 1;
}


/* ---- Navigation ---- */

header.nav {
  position: relative;
  top: 0;
  width: 100%;
  z-index: 100;
  height: 65px;
}

@media (min-width: 1024px) {
  header.nav {
    height: auto;
  }
}

header .nav__wrapper {
  display: flex;
  align-items: center;
  padding: 10px 0;
}

@media (min-width: 1024px) {
  header .nav__wrapper {
    position: relative;
    padding: 0;
 }
}


header .nav__logo a{
  display: flex;
  align-items: center;
}

header .nav__logo a span {
  display: none;
  color: #40B93C;
  font-size: 28px;
  margin-left: 10px;
  font-family: "Montserrat-Bold";
}

header .nav__logo a img {
  max-width: 50px;
}

@media (min-width: 768px) {
  header .nav__logo a span {
    display: block;
  }
}

@media (min-width: 1024px) {
  header .nav__logo a{
    display: flex;
    align-items: flex-start;
  }

  header .nav__logo a img {
    max-width: 160px;
  }
}

header .nav__logo a {
  width: 100%;
}

@media (min-width: 1024px) {
  header .nav__logo__mobile {
    display: none;
  }
}

header .nav__logo__desktop {
  display: none;
}

@media (min-width: 1024px) {
  header .nav__logo__desktop {
    display: block;
  }
}

header .nav__submenu {
  display: none;
}

@media (min-width: 1024px) {
  header .nav__submenu {
    transition: 0.45s;
    padding: 20px 10px;
    position: absolute;
    display: flex;
    top: calc(100% + 30px);
    visibility: hidden;
    pointer-events: none;
    left: 0;
    background: #fff;
    width: 100%;
    max-width: 1050px;
    box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
    border-bottom-left-radius: 20px;
    border-bottom-right-radius: 20px;
    opacity: 0;
  }
}


header .nav__notifications{
  background: #f5f5f5;
  width: 100%;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
  padding: 20px 10px;
  position: absolute;
  display: flex;
  top: calc(100% - 10px);
  visibility: hidden;
  left: 0;
  z-index: 100000;
  opacity: 0;
}

header .nav__notifications.open {
  transition: 0.45s;
  top: 100%;
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}

@media(min-width: 768px){
  header .nav__notifications {
    border-radius: 20px;
    min-width: 300px;
    right: 0;
    left: unset;
    z-index: 100000;
    background: #fff;
    top: calc(100% + 30px);
  }

  header .nav__notifications.open {
    top: calc(100% + 10px);
  }
}

header .nav__notifications ul li a{
  transition: 0s
}

header .nav__submenu > ul {
  margin-top: 10px;
}

@media (min-width: 1024px) {
  header .nav__submenu > ul {
    margin-top: 0;
  }
}

header .nav__list {
  position: absolute;
  top: calc(100% - 10px);
  left: 0;
  width: 100%;
  z-index: 10000;
  visibility: hidden;
  pointer-events: none;
  transition: 0.45s;
  opacity: 0;
  box-shadow: 0 12px 10px 0 rgba(0, 0, 0, 0.2);
  max-height: calc(100vh - 65px);
  overflow: auto;
  padding-bottom: 10px;
}

header .nav__list.open {
  position: absolute;
  background: #F5F5F5;
  display: block;
  top: 100%;
  opacity: 1;
  visibility: visible;
  pointer-events: all;
  z-index: 100000;
  width: 100%;
  left: 0;
}

@media (min-width: 1024px) {

  header .nav__list {
    position: static;
    display: block;
    visibility: visible;
    pointer-events: all;
    opacity: 1;
    box-shadow: none;
    padding: 0;
    margin-left: 40px;
    text-align: right;
    flex: 1;
  }

}

header .nav__list > ul > li {
  display: block;
  padding: 10px 0;
  margin: 0 10px;
  border-bottom: 1px solid #e6e6e6;
  font-family: "Montserrat-Medium";
}

header .nav__list > ul > li.current {
  font-family: "Montserrat-Bold";
}

@media (min-width: 1024px) {

  header .nav__list > ul > li {
    display: inline-block;
    border: 0;
    padding: 36px 10px;
    margin: 0 10px;
  }

  header .nav__list > ul > li:hover .nav__submenu {
    top: 100%;
    opacity: 1;
    visibility: visible;
    pointer-events: all;
  }

}

@media(min-width: 1200px){
  header .nav__list > ul > li {
    margin: 0 30px;
  }
}

header .nav__extras {
  margin-left: auto;
  display: flex;
  align-items: center;
}

header .nav__icons{
  max-width: 32px;
  margin-right: 40px;
  cursor: pointer;
  display: flex;
}

@media(min-width: 768px){
  header .nav__icons{
    position: relative;
  }
}

@media(min-width: 1024px){
  header .nav__icons{
    margin-left: 40px;
    margin-right: 0;
  }
}

.notification{
  position: relative;
  display: flex;
}

.notification span{
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  border-radius: 50%;
  color: #fff;
  background-color: red;
  font-size: 10px;
  width: 15px;
  height: 15px;
  top: -5px;
  right: -5px;
}

header .nav__hamburger {
  display: block;
  position: relative;
  width: 30px;
  height: 20px;
  cursor: pointer;
}

@media (min-width: 1024px) {
  header .nav__hamburger {
    display: none;
  }
}

header .nav__hamburger span {
  display: block;
  background: #000;
  position: absolute;
  height: 2px;
  width: 100%;
  opacity: 1;
  left: 0;
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
  -webkit-transition: 0.25s ease-in-out;
  -moz-transition: 0.25s ease-in-out;
  -o-transition: 0.25s ease-in-out;
  transition: 0.25s ease-in-out;
}

header .nav__hamburger span:nth-child(1) {
  top: calc(50% - 8px);
}

header .nav__hamburger span:nth-child(2) {
  top: 50%;
}

header .nav__hamburger span:nth-child(3) {
    top: calc(50% + 8px);
}

header .nav__hamburger.open span:nth-child(1) {
  top: 50%;
  -webkit-transform: rotate(135deg);
  -moz-transform: rotate(135deg);
  -o-transform: rotate(135deg);
  transform: rotate(135deg);
}

header .nav__hamburger.open span:nth-child(2) {
  opacity: 0;
}

header .nav__hamburger.open span:nth-child(3) {
  top: 50%;
  -webkit-transform: rotate(-135deg);
  -moz-transform: rotate(-135deg);
  -o-transform: rotate(-135deg);
  transform: rotate(-135deg);
}

/* ---- Other elements ----*/

.white-wrapper{
  background: #fff;
  padding: 20px 25px;
  box-shadow: 2px 2px 24px 0 rgba(0, 0, 0, 0.1);
  border-radius: 25px;
}

.white-wrapper__header{
  display: flex;
}

.white-wrapper__header{
  display: flex;
}


/* ---- Tabs ---- */

.tab-container {
  margin-bottom: 20px;
}

.tab-buttons {
  display: flex;
}

.tab-buttons button {
  background-color: transparent;
  font-family: "Montserrat";
  border: none;
  padding: 16px 10px;
  cursor: pointer;
  border-top-left-radius: 15px;
  border-top-right-radius: 15px;
  hyphens: auto;
}

@media(min-width: 768px){
  .tab-buttons button {
    padding: 16px 24px;
  }
}

.tab-buttons button.active {
  background-color: #fff;
  color: #40b93c;
  font-family: "Montserrat-SemiBold";
}

.tab-content {
  display: none;
}

.tab-content.active {
  display: block;
}


/* ---- Table styling ---- */

table{
  background: #fff;
  font-size: 16px;
  padding: 10px;
  border-radius: 25px;
  border-top-left-radius: 0;
  font-family: "Montserrat";
  font-size: 14px;
}

@media(min-width: 768px){
  table{
    font-size: 16px;
  }
}

@media(min-width: 1024px){
  table{
    font-size: 18px;
    padding: 0 20px 10px;
  }
}

.nested-table {
  display: none;
  width: 100%;
}

.dt-container table.dataTable>thead>tr>th{
  font-family: "Montserrat-SemiBold";
  padding: 20px 10px;
  border-bottom: 2px solid #D9D9D9;
}

.dt-container table.dataTable.hover>tbody>tr:hover>*, 
.dt-container table.dataTable.display>tbody>tr:hover>*,
.dt-container table.dataTable.stripe>tbody>tr:nth-child(odd)>*, 
.dt-container table.dataTable.display>tbody>tr:nth-child(odd)>*{
  box-shadow: unset;
}


@media(min-width: 1024px){
  .dt-container table.dataTable.display>tbody>tr{
    transition: 0.25s;
    cursor: pointer;
  }
  
  .dt-container table.dataTable.display>tbody>tr:hover{
    background: #f5f5f5;
  }
}

table.dataTable.dtr-inline.collapsed>tbody>tr>td.dtr-control, 
table.dataTable.dtr-inline.collapsed>tbody>tr>th.dtr-control{
  padding-right: 20px;
  padding-left: 20px;
  vertical-align: middle;
  position: relative;
}

table.dataTable.dtr-inline.collapsed>tbody>tr>td.dtr-control:before, 
table.dataTable.dtr-inline.collapsed>tbody>tr>th.dtr-control:before{
  position: absolute;
  left: 0;
  top: calc(50% - 5px)
}

.tab-container div.dt-container.dt-empty-footer tbody>tr:last-child>*{
  border-bottom: 0;
}

table.dataTable>tbody>tr.child ul.dtr-details{
  width: 100%;
}

table.dataTable>tbody>tr.child ul.dtr-details>li{
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.dt-container table.dataTable>tbody>tr>th, 
.dt-container table.dataTable>tbody>tr>td{
  padding: 20px 10px;
  border-top: 2px solid #D9D9D9
}

div.dt-container div.dt-layout-row.dt-layout-table div.dt-layout-cell{
  padding-top: 0;
}

div.dt-container .dt-info{
  display: none;
}

table .table-car-image{
  max-width: 120px;
}

/* ---- Popup ---- */

.popup{
  background: rgba(0, 0, 0, 0.5);
  box-shadow: 2px 2px 24px 0px rgba(0, 0, 0, 0.1);
  top: 0;
  position: fixed;
  right: 0;
  left: 0;
  bottom: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  visibility: hidden;
  opacity: 0;
  pointer-events: none;
  padding: 40px 10px;
  z-index: 101;
}

.popup.show{
  visibility: visible;
  opacity: 1;
  pointer-events: all;
}

.popup__wrapper{
  position: relative;
  background: linear-gradient(180deg, #FFFFFF 15.93%, #E9E9E9 54%, #FFFFFF 92.25%);
  box-shadow: 2px 2px 24px 0px rgba(0, 0, 0, 0.1);
  height: 100%;
  max-width: 1024px;
  max-height: 550px;
  padding: 20px;
  border-radius: 25px;
  width: 100%;
  overflow: auto;
}

.popup__close{
  position: absolute;
  right: 20px;
  top: 20px;
  cursor: pointer;
  z-index: 1;
}

button.popup__close{
  position: relative;
  right: unset;
  top: unset;
}

.popup__img{
  max-width: 320px;
}


.calendar{
  position: relative;
  display: inline-block;
  max-width: 440px;
  width: 100%;
}

.calendar-popup{
  position: relative;
  display: none;
  background: #fff;
  padding: 20px;
  border: 1px solid #808080;
  margin-top: 10px;
  width: 100%;
  max-width: 320px;
}

@media(min-width: 768px){
  .calendar-popup{
    position: absolute;
    left: 100%;
    bottom: 0;
    margin-top: 0;
  }
}

/* ---- datepicker styling ---- */

#datepicker .ui-datepicker{
  max-width: 440px;
  width: 100%;
  padding: 10px;
  border-radius: 15px;
  border: 0;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
}

@media(min-width: 768px){
  #datepicker .ui-datepicker{
    padding: 30px;
  }
}

.ui-datepicker .ui-datepicker-header{
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  background: transparent;
  border: 0;
  font-family: "Montserrat";
  max-width: 360px;
  margin: auto;
  margin-bottom: 15px;
}

.ui-datepicker .ui-datepicker-header .ui-datepicker-title{
  font-size: 20px;
  font-family: "Montserrat";
  font-weight: normal;
}

.ui-datepicker .ui-datepicker-calendar th{
  font-family: "Montserrat-SemiBold";
  font-weight: normal;
  text-transform: uppercase;
}

.ui-datepicker .ui-datepicker-calendar th:nth-child(6),
.ui-datepicker .ui-datepicker-calendar th:nth-child(7){
  opacity: 0.6;
}

.ui-datepicker .ui-datepicker-calendar td span,
.ui-datepicker .ui-datepicker-calendar td a{
  text-align: center;
  font-family: "Montserrat-SemiBold";
  font-size: 16px;
  border: 0;
  background: transparent;
  padding: 5px;
  width: 30px;
  height: 30px;
  margin: auto;
  border-radius: 5px;
  display: flex;
  align-items: center;
  justify-content: center;
}

@media(min-width: 768px){
  .ui-datepicker .ui-datepicker-calendar td span,
  .ui-datepicker .ui-datepicker-calendar td a{
    width: 40px;
    height: 40px;
  }
}

.ui-datepicker .ui-datepicker-calendar td.ui-state-disabled{
  opacity: 1;
}

.ui-datepicker .ui-datepicker-calendar td.ui-datepicker-today a{
  border: 2px solid #40b93c;
}

.ui-datepicker .ui-datepicker-calendar td.ui-datepicker-today a{
  border: 2px solid #40b93c;
  color: #000;
}

.ui-datepicker .ui-datepicker-calendar td.highlighted-date a{
  border: 2px solid #2B7B28;
  color: #000;
}

.ui-datepicker .ui-datepicker-calendar td.highlighted-date.ui-datepicker-current-day a{
  background: #2B7B28;
  color: #fff;
}

.ui-datepicker .ui-datepicker-header .ui-datepicker-prev, 
.ui-datepicker .ui-datepicker-header .ui-datepicker-next {
  position: absolute;
  display: block;
  width: 24px;
  height: 24px;
  background-position: right;
  background-repeat: no-repeat;
  background-size: contain;
  cursor: pointer;
  top: unset;
}

.ui-datepicker .ui-datepicker-header .ui-datepicker-prev{
  left: 0;
}

.ui-datepicker .ui-datepicker-header .ui-datepicker-prev:hover, 
.ui-datepicker .ui-datepicker-header .ui-datepicker-next:hover {
  background-color: transparent;
  border: 0;
}

.ui-datepicker .ui-datepicker-header .ui-datepicker-prev span, 
.ui-datepicker .ui-datepicker-header .ui-datepicker-next span{
  display: none;
}


.ui-datepicker .ui-datepicker-header .ui-datepicker-next{
  right: 0;
  background-image: url("../img/icons/chevron-right.svg");
}

.ui-datepicker .ui-datepicker-header .ui-datepicker-prev{
  right: 0;
  background-image: url("../img/icons/chevron-left.svg");
}


div#ui-datepicker-div{
  max-width: 320px;
  width: 100%;
  padding: 10px;
  border-radius: 15px;
  border: 0;
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
}

div#ui-datepicker-div .ui-datepicker-header .ui-datepicker-title{
  display: flex;
}

.ui-datepicker .ui-datepicker-header select.ui-datepicker-month, 
.ui-datepicker .ui-datepicker-header select.ui-datepicker-year {
  padding: 5px 30px 5px 10px;
  width: auto;
  display: inline-block;
  margin: 0 5px;
  border-radius: 10px;
  font-size: 14px;
}

/* ---- Accordions ---- */ 


.vlc-accordion {
  border-bottom: 2px solid #D9D9D9;
}

.vlc-accordion__button {
  position: relative;
  border: 0;
  outline: none;
  background: transparent;
  width: 100%;
  padding: 20px 0;
  text-align: left;
  font-size: 16px;
  line-height: 22px;
  font-family: "Montserrat-Bold";
  cursor: pointer;
}

.vlc-accordion__button::after {
  content: url('../img/icons/chevron-down.svg');
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: 0.25s;
}

@media (min-width: 768px) {
  .vlc-accordion__button {
    font-size: 18px;
  }
}

@media (min-width: 1024px) {
  .vlc-accordion__button {
    font-size: 20px;
  }
}

.vlc-accordion__button.open {
  border-bottom: 0;
}

.vlc-accordion__button.open::after {
  transform: rotate(180deg);
}

.vlc-accordion__content {
  display: none;
}

.vlc-accordion__content .vlc-accordion__button {
  font-family: "Montserrat-Bold";
  padding-right: 15px;
  font-size: 16px;
  line-height: 22px;
  padding: 15px 0;
}

.vlc-accordion__content .vlc-accordion__button::after {
  content: "+";
  font-size: 26px;
  top: calc(50% - 15px);
  bottom: unset;
  border: 2px solid #D9D9D9;
  border-radius: 50px;
  height: 30px;
  width: 30px;
  color: #D9D9D9;
  line-height: 1;
}

.vlc-accordion__content .vlc-accordion__button.open::after{
  content: "-";
  transform: none;
}

.vlc-accordion__content ul li{
  font-size: 14px;
  line-height: 22px;
}

.vlc-accordion__content .vlc-accordion__content{
  padding: 10px 0;
}

.vlc-accordion__content:last-of-type {
  border-bottom: 0;
}

.vlc-accordion__text, .vlc-accordion__background-text {
  margin-bottom: 20px;
  font-size: 14px;
  line-height: 20px;
}

@media (min-width: 768px) {
  .vlc-accordion__text, .vlc-accordion__background-text {
    font-size: 16px;
    line-height: 22px;
  }
}

.vlc-accordion__background-text {
  padding: 15px 10px;
  background: rgba(213, 213, 213, 0.4);
  border-radius: 15px;
}


/* ---- Car Details ---- */

.car-details{
  margin-top: 30px;
  margin-bottom: 80px;
}

.car-details__image{
  max-width: 280px;
}

.car-details__buttons{
  margin-top: 10px;
}

.car-details__buttons .vlc-btn{
  margin: auto;
  margin-bottom: 20px;
}

@media(min-width: 768px){
  .car-details__header{
    display: flex;
    justify-content: space-between;
  }

  .car-details__buttons{
    display: flex;
  }

  .car-details__buttons .vlc-btn{
    margin: 0;
    margin-right: 30px;
  }
}

.car-gallery{
  margin-bottom: 50px;
}

.car-gallery__image{
  border: 1px solid #000;
  padding: 10px;
}


/* ---- VLC card ---- */

.vlc-card{
  border-radius: 15px;
  background: #FFF;
  box-shadow: 2px 2px 24px 0 rgba(0, 0, 0, 0.1);
  padding: 16px 20px;
  margin-bottom: 20px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  color: #000;
  cursor: pointer;
}

.vlc-card:hover{
  color: #000;
}

.vlc-card__header{
  display: flex;
  flex-direction: column;
  height: 100%;
}

.vlc-card__image{
  max-height: 100px;
  margin: 0 auto 15px;
}

.vlc-card__image img{
  height: 100%;
  width: 100%;
  object-fit: contain;
}

.vlc-card__name p{
  font-family: "Montserrat-SemiBold";
  font-size: 16px;
  line-height: 20px;
  margin: 0;
}

.vlc-card__name span{
  font-size: 14px;
  line-height: 18px;
  display: block;
}

.vlc-card__number{
  margin-bottom: 15px;
}

.vlc-card__number span{
  display: block;
  font-size: 12px;
  line-height: 18px;
}

.vlc-card__number span:first-child{
  opacity: 0.5;
}

.vlc-card__number span:last-child{
  font-family: "Montserrat-SemiBold";
}

.vlc-card__status{
  background-color: rgba(64, 185, 60, 0.6);
  color: #2B7B28;
  padding: 5px;
  border-radius: 15px;
  font-size: 12px;
  font-family: "Montserrat-Medium";
  line-height: 14px;
  text-align: center;
}

.vlc-card__status.under-review{
  background-color: #FFEB7B;
  color: #D49C00;
}

/* ---- Filter ---- */

.vlc-filter{
  display: inline-block;
  background: #FFF;
  box-shadow: 2px 2px 24px 0 rgba(0, 0, 0, 0.1);
  padding: 24px 20px;
  border-radius: 15px;
  width: 100%;
}

.vlc-filter ul{
  columns: 1;
  -webkit-columns: 1;
  -moz-columns: 1;
}

.vlc-filter ul li{
  font-family: "Montserrat-Medium";
  font-size: 14px;
  line-height: 18px;
  margin-bottom: 10px;
}

.vlc-filter ul li label{
  font-family: "Montserrat-Medium";
  font-size: 14px;
  line-height: 18px;
}

@media(min-width: 400px){
  .vlc-filter ul{
    columns: 2;
    -webkit-columns: 2;
    -moz-columns: 2;
  }
}

@media(min-width: 560px){
  .vlc-filter ul{
    columns: 3;
    -webkit-columns: 3;
    -moz-columns: 3;
  }
}

@media(min-width: 768px){
  .vlc-filter{
    width: auto;
  }

  .vlc-filter ul{
    columns: 1;
    -webkit-columns: 1;
    -moz-columns: 1;
  }
  
  .vlc-filter ul li{
    margin-bottom: 20px;
  }
  
}

