/* colori */
@import url("https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300..800;1,300..800&display=swap");
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box; }

html {
  font-size: 10px;
  scroll-behavior: smooth; }

body {
  font-family: "Open Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-variation-settings: "wdth" 100;
  color: #2d2d2d;
  background: #fff;
  font-size: 1.6rem;
  line-height: 2.4; }

hr {
  margin: 3rem auto; }

ul, ol, nav {
  list-style: none; }

h1, h2, h3, h4, h5 {
  font-family: 'Raleway', sans-serif;
  line-height: 1.2; }

a {
  text-decoration: none;
  color: #2d2d2d;
  transition: all .3s;
  cursor: pointer; }

button {
  border: none;
  cursor: pointer;
  font-family: "Open Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-variation-settings: "wdth" 100;
  background: transparent;
  transition: all .4s; }

input {
  font-family: "Open Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-variation-settings: "wdth" 100; }

textarea {
  font-family: "Open Sans", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-variation-settings: "wdth" 100;
  resize: vertical; }

.center {
  text-align: center; }

.container {
  width: 100%;
  max-width: 142rem;
  padding: 0 2%;
  margin: 0 auto; }

.hidden {
  opacity: 0; }

.visible {
  opacity: 1; }

.splide__arrow {
  position: absolute;
  z-index: 9;
  top: 50%; }
  .splide__arrow svg {
    fill: #fff; }

.splide__arrow--prev {
  left: 1%; }

.splide__arrow--next {
  right: 1%;
  translate: 0 -7px;
  rotate: 180deg; }

/* PER ANIMAZIONI!!! mantenere in tutti i file insieme a reveal.js - selezionare le animazioni a mano e copiarle nel file animation.css con classe .active davanti*/
.reveal {
  position: relative;
  opacity: 0; }
  .reveal.active {
    opacity: 1; }

/* form */
form {
  margin: 3rem 0 0; }
  form .flex {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    justify-content: space-between; }
    form .flex div[class^="box-"] {
      padding: 0;
      text-align: left;
      display: flex;
      align-items: center;
      margin: 0 0 1rem;
      flex-wrap: wrap;
      flex-direction: column-reverse; }
    form .flex .box-50 {
      width: 100%; }
      @media screen and (min-width: 769px) {
        form .flex .box-50 {
          width: 48%; } }
    form .flex .box-100 {
      width: 100%; }
  form label {
    width: 100%;
    font-size: 1.5rem;
    opacity: .8;
    display: block;
    margin: 0;
    font-weight: 400;
    color: #2d2d2d; }
    form label span {
      color: #eb6a56; }
  form .input__text {
    width: 100%;
    border: 1px solid rgba(150, 150, 150, 0.3);
    background-color: transparent;
    font-size: 1.6rem;
    padding: 1.5rem;
    color: #666666;
    background-color: #fff;
    border-color: #e1e1e1; }
    form .input__text:focus {
      outline: none; }
  form textarea.input__text {
    resize: vertical;
    min-height: 12rem; }

.txt-small {
  font-size: 1.2rem;
  margin: 1rem 0 0;
  color: #fff; }

.privacy h2, .privacy h3, .privacy h4, .privacy h5 {
  margin: 2.5rem 0 1rem; }

.privacy h2 {
  font-size: 3rem; }

.privacy h3, .privacy h4, .privacy h5 {
  font-size: 2rem; }

/*SITEMAP*/
ul.sitemap {
  margin: 5rem auto 10rem; }
  ul.sitemap li {
    font-size: 1.8rem;
    text-transform: uppercase;
    padding: 5px 0; }
    ul.sitemap li a {
      color: #2d2d2d; }
      ul.sitemap li a:hover {
        color: #fff; }
    ul.sitemap li .sublink {
      font-size: 1.6rem;
      padding: 0 0 0 3rem; }

.heartbeat {
  -webkit-animation: heartbeat 1.5s ease-in-out infinite both;
  animation: heartbeat 1.5s ease-in-out infinite both; }

@-webkit-keyframes heartbeat {
  from {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-transform-origin: center center;
    transform-origin: center center;
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; }
  10% {
    -webkit-transform: scale(0.91);
    transform: scale(0.91);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }
  17% {
    -webkit-transform: scale(0.98);
    transform: scale(0.98);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; }
  33% {
    -webkit-transform: scale(0.87);
    transform: scale(0.87);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }
  45% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; } }

@keyframes heartbeat {
  from {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-transform-origin: center center;
    transform-origin: center center;
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; }
  10% {
    -webkit-transform: scale(0.91);
    transform: scale(0.91);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }
  17% {
    -webkit-transform: scale(0.98);
    transform: scale(0.98);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; }
  33% {
    -webkit-transform: scale(0.87);
    transform: scale(0.87);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }
  45% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; } }

.active.fade-in {
  -webkit-animation: fade-in 1.2s cubic-bezier(0.39, 0.575, 0.565, 1) both;
  animation: fade-in 1.2s cubic-bezier(0.39, 0.575, 0.565, 1) both; }

.fade {
  -webkit-animation: fade-in 0.7s cubic-bezier(0.39, 0.575, 0.565, 1) both;
  animation: fade-in 0.7s cubic-bezier(0.39, 0.575, 0.565, 1) both; }

.active.fade-up {
  -webkit-animation: fade-up 0.6s cubic-bezier(0.39, 0.575, 0.565, 1) both;
  animation: fade-up 0.6s cubic-bezier(0.39, 0.575, 0.565, 1) both; }

.active.fade-left {
  -webkit-animation: fade-left 0.6s cubic-bezier(0.39, 0.575, 0.565, 1) both;
  animation: fade-left 0.6s cubic-bezier(0.39, 0.575, 0.565, 1) both; }

.bounce-in-fwd {
  -webkit-animation: bounce-in-fwd 1.1s both;
  animation: bounce-in-fwd 1.1s both; }

@-webkit-keyframes bounce-in-fwd {
  0% {
    -webkit-transform: scale(0);
    transform: scale(0);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0; }
  38% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
    opacity: 1; }
  55% {
    -webkit-transform: scale(0.7);
    transform: scale(0.7);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }
  72% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; }
  81% {
    -webkit-transform: scale(0.84);
    transform: scale(0.84);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }
  89% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; }
  95% {
    -webkit-transform: scale(0.95);
    transform: scale(0.95);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }
  100% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; } }

@keyframes bounce-in-fwd {
  0% {
    -webkit-transform: scale(0);
    transform: scale(0);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0; }
  38% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
    opacity: 1; }
  55% {
    -webkit-transform: scale(0.7);
    transform: scale(0.7);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }
  72% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; }
  81% {
    -webkit-transform: scale(0.84);
    transform: scale(0.84);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }
  89% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; }
  95% {
    -webkit-transform: scale(0.95);
    transform: scale(0.95);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in; }
  100% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out; } }

/* KEYFRAMES */
/* animation fade-in */
@-webkit-keyframes fade-in {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }

@keyframes fade-in {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }

/* animation fade-up */
@-webkit-keyframes fade-up {
  0% {
    -webkit-transform: translateY(50px);
    transform: translateY(50px);
    opacity: 0; }
  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    opacity: 1; } }

@keyframes fade-up {
  0% {
    -webkit-transform: translateY(50px);
    transform: translateY(50px);
    opacity: 0; }
  100% {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    opacity: 1; } }

/* fade-left */
@-webkit-keyframes fade-left {
  0% {
    -webkit-transform: translateX(-50px);
    transform: translateX(-50px);
    opacity: 0; }
  100% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    opacity: 1; } }

@keyframes fade-left {
  0% {
    -webkit-transform: translateX(-50px);
    transform: translateX(-50px);
    opacity: 0; }
  100% {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    opacity: 1; } }

.fascia_menu {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  padding: 2.5rem 0; }
  .fascia_menu .container {
    display: flex;
    align-items: center;
    justify-content: space-between; }
  .fascia_menu .logo {
    width: 15rem;
    height: 11.3rem;
    object-fit: contain;
    max-width: 100%; }
    @media screen and (max-width: 580px) {
      .fascia_menu .logo {
        width: 12rem;
        height: 9.3rem; } }
  .fascia_menu a.cta {
    display: block;
    padding: 0 0 0 4rem;
    height: 2.9rem;
    transition: all .2s; }
    @media screen and (max-width: 400px) {
      .fascia_menu a.cta {
        padding: 0 0 0 2rem; } }
    .fascia_menu a.cta:hover {
      translate: 0 -8px; }
    .fascia_menu a.cta img {
      width: 2.9rem;
      height: 2.9rem; }

nav.menu {
  width: calc(100% - 15rem); }
  nav.menu ul {
    display: flex;
    align-items: center;
    gap: 4rem;
    display: flex;
    justify-content: flex-end; }
    nav.menu ul li a {
      text-transform: uppercase;
      color: #fff;
      display: block; }
      nav.menu ul li a.active {
        font-weight: 600; }
      nav.menu ul li a:hover {
        translate: 0 -5px; }
  @media screen and (max-width: 1024px) {
    nav.menu {
      display: none; } }

/* dropdown */
.dropdown-content {
  z-index: 11;
  left: 0;
  width: auto;
  top: 100%;
  height: 0;
  overflow: hidden;
  transition: all 0.3s ease-in-out;
  opacity: 0;
  min-width: 30rem;
  position: absolute; }

.dropdown {
  display: inline-block;
  margin: 0;
  position: relative; }
  .dropdown:hover .dropdown-content {
    height: auto;
    margin: 0;
    opacity: 1; }

/* menu dropdown */
.menuresponsive {
  display: none; }
  @media screen and (max-width: 1024px) {
    .menuresponsive {
      display: flex;
      width: calc(100% - 15rem - 6.9rem);
      justify-content: flex-end;
      align-items: center; }
      .menuresponsive img {
        width: 4rem;
        height: 4rem;
        aspect-ratio: 1 / 1; } }
  @media screen and (max-width: 580px) {
    .menuresponsive {
      width: calc(100% - 12rem - 6.9rem); } }
  @media screen and (max-width: 400px) {
    .menuresponsive {
      width: calc(100% - 12rem - 4.9rem); } }

/* accordion */
ul.accordion {
  list-style: none;
  padding: 0;
  width: 100%;
  display: block; }
  ul.accordion a {
    width: 100%;
    display: block; }
  ul.accordion .mainbox {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center; }
    ul.accordion .mainbox a {
      width: auto;
      display: inline-block;
      margin: 0; }
      ul.accordion .mainbox a:hover {
        color: #D21113; }
  ul.accordion li .toggle {
    cursor: pointer;
    transition: all .3s ease;
    flex-grow: 2;
    opacity: 1 !important; }
    ul.accordion li .toggle img {
      width: 20px; }
  ul.accordion .inner {
    overflow: hidden;
    display: none; }

/* sidenav menu resp */
.sidenav {
  height: 100%;
  width: 0;
  position: fixed;
  z-index: 100;
  top: 0;
  overflow-x: hidden;
  transition: .5s;
  right: 0;
  overflow-y: scroll; }
  .sidenav .closebtn {
    position: absolute;
    top: 2rem;
    color: #2d2d2d;
    font-size: 2.6rem;
    background: #fff;
    border-radius: 5px;
    width: 2.5rem;
    height: 2.5rem;
    display: flex;
    justify-content: center;
    align-items: center;
    line-height: 1;
    right: 2rem;
    z-index: 9;
    background: transparent; }
  .sidenav .flexnav {
    display: flex;
    position: relative; }
    .sidenav .flexnav .bgcolor {
      position: fixed;
      background-color: rgba(33, 150, 243, 0.9);
      width: 20%;
      min-height: 100vh;
      transition-timing-function: cubic-bezier(1.28, 0.89, 0.32, 0.18);
      left: 0;
      top: 0;
      position: absolute;
      height: 100%; }
    .sidenav .flexnav .bgblack {
      background-color: #2d2d2d;
      min-height: 100vh;
      height: 100%;
      padding: 10rem 2rem;
      margin-left: 20%;
      width: 80%;
      padding: 3rem; }
      .sidenav .flexnav .bgblack a {
        font-size: 2.5rem;
        color: #fff;
        font-weight: 500;
        text-transform: uppercase; }
  .sidenav .logo-resp {
    margin: 0 0 2rem; }
    .sidenav .logo-resp img {
      width: 15rem;
      height: 15rem;
      object-fit: contain; }

#myBtn {
  opacity: 0;
  visibility: hidden;
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  z-index: 99;
  transition: all .3s;
  background: #2d2d2d;
  border-radius: 10rem;
  height: 3.5rem;
  width: 3.5rem;
  box-shadow: 0 0 1rem rgba(0, 0, 0, 0.5); }
  #myBtn img {
    width: 2.5rem;
    height: 2.5rem; }
  #myBtn.arrow-visible {
    opacity: 1;
    visibility: visible; }

.preheader {
  width: 100%;
  height: 4rem;
  background-color: #196f48; }

.header {
  width: 100%;
  height: auto;
  aspect-ratio: 336/83;
  object-fit: cover; }

.wrap_form {
  padding: 2.53807% 0;
  text-align: center; }
  .wrap_form .logo {
    width: 25.5rem;
    max-width: 100%;
    height: auto;
    aspect-ratio: 85/41;
    margin-bottom: 3%; }

.form_bg form {
  background-color: #f4f4f4;
  max-width: 70rem;
  margin: 5rem auto 0;
  width: 100%;
  padding: 8rem 2%;
  text-align: left; }
  @media screen and (min-width: 769px) {
    .form_bg form {
      padding: 8rem 6rem; } }
  .form_bg form .btn {
    background-color: #196f48;
    color: #fff;
    padding: 2rem 4rem;
    width: 100%;
    margin: 2rem auto 0; }

footer {
  margin: 5rem auto 0;
  background-color: #f4f4f4;
  padding: 7rem 0 0; }
  footer .flex {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    justify-content: center;
    gap: 4rem;
    margin: 0 auto 10rem; }
    footer .flex .bl {
      width: 100%;
      text-align: center;
      max-width: 35rem;
      background-color: #fff;
      padding: 6rem 2rem; }
      @media screen and (min-width: 769px) {
        footer .flex .bl {
          width: calc(33.3% - 2.66rem); } }
      footer .flex .bl .title {
        font-size: 2.4rem;
        color: #2d2d2d; }
      footer .flex .bl .line {
        margin: 1.5rem auto;
        height: 2px;
        width: 3rem;
        background-color: #41a85f; }
      footer .flex .bl p, footer .flex .bl a {
        color: #6a6a6a;
        font-size: 1.5rem;
        line-height: 1.8; }
      footer .flex .bl a:hover {
        color: #196f48; }
  footer .credits {
    padding: 2rem 2%;
    background-color: #196f48;
    text-align: center;
    text-transform: uppercase;
    color: #fff;
    line-height: 1.6em;
    font-size: 1.5rem; }
