/* Shop Page Enhancements */

/* Override WooCommerce float layout with CSS grid for equal-height cards */
.woocommerce ul.products,
ul.products.columns-4 {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr);
    gap: 20px;
    align-items: stretch !important;
}

ul.products.columns-3 {
    grid-template-columns: repeat(3, 1fr);
}

ul.products.columns-2 {
    grid-template-columns: repeat(2, 1fr);
}

/* Kill WooCommerce ::before/::after pseudo-elements that steal grid cells */
.woocommerce ul.products::before,
.woocommerce ul.products::after,
ul.products::before,
ul.products::after {
    display: none !important;
    content: none !important;
}

/* Remove ALL WooCommerce float/width/clear on individual products */
.woocommerce ul.products li.product,
.woocommerce ul.products li.first,
.woocommerce ul.products li.last,
ul.products li.product {
    display: flex !important;
    flex-direction: column !important;
    float: none !important;
    clear: none !important;
    width: auto !important;
    margin: 0 !important;
    align-self: stretch !important;
}

/* Title gets a min-height so all cards align regardless of line count */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
ul.products li.product .woocommerce-loop-product__title {
    min-height: 3em;
    text-align: center;
}

/* Center all content within product cards */
.woocommerce ul.products li.product,
ul.products li.product {
    text-align: center;
}

@media (max-width: 768px) {
    .woocommerce ul.products,
    ul.products.columns-4,
    ul.products.columns-3 {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

@media (max-width: 480px) {
    .woocommerce ul.products,
    ul.products.columns-4,
    ul.products.columns-3,
    ul.products.columns-2 {
        grid-template-columns: 1fr !important;
    }
}

/* WooCommerce ordering dropdown */
.woocommerce-ordering select.orderby {
    background-color: var(--wp--preset--color--surface, #1a1a1a);
    color: var(--wp--preset--color--contrast, #fff);
    border: 1px solid var(--wp--preset--color--border, #333);
    border-radius: 4px;
    padding: 8px 12px;
    font-size: 0.875rem;
    font-family: var(--wp--preset--font-family--system, sans-serif);
    cursor: pointer;
    appearance: auto;
}

.woocommerce-ordering select.orderby:focus {
    border-color: var(--wp--preset--color--accent, #d4af37);
    outline: none;
}

.pm-shop-price-wrapper {
    margin: 10px 0;
}

.pm-shop-price .woocommerce-Price-amount {
    font-size: 1.3rem;
    font-weight: 700;
    color: #d4af37;
}

/* Ensure span-based price displays render as block for layout */
span.pm-price-display {
    display: block;
    text-align: center;
}

span.pm-price-display .pm-price-main {
    display: block;
}

span.pm-price-display .pm-metal-info {
    display: flex;
    justify-content: center;
    gap: 8px;
}

/* Price direction flash on live updates -- shop pages */
.pm-price-up .pm-value,
.pm-price-up .pm-currency {
    color: #28a745 !important;
    transition: color 0.3s ease;
}

.pm-price-down .pm-value,
.pm-price-down .pm-currency {
    color: #dc3545 !important;
    transition: color 0.3s ease;
}

/* Price direction flash -- cart / mini-cart */
.wc-block-components-product-price__value.pm-price-up,
.wc-block-formatted-money-amount.pm-price-up,
.wc-block-components-totals-item__value.pm-price-up {
    color: #28a745 !important;
    transition: color 0.3s ease;
}

.wc-block-components-product-price__value.pm-price-down,
.wc-block-formatted-money-amount.pm-price-down,
.wc-block-components-totals-item__value.pm-price-down {
    color: #dc3545 !important;
    transition: color 0.3s ease;
}