/* ============================================================
   SHOP — Product grid, product cards, hover effects,
   shop loop items, product gallery
   ============================================================ */


/* ── Product grid layout ── */
.woocommerce ul.products {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 27px;
    margin-bottom: 0 !important;
}
.woocommerce ul.products::before,
.woocommerce .products::after { display: none !important; }
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product { text-align: center; }
.woocommerce .products > li {
    min-width: 100% !important;
    margin: 0 0 40px !important;
    padding-bottom: 40px !important;
}
.product-type-simple li::before { content: none !important; }


/* ── Product card shape ── */
.product-type-simple {
    background: #E8E0E0;
    border-radius: 11px 11px 90px 90px;
}
.woocommerce ul.products li.product a img {
    max-height: 320px;
    object-fit: cover;
    margin-bottom: 0 !important;
}
.woocommerce ul.products li.product a .attachment-woocommerce_thumbnail {
    max-height: 320px;
    object-fit: cover;
}


/* ── Product card — category label ── */
.custom-product-category {
    background: var(--co-cta);
    padding: 20px 20px 10px;
    margin-top: -10px;
    border-radius: 0 0 11px 11px;
    color: #fff;
    font-size: 20px;
    font-family: 'Neue Haas Grotesk Display Pro roman';
    letter-spacing: 1px;
}


/* ── Product card — short description ── */
.custom-short-description {
    color: #1B1816;
    padding: 10px 25px 0;
    text-wrap: balance !important;
}

/* ── Product card — title ── */
.woocommerce .products .product a .woocommerce-loop-product__title {
    padding: 20px 15px 0 !important;
    letter-spacing: -0.023em !important;
}
.woocommerce ul.products li.product a .price { display: none; }


/* ── Buy now button ── */
.woocommerce ul.products li.product a.buy-now-button { color: #fff !important; }
.product-type-simple .buy-now-button {
    display: inline-flex;
    align-items: center;
    background: var(--co-cta);
    padding: 12px 30px;
    color: var(--co-cta-bg);
    border-radius: 30px;
    position: absolute;
    bottom: -20px;
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap;
    font-family: 'Neue Haas Grotesk Display Pro medium', Helvetica, Arial, sans-serif !important;
    text-transform: uppercase;
    z-index: 11;
}
.product-type-simple .buy-now-button img { width: 0 !important; transition: 0.5s all; transform: translateX(20px); }
.product-type-simple .buy-now-button:hover img { width: 22px !important; transform: translateX(8px); }


/* ── Product card colour variants (light-card_* from ACF product_label) ── */
.light-card_clear { background: #E0E8E2; }
.light-card_clear .custom-product-category,
.light-card_clear .buy-now-button { background: var(--co-clarify); }

.light-card_brighten { background: #E8DBC5; }
.light-card_brighten .custom-product-category,
.light-card_brighten .buy-now-button { background: var(--co-radiance); }
.light-card_brighten .hover-card-description { background: var(--co-radiance); }

.light-card_anti .hover-card-description { background: var(--co-protect); }


/* ── Hover card ── */
.custom-hover-card {
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%;
    border-radius: 11px 11px 90px 90px;
    overflow: hidden;
    z-index: 9;
}
.custom-hover-card .hover-card-description {
    background: #C8E6D5;
    height: 280px;
    padding: 30px;
    transform: translateY(-100%);
    transform-origin: top;
    transition-duration: 0.5s;
    overflow: hidden;
    opacity: 0;
}
.custom-hover-card .hover-card-list {
    height: 366px;
    padding: 2rem;
    text-align: left;
    background-size: cover;
    position: relative;
    background-color: var(--co-cta-bg);
    transform: scaleY(1) translateY(200%);
    transform-origin: bottom;
    transition: 0.5s;
}
.custom-hover-card .hover-card-list::before {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    background: #ffffff82;
    left: 0;
    top: 0;
}
.woocommerce .products > li:hover .custom-hover-card .hover-card-list { transform: scaleY(1) translateY(0); }
.woocommerce .products > li:hover .custom-hover-card .hover-card-description {
    transform: translateY(0);
    max-height: 100%;
    opacity: 1;
}
.woocommerce .products .custom-hover-card p { font-size: 20px; }
.custom-hover-card .hover-card-list li {
    font-size: 16px;
    line-height: 1.7;
    color: #1B1816;
    position: relative;
    padding-left: 40px;
}
.custom-hover-card .hover-card-list li:before {
    content: "";
    background-image: url(https://dev2.completebydrscs.com/wp-content/uploads/2025/07/Icon.svg);
    width: 20px;
    height: 20px;
    position: absolute;
    background-repeat: no-repeat;
    top: 6px;
    left: 0;
    background-size: cover;
}


/* ── Product category grid (category page) ── */
.product-category_item {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 2rem;
}
.product-category_item > .et_pb_column { width: 100% !important; }


/* ── Product card hover (Product_card_item) ── */
.Product_card_item { height: 100%; }
.Product_card_item .hover_card { transition: 1s all; opacity: 0; }
.Product_card_item:hover .hover_card { z-index: 200 !important; opacity: 1; }
.Product_card_item .hover_card .hover_card_top {
    transform: scaleY(1) translateY(100%);
    transform-origin: bottom;
    transition: 0.5s;
    z-index: -1 !important;
}
.Product_card_item:hover .hover_card .hover_card_top { transform: scaleY(1) translateY(0); z-index: 100 !important; }
.Product_card_item .hover_card .hover_card_bottom {
    transform: scaleY(1) translateY(-100%);
    transform-origin: top;
    transition: 0.5s;
    border-radius: 0 0 90px 90px;
}
.Product_card_item:hover .hover_card .hover_card_bottom { transform: scaleY(1); }
.Product_card_item .product_feature_image img { transition: 0.5s; }
.Product_card_item:hover .product_feature_image img { scale: 1.2; }
.Product_card_item .et_pb_button_module_wrapper { position: relative; z-index: 210; }
.product_feature_image img { object-fit: cover; min-width: 100%; }
.Product_card_item img { object-fit: cover; }
.et-db #et-boc .et-l .Product_card_item:hover .hover_card { z-index: 200 !important; }
.hover_card_top .et_pb_text_inner ul { padding: 0; list-style: none; }
.hover_card_top .et_pb_text_inner ul li { padding-left: 2rem; position: relative; }
.hover_card_top .et_pb_text_inner ul li:before {
    content: "";
    background-image: url(/wp-content/uploads/2025/07/Icon.svg);
    background-size: cover;
    width: 20px;
    height: 20px;
    position: absolute;
    left: 0;
    top: 6px;
}


/* ── Product gallery ── */
.product_image .woocommerce-product-gallery__trigger { display: none; }
.woocommerce-product-gallery .flex-control-thumbs { display: flex; margin-top: 25px !important; gap: 25px; }
.woocommerce-product-gallery .flex-control-thumbs li { clear: unset !important; margin: 0 !important; border-radius: 10px; overflow: hidden; }
.flex-viewport { min-height: 513px; }
.flex-viewport .woocommerce-product-gallery__image { height: 100%; }
.flex-viewport .woocommerce-product-gallery__wrapper { height: 100%; }
.flex-viewport .woocommerce-product-gallery__image a { height: 100%; }
.flex-viewport .woocommerce-product-gallery__image img { min-height: 100%; object-fit: cover; }


/* ── Single product related ── */
.single_product .products.columns-1 { grid-template-columns: auto; }
.card_items-product .products { grid-template-columns: 1fr !important; max-width: 410px; }


/* ── Sticky cart button ── */
.sticky-on-cart_button-product {
    white-space: nowrap;
    display: flex !important;
    align-items: center;
}
.sticky-on-cart_button-product img { width: 0; transition: 0.5s all; transform: translateX(20px); }
.sticky-on-cart_button-product:hover img { width: 18px; transform: translateX(0); margin-left: 5px; }


/* ── Responsive ── */
@media (max-width: 980px) {
    .woocommerce ul.products { grid-template-columns: 1fr 1fr; gap: 16px; }
    .product-category_item { grid-template-columns: 1fr 1fr; gap: 1rem; }
}

@media (max-width: 768px) {
    .custom-hover-card { display: none; }
    .product-type-simple { border-radius: 8px 8px 20px 20px; }
    .custom-short-description { padding: 5px 10px; line-height: 1.5; }
    .woocommerce .products .product a .woocommerce-loop-product__title { padding: 12px 10px 0 !important; }
    .product-type-simple .buy-now-button {
        padding: 6px 20px;
        font-size: 12px;
        background: var(--co-cta-dark);
        line-height: 1.5;
        width: 100%;
        justify-content: center;
        max-width: 116px;
    }
    .woocommerce-product-gallery .flex-control-thumbs { margin-top: 15px !important; gap: 15px; padding: 0 10px !important; }
    .flex-viewport { height: unset !important; min-height: unset !important; }
}

@media (max-width: 576px) {
    .woocommerce ul.products { grid-template-columns: 1fr 1fr; row-gap: 2rem; }
    .custom-short-description { line-height: 1.5; }
}
