@import url(https://fonts.googleapis.com/css?family=Montserrat:300,400,500,700);@import url(https://fonts.googleapis.com/css?family=Work+Sans:300,400,700);@import url(https://fonts.googleapis.com/css?family=Russo+One);@charset "UTF-8";

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
∞
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font-family: 'Montserrat', sans-serif;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

.footer-fixed {
  position: fixed;
  bottom: 50px;
  left: 0;
  width: 100%;
  color: #ffffff;
  padding: 0.5rem 0rem;
  font-size: 0.8rem;
  z-index: 1000;
}

.footer-fixed a {
	text-transform: uppercase;
	color: white;
}

.c-container {
  width: 100%;
  padding-left: 15px;
  margin-right: auto;
  margin-left: auto;
  /* max-width: 70vw; */
  max-width: 68vw;
}

.fullpage-layout {
  height: auto;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  display: -ms-flexbox;
  display: -webkit-box;
  display: flex;
  min-height: 100vh;
}

h1 {
  font-size: 2.4rem;
  color: #fff;
}

h2 {
  font-size: 1.6rem;
  color: #fff;
}
h3 {
  font-size: 1.3rem;
  color: #fff;
}

p {
  color: #fff;
  font-weight: lighter;
  padding: 0px 0px 10px
}
.explain { font-size: 75%; text-transform: uppercase; line-height: 110%;}

.os-scrollbar-vertical {
  display: none;
}

.custom-container {
  height: auto !important;
  overflow: auto !important;
  padding: 0;
  position: relative;
  overflow: hidden;
}

#main-background {
  padding: 0;
  position: relative;
  height: 100%;
  background-image: url("/img/bg_default.jpg");
  background-size: cover;
  background-position: center;
}

#company-background {
  padding: 0;
  position: relative;
  height: 100vh;
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

#company-background-2 {
  padding: 0;
  position: fixed;
  height: 100vh;
  width: 100vw;
  background-image: url("/img/bg_company.jpg");
  background-size: cover;
  background-position: center;
  top: 0;
}

#certification-background {
  padding: 0;
  position: relative;
  height: 100vh;
  background-image: url("/img/bg_default.jpg");
  background-size: cover;
  background-position: center;
  overflow: hidden;
}

#contacts-background {
  padding: 0;
  position: relative;
  height: 100vh;
  background: rgba(0, 0, 0, 0.5);
  background-size: cover;
  background-position: center;
}

#logo-center {
  position: absolute;
  z-index: 0;
  width: 100%;
  top: calc(50% - 110px);
  text-align: center;
}

#logo-center img {
  width: 220px;
  height: auto;
}

#header {
  position: absolute;
  top: 0;
  z-index: 1;
  width: 100%;
  display: -ms-flexbox;
  display: -webkit-box;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-align: center;
  -webkit-box-align: center;
          align-items: center;
  -ms-flex-pack: justify;
  -webkit-box-pack: justify;
          justify-content: space-between;
}

.main-menu-links {
  display: -ms-flexbox;
  display: -webkit-box;
  display: flex;
  padding: 1rem;
  margin-right: 5rem;
}

.main-menu-links .mm-link {
  color: #fff;
  margin: 0rem 1rem;
  font-weight: lighter;
  cursor: pointer;
  opacity: 0.8;
  -webkit-transition: opacity 0.5s;
  transition: opacity 0.5s;
  text-decoration: none !important;
}

.main-menu-links .mm-link:hover {
  opacity: 1;
}

.main-menu-links .mm-link.active {
  opacity: 1;
  font-weight: bold;
}

.header-brand {
  width: auto;
  height: auto;
  padding: 1rem 2rem;
  display: inline-block;
}

.header-brand svg {
  width: 80px;
  height: 80px;
}

.header-brand svg path {
  fill: #fff;
}

.vertical-heading {
  position: fixed;
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
  top: 290px;
  left: -120px;
  z-index: 1;
  display: grid;
}

.vertical-heading .vertical-breadcrumbs {
  float: left;
  color: #fff;
  font-weight: lighter;
  padding-left: 0.2rem;
}

.vertical-heading .vertical-breadcrumbs a {
  text-transform: uppercase;
  display: inline-block;
  color: #fff;
}

.vertical-heading .vertical-name {
  font-size: 3rem;
  z-index: 999;
  font-weight: bold;
  float: left;
  margin-bottom: -1rem;
}

.vertical-heading .vertical-name .v-grey {
  color: grey;
}

.vertical-heading .vertical-name .v-red {
  color: #A8260E;
}

#loading {
  position: absolute;
  z-index: 1001;
  width: 100vw;
  height: 100vh;
  right: 0;
  background-color: #262626;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center !important;
  -webkit-box-align: center !important;
          align-items: center !important;
  top: 0;
}

#loading .loading-logo {
  margin: 0 auto;
  width: 170px;
  height: 170px;
  opacity: 0;
}

#full-vertical-carousel {
  height: 100%;
  width: 100%;
  padding: 0;
  margin: 0;
  display: grid;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

#full-vertical-carousel .slide {
  height: 100vh;
  position: relative;
  display: grid;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.c-dots {
  display: block;
  position: absolute;
  right: 20px;
  list-style: none;
}

.c-dots .c-dot {
  width: 18px;
  height: 18px;
  z-index: 9999999;
  display: block;
  cursor: pointer;
  margin: 1.3rem 0rem;
  background-image: url("/img/dots.svg");
  background-position: center;
  background-size: cover;
}

.c-dots .d-title {
  display: block;
  text-transform: uppercase;
  right: 25px;
  position: absolute;
  font-weight: lighter;
  font-size: 0.8rem;
  font-weight: lighter;
  color: #fff;
  -webkit-transition: opacity 0.5s;
  transition: opacity 0.5s;
  opacity: 0;
  pointer-events: none;
  cursor: none;
}

.slick-active .d-title {
  opacity: 1;
  pointer-events: auto;
  cursor: pointer;
}

.box-red {
  background: #A8260E;
}

.box-red p {
  color: white;
}

.box-white {
  background: white;
}

.box-white p {
  color: black;
}

.box-white b, .box-red b {
  font-weight: bold;
}

.box-red,
.box-white {
  width: 100%;
  min-height: 250px;
  padding: 2rem;
}

.headquarters {
  height: 100vh;
  border-top: 1px solid red;
  width: 60vw;
  width: 70vw;
  left: -31vw;
  position: relative;
  top: -10vh;
  border-right: 1px solid red;
  padding: 5rem;
  padding-left: 30rem;
  text-align: right;
  color: #fff;
  min-width: 900px;
  background-color: rgba(0, 0, 0, 0.5);
}

.headquarters a {
  color: #ffffff;
}

.headquarters a:hover {
  color: #ffffff;
  text-decoration: underline;
}

.menu-informazioni {
  position: absolute;
  background-color: red;
  right: 2rem;
  bottom: 2rem;
  padding: 2rem;
}

.menu-informazioni p {
  font-size: 2rem;
  color: #fff;
  line-height: auto;
  font-weight: bold;
}

.map {
  height: 100vh;
  width: 50vw;
  left: -55vw;
  position: absolute;
  top: 0vh;
  border-right: 1px solid red;
  padding: 5rem;
  color: #fff;
  min-width: 900px;
}

.form {
  height: 100vh;
  width: 50vw;
  left: -55vw;
  position: absolute;
  top: 0vh;
  border-right: 1px solid red;
  padding: 5rem;
  color: #fff;
  min-width: 900px;
}

.certification img {
  max-width: 50px;
  margin: 0rem auto;
  text-align: center;
  display: block;
}

.certification .cert-title {
  font-weight: lighter;
  text-align: center;
  text-transform: uppercase;
  line-height: 110%;
  font-size: 90%;
}

.c-cert-offset {
  margin-left: 12%;
}

/* cookies */

#cookieChoiceInfo {
  line-height: 1.6em;
  font-weight: lighter;
  font-size: 0.8rem;
  background-color: #841d0a !important;
}

#cookieChoiceInfo a,
#cookieChoiceInfo span {
  color: #fff !important;
}

#cookieChoiceInfo a {
  font-weight: 700;
}

a#cookieChoiceDismiss {
  background: #fff !important;
  color: #333 !important;
  font-weight: normal !important;
  padding: 0.25rem 0.75rem !important;
  margin: 0px 20px !important;
}

.bttest {
  position: absolute;
  width: 10px;
  height: 10px;
  top: 1rem;
  right: 1rem;
  z-index: 999999999;
  background-color: green;
}

.bttest2 {
  position: absolute;
  width: 10px;
  height: 10px;
  top: 2rem;
  right: 1rem;
  z-index: 999999999;
  background-color: yellow;
}

#bg-map {
  width: 100vw;
  height: 100vh;
  position: absolute;
  z-index: -1;
}

.hamburger {
  position: fixed;
  right: 0.5rem;
  top: 1rem;
  z-index: 2;
  opacity: 1 !important;
}

.hamburger-inner,
.hamburger-inner::after,
.hamburger-inner::before {
  height: 3px;
  border-radius: 0px;
  background-color: #fff !important;
}

@media (max-width: 767px) {
  .certification{
      padding: 1rem 0rem;
  }

  .certification .col-8{
      display: flex;
      align-self: center;
  }
  .certification .cert-title{
      padding: 0px !important;
  }
  #header {
    position: fixed;
    height: 100vh;
    width: 100vw;
    background-color: black;
    display: none;
    z-index: 1;
  }

  #header .header-brand {
    position: absolute;
    top: 0;
  }

  #header .main-menu-links {
    display: inline-grid;
    float: right;
    width: 100%;
    text-align: right;
    margin-right: 0rem;
    height: 60vh;
    margin-top: 20vh;
  }

  #header .main-menu-links .mm-link {
    display: inline-block;
    text-align: right;
    font-size: 2rem;
    line-height: 3.5rem;
    font-weight: bold;
    opacity: 0.4;
  }

  #header .main-menu-links .mm-link.active {
    opacity: 1;
  }

  .vertical-heading {
    -webkit-transform: rotate(-90deg) scale(0.75);
            transform: rotate(-90deg) scale(0.75);
    top: inherit;
    left: -165px;
    display: grid;
    bottom: 120px;
  }

  #company-background,
  #certification-background {
    height: auto !important;
    overflow: auto !important;
  }

  .c-container {
    padding-top: 4.75rem;
    padding-bottom: 4.75rem;
  }

  .slide-resp {
    padding-right: 4.75rem;
    padding-left: 4.75rem;
  }

  .c-dots {
    display: block;
    position: absolute;
    right: 0px;
    bottom: 0.5rem;
    width: 100%;
    text-align: center;
  }

  .c-dots .c-dot {
    display: inline-block;
    margin: 0px 5px;
  }

  .c-dots .d-title {
    -ms-writing-mode: tb-rl;
        writing-mode: tb-rl;
    -webkit-writing-mode: tb-rl;
    writing-mode: tb-rl;
    display: block;
    right: inherit;
    top: inherit;
    left: inherit;
    right: 0.5rem;
    bottom: 0.2rem;
    position: absolute;
  }

  .box-red,
  .box-white {
    min-height: auto;
  }

  .headquarters {
    left: 0 !important;
    -webkit-transform: inherit !important;
            transform: inherit !important;
    min-width: auto;
    padding: 6rem;
    border: none;
    width: 100%;
    height: 100%;
    top: 0;
    text-align: left;
  }

  .box-red,
  .box-white {
    padding: 0.5rem;
    text-align: center;
  }

  #main-background {
    position: fixed;
  }

  #company-background .fullpage-layout .c-container h1 {
    font-size: 1.5rem;
    text-transform: uppercase;
    font-weight: bold;
  }

  #company-background .fullpage-layout .c-container h2 {
    font-size: 1.2rem;
  }

  #company-background .fullpage-layout .c-container p {
    font-size: 0.8rem;
  }
}

/* fix loading */
#loadOverlay {
  display: none;
}
