/*
 * Facilitec Pro final WooCommerce polish
 * Loaded after main.css so it safely overrides duplicated legacy rules.
 */

:root {
    --fac-container: 1220px;
    --fac-shop-gap: 22px;
    --fac-card-radius: 16px;
}

/* ---------------------------------------------------------
   1) CENTERED CONTAINERS / BREATHING ROOM
   --------------------------------------------------------- */
.container,
.fac-wc-wrap,
.fac-wc-container,
.woocommerce .fac-wc-wrap,
.woocommerce-page .fac-wc-wrap {
    width: 100% !important;
    max-width: var(--fac-container) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: clamp(16px, 2.6vw, 32px) !important;
    padding-right: clamp(16px, 2.6vw, 32px) !important;
    box-sizing: border-box !important;
}

.facilitec-main-content.fac-wc-shell {
    padding-top: clamp(24px, 3vw, 34px) !important;
    padding-bottom: clamp(56px, 7vw, 84px) !important;
}

.woocommerce-page .site-main,
.woocommerce .site-main {
    width: 100% !important;
}

/* ---------------------------------------------------------
   2) SHOP / CATEGORY / HOME PRODUCT GRIDS
   --------------------------------------------------------- */
.woocommerce ul.products,
.woocommerce-page ul.products,
ul.facilitec-products-grid,
.products.facilitec-products-grid,
.facilitec-products-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: var(--fac-shop-gap) !important;
    list-style: none !important;
    width: 100% !important;
    margin: 0 0 34px !important;
    padding: 0 !important;
    float: none !important;
    clear: both !important;
}

.woocommerce ul.products::before,
.woocommerce ul.products::after,
.facilitec-products-grid::before,
.facilitec-products-grid::after {
    display: none !important;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
ul.facilitec-products-grid li.product,
.products.facilitec-products-grid li.product,
.facilitec-products-grid li.product {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    float: none !important;
    clear: none !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    border: 1px solid #e4e8e5 !important;
    border-radius: var(--fac-card-radius) !important;
    background: #ffffff !important;
    box-shadow: 0 10px 28px rgba(13, 35, 22, 0.06) !important;
    transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease !important;
}

.woocommerce ul.products li.product:hover,
.woocommerce-page ul.products li.product:hover,
.facilitec-products-grid li.product:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 18px 34px rgba(13, 35, 22, 0.1) !important;
    border-color: #d3dbd5 !important;
}

.woocommerce ul.products li.product a:first-child,
.woocommerce-page ul.products li.product a:first-child,
.facilitec-products-grid li.product a:first-child {
    display: block !important;
    width: 100% !important;
    margin: 0 !important;
    line-height: 0 !important;
    overflow: hidden !important;
    flex-shrink: 0 !important;
}

.woocommerce ul.products li.product a img,
.woocommerce ul.products li.product img,
.woocommerce-page ul.products li.product a img,
.woocommerce-page ul.products li.product img,
.facilitec-products-grid li.product img {
    width: 100% !important;
    height: 235px !important;
    display: block !important;
    margin: 0 !important;
    object-fit: cover !important;
    object-position: center !important;
    border-radius: 0 !important;
    transition: transform .3s ease !important;
}

.woocommerce ul.products li.product:hover img,
.woocommerce-page ul.products li.product:hover img,
.facilitec-products-grid li.product:hover img {
    transform: scale(1.04) !important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2,
.woocommerce ul.products li.product h3,
.woocommerce-page ul.products li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product h2,
.woocommerce-page ul.products li.product h3,
ul.facilitec-products-grid li.product .woocommerce-loop-product__title,
ul.facilitec-products-grid li.product h2,
ul.facilitec-products-grid li.product h3,
.facilitec-products-grid li.product .woocommerce-loop-product__title,
.facilitec-products-grid li.product h2,
.facilitec-products-grid li.product h3 {
    display: -webkit-box !important;
    -webkit-box-orient: vertical !important;
    -webkit-line-clamp: 4 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: normal !important;
    min-height: calc(1.4em * 4) !important;
    margin: 0 !important;
    padding: 14px 16px 8px !important;
    font-family: 'Outfit', sans-serif !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    line-height: 1.4 !important;
    color: #171717 !important;
    letter-spacing: 0 !important;
}

.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price,
.facilitec-products-grid li.product .price {
    display: block !important;
    margin: 0 !important;
    padding: 2px 16px 12px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    line-height: 1.5 !important;
    color: var(--fac-primary) !important;
}

.woocommerce ul.products li.product .price del,
.woocommerce-page ul.products li.product .price del,
.facilitec-products-grid li.product .price del {
    color: #9ca3af !important;
    opacity: .85 !important;
}

.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.button,
.woocommerce ul.products li.product .added_to_cart,
.woocommerce-page ul.products li.product .button,
.woocommerce-page ul.products li.product a.button,
.woocommerce-page ul.products li.product .added_to_cart,
.facilitec-products-grid li.product .button,
.facilitec-products-grid li.product a.button {
    display: block !important;
    width: calc(100% - 32px) !important;
    margin: auto 16px 16px !important;
    padding: 12px 12px !important;
    border: 0 !important;
    border-radius: 10px !important;
    background: var(--fac-primary) !important;
    color: #fff !important;
    text-align: center !important;
    text-transform: uppercase !important;
    letter-spacing: .08em !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    line-height: 1.2 !important;
}

.woocommerce ul.products li.product .button:hover,
.woocommerce-page ul.products li.product .button:hover,
.facilitec-products-grid li.product .button:hover,
.facilitec-products-grid li.product a.button:hover {
    background: var(--fac-primary-dark) !important;
    color: #fff !important;
}

/* ---------------------------------------------------------
   3) SHOP / CATEGORY HEADER + PAGINATION
   --------------------------------------------------------- */
.woocommerce-products-header,
.woocommerce .page-title-wrap {
    margin-bottom: 22px !important;
    padding-bottom: 16px !important;
    border-bottom: 1px solid #edf0ed !important;
}

.woocommerce .page-title,
.woocommerce-products-header__title,
h1.woocommerce-products-header__title {
    margin: 0 0 6px !important;
    padding: 0 !important;
    font-family: 'Outfit', sans-serif !important;
    font-size: 1.6rem !important;
    font-weight: 700 !important;
    line-height: 1.2 !important;
    color: #111827 !important;
}

.woocommerce .term-description,
.woocommerce .term-description p {
    max-width: 760px !important;
    margin-bottom: 0 !important;
    color: #6b7280 !important;
    line-height: 1.7 !important;
}

.woocommerce .woocommerce-result-count {
    float: none !important;
    display: inline-block !important;
    margin: 0 0 18px !important;
    color: #6b7280 !important;
    font-size: 13px !important;
}

.woocommerce .woocommerce-ordering {
    float: right !important;
    margin: 0 0 18px !important;
}

.woocommerce .woocommerce-ordering select {
    min-height: 44px !important;
    border: 1px solid #d6ddd7 !important;
    border-radius: 12px !important;
    padding: 10px 14px !important;
    background: #fff !important;
    color: #374151 !important;
    font-size: 13px !important;
}

.woocommerce nav.woocommerce-pagination {
    clear: both !important;
    margin-top: 20px !important;
    text-align: center !important;
}

.woocommerce nav.woocommerce-pagination ul {
    display: inline-flex !important;
    gap: 8px !important;
    border: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

.woocommerce nav.woocommerce-pagination ul li {
    border: 0 !important;
    overflow: visible !important;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
    min-width: 42px !important;
    height: 42px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 10px !important;
    border: 1px solid #d7ddd8 !important;
    background: #fff !important;
    color: #374151 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
}

.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current {
    background: var(--fac-primary) !important;
    border-color: var(--fac-primary) !important;
    color: #fff !important;
}

/* ---------------------------------------------------------
   4) SINGLE PRODUCT PAGE
   --------------------------------------------------------- */
.single-product .woocommerce div.product,
.single-product .woocommerce-page div.product {
    display: grid !important;
    grid-template-columns: minmax(0, 1.04fr) minmax(340px, 0.96fr) !important;
    gap: clamp(28px, 3vw, 42px) !important;
    align-items: start !important;
    width: 100% !important;
    margin: 8px 0 52px !important;
}

.single-product .woocommerce div.product::before,
.single-product .woocommerce div.product::after,
.single-product .woocommerce-page div.product::before,
.single-product .woocommerce-page div.product::after {
    display: none !important;
}

.single-product .woocommerce div.product div.images,
.single-product .woocommerce div.product div.woocommerce-product-gallery,
.single-product .woocommerce-page div.product div.images,
.single-product .woocommerce-page div.product div.woocommerce-product-gallery {
    grid-column: 1 !important;
    float: none !important;
    clear: none !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    border: 1px solid #e7ece8 !important;
    border-radius: 20px !important;
    background: #ffffff !important;
    overflow: hidden !important;
    box-shadow: 0 14px 34px rgba(13, 35, 22, 0.05) !important;
}

.single-product .woocommerce div.product div.summary,
.single-product .woocommerce div.product div.summary.entry-summary,
.single-product .woocommerce-page div.product div.summary,
.single-product .woocommerce-page div.product div.summary.entry-summary {
    grid-column: 2 !important;
    float: none !important;
    clear: none !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: clamp(22px, 2.6vw, 30px) !important;
    border: 1px solid #e7ece8 !important;
    border-radius: 20px !important;
    background: #ffffff !important;
    box-shadow: 0 14px 34px rgba(13, 35, 22, 0.05) !important;
    position: sticky !important;
    top: 24px !important;
}

.single-product .woocommerce div.product .woocommerce-product-gallery__wrapper,
.single-product .woocommerce-page div.product .woocommerce-product-gallery__wrapper {
    margin: 0 !important;
}

.single-product .woocommerce div.product div.woocommerce-product-gallery img,
.single-product .woocommerce-page div.product div.woocommerce-product-gallery img {
    width: 100% !important;
    display: block !important;
    margin: 0 !important;
    object-fit: cover !important;
}

.single-product .woocommerce-product-gallery .flex-control-thumbs,
.single-product .woocommerce-page .woocommerce-product-gallery .flex-control-thumbs {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 12px !important;
    padding: 14px !important;
    margin: 0 !important;
}

.single-product .woocommerce-product-gallery .flex-control-thumbs li {
    width: 100% !important;
    float: none !important;
    margin: 0 !important;
}

.single-product .woocommerce-product-gallery .flex-control-thumbs img {
    border-radius: 12px !important;
    border: 1px solid #e5e7eb !important;
}

.single-product .woocommerce div.product .product_title,
.single-product .woocommerce-page div.product .product_title {
    margin: 0 0 14px !important;
    font-family: 'Outfit', sans-serif !important;
    font-size: clamp(1.8rem, 2.5vw, 2.3rem) !important;
    font-weight: 700 !important;
    line-height: 1.15 !important;
    color: #111827 !important;
    letter-spacing: -.02em !important;
}

.single-product .woocommerce div.product .woocommerce-product-details__short-description,
.single-product .woocommerce-page div.product .woocommerce-product-details__short-description {
    margin: 0 0 18px !important;
    padding: 0 0 18px !important;
    color: #4b5563 !important;
    line-height: 1.75 !important;
    border-bottom: 1px solid #eef2ef !important;
}

.single-product .woocommerce div.product p.price,
.single-product .woocommerce div.product span.price,
.single-product .woocommerce-page div.product p.price,
.single-product .woocommerce-page div.product span.price {
    margin: 0 0 18px !important;
    font-size: 1.45rem !important;
    font-weight: 700 !important;
    color: var(--fac-primary) !important;
}

.single-product .woocommerce div.product form.cart,
.single-product .woocommerce-page div.product form.cart {
    margin: 0 0 18px !important;
    padding: 18px !important;
    border: 1px solid #edf2ee !important;
    border-radius: 16px !important;
    background: #f9fbfa !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
    align-items: center !important;
}

.single-product .woocommerce div.product form.cart .quantity,
.single-product .woocommerce-page div.product form.cart .quantity {
    margin: 0 !important;
}

.single-product .woocommerce div.product form.cart .qty,
.single-product .woocommerce-page div.product form.cart .qty {
    min-height: 46px !important;
    border-radius: 12px !important;
    border: 1px solid #d6ddd7 !important;
}

.single-product .woocommerce div.product .single_add_to_cart_button,
.single-product .woocommerce div.product form.cart .button,
.single-product .woocommerce-page div.product .single_add_to_cart_button,
.single-product .woocommerce-page div.product form.cart .button {
    flex: 1 1 220px !important;
    min-height: 46px !important;
    margin: 0 !important;
    border-radius: 12px !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
    background: var(--fac-primary) !important;
    color: #fff !important;
}

.single-product .woocommerce div.product .single_add_to_cart_button:hover,
.single-product .woocommerce div.product form.cart .button:hover,
.single-product .woocommerce-page div.product .single_add_to_cart_button:hover,
.single-product .woocommerce-page div.product form.cart .button:hover {
    background: var(--fac-primary-dark) !important;
    color: #fff !important;
}

.single-product .woocommerce div.product .product_meta,
.single-product .woocommerce-page div.product .product_meta {
    margin: 0 !important;
    padding-top: 18px !important;
    border-top: 1px solid #eef2ef !important;
    font-size: 13px !important;
    line-height: 1.8 !important;
    color: #6b7280 !important;
}

.single-product .woocommerce div.product .product_meta > span,
.single-product .woocommerce-page div.product .product_meta > span {
    display: block !important;
    margin-bottom: 4px !important;
}

.single-product .woocommerce div.product .product_meta a,
.single-product .woocommerce-page div.product .product_meta a {
    color: var(--fac-primary) !important;
    font-weight: 600 !important;
}

.single-product .woocommerce div.product .woocommerce-tabs,
.single-product .woocommerce div.product section.related,
.single-product .woocommerce div.product section.upsells,
.single-product .woocommerce-page div.product .woocommerce-tabs,
.single-product .woocommerce-page div.product section.related,
.single-product .woocommerce-page div.product section.upsells {
    grid-column: 1 / -1 !important;
    width: 100% !important;
}

.single-product .woocommerce div.product .woocommerce-tabs,
.single-product .woocommerce-page div.product .woocommerce-tabs {
    margin-top: 6px !important;
    padding-top: 8px !important;
}

.single-product .woocommerce div.product .woocommerce-tabs ul.tabs,
.single-product .woocommerce-page div.product .woocommerce-tabs ul.tabs {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    margin: 0 0 20px !important;
    padding: 0 !important;
    border: 0 !important;
}

.single-product .woocommerce div.product .woocommerce-tabs ul.tabs::before,
.single-product .woocommerce-page div.product .woocommerce-tabs ul.tabs::before {
    display: none !important;
}

.single-product .woocommerce div.product .woocommerce-tabs ul.tabs li,
.single-product .woocommerce-page div.product .woocommerce-tabs ul.tabs li {
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
}

.single-product .woocommerce div.product .woocommerce-tabs ul.tabs li a,
.single-product .woocommerce-page div.product .woocommerce-tabs ul.tabs li a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 44px !important;
    padding: 10px 16px !important;
    border: 1px solid #d8dfda !important;
    border-radius: 999px !important;
    background: #fff !important;
    color: #374151 !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: .06em !important;
    text-transform: uppercase !important;
}

.single-product .woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.single-product .woocommerce-page div.product .woocommerce-tabs ul.tabs li.active a {
    background: var(--fac-primary) !important;
    border-color: var(--fac-primary) !important;
    color: #fff !important;
}

.single-product .woocommerce div.product .woocommerce-tabs .panel,
.single-product .woocommerce-page div.product .woocommerce-tabs .panel {
    padding: 0 !important;
    color: #4b5563 !important;
    line-height: 1.8 !important;
}

.single-product .woocommerce div.product section.related,
.single-product .woocommerce div.product section.upsells,
.single-product .woocommerce-page div.product section.related,
.single-product .woocommerce-page div.product section.upsells {
    margin-top: 18px !important;
    padding-top: 24px !important;
    border-top: 1px solid #edf0ed !important;
}

.single-product .woocommerce div.product section.related > h2,
.single-product .woocommerce div.product section.upsells > h2,
.single-product .woocommerce-page div.product section.related > h2,
.single-product .woocommerce-page div.product section.upsells > h2 {
    margin-bottom: 18px !important;
    font-size: 1.25rem !important;
    font-weight: 700 !important;
    color: #111827 !important;
}

/* ---------------------------------------------------------
   5) RESPONSIVE
   --------------------------------------------------------- */
@media (max-width: 1100px) {
    .woocommerce ul.products,
    .woocommerce-page ul.products,
    .facilitec-products-grid,
    .products.facilitec-products-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }

    .single-product .woocommerce div.product,
    .single-product .woocommerce-page div.product {
        grid-template-columns: 1fr !important;
        gap: 24px !important;
    }

    .single-product .woocommerce div.product div.summary,
    .single-product .woocommerce div.product div.summary.entry-summary,
    .single-product .woocommerce-page div.product div.summary,
    .single-product .woocommerce-page div.product div.summary.entry-summary {
        grid-column: 1 !important;
        position: static !important;
    }
}

@media (max-width: 860px) {
    .woocommerce ul.products,
    .woocommerce-page ul.products,
    .facilitec-products-grid,
    .products.facilitec-products-grid,
    .woocommerce .related ul.products,
    .woocommerce .up-sells ul.products {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
        gap: 14px !important;
    }

    .woocommerce ul.products li.product a img,
    .woocommerce ul.products li.product img,
    .woocommerce-page ul.products li.product a img,
    .woocommerce-page ul.products li.product img,
    .facilitec-products-grid li.product img {
        height: 190px !important;
    }

    .woocommerce ul.products li.product .woocommerce-loop-product__title,
    .woocommerce ul.products li.product h2,
    .woocommerce ul.products li.product h3,
    .woocommerce-page ul.products li.product .woocommerce-loop-product__title,
    .woocommerce-page ul.products li.product h2,
    .woocommerce-page ul.products li.product h3,
    .facilitec-products-grid li.product .woocommerce-loop-product__title,
    .facilitec-products-grid li.product h2,
    .facilitec-products-grid li.product h3 {
        -webkit-line-clamp: 3 !important;
        min-height: calc(1.38em * 3) !important;
        font-size: 13px !important;
        padding: 12px 12px 8px !important;
    }

    .woocommerce .woocommerce-result-count,
    .woocommerce .woocommerce-ordering {
        float: none !important;
        display: block !important;
        width: 100% !important;
    }

    .woocommerce .woocommerce-ordering {
        margin-top: 0 !important;
    }

    .woocommerce .woocommerce-ordering select {
        width: 100% !important;
    }
}

@media (max-width: 600px) {
    :root {
        --fac-shop-gap: 10px;
    }

    .container,
    .fac-wc-wrap,
    .fac-wc-container,
    .woocommerce .fac-wc-wrap,
    .woocommerce-page .fac-wc-wrap {
        padding-left: 14px !important;
        padding-right: 14px !important;
    }

    .woocommerce ul.products li.product a img,
    .woocommerce ul.products li.product img,
    .woocommerce-page ul.products li.product a img,
    .woocommerce-page ul.products li.product img,
    .facilitec-products-grid li.product img {
        height: 145px !important;
    }

    .woocommerce ul.products li.product .woocommerce-loop-product__title,
    .woocommerce ul.products li.product h2,
    .woocommerce ul.products li.product h3,
    .woocommerce-page ul.products li.product .woocommerce-loop-product__title,
    .woocommerce-page ul.products li.product h2,
    .woocommerce-page ul.products li.product h3,
    .facilitec-products-grid li.product .woocommerce-loop-product__title,
    .facilitec-products-grid li.product h2,
    .facilitec-products-grid li.product h3 {
        font-size: 12px !important;
        padding: 10px 10px 6px !important;
    }

    .woocommerce ul.products li.product .price,
    .woocommerce-page ul.products li.product .price,
    .facilitec-products-grid li.product .price {
        padding: 2px 10px 8px !important;
        font-size: 12px !important;
    }

    .woocommerce ul.products li.product .button,
    .woocommerce ul.products li.product a.button,
    .woocommerce ul.products li.product .added_to_cart,
    .woocommerce-page ul.products li.product .button,
    .woocommerce-page ul.products li.product a.button,
    .woocommerce-page ul.products li.product .added_to_cart,
    .facilitec-products-grid li.product .button,
    .facilitec-products-grid li.product a.button {
        width: calc(100% - 20px) !important;
        margin: auto 10px 10px !important;
        padding: 10px 8px !important;
        font-size: 10px !important;
    }

    .single-product .woocommerce div.product div.summary,
    .single-product .woocommerce div.product div.summary.entry-summary,
    .single-product .woocommerce-page div.product div.summary,
    .single-product .woocommerce-page div.product div.summary.entry-summary {
        padding: 18px !important;
        border-radius: 16px !important;
    }

    .single-product .woocommerce div.product .product_title,
    .single-product .woocommerce-page div.product .product_title {
        font-size: 1.45rem !important;
    }

    .single-product .woocommerce div.product form.cart,
    .single-product .woocommerce-page div.product form.cart {
        flex-direction: column !important;
        align-items: stretch !important;
    }

    .single-product .woocommerce div.product .single_add_to_cart_button,
    .single-product .woocommerce div.product form.cart .button,
    .single-product .woocommerce-page div.product .single_add_to_cart_button,
    .single-product .woocommerce-page div.product form.cart .button {
        width: 100% !important;
    }

    .single-product .woocommerce-product-gallery .flex-control-thumbs,
    .single-product .woocommerce-page .woocommerce-product-gallery .flex-control-thumbs {
        gap: 8px !important;
        padding: 10px !important;
    }

    .single-product .woocommerce div.product .woocommerce-tabs ul.tabs li a,
    .single-product .woocommerce-page div.product .woocommerce-tabs ul.tabs li a {
        min-height: 40px !important;
        padding: 8px 12px !important;
        font-size: 11px !important;
    }
}


/* ============================================================================
   v1.0.9 — DEFINITIVE FIX BLOCK (highest specificity, last in the cascade)
   - Forces proper left/right spacing on Shop, Category, Tag, Single Product
   - Makes the hero slider use a full-bleed background image with centered text
   - Adds styling for Inquiry + WhatsApp Quote + Request a Quote buttons on
     the single product page (below the Category / Tag meta)
   - Mobile-responsive throughout
   ============================================================================ */

:root {
    --fac-page-max: 1240px;
    --fac-page-pad-x: clamp(16px, 3vw, 36px);
    --fac-hero-overlay: linear-gradient(180deg, rgba(12, 28, 20, 0.52) 0%, rgba(12, 28, 20, 0.28) 45%, rgba(12, 28, 20, 0.68) 100%);
    --fac-slide-heading-font: "Playfair Display", "Outfit", Georgia, "Times New Roman", serif;
}

/* -- Outer page wrapper (from woocommerce.php template) ---------------------- */
body.woocommerce .fac-page-wrap,
body.woocommerce-page .fac-page-wrap,
body.single-product .fac-page-wrap,
body.post-type-archive-product .fac-page-wrap,
body.tax-product_cat .fac-page-wrap,
body.tax-product_tag .fac-page-wrap,
.fac-page-wrap {
    display: block !important;
    width: 100% !important;
    padding: clamp(22px, 3vw, 36px) 0 clamp(60px, 8vw, 96px) !important;
    background: #ffffff !important;
    box-sizing: border-box !important;
}

body.woocommerce .fac-page-wrap .fac-page-inner,
body.woocommerce-page .fac-page-wrap .fac-page-inner,
body.single-product .fac-page-wrap .fac-page-inner,
body.post-type-archive-product .fac-page-wrap .fac-page-inner,
body.tax-product_cat .fac-page-wrap .fac-page-inner,
body.tax-product_tag .fac-page-wrap .fac-page-inner,
.fac-page-wrap .fac-page-inner {
    width: 100% !important;
    max-width: var(--fac-page-max) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: var(--fac-page-pad-x) !important;
    padding-right: var(--fac-page-pad-x) !important;
    box-sizing: border-box !important;
}

/* Inner hook wrapper must now go full-width within .fac-page-inner (no
   double-padding). */
body.woocommerce .fac-page-wrap .fac-wc-shell,
body.woocommerce-page .fac-page-wrap .fac-wc-shell,
body.single-product .fac-page-wrap .fac-wc-shell,
body.post-type-archive-product .fac-page-wrap .fac-wc-shell,
body.tax-product_cat .fac-page-wrap .fac-wc-shell,
body.tax-product_tag .fac-page-wrap .fac-wc-shell {
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
}

body.woocommerce .fac-page-wrap .fac-wc-wrap,
body.woocommerce-page .fac-page-wrap .fac-wc-wrap,
body.single-product .fac-page-wrap .fac-wc-wrap,
body.post-type-archive-product .fac-page-wrap .fac-wc-wrap,
body.tax-product_cat .fac-page-wrap .fac-wc-wrap,
body.tax-product_tag .fac-page-wrap .fac-wc-wrap {
    max-width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin: 0 !important;
}

body.woocommerce .fac-page-wrap .site-main,
body.woocommerce-page .fac-page-wrap .site-main,
body.single-product .fac-page-wrap .site-main,
body.post-type-archive-product .fac-page-wrap .site-main,
body.tax-product_cat .fac-page-wrap .site-main,
body.tax-product_tag .fac-page-wrap .site-main {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Shop / archive title + result count: align inside the new wrapper */
body.post-type-archive-product .woocommerce-products-header,
body.tax-product_cat .woocommerce-products-header,
body.tax-product_tag .woocommerce-products-header {
    padding: 0 !important;
    margin: 0 0 18px !important;
}

body.post-type-archive-product .woocommerce-products-header__title,
body.tax-product_cat .woocommerce-products-header__title,
body.tax-product_tag .woocommerce-products-header__title {
    margin: 0 0 6px !important;
    padding: 0 !important;
    font-size: clamp(1.6rem, 2.4vw, 2.1rem) !important;
    line-height: 1.15 !important;
    font-weight: 600 !important;
}

body.post-type-archive-product .woocommerce-result-count,
body.tax-product_cat .woocommerce-result-count,
body.tax-product_tag .woocommerce-result-count {
    margin: 0 0 22px !important;
    color: #6b7280 !important;
    font-size: 14px !important;
}

/* Description tab content must stay inside the box — not full bleed */
body.single-product .woocommerce-tabs,
body.single-product div.product .woocommerce-tabs,
body.single-product div.product.type-product .woocommerce-tabs {
    margin-top: clamp(28px, 4vw, 44px) !important;
    padding: clamp(22px, 3vw, 32px) clamp(22px, 3vw, 32px) !important;
    background: #ffffff !important;
    border: 1px solid #e7ece8 !important;
    border-radius: 20px !important;
    box-shadow: 0 14px 34px rgba(13, 35, 22, 0.05) !important;
    grid-column: 1 / -1 !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

body.single-product .woocommerce-tabs .panel,
body.single-product div.product .woocommerce-tabs .panel {
    padding: 18px 0 6px !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
}

body.single-product .woocommerce-tabs .panel h2 {
    font-size: 1.35rem !important;
    margin: 0 0 14px !important;
    font-weight: 600 !important;
    color: #1a1a1a !important;
}

body.single-product .woocommerce-tabs .panel h3,
body.single-product .woocommerce-tabs .panel h4 {
    margin-top: 1.4em !important;
    margin-bottom: .6em !important;
    font-weight: 600 !important;
}

body.single-product .woocommerce-tabs .panel p,
body.single-product .woocommerce-tabs .panel li {
    line-height: 1.75 !important;
    color: #3a3a3a !important;
    font-size: 15.5px !important;
}

body.single-product .woocommerce-tabs .panel ul,
body.single-product .woocommerce-tabs .panel ol {
    padding-left: 1.3em !important;
    margin: 0 0 1.1em !important;
}

/* Related products also constrained */
body.single-product .related.products,
body.single-product .upsells.products {
    grid-column: 1 / -1 !important;
    max-width: 100% !important;
    margin-top: clamp(32px, 4vw, 52px) !important;
    padding-top: clamp(28px, 4vw, 42px) !important;
    border-top: 1px solid #e7ece8 !important;
}

body.single-product .related.products > h2,
body.single-product .upsells.products > h2 {
    font-size: 1.3rem !important;
    margin-bottom: 20px !important;
    font-weight: 600 !important;
}

/* ---------------------------------------------------------------------------
   INQUIRY + WHATSAPP BUTTONS on single product (below Category/Tag)
   --------------------------------------------------------------------------- */
.fac-product-actions {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    margin-top: 18px !important;
    padding-top: 18px !important;
    border-top: 1px solid #eef2ef !important;
}

.fac-product-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    padding: 12px 18px !important;
    border-radius: 10px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    letter-spacing: .02em !important;
    text-decoration: none !important;
    border: 1px solid transparent !important;
    cursor: pointer !important;
    transition: transform .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease, border-color .18s ease !important;
    line-height: 1 !important;
    min-height: 44px !important;
    box-sizing: border-box !important;
}

.fac-product-btn svg { flex-shrink: 0; }

.fac-product-btn-primary {
    background: var(--fac-primary, #1e7a4f) !important;
    color: #ffffff !important;
    border-color: var(--fac-primary, #1e7a4f) !important;
    box-shadow: 0 8px 20px rgba(30, 122, 79, 0.18) !important;
}
.fac-product-btn-primary:hover {
    background: #186138 !important;
    border-color: #186138 !important;
    color: #ffffff !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 12px 26px rgba(30, 122, 79, 0.26) !important;
}

.fac-product-btn-whatsapp {
    background: #25D366 !important;
    color: #ffffff !important;
    border-color: #25D366 !important;
    box-shadow: 0 8px 20px rgba(37, 211, 102, 0.22) !important;
}
.fac-product-btn-whatsapp:hover {
    background: #1fb357 !important;
    border-color: #1fb357 !important;
    color: #ffffff !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 12px 26px rgba(37, 211, 102, 0.3) !important;
}

.fac-product-btn-ghost {
    background: #ffffff !important;
    color: #1a1a1a !important;
    border-color: #d6dcd8 !important;
}
.fac-product-btn-ghost:hover {
    background: #f5f8f6 !important;
    border-color: var(--fac-primary, #1e7a4f) !important;
    color: var(--fac-primary, #1e7a4f) !important;
    transform: translateY(-1px) !important;
}

@media (max-width: 600px) {
    .fac-product-actions { gap: 8px !important; }
    .fac-product-btn {
        flex: 1 1 calc(50% - 4px) !important;
        padding: 11px 10px !important;
        font-size: 13px !important;
    }
    .fac-product-btn-ghost { flex: 1 1 100% !important; }
}

/* ---------------------------------------------------------------------------
   HERO SLIDER v1.0.9 — FULL-BLEED IMAGE, CENTERED TEXT, ELEGANT FONT
   --------------------------------------------------------------------------- */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,500;0,600;0,700;1,500&display=swap');

.facilitec-hero-slider {
    position: relative !important;
    overflow: hidden !important;
    min-height: clamp(440px, 62vh, 640px) !important;
    background: #0c1c14 !important;
}

.facilitec-hero-slider::before { display: none !important; height: 0 !important; }

.facilitec-slider-track {
    position: relative !important;
    width: 100% !important;
    height: 100% !important;
    min-height: clamp(440px, 62vh, 640px) !important;
}

.facilitec-slide {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background-size: cover !important;
    background-position: center center !important;
    background-repeat: no-repeat !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: clamp(40px, 6vh, 80px) var(--fac-page-pad-x) !important;
    opacity: 0 !important;
    transform: scale(1.04) !important;
    transition: opacity .9s ease, transform 7s ease !important;
    pointer-events: none !important;
    min-height: clamp(440px, 62vh, 640px) !important;
    box-sizing: border-box !important;
    text-align: center !important;
}

.facilitec-slide.is-active {
    opacity: 1 !important;
    transform: scale(1) !important;
    pointer-events: auto !important;
    z-index: 2 !important;
}

/* Dark overlay so white text stays readable over any image */
.facilitec-slide.has-image::before {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    background: var(--fac-hero-overlay) !important;
    z-index: 0 !important;
    pointer-events: none !important;
}

/* Slides without uploaded image: subtle centered pattern */
.facilitec-slide.no-image .facilitec-slide-pattern {
    position: absolute !important;
    inset: 0 !important;
    right: auto !important;
    top: auto !important;
    transform: none !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    opacity: .35 !important;
    pointer-events: none !important;
    z-index: 0 !important;
}
.facilitec-slide.no-image .facilitec-slide-pattern svg {
    width: min(520px, 80vw) !important;
    height: min(520px, 80vw) !important;
}

/* Centered content shell */
.facilitec-slide-inner {
    position: relative !important;
    z-index: 2 !important;
    width: 100% !important;
    max-width: 820px !important;
    margin: 0 auto !important;
    text-align: center !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.facilitec-slide-content {
    max-width: 100% !important;
    text-align: center !important;
    margin: 0 auto !important;
}

.facilitec-slide-eyebrow {
    display: inline-block !important;
    font-family: 'Outfit', sans-serif !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: .32em !important;
    text-transform: uppercase !important;
    color: #ffffff !important;
    background: rgba(255, 255, 255, 0.14) !important;
    backdrop-filter: blur(6px) !important;
    -webkit-backdrop-filter: blur(6px) !important;
    padding: 8px 18px !important;
    border-radius: 40px !important;
    margin: 0 auto 22px !important;
    border: 1px solid rgba(255, 255, 255, 0.22) !important;
}

/* Image slides: elegant serif heading */
.facilitec-slide.has-image .facilitec-slide-title,
.facilitec-slide.no-image .facilitec-slide-title {
    font-family: var(--fac-slide-heading-font) !important;
    font-size: clamp(2rem, 5.2vw, 4rem) !important;
    line-height: 1.08 !important;
    letter-spacing: -0.01em !important;
    font-weight: 600 !important;
    color: #ffffff !important;
    margin: 0 auto 18px !important;
    text-shadow: 0 2px 30px rgba(0, 0, 0, 0.35) !important;
    max-width: 18ch !important;
}

.facilitec-slide.no-image .facilitec-slide-title { color: #1a1a1a !important; text-shadow: none !important; }
.facilitec-slide.no-image .facilitec-slide-eyebrow { color: var(--fac-primary, #1e7a4f) !important; background: rgba(30, 122, 79, 0.08) !important; border-color: rgba(30, 122, 79, 0.15) !important; }

.facilitec-slide.has-image .facilitec-slide-subtitle,
.facilitec-slide.no-image .facilitec-slide-subtitle {
    font-family: 'Outfit', sans-serif !important;
    font-size: clamp(1rem, 1.4vw, 1.2rem) !important;
    line-height: 1.65 !important;
    color: rgba(255, 255, 255, 0.92) !important;
    margin: 0 auto 32px !important;
    max-width: 58ch !important;
    font-weight: 400 !important;
    text-shadow: 0 1px 16px rgba(0, 0, 0, 0.3) !important;
}
.facilitec-slide.no-image .facilitec-slide-subtitle { color: #3a3a3a !important; text-shadow: none !important; }

.facilitec-slide-actions {
    display: flex !important;
    gap: 12px !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
}

.facilitec-slide-actions .facilitec-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 13px 26px !important;
    border-radius: 10px !important;
    font-weight: 600 !important;
    font-size: 14.5px !important;
    letter-spacing: .02em !important;
    text-decoration: none !important;
    transition: transform .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease, border-color .18s ease !important;
    border: 1px solid transparent !important;
    line-height: 1 !important;
    min-height: 46px !important;
    box-sizing: border-box !important;
}

.facilitec-slide-actions .facilitec-btn-primary {
    background: var(--fac-primary, #1e7a4f) !important;
    color: #ffffff !important;
    border-color: var(--fac-primary, #1e7a4f) !important;
    box-shadow: 0 10px 30px rgba(30, 122, 79, 0.35) !important;
}
.facilitec-slide-actions .facilitec-btn-primary:hover {
    background: #186138 !important;
    border-color: #186138 !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 14px 36px rgba(30, 122, 79, 0.45) !important;
}

/* Light outline button (used on image slides) */
.facilitec-slide-actions .facilitec-btn-outline-light {
    background: rgba(255, 255, 255, 0.08) !important;
    color: #ffffff !important;
    border-color: rgba(255, 255, 255, 0.55) !important;
    backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important;
}
.facilitec-slide-actions .facilitec-btn-outline-light:hover {
    background: #ffffff !important;
    color: #1a1a1a !important;
    border-color: #ffffff !important;
    transform: translateY(-2px) !important;
}

/* On no-image slides, the light outline button needs dark treatment for contrast */
.facilitec-slide.no-image .facilitec-slide-actions .facilitec-btn-outline-light {
    background: transparent !important;
    color: #1a1a1a !important;
    border-color: rgba(0, 0, 0, 0.25) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}
.facilitec-slide.no-image .facilitec-slide-actions .facilitec-btn-outline-light:hover {
    background: #1a1a1a !important;
    color: #ffffff !important;
    border-color: #1a1a1a !important;
}

/* Arrow nav — white pill on images, dark on empty slides */
.facilitec-slider-arrow {
    background: rgba(255, 255, 255, 0.95) !important;
    color: #1a1a1a !important;
}
.facilitec-slider-arrow:hover {
    background: var(--fac-primary, #1e7a4f) !important;
    color: #ffffff !important;
}

/* Dots — white tint by default so they read over images */
.facilitec-slider-dot {
    background: rgba(255, 255, 255, 0.45) !important;
}
.facilitec-slider-dot:hover { background: rgba(255, 255, 255, 0.75) !important; }
.facilitec-slider-dot.is-active {
    background: #ffffff !important;
    width: 34px !important;
    border-radius: 5px !important;
}

/* --- Slider mobile responsive tuning --- */
@media (max-width: 900px) {
    .facilitec-hero-slider,
    .facilitec-slider-track,
    .facilitec-slide { min-height: clamp(420px, 72vh, 540px) !important; }

    .facilitec-slider-arrow { width: 42px !important; height: 42px !important; }
    .facilitec-slider-prev { left: 12px !important; }
    .facilitec-slider-next { right: 12px !important; }
}

@media (max-width: 600px) {
    .facilitec-hero-slider,
    .facilitec-slider-track,
    .facilitec-slide { min-height: 480px !important; }

    .facilitec-slide { padding: 48px 18px !important; }

    .facilitec-slide-eyebrow {
        font-size: 10.5px !important;
        letter-spacing: .28em !important;
        padding: 6px 14px !important;
        margin-bottom: 16px !important;
    }

    .facilitec-slide.has-image .facilitec-slide-title,
    .facilitec-slide.no-image .facilitec-slide-title {
        font-size: clamp(1.75rem, 7vw, 2.3rem) !important;
        max-width: 100% !important;
    }

    .facilitec-slide-subtitle {
        font-size: 15px !important;
        margin-bottom: 24px !important;
        max-width: 100% !important;
    }

    .facilitec-slide-actions { flex-direction: column !important; width: 100% !important; max-width: 320px !important; margin: 0 auto !important; gap: 10px !important; }
    .facilitec-slide-actions .facilitec-btn { width: 100% !important; justify-content: center !important; padding: 12px 18px !important; }

    .facilitec-slider-arrow { width: 36px !important; height: 36px !important; }
    .facilitec-slider-prev { left: 8px !important; }
    .facilitec-slider-next { right: 8px !important; }

    .facilitec-slider-dots { bottom: 22px !important; gap: 8px !important; }
    .facilitec-slider-dot { width: 8px !important; height: 8px !important; }
    .facilitec-slider-dot.is-active { width: 26px !important; }
}

/* ---------------------------------------------------------------------------
   SAFETY NET — if somehow .fac-page-wrap is NOT in the DOM, still constrain
   the raw WooCommerce content at the body level. This means even on a cached
   page or a misconfigured plugin render, the shop page will still look good.
   --------------------------------------------------------------------------- */
body.woocommerce:not(.home) > #page > .site-content > .woocommerce,
body.woocommerce-page:not(.home) > #page > .site-content > .woocommerce,
body.post-type-archive-product > #page > .site-content > .woocommerce,
body.tax-product_cat > #page > .site-content > .woocommerce,
body.tax-product_tag > #page > .site-content > .woocommerce,
body.single-product > #page > .site-content > .woocommerce {
    max-width: var(--fac-page-max) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: var(--fac-page-pad-x) !important;
    padding-right: var(--fac-page-pad-x) !important;
    box-sizing: border-box !important;
}

/* End v1.0.9 fix block */


/* ============================================================================
   v1.0.9.1 — MOBILE SINGLE PRODUCT PAGE FIX
   At narrow screens (<= 860px) the gallery + summary must STACK into a single
   column. Previous rules tried this but got out-ranked by the grid-template
   rule set at desktop. Here we force it at every common mobile breakpoint,
   with extra padding / font-size tuning so it reads well on phones.
   ============================================================================ */

@media (max-width: 860px) {
    /* Force the outer product layout to 1 column */
    body.single-product .woocommerce div.product,
    body.single-product .woocommerce-page div.product,
    body.single-product div.product.product,
    body.single-product div.product.type-product {
        display: block !important;
        grid-template-columns: 1fr !important;
        gap: 18px !important;
        margin: 0 0 40px !important;
    }

    /* Gallery + summary become full-width blocks, stacked */
    body.single-product .woocommerce div.product div.images,
    body.single-product .woocommerce div.product div.woocommerce-product-gallery,
    body.single-product .woocommerce-page div.product div.images,
    body.single-product .woocommerce-page div.product div.woocommerce-product-gallery,
    body.single-product div.product.product div.images,
    body.single-product div.product.product div.woocommerce-product-gallery,
    body.single-product .woocommerce div.product div.summary,
    body.single-product .woocommerce div.product div.summary.entry-summary,
    body.single-product .woocommerce-page div.product div.summary,
    body.single-product .woocommerce-page div.product div.summary.entry-summary,
    body.single-product div.product.product div.summary,
    body.single-product div.product.product div.summary.entry-summary {
        grid-column: 1 / -1 !important;
        width: 100% !important;
        max-width: 100% !important;
        float: none !important;
        margin: 0 0 16px !important;
        position: static !important;
        top: auto !important;
        display: block !important;
    }

    /* Gallery thumbnails row: slightly smaller, centered */
    body.single-product .woocommerce-product-gallery .flex-control-thumbs,
    body.single-product .woocommerce-product-gallery__image + .flex-control-thumbs {
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 8px !important;
        padding: 10px !important;
        margin: 0 !important;
        justify-content: flex-start !important;
    }

    body.single-product .woocommerce-product-gallery .flex-control-thumbs li {
        width: calc((100% - 24px) / 4) !important;
        max-width: 80px !important;
        margin: 0 !important;
    }

    /* Summary card: tighter padding on phones */
    body.single-product .woocommerce div.product div.summary,
    body.single-product .woocommerce div.product div.summary.entry-summary {
        padding: 20px 18px !important;
    }

    /* Product title readable on phone */
    body.single-product .woocommerce div.product .product_title,
    body.single-product .woocommerce-page div.product .product_title {
        font-size: clamp(1.4rem, 5vw, 1.9rem) !important;
        line-height: 1.2 !important;
        margin: 0 0 12px !important;
    }

    /* Short description font */
    body.single-product .woocommerce div.product .woocommerce-product-details__short-description,
    body.single-product .woocommerce div.product .woocommerce-product-details__short-description p {
        font-size: 14.5px !important;
        line-height: 1.6 !important;
    }

    /* Inquiry buttons: 2-up on phone (WhatsApp + Inquiry), Quote full-width */
    .fac-product-actions {
        margin-top: 16px !important;
        padding-top: 16px !important;
        gap: 8px !important;
    }
    .fac-product-btn {
        flex: 1 1 calc(50% - 4px) !important;
        min-width: 0 !important;
        padding: 11px 10px !important;
        font-size: 13px !important;
        min-height: 42px !important;
    }
    .fac-product-btn-ghost { flex: 1 1 100% !important; }

    /* Description / Tabs card: fit mobile snugly */
    body.single-product .woocommerce-tabs,
    body.single-product div.product .woocommerce-tabs {
        padding: 18px !important;
        border-radius: 14px !important;
        margin-top: 22px !important;
    }
    body.single-product .woocommerce-tabs ul.tabs {
        gap: 0 !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
        flex-wrap: nowrap !important;
    }
    body.single-product .woocommerce-tabs ul.tabs li a {
        font-size: 12px !important;
        padding: 10px 14px !important;
        white-space: nowrap !important;
    }
    body.single-product .woocommerce-tabs .panel h2 { font-size: 1.15rem !important; }
    body.single-product .woocommerce-tabs .panel p,
    body.single-product .woocommerce-tabs .panel li { font-size: 14.5px !important; }

    /* Page wrap padding: slightly tighter on phone */
    .fac-page-wrap { padding: 18px 0 56px !important; }
    .fac-page-wrap .fac-page-inner { padding-left: 16px !important; padding-right: 16px !important; }

    /* Product meta rows (Category, Tag) */
    body.single-product .woocommerce div.product .product_meta { font-size: 13.5px !important; padding-top: 14px !important; }
    body.single-product .woocommerce div.product .product_meta > span { margin-bottom: 4px !important; }
}

/* Even tighter on very small screens */
@media (max-width: 480px) {
    body.single-product .woocommerce div.product div.woocommerce-product-gallery img {
        max-height: 320px !important;
        object-fit: contain !important;
        background: #fafaf8 !important;
    }
    body.single-product .woocommerce-product-gallery .flex-control-thumbs li {
        width: calc((100% - 18px) / 4) !important;
        max-width: 64px !important;
    }
}

/* ============================================================================
   v1.0.9.1 — STATS COUNTER POLISH
   The PHP outputs `<span class="fsi-num">0</span><span class="fsi-suffix">+</span>`
   and JS updates only the .fsi-num node. Make sure the two spans sit on the
   same baseline with consistent typography.
   ============================================================================ */
.facilitec-stats-bar-light .fsi-value,
.facilitec-stats-bar .fsi-value {
    display: inline-flex !important;
    align-items: baseline !important;
    justify-content: center !important;
    gap: 2px !important;
    line-height: 1 !important;
}
.facilitec-stats-bar-light .fsi-num,
.facilitec-stats-bar .fsi-num {
    font-family: inherit !important;
    font-weight: inherit !important;
    font-size: inherit !important;
    color: inherit !important;
    font-variant-numeric: tabular-nums !important;
}
.facilitec-stats-bar-light .fsi-suffix,
.facilitec-stats-bar .fsi-suffix {
    font-family: inherit !important;
    font-weight: inherit !important;
    color: inherit !important;
    opacity: .85 !important;
}

/* End v1.0.9.1 fix block */


/* ============================================================================
   v1.0.9.2 — NUCLEAR MOBILE FIX (single product)
   Root cause found: main.css line ~5326 hard-sets `grid-column: 2 !important`
   on the summary div. On mobile, even with grid-template-columns: 1fr, the
   browser creates an implicit 2nd column to honor grid-column: 2 — which kept
   the side-by-side layout on phones. Fix: kill grid entirely on mobile, reset
   grid-column on every child back to `auto`, and use plain block flow.
   ============================================================================ */

@media screen and (max-width: 860px) {
    /* 1. KILL THE GRID ON THE OUTER PRODUCT WRAPPER -------------------------- */
    html body.single-product div.product,
    html body.single-product .woocommerce div.product,
    html body.single-product .woocommerce-page div.product,
    html body.single-product div.product.product,
    html body.single-product div.product.type-product,
    html body.single-product .fac-page-wrap div.product,
    html body.single-product .fac-page-wrap .woocommerce div.product {
        display: block !important;
        grid-template-columns: none !important;
        grid-template-rows: none !important;
        grid-gap: 0 !important;
        gap: 0 !important;
        margin: 0 0 32px !important;
    }

    /* 2. RESET grid-column ON EVERY CHILD SO IT CAN'T JUMP TO COL 2 ---------- */
    html body.single-product div.product > *,
    html body.single-product .woocommerce div.product > *,
    html body.single-product .woocommerce-page div.product > *,
    html body.single-product div.product.product > *,
    html body.single-product div.product.type-product > * {
        grid-column: auto !important;
        grid-row: auto !important;
        float: none !important;
        clear: both !important;
    }

    /* 3. GALLERY: full-width block, sits ON TOP -------------------------------- */
    html body.single-product div.product > div.images,
    html body.single-product div.product > div.woocommerce-product-gallery,
    html body.single-product .woocommerce div.product > div.images,
    html body.single-product .woocommerce div.product > div.woocommerce-product-gallery,
    html body.single-product .woocommerce-page div.product > div.images,
    html body.single-product .woocommerce-page div.product > div.woocommerce-product-gallery,
    html body.single-product div.product.product > div.images,
    html body.single-product div.product.product > div.woocommerce-product-gallery {
        display: block !important;
        grid-column: auto !important;
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        margin: 0 0 18px !important;
        padding: 0 !important;
        float: none !important;
        position: static !important;
        top: auto !important;
        right: auto !important;
        left: auto !important;
        box-sizing: border-box !important;
    }

    /* Gallery image */
    html body.single-product div.product .woocommerce-product-gallery__image img,
    html body.single-product div.product .flex-viewport img,
    html body.single-product div.product div.images img {
        width: 100% !important;
        max-width: 100% !important;
        height: auto !important;
        max-height: 360px !important;
        object-fit: contain !important;
        background: #fafaf8 !important;
        display: block !important;
    }

    /* 4. SUMMARY: full-width block, sits BELOW gallery ------------------------- */
    html body.single-product div.product > div.summary,
    html body.single-product div.product > div.summary.entry-summary,
    html body.single-product .woocommerce div.product > div.summary,
    html body.single-product .woocommerce div.product > div.summary.entry-summary,
    html body.single-product .woocommerce-page div.product > div.summary,
    html body.single-product .woocommerce-page div.product > div.summary.entry-summary,
    html body.single-product div.product.product > div.summary,
    html body.single-product div.product.product > div.summary.entry-summary {
        display: block !important;
        grid-column: auto !important;     /* <-- THE CRITICAL FIX */
        grid-row: auto !important;
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        float: none !important;
        clear: both !important;
        margin: 0 0 16px !important;
        padding: 22px 18px !important;
        position: static !important;
        top: auto !important;
        right: auto !important;
        left: auto !important;
        border: 1px solid #e7ece8 !important;
        border-radius: 18px !important;
        background: #ffffff !important;
        box-shadow: 0 10px 28px rgba(13, 35, 22, 0.05) !important;
        box-sizing: border-box !important;
    }

    /* 5. PRODUCT TITLE — reasonable mobile size ------------------------------- */
    html body.single-product div.product .product_title,
    html body.single-product .woocommerce div.product .product_title,
    html body.single-product .woocommerce-page div.product .product_title {
        font-size: clamp(1.35rem, 5.2vw, 1.85rem) !important;
        line-height: 1.18 !important;
        letter-spacing: -0.01em !important;
        margin: 0 0 12px !important;
        padding: 0 !important;
        text-transform: none !important;
        word-break: break-word !important;
    }

    /* 6. SHORT DESCRIPTION tuned for phone ----------------------------------- */
    html body.single-product div.product .woocommerce-product-details__short-description,
    html body.single-product div.product .woocommerce-product-details__short-description p,
    html body.single-product div.product .woocommerce-product-details__short-description li {
        font-size: 14.5px !important;
        line-height: 1.65 !important;
    }

    /* 7. CATEGORY / TAG meta ------------------------------------------------- */
    html body.single-product div.product .product_meta {
        font-size: 14px !important;
        padding-top: 14px !important;
        margin-top: 16px !important;
    }
    html body.single-product div.product .product_meta > span {
        display: block !important;
        margin-bottom: 6px !important;
    }

    /* 8. Gallery thumbnails on mobile: 4-across, tidy ------------------------ */
    html body.single-product .woocommerce-product-gallery .flex-control-thumbs {
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 8px !important;
        padding: 10px 4px 0 !important;
        margin: 0 !important;
        list-style: none !important;
    }
    html body.single-product .woocommerce-product-gallery .flex-control-thumbs li {
        width: calc((100% - 24px) / 4) !important;
        max-width: 84px !important;
        margin: 0 !important;
        padding: 0 !important;
        list-style: none !important;
    }
    html body.single-product .woocommerce-product-gallery .flex-control-thumbs li img {
        width: 100% !important;
        height: auto !important;
        aspect-ratio: 1 / 1 !important;
        object-fit: cover !important;
        border-radius: 8px !important;
        border: 1px solid #e7ece8 !important;
    }

    /* 9. INQUIRY BUTTONS — 2-up grid on phone -------------------------------- */
    html body.single-product .fac-product-actions {
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 8px !important;
        margin-top: 16px !important;
        padding-top: 16px !important;
        border-top: 1px solid #eef2ef !important;
    }
    html body.single-product .fac-product-actions .fac-product-btn {
        flex: 1 1 calc(50% - 4px) !important;
        min-width: 0 !important;
        padding: 11px 10px !important;
        font-size: 13px !important;
        min-height: 44px !important;
        justify-content: center !important;
    }
    html body.single-product .fac-product-actions .fac-product-btn-ghost {
        flex: 1 1 100% !important;
    }

    /* 10. TABS (Description / Reviews) — scroll horizontally on phone -------- */
    html body.single-product .woocommerce-tabs {
        padding: 16px !important;
        border-radius: 14px !important;
        margin-top: 22px !important;
        max-width: 100% !important;
        overflow-x: hidden !important;
    }
    html body.single-product .woocommerce-tabs ul.tabs {
        display: flex !important;
        flex-wrap: nowrap !important;
        gap: 0 !important;
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch !important;
        scrollbar-width: none !important;
        margin: 0 0 14px !important;
        padding: 0 !important;
        border-bottom: 2px solid #eef2ef !important;
    }
    html body.single-product .woocommerce-tabs ul.tabs::-webkit-scrollbar { display: none !important; }
    html body.single-product .woocommerce-tabs ul.tabs li {
        flex: 0 0 auto !important;
    }
    html body.single-product .woocommerce-tabs ul.tabs li a {
        padding: 10px 14px !important;
        font-size: 12px !important;
        white-space: nowrap !important;
    }
    html body.single-product .woocommerce-tabs .panel h2 { font-size: 1.15rem !important; }
    html body.single-product .woocommerce-tabs .panel p,
    html body.single-product .woocommerce-tabs .panel li { font-size: 14.5px !important; line-height: 1.7 !important; }

    /* 11. Related / upsells — single column on phone ------------------------- */
    html body.single-product .related.products,
    html body.single-product .upsells.products {
        margin-top: 30px !important;
        padding-top: 22px !important;
    }

    /* 12. Page wrap padding slightly tighter --------------------------------- */
    .fac-page-wrap { padding: 18px 0 48px !important; }
    .fac-page-wrap .fac-page-inner { padding-left: 14px !important; padding-right: 14px !important; }
}

/* Extra tightening for very small phones ------------------------------------ */
@media screen and (max-width: 420px) {
    html body.single-product div.product .woocommerce-product-gallery__image img,
    html body.single-product div.product .flex-viewport img {
        max-height: 300px !important;
    }
    html body.single-product div.product > div.summary.entry-summary {
        padding: 18px 14px !important;
    }
    html body.single-product .woocommerce-product-gallery .flex-control-thumbs li {
        width: calc((100% - 18px) / 4) !important;
        max-width: 64px !important;
    }
}

/* End v1.0.9.2 nuclear mobile fix */

/* =========================================================================
   v1.1.0 — WHY CHOOSE US SECTION
   ========================================================================= */
.facilitec-why-choose {
    padding-top: clamp(60px, 8vw, 100px) !important;
    padding-bottom: clamp(60px, 8vw, 100px) !important;
    background: linear-gradient(180deg, #ffffff 0%, #f9faf7 100%) !important;
    position: relative !important;
}

.facilitec-why-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr) !important;
    gap: clamp(32px, 4vw, 64px) !important;
    align-items: center !important;
    margin-top: 48px !important;
}

.facilitec-why-image {
    position: relative !important;
    border-radius: 22px !important;
    overflow: visible !important;
}

.facilitec-why-image img {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    border-radius: 22px !important;
    box-shadow:
        0 30px 60px -20px rgba(15, 45, 30, 0.25),
        0 12px 24px -12px rgba(15, 45, 30, 0.15) !important;
    object-fit: cover !important;
    aspect-ratio: 4 / 5 !important;
}

.facilitec-why-image-badge {
    position: absolute !important;
    right: -14px !important;
    bottom: 24px !important;
    padding: 16px 22px !important;
    background: #ffffff !important;
    border-radius: 14px !important;
    box-shadow: 0 18px 40px rgba(15, 45, 30, 0.18) !important;
    text-align: center !important;
    border-left: 4px solid var(--fac-accent, #f5b70a) !important;
}

.facilitec-why-image-badge .fwi-num {
    font-family: 'Outfit', sans-serif !important;
    font-size: 28px !important;
    font-weight: 700 !important;
    line-height: 1 !important;
    color: var(--fac-primary, #1e7a4f) !important;
}

.facilitec-why-image-badge .fwi-lbl {
    margin-top: 4px !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    color: #5a6b63 !important;
}

.facilitec-why-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 22px !important;
}

.facilitec-why-item {
    display: grid !important;
    grid-template-columns: 54px 1fr !important;
    gap: 18px !important;
    align-items: flex-start !important;
}

.facilitec-why-icon {
    width: 54px !important;
    height: 54px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 14px !important;
    background: linear-gradient(135deg, #e6f2ec 0%, #f4faf6 100%) !important;
    color: var(--fac-primary, #1e7a4f) !important;
    flex-shrink: 0 !important;
    border: 1px solid rgba(30, 122, 79, 0.15) !important;
}

.facilitec-why-text h3 {
    margin: 0 0 6px !important;
    font-family: 'Outfit', sans-serif !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    color: #0f2d1e !important;
    line-height: 1.3 !important;
}

.facilitec-why-text p {
    margin: 0 !important;
    font-size: 14.5px !important;
    line-height: 1.65 !important;
    color: #4a5b52 !important;
}

.facilitec-why-cta {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 18px !important;
    align-items: center !important;
    margin-top: 12px !important;
    padding-top: 14px !important;
    border-top: 1px dashed #d5ded7 !important;
}

.facilitec-why-cta .facilitec-btn-link {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--fac-primary, #1e7a4f) !important;
    text-decoration: none !important;
    border-bottom: 1px solid transparent !important;
    transition: border-color .2s ease !important;
}

.facilitec-why-cta .facilitec-btn-link:hover {
    border-bottom-color: var(--fac-primary, #1e7a4f) !important;
}

@media (max-width: 900px) {
    .facilitec-why-grid {
        grid-template-columns: 1fr !important;
        gap: 36px !important;
    }

    .facilitec-why-image img {
        aspect-ratio: 16 / 10 !important;
        max-height: 420px !important;
    }

    .facilitec-why-image-badge {
        right: 16px !important;
        bottom: 16px !important;
        padding: 12px 18px !important;
    }

    .facilitec-why-image-badge .fwi-num { font-size: 24px !important; }
}

@media (max-width: 600px) {
    .facilitec-why-item {
        grid-template-columns: 44px 1fr !important;
        gap: 14px !important;
    }

    .facilitec-why-icon {
        width: 44px !important;
        height: 44px !important;
        border-radius: 12px !important;
    }

    .facilitec-why-icon svg {
        width: 20px !important;
        height: 20px !important;
    }

    .facilitec-why-text h3 { font-size: 16px !important; }
    .facilitec-why-text p  { font-size: 14px !important; }
}

/* =========================================================================
   v1.1.0 — PRODUCT INQUIRY MODAL POPUP
   ========================================================================= */
.fac-inquiry-modal {
    position: fixed !important;
    inset: 0 !important;
    z-index: 99999 !important;
    display: none !important;
    align-items: flex-start !important;
    justify-content: center !important;
    padding: 24px 16px !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
}

.fac-inquiry-modal.is-open {
    display: flex !important;
    animation: fac-modal-fade-in .22s ease both !important;
}

@keyframes fac-modal-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
}

.fac-inquiry-modal-backdrop {
    position: fixed !important;
    inset: 0 !important;
    background: rgba(10, 30, 20, 0.62) !important;
    backdrop-filter: blur(3px) !important;
    -webkit-backdrop-filter: blur(3px) !important;
}

.fac-inquiry-modal-dialog {
    position: relative !important;
    width: 100% !important;
    max-width: 620px !important;
    margin: auto !important;
    background: #ffffff !important;
    border-radius: 18px !important;
    padding: 32px !important;
    box-shadow:
        0 40px 80px rgba(10, 30, 20, 0.35),
        0 0 0 1px rgba(0, 0, 0, 0.04) !important;
    animation: fac-modal-slide-in .28s cubic-bezier(.2, .7, .3, 1.2) both !important;
    z-index: 1 !important;
}

@keyframes fac-modal-slide-in {
    from { transform: translateY(24px) scale(.98); opacity: 0; }
    to   { transform: translateY(0) scale(1); opacity: 1; }
}

.fac-inquiry-modal-close {
    position: absolute !important;
    top: 14px !important;
    right: 14px !important;
    width: 36px !important;
    height: 36px !important;
    padding: 0 !important;
    border: 0 !important;
    background: #f4f6f5 !important;
    color: #2a2a2a !important;
    border-radius: 50% !important;
    font-size: 22px !important;
    line-height: 1 !important;
    cursor: pointer !important;
    transition: background .18s ease, color .18s ease, transform .18s ease !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.fac-inquiry-modal-close:hover {
    background: #1e7a4f !important;
    color: #ffffff !important;
    transform: rotate(90deg) !important;
}

.fac-inquiry-modal-header {
    display: flex !important;
    gap: 14px !important;
    align-items: flex-start !important;
    margin-bottom: 20px !important;
    padding-right: 40px !important;
}

.fac-inquiry-modal-icon {
    width: 52px !important;
    height: 52px !important;
    flex-shrink: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: linear-gradient(135deg, #1e7a4f 0%, #166540 100%) !important;
    color: #ffffff !important;
    border-radius: 14px !important;
    box-shadow: 0 8px 20px rgba(30, 122, 79, 0.28) !important;
}

.fac-inquiry-modal-header h2 {
    margin: 0 0 4px !important;
    font-family: 'Outfit', sans-serif !important;
    font-size: 22px !important;
    font-weight: 700 !important;
    color: #0f2d1e !important;
    line-height: 1.2 !important;
}

.fac-inquiry-modal-sub {
    margin: 0 !important;
    font-size: 13.5px !important;
    color: #5f6e66 !important;
    line-height: 1.5 !important;
}

.fac-inquiry-modal-product {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 12px 14px !important;
    margin-bottom: 20px !important;
    background: #f4faf6 !important;
    border: 1px solid #cfe7d7 !important;
    border-left: 4px solid var(--fac-primary, #1e7a4f) !important;
    border-radius: 8px !important;
    font-size: 14px !important;
}

.fac-inquiry-modal-product-label {
    color: #5f6e66 !important;
    font-weight: 500 !important;
}

.fac-inquiry-modal-product-name {
    color: #0f2d1e !important;
    font-weight: 600 !important;
}

/* Form fields inside the modal (reuse contact form visuals) */
.fac-inquiry-modal-form .fcf-row {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 14px !important;
    margin-bottom: 14px !important;
}

.fac-inquiry-modal-form .fcf-field {
    margin-bottom: 14px !important;
}

.fac-inquiry-modal-form .fcf-field label {
    display: block !important;
    margin-bottom: 6px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: #2a3a32 !important;
}

.fac-inquiry-modal-form .fcf-field .req {
    color: #d23a3a !important;
}

.fac-inquiry-modal-form input[type="text"],
.fac-inquiry-modal-form input[type="email"],
.fac-inquiry-modal-form input[type="tel"],
.fac-inquiry-modal-form select,
.fac-inquiry-modal-form textarea {
    width: 100% !important;
    padding: 11px 13px !important;
    border: 1px solid #d5ded7 !important;
    border-radius: 10px !important;
    background: #fbfcfb !important;
    font-family: inherit !important;
    font-size: 14px !important;
    color: #2a2a2a !important;
    transition: border-color .18s ease, box-shadow .18s ease, background .18s ease !important;
    box-sizing: border-box !important;
}

.fac-inquiry-modal-form input:focus,
.fac-inquiry-modal-form select:focus,
.fac-inquiry-modal-form textarea:focus {
    outline: none !important;
    border-color: var(--fac-primary, #1e7a4f) !important;
    background: #ffffff !important;
    box-shadow: 0 0 0 3px rgba(30, 122, 79, 0.12) !important;
}

.fac-inquiry-modal-form textarea {
    resize: vertical !important;
    min-height: 110px !important;
}

.fac-inquiry-modal-form .fcf-hp {
    position: absolute !important;
    left: -10000px !important;
    top: auto !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
}

.fac-inquiry-modal-form .fcf-submit-row {
    margin-top: 10px !important;
}

.fac-inquiry-modal-form .fcf-submit {
    width: 100% !important;
    padding: 14px 22px !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    letter-spacing: .04em !important;
}

.fac-inquiry-modal-form .fcf-submit.is-loading {
    opacity: .8 !important;
    cursor: wait !important;
}

.fac-inquiry-modal-form .fcf-response {
    margin-top: 14px !important;
    padding: 12px 14px !important;
    border-radius: 10px !important;
    font-size: 14px !important;
    display: none !important;
}

.fac-inquiry-modal-form .fcf-response.is-success {
    display: block !important;
    background: #e6f7ee !important;
    color: #146538 !important;
    border: 1px solid #b7e0c7 !important;
}

.fac-inquiry-modal-form .fcf-response.is-error {
    display: block !important;
    background: #fdecec !important;
    color: #b43c3c !important;
    border: 1px solid #f2c4c4 !important;
}

body.fac-modal-open {
    overflow: hidden !important;
}

@media (max-width: 600px) {
    .fac-inquiry-modal { padding: 12px !important; }

    .fac-inquiry-modal-dialog {
        padding: 22px 18px !important;
        border-radius: 14px !important;
    }

    .fac-inquiry-modal-header h2 { font-size: 19px !important; }

    .fac-inquiry-modal-icon {
        width: 44px !important;
        height: 44px !important;
        border-radius: 12px !important;
    }

    .fac-inquiry-modal-icon svg { width: 22px !important; height: 22px !important; }

    .fac-inquiry-modal-form .fcf-row {
        grid-template-columns: 1fr !important;
        gap: 0 !important;
        margin-bottom: 0 !important;
    }
}

/* =========================================================================
   v1.1.0 — MOBILE PRODUCT TITLE FIX (no more cut-off titles)
   Allow product titles to display in full on mobile product cards.
   ========================================================================= */
@media (max-width: 600px) {
    .woocommerce ul.products li.product .woocommerce-loop-product__title,
    .woocommerce ul.products li.product h2,
    .woocommerce ul.products li.product h3,
    .woocommerce-page ul.products li.product .woocommerce-loop-product__title,
    .woocommerce-page ul.products li.product h2,
    .woocommerce-page ul.products li.product h3,
    .facilitec-products-grid li.product .woocommerce-loop-product__title,
    .facilitec-products-grid li.product h2,
    .facilitec-products-grid li.product h3 {
        /* Remove restrictive line-clamp that was truncating titles */
        display: block !important;
        -webkit-line-clamp: unset !important;
        -webkit-box-orient: unset !important;
        overflow: visible !important;
        text-overflow: clip !important;
        white-space: normal !important;
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
        word-break: break-word !important;
        /* Let card grow naturally with the full title */
        min-height: 0 !important;
        max-height: none !important;
        height: auto !important;
        font-size: 12.5px !important;
        line-height: 1.4 !important;
        padding: 10px 10px 6px !important;
        hyphens: auto !important;
    }

    /* Ensure the card flex layout allows the title area to expand */
    .woocommerce ul.products li.product,
    .woocommerce-page ul.products li.product,
    .facilitec-products-grid li.product {
        height: auto !important;
    }
}
