/*
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(16px, 0.93vw, 18px);
    line-height: clamp(32px, 1.76vw, 34px);
}
h1,
h2,
h3,
h4,
h5,
h6 {
    color: #404040;
    font-weight: 300;
}
.block--title__40 {
    font-size: clamp(28px, 2.07vw, 40px);
    line-height: clamp(42px, 2.85vw, 55px);
}
.block--title__60 {
    font-size: clamp(32px, 3.12vw, 60px);
    line-height: clamp(54px, 4.16vw, 80px);
}
.block--title__70 {
    font-size: clamp(32px, 3.64vw, 70px);
    line-height: clamp(44px, 4.16vw, 80px);
}
.block--title__80 {
    font-size: clamp(36px, 4.16vw, 80px);
    line-height: clamp(46px, 4.68vw, 90px);
}
.block--title__90 {
    font-size: clamp(36px, 4.68vw, 90px);
    line-height: clamp(46px, 5.2vw, 100px);
}
#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 0.3s,
        opacity 0.5s,
        visibility 0.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;
}
.page-header-content .block--title h1,
.page-header-content .block--title h2 {
    color: #fff;
    font-weight: bold;
    text-transform: uppercase;
}
.block-breadcrums {
    color: #fff;
}
.block-breadcrums a:hover {
    color: #e64d00;
}
.sinlepage-main-wrapper .block-breadcrums {
    display: flex;
    justify-content: center;
    gap: 10px;
}
.sinlepage-main-wrapper .block-breadcrums a {
    color: #fff;
    transition: 300ms;
    text-decoration: none;
}
.page-header-separator {
    background: #e64d00;
    height: 5px;
    width: clamp(160px, 10.41vw, 200px);
    margin: 0 auto 10px;
}
.no-padding-bottom {
    padding-bottom: 0;
}
.page-intro-text-wrapper .block--title h3 {
    text-transform: uppercase;
    text-wrap: balance;
}
@media (min-width: 1281px) {
    .page-intro-text-wrapper {
        max-width: 80%;
    }
}
.lines-pattern {
    background-image: url(/wp-content/uploads/2025/11/background-lines-pattern.svg);
    background-color: #ffffff63;
    background-blend-mode: overlay;
    background-repeat: repeat-y;
    background-position: center;
    background-size: contain;
}
.simple-row-images {
    display: flex;
    gap: 25px;
}
.simple-row-column {
    background: #1f1f1f;
}
.simple-row-text h3.block--title__40 {
    text-transform: uppercase;
    color: #fff;
}
.simple-row-text .block--button {
    margin-top: clamp(30px, 2.59vw, 50px);
}
.simple-row-text .block--title {
    text-wrap: balance;
}
@media (min-width: 1281px) {
    .simple-row-text {
        max-width: 80%;
        margin: 0 auto;
    }
    .contact-form-text-wrapper {
        max-width: clamp(400px, 29.68vw, 570px);
    }
}
@media (min-width: 1025px) {
    .simple-row-images {
        display: flex;
        gap: 40px;
    }
    .lines-pattern {
        background-size: auto;
    }
}
.contact-form-text-wrapper .block--title h3 {
    text-wrap: wrap;
    text-transform: uppercase;
}
.contact-form-text-wrapper .block--title {
    margin-bottom: 30px;
}
.contact-form-text-wrapper .block--paragraph {
    margin-bottom: 30px;
}
.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: 20px 20px 19px;
    border: none;
    border-bottom: 1px solid #7f7f7f;
    background: transparent;
}
.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: #e64d00;
}
.contact_form_action input {
    background: #e64d00;
    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;
}
.contact_form_action input:hover {
    background: #333;
    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;
    }
}
.brand-loop-text .block--title h3 {
    text-transform: uppercase;
    margin: 0 auto;
}
.brand-loop-text {
    margin-bottom: clamp(40px, 7.28vw, 140px);
    margin-left: auto;
    margin-right: auto;
    text-wrap: balance;
}
@media (min-width: 1281px) {
    .brand-loop-text {
        max-width: 50%;
    }
}
.block-brand-image {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}
.block-brand-image .block--image {
    display: flex;
    max-width: clamp(240px, 15.62vw, 300px);
    justify-content: center;
}
.row-brand-mobile-with-carousel {
    display: block;
}
.row-brand-desktop-with-carousel {
    display: none;
}
@media (min-width: 1025px) {
    .row-brand-mobile-with-carousel {
        display: none;
    }
    .row-brand-desktop-with-carousel {
        display: grid;
    }
}
.row-brand-mobile-with-carousel .splide__slide {
    height: max-content;
    margin: auto 0;
}
@media (max-width: 1024px) {
    .row-change-grid-on-mobile {
        grid-template-columns: 1fr 1fr;
    }
}
.block--contact-card {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}
.block--contact-card .block--image {
    margin: 0 auto;
}
.block--contact-card .block--image {
    max-width: max-content;
    display: flex;
}
.block--contact-card .block--title {
    margin: 20px 0 15px;
}
.block--contacts-loop {
    text-wrap: balance;
    line-height: 1.3;
}
.company-header-text .block--title h2 {
    text-transform: uppercase;
}
.company-header-text {
    text-transform: uppercase;
    text-wrap: balance;
}
.section--company-header-images .block--image img {
    object-fit: cover;
    object-position: center;
}
@media (min-width: 1280px) {
    .section--company-header-images .block--paragraph {
        max-width: 85%;
        margin-left: auto;
    }
}
.company-icons {
    background: #1f1f1f;
    color: #fff;
}
.company-icons .block--title h3 {
    color: #fff;
    text-transform: uppercase;
}
.company-text-main {
    text-wrap: balance;
}
.company-icon-wrapper {
    display: flex;
    gap: 30px;
    align-items: flex-start;
    border-bottom: 1px solid #707070;
    padding-bottom: 39px;
    flex-direction: column;
}
.block--company-reapater {
    display: flex;
    flex-direction: column;
    gap: 40px;
}
.company-icon-wrapper .block--image {
    max-width: clamp(60px, 4.16vw, 80px);
    width: 100%;
    height: 100%;
    max-height: clamp(60px, 4.16vw, 80px);
    display: flex;
    justify-content: center;
    align-items: center;
}
.company-text-wrapper {
    display: flex;
    flex-direction: column;
    gap: 20px;
    text-wrap: balance;
}
.block--company-reapater .company-icon-wrapper:last-child {
    padding-bottom: 0;
    border: none;
}
@media (min-width: 1025px) {
    .company-text-main {
        max-width: 80%;
        text-wrap: balance;
    }
    .company-text-wrapper {
        display: flex;
        flex-direction: column;
        gap: 20px;
        max-width: clamp(300px, 21.08vw, 404px);
        text-wrap: balance;
    }
    .company-icon-wrapper {
        display: flex;
        gap: 30px;
        align-items: center;
        flex-direction: row;
        border-bottom: 1px solid #707070;
        padding-bottom: 39px;
    }
}
@media (min-width: 1280px) {
    .block--company-reapater {
        display: flex;
        flex-direction: column;
        gap: 40px;
        max-width: clamp(300px, 33.84vw, 650px);
        margin-left: auto;
    }
    .company-fluid-rows-image {
        max-width: 90%;
    }
    .company-fluid-text-wrapper {
        max-width: 80%;
        margin: 0 auto 0 0;
        text-wrap: balance;
    }
}
.company-fluid-text-wrapper .block--title h3 {
    text-transform: uppercase;
}
.company-fluid-text-wrapper .block--title {
    margin-bottom: 30px;
}
.company-fluid-content-wrapper .block--image {
    margin-top: clamp(60px, 5.2vw, 100px);
}
@media (max-width: 1024px) {
    .company-fluid-text-wrapper {
        margin: 0 5%;
    }
    .company-fluid-rows {
        padding: 0;
    }
}
.footer-main-wrapper {
    background: #1f1f1f;
}
.footer-socials {
    display: flex;
    gap: 10px;
}
.footer-socials a {
    display: flex;
    width: 30px;
    height: 30px;
    transition: 300ms;
}
.footer-socials svg {
    width: 30px;
    height: 30px;
    fill: #fff;
    transition: 300ms;
}
.footer-socials svg:hover {
    fill: #e64d00;
    transition: 300ms;
}
.footer-description {
    color: #fff;
    font-size: clamp(18px, 1.03vw, 20px);
    line-height: clamp(28px, 1.55vw, 30px);
    margin: 20px 0;
    text-wrap: balance;
}
.bottom-footer {
    background: #1f1f1f;
    padding: 20px 0;
    color: #fff;
    font-size: 14px;
    text-wrap: balance;
}
.botom-footer-wrapper {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
}
@media (min-width: 1025px) {
    .botom-footer-wrapper {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 20px;
    }
    .bottom-footer-designer {
        display: flex;
        justify-content: end;
        gap: 5px;
    }
}
.bottom-footer:before {
    content: "";
    border-top: 1px solid #707070;
    display: flex;
    position: absolute;
    top: 0;
    left: 50%;
    width: 90%;
    margin: 0 auto;
    transform: translate(-50%, -50%);
}
.bottom-footer a {
    transition: 300ms;
    color: #fff;
    text-decoration: none;
}
.bottom-footer a:hover {
    transition: 300ms;
    color: #e64d00;
    text-decoration: underline;
}
.footer-column-title h6 {
    font-size: 20px;
    text-transform: uppercase;
    color: #e64d00;
}
.footer-column-title {
    margin-bottom: 20px;
}
.footer-content ul {
    margin: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 15px;
}
.footer-content li {
    line-height: 1;
}
.footer-content a {
    transition: 300ms;
    text-decoration: none;
    line-height: 1;
    color: #fff;
}
.footer-content a:hover {
    transition: 300ms;
    line-height: 1;
    color: #e64d00;
}
.footer-content {
    color: #fff;
    text-wrap: balance;
}
.footer-columns-wrapper {
    display: grid;
    grid-template-columns: 1fr;
    gap: 60px;
}
@media (min-width: 769px) and (max-width: 1280px) {
    .footer-columns-wrapper {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 30px;
    }
}
@media (min-width: 1281px) {
    .footer-columns-wrapper {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
        gap: 30px;
    }
}
.blog-post-thumbnail a {
    display: flex;
    width: 100%;
    height: 100%;
    overflow: hidden;
}
.blog-post-thumbnail img {
    width: 100%;
    height: 100%;
    transition: 300ms;
}
.blog-post-thumbnail:hover img {
    transform: scale(1.02);
    transition: 300ms;
}
.blog-post-title h5 {
    font-size: clamp(20px, 1.29vw, 25px);
    line-height: clamp(30px, 1.81vw, 35px);
    text-wrap: balance;
    text-transform: uppercase;
}
.blog-post-title {
    margin: 25px 0;
}
.blog-post-text > a {
    color: #e64d00;
    transition: 300ms;
    text-decoration: none;
    text-transform: uppercase;
}
.blog-post-text > a:hover {
    color: #333;
    transition: 300ms;
}
.section-blog-post-loop .block--title h2 {
    text-transform: uppercase;
}
.section-blog-post-loop .block--title {
    text-wrap: balance;
}
.blog-post-main {
    margin-top: clamp(60px, 6.24vw, 120px);
}
.blog-post-pagination {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 60px;
}
@media (min-width: 1280px) {
    .section-blog-post-loop .block--title__60.block--title--center {
        max-width: 50%;
        margin: 0 auto !important;
        text-wrap: balance;
    }
}
.blog-post-loop {
    display: grid;
    grid-template-columns: 1fr;
    gap: 30px;
}
@media (min-width: 769px) and (max-width: 1440px) {
    .blog-post-loop {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 30px;
    }
}
@media (min-width: 1441px) {
    .blog-post-loop {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
        gap: 30px;
    }
}
.block-single-post-title .block--title h1 {
    text-transform: uppercase;
}
.post-meta {
    display: flex;
    gap: 20px;
    align-items: center;
    justify-content: center;
}
.post-meta > div {
    display: flex;
    gap: 8px;
    align-items: center;
    text-transform: uppercase;
}
.single-post-image {
    display: flex;
    width: 100%;
    max-height: clamp(300px, 41.66vw, 800px);
}
.single-post-image img {
    width: 100%;
    object-fit: cover;
    object-position: center;
}
.single-post-content {
    background: #f3f3f3;
    padding: 40px 5%;
}
@media (min-width: 1281px) {
    .block-single-post-title .block--title {
        max-width: 60%;
        margin: 0 auto 30px;
        text-wrap: balance;
    }
}
@media (min-width: 1025px) {
    .single-post-content {
        background: #f3f3f3;
        padding: 80px 60px;
    }
}
.single-post-content h1,
.single-post-content h2,
.single-post-content h3,
.single-post-content h4,
.single-post-content h5,
.single-post-content h6 {
    margin-bottom: 20px !important;
}
.single-post-content p {
    margin-bottom: 20px !important;
}
.single-bottom-content svg {
    transition: 300ms;
    height: 20px;
    fill: #e64d00;
}
.single-bottom-content svg:hover {
    transition: 300ms;
    height: 20px;
    fill: #333;
}
.single-post-sharing,
.single-author {
    display: flex;
    align-items: center;
    gap: 10px;
    text-transform: uppercase;
    color: #e64d00;
}
.post-sharing-links {
    display: flex;
    gap: 10px;
}
.post-sharing-links a {
    display: flex;
}
.single-bottom-content {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    align-items: center;
    padding-top: 49px;
    border-top: 1px solid #707070;
    margin-top: 60px;
    flex-direction: column;
}
@media (min-width: 1025px) {
    .single-bottom-content {
        display: flex;
        justify-content: space-between;
        gap: 20px;
        align-items: center;
        padding-top: 49px;
        border-top: 1px solid #707070;
        margin-top: 60px;
        flex-direction: row;
    }
}
.single-related-post-wrapper {
    background: #1f1f1f;
    color: #fff;
}
.related-product-title .block--title h3 {
    color: #fff;
    text-transform: uppercase;
}
.related-product-grid-desktop .blog-post-title h5,
.related-product-grid-mobile .blog-post-title h5 {
    color: #fff;
}
.related-product-grid-desktop {
    display: none;
}
.related-product-grid-mobile {
    display: block;
}
.single-related-post-wrapper .column {
    overflow: hidden;
}
.related-product-grid-mobile {
    margin-top: 60px;
}
.no-padding-top {
    padding-top: 0;
}
.related-product-grid-desktop .blog-post-text a:hover,
.related-product-grid-mobile .blog-post-text a:hover {
    transition: 300ms;
    color: #fff;
}
.section.contact-form-block.section--padding-md.white-bg-full {
    background: #fff;
}
@media (min-width: 1181px) {
    .related-product-grid-desktop {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
        gap: 30px;
        margin-top: 60px;
    }
    .related-product-grid-mobile {
        display: none;
    }
}
.single-related-post-wrapper ul.splide__pagination.splide__pagination--ltr {
    position: unset;
    margin-top: 60px;
}
.single-related-post-wrapper ul.splide__pagination.splide__pagination--ltr button {
    width: 15px;
    height: 15px;
}
.single-related-post-wrapper button.splide__pagination__page.is-active {
    background: #e64d00;
}
.column.column-last-post-button {
    margin: 0 0 0 auto;
    display: none;
}
.column.column-last-post-button .block--button {
    margin: 0 0 0 auto;
}
@media (min-width: 1025px) {
    .column.column-last-post-button {
        display: block;
    }
}
.single-showroom .block-breadcrums,
.taxonomy-showroom-wrapper .block-breadcrums,
.search-main .block-breadcrums {
    display: flex;
    justify-content: center;
    gap: 10px;
}
.single-showroom .block-breadcrums a,
.taxonomy-showroom-wrapper .block-breadcrums a,
.search-main .block-breadcrums a {
    color: #fff;
    text-decoration: none;
}
.single-showroom .block-breadcrums a:hover,
.taxonomy-showroom-wrapper .block-breadcrums a:hover,
.search-main .block-breadcrums a:hover {
    color: #e64d00;
    text-decoration: underline;
}
.single-showroom-heading .block--title h1,
.single-showroom-heading .block--title h3 {
    text-transform: uppercase;
}
.single-showroom-gallery {
    margin-top: clamp(60px, 4.16vw, 80px);
}
.single-showroom-thumbs {
    max-width: 80%;
    margin: 40px auto 0;
}
@media (min-width: 1280px) {
    .single-showroom-heading .block--paragraph {
        max-width: clamp(300px, 36.45vw, 700px);
        margin: 30px auto 0;
    }
}
.single-showroom-thumbs button.splide__arrow.splide__arrow--prev {
    left: -10%;
}
.single-showroom-thumbs button.splide__arrow.splide__arrow--next {
    right: -10%;
}
.single-showroom-thumbs button.splide__arrow.splide__arrow--prev,
.single-showroom-thumbs button.splide__arrow.splide__arrow--next {
    background: transparent;
    transition: 300ms;
    border: 1px solid #e64d00;
    width: 50px;
    height: 50px;
}
.single-showroom-thumbs button.splide__arrow.splide__arrow--prev svg,
.single-showroom-thumbs button.splide__arrow.splide__arrow--next svg {
    transition: 300ms;
    fill: #e64d00;
}
.single-showroom-thumbs button.splide__arrow.splide__arrow--prev:hover,
.single-showroom-thumbs button.splide__arrow.splide__arrow--next:hover {
    background: #e64d00;
    transition: 300ms;
}
.single-showroom-thumbs button.splide__arrow.splide__arrow--prev:hover svg,
.single-showroom-thumbs button.splide__arrow.splide__arrow--next:hover svg {
    fill: #fff;
    transition: 300ms;
}
.single-showroom-thumbs .splide__track--nav > .splide__list > .splide__slide.is-active {
    border: 2px solid #e64d00 !important;
}
.single-showroom-thumbs img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.single-showroom-content .column {
    overflow: hidden;
}
.single-showroom-main-slider ul.splide__pagination.splide__pagination--ltr {
    position: unset;
    margin-top: 40px;
}
.single-showroom-main-slider ul.splide__pagination.splide__pagination--ltr button {
    width: 15px;
    height: 15px;
}
.single-showroom-main-slider button.splide__pagination__page.is-active {
    background: #e64d00;
}
.main-showroom-image {
    display: flex;
    margin-top: 60px;
    width: 100%;
    max-height: clamp(300px, 41.66vw, 800px);
}
.main-showroom-image img {
    width: 100%;
    object-fit: contain;
}
.archive-showroom-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 60px;
}
.archive-showroom-thumb,
.archive-showromm-item > a {
    display: flex;
    width: 100%;
    overflow: hidden;
    position: relative;
    transition: 300ms;
    max-height: clamp(270px, 18.22vw, 340px);
    height: 100vh;
}
.archive-showroom-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 3;
    position: relative;
    transition: 300ms;
}
.archive-showromm-item a:before {
    content: "";
    display: flex;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background: #000;
    background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 1) 100%);
    z-index: 4;
    transition: 300ms;
}
span.archive-showroom-title {
    position: absolute;
    bottom: 30px;
    left: 20px;
    font-size: clamp(22px, 1.55vw, 30px);
    text-transform: uppercase;
    color: #fff;
    z-index: 5;
    font-family: "Merriweather";
}
.archive-showromm-item a:hover img {
    transition: 300ms;
    transform: scale(1.02);
}
.archive-showroom-wrapper {
    margin-top: clamp(60px, 6.24vw, 120px);
}
@media (min-width: 980px) and (max-width: 1280px) {
    .archive-showroom-grid {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 30px;
        row-gap: 80px;
    }
}
@media (min-width: 1281px) {
    .taxonomy-loop-title .block--title {
        max-width: clamp(400px, 43.22vw, 830px);
        margin: 0 auto;
    }
    .archive-showroom-grid {
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
        row-gap: 80px;
        gap: 30px;
    }
}
@media (min-width: 1025px) {
    span.archive-showroom-title {
        position: absolute;
        bottom: 50px;
        left: 40px;
        font-size: clamp(22px, 1.55vw, 30px);
        text-transform: uppercase;
        color: #fff;
        z-index: 5;
        font-family: "Merriweather";
    }
}
.taxonomy-loop-title .block--title h2 {
    text-transform: uppercase;
    text-wrap: balance;
}
.archive-showroom-pagination {
    margin-top: 60px;
    display: flex;
    justify-content: center;
    gap: 10px;
}
.home-hero-slide-background {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 4;
}
.home-hero-slide-background img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}
.home-hero-slide:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #0000005b;
    display: flex;
    z-index: 5;
}
.home-hero-slide-background {
    height: 100vh;
    width: 100%;
}
.home-hero-slide {
    height: 100%;
    display: flex;
    align-items: flex-end;
}
.block--hero-slide-text {
    position: relative;
    z-index: 6;
}
.block--hero-slide-text {
    position: relative;
    z-index: 6;
    margin-left: 5%;
    margin-bottom: 15%;
}
.home-hero-pagination {
    display: flex;
    flex-direction: column;
    gap: 15px;
    position: absolute;
    bottom: 0;
    right: 5%;
    padding-top: 0px !important;
}
.block--hero-slide-text .block--title {
    margin-bottom: clamp(30px, 2.59vw, 50px);
}
.block--hero-slide-text .block--title h1,
.block--hero-slide-text .block--title h2,
.block--hero-slide-text .block--title h3 {
    color: #fff;
    text-transform: uppercase;
    text-wrap: balance;
}
.home-hero-pagination button {
    padding: 0 5px 0 0;
    transition: 300ms;
    opacity: 0.4;
    font-weight: bold;
    font-size: 20px;
    background: transparent;
    line-height: 1;
}
.home-hero-pagination button:hover {
    transition: 300ms;
    opacity: 1;
    color: #e64d00;
}
.home-hero-pagination button.js-hero-count.is-active {
    border-right: 2px solid #e64d00;
    opacity: 1;
    transition: 400ms;
}
@media (min-width: 1025px) {
    .block--hero-slide-text {
        margin-bottom: 0%;
    }
    .block--hero-slide-text {
        position: relative;
        z-index: 6;
        margin-left: 5%;
        max-width: 50%;
    }
}
.home-showroom-slide {
    background: #1f1f1f;
}
.shoroom-slide-category .block--title {
    margin-bottom: 30px;
    margin: 40px 0;
    overflow: hidden;
}
.shoroom-slide-category .block--title h3 {
    text-wrap: balance;
    padding-right: 5%;
    color: #fff;
    text-transform: uppercase;
}
.shoroom-slide-category .page-header-separator {
    background: #e64d00;
    height: 5px;
    max-width: clamp(220px, 18.22vw, 350px);
    margin: 0 auto 10px;
    width: 100%;
}
.shoroom-slide-category .block--image {
    max-width: clamp(300px, 23.43vw, 450px);
    height: auto;
}
.home-showroom-arrows {
    display: flex;
    justify-content: center;
    gap: 20px;
    align-items: center;
    margin-top: 60px;
}
.home-showroom-arrows svg {
    max-width: clamp(30px, 3.12vw, 60px);
    cursor: pointer;
    transition: 300ms;
    overflow: visible;
}
.home-showroom-arrows > div:hover circle {
    transition: 300ms;
}
.home-showroom-arrows > div:hover circle {
    fill: #fff;
    stroke: #fff;
    transition: 300ms;
}
.prev-home-showroom.first-slide:hover circle,
.next-home-showroom.last-slide:hover circl {
    cursor: none;
    fill: unset;
    stroke: unset;
}
.prev-home-showroom,
.next-home-showroom {
    display: flex;
    transition: 300ms;
}
.prev-home-showroom.first-slide,
.next-home-showroom.last-slide {
    opacity: 0.4;
    transition: 300ms;
}
.home-design-text {
    max-width: clamp(500px, 43.22vw, 830px);
    margin: 0 auto;
    position: relative;
    z-index: 10;
}
.home-design-wrapper {
    min-height: clamp(800px, 84.63vw, 1625px);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.home-design-text h1 {
    text-transform: uppercase;
    text-wrap: balance;
}
.home-design-text .block--paragraph {
    max-width: clamp(400px, 25.25vw, 485px);
    text-wrap: balance;
    margin: 30px auto 40px;
}
.home-design-image-wrapper {
    position: absolute;
}
.home-design-image-wrapper.position-1 {
    left: 5vw;
    top: 26vw;
    max-width: clamp(180px, 16.14vw, 310px);
}
.home-design-image-wrapper.position-2 {
    right: 10vw;
    top: 17vw;
    max-width: clamp(80px, 11.71vw, 225px);
}
.home-design-image-wrapper.position-3 {
    left: 50%;
    top: 10vw;
    max-width: clamp(100px, 23.43vw, 450px);
    transform: translate(-50%, -30%);
}
.home-design-image-wrapper.position-4 {
    left: 52%;
    bottom: 7%;
    max-width: clamp(200px, 28.64vw, 500px);
}
.home-design-image-wrapper.position-5 {
    right: -6%;
    bottom: 43%;
    max-width: clamp(130px, 15.62vw, 300px);
}
.home-design-image-wrapper.position-6 {
    left: 0%;
    bottom: 13vw;
    max-width: clamp(200px, 28.64vw, 550px);
}
.home-design-text .block--button {
    margin: 0 auto;
}
@media (max-width: 1024px) {
    .home-design-image-wrapper.position-1 {
        left: -15vw;
        top: 22vw;
        max-width: clamp(232px, 16.14vw, 310px);
    }
    .home-design-image-wrapper.position-2 {
        right: -4vw;
        top: 20vw;
        max-width: clamp(139px, 11.71vw, 225px);
    }
    .home-design-image-wrapper.position-3 {
        left: 50%;
        top: -1vw;
        max-width: clamp(100px, 23.43vw, 450px);
        transform: translate(-50%, -30%);
    }
    .home-design-image-wrapper.position-4 {
        display: none;
    }
    .home-design-image-wrapper.position-5 {
        right: -6%;
        bottom: 43%;
        max-width: clamp(130px, 15.62vw, 300px);
    }
    .home-design-image-wrapper.position-6 {
        left: -13%;
        bottom: 30vw;
        max-width: clamp(261px, 28.64vw, 550px);
    }
    .home-design-image-wrapper {
        opacity: 0.15;
    }
    .home-design-wrapper {
        min-height: 1000px;
        display: flex;
        align-items: center;
        justify-content: center;
        overflow: hidden;
    }
}
.vibrate-1 {
    -webkit-animation: vibrate-1 7s linear infinite both;
    animation: vibrate-1 7s linear infinite both;
}
@-webkit-keyframes vibrate-1 {
    0% {
        -webkit-transform: translate(0);
        transform: translate(0);
    }
    20% {
        -webkit-transform: translate(-2px, 2px);
        transform: translate(-2px, 2px);
    }
    40% {
        -webkit-transform: translate(-2px, -2px);
        transform: translate(-2px, -2px);
    }
    60% {
        -webkit-transform: translate(2px, 2px);
        transform: translate(2px, 2px);
    }
    80% {
        -webkit-transform: translate(2px, -2px);
        transform: translate(2px, -2px);
    }
    100% {
        -webkit-transform: translate(0);
        transform: translate(0);
    }
}
@keyframes vibrate-1 {
    0% {
        -webkit-transform: translate(0);
        transform: translate(0);
    }
    20% {
        -webkit-transform: translate(-2px, 2px);
        transform: translate(-2px, 2px);
    }
    40% {
        -webkit-transform: translate(-2px, -2px);
        transform: translate(-2px, -2px);
    }
    60% {
        -webkit-transform: translate(2px, 2px);
        transform: translate(2px, 2px);
    }
    80% {
        -webkit-transform: translate(2px, -2px);
        transform: translate(2px, -2px);
    }
    100% {
        -webkit-transform: translate(0);
        transform: translate(0);
    }
}
.vibrate-2 {
    -webkit-animation: vibrate-1 5s linear infinite backwards;
    animation: vibrate-1 5s linear infinite backwards;
}
@-webkit-keyframes vibrate-2 {
    0% {
        -webkit-transform: translate(0);
        transform: translate(0);
    }
    20% {
        -webkit-transform: translate(-2px, 2px);
        transform: translate(-2px, 2px);
    }
    40% {
        -webkit-transform: translate(-2px, -2px);
        transform: translate(-2px, -2px);
    }
    60% {
        -webkit-transform: translate(2px, 2px);
        transform: translate(2px, 2px);
    }
    80% {
        -webkit-transform: translate(2px, -2px);
        transform: translate(2px, -2px);
    }
    100% {
        -webkit-transform: translate(0);
        transform: translate(0);
    }
}
@keyframes vibrate-1 {
    0% {
        -webkit-transform: translate(0);
        transform: translate(0);
    }
    20% {
        -webkit-transform: translate(-2px, 2px);
        transform: translate(-2px, 2px);
    }
    40% {
        -webkit-transform: translate(-2px, -2px);
        transform: translate(-2px, -2px);
    }
    60% {
        -webkit-transform: translate(2px, 2px);
        transform: translate(2px, 2px);
    }
    80% {
        -webkit-transform: translate(2px, -2px);
        transform: translate(2px, -2px);
    }
    100% {
        -webkit-transform: translate(0);
        transform: translate(0);
    }
}
.home-slides-image-carousel {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 3;
    height: 100%;
}
.home-slides-image-carousel img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}
.home-slides-image-content-wrapper:before {
    background: #0000005b;
    content: "";
    display: flex;
    height: 100%;
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 4;
}
.home-slides-image-content-wrapper {
    height: 100%;
    width: 100%;
}
.home-slides-carousel-text {
    position: relative;
    z-index: 6;
    height: 100%;
}
.home-slides-image-carousel .splide__track,
.home-slides-image-carousel .splide__list,
.home-slides-image-carousel .splide__slide {
    height: 100%;
}
.home-slides-carousel-text {
    max-width: 90%;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.block--home-carousel-slides-text .block--title h3 {
    color: #fff;
    text-transform: uppercase;
}
.block--home-carousel-slides-text {
    max-width: 100%;
    text-wrap: balance;
}
.home-slides-carousel-text {
    max-width: 90%;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 100%;
    min-height: 600px;
    max-height: 100%;
}
.home-slides-image-content-wrapper .home-showroom-arrows {
    position: absolute;
    right: 5%;
    bottom: 0;
    z-index: 10;
}
.home-slides-image-content-wrapper .home-showroom-arrows circle {
    stroke: #fff;
}
.home-slides-image-content-wrapper .home-showroom-arrows line {
    stroke: #fff;
}
.home-slides-image-content-wrapper .home-showroom-arrows circle {
    stroke: #fff;
}
.home-slides-image-content-wrapper .prev-home-showroom:hover line,
.home-slides-image-content-wrapper .next-home-showroom:hover line {
    stroke: #e64d00;
}
.home-slider-image-count {
    display: block;
}
@media (min-width: 1025px) {
    .home-slides-carousel-text {
        max-width: 90%;
        margin: 0 auto;
        display: flex;
        flex-direction: column;
        justify-content: space-between;
        height: 100vh;
        min-height: 600px;
        max-height: 800px;
    }
    .block--home-carousel-slides-text {
        max-width: 50%;
        text-wrap: balance;
    }
    .home-slider-image-count {
        position: absolute;
        bottom: 0;
        z-index: 10;
        color: #fff;
        left: 0;
        width: 100%;
        text-align: center;
        z-index: 4;
        display: block;
    }
}
@media (min-width: 1280px) {
    .single-post-header.promo-single .block--paragraph {
        max-width: clamp(400px, 35.41vw, 680px);
        margin: 0 auto;
    }
}
.promo-main-wrapper-image img {
    width: 100%;
    object-fit: cover;
    height: 100%;
}
.promo-details-wrapper .block--title h3 {
    text-transform: uppercase;
}
.promo-details-wrapper .block--title.promo-title {
    max-width: clamp(350px, 33.32vw, 640px);
    margin: 0 auto;
}
.promo-details-wrapper {
    margin-top: clamp(60px, 7.8vw, 150px);
}
.promo-detail-cards {
    margin-top: clamp(60px, 7.8vw, 150px);
    display: grid;
    grid-template-columns: 1fr;
    gap: 60px;
}
.promo-card-detail .block--title {
    text-transform: uppercase;
    margin-top: 20px;
    text-wrap: balance;
}
.promo-detail-cards .block--image {
    height: auto;
}
.block--title__30 {
    font-size: clamp(22px, 1.55vw, 30px);
    line-height: 1.3;
}
.single-post-header.promo-single .promo-gallery-wrapper.js-macy-gallery {
    margin-top: clamp(60px, 7.8vw, 150px);
}
@media (min-width: 1025px) {
    .promo-card-detail .block--title {
        max-width: 80%;
    }
    .promo-detail-cards .block--image {
        max-width: clamp(280px, 17.7vw, 320px);
    }
    .promo-card-detail {
        overflow: hidden;
        flex: 0 1 20%;
    }
    .promo-detail-cards {
        display: flex;
        justify-content: space-evenly;
        gap: 20px;
        flex-wrap: wrap;
        row-gap: 60px;
    }
    .promo-main-wrapper-image {
        max-height: clamp(380px, 41.66vw, 800px);
        overflow: hidden;
        height: 100%;
    }
}
.promo-loop-text .block--title h3 {
    text-transform: uppercase;
}
.promo-loop-text .block--paragraph {
    margin: 10px 0 50px;
}
@media (min-width: 1280px) {
    .promo-loop-text {
        max-width: 80%;
        margin: 0 auto;
    }
}
.section.promo-loop-items .section:nth-child(even) {
    background: #1f1f1f;
}
.section.promo-loop-items .section:nth-child(odd) {
    background-image: url(/wp-content/uploads/2025/11/background-lines-pattern.svg);
    background-color: #ffffff63;
    background-blend-mode: overlay;
    background-repeat: repeat-y;
    background-position: center;
    background-size: auto;
}
@media (max-width: 1024px) {
    .section.promo-loop-items .section:nth-child(odd) {
        background-image: url(/wp-content/uploads/2025/11/background-lines-pattern.svg);
        background-color: #ffffff63;
        background-blend-mode: overlay;
        background-repeat: repeat-y;
        background-position: center;
        background-size: contain;
    }
}
.section.promo-loop-items .section:nth-child(even) .promo-loop-text .block--title h3,
.section.promo-loop-items .section:nth-child(even) .promo-loop-text .block--paragraph {
    color: #fff;
}
.section.promo-loop-items .section:nth-child(even) .promo-loop-text .block--button a {
    color: #fff;
    border: 1px solid #fff;
}
.section.promo-loop-items .section:nth-child(even) .promo-loop-text .block--button a:hover {
    color: #333;
    background: #fff;
}
@media (max-width: 1024px) {
    .no-padding-bottom-mobile {
        padding-bottom: 0px;
    }
}
.header-main-wrapper {
    position: absolute;
    z-index: 100;
    top: 0;
    width: 100%;
    background: transparent;
    transition: 300ms;
    left: 0;
    padding: 20px 0;
}
.header-main-grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 30px;
    align-items: center;
}
.header-burger-wrapper {
    width: 30px;
    height: 30px;
    cursor: pointer;
    transition: 300ms;
    display: flex;
    flex-direction: column;
    gap: 6px;
    justify-content: center;
    align-items: flex-end;
    position: relative;
}
.header-burger-wrapper span:nth-child(2) {
    display: flex;
    width: 30px;
    height: 1px;
    background: #fff;
}
.header-burger-wrapper span {
    display: flex;
    width: 25px;
    height: 1px;
    background: #fff;
    transition: 300ms;
}
.header-burger-wrapper:hover span {
    width: 30px;
    transition: 300ms;
}
.header-burger-wrapper.active span:first-child {
    transition: 300ms;
    position: absolute;
    transform: rotate(45deg);
    top: 50%;
    left: 0;
}
.header-burger-wrapper.active span:last-child {
    transition: 300ms;
    position: absolute;
    transform: rotate(-45deg);
    top: 50%;
    left: 0;
}
.header-burger-wrapper.active span:nth-child(2) {
    transition: 300ms;
    position: absolute;
    transform: rotate(-45deg);
    top: 50%;
    left: 0;
}
.header-social-wrapper svg,
.header-search-wrapper svg {
    transition: 300ms;
    height: 25px;
    width: 25px;
    fill: #fff;
}
.header-social-wrapper svg:hover,
.header-search-wrapper svg:hover {
    transition: 300ms;
    fill: #ffffffbd;
}
.header-social-wrapper a {
    display: flex;
}
.header-social-wrapper {
    display: flex;
    align-items: center;
    gap: clamp(20px, 1.3vw, 25px);
}
.header-search-and-social > div {
    display: flex;
    justify-content: flex-end;
    gap: clamp(20px, 1.3vw, 25px);
}
.header-search-wrapper {
    display: flex;
    cursor: pointer;
}
.header-logo-wrapper {
    display: flex;
    justify-content: center;
}
.header-logo-wrapper a {
    display: flex;
    max-width: clamp(100px, 6.76vw, 130px);
}
.header-search-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
}
.header-search-box {
    position: absolute;
    top: 0;
    left: 0;
    height: 100vh;
    width: 100vw;
    background: #1c1c1c52;
    z-index: -10000;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
}
.header-search-box.active {
    transition: 500ms;
    z-index: 10000;
    position: absolute;
    top: 0;
    left: 0;
    height: 100vh;
    width: 100vw;
    background: #1c1c1c52;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 1;
}
.blur {
    filter: blur(60px);
}
.no-scroll {
    overflow: hidden;
}
.header-close-search {
    width: 30px;
    height: 30px;
    position: absolute;
    top: 5%;
    right: 5%;
    cursor: pointer;
}
.header-close-search span {
    width: 30px;
    height: 1px;
    background: #fff;
    display: flex;
    position: absolute;
    top: 50%;
}
.header-close-search span:first-child {
    transform: rotate(45deg);
}
.header-close-search span:last-child {
    transform: rotate(-45deg);
}
.header-searchbar-wrapper {
    display: flex;
    justify-content: center;
    align-items: center;
}
.search-results-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    margin-top: 60px;
}
.search-results-list a {
    display: flex;
    flex-direction: column;
    gap: 20px;
    text-decoration: none;
}
.header-submenu-wrapper {
    position: absolute;
    background: #fff;
    width: 100%;
    height: 0;
    z-index: 100;
    transition: 300ms;
    opacity: 0;
    visibility: hidden;
    overflow: hidden;
}
.header-submenu-wrapper.active {
    position: absolute;
    background: #fff;
    width: 100%;
    height: 100vh;
    z-index: 100;
    transition: 300ms;
    opacity: 1;
    visibility: visible;
    overflow: visible;
    padding-top: 100px;
}
.footer-logo path {
    fill: #fff;
}
.header-main-wrapper.burger-closed .header-logo-wrapper a path {
    fill: #fff;
}
.header-main-wrapper .header-logo-wrapper a path {
    fill: auto;
}
.header-main-wrapper.burger-opened {
    background: #fff;
}
.header-main-wrapper.burger-opened .header-search-and-social svg {
    transition: 300ms;
    fill: #333;
}
.header-main-wrapper.burger-opened span {
    background: #333;
}
.header-submenu-wrapper .row,
.header-submenu-wrapper .column {
    height: 100%;
}
.header-submenu-content {
    display: flex;
    width: 100%;
    height: 100%;
    flex-direction: column;
}
.block--submenu-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: 300ms;
    position: relative;
    flex-direction: column;
    cursor: pointer;
}
.block--submenu-item.has-children span:first-child {
    background: #ccc;
    width: 15px;
    height: 1px;
    display: flex;
    transition: 300ms;
}
.block--submenu-item.has-children span:last-child {
    background: #ccc;
    width: 15px;
    height: 1px;
    display: flex;
    transform: rotate(90deg);
    transition: 300ms;
}
.block--submenu-item.has-children > a {
    display: flex;
    align-items: center;
    gap: 20px;
    justify-content: space-between;
}
.block--subcontent-childs {
    opacity: 0;
    visibility: hidden;
    height: 0;
    transition: 300ms;
}
.block--subcontent-childs.open {
    opacity: 1;
    visibility: visible;
    height: auto;
    transition: 1s;
}
.father-wrapper-links {
    font-size: clamp(20px, 2.07vw, 40px);
    text-decoration: none;
    text-transform: uppercase;
    line-height: 1;
    font-family: "Merriweather";
    color: #333;
    transition: 300ms;
}
.father-wrapper-links:hover {
    color: #e64d00;
    transition: 300ms;
}
.block--subcontent-childs a {
    color: #333;
    text-decoration: none;
    line-height: 1;
}
.block--subcontent-childs a:hover {
    color: #e64d00;
    text-decoration: none;
    line-height: 1;
}
.block--subcontent-childs.open {
    display: flex;
    flex-direction: column;
    gap: 15px;
    padding: 0 0 clamp(20px, 2.02vw, 39px) 0;
}
.header-submenu-content > div:after {
    display: flex;
    content: "";
    width: 30px;
    height: 1px;
    background: #e64d00;
}
.header-submenu-content > div {
    padding-bottom: clamp(20px, 1.5vw, 29px);
}
.header-submenu-content > .block--submenu-item > a {
    padding-bottom: 19px;
    font-weight: 300;
}
.header-submenu-content .block--submenu-item:last-child > a {
    padding: 0;
}
.header-submenu-content .block--submenu-item:last-child:after {
    display: none;
}
.header-submenu-wrapper,
.header-submenu-content {
    overflow-y: auto !important;
}
.header-submenu-content {
    padding-bottom: 220px;
}
.block--submenu-item.has-children > a > div {
    display: none;
}
.icon-toggle-open span:last-child {
    transition: 300ms !important;
    transform: rotate(0deg) !important;
}
.header-submenu-content .header-social-wrapper svg {
    fill: #333;
}
.header-submenu-content .header-social-wrapper:after {
    display: none;
}
.header-submenu-content .header-social-wrapper {
    justify-content: center;
    margin-top: 60px;
}
.header-submenu-content .header-social-wrapper {
    display: none;
}
@media (max-width: 1024px) {
    .header-submenu-content .header-social-wrapper {
        display: flex;
    }
    .block--submenu-item.has-children > a > div {
        display: block;
    }
    .header-main-wrapper .header-search-and-social .header-social-wrapper {
        display: none;
    }
}
form.search-form {
    display: flex;
}
.header-burger-wrapper.active span:nth-child(2) {
    width: 30px;
    opacity: 0;
}
.header-burger-wrapper.active span {
    width: 30px;
}
.header-searchbar-wrapper label {
    width: 100%;
}
.header-searchbar-wrapper input.search-field {
    width: clamp(240px, 26.03vw, 500px);
}

.header-search-and-social .block--button {
    display: none;
}
.header-submenu-wrapper .block--button.block--button--primary {
    margin: 0 auto;
}
.header-submenu-wrapper .block--button.block--button--primary:after{
	display: none;
}
.header-submenu-wrapper .block--button{
   display: flex;
}
@media(min-width: 1025px){
	.header-submenu-wrapper .block--button{
	   display: none;
	}
	.header-search-and-social .block--button {
		display: flex;
	}
	.header-search-and-social a.block--button__link {
		padding: 6px 10px!important;
		min-width: 130px;
		font-size: 14px;
	}
}