@charset "UTF-8";

/* CSS Document */
body:after {
  position: absolute;
  width: 0;
  height: 0;
  overflow: hidden;
  z-index: -1;

}

body,
h1,
h2,
h3,
h4,
h5,
p {
  font-family: "Lato", sans-serif;
}

a {
  color: inherit;
  text-decoration: none;
}

.lato-thin {
  font-family: "Lato", sans-serif;
  font-weight: 100;
  font-style: normal;
}

.lato-light {
  font-family: "Lato", sans-serif;
  font-weight: 300;
  font-style: normal;
}

.lato-regular {
  font-family: "Lato", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.lato-bold {
  font-family: "Lato", sans-serif;
  font-weight: 700;
  font-style: normal;
}

.lato-black {
  font-family: "Lato", sans-serif;
  font-weight: 900;
  font-style: normal;
}

.lato-thin-italic {
  font-family: "Lato", sans-serif;
  font-weight: 100;
  font-style: italic;
}

.lato-light-italic {
  font-family: "Lato", sans-serif;
  font-weight: 300;
  font-style: italic;
}

.lato-regular-italic {
  font-family: "Lato", sans-serif;
  font-weight: 400;
  font-style: italic;
}

.lato-bold-italic {
  font-family: "Lato", sans-serif;
  font-weight: 700;
  font-style: italic;
}

.lato-black-italic {
  font-family: "Lato", sans-serif;
  font-weight: 900;
  font-style: italic;
}

.urbanist-<uniquifier> {
  font-family: "Urbanist", sans-serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
}
.oswald-<uniquifier> {
  font-family: "Oswald", sans-serif;
  font-optical-sizing: auto;
  font-weight: <weight>;
  font-style: normal;
}

.noise {
  pointer-events: none;
  z-index: calc(infinity);
  opacity: .06;
  background-image: url(../img/noise.gif);
  background-position: 0 0;
  background-size: 250px;
  background-attachment: fixed;
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}



.sp-nav {
  padding: 1rem;
}

.logo-nav {
  max-width: 300px;
  min-width: 300px;
  transition-duration: 1s;
}

.navbar {
  padding: 2rem;
  padding-left: 6rem;
  padding-right: 6rem;
  border-radius: 1rem;
  transition-duration: 1s;
}

.nav-link {
  font-family: "Afacad Flux", sans-serif;
  font-size: calc(16px + (24 - 16) * ((100vw - 300px) / (1920 - 300)));
  color: #1d1d1d;
  margin-left: 2rem;

}

.bg-light {
  background-color: #edededf6 !important;
}

.navbar.scrolled {
  padding: 1rem;
  transition-duration: 1s;
}

.navbar.scrolled>div>a>.logo-nav {
  max-width: 130px;
  min-width: 130px;
  transition-duration: 1s;
}

.h {
  height: 220vh;
}

.sp-head {
  padding-left: 4rem;
  padding-right: 4rem;
  padding-top: 1rem;
  transition-duration: 1s;
}

.sp-head.scrolledh {
  padding-left: 0.1rem;
  padding-right: 0.1rem;
  transition-duration: 1s;
}

.righe {
  background-image: url(../img/back.svg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  border-radius: 1rem 1rem 0rem 0rem;
}

.onda {
  background-image: url(../img/onda.svg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  border-radius: 1rem 1rem 0rem 0rem;
}

.title-h1 {
  font-size: calc(30px + (90 - 30) * ((100vw - 300px) / (1920 - 300)));
  line-height: calc(30px + (100 - 30) * ((100vw - 300px) / (1920 - 300)));
  font-weight: 300;
  color: #ededed;
  padding-top: 4rem;
  padding-left: 4rem;
}

.txt-video {
  font-size: calc(24px + (42 - 24) * ((100vw - 300px) / (1920 - 300)));
  line-height: calc(26px + (44 - 26) * ((100vw - 300px) / (1920 - 300)));
  font-weight: 300;
  color: #edededf6;
  padding-top: 8rem;
  padding-right: 4rem;
  text-align: right;
}

.logo {
  max-width: 60%;
  padding-top: 10vh;
}

.logo-s {
  max-width: 24%;
  padding-top: 10vh;
}

.big-title {
  font-size: calc(50px + (220 - 50) * ((100vw - 300px) / (1920 - 300)));
  line-height: calc(75px + (220 - 75) * ((100vw - 300px) / (1920 - 300)));
  font-weight: 400;
  color: #303030f6;
  text-transform: uppercase;
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.title-h2 {
  font-size: calc(30px + (44 - 30) * ((100vw - 300px) / (1920 - 300)));
  line-height: calc(30px + (44 - 30) * ((100vw - 300px) / (1920 - 300)));
  font-weight: 700;
  color: #303030f6;
}

.txt {
  font-size: calc(18px + (24 - 18) * ((100vw - 300px) / (1920 - 300)));
  line-height: calc(20px + (29 - 18) * ((100vw - 300px) / (1920 - 300)));
  font-weight: 400;
  color: #303030f6;
}

.sp-box {
  padding: 1rem;
}

.back-scheda {
  background-size: 100%;
  background-position: top center;
  background-repeat: no-repeat;
  border-radius: 0rem 0rem 2rem 2rem;
}

.h-azienda {
  padding-top: 30vh;
}

.sp-tecnologia {
  padding-top: 25vh;
  transition-duration: 1s;
}

.sp-tecnologia.scroll-schede {
  padding-top: 10vh;
  transition-duration: 1s;
}

.h-tecnologia {
  padding-top: 25vh;
}

.sp-produzione {
  padding-top: 10vh;
}

.h-assistenza {
  padding-top: 30vh;
}

.sp-assistenza {
  padding-top: 10vh;
}

.box-azienda {

  border-radius: 1rem;
  padding: 2rem;
}

.pos-txt-robot {
  padding-top: 25%;
  margin-left: -12%
}

.pos-txt-sistemi {
  padding-top: 10%;
  padding-left: 4%;

}

.pos-3 {
  margin-top: -10%;
  padding-bottom: 4rem;
}

.sp-2-img {
  padding-top: 10rem;
}

.txt-img {
  font-size: calc(18px + (28 - 18) * ((100vw - 300px) / (1920 - 300)));
  line-height: calc(20px + (32 - 20) * ((100vw - 300px) / (1920 - 300)));
  font-weight: 300;
  color: #303030f6;
}

.title-h2-serv {
  font-size: calc(30px + (54 - 30) * ((100vw - 300px) / (1920 - 300)));
  line-height: calc(30px + (54 - 30) * ((100vw - 300px) / (1920 - 300)));
  font-weight: 700;
  color: #303030f6;
}

.sp-video {
  padding-left: 6rem;
  padding-right: 6rem;
  padding-bottom: 4rem;
}

.sp-video-bot {
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  padding-bottom: 2rem;
}

.video-end {
  border-radius: 2rem;
}

.logo-foot {
  padding-left: 30%;
  max-height: 80%;
  padding-top: 15%;
}


.sp-foot {
  background-color: #1b1b1b;

  padding-top: 1.5rem;
}

.sp-contatti {
  padding-top: 4%;
  padding-right: 8%;
}

.tit-foot {
  color: #797979;
  font-size: calc(14px + (20 - 14) * ((100vw - 300px) / (1920 - 300)));
  font-weight: 300;
  letter-spacing: 0.05rem;
  line-height: calc(22px + (20 - 22) * ((100vw - 300px) / (1920 - 300)));
  text-decoration: none;
}

.txt-foot {

  color: #ffffff;
  font-size: calc(14px + (18 - 14) * ((100vw - 300px) / (1920 - 300)));
  font-weight: 300;
  letter-spacing: 0.05rem;
  line-height: calc(20px + (20 - 20) * ((100vw - 300px) / (1920 - 300)));
  text-decoration: none;
  padding-top: 7%;
}

.dati {
  color: #797979;
  font-size: calc(12px + (12 - 12) * ((100vw - 300px) / (1920 - 300)));
  font-weight: 500;
  letter-spacing: 0.05rem;
  line-height: calc(18px + (20 - 18) * ((100vw - 300px) / (1920 - 300)));
  text-decoration: none;
  padding-top: -3rem;
  padding-bottom: 3%;
  text-align: center;
}

.mappa {
  height: 40vh;
  filter: grayscale(100%);
}


/*-----------------------------------Video Back----------------------------------------------*/
.box-video-head {
  padding: 1rem;
  padding-top: 5rem;
  margin: 0px;

}

.video-background-holder {
  position: relative;
  background-color: #222222;
  height: 80vh;
  min-height: 25rem;
  width: 100%;
  overflow: hidden;
  opacity: 1;
  border-radius: 1rem;
}

.video-background-holder video {
  position: absolute;
  top: 50%;
  left: 50%;
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  z-index: 0;

  -ms-transform: translateX(-50%) translateY(-50%);
  -moz-transform: translateX(-50%) translateY(-50%);
  -webkit-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
}

.video-background-content {
  position: relative;
  z-index: 2;
}

.video-background-overlay {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: #fff;
  opacity: 0;
  z-index: 1;
}

/*-----------------------------------Fine Video Back----------------------------------------------*/
a:hover {
  color: #de7e24;
}

@media only screen and (max-width: 2000px) {
  .h-azienda {
    padding-top: 20vh;
  }

  .txt {
    font-size: calc(18px + (20 - 18) * ((100vw - 300px) / (1920 - 300)));
    line-height: calc(20px + (22 - 18) * ((100vw - 300px) / (1920 - 300)));
  }

  .title-h2 {
    font-size: calc(22px + (32 - 22) * ((100vw - 300px) / (1920 - 300)));
  }
}



@media only screen and (max-width: 1030px) {
  .sp-tecnologia {
    padding-top: 20vh;
    transition-duration: 1s;
  }

  .h-tecnologia {
    padding-top: 15vh;
    margin-top: -30%;
  }

  .sp-produzione {
    padding-top: 4vh;
  }

  .txt-img {
    font-size: calc(18px + (20 - 18) * ((100vw - 300px) / (1920 - 300)));
  }

  .sp-head {
    padding-left: 2rem;
    padding-right: 2rem;
    padding-top: 1rem;
    transition-duration: 1s;
  }

  .title-h1 {
    font-size: calc(30px +(90 - 30)*((100vw - 300px) /(1920 - 300)));
    line-height: calc(30px +(100 - 30)*((100vw - 300px) /(1920 - 300)));
    font-weight: 300;
    color: #ededed;
    padding-top: 2rem;
    padding-left: 2rem;
  }

  .logo-nav {
    max-width: 160px;
    min-width: 160px;
    transition-duration: 1s;
  }

  .navbar.scrolled>div>a>.logo-nav {
    max-width: 100px;
    min-width: 100px;
    transition-duration: 1s;
  }

  .navbar {
    padding: 2rem;
    padding-left: 3rem;
    padding-right: 3rem;
    border-radius: 1rem;
    transition-duration: 1s;
  }
}

@media only screen and (max-width: 840px) {
  .logo {
    max-width: 80%;
    padding-top: 20vh;
  }

  .h-tecnologia {
    padding-top: 15vh;
    margin-top: 0%;
  }

  .logo-s {
    max-width: 50%;
    padding-top: 10vh;
  }

  .sp-foot {
    background-color: #2D2D2D;

    padding-top: 1.5rem;
  }

  .sp-head {
    padding-left: 1rem;
    padding-right: 1rem;
    padding-top: 1rem;
    transition-duration: 1s;
  }

  .sp-head.scrolledh {
    padding-left: 0.1rem;
    padding-right: 0.1rem;
    transition-duration: 1s;
  }

  .box-video-head {
    padding: 0.2rem;
    margin: 0px;
  }

  .navbar {
    padding: 1rem;
    padding-left: 1rem;
    padding-right: 1rem;
    border-radius: 1rem;
    transition-duration: 1s;
  }

  .title-h1 {
    font-size: calc(30px +(90 - 30)*((100vw - 300px) /(1920 - 300)));
    line-height: calc(30px +(100 - 30)*((100vw - 300px) /(1920 - 300)));
    font-weight: 400;
    color: #ededed;
    padding-top: 4rem;
    padding-left: 0.5rem;
  }

  .txt-video {

    font-weight: 300;
    color: #edededf6;
    padding-top: 2rem;
    padding-right: 0.5rem;
    text-align: right;
  }

  .sp-tecnologia {
    padding-top: 5vh;
    transition-duration: 1s;
  }

  .pos-txt-robot {
    padding-top: 25%;
    margin-left: auto;
    padding: 2rem;
  }

  .pos-txt-sistemi {
    padding-top: 10%;
    padding-left: auto;
    padding: 2rem;
  }

  .pos-3 {
    padding: 2rem;
    padding-top: 1rem;
  }

  .logo-foot {
    padding-left: 5%;
    max-width: 80%;
    padding-top: 15%;
  }

  .sp-contatti {
    padding: 2rem;
  }

  .tit-foot {
    margin-bottom: 0.2rem;
    padding-top: 0.6rem;
  }

  .txt-foot {
    margin-bottom: 0.2rem;
    padding-top: 0.2rem;
  }

  .video-background-holder {
    position: relative;
    background-color: #222222;
    height: 90vh;
    min-height: 25rem;
    width: 100%;
    overflow: hidden;
    opacity: 1;
    border-radius: 1rem;
  }

  .sp-video {
    padding-left: 0.4rem;
    padding-right: 0.4rem;
    padding-bottom: 2rem;
  }

  .video-end {
    border-radius: 1rem;
  }

  .sp-video-bot {
    padding-left: 0.2rem;
    padding-right: 0.2rem;
    padding-bottom: 0.4rem;
  }
}