.elementor-548 .elementor-element.elementor-element-460cdf2:not(.elementor-motion-effects-element-type-background), .elementor-548 .elementor-element.elementor-element-460cdf2 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-image:url("https://xioline.com/wp-content/uploads/2026/06/Untitled-design-2026-06-21T155936.095.png");background-position:0px 8px;background-repeat:no-repeat;background-size:cover;}.elementor-548 .elementor-element.elementor-element-460cdf2 > .elementor-container{min-height:61vh;}.elementor-548 .elementor-element.elementor-element-460cdf2{transition:background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;}.elementor-548 .elementor-element.elementor-element-460cdf2 > .elementor-background-overlay{transition:background 0.3s, border-radius 0.3s, opacity 0.3s;}.elementor-548 .elementor-element.elementor-element-c7cc64a .elementor-icon-list-icon i{color:var( --e-global-color-e0dbc55 );transition:color 0.3s;}.elementor-548 .elementor-element.elementor-element-c7cc64a .elementor-icon-list-icon svg{fill:var( --e-global-color-e0dbc55 );transition:fill 0.3s;}.elementor-548 .elementor-element.elementor-element-c7cc64a{--e-icon-list-icon-size:14px;--icon-vertical-offset:0px;}.elementor-548 .elementor-element.elementor-element-c7cc64a .elementor-icon-list-text{color:var( --e-global-color-e0dbc55 );transition:color 0.3s;}.elementor-548 .elementor-element.elementor-element-c7cc64a .elementor-icon-list-item:hover .elementor-icon-list-text{color:var( --e-global-color-c542f99 );}.elementor-548 .elementor-element.elementor-element-907ae22{text-align:center;}.elementor-548 .elementor-element.elementor-element-907ae22 .elementor-heading-title{color:var( --e-global-color-e0dbc55 );}.elementor-548 .elementor-element.elementor-element-291e475 > .elementor-element-populated{margin:0px 0px 0px 0px;--e-column-margin-right:0px;--e-column-margin-left:0px;padding:0px 0px 0px 0px;}.elementor-548 .elementor-element.elementor-element-1b4c50a.elementor-wc-products  ul.products{grid-column-gap:20px;grid-row-gap:40px;}.elementor-548 .elementor-element.elementor-element-1b4c50a.elementor-wc-products ul.products li.product span.onsale{display:block;}@media(min-width:1025px){.elementor-548 .elementor-element.elementor-element-460cdf2:not(.elementor-motion-effects-element-type-background), .elementor-548 .elementor-element.elementor-element-460cdf2 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-attachment:fixed;}}@media(max-width:1024px){.elementor-548 .elementor-element.elementor-element-460cdf2:not(.elementor-motion-effects-element-type-background), .elementor-548 .elementor-element.elementor-element-460cdf2 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-position:0px 0px;}.elementor-548 .elementor-element.elementor-element-921ae24{margin-top:30px;margin-bottom:0px;padding:0px 20px 0px 20px;}.elementor-548 .elementor-element.elementor-element-291e475 > .elementor-element-populated{margin:0px 0px 20px 0px;--e-column-margin-right:0px;--e-column-margin-left:0px;padding:0px 0px 0px 0px;}.elementor-548 .elementor-element.elementor-element-1b4c50a.elementor-wc-products  ul.products{grid-column-gap:20px;grid-row-gap:40px;}}@media(max-width:767px){.elementor-548 .elementor-element.elementor-element-460cdf2 > .elementor-container{min-height:60vh;}.elementor-548 .elementor-element.elementor-element-460cdf2:not(.elementor-motion-effects-element-type-background), .elementor-548 .elementor-element.elementor-element-460cdf2 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-position:-195px 0px;}.elementor-548 .elementor-element.elementor-element-460cdf2{margin-top:0px;margin-bottom:0px;padding:0px 0px 0px 0px;}.elementor-548 .elementor-element.elementor-element-921ae24{margin-top:30px;margin-bottom:20px;padding:0px 20px 0px 20px;}.elementor-548 .elementor-element.elementor-element-291e475 > .elementor-element-populated{margin:0px 0px 0px 0px;--e-column-margin-right:0px;--e-column-margin-left:0px;padding:0px 0px 0px 0px;}.elementor-548 .elementor-element.elementor-element-1b4c50a.elementor-wc-products  ul.products{grid-column-gap:20px;grid-row-gap:40px;}}/* Start custom CSS for section, class: .elementor-element-460cdf2 *//* =====================================================
   XIOLINE PREMIUM CONTACT HERO
   Main section class: xioline-contact-hero
   Colours used: Black, White and Grey only
===================================================== */

.xioline-contact-hero {
    position: relative;
    min-height: 600px;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    isolation: isolate;

    background-position: center center !important;
    background-size: cover !important;
    background-repeat: no-repeat !important;
}

/* Main black luxury overlay */
.xioline-contact-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 0;
    pointer-events: none;

    background:
        radial-gradient(
            circle at center,
            rgba(17, 17, 17, 0.42) 0%,
            rgba(17, 17, 17, 0.66) 55%,
            rgba(0, 0, 0, 0.88) 100%
        ),
        linear-gradient(
            90deg,
            rgba(0, 0, 0, 0.76) 0%,
            rgba(17, 17, 17, 0.48) 50%,
            rgba(0, 0, 0, 0.76) 100%
        );
}

/* Soft centre glow */
.xioline-contact-hero::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 720px;
    height: 360px;
    transform: translate(-50%, -50%);
    z-index: 1;
    pointer-events: none;

    border-radius: 50%;
    background: rgba(255, 255, 255, 0.07);
    filter: blur(90px);
}

/* Elementor section container */
.xioline-contact-hero > .elementor-container,
.xioline-contact-hero > .e-con-inner {
    position: relative;
    z-index: 2;
    width: 100%;
    display: flex;
    justify-content: center;
}

/* Elementor column */
.xioline-contact-hero .elementor-column {
    width: 100%;
}

/* Main premium content panel */
.xioline-contact-hero .elementor-widget-wrap {
    position: relative;

    width: calc(100% - 40px);
    max-width: 960px;
    min-height: 310px;

    margin: 0 auto;
    padding: 52px 70px 58px !important;

    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;

    text-align: center;

    background:
        linear-gradient(
            145deg,
            rgba(17, 17, 17, 0.78),
            rgba(0, 0, 0, 0.88)
        );

    border: 1px solid rgba(255, 255, 255, 0.38);
    border-radius: 34px;

    box-shadow:
        0 30px 80px rgba(0, 0, 0, 0.48),
        inset 0 1px 0 rgba(255, 255, 255, 0.14),
        inset 0 -1px 0 rgba(255, 255, 255, 0.05);

    backdrop-filter: blur(13px);
    -webkit-backdrop-filter: blur(13px);
}

/* Fine inner border */
.xioline-contact-hero .elementor-widget-wrap::before {
    content: "";
    position: absolute;
    inset: 10px;

    border: 1px solid rgba(255, 255, 255, 0.14);
    border-radius: 26px;

    pointer-events: none;
}

/* Centre highlight line */
.xioline-contact-hero .elementor-widget-wrap::after {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;

    width: 58%;
    height: 1px;

    transform: translateX(-50%);

    background: linear-gradient(
        90deg,
        transparent,
        rgba(255, 255, 255, 0.9),
        transparent
    );

    box-shadow: 0 0 18px rgba(255, 255, 255, 0.38);
}

/* Remove Elementor default widget spacing */
.xioline-contact-hero .elementor-widget {
    margin-bottom: 0 !important;
}

/* =====================================================
   BREADCRUMB
===================================================== */

.xioline-contact-hero .elementor-widget-icon-list {
    position: relative;
    margin-bottom: 24px !important;
    z-index: 2;
}

.xioline-contact-hero .elementor-icon-list-items {
    display: flex !important;
    align-items: center;
    justify-content: center;
    flex-wrap: nowrap;

    gap: 20px;
}

.xioline-contact-hero .elementor-icon-list-item {
    margin: 0 !important;
    padding: 0 !important;
}

/* Breadcrumb text */
.xioline-contact-hero .elementor-icon-list-text {
    color: #FFFFFF !important;

    font-size: 13px !important;
    font-weight: 500 !important;
    line-height: 1.4;

    letter-spacing: 4px;
    text-transform: uppercase;

    text-shadow: 0 2px 12px rgba(0, 0, 0, 0.7);
}

/* Breadcrumb arrow/icon */
.xioline-contact-hero .elementor-icon-list-icon {
    color: #FFFFFF !important;
}

.xioline-contact-hero .elementor-icon-list-icon i {
    color: #FFFFFF !important;
    font-size: 10px !important;
}

.xioline-contact-hero .elementor-icon-list-icon svg {
    width: 10px !important;
    height: 10px !important;

    fill: #FFFFFF !important;
    color: #FFFFFF !important;
}

/* =====================================================
   HEADING AREA
===================================================== */

.xioline-contact-hero .elementor-widget-heading {
    position: relative;
    width: 100%;

    padding-top: 34px;
    padding-bottom: 32px;

    z-index: 2;
}

/* Top decorative line */
.xioline-contact-hero .elementor-widget-heading::before {
    content: "✦";

    position: absolute;
    top: 0;
    left: 50%;

    width: 270px;
    transform: translateX(-50%);

    color: #FFFFFF;

    font-size: 12px;
    line-height: 20px;
    text-align: center;

    background:
        linear-gradient(
            90deg,
            transparent,
            rgba(255, 255, 255, 0.7)
        )
        left center / 105px 1px no-repeat,

        linear-gradient(
            90deg,
            rgba(255, 255, 255, 0.7),
            transparent
        )
        right center / 105px 1px no-repeat;
}

/* Bottom decorative line */
.xioline-contact-hero .elementor-widget-heading::after {
    content: "◆";

    position: absolute;
    bottom: 0;
    left: 50%;

    width: 340px;
    transform: translateX(-50%);

    color: #FFFFFF;

    font-size: 7px;
    line-height: 14px;
    text-align: center;

    background:
        linear-gradient(
            90deg,
            transparent,
            rgba(255, 255, 255, 0.7)
        )
        left center / 145px 1px no-repeat,

        linear-gradient(
            90deg,
            rgba(255, 255, 255, 0.7),
            transparent
        )
        right center / 145px 1px no-repeat;
}

/* Main Contact Us heading */
.xioline-contact-hero .elementor-heading-title {
    margin: 0 !important;

    color: #FFFFFF !important;

    font-family:
        "Cormorant Garamond",
        "Playfair Display",
        Georgia,
        serif !important;

    font-size: clamp(60px, 7vw, 104px) !important;
    font-weight: 400 !important;
    line-height: 0.95 !important;

    letter-spacing: -2px;
    text-transform: none;

    text-shadow:
        0 4px 22px rgba(0, 0, 0, 0.75),
        0 0 35px rgba(255, 255, 255, 0.08);
}

/* Optional subtle shine on heading */
.xioline-contact-hero .elementor-heading-title {
    background: linear-gradient(
        180deg,
        #FFFFFF 0%,
        #F5F5F5 55%,
        #D9D9D9 100%
    );

    -webkit-background-clip: text;
    background-clip: text;

    -webkit-text-fill-color: transparent;
}

/* =====================================================
   OPTIONAL XIOLINE-STYLE CORNER DETAILS
===================================================== */

.xioline-contact-hero .elementor-column::before,
.xioline-contact-hero .elementor-column::after {
    content: "";
    position: absolute;

    width: 70px;
    height: 70px;

    z-index: 4;
    pointer-events: none;
}

/* Top-left corner */
.xioline-contact-hero .elementor-column::before {
    top: 18px;
    left: calc(50% - 462px);

    border-top: 1px solid rgba(255, 255, 255, 0.5);
    border-left: 1px solid rgba(255, 255, 255, 0.5);

    border-radius: 24px 0 0 0;
}

/* Bottom-right corner */
.xioline-contact-hero .elementor-column::after {
    right: calc(50% - 462px);
    bottom: 18px;

    border-right: 1px solid rgba(255, 255, 255, 0.5);
    border-bottom: 1px solid rgba(255, 255, 255, 0.5);

    border-radius: 0 0 24px 0;
}

/* =====================================================
   HOVER EFFECT
===================================================== */

.xioline-contact-hero .elementor-widget-wrap {
    transition:
        transform 0.4s ease,
        border-color 0.4s ease,
        box-shadow 0.4s ease;
}

.xioline-contact-hero .elementor-widget-wrap:hover {
    transform: translateY(-4px);

    border-color: rgba(255, 255, 255, 0.62);

    box-shadow:
        0 38px 95px rgba(0, 0, 0, 0.58),
        0 0 0 1px rgba(255, 255, 255, 0.04),
        inset 0 1px 0 rgba(255, 255, 255, 0.18);
}

/* =====================================================
   TABLET
===================================================== */

@media screen and (max-width: 1024px) {

    .xioline-contact-hero {
        min-height: 350px;
    }

    .xioline-contact-hero .elementor-widget-wrap {
        width: calc(100% - 50px);
        max-width: 780px;
        min-height: 290px;

        padding: 48px 48px 52px !important;

        border-radius: 30px;
    }

    .xioline-contact-hero .elementor-widget-wrap::before {
        border-radius: 22px;
    }

    .xioline-contact-hero .elementor-heading-title {
        font-size: 74px !important;
    }

    .xioline-contact-hero .elementor-column::before {
        left: calc(50% - 370px);
    }

    .xioline-contact-hero .elementor-column::after {
        right: calc(50% - 370px);
    }
}

/* =====================================================
   MOBILE
===================================================== */

@media screen and (max-width: 767px) {

    .xioline-contact-hero {
        min-height: 290px;

        background-position: center center !important;
    }

    .xioline-contact-hero::after {
        width: 320px;
        height: 240px;

        filter: blur(55px);
    }

    .xioline-contact-hero .elementor-widget-wrap {
        width: calc(100% - 30px);
        min-height: 260px;

        padding: 40px 20px 44px !important;

        border-radius: 24px;

        backdrop-filter: blur(9px);
        -webkit-backdrop-filter: blur(9px);
    }

    .xioline-contact-hero .elementor-widget-wrap::before {
        inset: 7px;
        border-radius: 18px;
    }

    .xioline-contact-hero .elementor-widget-wrap::after {
        width: 65%;
    }

    .xioline-contact-hero .elementor-icon-list-items {
        gap: 10px;
    }

    .xioline-contact-hero .elementor-icon-list-text {
        font-size: 10px !important;
        letter-spacing: 2px;
    }

    .xioline-contact-hero .elementor-icon-list-icon i {
        font-size: 8px !important;
    }

    .xioline-contact-hero .elementor-widget-icon-list {
        margin-bottom: 20px !important;
    }

    .xioline-contact-hero .elementor-widget-heading {
        padding-top: 28px;
        padding-bottom: 28px;
    }

    .xioline-contact-hero .elementor-heading-title {
        font-size: 48px !important;
        line-height: 1 !important;
        letter-spacing: -1px;
    }

    .xioline-contact-hero .elementor-widget-heading::before {
        width: 190px;

        background:
            linear-gradient(
                90deg,
                transparent,
                rgba(255, 255, 255, 0.65)
            )
            left center / 70px 1px no-repeat,

            linear-gradient(
                90deg,
                rgba(255, 255, 255, 0.65),
                transparent
            )
            right center / 70px 1px no-repeat;
    }

    .xioline-contact-hero .elementor-widget-heading::after {
        width: 230px;

        background:
            linear-gradient(
                90deg,
                transparent,
                rgba(255, 255, 255, 0.65)
            )
            left center / 92px 1px no-repeat,

            linear-gradient(
                90deg,
                rgba(255, 255, 255, 0.65),
                transparent
            )
            right center / 92px 1px no-repeat;
    }

    /* Hide large outer corner lines on mobile */
    .xioline-contact-hero .elementor-column::before,
    .xioline-contact-hero .elementor-column::after {
        display: none;
    }

    .xioline-contact-hero .elementor-widget-wrap:hover {
        transform: none;
    }
}

/* =====================================================
   SMALL MOBILE
===================================================== */

@media screen and (max-width: 420px) {

    .xioline-contact-hero {
        min-height: 360px;
    }

    .xioline-contact-hero .elementor-widget-wrap {
        width: calc(100% - 22px);
        padding: 36px 15px 40px !important;
    }

    .xioline-contact-hero .elementor-heading-title {
        font-size: 42px !important;
    }

    .xioline-contact-hero .elementor-icon-list-text {
        font-size: 9px !important;
        letter-spacing: 1.5px;
    }

    .xioline-contact-hero .elementor-widget-heading::after {
        width: 200px;

        background:
            linear-gradient(
                90deg,
                transparent,
                rgba(255, 255, 255, 0.65)
            )
            left center / 78px 1px no-repeat,

            linear-gradient(
                90deg,
                rgba(255, 255, 255, 0.65),
                transparent
            )
            right center / 78px 1px no-repeat;
    }
}/* End custom CSS */
/* Start custom CSS for section, class: .elementor-element-921ae24 *//* =========================================================
   XIOLINE PREMIUM SHOP PRODUCT GRID
   Main section class: xioline-shop-products
========================================================= */

.xioline-shop-products {
    position: relative;
    overflow: hidden;
    isolation: isolate;

    padding: 75px 45px 90px !important;

    background:
        radial-gradient(
            circle at 50% -20%,
            rgba(17, 17, 17, 0.035),
            transparent 38%
        ),
        linear-gradient(
            135deg,
            #ffffff 0%,
            #f7f7f7 50%,
            #ffffff 100%
        ) !important;

    border-top: 1px solid rgba(17, 17, 17, 0.08);
    border-bottom: 1px solid rgba(17, 17, 17, 0.08);
}

/* Decorative background detail */
.xioline-shop-products::before {
    content: "";
    position: absolute;
    top: -250px;
    right: -170px;

    width: 560px;
    height: 560px;

    border: 1px solid rgba(17, 17, 17, 0.045);
    border-radius: 50%;

    pointer-events: none;
    z-index: 0;
}

/* Premium top line */
.xioline-shop-products::after {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;

    width: 50%;
    height: 1px;

    transform: translateX(-50%);

    background: linear-gradient(
        90deg,
        transparent,
        rgba(17, 17, 17, 0.55),
        transparent
    );

    pointer-events: none;
    z-index: 2;
}

/* Main section container */
.xioline-shop-products > .elementor-container,
.xioline-shop-products > .e-con-inner {
    position: relative;
    z-index: 2;

    max-width: 1380px;
    margin: 0 auto;
}

/* =========================================================
   RESULT COUNT + SORTING BAR
========================================================= */

.xioline-shop-products .woocommerce-result-count,
.xioline-shop-products .woocommerce-ordering {
    margin-bottom: 38px !important;
}

/* Result count */
.xioline-shop-products .woocommerce-result-count {
    color: #666666 !important;

    font-family: "Montserrat", Arial, sans-serif !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    line-height: 1.5;

    letter-spacing: 1px;
}

/* Sorting dropdown */
.xioline-shop-products .woocommerce-ordering select {
    min-width: 250px;
    height: 52px;

    padding: 0 44px 0 18px !important;

    color: #111111 !important;
    background: #ffffff !important;

    border: 1px solid rgba(17, 17, 17, 0.18) !important;
    border-radius: 10px !important;

    box-shadow:
        0 10px 25px rgba(0, 0, 0, 0.055);

    font-family: "Montserrat", Arial, sans-serif !important;
    font-size: 13px !important;
    font-weight: 500 !important;

    cursor: pointer;
    outline: none;

    transition:
        border-color 0.3s ease,
        box-shadow 0.3s ease;
}

.xioline-shop-products .woocommerce-ordering select:focus {
    border-color: #111111 !important;

    box-shadow:
        0 0 0 3px rgba(17, 17, 17, 0.06),
        0 12px 28px rgba(0, 0, 0, 0.08);
}

/* =========================================================
   PRODUCT GRID
========================================================= */

.xioline-shop-products ul.products {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;

    gap: 30px !important;

    margin: 0 !important;
    padding: 0 !important;
}

/* Product card */
.xioline-shop-products ul.products li.product {
    position: relative;
    overflow: hidden;

    width: 100% !important;
    margin: 0 !important;
    padding: 14px 14px 26px !important;

    background:
        linear-gradient(
            145deg,
            #ffffff 0%,
            #f4f4f4 100%
        );

    border: 1px solid rgba(17, 17, 17, 0.10);
    border-radius: 22px;

    box-shadow:
        0 20px 48px rgba(0, 0, 0, 0.07),
        inset 0 1px 0 rgba(255, 255, 255, 1);

    transition:
        transform 0.4s ease,
        border-color 0.4s ease,
        box-shadow 0.4s ease;
}

/* Fine top accent */
.xioline-shop-products ul.products li.product::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;

    width: 42%;
    height: 2px;

    transform: translateX(-50%);

    background: linear-gradient(
        90deg,
        transparent,
        #111111,
        transparent
    );

    opacity: 0.42;
}

/* Product card hover */
.xioline-shop-products ul.products li.product:hover {
    transform: translateY(-9px);

    border-color: rgba(17, 17, 17, 0.26);

    box-shadow:
        0 30px 68px rgba(0, 0, 0, 0.12),
        inset 0 1px 0 rgba(255, 255, 255, 1);
}

/* Product link */
.xioline-shop-products
ul.products
li.product
.woocommerce-LoopProduct-link {
    display: block;

    color: inherit !important;
    text-decoration: none !important;
}

/* =========================================================
   PRODUCT IMAGE
========================================================= */

.xioline-shop-products ul.products li.product img {
    display: block;

    width: 100% !important;
    aspect-ratio: 1 / 1;

    margin: 0 0 22px !important;
    padding: 12px;

    object-fit: contain;

    background: #ffffff;

    border: 1px solid rgba(17, 17, 17, 0.07);
    border-radius: 16px;

    box-shadow:
        0 12px 30px rgba(0, 0, 0, 0.055);

    transition:
        transform 0.55s ease,
        filter 0.55s ease,
        box-shadow 0.55s ease;
}

.xioline-shop-products ul.products li.product:hover img {
    transform: scale(1.025);

    filter:
        saturate(1.03)
        contrast(1.02);

    box-shadow:
        0 18px 42px rgba(0, 0, 0, 0.09);
}

/* =========================================================
   SALE BADGE
========================================================= */

.xioline-shop-products ul.products li.product .onsale {
    top: 20px !important;
    right: 20px !important;
    left: auto !important;

    min-width: 58px !important;
    min-height: 58px !important;

    display: flex;
    align-items: center;
    justify-content: center;

    margin: 0 !important;
    padding: 5px !important;

    color: #ffffff !important;
    background: #111111 !important;

    border: 4px solid #ffffff;
    border-radius: 50% !important;

    box-shadow:
        0 12px 28px rgba(0, 0, 0, 0.20);

    font-family: "Montserrat", Arial, sans-serif !important;
    font-size: 9px !important;
    font-weight: 600 !important;
    line-height: 1 !important;

    letter-spacing: 1.5px;
    text-transform: uppercase;

    z-index: 5;
}

/* =========================================================
   PRODUCT TITLE
========================================================= */

.xioline-shop-products
ul.products
li.product
.woocommerce-loop-product__title {
    margin: 0 8px 12px !important;

    color: #111111 !important;

    font-family:
        "Cormorant Garamond",
        "Playfair Display",
        Georgia,
        serif !important;

    font-size: 25px !important;
    font-weight: 500 !important;
    line-height: 1.25 !important;

    letter-spacing: 0.1px;

    transition: color 0.3s ease;
}

.xioline-shop-products
ul.products
li.product:hover
.woocommerce-loop-product__title {
    color: #4c4c4c !important;
}

/* =========================================================
   PRODUCT PRICE
========================================================= */

.xioline-shop-products ul.products li.product .price {
    display: flex;
    align-items: center;
    flex-wrap: wrap;

    gap: 8px;

    min-height: 28px;

    margin: 0 8px 21px !important;

    color: #111111 !important;

    font-family: "Montserrat", Arial, sans-serif !important;
    font-size: 14px !important;
    font-weight: 500 !important;
}

/* Old price */
.xioline-shop-products ul.products li.product .price del {
    color: #8b8b8b !important;
    opacity: 1 !important;

    font-size: 12px !important;
    font-weight: 400 !important;
}

/* Sale price */
.xioline-shop-products ul.products li.product .price ins {
    color: #111111 !important;
    background: transparent !important;

    font-size: 15px !important;
    font-weight: 600 !important;

    text-decoration: none !important;

    border-bottom: 1px solid #111111;
}

/* =========================================================
   ADD TO CART BUTTON
========================================================= */

.xioline-shop-products ul.products li.product .button {
    position: relative;
    overflow: hidden;

    width: calc(100% - 16px);

    margin: 0 8px !important;
    padding: 16px 20px !important;

    color: #ffffff !important;
    background: #111111 !important;

    border: 1px solid #111111 !important;
    border-radius: 10px !important;

    box-shadow:
        0 13px 30px rgba(0, 0, 0, 0.16),
        inset 0 1px 0 rgba(255, 255, 255, 0.10);

    font-family: "Montserrat", Arial, sans-serif !important;
    font-size: 10px !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;

    letter-spacing: 3px;
    text-align: center;
    text-transform: uppercase;

    transition:
        transform 0.35s ease,
        color 0.35s ease,
        background-color 0.35s ease,
        box-shadow 0.35s ease;
}

/* Button shine */
.xioline-shop-products ul.products li.product .button::before {
    content: "";
    position: absolute;

    top: 0;
    left: -130%;

    width: 85%;
    height: 100%;

    background: linear-gradient(
        90deg,
        transparent,
        rgba(255, 255, 255, 0.23),
        transparent
    );

    transform: skewX(-22deg);

    transition: left 0.55s ease;
}

.xioline-shop-products ul.products li.product .button:hover {
    transform: translateY(-3px);

    color: #111111 !important;
    background: #ffffff !important;

    border-color: #111111 !important;

    box-shadow:
        0 18px 38px rgba(0, 0, 0, 0.14);
}

.xioline-shop-products
ul.products
li.product
.button:hover::before {
    left: 130%;
}

/* View cart after adding */
.xioline-shop-products ul.products li.product .added_to_cart {
    display: block;

    margin: 12px 8px 0 !important;

    color: #111111 !important;

    font-family: "Montserrat", Arial, sans-serif !important;
    font-size: 10px !important;
    font-weight: 600 !important;

    letter-spacing: 2px;
    text-align: center;
    text-transform: uppercase;
}

/* =========================================================
   TABLET
========================================================= */

@media screen and (max-width: 1024px) {

    .xioline-shop-products {
        padding: 65px 28px 75px !important;
    }

    .xioline-shop-products ul.products {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 20px !important;
    }

    .xioline-shop-products
    ul.products
    li.product
    .woocommerce-loop-product__title {
        font-size: 21px !important;
    }

    .xioline-shop-products .woocommerce-ordering select {
        min-width: 220px;
    }
}

/* =========================================================
   MOBILE
========================================================= */

@media screen and (max-width: 767px) {

    .xioline-shop-products {
        padding: 48px 12px 60px !important;
    }

    /* Result count and sorting */
    .xioline-shop-products .woocommerce-result-count,
    .xioline-shop-products .woocommerce-ordering {
        float: none !important;
        width: 100%;
    }

    .xioline-shop-products .woocommerce-result-count {
        margin-bottom: 14px !important;

        font-size: 12px !important;
        text-align: center;
    }

    .xioline-shop-products .woocommerce-ordering {
        margin-bottom: 28px !important;
    }

    .xioline-shop-products .woocommerce-ordering select {
        width: 100%;
        min-width: 0;
        height: 50px;
    }

    /* Two products per row */
    .xioline-shop-products ul.products {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 11px !important;
    }

    .xioline-shop-products ul.products li.product {
        padding: 8px 8px 16px !important;

        border-radius: 16px;
    }

    .xioline-shop-products ul.products li.product img {
        margin-bottom: 14px !important;
        padding: 5px;

        border-radius: 11px;
    }

    .xioline-shop-products ul.products li.product .onsale {
        top: 11px !important;
        right: 11px !important;

        min-width: 43px !important;
        min-height: 43px !important;

        border-width: 3px;

        font-size: 7px !important;
        letter-spacing: 1px;
    }

    .xioline-shop-products
    ul.products
    li.product
    .woocommerce-loop-product__title {
        margin: 0 3px 8px !important;

        font-size: 18px !important;
        line-height: 1.2 !important;
    }

    .xioline-shop-products ul.products li.product .price {
        gap: 4px;

        margin: 0 3px 13px !important;

        font-size: 12px !important;
    }

    .xioline-shop-products ul.products li.product .price del {
        font-size: 10px !important;
    }

    .xioline-shop-products ul.products li.product .price ins {
        font-size: 12px !important;
    }

    .xioline-shop-products ul.products li.product .button {
        width: calc(100% - 6px);

        margin: 0 3px !important;
        padding: 13px 7px !important;

        font-size: 8px !important;
        letter-spacing: 1.6px;

        border-radius: 8px !important;
    }

    .xioline-shop-products ul.products li.product:hover {
        transform: none;
    }
}

/* =========================================================
   SMALL MOBILE
========================================================= */

@media screen and (max-width: 420px) {

    .xioline-shop-products {
        padding-left: 8px !important;
        padding-right: 8px !important;
    }

    .xioline-shop-products ul.products {
        gap: 8px !important;
    }

    .xioline-shop-products
    ul.products
    li.product
    .woocommerce-loop-product__title {
        font-size: 16px !important;
    }

    .xioline-shop-products ul.products li.product .button {
        font-size: 7px !important;
        letter-spacing: 1.1px;
    }
}







/* ==========================================
   FIX SALE BADGE BALANCE
   Shop Products + Related Products
========================================== */

/* Desktop */
.xioline-shop-products ul.products li.product .onsale,
.xioline-related-products ul.products li.product .onsale {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;

    width: 62px !important;
    height: 62px !important;
    min-width: 62px !important;
    min-height: 62px !important;

    padding: 0 !important;
    margin: 0 !important;

    border-radius: 50% !important;
    box-sizing: border-box !important;

    font-size: 10px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    letter-spacing: 1.2px !important;
    text-transform: uppercase !important;
    text-align: center !important;

    top: 18px !important;
    right: 18px !important;
    left: auto !important;
}

/* Mobile */
@media only screen and (max-width: 767px) {
    .xioline-shop-products ul.products li.product .onsale,
    .xioline-related-products ul.products li.product .onsale {
        width: 48px !important;
        height: 48px !important;
        min-width: 48px !important;
        min-height: 48px !important;

        font-size: 8px !important;
        letter-spacing: 0.8px !important;

        top: 10px !important;
        right: 10px !important;
    }
}

/* Small mobile */
@media only screen and (max-width: 420px) {
    .xioline-shop-products ul.products li.product .onsale,
    .xioline-related-products ul.products li.product .onsale {
        width: 44px !important;
        height: 44px !important;
        min-width: 44px !important;
        min-height: 44px !important;

        font-size: 7px !important;
        letter-spacing: 0.6px !important;
    }
}/* End custom CSS */