/*
Theme Name: VibGroup Theme
Theme URI: https://und3fined.it/
Template: generatepress
Author: Gabriele Visconti
Author URI: https://und3fined.it/
Description: Questo tema è stato realizzato dal developer team di Vib. G.V
Tags: two-columns,three-columns,one-column,right-sidebar,left-sidebar,footer-widgets,blog,e-commerce,flexible-header,full-width-template,buddypress,custom-header,custom-background,custom-menu,custom-colors,sticky-post,threaded-comments,translation-ready,rtl-language-support,featured-images,theme-options
Version: 1.52
Updated: 2025-04-30 16:41:41

*/



/* --------------------------------------------
   Typografy
-------------------------------------------- */
 body{
    font-size: clamp(16px, 0.937vw, 18px);
    line-height: clamp(24px, 1.666vw, 32px);
    color: #BEBEBE !important;
    }
    div#content{
      color: #BEBEBE !important;
    }
   .block--title__40{
         font-size: clamp(26px, 2.079vw, 40px);
         line-height: clamp(30px, 2.49vw, 48px);
      }
   .block--title__45{
      font-size: clamp(26px, 2.33vw, 45px);
      line-height: clamp(30px, 2.49vw, 528px);
   }
   .block--title__50{
      font-size: clamp(28px, 2.59vw, 50px);
      line-height: clamp(34px, 3.01vw, 58px);
   }
   .block--title__60{
      font-size: clamp(32px, 3.12vw, 60px);
      line-height: clamp(44px, 3.74vw, 72px);
   }
   .block--title__70{
      font-size: clamp(34px, 3.64vw, 70px);
      line-height: clamp(46px, 4.26vw, 82px);
   }
   .block--title__80{
      font-size: clamp(36px, 4.16vw, 80px);
      line-height: clamp(42px, 4.426vw, 85px);
   }
   .block--title__90{
      font-size: clamp(36px, 4.687vw, 90px);
      line-height: clamp(36px, 4.687vw, 90px);
   }
   h1,h2,h3,h4,h5,h6{
      color: #fff;
   }
/* --------------------------------------------
   Global
-------------------------------------------- */
#to-the-top {
    display: flex;
    background-color:#81818173;
    width: 50px;
    height: 50px;
    border-radius: 25px 0 0 25px;
    position: fixed;
    bottom: 10%;
    right: 0;
    transition: background-color .3s, opacity .5s, visibility .5s;
    opacity: 0;
    visibility: hidden;
    z-index: 1000;
    justify-content: center;
    align-items: center;
}
a#to-the-top svg {
    width: 20px;
    height: 20px;
    fill: #fff;
    transition: 300ms;
}

#to-the-top:hover {
	cursor: pointer;
	background-color: #333;
}

#to-the-top:active {
	background-color: #555;
}

#to-the-top.show {
	opacity: 1;
	visibility: visible;
}

/* --------------------------------------------
   Home
-------------------------------------------- */
.home-hero {
    height: 100vh;
}
.home-hero .row,.home-hero .column,.home-hero .home-hero-cursor{
   height: 100%;
}
.home-hero-cursor {
    display: flex;
    justify-content: center;
    align-items: flex-end;
}
.home-hero-cursor {
  animation: scrollHint 2s ease-in-out infinite;
}

@keyframes scrollHint {
  0% {
    transform: translateY(0);
    opacity: 1;
  }
  50% {
    transform: translateY(10px); /* quanto scende */
    opacity: 0.8;               /* leggero fade opzionale */
  }
  100% {
    transform: translateY(0);
    opacity: 1;
  }
}

.gold{
   color: #B78B61;
   font-style: italic;
}
.home-collection-start-content {
      transition: 300ms;
}
.home-collection-start{
   z-index: 999;
}
.home-collection-promo {
    position: relative;
    z-index: 5;
}
@media(min-width: 1181px){
   .home-collection-start-content {
      transition: 300ms;
      max-width: clamp(480px, 27.603vw, 530px);
      margin: 0 auto;
   }
}
.home-collection-start-content .block--button {
    margin-top: 40px;
}

@media(min-width: 1025px){
   .home-collection-start-title .block--title__90 {
      text-align: right;
   }
   .home-collection-start-title .block--title {
      max-width: clamp(600px, 38.280vw, 735px);
      margin: 0 0 0 auto;
      text-wrap: balance;
   }
}
@media(max-width: 1180px){
   .home-collection-start .row{
      gap: 30px;
   }
}
.home-centered-text-content .block--title {
    /*text-wrap: balance;*/
    margin-bottom: 30px;
}
.home-centered-text-content .block--button {
    margin: 40px auto 0;
}
.block--subtitle {
    text-transform: uppercase;
    font-weight: 300;
    margin-bottom: 5px;
}
@media(min-width: 1025px){
   .home-centered-text-content {
      max-width: clamp(800px, 51.301vw, 985px);
      margin: 0 auto;
   }
   .home-centered-text-content .block--paragraph {
      max-width: clamp(600px, 32.290vw, 620px);
      margin: 0 auto;
   }
}

.gallery.autoscroll .js-splide-2{
   margin-top: 35px;
}
.home-quote-wrapper h5{
    color: #B78B61;
    font-size: clamp(22px, 2.082vw, 40px);
    font-style: italic;
}
.home-quote-wrapper{
    margin-top: 40px;
}
.home-column-text-wrapper {
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 35px;
}
@media(min-width: 1181px){
   .home-column-image-wrapper {
      max-width: 85%;
      margin: 0 auto;
   }
   .home-column-text-wrapper {
      max-width: clamp(450px, 28.384vw, 545px);
      margin: 0 10% 0 auto;
      display: flex;
      flex-direction: column;
      gap: 35px;
   }
   .home-quote-wrapper-text {
      max-width: clamp(800px, 81.50vw, 1565px);
   }
}
@media(min-width: 1025px){
   .quote-wrapper-image .block--image {
      max-width: 80%;
   }
   .last-post-header-text .block--paragraph {
      max-width: clamp(600px,39.062vw, 750px);
   }
}

.last-post-header-text .block--paragraph {
    margin-bottom: 30px;
}

.no-padding-top{
   padding-top: 0px;
}
.row-last-post-loop {
    margin-top: clamp(50px, 5.207vw, 100px);
}

.post-link-button a {
    transition: 300ms;
    color: #B78B61;
    text-decoration: none;
    text-transform: uppercase;
}

.post-link-button a:hover {
    transition: 300ms;
    color: #fff;
    text-decoration: underline;
}
.post-link-button{
    margin-top: 25px;
}
.post-title-wrapper {
    margin-top: 20px;
    max-width: 90%;
    margin-bottom: 15px;
}
.post-content {
    text-wrap: balance;
}
.home-last-post ul.splide__pagination.splide__pagination--ltr {
    position: unset;
    margin: 60px 0 0;
    padding: 0px;
}
.home-last-post button{
   width: 15px;
   height: 15px;
}

.home-last-post button.splide__pagination__page.is-active{
   background: #B78B61;
}

.home-promo-collection-text {
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: 100%;
}

.home-promo-collection-item  .block--button.block--button--outline--white{
   margin-top:30px;
}
.home-promo-collection-item  .block--button.block--button--outline--white a{
   border: 1px solid #fff;
}
.home-promo-collection-item  .block--button.block--button--outline--white a:hover{
   border: 1px solid #fff;
   background: #fff;
   color: #151515;
}
.home-promo-collection-text .block--subtitle {
    color: #fff;
}

@media(min-width: 1025px){
   .section.home-collection-promo {
      width: 95%;
   }
   .home-collection-promo {
     /* transform: translateY(-13vw);
      height: calc(100vh - 13vw);*/
   }
   .home-promo-collection-item{
      min-height: 600px;
   }
   .home-collection-promo .row--fluid .column:first-child .home-promo-collection-item{
      height: 100vh;
   }
   .home-collection-promo .row--fluid .column:last-child .home-promo-collection-item{
      height: 80vh;
   }
}

@media(max-width: 1024px){
   .section.home-collection-promo.home-collection-promo__row-desktop.section--relative{
      display: none;
   }
   .section.home-collection-promo-.home-collection-promo__row-mobile.section--relative {
      display: block;
   }
   .home-promo-collection-item.section--overlay--dark.section--bg {
      padding: 60px 5%;
      height: clamp(480px, 30.207vw, 580px);
   }
}
@media(min-width: 1025px){
   .section.home-collection-promo-.home-collection-promo__row-mobile.section--relative {
      display: none;
   }
   .section.home-collection-promo.home-collection-promo__row-desktop.section--relative{
      display: block;
   }
}
.section.home-collection-promo-.home-collection-promo__row-mobile.section--relative .column {
    overflow: hidden;
}
.home-promo-collection-item h4 {
    text-transform: uppercase;
    font-family: 'Montserrat';
}

.section.home-collection-promo-.home-collection-promo__row-mobile.section--relative ul.splide__pagination.splide__pagination--ltr button{
   width: 15px;
   height: 15px;
}
.section.home-collection-promo-.home-collection-promo__row-mobile.section--relative ul.splide__pagination.splide__pagination--ltr{
   margin: 0px auto 40px;
}
.footer-socials {
    display: flex;
    gap: 10px;
    align-items: center;
}
.footer-socials a {
    display: flex;
}
.footer-socials svg{
    fill: #B78B61;
    width: 25px;
    height: 25px;
    transition: 300ms;
}
.footer-content {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
.footer-logo a:before, .footer-logo a:after {
    content: '';
    display: flex;
    background: #686868;
    width: 100%;
    height: 1px;
}
.footer-logo {
    width: 100%;
}

.footer-logo a {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 40px;
}
.footer-menu ul {
    list-style: none;
    margin: 0px;
    display: flex;
    flex-direction: column;
    gap: 30px;
    align-items: center;
}
.footer-menu a{
   color: #fff;
   text-transform: uppercase;
   text-decoration: none;
   transition:300ms;
}
.footer-menu a:hover{
   color: #B78B61;
   transition:300ms;
}
.footer-menu{
   margin: 60px 0;
}
@media(min-width: 1025px){
   .footer-menu ul {
      list-style: none;
      margin: 0px;
      flex-direction: row;
      display: flex;
      gap: 30px;
      align-items: center;
   }
}
.bottom-footer-wrapper.block--title--center {
    border-top: 1px solid #686868;
    width: 100%;
    padding-top: 29px;
    padding-bottom: 30px;
    margin-top: 80px;
    font-size: 14px;
    font-style: italic;
}

.page-header-content {
    max-width: clamp(500px, 48.176vw, 925px);
    margin: 0 auto;
}
.block-breadcrums {
    color: #fff;
    margin-bottom: 5px;
}
@media(max-width: 1024px){
   .block-breadcrums {
      font-size: 13px;
   }
}

.about-column-text {
    max-width: clamp(480px, 27.864vw, 535px);
    margin: clamp(60px, 6.24vw, 120px) auto 0;
}
.about-column-text .block--button {
    margin-top: 40px;
}
.home-two-column-in-about .block--image img {
    width: 100%;
}
@media(min-width: 1025px){
   .section.home-two-column-in-about {
      max-width: 95%;
      margin: 0 0 0 auto;
   }
}
@media(max-width: 1024px){
   .about-column-text{
      padding: 0 5%;
   }
}

.logos-item-wrapper {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    max-width: clamp(300px, 16.145vw, 310px);
    height: 100%;
    gap: 20px;
}

.logos-item-wrapper .block--image {
    max-width: 150px;
    height: auto;
}
.logos-item-wrapper h5{
   text-align: center;
}
.logos-item-wrapper .block--title {
    text-wrap: balance;
}

@media(max-width: 1024px){
   .icons-repeater .column{
      overflow: hidden;
   }
   .logos-item-wrapper {
      display: flex;
      flex-direction: column;
      justify-content: center;
      align-items: center;
      text-align: center;
      max-width: 100%;
      height: 100%;
      gap: 20px;
   }
   .icons-repeater ul.splide__pagination.splide__pagination--ltr button{
      width: 15px;
      height: 15px;
   }
   .icons-repeater ul.splide__pagination.splide__pagination--ltr{
      margin: 40px auto 0;
      position: unset;
   }
   .icons-repeater button.splide__pagination__page.is-active{
      background: #B78B61;
   }
}
@media(min-width: 1025px){
   .icons-repeater .splide__slide {
      margin: 0 auto;
   }
}

.background-section-wrapper {
    max-width: clamp(600px, 52.082vw, 1000px);
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
}
.background-section-wrapper .block--title{
   margin-bottom: 50px;
}
.background-section-wrapper .block--title h3{
   text-align: center;
}
.custom-margin-bottom {
    margin-bottom: clamp(60px, 10.40vw, 200px);
}

.footer-contacts-icon svg {
    width: 20px;
    height: 20px;
    fill: #B78B61;
}
.footer-contacts-icon {
   display: flex;
}
.footer-contacts-wrapper {
    display: flex;
    align-items: center;
    gap: 10px;
}
.contact-label-wrapper h5{
    color: #B78B61;
    text-transform: uppercase;
    font-family: 'Cormorant Garamond';
}
.contact-address-wrapper {
    display: flex;
    flex-direction: column;
    gap: 15px;
    line-height: 1;
}
.contact-loop-informations {
    display: flex;
    flex-direction: column;
    gap: 30px;
}
.opening-time-grid {
    display: flex;
    gap: 5px;
}
.contact-section-wrapper .block--paragraph {
    margin: 20px 0 30px;
}
.contact-wrapper-map iframe {
    width: 100%;
    height: 100%;
}
.contact-section,.contact-section .row, .contact-section .column{
   height: 100%;
}
.contact-wrapper-map {
    display: flex;
    height: 100%;
    min-height: 400px;
}
.contact-section-wrapper h2.block--title__90 {
    text-wrap: balance;
}
.contact-section-wrapper .block--paragraph {
    text-wrap: balance;
}

.block-contact-form-text-wrapper {
    max-width: clamp(600px, 38.020vw, 730px);
    text-wrap: balance;
}
.custom-width-catalog .home-column-image-wrapper {
    max-width: 100%;
}
@media(min-width: 1025px){
   .custom-width-catalog .home-column-text-wrapper {
      max-width: 90%;
   }
}


/* Contact form */
 .contact_form_grid {
     display: grid;
     grid-template-columns: 1fr;
     gap: 20px;
     margin-bottom: 20px;
}
 .contact_form_input input, .contact_form_input select, .contact_form_message textarea {
     width: 100% !important;
     color: #fff !important;
     padding: 20px 20px 19px !important;
     border: none !important;
     border-bottom: 1px solid #7F7F7F !important;
     background: transparent !important;
}
 .contact_form_message textarea {
     max-height: 100px;
}
 .contact_form_optin {
     margin: 20px 0;
     display: flex;
     flex-direction: column;
     gap: 5px;
}
 .contact_form_action {
     margin-top: 40px;
     position: relative;
     display: flex;
     flex-direction: column;
     gap: 20px;
}
 .contact_form_optin span.wpcf7-list-item {
     margin: 0;
}
 .contact_form_optin a {
     color: unset;
     text-decoration: underline;
}
 span.required_span{
     font-weight: bold;
     color: #B78B61;
}
 .contact_form_action input {
     background: #B78B61 !important;
     padding: 16px 20px;
     border: none;
     font-weight: 500;
     color: #fff;
     text-transform: uppercase;
     max-width: max-content;
     transition: 300ms;
     cursor: pointer;
     border-radius: 0px;
     min-width: 200px !important;
}
 .contact_form_action input:hover {
     background: #0B0F19;
     color: #fff;
     transition: 300ms;
}
 .contact-form-wrapper-shortcode {
     margin-top: 40px;
}
 .block-contact-form-text-wrapper .block--title__60 h3 {
     text-wrap: balance;
}
 .block-contact-form-text-wrapper .block--title__60 {
     text-wrap: balance;
}
 .block-contact-form-text-wrapper a {
     text-decoration: none;
     transition: 300ms;
}
 .block-contact-form-text-wrapper a span{
     transition: 300ms;
}
 .block-contact-form-text-wrapper a:hover span{
     color: #0B0F19;
     transition: 300ms;
}
 @media(min-width: 1025px){
     .block-contact-form-text-wrapper .block--title__60 {
         text-wrap: balance;
    }
     .contact_form_grid {
         grid-template-columns: 1fr 1fr;
    }
}




/* --------------------------------------------
   Single post
-------------------------------------------- */
.single-post-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.single-post-image {
    overflow: hidden;
    width: 100%;
    display: flex;
}

.single-post-content-text .single-post-content {
    padding: 20px 5%;
}

.post-sharing-links svg {
    height: 15px;
    width: 15px;
    transition: 300ms;
}

.post-sharing-links a {
    display: flex;
}
.post-sharing-links{
    display: flex;
    align-items: center;
    gap: 5px;
}

.single-post-sharing {
    display: flex;
    gap: 5px;
    align-items: center;
    line-height: 1;
}
.single-bottom-content {
    display: flex;
    padding-top: 29px;
    border-top: 1px solid #B78B61;
    margin-top: 60px;
    justify-content: space-between;
    gap: 10px;
    font-size: 13px;
    text-transform: uppercase;
    font-weight: bold;
}
.single-author {
    display: flex;
    align-items: center;
    gap: 5px;
    line-height: 1;
}

.block--title.gloock.block--title--center {
    margin-bottom: 50px;
    line-height: 1.2em;
}


.single-post-content.with-title h1.block--title__80.block--title--center {
    text-wrap: balance;
}

.single-post-content-text .single-post-content h1,.single-post-content-text .single-post-content h2,
.single-post-content-text .single-post-content h3,.single-post-content-text .single-post-content h4,.single-post-content-text .single-post-content h5,.single-post-content-text .single-post-content h6 {
    margin-bottom: 25px !important;
    display: block;
    color: #B78B61;
}
.single-post-content-text .single-post-content p{
    margin-bottom: 25px !important;
    display: block;
    color: #fff;
}

.single-post-content figure.wp-block-image.size-full{
    margin: 10px;
}
.single-post-content figure.wp-block-image.size-full img {
    width: 100%;
    height: 100%;
}
.post-meta {
    display: flex;
    gap: 20px;
    justify-content: center;
    margin: 15px 0 80px;
}
.user, .single-post-date {
    display: flex;
    align-items: center;
    gap: 6px;
}
.single-post-content-text .single-post-content h1,
.single-post-content-text .single-post-content h2,
.single-post-content-text .single-post-content h3,
.single-post-content-text .single-post-content h4,
.single-post-content-text .single-post-content h5,
.single-post-content-text .single-post-content h6{
    font-size: clamp(30px, 1.87vw, 36px);
}
.related-post-grid.desktop{
    display: none;
}
.section.section--padding-sm.form-section-wrapper.title-color__gold.faraglioni-bg.section-single-related .column {
    overflow: hidden;
}
.my-slider-progress {
    background: #ccc;
    height: 3px;
    margin-top: 10px;
    max-width: 80%;
    margin: 40px auto 0;
}
.my-slider-progress-bar {
  background: #151515;
  height: 3px;
  width: 0;
  transition: width 400ms ease;
}
.section.section--padding-sm.form-section-wrapper.title-color__gold.faraglioni-bg.section-single-related {
    padding-top: 0;
}
@media(min-width: 1025px){
    .my-slider-progress {
        background: #ccc;
        height: 3px;
        margin-top: 10px;
        max-width: 100%;
        margin: 60px auto 0;
    }
    .single-post-image {
        overflow: hidden;
        width: 100%;
        display: flex;
        height: clamp(500px, 38vw, 730px);
    }
    .related-post-grid-.mobile{
        display: none;
    }
    .related-post-grid.desktop {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
        gap: 25px;
    }
    .post-sharing-links svg {
        height: 20px;
        width: 20px;
        transition: 300ms;
    }
    .single-post-content.with-title,.related-post-grid {
        max-width: 90%;
        margin: 0 auto;
    }
    .single-post-content-text .single-post-content {
        padding: 80px 60px;
    }
}

.post-sharing-links svg {
    fill: #B78B61;
}
.post-meta.figtree {
    color: #B78B61;
    text-transform: uppercase;
}
@media(min-width: 1025px){
   .single-post-content.with-title .block--title {
      max-width: clamp(400px, 44.27vw, 850px);
      margin: 0 auto;
   }
}

.last-post-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 50px;
}
@media(min-width: 769px) and (max-width: 1280px){
   .last-post-grid {
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 50px;
   }
}
@media(min-width: 1281px){
   .last-post-grid {
      display: grid;
      grid-template-columns: 1fr 1fr 1fr;
      gap: 50px;
   }
}
.block-breadcrums {
    display: flex;
    gap: 5px;
    justify-content: center;
    margin-top: 5px;
    text-transform: uppercase;
}
.page-header-content a {
    color: #fff;
    text-decoration: none;
    text-transform: uppercase;
    transition: 300ms;
}
.page-header-content a:hover {
    text-decoration: underline;
    transition: 300ms;
}


.single-collection-gallery {
    display: grid;
    grid-template-columns: 1fr;
}
@media(min-width: 769px) and (max-width: 1280px){
   .single-collection-gallery {
      display: grid;
      grid-template-columns: 1fr 1fr;
   }
}
@media(min-width: 1281px) and (max-width: 1440px){
   .single-collection-gallery {
      display: grid;
      grid-template-columns: 1fr 1fr 1fr;
   }
}
@media(min-width: 1441px){
   .single-collection-gallery {
      display: grid;
      grid-template-columns: 1fr 1fr 1fr 1fr;
   }
}
.single-collection-gallery .block--image img {
    width: 100%;
}
.section.section--padding-lg.single-collection-header {
    padding-bottom: clamp(80px, 5.207vw, 100px);
}
.text-wrap-balance {
    text-wrap: balance;
}

.collection-image-wrapper {
    display: flex;
}
.collection-image-wrapper img{
    width: 100%;
}
.collection-item-wrapper.section--relative .home-promo-collection-text {
    position: absolute;
    top: 0;
    background: #00000033;
    width: 100%;
    z-index: 6;
}
.collection-image-wrapper {
    display: flex;
    width: 100%;
    position: relative;
    z-index: 5;
}
.collection-loop {
    display: grid;
    grid-template-columns: 1fr;
}
@media(min-width: 1025px){
    .collection-loop {
        display: grid;
        grid-template-columns: 1fr 1fr;
    }
}
.home-promo-collection-text .block--button {
    margin-top: 35px;
}
nav.collection-pagination {
    padding: 80px 0 0;
    display: flex;
    justify-content: center;
    align-items: center;
}
ul.page-numbers {
    display: flex;
    gap: 20px;
    margin: 0px;
    list-style: none;
}














/* Header */
.small-header-contact-item svg,.header-submenu-footer-contacts svg {
    width: 20px;
    height: 20px;
    fill: #B78B61;
}
.small-header-contact-item a, .small-header-contact-item p,.header-submenu-footer-contacts a,.header-submenu-footer-contacts p{
    display: flex;
    gap: 6px;
    align-items: center;
    text-decoration: none;
    color: #333;
    font-size: clamp(12px, 0.72vw, 14px);
}
.small-header-contact {
    display: flex;
    gap: clamp(10px, 0.77vw, 15px);
    align-items: center;
}

span.small-header-separator,.header-separator span {
    height: 16px;
    width: 1px;
    display: flex;
    background: #B78B61;
}

.small-header-social .footer-socials a {
    width: 20px;
    background: transparent;
    padding: 0;
    border-radius: unset;
    transition: 300ms;
    display: flex;
    align-items: center;
    justify-content: center;
}
.small-header-row {
    display: flex;
    justify-content: space-between;
    gap: 10px;
}
.small-header-wrapper .small-header-row {
    border-bottom: 1px solid #D1D1D1;
    padding: 12px 0;
}

.header-main-row {
    display: grid;
    grid-template-columns: 1fr 3fr 1fr;
    gap: 20px;
    align-items: center;
}
.header-logo-wrapper a {
    display: flex;
}
.header-logo-wrapper img {
    width: clamp(170px, 13.79vw, 265px);
}
.header-menu-item.area-mega-menu {
    cursor: pointer;
}
.header-menu-item > a,.header-menu-item.area-mega-menu > div > a {
    text-decoration: none;
    text-transform: uppercase;
    transition: 300ms;
    color: #484381;
    font-size: clamp(13px,0.829vw, 16px);
    line-height: 1;
    display: block;
    line-height: clamp(70px, 4.68vw, 90px);
}

.header-menu-item > a:hover,.header-menu-item.area-mega-menu > div > a:hover {
    transition: 300ms;
    color: #333;
}

.header-main-menu-pages {
    display: flex;
    justify-content: center;
    gap: clamp(18px, 1.55vw, 30px);
    transition: 300ms;
}


.area-mega-menu-wrapper {
    position: absolute;
    z-index: 10;
    background: #F7F9FC;
    width: 100%;
    left: 0;
    padding: clamp(40px, 5.2vw, 100px);
    height: 0;
    overflow: hidden;
    visibility: hidden;
    opacity: 0;
    transition: 500ms;
    box-shadow: 0 5px 10px #00000013;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    gap: 20px;
}
.header-menu-item.area-mega-menu > div:hover .area-mega-menu-wrapper {
    height: auto;
    overflow: visible;
    visibility: visible;
    opacity: 1;
    transition: 500ms;
}

.submenu-area-item a {
    display: flex;
    gap: 20px;
    text-wrap: balance;
    text-decoration: none;
    color: unset;
}
.submenu-area-item .area-submenu-title {
    font-size: 1.04vw;
    line-height: 1;
    margin-bottom: 8px;
}
.area-submenu-description {
    font-size: clamp(12px, 0.72vw, 14px);
    line-height: 1.4;
}
.area-submenu-icon {
    display: flex;
}
.area-submenu-icon img {
    width: clamp(40px, 3.64vw, 70px);
    height: auto;
    transition: 300ms;
}

.submenu-area-item:hover a {
    transition: 300ms;
    padding: 10px;
    background: #fff;
    border-radius: 15px;
}
.submenu-area-item a {
    transition: 300ms;
    padding: 10px 0;
}
.header-search-icon svg {
    fill: #484381;
    transition: 300ms;
    width: 25px;
    cursor: pointer;
}
.header-search-icon {
    display: flex;
}
.header-search-wrapper {
    display: flex;
    gap: clamp(20px, 2.082vw, 40px);
    align-items: center;
    justify-content: flex-end;
}
.header-menu-item.area-mega-menu > div {
    overflow: hidden;
}
.header-actions-wrapper a.block--button__link{
    font-size: clamp(12px, 0.82vw, 16px);
    min-width: clamp(140px, 9.37vw, 180px);
}

.desktop-reasearch-header-wrapper {
    transition: 400ms;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}
.desktop-reasearch-header-wrapper form.search-form, .desktop-reasearch-header-wrapper label {
    width: 100%;
    display: flex;
    position: relative;
}
.desktop-reasearch-header-wrapper form.search-form input {
    width: 100%;
    border: 1px solid #ccc;
    border-radius: 30px;
}
.desktop-reasearch-header-wrapper button.search-submit {
    position: absolute;
    right: 0;
    border-radius: 0 30px 30px 0;
    background: #484381;
    transition: 300ms;
}
.desktop-reasearch-header-wrapper button.search-submit:hover {
    background: #333;
    transition: 300ms;
}

.header-main-menu-wrapper.search-active .header-main-menu-pages {
    height: 0;
    transition: 1s;
    overflow: hidden;
    opacity: 0;
}
.desktop-reasearch-header-wrapper {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    visibility: hidden;
    overflow: hidden;
    transition: opacity 0.35s ease, visibility 0s linear 0.35s;
    height: 0;
}
.header-main-menu-wrapper.search-active .desktop-reasearch-header-wrapper {
    width: 100%;
    padding: 15px 0;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 1;
    visibility: visible;
    overflow: visible;
    height: 100%;
    transition: opacity 0.35s ease, visibility 0s;
}

.desktop-search-close {
    position: relative;
    transition: 300ms;
    opacity: 0;
    visibility: hidden;
    overflow: hidden;
    cursor: pointer;
    width: 25px;
    height: 0;
}
.desktop-search-close span {
    width: 20px;
    height: 1px;
    background: #484381;
    display: flex;
    transition: 300ms;
    position: absolute;
    top: 50%;
}
.desktop-search-close span:first-child {
    transform: rotate(-45deg);
}
.desktop-search-close span:last-child {
    transform: rotate(45deg);
}
.header-search-icon.search-active svg{
    opacity: 0;
    visibility: hidden;
    overflow: hidden;
    height: 0;
    width: 0;
    transition: 300ms;
}
.header-search-icon.search-active .desktop-search-close {
    transition: 300ms;
    opacity: 1;
    visibility: visible;
    overflow: visible;
    height: 25px;
}



.header-burger-menu {
    cursor: pointer;
    position: relative;
    width: 60px;
    height: 30px;
    display: flex;
    gap: 6px;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}

.header-burger-menu span{
    transition: 300ms;
    background: #B78B61;
    height: 1px;
    width: 60px;
    display: flex;
}
.header-burger-menu.active span:first-child{
    transition: 300ms;
    opacity: 0;
}
.header-burger-menu.active span:last-child{
    transition: 300ms;
    transform: rotate(45deg);
    position: absolute;
    top: 50%;
}
.header-burger-menu.active span:nth-child(2){
    transition: 300ms;
    transform: rotate(-45deg);
    position: absolute;
    top: 50%;
}

@media(max-width: 1440px){
    .header-block-button{
        display: none !important;
    }
    .small-header-wrapper,.header-main-menu-wrapper,.header-search-icon,.header-separator,.header-booking-button{
        display: none;
    }
    .header-main-row {
        display: flex;
        justify-content: space-between;
        gap: 20px;
        align-items: center;
        padding: 20px 0;
    }
}
@media(min-width: 1441px){
    /*.header-burger-menu{
        display: none;
    }*/
}

.small-header-wrapper, .header-main-wrapper {
    background: transparent;
}
.header-mobile-menu{
    height: 0;
    overflow: hidden;
    transition: 300ms;
}
.header-mobile-menu.active {
    height: 100vh;
    background: #F7F9FC;
    padding: 60px 0;
    transition: 300ms;
    z-index: 9999999999999999999;
    position: relative;
}
.header-submenu-footer {
    display: flex;
    flex-direction: column;
    gap: 30px;
    padding-top: 39px;
    border-top: 1px solid #ccc;
}

.mobile-reasearch-header-wrapper form.search-form,.mobile-reasearch-header-wrapper label{
    width: 100%;
    position: relative;
}

.mobile-reasearch-header-wrapper input.search-field {
    width: 100%;
    border-radius: 30px;
    border: 1px solid #ccc;
    background: #fff;
}
.mobile-reasearch-header-wrapper button.search-submit {
    position: absolute;
    right: 0;
    border-radius: 0 30px 30px 0;
    transition: 300ms;
    background: #484381;
}
.header-submenu-footer-contacts {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.toggle-menu-icon {
    width: 20px;
    height: 20px;
    transition: 300ms;
    cursor: pointer;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
}
.toggle-menu-icon span{
    width: 15px;
    height: 1px;
    display: flex;
    background: #484381;
    transition: 300ms;
}
.toggle-menu-icon span:first-child {
    transform: rotate(90deg);
    position: absolute;
    top: 50%;
}
a.toggle-menu--head.toggle-menu-content.active .toggle-menu-icon span:first-child {
    transform: rotate(0deg);
    position: absolute;
    top: 50%;
    transition: 300ms;
}
.no-scroll{
    overflow: hidden;
}
@media(max-width: 1440px){
    .header-mobile-menu.active .row,
    .header-mobile-menu.active .column{
        height: 100%;
    }
    a.toggle-menu--head.toggle-menu-content {
        display: flex !important;
        align-items: center;
        justify-content: space-between;
    }
    .area-mega-menu-wrapper-mobile.active {
        display: flex;
        gap: 10px;
        flex-direction: column;
        height: 100%;
        transform: translateY(0px);
        overflow: visible;
        opacity: 1;
        visibility: visible;
        transition: 400ms;
        padding: 24px 0;
    }
    .area-mega-menu-wrapper-mobile {
        height: 0;
        transform: translateY(-100px);
        overflow: hidden;
        opacity: 0;
        visibility: hidden;
        transition: 400ms;
    }
    .header-submenu-body .header-menu-item > a, .header-submenu-body .header-menu-item > div > a {
        line-height: unset;
    }
    .header-submenu-body {
        display: flex;
        flex-direction: column;
        transition: 300ms;
        gap: 10px;
    }
    .header-submenu-mobile-wrapper {
        display: flex;
        flex-direction: column;
        height: 100%;
        gap: 50px;
    }
    .area-mega-menu-wrapper-mobile.active .area-submenu-title {
        font-size: 14px;
        margin: 0px;
    }
    .submenu-area-item a {
        display: flex;
        align-items: center;
    }
    .header-mobile-menu.active .column {
        padding-bottom: 250px;
        overflow-y: auto;
    }
}

.search-rsults-item {
    border-bottom: 1px solid #ccc;
}
.search-rsults-item a {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 20px 10px;
    transition: 300ms;
    text-decoration: none;
}
.block-search-label {
    border: 1px solid #B2B1CB;
    width: max-content;
    padding: 6px 15px;
    border-radius: 30px;
    color: #fff;
    font-size: 12px;
    line-height: 1;
    color: #B2B1CB;
}
.search-results-name {
    font-size: clamp(22px, 2.18vw, 42px);
    line-height: 1.3;
    margin-top: 5px;
    color: #333;
}
.search-rsults-item:hover a {
    transition: 300ms;
    background: #b2b1cb4d;
}
.block-search-results {
    margin-top: 40px;
}
.search-rsults-item- {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    gap: 30px;
}
.search-results-wrapper .block--title__50 span {
    opacity: 0.5;
    font-style: italic;
}
@media(min-width: 1025px){
    .search-rsults-item a {
        display: flex;
        flex-direction: column;
        gap: 10px;
        padding: 30px 20px;
        transition: 300ms;
        text-decoration: none;
    }
    .block-search-label {
        border: 1px solid #B2B1CB;
        width: max-content;
        padding: 6px 20px;
        border-radius: 30px;
        color: #fff;
        font-size: 12px;
        line-height: 1;
        color: #B2B1CB;
    }
}
.footer-socials {
    display: flex;
    gap: 10px;
}
.footer-socials svg{
   fill: #B78B61;
}


ul#menu-menu-principale {
    display: flex;
    flex-direction: column;
    gap: clamp(20px, 2.082vw, 40px);
    margin: 0px;
    list-style: none;
}
ul#menu-menu-principale ul.sub-menu {
    visibility: hidden;
    height: 0px;
    opacity: 0;
    transition: 300ms;
    overflow: hidden;
    position: absolute;
    z-index: 99;
    top: 100%;
    list-style: none;
    margin: 0px;
}



.header-main-menu-pages{
    position: relative;
}

.header-actions-wrapper {
    height: 100%;
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

.strong > a {
    font-weight: bold;
}


/**/
.header-wrapper.is-home,
.page-id-11 .header-wrapper {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 9999;
}

.header-wrapper.is-home .small-header-wrapper,
.header-wrapper.is-home .header-main-wrapper,
.page-id-11 .small-header-wrapper{
    background: transparent;
}

.header-wrapper.is-home .header-logo-wrapper svg,
.header-wrapper.is-home .header-logo-wrapper path,
.header-wrapper.is-home .header-logo-wrapper rect,
.page-id-11 .header-logo-wrapper svg,
.page-id-11 .header-logo-wrapper path,
.page-id-11 .header-logo-wrapper rect{
    fill: #fff;
}

.header-wrapper.is-home .small-header-wrapper svg,
.page-id-11 .small-header-wrapper svg{
    fill: #fff;
}

.header-wrapper.is-home span.small-header-separator,
.header-wrapper.is-home .header-separator span,
.page-id-11 span.small-header-separator,
.page-id-11 .header-separator span{
    background: #fff;
}
.header-wrapper.is-home .small-header-wrapper a,
.header-wrapper.is-home .small-header-wrapper,
.header-wrapper.is-home .small-header-contact-item p,
.page-id-11 .small-header-wrapper a,
.page-id-11 .small-header-wrapper,
.page-id-11 .small-header-contact-item p{
    color: #fff !important;
}
.header-wrapper.is-home .header-booking-button a.block--button__link{
    border:1px solid #fff;
    color: #fff;
}
.header-wrapper.is-home .header-booking-button a.block--button__link:hover{
    background: #fff;
    color: #151515;
}

.header-wrapper.is-home ul#menu-menu-principale > li > a {
    color: #fff;
}

.header-main-row {
    padding-top: clamp(19px, 2.603vw, 50px);
}

.header-wrapper.is-home .header-burger-menu span{
    /*background: #fff;*/
}
ul.sub-menu > li > a {
    color: #fff;
    border-bottom: 1px solid #D9010C;
    display: flex;
    line-height: 1;
    padding-bottom: 19px;
}
ul#menu-menu-principale a:hover{
    opacity: 0.7;
    transition: 300ms;
}
.small-header-row, .small-header-row p, .small-header-row a{
    color: #fff;
}

.header-wrapper.is-home .header-main-wrapper.active{
    background: #fff;
}
.header-wrapper.is-home .header-main-wrapper.active .header-logo-wrapper svg,
.header-wrapper.is-home .header-main-wrapper.active .header-logo-wrapper path,
.header-wrapper.is-home .header-main-wrapper.active .header-logo-wrapper rect{
    fill: #B78B61;
}
.header-wrapper.is-home .header-main-wrapper.active .header-burger-menu.active span{
    background: #fff;
}
@media(max-width: 768px){
    .header-logo-wrapper{
        max-width: 200px;
    }
}

.header-mobile-menu ul#menu-menu-principale-1 {
    margin: 0px;
    list-style: none;
    list-style-type: unset;
}

.header-mobile-menu ul#menu-menu-principale-1 > li > a{
    text-decoration: none;
}
.header-mobile-menu ul#menu-menu-principale-1 > li > ul > a{
    text-decoration: none;
}

/* bottone toggle accanto al link */
.header-submenu-mobile-wrapper .menu-item-has-children {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 10px;
    align-items: center;
}
.header-submenu-mobile-wrapper .menu-item-has-children svg, .header-submenu-mobile-wrapper .menu-item-has-children path {
    fill: #151515;
}
.header-submenu-mobile-wrapper .submenu-toggle {
  appearance: none;
  border: 0;
  background: transparent;
  padding: 8px;
  margin-left: 6px;
  line-height: 0;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* rotazione freccia quando aperto */
.header-submenu-mobile-wrapper .menu-item-has-children .submenu-toggle__icon {
  display: inline-flex;
  transition: transform .2s ease;
}

.header-submenu-mobile-wrapper .menu-item-has-children.is-open .submenu-toggle__icon {
  transform: rotate(180deg);
}
.header-submenu-mobile-wrapper .menu-item-has-children ul.sub-menu{
    width: 100%;
}
.header-submenu-mobile-wrapper .menu-item-has-children ul.sub-menu {
    width: 100%;
    text-decoration: none;
    list-style: none;
    margin: 0px;
    padding-bottom: 20px;
}
.header-submenu-mobile-wrapper .menu-item-has-children ul.sub-menu a{
   text-decoration: none;
}


.header-lang-wrapper .gtranslate_wrapper {
    display: flex;
    gap: 8px;
}

.header-logo-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
}
.header-actions {
    display: flex;
    justify-content: flex-end;
    gap: 20px;
    align-items: center;
}

.header-sidemenu {
    /*background: #00000056;*/
    z-index: 9999;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
}

.header-sidemenu-content {
    background: #101010;
    width: clamp(520px, 31.24vw, 600px);
    display: flex;
    height: 100vh;
    position: absolute;
    right: 0;
    transition: 300ms;
    padding: clamp(40px, 3.124vw, 60px) clamp(60px, 5.207vw, 100px);
    flex-direction: column;
    justify-content: space-between;
    overflow-y: auto;
    gap: clamp(35px, 2.603vw, 50px);
}

.header-sidemnu-close span {
    display: flex;
    background: #B78B61;
    width: 50px;
    height: 1px;
    transition: 300ms;
    position: absolute;
    top: 50%;
}

.header-close-wrapper {
    width: 50px;
    height: 50px;
    cursor: pointer;
    transition: 300ms;
    position: relative;
}
.header-close-wrapper span:last-child {
    transform: rotate(-45deg);
}
.header-close-wrapper span:first-child {
    transform: rotate(45deg);
}
.header-sidemnu-close {
    display: flex;
    justify-content: flex-end;
}


.header-sidemenu-content .header-sidebar-contacts, .header-sidemenu-content .header-sidebar-contacts a, .header-sidemenu-content .header-sidebar-contacts p {
    color: #fff!important;
    line-height: 20px;
    text-wrap: balance;
}
.header-sidebar-contact {
    display: flex;
    flex-direction: column;
    gap: 30px;
}
.header-sidebar-contacts {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

ul#menu-menu-principale a {
    font-size: clamp(22px,2.082vw, 40px);
    line-height: 1;
    display: flex;
    text-decoration: none;
    color: #fff;
    transition: 300ms;
    padding-bottom: 19px;
    border-bottom: 1px solid #fff;
}

ul#menu-menu-principale a:hover {
    color: #B78B61;
    transition: 300ms;
    border-bottom: 1px solid #B78B61;
}
.header-sidemenu {
    transition: 300ms;
    transform: translateX(5000px);
}
.header-sidemenu.active {
    transition: 300ms;
    transform: unset;
}
.no-scroll{
    overflow: hidden;
}

.collection-item-wrapper.section--relative h4.block--title__60{
    font-family: 'Montserrat';
}

.page-id-11 .page-header {
    align-items: flex-end;
    justify-content: center;
    display: flex;
}

@media(max-width: 980px){
    .header-sidemenu-content {
        width: 100%;
        padding: 60px 5%;
    }
}

@media(max-width: 1024px){
    .home-hero-cursor{
        display: none;
    }
    .home-hero {
        height: 35vh;
    }
    .home-last-post .row {
        gap: 30px;
    }
}
@media(min-width: 1025px){
    .page-id-11 .page-header{
        padding-bottom: clamp(60px, 9.374vw, 180px);
    }
}
.cms-template .block-content {
    margin-top: 60px;
}

.grecaptcha-badge{visibility:hidden!important}

/* Video carousel */

.video-item-carousel video {
    width: 100%;
    height: 100%;
}

.video-carousel-desktop {
    display: none;
}
.section-wrapper-video ul.splide__pagination.splide__pagination--ltr{
    position: unset;
    margin-top: 40px;
}
.section-wrapper-video ul.splide__pagination.splide__pagination--ltr button{
    width: 15px;
    height: 15px;
}
.section-wrapper-video ul.splide__pagination.splide__pagination--ltr button.is-active{
    background: #B78B61;
}
.section-wrapper-video.section--padding-lg.no-padding-top{
    padding-top: 20px;
}
@media(min-width: 1025px){
   .video-carousel-mobile {
    display: none;
} 
.section-wrapper-video.section--padding-lg.no-padding-top{
    padding-top: 0px;
}
}
@media(min-width: 1025px) and (max-width: 1440px){
    .video-carousel-desktop {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
        gap: 20px;
    }    
}
@media(min-width: 1441px){
    .video-carousel-desktop {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr 1fr;
        gap: 20px;
    }    
}