@font-face {
  font-family: Optima;
  src: url('../fonts/OPTIMA.TTF') format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Optima;
  src: url('../fonts/OPTIMA_B.TTF') format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Optima;
  src: url('../fonts/Optima_Italic.ttf') format("truetype");
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}

@font-face {
  font-family: Optima;
  src: url('../fonts/Optima-Medium.ttf') format("truetype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Proximanova;
  src: url('../fonts/proximanova_black.ttf') format("truetype"), url('../fonts/proximanova_blackit.otf') format("opentype"), url('../fonts/proximanova_black.otf') format("opentype");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Proximanova;
  src: url('../fonts/proximanova_regular.ttf') format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Proximanova;
  src: url('../fonts/proximanova_light.otf') format("opentype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Proximanova;
  src: url('../fonts/proximanova_bold.otf') format("opentype"), url('../fonts/proximanova_extrabold.otf') format("opentype"), url('../fonts/proximanova_boldit.otf') format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

:root {
  --white: white;
  --f1white: #f1f1f1;
  --fakeblack: #393939;
  --milk: #f1f1e6;
  --orange: #f59432;
  --futurecyan: #00647c;
  --40-space: 40px;
  --64-space: 64px;
  --20-space: 20px;
  --10-space: 10px;
  --16-9: 56.25vw;
}

body {
  color: #333;
  font-family: Arial, Helvetica Neue, Helvetica, sans-serif;
  font-size: 14px;
  line-height: 20px;
}

.navbar-logo-center-container {
  z-index: 5;
  background-color: #0000;
  width: 1030px;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding: 20px;
}

.navbar-logo-center-container.shadow-three {
  width: 100%;
  height: 80px;
  margin-left: 0;
  margin-right: 0;
  padding: 0;
  display: flex;
}

.container {
  background-color: var(--white);
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
  display: flex;
  position: relative;
}

.container.center {
  justify-content: center;
  align-items: center;
}

.navbar-wrapper-three {
  justify-content: center;
  align-items: center;
  display: flex;
  position: relative;
}

.navbar-brand-three {
  z-index: 5;
  position: absolute;
}

.navbar-brand-three.w--current {
  position: relative;
}

.nav-menu-wrapper-three {
  justify-content: center;
  align-items: stretch;
  width: 100%;
  padding-left: 10px;
  padding-right: 10px;
  display: flex;
}

.nav-menu-three {
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0;
  display: flex;
}

.nav-menu-block {
  justify-content: center;
  align-items: center;
  margin-bottom: 0;
  display: flex;
}

.nav-link {
  color: #1a1b1f;
  letter-spacing: .25px;
  margin-left: 5px;
  margin-right: 5px;
  padding: 5px 10px;
  font-family: Anek Gujarati;
  font-size: 16px;
  line-height: 120%;
  text-decoration: none;
}

.nav-link:hover {
  color: #1a1b1fbf;
}

.nav-link:focus-visible, .nav-link[data-wf-focus-visible] {
  outline-offset: 0px;
  color: #0050bd;
  border-radius: 4px;
  outline: 2px solid #0050bd;
}

.pagewrapper {
  width: 100%;
  height: calc(100vh - 80px);
  display: flex;
}

.pagewrapper.ipad {
  flex-flow: column;
  max-width: 991px;
  margin-left: auto;
  margin-right: auto;
  display: none;
  position: relative;
}

.domuscolumn {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  flex-flow: column;
  justify-content: center;
  align-items: flex-end;
  width: 50%;
  height: 100%;
  display: flex;
  position: relative;
  overflow: hidden;
}

.futuracolumn {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  width: 50%;
  height: 100%;
  display: flex;
  position: relative;
  overflow: hidden;
}

.linkhero {
  z-index: 0;
  text-underline-offset: 5px;
  font-family: Anek Gujarati;
  font-size: 16px;
  line-height: 120%;
  text-decoration: underline;
  position: absolute;
}

.linkhero.white {
  color: var(--white);
  display: none;
}

.paragrafohero {
  width: 100%;
  max-width: 520px;
  height: 0;
  margin-bottom: 20px;
  font-family: Proximanova, Arial, sans-serif;
  font-size: 16px;
  line-height: 120%;
  display: flex;
}

.paragrafohero.white {
  color: var(--white);
  flex-flow: column;
  height: 0;
  display: flex;
  overflow: hidden;
}

.paragrafohero.right {
  text-align: right;
  flex-flow: column;
  display: flex;
  overflow: hidden;
}

.sottotitolohero {
  color: var(--fakeblack);
  text-align: right;
  max-width: 25ch;
  font-family: Proximanova, Arial, sans-serif;
  font-size: 28px;
  font-weight: 700;
  line-height: 120%;
}

.sottotitolohero.white {
  color: var(--f1white);
  text-align: left;
  max-width: 30ch;
}

.sottotitolohero.none {
  display: none;
}

.titolohero {
  color: var(--fakeblack);
  margin-top: -32px;
  margin-bottom: 0;
  font-family: Optima, Arial, sans-serif;
  font-size: 100px;
  font-weight: 700;
  line-height: 100%;
}

.titolohero.white {
  color: var(--white);
}

.titolohero.none {
  display: none;
}

.wrapperhero {
  z-index: 3;
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  min-width: 500px;
  height: 65%;
  padding-left: 32px;
  transition: all .2s;
  display: flex;
  position: relative;
}

.wrapperhero.left {
  justify-content: center;
  align-items: flex-end;
  padding-left: 0;
  padding-right: 32px;
}

.image {
  height: 65px;
}

.buttonhero {
  z-index: 1;
  background-color: var(--fakeblack);
  color: #004960;
  text-align: center;
  border-radius: 5px;
  justify-content: center;
  align-items: center;
  width: 250px;
  height: 45px;
  min-height: 45px;
  padding-left: 10px;
  padding-right: 10px;
  font-family: Anek Gujarati;
  font-size: 16px;
  font-weight: 700;
  display: flex;
  position: absolute;
}

.buttonhero.milk {
  background-color: var(--white);
  border-radius: 5px;
}

.buttonhero.milk.alto {
  z-index: 8;
  display: none;
  inset: 20px auto 0 20px;
}

.buttonhero.indietro {
  z-index: 8;
  background-color: var(--fakeblack);
  display: none;
  top: 20px;
  bottom: 0;
  right: 20px;
}

.wrapperbutton {
  width: 100%;
  height: 45px;
  margin-top: 20px;
  position: relative;
}

.wrapperbutton.right {
  justify-content: flex-end;
  align-items: stretch;
  display: flex;
}

.arrowbutton {
  cursor: pointer;
  width: 32px;
  height: 32px;
  display: none;
}

.arrowbutton.mosaico {
  z-index: 1;
  display: flex;
  position: absolute;
  inset: 20px 20px 0 auto;
}

.arrowbutton.mosaico.domus {
  transform-style: preserve-3d;
  inset: 20px auto auto 20px;
  transform: rotateX(0)rotateY(180deg)rotateZ(0);
}

.textbutton {
  font-family: Proximanova, Arial, sans-serif;
}

.textbutton.indietro {
  color: var(--white);
}

.futuramosaico {
  z-index: 10;
  background-image: linear-gradient(90deg, #10313ba6, #16292fa6);
  width: 100%;
  height: 100%;
  display: none;
  position: relative;
}

.wrappermosaico {
  z-index: 0;
  background-image: none;
  flex-flow: column;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  height: 100%;
  display: flex;
  position: relative;
}

.casellamosaico {
  z-index: 0;
  border: 1px solid var(--f1white);
  color: var(--white);
  cursor: pointer;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  text-decoration: none;
  display: flex;
  position: relative;
}

.casellamosaico:hover {
  -webkit-backdrop-filter: blur(3px);
  backdrop-filter: blur(3px);
  text-underline-offset: 5px;
  background-color: #1c1c1c33;
  text-decoration: underline;
}

.casellamosaico.fakeblack {
  color: var(--white);
  font-family: Optima, Arial, sans-serif;
}

.titolomosaico {
  z-index: 1;
  text-align: center;
  font-size: 20px;
  line-height: 120%;
  position: relative;
}

.rowmosaicofutura {
  color: var(--f1white);
  flex-flow: row;
  width: 100%;
  height: 100%;
  font-family: Inter;
  font-weight: 700;
  display: flex;
}

.rowmosaicofutura.fakeblack {
  font-family: Inter;
  font-weight: 700;
}

.domusmosaico {
  background-image: linear-gradient(90deg, #b2804ccc, #c9a58066);
  width: 100%;
  height: 100%;
  display: none;
  position: relative;
}

.domusmosaicoipad, .futuramosaicoipad {
  width: 100%;
  height: 100%;
  display: none;
  position: relative;
  overflow: hidden;
}

.futuracolumn-ipad {
  z-index: 2;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  height: 50%;
  padding: 10px;
  display: flex;
  position: relative;
}

.domuscolumn-ipad {
  z-index: 2;
  flex-flow: row;
  justify-content: center;
  align-items: flex-end;
  width: 100%;
  height: 50%;
  padding: 10px 20px;
  font-family: Inter;
  display: flex;
  position: relative;
}

.wrapperhero-ipad {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  display: flex;
}

.wrapperbutton-ipad {
  justify-content: center;
  align-items: stretch;
  width: 100%;
  height: 45px;
  display: flex;
  position: relative;
}

.buttonhero-ipad {
  display: none;
}

.buttonhero-ipad.milk {
  background-color: var(--milk);
  width: 250px;
  height: 45px;
}

.buttonhero-ipad.orange {
  background-color: var(--orange);
  width: 250px;
  height: 45px;
  display: none;
}

.titolohero-ipad {
  color: var(--fakeblack);
  text-align: center;
  font-family: Inter;
  font-size: 40px;
  font-weight: 800;
  line-height: 100%;
}

.titolohero-ipad.white {
  color: var(--f1white);
  text-align: center;
  line-height: 100%;
}

.paragrafohero-ipad {
  color: var(--f1white);
  text-align: center;
  width: 100%;
  max-width: 520px;
  height: 1px;
  font-family: Inter;
  overflow: hidden;
}

.arrowbutton-ipad {
  z-index: 1;
  color: var(--fakeblack);
  width: 28px;
  height: 28px;
  position: absolute;
  top: 20px;
  right: 20px;
}

.arrowbutton-ipad.white {
  color: var(--f1white);
}

.wrappermosaico-ipad {
  z-index: 0;
  flex-flow: column;
  width: 100%;
  height: 100%;
  display: flex;
  position: relative;
}

.casellamosaico-ipad {
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  display: flex;
  position: relative;
}

.rowmosaicofutura-ipad {
  z-index: 0;
  flex-flow: row;
  width: 100%;
  height: 100%;
  display: flex;
}

.titolomosaico-ipad {
  z-index: 1;
  color: var(--fakeblack);
  text-align: center;
  font-family: Inter;
  font-size: 18px;
  font-weight: 600;
  line-height: 120%;
  position: relative;
}

.titolomosaico-ipad.white {
  color: var(--f1white);
}

.rowmosaicodomus-ipad {
  width: 100%;
  height: 100%;
  display: flex;
}

.buttonservizi {
  background-color: var(--orange);
  color: var(--fakeblack);
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 250px;
  height: 45px;
  min-height: 45px;
  font-family: Anek Gujarati;
  display: flex;
}

.buttonservizi:hover {
  border: 1px solid var(--orange);
  background-color: var(--milk);
  color: var(--orange);
  font-weight: 500;
}

.buttonservizi.futura {
  border: 1px solid var(--futurecyan);
  background-color: var(--futurecyan);
  color: var(--f1white);
}

.buttonservizi.futura:hover {
  background-color: var(--milk);
  color: var(--futurecyan);
  border-width: 1px;
  font-weight: 600;
}

.bold {
  color: var(--fakeblack);
  font-family: Anek Gujarati;
  font-weight: 600;
}

.wrapperfasciaprogetto {
  grid-column-gap: 32px;
  grid-row-gap: 32px;
  width: 100%;
  max-width: 1800px;
  height: 100%;
  padding-left: 32px;
  padding-right: 32px;
  display: flex;
}

.wrapperimagefasciaprogetto {
  width: 50%;
}

.wrappertestofasciaprogetto {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  width: 50%;
  display: flex;
}

.titolofasciaprogetto {
  font-family: Inter;
  font-size: 30px;
  font-weight: 500;
  line-height: 120%;
}

.descrizionefasciaprogetto {
  font-family: Anek Gujarati;
  font-size: 16px;
  font-weight: 400;
  line-height: 120%;
}

.descrizionefasciaprogetto.bold {
  font-size: 18px;
  font-weight: 600;
}

.prezzofasciaprogetto {
  letter-spacing: 2px;
  font-family: Anek Gujarati;
  font-size: 16px;
  line-height: 120%;
}

.sliderprogetti {
  background-color: #0000;
  border-radius: 20px;
  width: 50%;
  height: 100%;
  overflow: clip;
}

.slidefasceprogetto {
  width: 100%;
  height: 100%;
}

.immaginefasceprogetto {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.iconafasciaprogetto {
  color: var(--orange);
  width: 49px;
  height: 49px;
}

.iconafasciaprogetto.futura {
  color: var(--futurecyan);
}

.right-arrow-fasciaprogetto, .left-arrow-fasciaprogetto {
  justify-content: center;
  align-items: center;
  display: flex;
}

.utility-page-wrap {
  justify-content: center;
  align-items: center;
  width: 100vw;
  max-width: 100%;
  height: 100vh;
  max-height: 100%;
  display: flex;
}

.utility-page-content {
  text-align: center;
  flex-direction: column;
  width: 260px;
  display: flex;
}

.utility-page-form {
  flex-direction: column;
  align-items: stretch;
  display: flex;
}

.bold-text {
  font-weight: 400;
}

.cookie-titolo {
  color: var(--futurecyan);
  font-size: 28px;
  font-weight: 400;
  line-height: 42px;
}

.cookie-text {
  color: var(--fakeblack);
  font-family: Lato, sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 21px;
}

.cookie {
  background-color: var(--f1white);
}

.cookie-sezione {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  flex-flow: column;
  display: flex;
}

.wrapper-cookie {
  grid-column-gap: 29px;
  grid-row-gap: 29px;
  flex-flow: column;
  padding: 58px;
  display: flex;
}

.titolo-tabella {
  background-color: var(--futurecyan);
}

.cookie-text-2 {
  color: var(--fakeblack);
  font-family: Lato, sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 21px;
}

.ul {
  grid-column-gap: 5px;
  grid-row-gap: 5px;
  flex-flow: column;
  display: flex;
}

.cookie-sottotitolo {
  color: var(--fakeblack);
  font-family: Lato, sans-serif;
  font-size: 18px;
  font-weight: 700;
  line-height: 27px;
}

.cookie-sottotitolo.tabella {
  color: #fff;
}

.cookie-titolo-2 {
  color: var(--futurecyan);
  font-size: 28px;
  font-weight: 700;
  line-height: 42px;
}

.td {
  border: 1px solid #000;
  width: auto;
  height: 40px;
  padding-left: 20px;
}

.cookie-titolo-3 {
  color: var(--futurecyan);
  font-size: 28px;
  font-weight: 700;
  line-height: 42px;
}

.bold-text-9 {
  color: var(--futurecyan);
}

.cookie-text-3 {
  color: var(--fakeblack);
  font-family: Lato, sans-serif;
  font-size: 14px;
  font-weight: 400;
  line-height: 21px;
}

.cookie-sottotitolo-2 {
  color: #3f3432;
  font-size: 18px;
  font-weight: 700;
  line-height: 27px;
}

.bold-text-8 {
  color: var(--futurecyan);
}

.image-change {
  opacity: 0;
  object-fit: cover;
  width: 100%;
  height: 100%;
  display: none;
  position: absolute;
  inset: 0%;
}

.image-2 {
  z-index: 1;
  object-fit: cover;
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
}

.opacity {
  z-index: 2;
  background-image: linear-gradient(90deg, #00496080, #00496080);
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0;
}

.opacity.orange {
  background-image: linear-gradient(90deg, #ffebd766, #fff);
}

.wrapper-page {
  grid-column-gap: 0px;
  grid-row-gap: 0px;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  display: flex;
}

.s-image-text-start {
  width: 100%;
}

.c-image-start {
  width: 100%;
  height: 85vh;
  position: sticky;
  top: 0;
}

.image-start {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.c-text-start {
  grid-column-gap: 50px;
  grid-row-gap: 50px;
  background-color: var(--white);
  border-top-left-radius: 100px;
  border-top-right-radius: 100px;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  margin-top: -80px;
  display: flex;
  position: relative;
  overflow: clip;
}

.text-page {
  text-align: center;
  font-family: Proximanova, Arial, sans-serif;
  font-size: 16px;
  font-weight: 700;
  line-height: 100%;
}

.sottotitle-page {
  color: var(--white);
  text-align: center;
  font-family: Optima, Arial, sans-serif;
  font-size: 40px;
  font-weight: 700;
  line-height: 100%;
}

.body {
  font-size: 24px;
}

.text-section {
  text-align: left;
  max-width: 20ch;
  font-family: Optima, Arial, sans-serif;
  font-size: 40px;
  font-weight: 700;
  line-height: 100%;
}

.text-section.white {
  color: var(--white);
}

.text-section.orange {
  color: #ffd89b;
}

.text-description {
  text-align: left;
  font-family: Proximanova, Arial, sans-serif;
  font-size: 16px;
  line-height: 150%;
}

.text-description.white {
  color: var(--white);
}

.text-center {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  max-width: 550px;
  display: flex;
}

.text-center-box {
  justify-content: center;
  align-items: center;
  width: 50%;
  display: flex;
}

.text-center-box.left {
  justify-content: flex-start;
  align-items: center;
  width: 40%;
}

.imege-box {
  object-fit: cover;
  border-radius: 20px;
  width: 50%;
}

.button-template-3 {
  background-color: var(--fakeblack);
  color: var(--white);
  text-align: center;
  white-space: nowrap;
  border-radius: 10px;
  justify-content: center;
  align-items: center;
  width: 100%;
  min-width: 250px;
  max-width: 250px;
  height: 45px;
  max-height: 45px;
  font-family: Proximanova, Arial, sans-serif;
  font-size: 16px;
  font-weight: 700;
  display: flex;
}

.button-template-3.futura {
  background-color: var(--white);
  color: var(--futurecyan);
}

.button-template-3.blu {
  background-color: var(--futurecyan);
}

.button-template-3.grigio {
  background-color: #9a9a9a;
}

.c-text-image-template-3 {
  justify-content: center;
  align-items: stretch;
  width: 100%;
  max-width: 1800px;
  height: 60vh;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
  display: flex;
  position: sticky;
  top: 0;
}

.c-text-image-template-3.little {
  height: 50vh;
}

.c-text-image-template-3.bg {
  background-color: var(--white);
  padding-top: 50px;
  padding-bottom: 50px;
}

.s-text-image {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  background-color: #ffd89b;
  flex-flow: column;
  justify-content: center;
  align-items: stretch;
  width: 100%;
  padding-top: 50px;
  display: flex;
}

.s-text-image.no-orange {
  background-color: var(--white);
}

.s-text-image.no-orange.bottom {
  justify-content: center;
  align-items: stretch;
  padding-bottom: 50px;
}

.s-text-image.grey {
  background-color: #f2f2f2;
  background-image: none;
}

.s-text-image.futura {
  background-color: var(--futurecyan);
}

.s-text-image.futura.bordo, .s-text-image.bottom {
  padding-bottom: 50px;
}

.c-bg-image-text {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100vh;
  display: flex;
  position: relative;
}

.image-sovrapposta {
  object-fit: cover;
  object-position: 50% 0%;
  border-top-left-radius: 100px;
  border-top-right-radius: 100px;
  width: 100%;
  height: 100%;
}

.c-text-absolute {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  border: 1px solid var(--white);
  background-color: #494949b3;
  border-radius: 20px;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 700px;
  height: 100%;
  max-height: 300px;
  padding-left: 40px;
  padding-right: 40px;
  display: flex;
  position: absolute;
}

.c-text-absolute.form {
  grid-column-gap: 35px;
  grid-row-gap: 35px;
  max-height: 700px;
}

.c-text-absolute.form.white {
  background-color: #ffffffb3;
}

.title-absolute {
  color: #ffd89b;
  text-align: center;
  font-family: Optima, Arial, sans-serif;
  font-size: 40px;
  font-weight: 700;
  line-height: 100%;
  text-decoration: underline;
}

.title-absolute.white {
  color: var(--white);
}

.title-absolute.futura {
  color: var(--futurecyan);
}

.text-absolute {
  color: var(--white);
  text-align: center;
  font-family: Proximanova, Arial, sans-serif;
  font-size: 16px;
  line-height: 150%;
}

.track {
  width: 80vw;
  height: 50vh;
  display: flex;
  position: relative;
  overflow: hidden;
}

.camera {
  flex-flow: row;
  width: 80vw;
  height: 50vh;
  position: sticky;
  top: 0;
}

.frame {
  grid-column-gap: 50px;
  grid-row-gap: 50px;
  width: 100%;
  height: 100%;
  display: flex;
  position: relative;
}

.item {
  grid-column-gap: 50px;
  grid-row-gap: 50px;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  height: 100%;
  padding-top: 50px;
  padding-bottom: 50px;
  display: flex;
}

.text-sticky {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  text-align: center;
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  width: 30vw;
  min-width: 300px;
  max-width: 550px;
  padding: 30px;
  display: flex;
  position: sticky;
  left: 0;
}

.card-importanti {
  aspect-ratio: 16 / 9;
  border-radius: 20px;
  flex: none;
  width: 50vw;
  max-width: 700px;
  max-height: 40vh;
  position: relative;
  overflow: clip;
}

.image-card {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.description-card {
  background-color: var(--white);
  border: 1px solid #000;
  border-bottom-right-radius: 20px;
  border-bottom-left-radius: 20px;
  justify-content: flex-start;
  align-items: center;
  min-height: 70px;
  max-height: 70px;
  padding-left: 20px;
  display: flex;
  position: absolute;
  inset: auto 0% 0%;
}

.text-card {
  font-family: Optima, Arial, sans-serif;
  font-size: 16px;
  font-weight: 700;
  line-height: 100%;
}

.wrapper-floating-text {
  display: flex;
  position: sticky;
  top: 0;
}

.s-text-image-mobile {
  display: none;
}

.slider {
  flex-flow: row;
  width: 100%;
  display: flex;
}

.slider-item {
  text-align: center;
  object-fit: cover;
  border-radius: 10px;
  width: 100%;
  max-width: 450px;
  height: 100%;
  margin-right: 7px;
  font-weight: 900;
  position: relative;
  overflow: clip;
}

.slider-item.big {
  max-width: 600px;
}

.img-slider {
  z-index: 1;
  aspect-ratio: 3 / 2;
  object-fit: cover;
  width: 100%;
  position: relative;
}

.text-slide {
  z-index: 2;
  border: 1px solid var(--fakeblack);
  background-color: var(--white);
  border-bottom-right-radius: 10px;
  border-bottom-left-radius: 10px;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 75px;
  min-height: 75px;
  max-height: 75px;
  display: flex;
  position: absolute;
  inset: auto 0 0;
}

.s-tabella {
  width: 100%;
  margin-top: 100px;
}

.c-tabella {
  flex-flow: column;
  justify-content: center;
  align-items: stretch;
  max-width: 1800px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 20px;
  padding-right: 20px;
  display: flex;
}

.facia-tabella {
  grid-column-gap: 30px;
  grid-row-gap: 30px;
  border-bottom: 1px solid #000;
  justify-content: flex-start;
  align-items: flex-end;
  padding-top: 30px;
  padding-bottom: 30px;
  display: flex;
}

.text-tabella {
  font-family: Proximanova, Arial, sans-serif;
  font-size: 16px;
}

.text-tabella.bold {
  width: 30%;
  min-width: 200px;
  font-family: Optima, Arial, sans-serif;
  font-size: 18px;
  font-weight: 700;
}

.c-name {
  grid-column-gap: 35px;
  grid-row-gap: 35px;
  flex-flow: column;
  width: 35%;
  margin-left: auto;
  margin-right: auto;
  display: flex;
}

.decor-name {
  border: 1px solid var(--fakeblack);
  border-radius: 10px;
  justify-content: flex-start;
  align-items: center;
  width: 100%;
  min-width: 250px;
  max-width: 230px;
  height: 60px;
  min-height: 60px;
  max-height: 60px;
  padding-left: 15px;
  padding-right: 15px;
  display: flex;
}

.decor-name.domus {
  border-color: #ffd89b;
  box-shadow: 0 0 7px 2px #ffd89b;
}

.title-tab {
  color: var(--fakeblack);
  font-family: Proximanova, Arial, sans-serif;
  font-size: 18px;
  font-weight: 700;
}

.accordion-wrapper {
  display: none;
}

.s-card {
  width: 100%;
  margin-top: 100px;
  overflow: clip;
}

.c-card {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  padding-left: 20px;
  padding-right: 20px;
  display: flex;
}

.icon-text {
  grid-column-gap: 15px;
  grid-row-gap: 15px;
  width: 100%;
  display: flex;
}

.title-card {
  text-align: center;
  max-width: 40ch;
  margin-left: auto;
  margin-right: auto;
  padding-bottom: 60px;
  font-family: Optima, Arial, sans-serif;
  font-size: 40px;
  font-weight: 700;
  line-height: 100%;
}

.wrapper-card {
  grid-column-gap: 40px;
  grid-row-gap: 40px;
  justify-content: center;
  align-items: center;
  display: flex;
}

.card {
  border: 1px solid var(--fakeblack);
  border-radius: 10px;
  width: 50%;
  max-width: 650px;
  height: 100%;
  max-height: 655px;
  overflow: clip;
}

.text-button {
  grid-column-gap: 35px;
  grid-row-gap: 35px;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  padding: 40px;
  font-weight: 700;
  display: flex;
}

.imag-card {
  object-fit: cover;
  width: 100%;
  height: 420px;
}

.title-card-big {
  text-align: center;
  font-family: Optima, Arial, sans-serif;
  font-size: 24px;
  font-weight: 700;
}

.subtitle-card {
  text-align: center;
  font-family: Optima, Arial, sans-serif;
  font-size: 16px;
}

.footer-1 {
  background-color: var(--fakeblack);
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-top: 100px;
  display: flex;
}

.footer-1.no-padding, .footer-1.nopad {
  margin-top: 0;
}

.wrapper-footer-1 {
  grid-column-gap: 45px;
  grid-row-gap: 45px;
  flex-flow: column;
  width: 100%;
  max-width: 1800px;
  padding: 60px 20px;
  display: flex;
}

.text-footer {
  color: var(--white);
  max-width: 26ch;
  font-family: Optima, Arial, sans-serif;
  font-size: 82px;
  font-weight: 700;
  line-height: 120%;
}

.striscia-footer {
  justify-content: space-between;
  align-items: stretch;
  width: 100%;
  display: flex;
}

.striscia-footer.padding {
  padding-top: 20px;
  padding-bottom: 20px;
}

.striscia-footer.linea {
  border-top: 1px solid var(--white);
  justify-content: center;
  align-items: center;
}

.inf-contatti {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  flex-flow: column;
  width: 70%;
  display: flex;
}

.inf-contatti.little {
  width: 30%;
}

.button-contattaci {
  border: 1px solid var(--white);
  background-color: var(--fakeblack);
  border-radius: 10px;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 250px;
  height: 45px;
  min-height: 45px;
  max-height: 45px;
  font-family: Proximanova, Arial, sans-serif;
  font-size: 18px;
  font-weight: 400;
  display: flex;
}

.title-navigatore {
  color: var(--white);
  font-family: Proximanova, Arial, sans-serif;
  font-size: 32px;
  font-weight: 700;
  line-height: 100%;
  text-decoration: none;
}

.text-navigatore {
  color: var(--white);
  font-family: Proximanova, Arial, sans-serif;
  font-size: 32px;
  font-weight: 300;
  line-height: 100%;
  text-decoration: none;
}

.contatti-struttura {
  color: var(--white);
  font-family: Proximanova, Arial, sans-serif;
  font-size: 18px;
  font-weight: 400;
  line-height: 130%;
}

.text-domus {
  object-fit: contain;
  width: 100%;
}

.c-cookie {
  grid-column-gap: 80px;
  grid-row-gap: 80px;
  width: 100%;
  max-width: 1800px;
  padding: 40px 20px;
  display: flex;
}

.text-cookie {
  color: var(--white);
  font-family: Proximanova, Arial, sans-serif;
  font-size: 16px;
}

.logo-footer {
  max-width: 75px;
}

.button {
  color: var(--fakeblack);
  background-color: #3898ec00;
  margin-left: auto;
  font-family: Optima, Arial, sans-serif;
  font-size: 16px;
  font-weight: 700;
}

.fascia-nera {
  background-color: var(--fakeblack);
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  padding-top: 25px;
  padding-bottom: 25px;
  display: flex;
}

.custom-dots {
  text-align: center;
  justify-content: center;
  align-items: center;
  display: flex;
}

.slider-dots {
  flex-flow: column;
  justify-content: center;
  align-items: stretch;
  width: 60%;
  margin-top: auto;
  margin-bottom: auto;
  display: flex;
  position: relative;
}

.slide {
  background-color: var(--futurecyan);
}

.input {
  color: #393939;
  background-color: #fff;
  border: 1px solid #393939;
  border-radius: 10px;
  width: 100%;
  height: 41px;
  padding-left: 16px;
  padding-right: 16px;
  font-family: Proximanova, Arial, sans-serif;
  font-weight: 400;
  line-height: 120%;
}

.input.message {
  height: 100vh;
  max-height: 150px;
  padding-top: 8px;
  font-family: Proximanova, Arial, sans-serif;
}

.checkbox-field {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
  margin-top: 0;
  margin-bottom: 0;
  display: flex;
}

.inputform {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  grid-template-rows: auto;
  grid-template-columns: 100px 1fr;
  grid-auto-columns: 1fr;
  justify-content: space-between;
  place-items: end center;
  display: flex;
}

.buttonservizi-2 {
  color: #393939;
  background-image: linear-gradient(90deg, #ffd89b, #fffbf4);
  border-radius: 10px;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 250px;
  height: 45px;
  min-height: 45px;
  font-family: Proximanova, Arial, sans-serif;
  font-weight: 400;
  display: flex;
}

.buttonservizi-2:hover {
  color: var(--fakeblack);
  background-color: #f1f1e6;
  background-image: none;
  border: 1px solid #f59432;
  font-weight: 500;
}

.buttonservizi-2.futura {
  background-image: linear-gradient(90deg, #00647c, #fff);
}

.buttonservizi-2.futura:hover {
  border-color: var(--white);
  background-image: none;
}

.wrapperfrom {
  grid-column-gap: 32px;
  grid-row-gap: 32px;
  flex-flow: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  display: flex;
}

.form {
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  flex-direction: column;
  grid-template-rows: auto auto auto auto auto auto auto;
  grid-template-columns: 1fr;
  grid-auto-columns: 1fr;
  justify-content: center;
  align-items: stretch;
  width: 100%;
  display: flex;
}

.checkbox {
  border: 1px solid #000;
}

.linkformativa {
  color: var(--white);
  text-decoration: underline;
}

.titoloform {
  color: #393939;
  font-size: 30px;
  font-weight: 500;
  line-height: 120%;
}

.checkbox-label {
  color: var(--white);
  font-family: Proximanova, Arial, sans-serif;
  line-height: 120%;
}

.buttonservizi-3 {
  color: #393939;
  background-color: #f59432;
  justify-content: center;
  align-items: center;
  width: 100%;
  max-width: 250px;
  height: 45px;
  min-height: 45px;
  display: flex;
}

.buttonservizi-3:hover {
  color: #f59432;
  background-color: #f1f1e6;
  border: 1px solid #f59432;
  font-weight: 500;
}

.iconafasciaprogetto-2 {
  color: #ffd89b;
  -webkit-text-stroke-color: #ffd89b;
  width: 49px;
  height: 49px;
}

.titolofasciaprogetto-2 {
  font-size: 30px;
  font-weight: 500;
  line-height: 120%;
}

.descrizionefasciaprogetto-2 {
  font-size: 16px;
  font-weight: 400;
  line-height: 120%;
}

.descrizionefasciaprogetto-2.bold {
  font-size: 18px;
  font-weight: 600;
}

.prezzofasciaprogetto-2 {
  letter-spacing: 2px;
  font-size: 16px;
  line-height: 120%;
}

.container-button {
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  width: 100%;
  display: flex;
}

.loading-screen {
  z-index: 2000;
  grid-column-gap: 16px;
  grid-row-gap: 16px;
  opacity: 1;
  background-color: #fff;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  display: none;
  position: fixed;
}

.loaderlogo {
  filter: invert(0%);
  width: 100px;
  height: 100px;
  position: absolute;
}

.loader {
  mix-blend-mode: screen;
  background-color: #fff0;
  width: 100px;
  display: block;
  position: relative;
}

.title-composto {
  grid-column-gap: 25px;
  grid-row-gap: 25px;
  display: flex;
}

.inline-gallery-container {
  z-index: 999;
  grid-column-gap: 36px;
  grid-row-gap: 36px;
  background-color: #b09373;
  flex-direction: column;
  grid-template-rows: auto auto;
  grid-template-columns: 1fr 1fr;
  grid-auto-columns: 1fr;
  width: 100%;
  height: 100%;
  display: none;
  position: fixed;
  inset: 0;
}

.button-gallery {
  background-color: var(--fakeblack);
  border-radius: 10px;
  justify-content: center;
  align-items: center;
  width: 100%;
  min-width: 250px;
  max-width: 250px;
  height: 45px;
  display: flex;
}

.text-button-gallery {
  color: var(--white);
  text-align: center;
  font-family: Proximanova, Arial, sans-serif;
  font-size: 16px;
  font-weight: 700;
}

.heading {
  font-family: Optima, Arial, sans-serif;
}

.text-block {
  font-family: Proximanova, Arial, sans-serif;
}

@media screen and (max-width: 991px) {
  body {
    --40-space: 20px;
    --64-space: 32px;
    --20-space: 20px;
    --10-space: 10px;
  }

  .navbar-wrapper-three {
    justify-content: space-between;
    align-items: center;
  }

  .navbar-brand-three {
    position: relative;
  }

  .navbar-brand-three.w--current {
    left: 0;
  }

  .nav-menu-wrapper-three {
    background-color: #0000;
    top: 70px;
  }

  .nav-menu-three {
    background-color: var(--f1white);
    border-radius: 10px;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    margin-top: 10px;
    padding: 20px;
    display: flex;
    box-shadow: 0 8px 50px #0000000d;
  }

  .nav-menu-block {
    padding-left: 0;
  }

  .nav-link {
    padding-left: 5px;
    padding-right: 5px;
  }

  .menu-button {
    padding: 12px;
  }

  .menu-button.w--open {
    color: #fff;
    background-color: #004259;
    border-radius: 10px;
  }

  .pagewrapper.pc {
    display: none;
  }

  .pagewrapper.ipad {
    background-position: 25%;
    flex-flow: column;
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
    display: flex;
  }

  .linkhero.white {
    background-color: var(--white);
    color: #393939;
    border-radius: 5px;
    justify-content: center;
    align-items: center;
    width: 150px;
    height: 45px;
    font-family: Proximanova, Arial, sans-serif;
    font-weight: 700;
    text-decoration: none;
    display: flex;
  }

  .linkhero.white.black {
    color: var(--white);
    background-color: #39393900;
    justify-content: center;
    align-items: center;
    font-family: Proximanova, Arial, sans-serif;
  }

  .linkhero.white.black.singolo {
    color: var(--fakeblack);
    justify-content: flex-start;
    align-items: center;
  }

  .linkhero.white.singolo {
    color: var(--white);
    background-color: #fff0;
    justify-content: flex-start;
    align-items: center;
  }

  .sottotitolohero.white {
    text-align: center;
    font-size: 22px;
  }

  .sottotitolohero.white.black {
    color: var(--fakeblack);
    text-align: center;
  }

  .sottotitolohero.white.black.left {
    text-align: left;
  }

  .sottotitolohero.white.right {
    text-align: right;
  }

  .domusmosaico {
    background-image: linear-gradient(90deg, #b2804ccc, #c9a58066);
  }

  .domusmosaicoipad {
    background-image: linear-gradient(90deg, #ffebd766, #fff);
    display: none;
  }

  .futuramosaicoipad {
    background-image: linear-gradient(90deg, #478598, #00496080);
    display: none;
  }

  .futuracolumn-ipad, .domuscolumn-ipad {
    justify-content: center;
    align-items: center;
    display: flex;
  }

  .wrapperhero-ipad {
    z-index: 3;
    position: relative;
  }

  .wrapperhero-ipad.left {
    justify-content: center;
    align-items: flex-start;
  }

  .wrapperhero-ipad.right {
    justify-content: center;
    align-items: flex-end;
  }

  .wrapperbutton-ipad.left {
    justify-content: flex-start;
    align-items: stretch;
  }

  .wrapperbutton-ipad.right {
    justify-content: flex-end;
    align-items: stretch;
  }

  .buttonhero-ipad {
    z-index: 1;
    justify-content: center;
    align-items: center;
    width: 250px;
    height: 45px;
    font-family: Anek Gujarati;
    display: none;
    position: absolute;
  }

  .buttonhero-ipad.milk {
    background-color: var(--white);
    color: var(--fakeblack);
    -webkit-text-stroke-color: var(--white);
    border-radius: 5px;
    font-size: 16px;
    font-weight: 700;
    display: none;
  }

  .buttonhero-ipad.milk.black {
    background-color: var(--fakeblack);
    color: var(--white);
  }

  .buttonhero-ipad.orange {
    background-color: var(--fakeblack);
    color: var(--white);
    border-radius: 5px;
    width: 200px;
    font-size: 16px;
    font-weight: 700;
    display: none;
  }

  .titolohero-ipad.white {
    margin-top: 0;
    margin-bottom: 0;
    font-family: Optima, Arial, sans-serif;
    font-size: 54px;
  }

  .titolohero-ipad.white.black {
    color: var(--fakeblack);
    font-family: Optima, Arial, sans-serif;
    font-weight: 700;
  }

  .paragrafohero-ipad {
    color: var(--fakeblack);
    width: 100%;
    max-width: 520px;
    height: 0;
    font-family: Proximanova, Arial, sans-serif;
    font-size: 16px;
    overflow: hidden;
  }

  .paragrafohero-ipad.white {
    color: var(--white);
  }

  .paragrafohero-ipad.white.right {
    text-align: right;
  }

  .paragrafohero-ipad.left {
    text-align: left;
  }

  .arrowbutton-ipad {
    width: 20px;
    height: 20px;
  }

  .arrowbutton-ipad.white {
    color: var(--fakeblack);
    width: 20px;
    height: 20px;
  }

  .arrowbutton-ipad.white.black {
    color: var(--white);
  }

  .arrowbutton-ipad.white.button {
    color: var(--fakeblack);
    top: 10px;
    right: 10px;
  }

  .arrowbutton-ipad.white.button-white {
    color: var(--white);
    top: 10px;
    right: 10px;
  }

  .wrappermosaico-ipad {
    z-index: 0;
    flex-flow: column;
    display: flex;
    position: relative;
  }

  .casellamosaico-ipad {
    z-index: 0;
    color: var(--f1white);
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
    font-family: Optima, Arial, sans-serif;
    font-size: 20px;
    font-weight: 700;
    line-height: 120%;
    text-decoration: none;
    display: flex;
    position: relative;
  }

  .casellamosaico-ipad.white {
    border-color: var(--white);
    text-decoration: none;
  }

  .casellamosaico-ipad.white.left {
    border-left-style: solid;
    border-left-width: 1px;
  }

  .casellamosaico-ipad.bordo {
    border-left: 1px solid var(--fakeblack);
  }

  .rowmosaicofutura-ipad {
    width: 100%;
    height: 100%;
    display: flex;
  }

  .rowmosaicofutura-ipad.border {
    border-top: 1px solid var(--white);
  }

  .titolomosaico-ipad.white {
    color: var(--fakeblack);
    font-family: Optima, Arial, sans-serif;
    font-weight: 700;
  }

  .titolomosaico-ipad.white.black {
    color: var(--white);
  }

  .rowmosaicodomus-ipad {
    border-bottom: 1px solid var(--fakeblack);
  }

  .rowmosaicodomus-ipad.top {
    border-top: 1px solid var(--fakeblack);
  }

  .wrapperfasciaprogetto {
    flex-flow: column;
  }

  .wrapperimagefasciaprogetto {
    width: 100%;
  }

  .wrappertestofasciaprogetto {
    justify-content: center;
    align-items: center;
    width: 100%;
  }

  .sliderprogetti {
    width: 100%;
    height: 56.25vw;
  }

  .wrapper-page {
    grid-column-gap: 0px;
    grid-row-gap: 0px;
  }

  .c-image-start {
    z-index: 0;
    height: 70vh;
    position: sticky;
    top: 0;
  }

  .c-text-start {
    z-index: 1;
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    background-color: var(--white);
    border-top-left-radius: 50px;
    border-top-right-radius: 50px;
    margin-top: -45px;
    padding-bottom: 40px;
    position: relative;
  }

  .text-page {
    margin-top: 20px;
    padding-left: 10px;
    padding-right: 10px;
    font-size: 16px;
    font-weight: 700;
    line-height: 150%;
  }

  .sottotitle-page {
    font-size: 28px;
    line-height: 100%;
  }

  .text-section {
    text-align: center;
    width: 100%;
    max-width: none;
    font-size: 28px;
  }

  .text-description {
    text-align: center;
    max-width: 500px;
    font-family: Proximanova, Arial, sans-serif;
    font-size: 16px;
  }

  .text-center {
    justify-content: center;
    align-items: center;
    max-width: 600px;
  }

  .text-center.prezzi {
    grid-column-gap: 17px;
    grid-row-gap: 17px;
  }

  .text-center-box {
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 50%;
  }

  .imege-box {
    width: 100%;
  }

  .button-template-3 {
    font-size: 14px;
  }

  .c-text-image-template-3 {
    grid-column-gap: 45px;
    grid-row-gap: 45px;
    flex-flow: column;
    padding-left: 10px;
    padding-right: 10px;
  }

  .s-text-image {
    display: none;
  }

  .title-absolute {
    font-size: 28px;
  }

  .title-absolute.black {
    color: var(--fakeblack);
  }

  .text-absolute {
    max-width: 45ch;
    font-size: 16px;
    line-height: 150%;
  }

  .text-absolute.black {
    color: var(--fakeblack);
    max-width: 45ch;
  }

  .track {
    display: none;
  }

  .item {
    width: 95%;
    padding-right: 20px;
  }

  .text-card {
    text-align: left;
    font-size: 16px;
  }

  .s-text-image-mobile {
    flex-flow: column;
    width: 100%;
    height: 100%;
    display: flex;
    position: relative;
    overflow: clip;
  }

  .s-text-image-mobile.orange {
    background-color: #ffd89b;
    padding-top: 60px;
  }

  .s-text-image-mobile.grey {
    background-color: #f2f2f2;
    padding-top: 60px;
  }

  .s-text-image-mobile.padd {
    background-color: #ffd89b;
    padding-top: 50px;
  }

  .s-text-image-mobile.staccato {
    padding-top: 50px;
  }

  .s-text-image-mobile.staccato.futura {
    background-color: var(--futurecyan);
  }

  .s-text-image-mobile.padd-bianco {
    padding-top: 60px;
  }

  .c-text-image-mobile {
    z-index: 1;
    grid-column-gap: 35px;
    grid-row-gap: 35px;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
    padding-bottom: 60px;
    padding-left: 10px;
    padding-right: 10px;
    display: flex;
    position: sticky;
    top: -150px;
  }

  .c-text-image-mobile.bianco {
    background-color: var(--white);
    padding-top: 60px;
  }

  .image-mobile {
    object-fit: cover;
    border-radius: 20px;
    width: 100%;
    height: 50%;
    max-height: 500px;
  }

  .c-image-sovrap {
    z-index: 2;
    width: 100%;
    height: 100%;
    max-height: 550px;
    position: sticky;
    top: 0;
  }

  .image-sovrap {
    object-fit: cover;
    border-top-left-radius: 50px;
    border-top-right-radius: 50px;
    width: 100%;
    height: 100%;
  }

  .c-text-sovrap {
    z-index: 3;
    grid-column-gap: 35px;
    grid-row-gap: 35px;
    border: 1px solid var(--white);
    background-color: var(--fakeblack);
    border-top-left-radius: 50px;
    border-top-right-radius: 50px;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    min-height: 500px;
    margin-top: -40px;
    padding-left: 15px;
    padding-right: 15px;
    display: flex;
    position: relative;
  }

  .c-text-sovrap.white {
    border-width: 1px;
    border-color: var(--fakeblack);
    background-color: var(--white);
  }

  .c-text-sovrap.form {
    min-height: 700px;
  }

  .c-text-sovrap.form.futura {
    background-color: var(--white);
  }

  .slider {
    width: 100%;
    max-width: 100%;
    max-height: 350px;
    margin: 0 auto 0 0;
  }

  .slider-item {
    border-radius: 20px;
    flex: none;
    overflow: clip;
  }

  .text-slide {
    border-bottom-right-radius: 20px;
    border-bottom-left-radius: 20px;
    justify-content: center;
    align-items: center;
    height: 50px;
    min-height: 50px;
    max-height: 50px;
    padding-left: 15px;
    padding-right: 15px;
  }

  .s-tabella {
    display: flex;
  }

  .c-tabella {
    display: none;
  }

  .accordion-wrapper {
    grid-column-gap: 5px;
    grid-row-gap: 5px;
    flex-flow: column;
    width: 100%;
    padding-left: 10px;
    padding-right: 10px;
    display: flex;
  }

  .accordion-item {
    cursor: pointer;
    flex-flow: column;
    width: 100%;
    display: flex;
  }

  .accordion-header {
    border: 1px solid var(--fakeblack);
    border-radius: 10px;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    padding: 15px 10px;
    display: flex;
  }

  .title-accordion {
    font-family: Optima, Arial, sans-serif;
    font-size: 18px;
  }

  .icon-arrow {
    width: 25px;
  }

  .accordion-content {
    grid-column-gap: 10px;
    grid-row-gap: 10px;
    flex-flow: column;
    height: 0%;
    padding: 10px 20px;
    display: none;
  }

  .name-caratteristica {
    grid-column-gap: 5px;
    grid-row-gap: 5px;
    flex-flow: column;
    display: flex;
  }

  .title-tipologia, .description {
    font-family: Proximanova, Arial, sans-serif;
    font-size: 16px;
  }

  .title-card {
    font-size: 28px;
  }

  .wrapper-card {
    flex-flow: column;
    padding-left: 10px;
    padding-right: 10px;
  }

  .card {
    width: 100%;
  }

  .subtitle-card {
    font-size: 16px;
  }

  .text-footer {
    font-size: 84px;
  }

  .striscia-footer {
    grid-column-gap: 20px;
    grid-row-gap: 20px;
    flex-flow: wrap;
    justify-content: center;
    align-items: center;
  }

  .striscia-footer.left {
    grid-column-gap: 30px;
    grid-row-gap: 30px;
    justify-content: flex-start;
    align-items: center;
  }

  .inf-contatti, .inf-contatti.little {
    width: 100%;
  }

  .title-navigatore {
    font-size: 18px;
  }

  .text-navigatore {
    font-size: 18px;
    font-weight: 400;
  }

  .c-cookie {
    grid-column-gap: 5px;
    grid-row-gap: 5px;
    flex-flow: column;
    padding-top: 20px;
    padding-bottom: 20px;
  }

  .logo-footer {
    max-height: 120px;
  }

  .button {
    font-weight: 700;
  }

  .slider-dots {
    width: 100%;
  }

  .wrapperfrom {
    max-width: 500px;
  }

  .checkbox-label.black {
    color: var(--fakeblack);
  }

  .inline-gallery-container {
    grid-column-gap: 18px;
    grid-row-gap: 18px;
    height: auto;
  }

  .text-button-gallery {
    font-size: 14px;
  }

  .sottotitolo {
    font-family: Optima, Arial, sans-serif;
    font-size: 22px;
    font-weight: 700;
    line-height: 100%;
    display: none;
  }

  .sottotitolo.white {
    color: var(--white);
  }

  .title-wrap {
    flex-flow: column;
    justify-content: center;
    align-items: flex-end;
    display: flex;
  }

  .title-wrap.lef {
    justify-content: center;
    align-items: flex-start;
  }
}

@media screen and (max-width: 767px) {
  body {
    --40-space: 18px;
    --64-space: 28px;
    --20-space: 20px;
    --10-space: 10px;
  }

  .navbar-brand-three {
    padding-left: 0;
  }

  .nav-menu-three {
    border-radius: 20px;
    flex-direction: column;
    padding-bottom: 30px;
  }

  .nav-menu-block {
    flex-direction: column;
  }

  .nav-link {
    padding-top: 10px;
    padding-bottom: 10px;
    display: inline-block;
  }

  .titolomosaico-ipad {
    font-size: 16px;
  }

  .wrapperfasciaprogetto {
    padding-left: 20px;
    padding-right: 20px;
  }

  .track {
    margin-top: 30px;
  }

  .slider-item {
    min-width: auto;
    max-height: 350px;
  }

  .text-footer {
    font-size: 52px;
  }

  .contatti-struttura {
    font-size: 16px;
  }

  .logo-footer {
    max-height: 100px;
  }

  .fascia-nera {
    padding-left: 10px;
    padding-right: 10px;
  }

  .checkbox-label {
    font-size: 13px;
  }
}

@media screen and (max-width: 479px) {
  body {
    --40-space: 15px;
    --64-space: 24px;
    --20-space: 15px;
    --10-space: 10px;
  }

  .navbar-logo-center-container.shadow-three {
    height: 60px;
  }

  .container {
    max-width: none;
  }

  .container.center {
    justify-content: center;
    align-items: center;
  }

  .nav-menu-three {
    flex-direction: column;
  }

  .pagewrapper.ipad {
    height: calc(100vh - 60px);
  }

  .linkhero.white, .linkhero.white.black {
    font-family: Proximanova, Arial, sans-serif;
  }

  .sottotitolohero.white {
    font-size: 18px;
  }

  .image {
    height: 50px;
  }

  .domusmosaicoipad {
    display: none;
  }

  .wrapperhero-ipad {
    grid-column-gap: 5px;
    grid-row-gap: 5px;
  }

  .buttonhero-ipad.milk, .buttonhero-ipad.orange {
    width: 200px;
    display: none;
  }

  .titolohero-ipad.white {
    font-size: 62px;
  }

  .paragrafohero-ipad, .paragrafohero-ipad.white {
    font-size: 14px;
  }

  .paragrafohero-ipad.white.right {
    text-align: right;
  }

  .paragrafohero-ipad.left {
    text-align: left;
  }

  .arrowbutton-ipad.white.button, .arrowbutton-ipad.white.button-white {
    top: 10px;
    right: 10px;
  }

  .wrapperfasciaprogetto {
    padding-left: 10px;
    padding-right: 10px;
  }

  .iconafasciaprogetto.futura {
    width: 24.5px;
    height: 24.5px;
  }

  .right-arrow-fasciaprogetto, .left-arrow-fasciaprogetto {
    width: 30px;
  }

  .image-start {
    object-fit: cover;
    object-position: 45% 50%;
  }

  .c-text-start {
    margin-top: -40px;
  }

  .text-page {
    font-size: 14px;
  }

  .sottotitle-page {
    max-width: 17ch;
  }

  .text-section {
    font-size: 22px;
  }

  .text-description {
    font-size: 14px;
  }

  .title-absolute {
    font-size: 22px;
  }

  .text-absolute {
    font-size: 14px;
  }

  .text-absolute.black {
    color: var(--fakeblack);
  }

  .text-card {
    text-align: center;
  }

  .image-mobile {
    max-height: 350px;
  }

  .c-text-sovrap {
    min-height: 300px;
  }

  .c-text-sovrap.bianco {
    background-color: var(--white);
  }

  .slider-item {
    min-width: auto;
    max-height: 280px;
  }

  .s-tabella {
    margin-top: 60px;
  }

  .bold-text-10 {
    font-size: 16px;
  }

  .s-card {
    margin-top: 60px;
  }

  .c-card {
    padding-left: 10px;
    padding-right: 10px;
  }

  .title-card {
    padding-bottom: 20px;
    font-size: 22px;
  }

  .wrapper-card {
    padding-left: 0;
    padding-right: 0;
  }

  .text-button {
    padding: 25px 10px;
  }

  .title-card-big {
    font-size: 16px;
  }

  .subtitle-card {
    font-size: 14px;
  }

  .footer-1 {
    margin-top: 60px;
  }

  .wrapper-footer-1 {
    grid-column-gap: 25px;
    grid-row-gap: 25px;
    padding-top: 20px;
    padding-bottom: 20px;
  }

  .text-footer {
    font-size: 32px;
  }

  .striscia-footer.padding {
    padding-top: 0;
    padding-bottom: 0;
  }

  .striscia-footer.left {
    grid-column-gap: 30px;
    grid-row-gap: 30px;
  }

  .inf-contatti {
    grid-column-gap: 7px;
    grid-row-gap: 7px;
  }

  .button-contattaci {
    font-size: 16px;
  }

  .title-navigatore, .text-navigatore, .contatti-struttura {
    font-size: 14px;
  }

  .c-cookie {
    grid-column-gap: 7px;
    grid-row-gap: 7px;
  }

  .text-cookie, .button {
    font-size: 14px;
  }

  .bold-text-12 {
    font-size: 26px;
  }

  .checkbox-label {
    font-size: 12px;
    line-height: 16px;
  }

  .iconafasciaprogetto-2 {
    width: 30px;
    height: 30px;
  }

  .loading-screen {
    display: none;
  }

  .loaderlogo {
    filter: grayscale();
  }
}


@font-face {
  font-family: 'Optima';
  src: url('../fonts/OPTIMA.TTF') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Optima';
  src: url('../fonts/OPTIMA_B.TTF') format('truetype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Optima';
  src: url('../fonts/Optima_Italic.ttf') format('truetype');
  font-weight: 400;
  font-style: italic;
  font-display: swap;
}
@font-face {
  font-family: 'Optima';
  src: url('../fonts/Optima-Medium.ttf') format('truetype');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Proximanova';
  src: url('../fonts/proximanova_black.ttf') format('truetype'), url('../fonts/proximanova_blackit.otf') format('opentype'), url('../fonts/proximanova_black.otf') format('opentype');
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Proximanova';
  src: url('../fonts/proximanova_regular.ttf') format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Proximanova';
  src: url('../fonts/proximanova_light.otf') format('opentype');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Proximanova';
  src: url('../fonts/proximanova_bold.otf') format('opentype'), url('../fonts/proximanova_extrabold.otf') format('opentype'), url('../fonts/proximanova_boldit.otf') format('opentype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}