/*
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(14px, 0.83vw, 16px);
    line-height: clamp(24px,1.35vw, 26px);
    }
   .block--title__26{
      font-size: clamp(22px, 1.34vw, 40px);
      line-height: clamp(30px, 2.49vw, 48px);
   }
   .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, 5.2vw, 100px);
   }
/* --------------------------------------------
   Global
-------------------------------------------- */
html,body{
    scroll-behavior: smooth;
}

#to-the-top {
    display: flex;
    background-color: #11111173;
    width: 50px;
    height: 50px;
    border-radius: 25px 0 0 25px;
    position: fixed;
    bottom: 30px;
    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;
}
.no-padding-top{
   padding-top: 0px!important;
}
@media(max-width: 1024px){
   .no-padding-mobile{
      padding-top: 0px!important;
      padding-bottom: 0px!important;
   }
   .no-padding-top-only-mobile{
      padding-top: 0px!important;
   }
   .no-padding-bottom-only-mobile{
      padding-bottom: 0px!important;
   }
}
/* --------------------------------------------
   Hero
-------------------------------------------- */
.landing-hero-content {
    height: 95vh;
    width: 100%;
}
.landing-hero-content:before{
   content: '';
   height: 100%;
   width: 100%;
   position: absolute;
   top: 0;
   left: 0;
   z-index: 4;
}
.landing-hero-content.dark:before {
    background: #00000040;
}
.landing-hero-content.light:before {
    background: #ffffff40;
}
.landing-hero-desktop-image {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 3;
    display: flex;
}
.landing-hero-desktop-image img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.landing-hero-content-text-wrapper {
    position: relative;
    z-index: 5;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    max-width: clamp(400px, 31.24vw, 600px);
}
.landing-hero-content .row, .landing-hero-content .column {
    height: 100%;
}
.landing-hero-content.centered .landing-hero-content-text-wrapper {
   align-items: center;
   text-align: center;
   margin: 0 auto;
}
.landing-hero-content.left .landing-hero-content-text-wrapper {
    align-items: flex-start;
    margin: 0 auto 0 0;
}
.landing-hero-content.right .landing-hero-content-text-wrapper {
    align-items: flex-end;
    margin:0 0 0 auto;
}
.landing-hero-content-text-wrapper .block--paragraph {
    text-wrap: balance;
    margin-top: 15px;
}
.landing-hero-content.centered .landing-hero-content-text-wrapper .block--title h3,
.landing-hero-content.centered .landing-hero-content-text-wrapper .block--paragraph{
    text-align: center;
    display: flex;
    width: 100%;
}
.landing-hero-content.left .landing-hero-content-text-wrapper .block--title h3,
.landing-hero-content.left .landing-hero-content-text-wrapper .block--paragraph{
    text-align: left;
    display: flex;
    width: 100%;
}
.landing-hero-content.right .landing-hero-content-text-wrapper .block--title h3,
.landing-hero-content.right .landing-hero-content-text-wrapper .block--paragraph{
    text-align: right;
    display: flex;
    width: 100%;
}
.landing-hero-content-text-wrapper .block--button {
    margin-top: 20px;
}

.landing-hero-mobile-image {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 3;
    width: 100%;
    height: 100%;
}

.landing-hero-mobile-image img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}
.landing-hero-content.dark h3,
.landing-hero-content.dark .block--paragraph{
   color: #fff;
}
.landing-hero-content.dark a{
   background: #fff;
   color: #333;
   transition: 300ms;
}
.landing-hero-content.dark a:hover{
   background: #333;
   color: #fff;
   transition: 300ms;
}
.landing-hero-content.light h3,
.landing-hero-content.light .block--paragraph{
   color: #333;
}
.landing-hero-content.light a{
   background: #333;
   color: #fff;
   transition: 300ms;
}
.landing-hero-content.dark a:hover{
   background: #333;
   color: #fff;
   transition: 300ms;
}
.landing-hero-desktop-image.disable-image-on-mobile{
   display: none !important;
}
.landing-hero-section ul.splide__pagination.splide__pagination--ltr {
    bottom: 40px;
    margin: 0px!important;
    padding: 0px!important;
}
@media(min-width: 1025px){
   .landing-hero-mobile-image {
      display: none;
   }
   .landing-hero-desktop-image.disable-image-on-mobile{
      display: flex !important;
   }  
}

/* --------------------------------------------
   Cards module
-------------------------------------------- */
.landing-card-body .block--paragraph {
    text-wrap: balance;
}
.landing-card-item.left * {
    text-align: left;
}
.landing-card-item.center * {
    text-align: center;
}
.landing-card-item.right * {
    text-align: right;
}
.landing-card-item.left .block--card__image.card-icon-choise {
    margin: 0;
}
.landing-card-item.center .block--card__image.card-icon-choise {
    margin: 0 auto;
}
.landing-card-item.right .block--card__image.card-icon-choise {
    margin: 0 0 0 auto;
}
.block--card__image.card-icon-choise {
    max-width: clamp(60px, 5.207vw, 100px);
}

.landing-card-header, .block--card__image {
    display: flex;
}
.landing-card-header{
    margin-bottom: 25px;
}
.block--card__image img{
   width: 100%;
   height: 100%;
}
.landing-card-body {
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.row-landing-card-carousel .column{
    overflow: hidden !important;
}
.landing-card-splide {
    padding-bottom: 60px;
}
@media(min-width: 1025px){
   .landing-card-splide {
      padding-bottom: 80px;
   }
   .row-landing-card-carousel,
   .row-landing-card-carousel .column,
   .row-landing-card-carousel .splide,
   .row-landing-card-carousel .splide__track,
   .row-landing-card-carousel .splide__list {
      overflow: visible !important;
   }  
}
.section.landing-card-section.light * {
    color: #fff!important;
}
.section.landing-card-section.dark * {
    color: #151515!important;
}
.landing-card-item {
    padding: 25px 20px;
}
.landing-card-item.yesBorderRadius {
    border-radius: 20px;
}
.landing-card-section.dark ul.splide__pagination.splide__pagination--ltr button.splide__pagination__page.is-active{
   background: #333;
}
.landing-card-title-wrapper {
    margin-bottom: clamp(40px, 2.603vw, 50px);
}

/* --------------------------------------------
   Text and media block
-------------------------------------------- */

.landing-text-and-media-content-wrapper {
    text-wrap: balance;
    display: flex;
    flex-direction: column;
    gap: 20px;
    max-width: clamp(600px, 36.457vw, 700px);
}
.landing-text-and-media-images-wrapper .block--video iframe,
.landing-text-and-media-images-wrapper .block--video video {
    height: clamp(400px, 31.24vw, 600px);
    object-fit: cover;
}
.landing-text-and-media-section.light h2,
.landing-text-and-media-section.light{
    color: #fff;
}
.landing-text-and-media-section.dark h2,
.landing-text-and-media-section.dark{
    color: #151515;
}
/* --------------------------------------------
   TReview block
-------------------------------------------- */
.review-stars-wrapper {
    display: flex;
    gap: 5px;
    align-items: center;
}
.review-stars-wrapper svg {
    width: 20px;
}
.block--review-author--image {
    display: flex;
    max-width: 80px;
    height: auto;
    overflow: hidden;
    border-radius: 50%;
    margin: 10px 0 20px;
}
.block--review-author--image img{
   width: 100%;
   height: 100%;
   object-fit: cover;
}
.block--review-athor {
    font-weight: bold;
}
.landing-review-item {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 40px 20px;
}
.review-stars-wrapper.gold svg {
    fill: gold;
}
.review-stars-wrapper.dark svg {
    fill: #333;
}
.review-stars-wrapper.light svg {
    fill: #fff;
}
.landing-review-item.center {
    align-items: center;
    text-align: center;
}
.landing-review-item.left {
    align-items: flex-start;
}
.landing-review-item.right {
    align-items: flex-end;
}

.landing-review-item.border-radius-card {
    border-radius: 20px;
}
.landing-review-section .column {
    overflow: hidden;
}
.landing-review-main-title {
    margin-bottom: clamp(40px, 2.603vw, 50px);
}
.landing-manual-review-wrapper .landing-review-splide {
    padding-bottom: 60px;
}
.landing-review-section.dark .landing-manual-review-wrapper ul.splide__pagination.splide__pagination--ltr button.is-active {
    background: #000;
}
.landing-review-item.border-radius-card.center .block--paragraph {
    text-wrap: balance;
}
.landing-review-item.border-radius-card {
    height: 100%;
}
/* --------------------------------------------
   background and text
-------------------------------------------- */

.landing-background-and-text-wrapper {
    display: flex;
    flex-direction: column;
    gap: 10px;
    text-wrap: balance;
    max-width: clamp(600px, 41.666vw, 800px);
}
.landing-background-and-text-section.left .landing-background-and-text-wrapper,
.landing-background-and-text-section.left h3{
   text-align: left;
   margin: 0;
}
.landing-background-and-text-section.center .landing-background-and-text-wrapper,
.landing-background-and-text-section.center h3{
   text-align: center;
   margin: 0 auto;
}
.landing-background-and-text-section.right .landing-background-and-text-wrapper,
.landing-background-and-text-section.right h3{
   text-align: right;
   margin: 0 0 0 auto;
}
.landing-background-and-text-section.light .block--title__40,
.landing-background-and-text-section.light .block--paragraph{
   color: #fff;
}
.landing-background-and-text-section.dark .block--title__40,
.landing-background-and-text-section.dark .block--paragraph{
   color: #151515;
}
.landing-background-and-text-section.dark{
   background-color: #ffffffc9!important;
}
/* --------------------------------------------
   conversion-module
-------------------------------------------- */
.footer-contacts-icon svg {
    width: 20px;
}
.footer-contacts-wrapper {
    display: flex;
    gap: 10px;
}
.footer-column-contacts {
    display: flex;
    flex-direction: column;
    gap: 10px;
}


 .custom-contact-row  .contact_form_grid {
     display: grid;
     grid-template-columns: 1fr;
     gap: 20px;
     margin-bottom: 20px;
}
.custom-contact-row .contact_form_input input,
.custom-contact-row .contact_form_input select,
.custom-contact-row .contact_form_message textarea {
    width: 100%;
    padding: 16px 20px 15px;
    border: none;
    border-bottom: 1px solid #7f7f7f2a;
    background: transparent;
}
.custom-contact-row  .contact_form_message textarea {
     max-height: 80px;
}
.custom-contact-row .contact_form_optin {
     margin: 15px 0;
     display: flex;
     flex-direction: column;
     gap: 5px;
}
.custom-contact-row .contact_form_action {
     margin-top: 40px;
     position: relative;
     display: flex;
     flex-direction: column;
     gap: 20px;
}
.custom-contact-row .contact_form_optin span.wpcf7-list-item {
     margin: 0;
}
.custom-contact-row .contact_form_optin a {
     color: unset;
     text-decoration: underline;
}
.custom-contact-row span.required_span{
     font-weight: bold;
     color: #151515;
}
.custom-contact-row .contact_form_action input {
     background: #151515;
     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;
}
.custom-contact-row .contact_form_action input:hover {
     background: #333;
     color: #fff;
     transition: 300ms;
}
.custom-contact-row .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;
    }
    .custom-contact-row .contact_form_grid {
         grid-template-columns: 1fr 1fr;
    }
}
@media(max-width: 1025px){
    .contact-embed-map {
        display: flex;
        height: 400px;
        /*width: 95%;*/
    }
}
.landing-conversion-content-wrapper {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.landing-conversion-content-wrapper .block--paragraph {
    max-width: clamp(400px, 31.24vw, 600px);
    text-wrap: balance;
}
.footer-column {
    margin: 20px 0;
}
.contact-embed-map iframe {
    width: 100%;
}

/* --------------------------------------------
   Logo autoscroll
-------------------------------------------- */

.landing-logos-autoscroll .block--image{
    max-width: 250px;
}
/* --------------------------------------------
   gallery mosaic
-------------------------------------------- */
.block--image__mansory img {
    width: 100%;
}

/* --------------------------------------------
   header
-------------------------------------------- */
.header-main-wrapper {
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 9999;
    background: #fff;
    padding: 15px 0;
    box-shadow: 0 5px 10px #0000002e;
}
.header-custom-row {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: center;
}
.header-logo-wrapper a {
    display: flex;
}
.header-logo-wrapper {
    max-width: 120px;
    width: 100%;
}
.header-logo-wrapper img{
    width: 100%;
}
.header-cta-wrapper a {
    background: #151515;
    color: #fff;
    display: flex;
    gap: 10px;
    align-items: center;
    padding: 10px 20px;
    text-decoration: none;
    transition: 300ms;
}
.header-cta-wrapper div {
    display: flex;
}
.header-cta-wrapper svg {
    width: 20px;
    fill: #fff;
}

.footer-socials {
    display: flex;
    gap: 8px;
    align-items: center;
}

.footer-socials a {
    display: flex;
}
.footer-socials svg {
    width: 20px;
}

.footer-main-wrapper {
    background: #000;
    color: #fff;
    padding: 80px 0;
}
.footer-main-wrapper a{
    color: #fff;
}
.legal-link-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    margin: 25px 0 0;
}

.custom-footer-menu {
    display: flex;
    gap: 8px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin-bottom: 30px;
}

@media(min-width: 1025px){
    .custom-footer-menu {
        display: flex;
        gap: 8px;
        flex-direction: row;
        justify-content: center;
        align-items: center;
        margin-bottom: 30px;
    }
}
.footer-logo {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 40px;
}
/* --------------------------------------------
   Centered text block
-------------------------------------------- */
.landing-centered-content {
    display: flex;
    flex-direction: column;
    text-align: center;
    align-items: center;
    justify-content: center;
    gap: 10px;
    max-width: clamp(600px, 46.874vw, 900px);
    margin: 0 auto;
}
.landing-centered-content .block--image {
    margin-bottom: 20px;
}
.landing-centered-text-section.light h3,
.landing-centered-text-section.light{
    color: #fff;
}
.landing-centered-text-section.dark h3,
.landing-centered-text-section.dark{
    color: #151515;
}
.landing-logos-autoscroll-section .block--title {
    margin-bottom: clamp(40px, 2.603vw, 50px);
}