@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400;1,500;1,600;1,700;1,800;1,900&family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');
@import url('https://fonts.cdnfonts.com/css/quentin');
#sp-page-builder > div.page-header {position: absolute; top:-99999px}


body, a, p {
    font-family: 'Poppins', sans-serif;
    font-weight:400;

     font-size: clamp(1rem, 1vw + 1rem, 1.2rem);
  line-height: 1.6;
}
#sp-main-body {
    padding: 20px 0;
}

.breadcrumb {
    padding: 15px  0rem;
    background-color: transparent;
    border-radius: 0rem;
    margin: 0px;
}
.price {
       font-family:  'Poppins', sans-serif;
    font-weight: 500;
      font-size: clamp(1rem, 2vw + 1rem, 2rem);
      letter-spacing: 0.1em;
          margin-right:0px;
          color: #ff2f31;
  
}
strong {
    font-family: 'Poppins', sans-serif;
    font-weight:600;
}

.title, h1, h2, h3, h4, h5, h6 {
      font-family:  'Poppins', sans-serif;
      text-transform: uppercase; 

}

h1 {
  /* La dimensione base è 2rem. Cresce in base alla larghezza dello schermo (5vw) ma non supera mai 4rem. */
  font-size: clamp(2rem, 5vw + 1rem, 4rem);
}

h2 {
  /* Dimensioni leggermente più piccole di h1, ma con la stessa logica reattiva. */
  font-size: clamp(1.8rem, 4vw + 1rem, 3.5rem);
}

h3 {
  /* Dimensioni intermedie. */
  font-size: clamp(1.5rem, 3vw + 1rem, 2.8rem);
}

h4 {
  /* Dimensioni simili al testo del corpo ma leggermente più grandi. */
  font-size: clamp(1.2rem, 2vw + 1rem, 2.5rem);
}

h6 {
  /* Dimensioni simili al testo del corpo ma leggermente più grandi. */
  font-size: clamp(0.9rem, 1vw + 1rem, 0.9rem);
  letter-spacing: 0.2em; 
  text-transform: uppercase!important;
  color:#999;
}

.Quentin  {
    font-family: 'Quentin', sans-serif;
font-size: clamp(1.2rem, 2vw + 1rem, 2.5rem);
    white-space:  normal!important;
}

#column-wrap-id-1758099375619 {

    z-index: 2!important;
}
 #section-id-1683121298078 {

    position: relative!important;
    z-index: 9!important;
}

#column-wrap-id-1758099375620 {

    z-index: -1;
}
/* carosello servizi */

#servizi-carosello .sppb-carousel-extended-item img {
  filter: invert(100%) !important;
    width: 100%;
    height: 100%;
    max-height: 100px!important;
    object-fit:  scale-down!important;
    object-position: center;
    -o-object-fit:  scale-down!important;
    -webkit-object-fit:  scale-down!important;
    display: block;
}

#servizi-carosello .sppb-carousel-extended-team-name {
   font-size: clamp(1.2rem, 2vw + 1rem, 1.4rem);
    font-weight: 600;
    text-transform: uppercase;
    color: #eee;
    margin-bottom: 10px;
}

#servizi-carosello .sppb-carousel-extended-team-designation {
     font-size: clamp(1rem, 1vw + 1rem, 1.2rem);
  line-height: 1.6;
  color:#fff
    
    
}
#servizi-carosello .sppb-carousel-extended-team-img {
    width: 20%;
    margin-right: 20px;
    display: flex;
   align-items: center;
}
#servizi-carosello .sppb-carousel-extended-team-content.sppb-carousel-layout3 {
 width: 80%;}
    

.sppb-carousel-extended-dots ul li span {

    background: #fff;
 
}
div.sppb-carousel-extended-dots {
bottom: 0px; 
    height: 20px;
    top: auto; 
}

.sppb-carousel-extended-nav-control .nav-control {
    cursor: pointer;
    text-align: center;
    font-size: 24px;
    border-radius: 3px;
    color: #ccc;
    border: 1px solid #ccc;
    border-radius: 100%;
    transition: .35s;
    
        height: 45px;
    line-height: 45px;
    width: 45px;
}

.sppb-carousel-extended-nav-control .nav-control:hover {
    cursor: pointer;
    text-align: center;
    font-size: 24px;
    border-radius: 3px;
    color: #333;
    border: 1px solid #333;
    border-radius: 100%;
    transition: .35s;
    
        height: 45px;
    line-height: 45px;
    width: 45px;
}

.animated-heading-before-part {
       font-family:  'Poppins', sans-serif;
    font-weight: 500;
    line-height: auto; 
      font-size: clamp(2rem, 3vw + 1.5rem, 4rem);
      letter-spacing: 0.1em;
          margin-right:0px;
          width: 80%;
  
}

 .animated-heading-after-part {
       font-family:  'Poppins', sans-serif;
    font-weight: 500;
      font-size: clamp(1rem, 2vw + 0.8rem, 2rem);
      letter-spacing: 0.1em;
          margin-right:0px;
          width: 100%;
  
}

.animated-text-words-wrapper .animated-text {

      white-space:  normal!important;
 line-height: normal; 
}

.published, .modified, .hits, .autore-sito {
    display:none;
}
 .animated-text-words-wrapper  {
    font-family: 'Quentin', sans-serif;
         font-size: clamp(2rem, 2vw + 2rem, 5rem);
color: #f93531!important;
 display: block;
     width: 80%;
     line-height: auto!important; 
     margin-top: -10px;
    white-space:  normal!important;
}
/*lingua*/




/*top bar*/

#sp-top-bar {
    background: #EC92A2;
    color: #fff;
}

#sp-top-bar a {
   color:#fff
}



#sp-main-body {
    
}

.sp-contact-info {

}

.sp-contact-info li {

}

/*header */


#sp-header.lg-header .logo {

}
.itemid-101 .logo-image {
filter: invert(100%)!important;
}

.logo-image-white {
filter: invert(100%)!important;
}



.logo-image {


}

#sp-header .logo {
    height: 100px;

}


#sp-header {

height: 45px;
    background: rgb(255, 255, 255, 0.9);

}

#sp-header-topbar .container-inner {
    border-bottom: 0px solid #e5e5e5;
}
.itemid-101 #sp-header {
    height: 45px;
     background: transparent; 
}
#sp-header {
    height: 45px;
     background: #000; 
}

.itemid-101 #sp-header-topbar {background: transparent;  }

#sp-header-topbar {background: #fff  }
#sp-header.header-sticky {

     background: rgb(255, 255, 255, 0.8); 
}
#sp-header.lg-header {
    box-shadow: 0 2px 3px rgba(0, 0, 0, 0);
}

#sp-header.header-sticky.lg-header {
    box-shadow: 0 2px 3px rgba(0, 0, 0, 0.1);
}
/*menu offcanvas*/



/*menu*/

.sp-megamenu-parent>li>a, .sp-megamenu-parent>li>span {
    display: inline-block;
    padding: 0 15px;
       font-family: 'Poppins', sans-serif;
font-size: 14px;
letter-spacing: 0.1em;
line-height: 45px;
    font-weight: 600!important;
 margin: 0;
    text-transform: uppercase;
}



#sp-header .sp-megamenu-parent>li>a,#sp-header  .sp-megamenu-parent>li.active>a,#sp-header  .sp-megamenu-parent>li.active:hover>a, #sp-header  .sp-megamenu-parent>li a:active  {
    color: #fff;
    

}

#sp-header.header-sticky .sp-megamenu-parent>li>a,#sp-header.header-sticky  .sp-megamenu-parent>li.active>a,#sp-header.header-sticky  .sp-megamenu-parent>li.active:hover>a, #sp-header.header-sticky  .sp-megamenu-parent>li a:active  {
    color: #000;
    

}
.sp-megamenu-parent>li a:hover{color:#EC92A2;}

.sp-megamenu-parent>li:last-child>a {
    padding: 0px 7px 0px 15px;
}

/*bottoni*/
.bfQuickMode .bfbs5-btn, .bfQuickMode .btn {
  font-size: 16px!important; 
}

.btn-primary, .sppb-btn-primary {
    background:#ff2f31 !important;
    border:#ff2f31 !important;
    color:#fff;
        border:1px solid #ff2f31 !important;

}

.btn-primary:hover, .sppb-btn-primary:hover {
    background:transparent !important;
    border:1px solid #ff2f31 !important;
    color:#ff2f31;
}


.sppb-btn-secondary {
    color: #000;
    background-color: #eee;
    border-color: #eee;
}


.sppb-btn-secondary:hover, .sppb-btn-secondary:hover {
    background:transparent !important;
    border:1px solid #eee !important;
    color:#eee;
}

.sppb-btn-info {
    color: #909196;
    background-color: transparent;
    border-color: #909196
}



.sppb-btn-info:hover {
    color: #f93531;
    background-color: transparent;
    border-color: #f93531
}

/*footer and bottom*/

#sp-bottom .sp-module .sp-module-title {
}


#sp-footer , #sp-bottom {
background:#222!important
  color:#fff;
}






/*home*/


/*contatti*/


/* CSS BOOTSTRAP SPECIFICI */


.pricelist-point-zero {
  font-size: 100%; 
}
.sppb-carousel-extended-item img {
     width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    -o-object-fit: cover;          /* vecchi Opera */
    -webkit-object-fit: cover;     /* Safari */
    display: block;      
}
.sppb-carousel-extended-item {

    border-radius: 0%!important;
}

.animated {
    animation-duration: 2.5s!important;
    animation-iteration-count: infinite!important;
}

.bounce {
    -webkit-animation-name: bounce;
    animation-name: bounce;
    -webkit-transform-origin: center bottom;
    -ms-transform-origin: center bottom;
    transform-origin: center bottom;
}


.burger-icon>span {
  
    background-color: #fff;

}
.header-sticky .burger-icon>span {
  
    background-color: #000;

}

.sp-contact-info li {
    display: inline-block;
    margin: 0px 10px 0px 0px;
    font-size: 90%;
    white-space: normal!important;
}

/* Wrapper centrato */
#servizi-carosello .carousel-controls-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 25px;
    margin-top: 0px;
    position: relative;
}

/* Frecce più grandi e bianche */
#servizi-carosello .prev-control i,
#servizi-carosello .next-control i {
    font-size: 40px;
    color: #fff;
    transition: color 0.3s ease;
    cursor: pointer;
}

#servizi-carosello .prev-control i:hover,
#servizi-carosello .next-control i:hover {
    color: #ccc; /* grigio in hover */
}

/* Dots visibili e allineati */
#servizi-carosello .sppb-carousel-extended-dots {
    display: flex !important;
    gap: 10px;
    order: 2;
}

#servizi-carosello .sppb-carousel-extended-dots li {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: #fff;
    opacity: 0.5;
    transition: opacity 0.3s ease, transform 0.3s ease;
}

#servizi-carosello .sppb-carousel-extended-dots li.active {
    opacity: 1;
    transform: scale(1.2);
    background: #ccc; /* dot attivo grigio */
}

.sppb-carousel-extended-dots, .sppb-carousel-extended-nav-control {
    position: relative; 
    height: 1px;
     width: auto; 
    z-index: 3;
    top: 0;
    bottom: 0;
     margin:0px 10px; 
}
/* Ordine frecce */
#servizi-carosello .prev-control { order: 1; }
#servizi-carosello .sppb-carousel-extended-dots { order: 2; }
#servizi-carosello .next-control { order: 3; }
/* MOBILE */
@media  screen and (max-width: 767px){
  
   #servizi-carosello .sppb-carousel-extended-item {
    height: auto;
}
  /* Disposizione su due righe e titolo più piccolo per tutti i layout */
  #servizi-carosello .sppb-carousel-extended-team-wrap {
    display: block!important;
    flex-direction: column!important;
    align-items: center; /* Centra l'immagine e il titolo */
}

  #servizi-carosello .sppb-carousel-extended-team-img {
    margin-bottom: 10px; /* Aggiunge spazio sotto l'immagine */
}

/* This rule will ensure the title and description are also stacked */
#servizi-carosello .sppb-carousel-extended-team-content {
    display: flex;
    flex-direction: column;
    text-align: center;
}

  #servizi-carosello .sppb-carousel-extended-team-name {
    font-size: 14px; /* Rende il titolo più piccolo, puoi regolare il valore */
    text-align: center;
}

#servizi-carosello .sppb-carousel-extended-team-img {
    width: 100%;
    margin-right: 0px; justify-content: center;
}

#servizi-carosello .sppb-carousel-extended-team-content.sppb-carousel-layout3 {
    width: 100%;
}
  /* Stile mobile per #servizi-carosello */

  #servizi-carosello .sppb-carousel-extended-list,
  #servizi-carosello .sppb-carousel-extended-outer-stage {
    display: flex;
    flex-wrap: wrap;
    transform: none !important;
    width: 100% !important;
    height: auto !important;
  }

  #servizi-carosello .sppb-carousel-extended-item {
    width: 50% !important; /* 2 colonne */
    margin: 0 !important;
    box-sizing: border-box;
    padding: 10px;
  }

  /* Solo icona e titolo */
  #servizi-carosello .sppb-carousel-extended-team-designation {
    display: none;
  }

  #servizi-carosello .sppb-carousel-extended-team-content {
    text-align: center;
  }

  /* Nascondo frecce e dots */
  #servizi-carosello .sppb-carousel-extended-nav-control,
  #servizi-carosello .sppb-carousel-extended-dots, #servizi-carosello .carousel-controls-wrapper {
    display: none !important;
  
}

.itemid-101 #sp-header.header-sticky  {
    height: 45px;

}

 #sp-header.header-sticky   #offcanvas-toggler {
        height: 45px;
        line-height: 45px;
    }

#sp-header {
    height: 60px;
    background: #000;
}
.header-sticky .logo-image {
      height: 36px!important;
      filter: invert(0%) !important;
    }
    
 
   #sp-header .logo {
    height: 45px!important;
} 
    #sp-logo{
        height: 45px!important;
      
    }
.logo-image {
        height: 46px!important;
      filter: invert(100%) !important;
    }

}
/* IPAD VERTICALE */
@media (min-width: 768px) and (max-width: 1023px){

    .sp-megamenu-parent>li>a, .sp-megamenu-parent>li>span {
        display: inline-block;
        padding: 0 5px;
    }
    
    .itemid-101 #sp-header.header-sticky  {
    height: 65px;

}
.sp-megamenu-parent>li>a, .sp-megamenu-parent>li>span
 {
 
    font-size: 14px;
    letter-spacing: 0.1em;
    line-height: 65px;

}
 #sp-header.header-sticky   #offcanvas-toggler {
        height: 65px;
        line-height: 65px;
    }

#sp-header {
    height: 60px;
    background: #000;
}
.header-sticky .logo-image {
      height: 36px!important;
      filter: invert(0%) !important;
    }
    
 
   #sp-header .logo {
    height: 65px!important;
} 
    #sp-logo{
        height: 65px!important;
      
    }
.logo-image {
        height: 46px!important;
      filter: invert(100%) !important;
    }
}


/* IPAD ORIZZONTALE e IPAD PRO VERTICALE */
@media (min-width: 1024px) and (max-width: 1365px){
 .itemid-101 #sp-header.header-sticky  {
    height: 65px;

}
.sp-megamenu-parent>li>a, .sp-megamenu-parent>li>span
 {
 
    font-size: 14px;
    letter-spacing: 0.1em;
    line-height: 65px;

}
 #sp-header.header-sticky   #offcanvas-toggler {
        height: 65px;
        line-height: 65px;
    }

#sp-header {
    height: 60px;
    background: #000;
}
.header-sticky .logo-image {
      height: 36px!important;
      filter: invert(0%) !important;
    }
    
 
   #sp-header .logo {
    height: 65px!important;
} 
    #sp-logo{
        height: 65px!important;
      
    }
.logo-image {
        height: 46px!important;
      filter: invert(100%) !important;
    }


}


/* IPAD PRO ORIZZONTALE */
@media (min-width: 1365px) and (max-width: 1659px){
}

@media (min-width: 1650px){
}

/* ------------------------------------------------------------------------------------ */

.cc-revoke.cc-top {
    right: 0!important;
    font-size: 12px;
    top: auto!important;
    bottom: 0!important;
    border-bottom-left-radius: 0!important;
    border-bottom-right-radius: 0!important;
}