
    @font-face {
      font-family: Avant_Medium;
      src: url(font/ITC_Avant-Garde_Gothic_Medium.otf) format("opentype");
    }

    @font-face {
      font-family: Nexa_Bold;
      src: url(font/Nexa_Bold.otf) format("opentype");
    }
    @font-face {
      font-family: Nexa_Light;
      src: url(font/Nexa_Light.otf) format("opentype");
    }



    *, *:before, *:after {
      -webkit-box-sizing: border-box;
      -moz-box-sizing: border-box;
      box-sizing: border-box;
      font-weight: unset;
      font-family: 'Nexa_Light';
      -webkit-user-select: none; /* Safari */
  -ms-user-select: none; /* IE 10 and IE 11 */
  user-select: none; /* Standard syntax */
      }
    html{
        scroll-behavior: smooth;
    }
    body{
        margin: 0;
        padding: 0;
        width: 100vw;
        background-color: white;
        overflow-x: hidden;
    }

    body::-webkit-scrollbar {
  width: 1em;
}
 
body::-webkit-scrollbar-track {
  background-color: #BCFF84;
}
 
body::-webkit-scrollbar-thumb {
  background-color: #1A332D;
}

    img{
        width: 100%;
    }

    svg{
        display: none;
    }

    a {
        color: inherit;
        text-decoration: none;
    }

a:hover,a:visited,a:hover,a:active {
    color:inherit; 
    text-decoration:none; 
    cursor:pointer;  
}

canvas[resize] {
    width: 100vw;
    height: inherit;
}

/*menu desktop*/

    .desktop{
        display: block;
    }
    .mobile{
        display: none;
    }

    .menu_d{
        display: flex;
        width: 100%;
        padding: 16px 45px;
        position: fixed;
        top: 0;
    background: white;
    box-shadow: 0 4px 16px #0000000f;
    z-index: 99;
    }

    .logo_lab_d{
        width: 60px;
    }

    .buttons_menu_d{
        display: flex;
        gap: 30px;
        align-self: center;
        margin-left: auto;
    }

    .button_menu_d{
        position: relative;
         padding: 10px 20px;
         transition: all 0.5s cubic-bezier(.47,1.64,.41,.8);
         cursor: pointer;
    }

    .button_menu_d:hover{
        font-weight: bolder;
    }

    .blur_back{
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: #BCFF84;
        border-radius: 15px;
        z-index: -1;
        -webkit-filter: url('#liquid');
        filter: url('#liquid');
        transform: scale(0);
        transition: all 0.5s;
    }

    .button_menu_d:hover .blur_back{
        /*display: block;*/
        transform: scale(1);
    }


    .ball {
        width: 20px;
        height: 20px;
        position: absolute;
        top: calc(50% - 10px);
        left: calc(50% - 10px);
    }
 .ball:before {
     background: #BCFF84;
     border-radius: 100%;
     position: absolute;
     top: 0;
     left: 0;
     width: 100%;
     height: 100%;
     content: '';
}
 .ball:nth-child(1) {
     transform: translate(-66px);
     animation: x-axis-lateral 2s infinite alternate ease-in-out;
}
 .ball:nth-child(1):before {
     animation: y-axis-lateral 1s infinite 0.1s alternate ease-in-out;
}
 .ball:nth-child(2) {
     animation: x-axis 2s infinite alternate ease-in-out;
}
 .ball:nth-child(2):before {
     animation: y-axis 1s infinite 0.5s alternate ease-in-out;
}
 .ball:nth-child(3) {
     transform: translate(66px, 78px);
     animation: x-axis-lateral 2s infinite alternate ease;
}
 .ball:nth-child(3):before {
     animation: y-axis-lateral 1s infinite 0.4s alternate ease-in-out;
}
 @keyframes x-axis {
     0% {
         transform: translate(-180%);
    }
     100% {
         transform: translate(180%);
    }
}
 @keyframes y-axis {
     0% {
         transform: translateY(120%);
    }
     100% {
         transform: translateY(-120%) scale(0.8);
         background: #BCFF84;
    }
}
 @keyframes x-axis-lateral {
     0% {
         transform: translate(-180%);
    }
     100% {
         transform: translate(180%);
    }
}
 @keyframes y-axis-lateral {
     0% {
         transform: translateY(110%);
    }
     100% {
         transform: translateY(-110%);
         background: #BCFF84;
    }
}
/*end menu dekstop*/
/*Slider*/

header{
    width: 100%;
    height: 55vh;
    margin-top: 121px;
    /*background-color: lightgray;*/
}

#slider{
    overflow-x: hidden;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    max-width: 1280px;
    margin: auto;
}

.slide{
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10%;
    width: 100%;
    max-width: 1110px;
}

.title_slide{
    width: 30%;
    font-size: 0.8rem;
    font-family: Avant_Medium;
        height: 20vh;
}

.slide_title{
    line-height: 250%;
    margin-bottom: 10px;
}

.slide_title .main{
    font-family: Nexa_Bold;
    font-size: 6rem;
    color: #1A332D;

}

.slide_title .sub{
    font-family: Nexa_Bold;
    font-size: 2rem;
    color: lightgrey;
}
.image_slide{
    width: 40%;
}

#container_know{
    width: 100%;
    height: 40vh;
    position: relative;
}

/*meet the lab*/
#container_know canvas {
  position: absolute;
  top: -50px;
  /*right: -50px;*/
  bottom: -50px;
  /*left: -50px;*/

  z-index: -1;
}

.know_content{
    padding: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10%;
    height: 100%;
}

.title{
    color: #1A332D;
    font-family: Nexa_Bold;
    font-size: 6rem;
    width: 40%;
    text-align: right;
    line-height: 80%;
}

.text{
    color: #252525;
    font-family: Avant_Medium;
    font-size: 0.8rem;
    width: 50%;
    padding-right: 10%;
}
/*Client*/

.clients_container{
    width: 100%;
    /*background-color: lightgray;*/
    padding-top: 50px;
    padding-bottom: 50px;
    position: relative;
}

.client_title{
    margin: auto;
    width: 150px;
}

.client_icons{
    display: flex;
    flex-wrap: wrap;
    width: 95%;
    margin: auto;
    max-width: 1024px;
    gap: 10px;
    justify-content: space-between;

}

.client_icon{
    width: 140px;
}

#base{
    /*-webkit-filter: url('#liquid');
        filter: url('#liquid');*/
        position: absolute;
    z-index: -1;
    top: 0;
        height: 100%;
}


/*Services*/

.services_container{
    padding: 50px 0;
}

.services_title{
    width: 160px;
    margin: auto;

}

.services{
    display: flex;
    max-width: 900px;
    width: 95%;
    margin: auto;
    margin-top: 50px;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 30px;
}



.service_icon{
    background-color: #E9FF85;
    border-radius: 10px;
    padding: 36px;
    width: 144px;
    height: 144px;
}

.service_icon img{
    width: auto;
    height: 75px;
    margin: auto;
    display: block;
}
/*proyects*/
.proyects_container{
 position: relative;
 padding: 50px 0;
 background: repeating-linear-gradient(
  45deg,
  #ffffff,
  #ffffff 10px,
  #E9FF85 10px,
  #E9FF85 20px
);
height: 70vh;
}
.proyects_title{
    width: 200px;
    margin: auto;
    position: relative;
    z-index: 60;
}

.proyect_card{
    width: 150px;
    height: 150px;
    background: white;
    box-shadow: 2px 1px 8px 1px #1a332d69;
    position: absolute;
    z-index: 2;
    border-radius: 10px;
    border: solid 2px #1a332d;
    cursor: grab;
    /*display: flex;*/
    transform: translate(-50%,-50%);
    /*overflow: hidden;*/
}

.activeTrasition{
    cursor: default;
    transition: all 0.5s;
}

.card_image{
    pointer-events: none;
    transition: all 0.5s;
    overflow: hidden;
    border-radius: 8px;
    z-index: 0;
}
.cadr_info_container{
    position: absolute;
    top: 0;
    width: 150px;
    height: 150px;
    pointer-events: none;
    opacity: 0;
    transition:  all 0.5s;
}
.cadr_info_image_container{
    border-radius: 8px 8px 0 0;
    overflow: hidden;
    width: 100%;
    pointer-events: none;
}
.description_container{
        background-image: url(../img/back_info.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 100% 100%;
    border-radius: 0 0 8px 8px;
    overflow: hidden;
    position: absolute;
    bottom: 4px;
    height: 196px;
    padding: 71px 10px 10px 10px;
    pointer-events: none;
}
.card_title{
    font-family: 'Nexa_Bold';
    font-size: 1.6rem;
    text-align: right;
}
.card_description{
    font-family: 'Avant_Medium';
    font-size: 0.7rem;
    padding-top: 7px;
}
.close_button{
    width: 30px;
    position: absolute;
    transform: translate(50%, -50%);
    top: 0;
    right: 0;
    pointer-events: auto;
    cursor: pointer;
    z-index: 9;
    display: none;
}
.url_buton{
    width: 94px;
    height: 25px;
    font-family: 'Nexa_Bold';
    font-size: 0.8rem;
    position: absolute;
    background-color: #e9ff85;
    border-radius: 20px;
    display: flex;
    justify-content: center;
    align-items: center;
    bottom: 0;
    transform: translateY(-50%);
    right: 0;
    bottom: -25px;
    right: 8px;
    pointer-events: auto;
    cursor: pointer;
    z-index: 9;
}
.eye{
    width: 20px;
    height: 20px;
    background-image: url('../img/plus.svg');
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    cursor: pointer;
    position: absolute;
    bottom: 8px;
    right: 8px;
    z-index: 1;

}

.gallery_container{
    position: absolute;
    top: 256px;
    flex-direction: column;
    gap: 10px;
    left: 11px;
    transform: translateY(-100%);
    display: none;
}

.gallery_button{
    width: 35px;
    height: 35px;
    border-radius: 20px;
    border: solid 2px #bcff84;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    cursor: pointer;
    pointer-events: all;
}


/*pop video*/
.black_background{
    background-color: #1a332dd4;
    position: fixed;
    width: 100%;
    height: 100vh;
    backdrop-filter: blur(10px);
    top: 0;
    z-index: 1000;
    display: none;
}

.pop_video{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    width: 95%;
    max-width: 1280px;
    background-color: #1a332d;
}
.pop_close{
    width: 30px;
    height: 30px;
    position: absolute;
    right: 10px;
    top: 10px;
    cursor: pointer;
    z-index: 99;

}

/*footer*/
footer{
    height: 250px;
    background-color: #1a332d;
}

.info_lab{
        display: flex;
    align-items: center;
        height: 100%;
    padding: 0 10%;
    justify-content: space-between;
}

.logo_footer{
    width: 100px;
}

.footer_info_container{
    border-left: 1px white solid;
    padding-left: 20px;
}

.footer_text{
        margin-bottom: 20px;
    color: white;
    font-family: sans-serif;
    font-size: 1rem;
    text-align: left;
}

.icon_container_know{
        max-width: 150px;
    margin-top: 20px;
    margin-right: auto;
}
.icon_container{
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}

.icon_social{
        width: 35px;
}


/*whatsapp*/

.whatsapp_container{
    position: fixed;
    bottom: 0;
    right: -24px;
    width: 150px;
    height: 150px;
    z-index: 999;
    transform: scale(0.7);
}

.whatsapp_link{
    width: 150px;
    height: 150px;
}

.sprite_wp{
    width: 150px;
    height: 150px;
    background-image: url(../img/whatsappv1.png);
    background-repeat: no-repeat;
    background-position: 0;
    /*animation: sprite_wp 1s steps(15) infinite;*/
    background-size: cover;
}

.sprite_wp_active{
    animation: sprite_wp 1s steps(15) infinite;
}

@keyframes sprite_wp {
  from { background-position: 0px; }
  to { background-position: -2250px; }
}



/*responsive*/
.mobile{
    display: none;
  }

  /*loading*/
  #loading{
    display: flex;
    position: fixed;
    width: 100vw;
    height: 100vh;
    background-color: white;
    justify-content: center;
    align-items: center;
    z-index: 999;
    top: 0;
    opacity: 1;
    flex-direction: column;
  }

  .loading_animation{
    width: 150px;
    height: 150px;
    background-image: url(../img/loading.png);
    background-position: 0;
    animation: sprite-loading 2s steps(27) infinite;
    transform: scale(.7);
    padding: 0;
    -webkit-filter: url('#liquid');
        filter: url('#liquid');
  }

  .loading_text{
    font-size: 0.8;
    text-align: center;
    font-family: Avant_Medium;
  }

  @keyframes sprite-loading {
  from { background-position: 0px; }
  to { background-position: -4050px; }
}

