/*
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

*/


.grecaptcha-badge{visibility:hidden!important}
/* --------------------------------------------
   Typografy
-------------------------------------------- */
body{
    font-size: clamp(14px, 0.83vw, 16px);
    line-height: clamp(30px,1.666vw, 32px);
    }
    h1,h2,h3,h4,h5,h6{
      font-family: "Hanken Grotesk", sans-serif;
      font-weight: 300;
      text-transform: uppercase;
    }
    .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
-------------------------------------------- */
#to-the-top {
    display: flex;
    background-color: #11111173;
    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;
}

/* --------------------------------------------
   Header
-------------------------------------------- */


/* --------------------------------------------
   Footer
-------------------------------------------- */
.footer-main-wrapper {
    background: #fff;
    padding: 50px 0;
}

.footer-content-custom-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: clamp(60px,5.207vw, 100px);
}
.footer-menu-informations {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    row-gap: clamp(40px,3.124vw, 60px);
}

.footer-menu-wrapper {
    padding-top: clamp(40px,3.124vw, 60px);
    border-top: 1px solid #707070;
}
.footer-menu-wrapper ul{
    list-style-type: none;
    flex-direction: column;
    margin: 0px;
    display: flex;
    gap: 10px;
}
.footer-menu-wrapper li{
    line-height: 1;
}
.footer-menu-wrapper a,.footer-customer-service{
   font-size: clamp(16px, 0.937vw, 18px);
   transition: 300ms;
   display: flex;
   text-transform: uppercase;
   text-decoration: none;
   color: #161615;
   font-weight: 300;
}
.footer-menu-wrapper a:hover{
   transition: 300ms;
   color: #000;
   text-decoration: underline;
}
.footer-newsletter-content h5 {
    text-transform: uppercase;
    font-size: clamp(24px, 1.353vw, 26px);
}
.footer-newsletter-content .block--paragraph {
    margin: 15px 0;
    max-width: clamp(380px, 19.582vw, 376px);
    line-height: 26px;
}
.block--footer-form{
   max-width: clamp(380px, 19.582vw, 376px);
}
.bottom-footer-row {
    margin-top: clamp(50px, 3.124vw, 60px);
}
.bottom-footer-text {
    font-size: clamp(12px,0.728vw, 14px);
    line-height: 18px;
    font-style: italic;
    color: #161615;
}
.bottom-footer-text a{
   transition: 300ms;
   text-decoration: none;
   color: #161615;
}
.bottom-footer-text a:hover{
   transition: 300ms;
   text-decoration: underline;
   color: #000;
}
.footer-logo, .footer-logo a {
    display: flex;
    width: 100%;
}
.footer-logo svg {
    width: 100%;
    height: 100%;
}
@media(min-width: 1025px){
   .footer-logo svg {
      max-width: clamp(280px, 15.624vw, 300px);
   }
   .footer-logo a {
      justify-content: flex-end;
   }
}
@media(min-width: 1181px){
   .footer-menu-wrapper {
      padding-top: 20px;
   }
   .footer-content-custom-row {
      grid-template-columns: 1fr 2fr;
   }
   .footer-menu-informations {
      grid-template-columns: 1fr 1fr 1fr;
   }
}
@media(min-width: 1441px){
   .footer-content-custom-row {
      grid-template-columns: 1fr 1fr;
   }
}

.block--subtitle{
   text-transform: uppercase;
   color: #161615;
   font-size: clamp(16px, 0.937vw, 18px);
   margin-bottom: clamp(6px, 0.520vw, 10px);
}


/* --------------------------------------------
   ContactForm
-------------------------------------------- */
 .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%;
     padding: 14px 20px;
     border: none;
     border-bottom: none;
     background: #EFEFEF;
}
 .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: #161615;
}
.contact_form_action input {
    background: transparent;
    padding: clamp(15px,1.301vw, 25px) clamp(25px,1.562vw, 30px);
    border: 1px solid #000;
    color: #161615;
    text-transform: uppercase;
    max-width: max-content;
    transition: 300ms;
    cursor: pointer;
    border-radius: 0px;
    min-width: clamp(200px, 13.020vw, 250px);
    line-height: 1;
}
 .contact_form_action input:hover {
     background: #161615;
     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;
    }
}

.prefooter-block-form-content h4 {
    text-wrap: balance;
}
.prefooter-form-wrapper {
    margin-top: 25px;
}


/* --------------------------------------------
   Home
-------------------------------------------- */
.background-section, .background-section h4,.background-section .block--subtitle {
    color: #fff;
}
.background-section .background-section-text-wrapper {
    max-width: clamp(400px, 31.77vw, 610px);
    margin: 0 auto;
}
.background-section .block--paragraph {
    margin-top: 15px;
}

.background-section .block--paragraph {
    text-wrap: balance;
}
.background-section-text-wrapper .block--button {
    margin: 30px auto 0;
}
@media(min-width: 1025px){
   .background-section-text-wrapper .block--button {
      margin: 50px auto 0;
   }
}
.block--carousel-controls {
    display: flex;
    gap: clamp(25px, 2.082vw, 40px);
    align-items: center;
}
.block--carousel-controls div {
    display: flex;
}
.block--carousel-controls svg {
    width: clamp(15px, 1.822vw, 35px);
    cursor: pointer;
    transition: 300ms;
}
.block--carousel-controls svg:hover {
    opacity: 0.5;
    transition: 300ms;
}
.block--carousel-control {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.carousel-section-text .block--paragraph {
    margin-top: 15px;
}
.carousel-section-text .block--carousel-control {
    margin-top: clamp(40px, 2.603vw, 50px);
}
.carousel-section-text {
    max-width: clamp(600px, 35.937vw, 690px);
}
/*.carousel-section .row-carousel-gallery,
.carousel-section .row-carousel-gallery .splide__track{
   overflow: visible;
}*/
.carousel-section .row-carousel-gallery{
    margin: 0 5%;
}
.carousel-with-gallery-carousel .block--image img{
    width: 100%;
}
@media(min-width: 1025px){
    .carousel-with-gallery-carousel .block--image {
        max-width: clamp(500px,36.457vw, 700px);
    }
    .carousel-section .row-carousel-gallery{
        margin: 0;
    }
    .carousel-section .row-carousel-gallery .column:first-child{
        margin: 0 5%;
    }
   .carousel-section .row-carousel-gallery{
      margin-left: 5%;
   }
   .carousel-section .row-carousel-gallery .column:first-child{
       margin: 0;
   }
}


/* Attribute block */
.attribute-block-wrapper .block--image {
    position: relative;
    top: 0;
    left: 0;
    transition: 300ms;
    z-index: 2;
    overflow:hidden;
}
.attribute-block-wrapper.section--relative img {
    width: 100%;
    transition: 800ms;
    object-fit: cover;
}
.attribute-block-text {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
    transform: translateY(1.2%);
}
.attribute-block-wrapper:before {
    display: flex;
    content: '';
    background: #00000014;
    z-index: 3;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    position: absolute;
}
.attribute-block-text .block--title h3 {
    color: #fff;
}
.attribute-block-wrapper:hover img {
    transition: 1s;
    transform: scale(1.10);
}
.row-attribute-block-desktop {
    gap: 10px;
}
.attribute-block ul.splide__pagination {
    margin: 40px 0 0;
    padding: 0;
    display: flex;
    gap: 5px;
    position: unset;
}
.attribute-block ul.splide__pagination button{
    width: 15px;
    height: 15px;
}
.attribute-block button.splide__pagination__page.is-active{
    background: #151515;
}

.row-attribute-block-desktop { display: grid; }
.row-attribute-block-mobile  { display: none; }

@media(max-width: 1024px){
    .attribute-block-wrapper h3 {
        font-size: clamp(60px, 4.166vw, 80px);
        line-height: clamp(30px, 2.603vw, 50px);;
    }

    .attribute-block-text .block--title {
        margin-bottom: 10px;
    }
    /*.attribute-block-text{
        padding-bottom: 80px;
    }*/
    .row-attribute-block-desktop { display: none; }
    .row-attribute-block-mobile  { display: grid; }

    .attribute-block-wrapper.section--relative img {
        width: 100%;
        transition: 800ms;
        object-fit: cover;
        min-height: clamp(500px, 31.24vw, 550px);
    }
}
.attribute-block-wrapper.section--relative a {
    background: #0000001c;
    display: flex;
    height: 100%;
    width: 100%;
    position: absolute;
    top: 0;
    z-index: 9;
    text-decoration: none;
}
.block--title__144 {
    font-size: clamp(32px, 7.49vw, 144px);
    line-height: clamp(20px, 5.207vw, 100px);
}
.attribute-block-text h3 {
    font-weight: bold;
}
.attribute-block-mobile .attribute-block-text {
    position: absolute;
    top: 0;
    background: #00000012;
    width: 100%;
    height: 100%;
    z-index: 99;
}

.two-column-text .block--paragraph {
    max-width: clamp(600px, 35.416vw, 680px);
    margin: 15px 0 0;
}
.two-column-text .block--button{
    margin: 50px 0 0;
}

@media(min-width: 1025px){
    .custom-margin-home .two-column-text {
        max-width: clamp(600px, 35.416vw, 680px);
        margin: 0 auto;
    }
    .two-column-text .block--title {
        max-width: clamp(780px, 44.791vw, 860px);
        text-wrap: balance;
    }
}



.home-hero .splide__slide{
   width: 100%;
}
.hero-slide-content {
    position: relative;
    width: 100%;
}
.home-slide-media-wrapper {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 5;
}
.home-slide-media-wrapper img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}
.hero-text-wrapper {
    position: relative;
    z-index: 7;
    max-width: 1720px;
    width: 90%;
    margin: 0 auto;
    height: 100vh;
    padding-top: clamp(60px, 7.80vw, 150px);
    padding-bottom: clamp(60px, 7.80vw, 150px);
}
.hero-slide-content:before {
    content: '';
    width: 100%;
    height: 100%;
    background: #000000;
    position: absolute;
    display: flex;
    top: 0;
    left: 0;
    z-index: 6;
    opacity: 0.4;
}
.hero-text-content {
    display: flex;
    flex-direction: column;
    height: 100%;
    justify-content: flex-end;
    transition: 300ms;
    padding-bottom: 20%;
}
.hero-slide-content .block--title__60{
    color: #fff;
}

.block--title__90 {
    font-size: clamp(38px, 4.68vw, 90px);
    line-height: clamp(38px, 4.68vw, 90px);
}
/*.block--subtitle {
    color: #B79E80;
    font-size: clamp(18px, 1.14vw, 22px);
    text-transform: uppercase;
    margin-bottom: 5px;
}*/
.hero-slide-content .block--subtitle {
    /*font-size: clamp(18px, 1.45vw, 28px);*/
}
.hero-text-content .block--button {
    margin-top: clamp(30px, 2.082vw, 40px);
}


.home-hero ul.splide__pagination button {
    background: transparent;
    border: 1px solid #fff;
    width: 15px;
    height: 15px;
    transition: 300ms;
}
.home-hero button.splide__pagination__page.is-active {
    transition: 300ms;
    background: #fff;
}
.home-hero ul.splide__pagination {
    bottom: 40px;
    left: 0!important;
    display: flex;
    flex-direction: row;
    gap: 5px;
    justify-content: flex-start;
    align-items: flex-end;
    padding-top: 30px;
    padding-left: 5%;
}
.block--video, .block--video video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

@media(min-width: 1025px){
   .hero-text-content {
      max-width: clamp(600px, 38.53vw, 740px);
   }
   .home-hero ul.splide__pagination {
      padding: 0px;
      right: 5%!important;
      left: unset;
      display: flex;
      flex-direction: row;
      bottom: clamp(60px, 7.80vw, 150px);
      gap: 5px;
      justify-content: flex-end;
   }
   .hero-text-content {
      justify-content: flex-end;
      padding-bottom: 0px;
      
   }
}
@media(min-width: 1921px){
   .hero-text-wrapper {
      width: 95%;
   }
}

.hero-text-content .block--subtitle {
    margin-bottom: 5px;
    color: #fff;
}
.hero-text-content .block--subtitle h5{
    
}
.hero-text-content .block--paragraph {
    color: #fff;
    max-width: clamp(500px, 27.864vw, 535px);
    margin-top: 15px;
}
.section.home-hero .column{
   overflow: hidden;
}
.home-slide-media-wrapper .mobile-version-avaible img.desktop-image{
    display: none;
}
.home-slide-media-wrapper img.mobile-image{
    display: block;
}
@media(min-width: 1025px){
    .home-slide-media-wrapper .mobile-version-avaible img.desktop-image{
        display: block;
    }
    .home-slide-media-wrapper img.mobile-image{
        display: none;
    }
   .custom-home-width .block--title {
      max-width: clamp(800px, 44.791vw, 860px ) !important;
   }
}

.only-bg {
    min-height: clamp(450px, 28.645vw, 550px);
}

.row-carousel-cards .carousel-text-header-wrapper {
    max-width: clamp(500px, 28.645vw, 550px);
    text-wrap: balance;
}
.card-carousel-counter {
    font-size: clamp(60px, 5.207vw, 100px);
    line-height: 1;
    font-family: 'Hanken Grotesk';
    font-weight: 900;
    color: white;
    background-color: white;
    text-shadow: -2px -2px 0 #000, 2px -2px 0 #000, -2px 2px 0 #000, 2px 2px 0 #000;
}

.card-carousel-item {
    display: flex;
    flex-direction: column;
    gap: 10px;  
}




.carousel-section-single-cards {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 100%;
}
.card-carousel-slider-wrapper {
    margin-top: clamp(60px, 10.416vw, 200px);
}
.card-carousel-slider-wrapper .block--carousel-controls {
    margin-top: 60px;
}
.carousel-section-single-cards{
    padding: 0 5%;
}
.row-carousel-cards .column {
    overflow: hidden;
}
.card-carousel-slider-wrapper .block--carousel-controls{
    display: none;
}

@media(min-width: 1025px){
    .card-carousel-slider-wrapper .block--carousel-controls{
        display: flex;
    }
    .carousel-section-single-cards{
        padding: 0;
    }
    .row-carousel-cards{
        grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    }
    .card-carousel-item {
        max-width: 30.208vw;
        display: flex;
        flex-direction: column;
        gap: 10px;
    }
}

.carousel-section-single-cards ul.splide__pagination.splide__pagination--ltr {
    position: unset;
    margin: 30px 0 0;
    padding: 0px;
}
.carousel-section-single-cards ul.splide__pagination.splide__pagination--ltr button{
    background: transparent;
    border: 1px solid #151515;
    width: 15px;
    height: 15px;
}
.carousel-section-single-cards ul.splide__pagination.splide__pagination--ltr button.is-active{
    background: #151515;
    border: 1px solid #151515;
}

@media(max-width: 1024px){
    .no-padding-bottom-on-mobile{
        padding-bottom: 0px;
    }
}



.repeated-icon-text {
    text-align: center;
    text-transform: uppercase;
    margin-top: 20px;
}
.icon-wrapper {
    display: flex;
    max-width: clamp(70px, 4.687vw, 90px);
    margin: 0 auto;
    height: clamp(70px, 4.687vw, 90px);
}
.repeated-icon {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    position: relative;
}

.row-icons-desktop{
   display: none;
}
.row-icon-mobile{
   display: grid;
}
.row-icon-mobile ul.splide__pagination.splide__pagination--ltr {
    position: unset;
    margin: 30px 0 0;
    padding: 0px;
}
.row-icon-mobile ul.splide__pagination.splide__pagination--ltr button.is-active{
    background: #151515;
}
.row-icon-mobile ul.splide__pagination.splide__pagination--ltr button{
    width: 15px;
    height: 15px;
    border:1px solid #151515;
    background: transparent;
}
.row-icon-mobile .column{
   overflow: hidden;
}
@media(min-width: 1181px){
   .row-icon-mobile{
      display: none;
   }
   .row-icons-desktop{
      display: grid;
   }
   .repeated-icon:after {
      content: '';
      display: flex;
      background: #151515;
      height: clamp(100px, 8.853vw, 170px);
      width: 1px;
      position: absolute;
      right: 0;
      top: 50%;
      transform: translate(50%, -50%);
   }
   .section.section-with-icons.section--padding-md .row .column:last-child .repeated-icon:after {
     display: none;
   }
}

.section-with-icons {
    background: #f8f8f8;
}

.repeated-icon .block--paragraph {
    max-width: clamp(300px, 23.437vw, 450px);
    text-align: center;
    margin: 10px auto 0;
}
.carousel-section-single-image img {
    width: 100%;
}

.section-with-icons:before{
    content: '';
    height: 100%;
    width: 100%;
    position: absolute;
    display: flex;
    z-index: 3;
    
}
.section-with-icons:before{
    top: 0;
    box-shadow: inset 0 0 15px #00000063;
}
.row-icon-mobile, .row-icons-desktop {
    position: relative;
    z-index: 10;
}
@media(max-width: 1024px){
    .custom-remove-image .column:first-child {
        display: none;
    }
}

.custom-padding-for-centered-text {
    padding-top: clamp(80px,10.416vw, 200px);
    padding-bottom: clamp(60px,7.812vw, 150px);
}
.centered-text-wrapper {
    max-width: clamp(550px, 34.374vw, 660px);
    margin: 0 auto;
}
.centered-text-wrapper .block--title {
    text-wrap: balance;
}
.centered-text-wrapper .block--paragraph {
    margin-top: 15px;
}


.catalogs-list-wrapper {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
}
@media(min-width: 1024px){
    .catalogs-list-wrapper {
		display: grid;
		grid-template-columns: 1fr 1fr;
		gap: 10px;
		overflow: hidden;
	}
}
.catalogs-list-wrapper .attribute-block-text {
    height: 100%;
    position: absolute;
    top: 0;
    z-index: 9;
}
.catalog-pagination {
    max-width: 90%;
    margin: 40px auto 0;
    display: flex;
    gap: 10px;
    justify-content: center;
    font-size: 18px;
}
.catalog-pagination a{
    text-decoration: none;
    color: #151515;
}

.single-catalog-wrapper .block--button.block--button--primary svg {
    width: 25px;
    height: 25px;
    transition: 300ms;
}
.single-catalog-wrapper .block--button.block--button--primary:hover svg {
    fill: #fff;
    transition: 300ms;
}
.single-catalog-wrapper .block--button.block--button--primary a {
    align-items: center;
    display: flex;
    gap: 10px;
}

.single-catalog-wrapper .block--button.block--button--primary {
    margin: 30px auto 0;
}
.custom-padding-for-centered-text.single-catalog-wrapper{
    border-bottom: 1px solid #ccc;
}

@media(min-width: 1025px){
    .carousel-section-single-image {
        max-width: 90%;
    }
}
.hero-text-wrapper .block--button a:hover {
    background: #fff;
    border: 1px solid #fff;
    color: #151515;
}

.catalog-request-text-wrapper h1.block--title__40 {
    text-wrap: balance;
}
.catalog-request-text-wrapper .block--registration-form {
    margin-top: 40px;
}
.form-grid-sistem {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.form-grid-sistem input{
    background: #EFEFEF;
    width: 100%;
    padding: 8px 15px;
    border: none;
}
label.field.field--checkbox {
    display: flex;
    gap: 9px;
    max-width: max-content;
    line-height: 1.2;
}
label.field.field--checkbox {
    margin: 25px 0 0;
}
.required-field{
    margin-bottom: 35px;
}

form.b2b-register-form button {
    min-width: 200px;
    padding: 16px 20px;
    text-transform: uppercase;
    background: transparent;
    border: 1px solid #151515;
    color: #151515;
    transition: 300ms;
}

form.b2b-register-form button:hover {
    transition: 300ms;
    background: #151515;
    border: 1px solid #151515;
    color: #fff;
}
form.b2b-register-form a {
    color: unset;
}
.single-catalog .prefooter-block.section--padding-lg {
    display: none;
}
.b2b-message.b2b-message--success {
    line-height: 1.3;
    text-align: center;
    padding: 10px;
    text-wrap: balance;
    margin-bottom: 30px;
    background: #65d165;
    color: #151515;
    font-weight: bold;
}
.b2b-message.b2b-message--error {
    line-height: 1.3;
    text-align: center;
    padding: 10px;
    text-wrap: balance;
    margin-bottom: 30px;
    background: #d1ce65;
    color: #151515;
    font-weight: bold;
}
.contact-page-informations {
    display: flex;
    gap: 20px;
    align-items: center;
    margin-bottom: 20px;
    flex-direction: column;
}
.contact-page-informations .contact a {
    display: flex;
    gap: 6px;
    text-decoration: none;
    color: #151515;
    line-height: 1;
}
.contact-page-informations .contact svg {
    width: 18px;
}

@media(min-width: 1025px){
    .contact-page-informations {
        display: flex;
        gap: 20px;
        align-items: center;
        margin-bottom: 20px;
        flex-direction: row;
    }
    .custom-contact-row .two-column-text {
        margin-left: 5%;
    }
}
@media(max-width: 1024px){
    .reverse-only-mobile .row {
        display: flex;
        flex-direction: column-reverse;
    }
    .contact {
        width: 100%;
    }
}
.custom-contact-row .row {
    align-items: flex-start;
}


/*------------ header */
.header-social a {
    display: flex;
    transition: 300ms;
}
.header-social a:hover {
    opacity: 0.6;
    transition: 300ms;
}
.header-social svg{
    width: 24px;
    transition: 300ms;
}


.header-actions {
    display: flex;
    gap: 20px;
    align-items: center;
}
.header-lang-selector .gt_float_switcher{
    box-shadow: unset!important;
}
.header-lang-selector .gt_float_switcher .gt_options{
    position: absolute;
}
.header-lang-selector .gt-current-lang {
    padding: 0px!important;
    font-size: 15px!important;
}

.desktop-menu-wrapper ul {
    display: flex;
    list-style: none;
    gap: clamp(20px, 1.562vw, 30px);
    align-items: center;
    margin: 0px;
}
.desktop-menu-wrapper ul > li > a {
    text-decoration: none;
    color: #161615;
    text-transform: uppercase;
    font-weight: 300;
    font-size: clamp(14px, 0.937vw, 18px);
}



.header-logo-wrapper,.header-logo-wrapper a{
    display: flex;
}
.header-logo-wrapper svg {
    width: 100%;
    max-width: clamp(160px, 9.895vw, 190px);
    height: 100%;
}
.header-actions {
    display: flex;
    justify-content: flex-end;
}

.header-actions .gt_float_switcher img {
    width: 20px;
}
.header-actions div#gt_float_wrapper {
    display: flex;
}
.header-actions .gt_options.gt-open {
    padding: 0px!important;
    box-shadow: 0 10px 10px #0000001a;
}


.burger-action-wrapper {
    width: 25px;
    display: flex;
    flex-direction: column;
    cursor: pointer;
    transition: 300ms;
    position: relative;
    gap: 5px;
}
.burger-action-wrapper span {
    width: 25px;
    display: flex;
    height: 1px;
    background: #151515;
}
.header-content-grid .header-action-separator {
    display: none;
}
.header-content-grid .header-social {
    display: none;
}
.header-content-grid .header-lang-selector{
    display: none;
}
.header-content-grid .desktop-menu-wrapper{
    display: none;
}
.header-content-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    align-items: center;
}
.header-logo-wrapper {
    display: flex;
}
.header-content-grid {
    padding: clamp(20px, 4.687vw, 90px) 0 20px;
}
@media(min-width: 1181px){
    .header-logo-wrapper {
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .header-content-grid {
        display: grid;
        grid-template-columns: 35% 26% 35%;
        gap: 2%;
        align-items: center;
    }
    .header-content-grid .desktop-menu-wrapper{
        display: block;
    }
    .header-content-grid .header-lang-selector {
        display: flex;
        gap: 12px;
        align-items: center;
    }
    .header-content-grid .header-social {
        display: flex;
        align-items: center;
        gap: 10px;
    }
    .header-content-grid .burger-action-wrapper {
        display: none;
    }
    .header-action-separator {
        width: 1px;
        height: 20px;
        background: #151515;
        display: flex;
    }
}


/* header sidebar */
.header-sidebar.active {
    background: #fff;
    max-width: 100%;
    height: 100vh;
    transition: right 300ms, height 1ms, width 1ms;
    top: 0;
    right: 0;
    position: absolute;
    z-index: 9999;
    width: 100%;
    overflow: visible;
    opacity: 1;
    visibility: visible;
    padding: 60px 5%;
}
.header-sidebar {
    background: #fff;
    max-width: 100%;
    height: 100vh;
    transition: right 300ms, height 1s, width 1s;
    top: 0;
    right: -200px;
    position: absolute;
    z-index: 9999;
    width: 0;
    overflow: hidden;
    box-shadow: 0 10px 10px #0000001e;
    width: 0px;
    height: 0px;
    opacity: 0;
    visibility: hidden;
}
@media(min-width: 769px){
.header-sidebar.active {
    background: #fff;
    max-width: clamp(400px, 26.041vw, 500px);
    height: 100vh;
    transition: right 300ms, height 1ms, width 1ms;
    top: 0;
    right: 0;
    position: absolute;
    z-index: 9999;
    width: 100%;
    overflow: visible;
    visibility: visible;
    opacity: 1;
    padding: 60px 5%;
    width: 100%;
}
}

.sidebar-header-content {
    display: flex;
    gap: 20px;
    align-items: center;
    justify-content: space-between;
    padding-bottom: 19px;
    border-bottom: 1px solid #0808088c;
}
.header-sidebar-logo svg, .header-sidebar-logo path {
    fill: #151515;
}
.header-sidebar-close{
    cursor: pointer;
}

.header-sidebar-close span{
    background: #151515;
    display: flex;
    width: 25px;
    height: 1px;
    transition: 300ms;
}
.header-sidebar-close span:first-child{
    transform: rotate(45deg);
}
.header-sidebar-close span:last-child{
    transform: rotate(-45deg);
}
.header-sidebar-logo {
    display: flex;
}
.sidebar-header-body ul {
    margin: 0px;
    display: flex;
    flex-direction: column;
    gap: 15px;
    list-style: none;
}
.sidebar-header-body a {
    transition: 300ms;
    font-size: clamp(22px, 1.666vw, 32px);
    color: #151515;
    text-decoration: none;
    text-transform: uppercase;
    line-height: 1;
    transition: 300ms;
}
.sidebar-header-body a:hover{
    opacity: 0.6;
    transition: 300ms;
}

.header-row-wrapper {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.header-sidebar-bottom {
    display: flex;
    padding-top: 19px;
    border-top: 1px solid #0808088c;
    flex-direction: column;
    gap: 20px;
}

.header-lang-selector div#gt-wrapper-68379690 {
    display: flex;
    gap: 8px;
}
.header-sidebar-bottom .header-social svg {
    fill: #151515;
}

.no-scroll{
    overflow: hidden;
}
body,html,div#page {
    overflow-x: hidden;
}
.header-sidebar-bottom .header-social {
    display: flex;
    gap: 15px;
}
.site-content{
    transition: 300ms;
}
.blur{
    transition: 300ms;
    filter: blur(30px);
}

/*is home */
.header-main-wrapper.is-home{
    position: absolute;
    top: 0px;
    left: 0px;
    transition: 300ms;
    width: 100%;
    z-index: 9997;
}
.header-main-wrapper.is-home .header-social  svg{
    fill: #fff;
}
.header-main-wrapper.is-home .header-action-separator{
    background: #fff;
}

.header-main-wrapper.is-home .desktop-menu-wrapper a{
    color: #fff;
}
.header-main-wrapper.is-home .header-logo-wrapper svg,.header-main-wrapper.is-home .header-logo-wrapper path{
    fill: #fff;
}
.header-main-wrapper.is-home .header-lang-selector .gt_float_switcher,
.header-main-wrapper.is-home .header-lang-selector .gt_float_switcher .gt-selected{
    background: transparent;
    background-color: transparent;
}
.gt_options.gt-open{
    background: #fff;
}
.header-main-wrapper.is-home span.gt-lang-code{
    color: #fff;
}
.header-main-wrapper.is-home .burger-action-wrapper span{
    background: #fff;
}








/* Single product imported */
/* --------------------------------------------
   Single products
-------------------------------------------- */

.filter-sidebar-body .wpf_slider.ui-slider .ui-widget-header {
    background: #000;
    border: none;
}

.single-product-quantity {
    display: flex;
    align-items: center;
    gap: 8px;
}

.stock-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    display: inline-block;
}

.stock-dot.available {
    background-color: green;
}

.stock-dot.ending {
    background-color: orange;
}

.stock-dot.not-available {
    background-color: red;
}

.custom-quantity-wrapper {
    display: flex;
    background: #fff;
    width: max-content;
    border: 1px solid #AEAEAE;
}
.custom-quantity-wrapper button {
    background: transparent;
    color: #AEAEAE;
    transition: 300ms;
}
.custom-quantity-wrapper input {
    background: transparent;
    transition: 300ms;
}
.custom-quantity-wrapper button:hover {
    color: #151515;
    transition: 300ms;
}

/* Chrome, Safari, Edge, Opera */
input[type=number]::-webkit-inner-spin-button,
input[type=number]::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

/* Firefox */
input[type=number] {
    -moz-appearance: textfield;
}

.single-product-attribute-list {
    display: flex;
    gap: 4px;
    line-height: 1;
    margin-top: 10px;
    font-size: clamp(10px,0.728vw, 14px);
    flex-wrap: wrap;
}
.attribute-wrapper.figtree {
    display: flex;
    gap: 4px;
}

.single-product-category.lora {
    font-weight: 300;
    text-transform: uppercase;
}
.single-product-price {
    margin-bottom: clamp(40px, 4.687vw, 90px);
}
.single-product-price.size-active{
    margin-bottom: 30px;
}

.single-product-price {
    font-weight: 300;
    color: #373735;
    font-size: clamp(22px, 1.562vw, 30px);
}
.single-product-price {
    display: flex;
    gap: 5px;
    align-items: flex-end;
}
span.price-tax-included-text {
    font-weight: 300;
    color: #a7a7a7d7;
    font-size: clamp(14px, 0.82vw, 16px);
    line-height: 1;
    padding-bottom: 5px;
}
.file-size-wrapper {
    display: flex;
    line-height: 1;
    font-size: 16px;
    margin-bottom: 40px;
}
.file-size-wrapper a{
    color: #161615;
    font-weight: bold;
    transition: 300ms;
}
.file-size-wrapper a:hover{
    opacity: 0.6;
    transition: 300ms;
}
.single-product-wishlist-button .tinvwl-tooltip {
    /*display: flex;*/
}
.single-product-wishlist-button .tinv-wraper {
    width: 100%;
    display: flex;
}
.single-product-wishlist-button a.tinvwl_add_to_wishlist_button{
    display: flex;
    align-items: center;
    gap: 10px;
    border: 1px solid #373735 !important;
    justify-content: center;
    align-items: center;
    padding: 10px;
    transition: 300ms;
    width: 100%;
}
.single-product-wishlist-button a.tinvwl_add_to_wishlist_button:hover{
    color: #fff !important;
    border: 1px solid #373735;
    transition: 300ms;
    background: #373735;
}

.single-product-actions {
    display: flex;
    width: 100%;
    gap: 20px;
}
.single-product-actions .custom-quantity-wrapper {
    order: 1;
    width: 100%;
    max-width: 147px;
    justify-content: space-between;
    align-items: center;
}
.single-product-actions > button {
    order: 3;
    display: flex;
}
.single-product-actions .single-product-wishlist-button {
    order: 2;
    flex: 0 1 calc(100% - 167px);
    display: flex;
    width: 100%;
    cursor: pointer;
}
.single-product-actions > button {
    order: 3;
    display: flex;
    width: 100%;
    padding: 16px!important;
    text-transform: uppercase;
}
.single-product-actions > button {
    border-radius: 0px !important;
    background: #373735 !important;
    transition: 300ms;
}
.single-product-actions > button:hover {
    background: #666 !important;
    transition: 300ms;
}
.woocommerce .quantity .qty {
    border: none;
}
@media(max-width: 375px){
   .single-product-actions {
        display: flex;
        width: 100%;
        flex-wrap: wrap;
        gap: 20px;
        flex-direction: column;
    }
    .single-product-actions .custom-quantity-wrapper {
        order: 1;
        width: 100%;
        max-width: 100%;
        justify-content: space-between;
        align-items: center;
    }
}
/* single product select variazioni */
.variations {
    display: flex;
    flex-direction: column;
    gap: 30px;
}
.variations.multiple-variations {
    display: grid;
    grid-template-columns: 1fr;
    gap: 30px;
}
.variations.multiple-variations .value select {
    background: transparent;
    border: none;
    padding: 10px 20px;
    font-size: clamp(14px, 0.82vw, 16px);
    border: 1px solid #CFCFCF;
    color: #A7A7A7;
    width: 100%;
}
.variations .value select {
    background: transparent;
    border: none;
    padding: 10px 20px;
    font-size: clamp(14px, 0.82vw, 16px);
    border: 1px solid #CFCFCF;
    color: #A7A7A7;
    width: 100%;
}
.woocommerce-variation.single_variation {
    overflow: hidden;
    height: 1px;
    width: 1px;
    opacity: 0;
}
a.reset_variations {
    margin: 10px 0;
    display: flex;
    color: #151515;
    line-height: 1;
}
@media(min-width: 1024px){
    .variations.multiple-variations {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 30px;
    }
}
.single-product-quantity span.stock-label {
    color: #151515;
}
.single-box-addon-wrapper {
    display: flex;
    gap: 20px;
    align-items: center;
    color: #373735;
    font-size: clamp(12px, 1.041vw, 20px);
    margin-bottom: clamp(40px, 3.124vw, 60px);
    line-height: 1.35;
    margin-top: 30px;
}
.single-box-addon-wrapper a{
    transition: 300ms;
    color: #373735;
}
.single-box-addon-wrapper a:hover{
    transition: 300ms;
    color: #000;
}
.block--image-single img {
    height: 100%;
    width: 100%;
}
.block--image-single {
    display: flex;
    max-width: clamp(60px, 6.24vw, 120px);
}
.block--paragraph-single {
    display: flex;
    flex-direction: column;
    gap: 5px;
}
/* single whatsapp */
.single-product-whatsapp-wrapper {
    display: flex;
    text-wrap: balance;
}
.single-product-whatsapp-wrapper a {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #1FBA5C;
    border-radius: 100px;
    padding: 10px 25px;
    transition: 300ms;
    color: #fff;
    text-decoration: none;
    font-weight: bold;
    line-height: 1.3;
    width: 100%;
    justify-content: center;
}
.single-product-whatsapp-wrapper svg {
    transition: 300ms;
    width: clamp(40px,3.124vw, 60px);
    fill: #fff;
}
.single-product-whatsapp-wrapper a:hover {
    transition: 300ms;
    background: #151515;
}
.single-product-secure {
    margin: 30px 0 40px;
    display: flex;
    flex-direction: column;
    width: max-content;
    color: #BFBFBF;
    gap: 5px;
    font-weight: bold;
    line-height: 1.1;
}
@media(min-width: 981px){
    .single-product-secure {
        margin: 20px 0 30px;
        display: flex;
        flex-direction: column;
        width: max-content;
        color: #BFBFBF;
        gap: 5px;
    }
    .single-product-whatsapp-wrapper {
        display: flex;
        max-width: 350px;
        text-wrap: balance;
    }
    .single-product-whatsapp-wrapper a {
        display: flex;
        align-items: center;
        gap: 10px;
        background: #1FBA5C;
        border-radius: 100px;
        padding: 10px 25px;
        transition: 300ms;
        color: #fff;
        text-decoration: none;
        font-weight: bold;
        line-height: 1.3;
    }
}

/* single toggle */
.single-product-toggle-informations {
    margin-top: clamp(40px, 2.603vw, 50px);
}
.single-toggle-head {
    display: flex;
    justify-content: space-between;
    gap: 10px;
    align-items: center;
    color: #373735;
    font-size: clamp(16px, 0.937vw, 18px);
}
.single-toggle-icon {
    position: relative;
    width: 20px;
    height: 20px;
    display: flex;
}
.single-toggle-icon span {
    transition: 300ms;
    background: #151515;
    height: 1px;
    width: 18px;
    position: absolute;
    top: 50%;
}
.single-toggle-icon span:first-child{
    transform: rotate(90deg);
    transition: 300ms;
}
.single-toggle-wrapper {
    padding-bottom: 20px;
    border-bottom: 1px solid #707070;
    transition: 300ms;
    cursor: pointer;
}
.single-toggle-wrapper.active {
    padding-bottom: 30px;
    transition: 300ms;
}
.single-toggle-head {
    padding: 20px 0 0;
}
.single-toggle-wrapper:first-child .single-toggle-head {
    padding: 0;
}
.single-toggle-content {
    visibility: hidden;
    height: 0px;
    opacity: 0;
    transform: translateY(-5px);
    transition: 200ms;
}
.single-toggle-wrapper.active .single-toggle-content {
    visibility: visible;
    height: auto;
    opacity: 1;
    transform: translateY(0);
    transition: 500ms;
    padding: 10px;
}
.single-toggle-wrapper.active .single-toggle-icon span:first-child {
    transform: rotate(0);
    transition: 300ms;
}

/* single product fix */
.woocommerce-product-details__short-description {
    margin-bottom: 30px;
}
.single-product-quantity {
    margin: 15px 0 20px;
}
.single-product-variation-action .single-box-addon-wrapper {
    margin-top: clamp(40px, 3.124vw, 60px);
}

@media(min-width: 1181px){
    .single-product-content {
        max-width: clamp(500px, 31.770vw, 610px);
        margin: 0 auto 0 10%;
    }
}


@media(min-width: 1025px){
    .my-slider-progress{
        display: none;
    }
    body.single-product{
        overflow: visible;
    }
    .section-single-product .single-product-gallery-wrapper{
    position: -webkit-sticky;
    position: sticky;
    top: 5%;
    }
    .section-single-product .single-product-gallery-wrapper{
    overflow: visible !important;
    }
    .single-product-gallery-wrapper.single-gallery-active{
        display: grid;
        grid-template-columns: 1fr 5fr;
        gap: clamp(10px, 1.041vw, 20px);
    }  
    div#splide-main {
        max-height: clamp(200px, 36.457vw, 700px);
        overflow: hidden;
    }
    div#splide-main li, div#splide-main img{
        height: 100%!important;
    }
    div#splide-main .splide__track{
        height: 100%;
    }
    .single-product-image {
        max-width: clamp(580px, 35.416vw, 680px);
        margin: 0 0 0 auto;
    }
}


div#splide-thumbs .splide__track--nav>.splide__list>.splide__slide {
    overflow: hidden;
}
div#splide-thumbs .splide__track--nav>.splide__list>.splide__slide.is-active {
    border: 2px solid #151515;
}
.single-product-image img {
    width: 100%;
}
@media(min-width: 1921px){
    .single-product-gallery-wrapper.single-gallery-active {
        max-width: clamp(845px, 44vw, 845px);
        margin: 0 auto;
    }
}

.shop-benefit.desktop {
    display: none;
}
.benefit-icon-wrapper {
    display: flex;

}
.benefit-icon-wrapper img{
    width: 100%;
}
.benefit-text-wrapper.lora {
    font-size: 12px;
    text-wrap: balance;
    line-height: 1.3;
}
.benefit-wrapper {
    display: flex;
    align-items: center;
    gap: 12px;
}
.single-product-image {
    border: 1px solid #ccc;
}
.shop-benefit.mobile{
    display: block;
}
@media(min-width: 1181px){
    .benefit-text-wrapper.lora {
        font-size: 8px;
        text-wrap: balance;
        line-height: 1.3;
    }
    .shop-benefit.mobile{
        display: none;
    }
    .shop-benefit.desktop{
        display: flex;
        gap: clamp(20px, 1.562vw, 30px);
        align-items: center;
    }
}
.column-single-product-content{
    overflow: hidden;
}
body.single-product {
    overflow: visible;
}
.production-time-text {
    color: #1C1C1C;
    margin-bottom: 10px;
}
@media(max-width: 1024px){
    div#splide-main {
        border: 0;
    }
    .single-product-image {
        border: 0;
    }
}


.product-carousel .product-carousel-bar-wrapper,.my-slider-progress {
    width: 100%;
    display: flex;
    background: #ccc;
    height: 1px;
    margin-top: 40px;
    align-items: center;
    padding: 1px 0;
    transition: 300ms;
}
.progress-bar,.my-slider-progress-bar {
    background: #000;
    height: 2px;
    border-radius: 50px;
    transition: 500ms;
}


.product-card-thumbnail, .product-card-thumbnail a {
    display: flex;
    transition: 300ms;
    width: 100%;
}

.product-card-thumbnail img {
    width: 100%;
    transition: 300ms;
}
.product-card-body .product-card-title a {
    font-size: clamp(18px, 1.041vw, 20px);
    text-decoration: none;
    color: #161615;
    text-transform: uppercase;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.6;
}
.product-card-price.lora {
    font-size: clamp(16px, 0.937vw, 18px);
}
.product-card-body {
    margin-top: 20px;
    padding-right: 10px;
}
.product-card-thumbnail a:before {
    transition: 500ms;
    content: '';
    display: flex;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}
.product-card-thumbnail a:hover:before {
    box-shadow: inset 0 0 15px #00000041;
    transition: 500ms;
}
.section.product-carousel .product-carousel {
    margin-top: clamp(40px, 3.124vw, 60px);
}
.product-card-thumbnail {
    border: 1px solid #CFCFCF;
}
@media(min-width: 1181px){
    .progres--related-product {
        display: none;
    }
}

.single-product-custom-padding{
    padding: clamp(60px, 8.853vw, 170px) 0 clamp(60px, 10.416vw, 200px);
}
.section.product-carousel{
    padding: clamp(30px, 1.562vw, 30px) 0 clamp(30px, 5.207vw, 100px);
}
.section.product-carousel .row.row--1col-full.section--relative .column {
    overflow: hidden;
}



/* Archive product */
.products.products-list {
    display: grid;
    grid-template-columns: 1fr;
    width: 100%;
    gap: 10px;
    row-gap: clamp(40px, 4.166vw, 80px);
}
@media(min-width: 769px) and (max-width: 1024px){
    .products.products-list {
        grid-template-columns: 1fr 1fr;
    }
}
@media(min-width: 1025px) and (max-width: 1280px){
    .products.products-list {
        grid-template-columns: 1fr 1fr 1fr;
    }
}
@media(min-width: 1281px){
    .products.products-list {
        grid-template-columns: 1fr 1fr 1fr 1fr;
    }  
}
.archive-search-button div {
    display: flex;
}
.archive-search-button svg {
    width: 20px;
    height: 20px;
}
.archive-search-button {
    display: flex;
    align-items: center;
    gap: 5px;
    line-height: 1;
    font-weight: bold;
}
.category-and-search {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: center;
    padding-bottom:  29px;
    border-bottom: 1px solid #D0D0D0;
}
.archive-category a {
    text-decoration: none;
    color: #161615;
    text-transform: uppercase;
    transition: 300ms;
}
.archive-category a:hover {
    opacity: 0.6;
    transition: 300ms;
}
.archive-filter-button {
    display: flex;
    gap: 5px;
    align-items: center;
}
.archive-filter-button > div{
    display: flex;
}
.archive-filter-button svg{
    width: 15px;
    height: 15px;
}
.filters-and-count{
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: center;
    padding:  29px 0 30px;
}

.page-load-status{
    display: none;
}
.infinite-scroll-request.loader {
    max-width: 100px;
    margin: 30px auto 0;
    display: none;
    justify-content: center;
    align-items: center;
    text-align: center;
    animation: pulseLoader 1.2s ease-in-out infinite;
}
.infinite-scroll-request.loader span {
    font-size: 12px;
    letter-spacing: 1px;
    opacity: 0.5;
}
.infinite-scroll-last,.infinite-scroll-error {
    text-align: center;
    margin-top: 60px;
}
@keyframes pulseLoader {
    0% {
        transform: scale(1);
        opacity: 1;
    }
    50% {
        transform: scale(1.1);
        opacity: 0.6;
    }
    100% {
        transform: scale(1);
        opacity: 1;
    }
}


.infinite-scroll-request.loader img{
    max-width: 60px;
    margin: 0 auto;
}

.section-archive-products .row-head-archive {
    margin-bottom: clamp(40px, 3.124vw, 60px);
}
.archive-category a.active {
    font-weight: bold;
    transition: 300ms;
}
.archive-category,.archive-search-button,.archive-filter-button,.count-total-product {
    line-height: 1;
    font-size:clamp(13px, 0.83vw, 16px);
}
.archive-search-button, .archive-filter-button {
    cursor: pointer;
}
.filter-sidebar-wrapper{
    width: 0;
    max-width: clamp(450px, 29.947vw, 575px);
    position: absolute;
    top: 0;
    left: -500px;
    background: #fff;
    height: 0;
    transition: width 1ms, height 1ms, left 500ms;
    z-index: 9999;
}

.filter-sidebar-wrapper.active {
    width: 100%;
    left: 0px;
    height: 100vh;
    transition: width 1ms, height 1ms, left 500ms;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    box-shadow: 0px 10px 10px #00000036;
}

.filter-sidebar-header {
    display: flex;
    gap: 20px;
    background: #ccc;
    align-items: center;
    justify-content: space-between;
    background: #EFEFEF;
    padding: 10px 20px;
    text-transform: uppercase;
}
.filter-sidebar-close{
    cursor: pointer;
    width: 20px;
    height: 20px;
    display: flex;
    position: relative;
}
.filter-sidebar-close span{
    background: #151515;
    width: 20px;
    display: flex;
    height: 1px;
    position: absolute;
    top: 50%;
    left: 0%;
}
.filter-sidebar-close span:first-child{
    transform:rotate(45deg);
}
.filter-sidebar-close span:last-child{
    transform:rotate(-45deg);
}
.filter-sidebar-footer {
    background: #EFEFEF;
    display: flex;
    min-height: 30%;
}
.filter-sidebar-body {
    padding: 60px 20px;
    overflow-y: auto;
}
.filter-sidebar-footer-row {
    width: 100%;
    padding: 30px 20px 60px;
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: flex-end;
    flex-direction: column;
}
@media(min-width: 1025px){
    .filter-sidebar-footer-row {
        width: 100%;
        padding: 30px 20px 60px;
        display: flex;
        justify-content: space-between;
        gap: 20px;
        align-items: flex-end;
        flex-direction: row;
    }
}

.filter-sidebar-footer-row .block--button {
    width: 100%;
}
.filter-sidebar-footer-row .block--button a{
    transition: 300ms;
    text-transform: uppercase;
    text-decoration: none;
    min-width: 180px;
    display: flex;
    justify-content: center;
    text-align: center;
    width: 100%;
    cursor: pointer;
}
.filter-sidebar-footer-row .block--button:first-child a {
    border: 1px solid #161615;
    color: #161615;
    padding: 10px 20px;
    background: transparent;
}
.filter-sidebar-footer-row .block--button:first-child a:hover {
    border: 1px solid #161615;
    color: #fff;
    background: #161615;
    transition: 300ms;
}
.filter-sidebar-footer-row .block--button:last-child a {
    border: 1px solid #161615;
    color: #fff;
    padding: 10px 20px;
    background: #161615;
}
.filter-sidebar-footer-row .block--button:last-child a:hover {
    opacity: 0.6;
    transition: 300ms;
}


.filter-sidebar-body .wpf_item_name {
    font-weight: 300 !important;
    text-transform: uppercase;
    border-bottom: 0px !important;
    padding-bottom: 0px!important;
}
.filter-sidebar-body .wpf_reset_btn {
    visibility: hidden;
}







.search-box-wrapper.active {
    width: 100vw;
    height: 100vh;
    background: #00000061;
    z-index: 9999;
    position: fixed;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: 300ms;
    opacity: 1;
}
.search-box-wrapper {
    position: fixed;
    z-index: -1000;
    width: 100vw;
    height: 100vh;
    top: 0;
    opacity: 0;
    transition: 500ms;
    left: 0;
    display: flex;
    padding: 5%;
}
.search-close-button {
    width: 35px;
    height: 15px;
    position: relative;
    display: flex;
    cursor: pointer;
}
.search-close-button span {
   width: 100%;
   height: 1px;
   background: #fff;
   transition: 300ms;
   display: flex;
   position: absolute;
   top: 50%;
}
.search-close-button span:first-child {
   transform: rotate(45deg);
}
.search-close-button span:last-child {
   transform: rotate(-45deg);
}
.saerchbar-content {
    display: flex;
    align-items: center;
    gap: 20px;
}
.searchbar-label {
    color: #fff;
    margin-bottom: 8px;
}
.saerchbar-content form.search-form,
.saerchbar-content label {
    width: 100%;
}
.saerchbar-content label {
    position: relative;
}
.search-bar-wrapper {
    width: 100%;
    max-width: 560px;
}
.saerchbar-content input {
    width: 100%;
    padding-left:60px;
    border-radius: 40px;
}
.saerchbar-content button.search-submit {
    position: absolute;
    left: 0;
    background: unset;
    width: 50px;
}
.seach-results-wrapper.search-header-wrapper .saerchbar-content button.search-submit svg {
    fill: #151515;
    font-size: 20px;
}
.seach-results-wrapper .gp-icon svg {
    height: 1em;
    width: 1em;
    top: .125em;
    position: relative;
    fill: unset;
}


/* Search bar */
.seach-results-wrapper .search-bar-wrapper {
    max-width: 100%;
}

.search-bar-wrapper input.search-field {
    background: transparent;
}
.search-bar-wrapper .saerchbar-content {
    max-width: 600px;
    margin: 0 auto;
}
.seach-results-wrapper {
    padding: 30px 0 59px;
    margin-bottom: 60px;
}
.seach-results-wrapper .searchbar-label{
    display: none;
}
.pagination span, .pagination > a {
    display: none;
}
.seach-results-wrapper .search-close-button {
    display: none;
}
.search-results-page{
    background: #fff;
}

/* --------------------------------------------
   Cart
-------------------------------------------- */
.cms-template .wc-block-components-product-details {
    line-height: 1;
}
dl.variation {
    line-height: 1;
    opacity: 0.5;
}
.woocommerce-cart h1.block--title__80 {
    text-align: center;
}

.woocommerce-cart .wc-block-components-sidebar.wc-block-cart__sidebar.wp-block-woocommerce-cart-totals-block {
    background: #F3F3F3;
    padding: 20px;
    height: 100%;
    color: #151515;
}
.woocommerce-cart h2.wp-block-woocommerce-cart-order-summary-heading-block.wc-block-cart__totals-title {
    text-align: center;
    font-size: 18px;
    line-height: 1;
    padding-bottom: 20px;
    color: #32303B;
}
.woocommerce-cart .wc-block-cart__submit-container a {
    background: #151515;
    text-transform: uppercase;
    text-decoration: none;
    transition: 300ms;
    color: #fff;
    padding: 12px 20px;
}
.woocommerce-cart .wc-block-cart__submit-container a:hover {
    background: #666;
    transition: 300ms;
    color: #fff;
}

form#wc-block-components-totals-coupon__form input#wc-block-components-totals-coupon__input-coupon {
    background: transparent;
    border-radius: 0px;
}
button.wc-block-components-button.wp-element-button.wc-block-components-totals-coupon__button.contained{
    background: #151515;
}

 .woocommerce-cart a.wc-block-components-product-name {
    text-decoration: none;
    margin-bottom: 5px !important;
    color: #151515;
 }
  .woocommerce-cart .wc-block-components-product-metadata__description {
    display: none;
}
.cms-template .block--title {
    margin-bottom: 60px;
}

.cms-template .wc-block-components-quantity-selector {
    background: #fff;
}
.cms-template .wc-block-cart-item__prices,
.cms-template td.wc-block-cart-item__total,
.cms-template  th.wc-block-cart-items__header-image,
.cms-template  th.wc-block-cart-items__header-total {
    color: #373735;
}


/* --------------------------------------------
   User
-------------------------------------------- */
.woocommerce-account nav.woocommerce-MyAccount-navigation {
    background: #F3F3F3;
    padding: clamp(30px, 2.07vw, 40px);
    text-align: center;
}
.login-form-wrapper {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    max-width: 600px;
    margin: 0 auto;
}
.login-form-input-wrapper {
    display: flex;
    flex-direction: column;
    gap: 20px;
    width: 100%;
}
.login-form-input-wrapper input {
    border-radius: 30px;
    padding: 12px 30px;
    border: 1px solid #ccc;
    background: #fff;
    color: #151515;
}
.login-form-input-wrapper input::placeholder {
    font-size: 15px;
    color: #15151575;
}
input.search-field::placeholder {
    font-size: 15px;
    color: #fff;
}
.login-form-lost-password {
    margin: 20px 0 50px;
    text-align: left;
    width: 100%;
    padding: 0 30px;
    font-size: 14px;
}
.login-form-lost-password a{
    transition: 300ms;
    color: #151515;
}
.login-form-lost-password a:hover{
    transition: 300ms;
    opacity: 0.70;
}
.login-buttons {
    display: flex;
    gap: 20px;
    align-items: center;
    flex-direction: column;
}
.block--button button.block--button__outline {
    transition: 300ms;
    background: transparent;
}
.login-buttons > span {
    color: #15151587;
    font-size: 16px;
}
.lost-password-label {
    text-align: center;
    text-wrap: balance;
    margin-bottom: 20px;
}
.login-form-wrapper.lost-password-form .login-form-input-wrapper {
    margin-bottom: 20px;
}
@media(min-width: 1025px){
    .login-form-wrapper {
        padding: 20px;
    }
}
@media(max-width: 560px){
    .login-buttons .block--button, .login-buttons .block--button a,.login-buttons,.login-buttons .block--button button {
        width: 100%!important;
        max-width: 100%!important;
        gap: 15px;
    }
    .login-form-button {
        width: 100%;
    }
}
@media(min-width: 561px){
    .login-buttons {
        display: flex;
        gap: 20px;
        align-items: center;
        flex-direction: row;
    }
}

.block--button button.block--button__outline {
    transition: 300ms;
    background: transparent;
}
.block--button .block--button__outline {
    padding: 18px 20px;
    text-decoration: none;
    text-align: center;
    color: #151515;
    transition: 300ms;
    border: 1px solid #151515;
    line-height: 1em;
    text-transform: uppercase;
    font-size: 14px;
    min-width: 150px;
}
.block--button .block--button__full {
    padding: 18px 20px;
    text-decoration: none;
    text-align: center;
    color: #fff;
    transition: 300ms;
    background: #151515;
    line-height: 1em;
    text-transform: uppercase;
    font-size: 14px;
    min-width: 150px;
}
.block--button .block--button__outline:hover {
    color: #fff;
    transition: 300ms;
    border: 1px solid #151515;
    background: #151515;
}
.block--button .block--button__full:hover {
    color: #fff;
    transition: 300ms;
    background: #666;
}
input#username,
input#password{

}

/* Profile logged */
.woocommerce-MyAccount-content {
    text-wrap: balance;
}
.woocommerce-MyAccount-content a{
    color: #151515;
}
nav.woocommerce-MyAccount-navigation ul {
    margin: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 20px;
}
nav.woocommerce-MyAccount-navigation ul li:last-child a{
    background: none!important;
}

nav.woocommerce-MyAccount-navigation li a{
    text-transform: uppercase;
    text-decoration: none;
    width: 100%;
    display: flex;
    padding: 12px 20px;
    transition: 300ms;
    text-align: center;
    color: #151515;
    justify-content: center;
    background: #fff;
}
nav.woocommerce-MyAccount-navigation li.is-active a,nav.woocommerce-MyAccount-navigation li a:hover{
    background: #151515;
    color: #fff;
    transition: 300ms;
}

form.woocommerce-EditAccountForm.edit-account .block--button {
    margin-top: 30px;
}
.form-edit-info-main .login-form-input-wrapper input {
    width: 100%;
}
p.edit-account-name-account input {
    cursor: not-allowed;
    opacity: 0.5;
}
p.password-change-legend {
    font-weight: bold;
    margin-top: 30px !important;
    display: flex;
}
p.edit-account-name-account span {
    margin-top: 5px;
    display: flex;
}
form.woocommerce-EditAccountForm.edit-account,form.form-account-edit-address,.account-my-address-wrapper,.account-order-list-wrapper,.my-order-prodile,.myprofile-dashboard {
    margin-top: 60px;
}
.woocommerce-address-fields__field-wrapper input {
    border-radius: 30px!important;
    padding: 12px 30px!important;
    border: 1px solid #ccc!important;
    color: #151515;
}
.woocommerce-address-fields__field-wrapper .form-row {
    margin-bottom: 20px!important;
}
form.form-account-edit-address .lost-password-action {
    margin-top: 20px;
}
form.form-account-edit-address .select2-selection__rendered {
    border-radius: 30px!important;
    border: 1px solid #ccc;
    padding: 10px 30px!important;
}
form.form-account-edit-address span.select2-selection.select2-selection--single {
    border: none;
}
.account-my-address-wrapper .u-columns.woocommerce-Addresses.col2-set.addresses {
    display: flex;
    flex-direction: column;
    gap: 40px;
}
.account-my-address-wrapper .woocommerce-Address {
    width: 100%!important;
}
.account-my-address-wrapper .woocommerce-Address header h2{
    margin-bottom: 20px!important;
}
.account-my-address-wrapper .woocommerce-Address address{
    padding-top:30px;
    border-top: 1px solid #ccc;
    margin-top: 30px;
}
.account-order-list-wrapper > table {
    border: none!important;
}
.my-order-prodile h2{
    margin-bottom: 30px !important;
}
    .woocommerce-account .addresses .title .edit {
    float: left;
}
  
@media(min-width: 1025px){
  .woocommerce-MyAccount-content {
        padding-left: clamp(40px,5.20vw, 100px );
    }
    form.woocommerce-EditAccountForm.edit-account,form.form-account-edit-address,.account-my-address-wrapper,.account-order-list-wrapper,.my-order-prodile,.myprofile-dashboard {
        margin-top: 0px;
    }
    p.edit-account-name-account span {
        padding-left: 30px;
        margin-top: 5px;
        display: flex;
    }
    p.password-change-legend {
        font-weight: bold;
        padding-left: 30px;
        margin-top: 30px !important;
        display: flex;
    }
}
table.woocommerce-orders-table.woocommerce-MyAccount-orders.shop_table.shop_table_responsive.my_account_orders.account-orders-table {
    text-align: center;
}
table.woocommerce-orders-table.woocommerce-MyAccount-orders.shop_table.shop_table_responsive.my_account_orders.account-orders-table tr.woocommerce-orders-table__row.woocommerce-orders-table__row--status-on-hold.order td:last-child {
    border-right: 0;
}
table.woocommerce-orders-table.woocommerce-MyAccount-orders.shop_table.shop_table_responsive.my_account_orders.account-orders-table tr th:last-child {
    border-right: 0!important;
}
table.woocommerce-orders-table.woocommerce-MyAccount-orders.shop_table.shop_table_responsive.my_account_orders.account-orders-table td {
    padding-top: 10px!important;
    padding-bottom: 10px !important;
}
@media(max-width: 1024px){
    .woocommerce-account .block--title{
        margin-bottom: 30px!important;
    }
    table.woocommerce-orders-table.woocommerce-MyAccount-orders.shop_table.shop_table_responsive.my_account_orders.account-orders-table td {
        border-right: 0px!important;
    }
}

.section.section-order-confirmation.section--padding-md.order-confirmation-wrapper {
    background: #DFDED2;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
}
.order-confirmation-wrapper .block-paragraph.figtree {
    margin: 20px auto 30px;
    max-width: 500px;
}
.thank-you-block__button {
    display: flex;
    justify-content: center;
}


/* --------------------------------------------
   Checkout
-------------------------------------------- */
.woocommerce-checkout span.wc-block-components-order-summary-item__individual-prices.price.wc-block-components-product-price {
    line-height: 1;
    padding: 03px 0;
}
@media(max-width: 1024px){
    a.wc-block-checkout__login-prompt {
        float: unset!important;
        margin: 20px 0!important;
        width: 100%!important;
        display: flex;
        text-align: center;
        justify-content: center;
        max-width: 400px!important;
    }
}
.wc-block-components-sidebar.wc-block-checkout__sidebar.wp-block-woocommerce-checkout-totals-block.is-sticky {
    color: #151515;
}
a.wc-block-checkout__login-prompt {
    color: #111 !important;
    text-decoration: none;
    border: 1px solid #000;
    padding: 10px 20px;
    line-height: 1;
    text-transform: uppercase;
    transition: 300ms;
}
a.wc-block-checkout__login-prompt:hover {
    color: #fff !important;
    background: #000;
    border: 1px solid #000;
    transition: 300ms;
}

.woocommerce-checkout .cms-template .wc-blocks-components-select__container {
    border-radius: 30px !important;
    overflow: hidden;
}
.woocommerce-checkout .cms-template .woocommerce-checkout h1.block--title__80 {
    text-align: center;
}
h2.wc-block-components-title.wc-block-components-checkout-step__title {
    text-transform: uppercase;
}
.woocommerce-checkout .wc-block-components-sidebar.wc-block-checkout__sidebar.wp-block-woocommerce-checkout-totals-block.is-sticky.is-large {
    background: #F3F3F3;
    padding: 20px;
    height: 100%;
    color: #32303B;
}
.woocommerce-checkout .wp-block-woocommerce-checkout-order-summary-block {
    border: none;
}
.woocommerce-checkout p.wc-block-components-checkout-order-summary__title-text {
    text-transform: uppercase;
    text-align: left;
}
.woocommerce-checkout .wc-block-components-product-metadata__description{
    display: none;
}
.woocommerce-checkout p.wc-block-components-checkout-step__description {
    margin-bottom: 15px!important;
}
.woocommerce-checkout .edit-post-visual-editor .wc-block-checkout__shipping-method-option.wc-block-checkout__shipping-method-option--selected, 
.woocommerce-checkout .wc-block-checkout__shipping-method-option.wc-block-checkout__shipping-method-option--selected {
    background: #DFDED2;
    border: unset;
}

.woocommerce-checkout .wc-block-components-form .wc-block-components-text-input input[type=email], 
.woocommerce-checkout .wc-block-components-form .wc-block-components-text-input input[type=number],
.woocommerce-checkout .wc-block-components-form .wc-block-components-text-input input[type=password],
.woocommerce-checkout .wc-block-components-form .wc-block-components-text-input input[type=tel],
.woocommerce-checkout .wc-block-components-form .wc-block-components-text-input input[type=text],
.woocommerce-checkout .wc-block-components-form .wc-block-components-text-input input[type=url],
.woocommerce-checkout .wc-block-components-text-input input[type=email],
.woocommerce-checkout .wc-block-components-text-input input[type=number],
.woocommerce-checkout .wc-block-components-text-input input[type=password],
.woocommerce-checkout .wc-block-components-text-input input[type=tel],
.woocommerce-checkout .wc-block-components-text-input input[type=text],
.woocommerce-checkout .wc-block-components-text-input input[type=url] {
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 30px;
    box-sizing: border-box;
    color: #2b2d2f;
    font-family: inherit;
    font-size: 1em;
    height: 3.125em;
    line-height: 1em;
    margin: 0;
    min-height: 0;
    padding: 1em 30px 0!important;
    width: 100%;
}
.woocommerce-checkout .wc-block-components-form .wc-block-components-text-input label, .wc-block-components-text-input label {
    left: 30px;
}

.woocommerce-checkout .wc-blocks-components-select .wc-blocks-components-select__select {
    appearance: none;
    background: none;
    border: 1px solid #ccc;
    border-radius: 30px;
    color: #2b2d2f;
    font-family: inherit;
    font-size: inherit;
    font-size: 1em;
    font-style: inherit;
    font-weight: inherit;
    height: 100%;
    letter-spacing: inherit;
    line-height: 43px;
    padding: 1em 30px 0;
    text-decoration: inherit;
    text-transform: inherit;
    width: 100%;
}
.woocommerce-checkout .wc-blocks-components-select .wc-blocks-components-select__label {
    color: #2b2d2f;
    font-family: inherit;
    font-size: inherit;
    font-size: 1em;
    font-style: inherit;
    font-weight: inherit;
    left: 30px;
    letter-spacing: inherit;
    line-height: inherit;
    line-height: 1.25;
    margin: 0;
    max-width: calc(100% - 32px);
    overflow: hidden;
    position: absolute;
    text-decoration: inherit;
    text-overflow: ellipsis;
    text-transform: inherit;
    top: 2px;
    transform: translateY(15%) scale(.75);
    transform-origin: top left;
    transition: all .2s ease;
    white-space: nowrap;
    z-index: 1;
}

.woocommerce-checkout label.wc-block-components-radio-control__option.wc-block-components-radio-control__option-checked.wc-block-components-radio-control__option--checked-option-highlighted {
    box-shadow: unset;
    border: none;
    border-radius: 0px;
}
.woocommerce-checkout .wc-block-components-radio-control--highlight-checked.wc-block-components-radio-control--highlight-checked--last-selected:after{
    display: none;
}
.wc-block-components-radio-control--highlight-checked .wc-block-components-radio-control-accordion-option--checked-option-highlighted,
.wc-block-components-radio-control--highlight-checked label.wc-block-components-radio-control__option--checked-option-highlighted{
    background: #DFDED2;
    border: none;
    box-shadow: none !important;
}
.woocommerce-checkout .wc-block-components-radio-control--highlight-checked:after{
    border: none;
}
.woocommerce-checkout span.wc-block-components-radio-control__description{
    color: #151515;
}
.woocommerce-checkout span.wc-block-components-checkbox__label a {
    color: #151515;
}
.woocommerce-checkout button.wc-block-components-button.wp-element-button.wc-block-components-checkout-place-order-button.contained{
    background: #151515;
    text-transform: uppercase;
}

@media(max-width: 768px){
    .professor-card-actions a{
        font-size: 12px !important;
    }
}

.header-main-wrapper.is-home .header-lang-selector .account-icon svg {
    fill: #fff;
}
.account-icon, .account-icon a {
    display: flex;
}

.account-icon svg{
    width: 20px;
}
.sidebar-header-body .account-icon {
    margin-top: 20px;
}







.login-form-wrapper {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    max-width: 600px;
    margin: 0 auto;
}
.login-form-input-wrapper {
    display: flex;
    flex-direction: column;
    gap: 20px;
    width: 100%;
}
.login-form-input-wrapper input {
    border-radius: 30px;
    padding: 12px 30px;
    border: 1px solid #ccc;
    background: transparent;
    color: #151515;
}
.login-form-input-wrapper input::placeholder {
    font-size: 15px;
    color: #15151575;
}
.login-form-lost-password {
    margin: 20px 0 50px;
    text-align: left;
    width: 100%;
    padding: 0 30px;
    font-size: 14px;
}
.login-form-lost-password a{
    transition: 300ms;
    color: #151515;
}
.login-form-lost-password a:hover{
    transition: 300ms;
    opacity: 0.70;
}
.login-buttons {
    display: flex;
    gap: 20px;
    align-items: center;
    flex-direction: column;
}
.block--button button.block--button__outline {
    transition: 300ms;
    background: transparent;
}
.login-buttons > span {
    color: #15151587;
    font-size: 16px;
}
.lost-password-label {
    text-align: center;
    text-wrap: balance;
    margin-bottom: 20px;
}
.login-form-wrapper.lost-password-form .login-form-input-wrapper {
    margin-bottom: 20px;
}
@media(min-width: 1025px){
    .login-form-wrapper {
        padding: 20px;
    }
}
@media(max-width: 560px){
    .login-buttons .block--button, .login-buttons .block--button a,.login-buttons,.login-buttons .block--button button {
        width: 100%!important;
        max-width: 100%!important;
        gap: 15px;
    }
    .login-form-button {
        width: 100%;
    }
}
@media(min-width: 561px){
    .login-buttons {
        display: flex;
        gap: 20px;
        align-items: center;
        flex-direction: row;
    }
}