/**
 * Hammer Tools & Paint - WooCommerce Styles
 *
 * @package Hammer_Shop
 * @since 1.0.0
 *
 * Refactored for DRY principles, reduced duplication, and improved maintainability
 */

/* ==========================================================================
   REUSABLE BASE STYLES & UTILITIES
   ========================================================================== */

/* Circular Icon Button - Used for quick view, gallery triggers */
.circular-icon-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    background-color: var(--hammer-white);
    border: none;
    border-radius: var(--hammer-radius-full);
    cursor: pointer;
    transition: all var(--hammer-transition-fast);
    box-shadow: var(--hammer-shadow-md);
    z-index: 2;
}

.circular-icon-btn:hover {
    background-color: var(--hammer-primary);
    color: var(--hammer-white);
}

/* Base Badge Style */
.badge {
    display: inline-block;
    padding: 4px 10px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border-radius: var(--hammer-radius-sm);
}

.badge--sale {
    background-color: var(--hammer-accent);
    color: var(--hammer-primary);
}

.badge--new {
    background-color: var(--hammer-primary);
    color: var(--hammer-white);
}

.badge--featured {
    background-color: #28a745;
    color: var(--hammer-white);
}

.badge--out-of-stock {
    background-color: var(--hammer-gray-600);
    color: var(--hammer-white);
}

.badge--call-only {
    background-color: var(--hammer-primary);
    color: var(--hammer-white);
}

/* Base Price Styling - Shared across all product views */

ul.products li .hammer-special-price-range {
    font-size: .857rem!important;
}

.woocommerce .price {
    font-family: var(--hammer-font-heading);
    font-weight: 700;
    color: var(--hammer-primary);
    margin-bottom: var(--hammer-spacing-sm);
    line-height: 1.2;
    display: flex;
    align-items: center;
    gap: var(--hammer-spacing-sm);
    flex-wrap: wrap;
    min-height: 40px;
}


.woocommerce .price:not(:has(del)):not(:has(ins)) .woocommerce-Price-amount,
.wc-block-components-product-price:not(:has(del)):not(:has(ins)) .woocommerce-Price-amount,
.wc-block-grid__product-price:not(:has(del)):not(:has(ins)) .woocommerce-Price-amount {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

/* Original price when on sale (strikethrough) */
.woocommerce .price del,
.wc-block-components-product-price del,
.wc-block-grid__product-price del {
    color: var(--hammer-gray-500);
    font-weight: 400;
    margin-right: 0;
    order: -1;
}

.woocommerce .price del .woocommerce-Price-amount,
.wc-block-components-product-price del .woocommerce-Price-amount,
.wc-block-grid__product-price del .woocommerce-Price-amount {
    color: var(--hammer-gray-500);
}

/* Sale price styling */
.woocommerce .price ins,
.wc-block-components-product-price ins,
.wc-block-grid__product-price ins {
    text-decoration: none;
    padding: 0 6px;
}

/* Base Notice/Message Styling */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error,
.woocommerce-notice {
    display: block;
    gap: var(--hammer-spacing-md);
    padding: var(--hammer-spacing-lg);
    padding-left: calc(var(--hammer-spacing-lg) + 24px + 6px);
    margin-bottom: var(--hammer-spacing-lg);
    border-radius: var(--hammer-radius-md);
    font-size: var(--hammer-text-base);
    line-height: 1.6;
    position: relative;
}

.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before,
.woocommerce-notice::before {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    color: var(--hammer-white);
    border-radius: var(--hammer-radius-full);
    font-weight: 700;
    flex-shrink: 0;
    position: absolute;
    top: calc(50% - 12px);
    left: 12px;
}

/* Success Message */
.woocommerce-message,
.woocommerce-notice--success {
    background-color: #d4edda;
    border-left: 4px solid #28a745;
    color: #155724;
}

.woocommerce-message::before,
.woocommerce-notice--success::before {
    content: '✓';
    background-color: #28a745;
}

/* Info Message */
.woocommerce-info,
.woocommerce-notice--info {
    background-color: #d1ecf1;
    border-left: 4px solid #0c5460;
    color: #0c5460;
}

.woocommerce-info::before,
.woocommerce-notice--info::before {
    content: 'i';
    background-color: #0c5460;
}

/* Error Message */
.woocommerce-error,
.woocommerce-notice--error {
    background-color: #f8d7da;
    border-left: 4px solid #dc3545;
    color: #721c24;
}

.woocommerce-error::before,
.woocommerce-notice--error::before {
    content: '×';
    background-color: #dc3545;
    font-size: var(--hammer-text-xl);
}

/* Notice/Message Links */
.woocommerce-message a,
.woocommerce-info a,
.woocommerce-error a,
.woocommerce-notice a {
    color: inherit;
    text-decoration: underline;
    font-weight: 600;
}

.woocommerce-message a:hover,
.woocommerce-info a:hover,
.woocommerce-error a:hover,
.woocommerce-notice a:hover {
    color: var(--hammer-primary);
}

/* Notice Lists */
.woocommerce-error ul,
.woocommerce-info ul,
.woocommerce-message ul,
.woocommerce-notice ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.woocommerce-error li,
.woocommerce-info li,
.woocommerce-message li,
.woocommerce-notice li {
    margin-bottom: var(--hammer-spacing-xs);
}

.woocommerce-error li:last-child,
.woocommerce-info li:last-child,
.woocommerce-message li:last-child,
.woocommerce-notice li:last-child {
    margin-bottom: 0;
}

/* Thank You Order Received Message */
.woocommerce-thankyou-order-received {
    background-color: #d4edda;
    border-left: 4px solid #28a745;
    color: #155724;
    padding: var(--hammer-spacing-xl);
    margin-bottom: var(--hammer-spacing-2xl);
    border-radius: var(--hammer-radius-md);
    font-size: var(--hammer-text-lg);
    font-weight: 600;
    text-align: center;
}

/* Base Pagination Styling */
.woocommerce .pagination,
.woocommerce-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--hammer-spacing-xs);
    padding: var(--hammer-spacing-2xl) 0;
    margin-top: var(--hammer-spacing-2xl);
    flex-wrap: wrap;
}

.woocommerce nav.woocommerce-pagination ul {
    border: none;
    margin: 0;
}

.woocommerce nav.woocommerce-pagination ul li {
    border: none;
    padding: 0 4px;
    min-width: 45px;
    overflow: visible;
}

.woocommerce .pagination .next::after,
.woocommerce-pagination .next::after,
.woocommerce .pagination .prev::before,
.woocommerce-pagination .prev::before {
    display: none;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
    padding: 10px 0;
    min-width: unset;
}

/* Pagination Links & Numbers */
.woocommerce .pagination a,
.woocommerce .pagination span,
.woocommerce-pagination a,
.woocommerce-pagination span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    height: 44px;
    padding: 0 var(--hammer-spacing-sm);
    font-family: var(--hammer-font-heading);
    font-weight: 600;
    font-size: var(--hammer-text-sm);
    color: var(--hammer-gray-700);
    background-color: var(--hammer-gray-100);
    border: 2px solid transparent;
    border-radius: var(--hammer-radius-md);
    transition: all var(--hammer-transition-fast);
    text-decoration: none;
    cursor: pointer;
    line-height: 1;
}

.woocommerce .pagination a:hover,
.woocommerce-pagination a:hover {
    background-color: var(--hammer-primary);
    color: var(--hammer-white);
    border-color: var(--hammer-primary);
    transform: translateY(-2px);
    box-shadow: var(--hammer-shadow-md);
}

.woocommerce .pagination a:focus,
.woocommerce-pagination a:focus {
    outline: 2px solid var(--hammer-accent);
    outline-offset: 2px;
}

/* Current Page */
.woocommerce .pagination .current,
.woocommerce-pagination .current {
    background-color: var(--hammer-primary);
    color: var(--hammer-white);
    border-color: var(--hammer-primary);
    font-weight: 700;
    cursor: default;
}

/* Pagination Dots */
.woocommerce .pagination .page-numbers.dots,
.woocommerce-pagination .page-numbers.dots {
    background-color: transparent;
    color: var(--hammer-gray-500);
    cursor: default;
    pointer-events: none;
}

.woocommerce .pagination .page-numbers.dots:hover,
.woocommerce-pagination .page-numbers.dots:hover {
    background-color: transparent;
    color: var(--hammer-gray-500);
    transform: none;
}

/* Previous/Next Links */
.woocommerce .pagination .prev,
.woocommerce .pagination .next,
.woocommerce-pagination .prev,
.woocommerce-pagination .next {
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    min-width: auto;
    padding-left: var(--hammer-spacing-md);
    padding-right: var(--hammer-spacing-md);
}

.woocommerce .pagination .prev::before,
.woocommerce-pagination .prev::before {
    content: '←';
    margin-right: var(--hammer-spacing-xs);
}

.woocommerce .pagination .prev:hover::before,
.woocommerce-pagination .prev:hover::before {
    animation: slide-left var(--hammer-transition-fast) ease;
}

.woocommerce .pagination .next::after,
.woocommerce-pagination .next::after {
    content: '→';
    margin-left: var(--hammer-spacing-xs);
}

.woocommerce .pagination .next:hover::after,
.woocommerce-pagination .next:hover::after {
    animation: slide-right var(--hammer-transition-fast) ease;
}

/* Disabled Pagination */
.woocommerce .pagination .prev.disabled,
.woocommerce .pagination .next.disabled,
.woocommerce-pagination .prev.disabled,
.woocommerce-pagination .next.disabled,
.woocommerce .pagination span.prev,
.woocommerce .pagination span.next,
.woocommerce-pagination span.prev,
.woocommerce-pagination span.next {
    color: var(--hammer-gray-400);
    background-color: var(--hammer-gray-50);
    border-color: var(--hammer-gray-200);
    cursor: not-allowed;
    opacity: 0.6;
}

.woocommerce .pagination .prev.disabled:hover,
.woocommerce .pagination .next.disabled:hover,
.woocommerce-pagination .prev.disabled:hover,
.woocommerce-pagination .next.disabled:hover,
.woocommerce .pagination span.prev:hover,
.woocommerce .pagination span.next:hover,
.woocommerce-pagination span.prev:hover,
.woocommerce-pagination span.next:hover {
    background-color: var(--hammer-gray-50);
    color: var(--hammer-gray-400);
    transform: none;
    box-shadow: none;
}

/* Pagination Animations */
@keyframes slide-left {
    0% {
        transform: translateX(0);
    }

    50% {
        transform: translateX(-4px);
    }

    100% {
        transform: translateX(0);
    }
}

@keyframes slide-right {
    0% {
        transform: translateX(0);
    }

    50% {
        transform: translateX(4px);
    }

    100% {
        transform: translateX(0);
    }
}

/* Promotional banner */
.promotional-banner-heading {
    padding: 4px 10px;
    background-color: var(--hammer-accent);
    display: inline-block;
}

/* ==========================================================================
   SHOP ARCHIVE & PRODUCT GRID
   ========================================================================== */

.woocommerce .woocommerce-breadcrumb {
    margin-top: var(--hammer-spacing-md);
}

.woocommerce-main {
    padding: var(--hammer-spacing-2xl) 0;
}

/* Shop Layout with Sidebar */
.shop-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--hammer-spacing-2xl);
    align-items: start;
}

/* Sidebar Layout - Medium Screens and Up */
@media (min-width: 768px) {
    .shop-layout.has-sidebar {
        grid-template-columns: 1fr 280px;
    }
}

/* Sidebar Layout - Large Screens */
@media (min-width: 1024px) {
    .shop-layout.has-sidebar {
        grid-template-columns: 1fr 320px;
    }
}

/* Sticky Sidebar on Large Screens */
@media (min-width: 1024px) {
    .shop-layout.has-sidebar .shop-sidebar {
        position: sticky;
        top: calc(var(--hammer-header-height, 80px) + var(--hammer-spacing-lg));
    }
}

.woocommerce-products-header {
    margin-bottom: var(--hammer-spacing-xl);
}

.woocommerce-products-header__title {
    font-size: var(--hammer-text-3xl);
    color: var(--hammer-primary);
    margin-bottom: var(--hammer-spacing-sm);
}

.term-description {
    color: var(--hammer-gray-600);
    max-width: 800px;
}

/* Result Count & Ordering */
.woocommerce-result-count,
.woocommerce-ordering {
    margin-bottom: var(--hammer-spacing-lg);
}

.woocommerce-result-count {
    color: var(--hammer-gray-600);
    font-size: var(--hammer-text-sm);
}

.woocommerce-ordering select {
    min-width: 200px;
}

/* Products Grid */
ul.products {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--hammer-spacing-lg);
    margin: 0;
    padding: 0;
}

ul.products li.product {
    position: relative;
    background-color: var(--hammer-white);
    border-radius: var(--hammer-radius-md);
    overflow: hidden;
    box-shadow: var(--hammer-shadow-sm);
    transition: box-shadow var(--hammer-transition-base), transform var(--hammer-transition-base);
    margin: 0;
    padding: 0;
    list-style: none;
}

/* Products Grid OVERRIDES */
.wp-theme-hammer-shop.woocommerce ul.products li.first,
.wp-theme-hammer-shop.woocommerce-page ul.products li.first {
    clear: none;
}

.wp-theme-hammer-shop.woocommerce ul.products li.product,
.wp-theme-hammer-shop.woocommerce-page ul.products li.product {
    float: none;
    width: 100%;
}

.wp-theme-hammer-shop.woocommerce .products ul::after,
.wp-theme-hammer-shop.woocommerce .products ul::before,
.wp-theme-hammer-shop.woocommerce ul.products::after,
.wp-theme-hammer-shop.woocommerce ul.products::before {
    display: none;
}

.wp-theme-hammer-shop.woocommerce ul.products li.product .button {
    text-align: center;
}


/* Product Image Wrapper */
.product-image-wrapper {
    position: relative;
    overflow: hidden;
    background-color: white;
}

.product-image-wrapper img {
    width: 100%;
    height: auto;
    aspect-ratio: 1;
    object-fit: cover;
    transition: transform var(--hammer-transition-base);
}

ul.products li.product:hover .product-image-wrapper img {
    transform: scale(1.05);
}

/* Product Badges */
.product-badges {
    position: absolute;
    top: var(--hammer-spacing-sm);
    left: var(--hammer-spacing-sm);
    display: flex;
    flex-direction: column;
    gap: var(--hammer-spacing-xs);
    z-index: 2;
}

/* Quick View Button */
.quick-view-button {
    position: absolute;
    bottom: var(--hammer-spacing-sm);
    right: var(--hammer-spacing-sm);
    opacity: 0;
    transform: translateY(10px);
    transition: all var(--hammer-transition-fast);
}

ul.products li.product:hover .quick-view-button {
    opacity: 1;
    transform: translateY(0);
}

.quick-view-button {
    display: none;
}

/* Product Content */
.product-content {
    padding: var(--hammer-spacing-md);
}

.product-category {
    display: block;
    font-size: var(--hammer-text-xs);
    color: var(--hammer-gray-500);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: var(--hammer-spacing-xs);
}

.product-category:hover {
    color: var(--hammer-accent);
}

.woocommerce-loop-product__title {
    font-family: var(--hammer-font-heading);
    font-size: var(--hammer-text-base);
    font-weight: 600;
    line-height: 1.4;
    margin: 0 0 var(--hammer-spacing-sm) 0;
    color: var(--hammer-primary);
    min-height: 45px;
}

.woocommerce-loop-product__title a {
    color: inherit;
}

.woocommerce ul.products li.product .woocommerce-loop-category__title,
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h3 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    line-height: 1.4;
    min-height: calc(2em * 2);
    /* Reserve space for exactly 2 lines */
    max-height: calc(2em * 2);
    /* Prevent expansion beyond 2 lines */
}

.quick-view-button {
    display: none;
}

.woocommerce-loop-product__title a:hover {
    color: var(--hammer-accent);
}

/* Product Loop Price Overrides */
ul.products li.product .price {
    font-size: var(--hammer-text-xl);
}

ul.products li.product .price:not(:has(del)):not(:has(ins)) {
    font-size: var(--hammer-text-2xl);
}

/* Star Rating */
.star-rating {
    display: flex;
    align-items: center;
    font-size: var(--hammer-text-sm);
    margin-bottom: var(--hammer-spacing-sm);
    color: var(--hammer-accent);
    overflow: hidden;
    position: relative;
    height: 1em;
    line-height: 1;
    width: 5.4em;
}

.star-rating::before {
    content: '\2605\2605\2605\2605\2605';
    color: var(--hammer-gray-300);
    float: left;
    top: 0;
    left: 0;
    position: absolute;
}

.star-rating span {
    overflow: hidden;
    float: left;
    top: 0;
    left: 0;
    position: absolute;
    padding-top: 1.5em;
}

.star-rating span::before {
    content: '\2605\2605\2605\2605\2605';
    top: 0;
    position: absolute;
    left: 0;
}

/* Add to Cart Button */
ul.products li.product .button {
    width: 100%;
    margin-top: auto;
}

ul.products li.product .added_to_cart {
    display: block;
    text-align: center;
    margin-top: var(--hammer-spacing-xs);
    font-size: var(--hammer-text-sm);
    color: var(--hammer-accent);
}

.wp-theme-hammer-shop.woocommerce ul.products li.product .button.call-only-button span {
    text-align: left;
    width: min-content;
}

/* ==========================================================================
   Single Product
   ========================================================================== */

.single-product .woocommerce-main {
    padding-top: 0;
}

.single-product .product {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--hammer-spacing-2xl);
}

/* ==========================================================================
   Product Overview - Main Product Page Components
   ========================================================================== */

/**
 * Product Images Container
 * Wrapper for the main product gallery including thumbnails
 * Located on the left side of product page (desktop)
 */
.woocommerce div.product div.images.woocommerce-product-gallery {
    float: none;
    width: auto;
}

/**
 * Product Summary Container
 * Contains product title, price, description, add to cart, and meta information
 * Located on the right side of product page (desktop)
 */
.woocommerce div.product div.summary {
    float: none;
    width: auto;
}

/* Product Gallery */
.product-gallery-wrapper {
    position: relative;
}

.woocommerce-product-gallery {
    position: relative;
}

.woocommerce-product-gallery__image {
    border-radius: var(--hammer-radius-md);
    overflow: hidden;
    background-color: var(--hammer-gray-100);
}

.woocommerce-product-gallery__image img {
    width: 100%;
    height: auto;
}

.woocommerce-product-gallery__trigger {
    position: absolute;
    top: var(--hammer-spacing-md);
    right: var(--hammer-spacing-md);
    z-index: 10;
}

.woocommerce-product-gallery .flex-control-thumbs {
    display: flex;
    gap: var(--hammer-spacing-sm);
    margin-top: var(--hammer-spacing-md);
    padding: 0;
    list-style: none;
}

.woocommerce-product-gallery .flex-control-thumbs li {
    flex: 0 0 calc(25% - 9px);
}

.woocommerce-product-gallery .flex-control-thumbs li img {
    border-radius: var(--hammer-radius-sm);
    border: 2px solid transparent;
    cursor: pointer;
    transition: border-color var(--hammer-transition-fast);
}

.woocommerce-product-gallery .flex-control-thumbs li img:hover,
.woocommerce-product-gallery .flex-control-thumbs li img.flex-active {
    border-color: var(--hammer-accent);
}

/* Product Summary */
.product-summary-wrapper {
    padding: 0;
}

.product_title {
    font-size: var(--hammer-text-3xl);
    color: var(--hammer-primary);
    margin-bottom: var(--hammer-spacing-md);
}

/* Product Meta Info */
.product-meta-info {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--hammer-spacing-md);
    margin-bottom: var(--hammer-spacing-lg);
    padding-bottom: var(--hammer-spacing-lg);
    border-bottom: 1px solid var(--hammer-gray-200);
}

.sku-wrapper {
    font-size: var(--hammer-text-sm);
    color: var(--hammer-gray-600);
}

.sku-wrapper .label {
    font-weight: 600;
}

.stock-status {
    display: inline-flex;
    align-items: center;
    gap: var(--hammer-spacing-xs);
    font-size: var(--hammer-text-sm);
    font-weight: 600;
}

.stock-status.in-stock {
    color: #28a745;
}

.stock-status.out-of-stock {
    color: #dc3545;
}

/* Short Description */
.woocommerce-product-details__short-description {
    color: var(--hammer-gray-700);
    margin-bottom: var(--hammer-spacing-lg);
    line-height: 1.7;
}

.woocommerce-product-details__short-description p:last-child {
    margin-bottom: 0;
}

/* Quantity & Add to Cart */
.single-product form.cart {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: var(--hammer-spacing-md);
    margin-bottom: var(--hammer-spacing-lg);
    padding-bottom: var(--hammer-spacing-lg);
    border-bottom: 1px solid var(--hammer-gray-200);
}

.woocommerce div.product form.cart {
    gap: unset;
}

.woocommerce div.product form.cart div.quantity {
    display: flex;
    align-items: center;
    gap: 0;
    margin: 0 18px 0 0;
}

.single-product form.cart .quantity .qty {
    width: 80px;
    height: 48px;
    text-align: center;
    font-weight: 600;
    font-size: var(--hammer-text-base);
    border-width: 1px;
    border-left: none;
    border-right: none;
}

.single-product form.cart .quantity input[type="button"],
.single-product form.cart .quantity .qty-btn {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: var(--hammer-text-lg);
    font-weight: 600;
    color: var(--hammer-gray-700);
    background-color: var(--hammer-gray-100);
    border: 1px solid var(--hammer-gray-300);
    cursor: pointer;
    transition: all var(--hammer-transition-fast);
}

.single-product form.cart .quantity input[type="button"]:hover,
.single-product form.cart .quantity .qty-btn:hover {
    background-color: var(--hammer-primary);
    color: var(--hammer-white);
    border-color: var(--hammer-primary);
}

.single-product form.cart .quantity input[type="button"]:first-child {
    border-radius: var(--hammer-radius-md) 0 0 var(--hammer-radius-md);
}

.single-product form.cart .quantity input[type="button"]:last-child {
    border-radius: 0 var(--hammer-radius-md) var(--hammer-radius-md) 0;
}

.single-product form.cart .single_add_to_cart_button {
    flex: 1;
    min-width: 200px;
}

/* Variable Products */
.variations {
    width: 100%;
    margin-bottom: var(--hammer-spacing-lg);
    border-collapse: collapse;
}

.variations tr {
    margin-bottom: var(--hammer-spacing-md);
}

.variations td {
    padding: var(--hammer-spacing-sm) 0;
    vertical-align: middle;
}

.variations .label {
    width: 100px;
    font-weight: 600;
    color: var(--hammer-gray-700);
}

.variations select {
    width: 100%;
}

.reset_variations {
    font-size: var(--hammer-text-sm);
    color: var(--hammer-gray-600);
    margin-left: var(--hammer-spacing-md);
}

.reset_variations:hover {
    color: var(--hammer-accent);
}

/* Trust Badges */
.product-trust-badges {
    display: flex;
    flex-wrap: wrap;
    gap: var(--hammer-spacing-md);
    padding: var(--hammer-spacing-lg);
    background-color: var(--hammer-gray-100);
    border-radius: var(--hammer-radius-md);
    margin-bottom: var(--hammer-spacing-lg);
}

.trust-badge {
    display: flex;
    align-items: center;
    gap: var(--hammer-spacing-sm);
    font-size: var(--hammer-text-sm);
    color: var(--hammer-gray-700);
}

.trust-badge svg {
    color: var(--hammer-accent);
}

/* Product Meta */
.product_meta {
    font-size: var(--hammer-text-sm);
    color: var(--hammer-gray-600);
}

.product_meta>span {
    display: block;
    margin-bottom: var(--hammer-spacing-xs);
}

.product_meta a {
    color: var(--hammer-primary);
}

.product_meta a:hover {
    color: var(--hammer-accent);
}

/* ==========================================================================
   SINGLE PRODUCT PAGE
   ========================================================================== */

/* ==========================================================================
   Product Tabs
   ========================================================================== */

.woocommerce-tabs {
    margin-top: var(--hammer-spacing-3xl);
    clear: both;
}

.woocommerce-tabs ul.tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0;
    margin: 0 0 -1px 0;
    padding: 0;
    list-style: none;
    border-bottom: 1px solid var(--hammer-gray-300);
}

.woocommerce-tabs ul.tabs li {
    margin: 0;
}

.woocommerce-tabs ul.tabs li a {
    display: block;
    padding: var(--hammer-spacing-md) var(--hammer-spacing-lg);
    font-family: var(--hammer-font-heading);
    font-weight: 600;
    color: var(--hammer-gray-600);
    background-color: var(--hammer-gray-100);
    border: 1px solid transparent;
    border-bottom: none;
    border-radius: var(--hammer-radius-md) var(--hammer-radius-md) 0 0;
    transition: all var(--hammer-transition-fast);
}

.woocommerce-tabs ul.tabs li a:hover {
    color: var(--hammer-primary);
}

.woocommerce-tabs ul.tabs li.active a {
    color: var(--hammer-primary);
    background-color: var(--hammer-white);
    border-color: var(--hammer-gray-300);
    border-bottom-color: var(--hammer-white);
    position: relative;
}

.woocommerce-tabs .panel {
    padding: var(--hammer-spacing-xl);
    border: 1px solid var(--hammer-gray-300);
    border-top: none;
    border-radius: 0 0 var(--hammer-radius-md) var(--hammer-radius-md);
}

.woocommerce-tabs .panel h2 {
    font-size: var(--hammer-text-xl);
    margin-bottom: var(--hammer-spacing-lg);
}

/* Reviews */
#reviews .commentlist {
    margin: 0;
    padding: 0;
    list-style: none;
}

#reviews .comment {
    padding: var(--hammer-spacing-lg) 0;
    border-bottom: 1px solid var(--hammer-gray-200);
}

#reviews .comment:last-child {
    border-bottom: none;
}

#reviews .comment_container {
    display: flex;
    gap: var(--hammer-spacing-md);
}

#reviews .avatar {
    flex-shrink: 0;
    border-radius: var(--hammer-radius-full);
}

#reviews .comment-text {
    flex: 1;
}

#reviews .meta {
    margin-bottom: var(--hammer-spacing-sm);
}

#reviews .meta strong {
    color: var(--hammer-primary);
}

#reviews .meta time {
    color: var(--hammer-gray-500);
    font-size: var(--hammer-text-sm);
}

#reviews .description p {
    margin: 0;
}

#review_form_wrapper {
    margin-top: var(--hammer-spacing-xl);
}

/* ==========================================================================
   Related Products & Upsells
   ========================================================================== */

.related.products,
.upsells.products,
.cross-sells {
    margin-top: var(--hammer-spacing-3xl);
    padding-top: var(--hammer-spacing-3xl);
    border-top: 1px solid var(--hammer-gray-200);
}

.related.products>h2,
.upsells.products>h2,
.cross-sells>h2 {
    font-size: var(--hammer-text-2xl);
    margin-bottom: var(--hammer-spacing-xl);
    color: var(--hammer-primary);
}

.related.products .product {
    grid-template-columns: none;
}

/* Break out of 2-column grid on single product page - span full width */
@media (min-width: 768px) {

    .single-product .product .related.products,
    .single-product .product .upsells.products {
        grid-column: 1 / -1;
    }
}

/* 4-column grid for related products on desktop - matches shop grid */
@media (min-width: 1024px) {

    .single-product .related.products ul.products,
    .single-product .upsells.products ul.products {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* ==========================================================================
   Cart Page
   ========================================================================== */

.woocommerce-cart-form {
    margin-bottom: var(--hammer-spacing-2xl);
}

.continue-shopping {
    margin-bottom: var(--hammer-spacing-xl);
}

.shop_table {
    width: 100%;
    border-collapse: collapse;
}

.shop_table th,
.shop_table td {
    padding: var(--hammer-spacing-md);
    text-align: left;
    border-bottom: 1px solid var(--hammer-gray-200);
}

.shop_table th {
    font-family: var(--hammer-font-heading);
    font-weight: 600;
    color: var(--hammer-primary);
    background-color: var(--hammer-gray-100);
}

.shop_table .product-thumbnail img {
    width: 80px;
    height: 80px;
    object-fit: cover;
    border-radius: var(--hammer-radius-sm);
}

.shop_table .product-name a {
    font-weight: 600;
    color: var(--hammer-primary);
}

.shop_table .product-name a:hover {
    color: var(--hammer-accent);
}

.shop_table .product-remove a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    color: var(--hammer-gray-500);
    background-color: var(--hammer-gray-100);
    border-radius: var(--hammer-radius-full);
    font-size: var(--hammer-text-lg);
    transition: all var(--hammer-transition-fast);
}

.shop_table .product-remove a:hover {
    color: var(--hammer-white);
    background-color: #dc3545;
}

.shop_table .quantity .qty {
    width: 70px;
    text-align: center;
}

.shop_table .actions {
    padding: var(--hammer-spacing-lg);
}

.shop_table .actions .coupon {
    display: flex;
    gap: var(--hammer-spacing-sm);
    flex-wrap: wrap;
}

.shop_table .actions .coupon input {
    max-width: 200px;
}

.shop_table .actions button[name="update_cart"] {
    margin-left: auto;
}

/* Cart Totals */
.cart_totals {
    background-color: var(--hammer-gray-100);
    padding: var(--hammer-spacing-xl);
    border-radius: var(--hammer-radius-md);
}

.cart_totals h2 {
    font-size: var(--hammer-text-xl);
    margin-bottom: var(--hammer-spacing-lg);
}

.cart_totals table {
    width: 100%;
}

.cart_totals th,
.cart_totals td {
    padding: var(--hammer-spacing-sm) 0;
    vertical-align: top;
}

.cart_totals th {
    font-weight: 600;
    text-align: left;
}

.cart_totals td {
    text-align: right;
}

.cart_totals .order-total th,
.cart_totals .order-total td {
    font-size: var(--hammer-text-xl);
    font-weight: 700;
    color: var(--hammer-primary);
    border-top: 2px solid var(--hammer-gray-300);
    padding-top: var(--hammer-spacing-md);
}

.wc-proceed-to-checkout {
    margin-top: var(--hammer-spacing-lg);
}

.wc-proceed-to-checkout .checkout-button {
    width: 100%;
}

/* Empty Cart */
.empty-cart-wrapper {
    text-align: center;
    padding: var(--hammer-spacing-3xl);
}

.empty-cart-wrapper svg {
    color: var(--hammer-gray-300);
    margin-bottom: var(--hammer-spacing-lg);
}

.empty-cart-wrapper h2 {
    font-size: var(--hammer-text-2xl);
    margin-bottom: var(--hammer-spacing-sm);
}

.empty-cart-wrapper p {
    color: var(--hammer-gray-600);
    margin-bottom: var(--hammer-spacing-xl);
}

/* WooCommerce Block Action Buttons */
.wc-block-cart__submit-container a,
.wc-block-cart__submit-container .wc-block-components-button,
.wc-block-components-checkout-place-order-button,
.wc-block-components-button.wp-element-button.contained {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--hammer-spacing-sm);
    padding: 12px 24px;
    font-family: var(--hammer-font-heading);
    font-size: var(--hammer-text-sm);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--hammer-white);
    background-color: var(--hammer-primary);
    border: 2px solid var(--hammer-primary);
    border-radius: var(--hammer-radius-md);
    cursor: pointer;
    transition: all var(--hammer-transition-fast);
    text-decoration: none;
    width: 100%;
}

.wc-block-cart__submit-container a:hover,
.wc-block-cart__submit-container .wc-block-components-button:hover,
.wc-block-components-checkout-place-order-button:hover,
.wc-block-components-button.wp-element-button.contained:hover {
    background-color: var(--hammer-accent);
    border-color: var(--hammer-accent);
    color: var(--hammer-primary);
}

.wc-block-components-order-summary-item__individual-prices.price.wc-block-components-product-price,
table.wc-block-cart-items .wc-block-cart-item__wrap .wc-block-components-product-price {
    color: #958e09;
    font-weight: 400;
    font-size: .857em;
}

/* ==========================================================================
   Checkout Page
   ========================================================================== */

.woocommerce-checkout {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--hammer-spacing-2xl);
}

.woocommerce-order-received.woocommerce-checkout {
    gap: 0;
}

.checkout-section-title {
    font-size: var(--hammer-text-xl);
    margin-bottom: var(--hammer-spacing-lg);
    padding-bottom: var(--hammer-spacing-sm);
    border-bottom: 2px solid var(--hammer-accent);
}

.woocommerce-billing-fields,
.woocommerce-shipping-fields,
.woocommerce-additional-fields {
    margin-bottom: var(--hammer-spacing-2xl);
}

.woocommerce-checkout .form-row {
    margin-bottom: var(--hammer-spacing-md);
}

.woocommerce-checkout .form-row-first,
.woocommerce-checkout .form-row-last {
    width: 100%;
}

.woocommerce-checkout .form-row label {
    display: block;
    margin-bottom: var(--hammer-spacing-xs);
    font-weight: 500;
}

.woocommerce-checkout .form-row .required {
    color: #dc3545;
}

.woocommerce-checkout .form-row input,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea {
    width: 100%;
}

/* Order Review */
.woocommerce-checkout-review-order {
    background-color: var(--hammer-gray-100);
    padding: var(--hammer-spacing-xl);
    border-radius: var(--hammer-radius-md);
}

.woocommerce-checkout-review-order-table {
    width: 100%;
    margin-bottom: var(--hammer-spacing-lg);
}

.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td {
    padding: var(--hammer-spacing-sm) 0;
}

.woocommerce-checkout-review-order-table thead th {
    font-family: var(--hammer-font-heading);
    border-bottom: 1px solid var(--hammer-gray-300);
    padding-bottom: var(--hammer-spacing-md);
}

.woocommerce-checkout-review-order-table .cart_item td {
    border-bottom: 1px solid var(--hammer-gray-200);
}

.woocommerce-checkout-review-order-table tfoot th {
    font-weight: 600;
}

.woocommerce-checkout-review-order-table .order-total th,
.woocommerce-checkout-review-order-table .order-total td {
    font-size: var(--hammer-text-lg);
    font-weight: 700;
    color: var(--hammer-primary);
}

/* Payment Methods */
#payment {
    margin-top: var(--hammer-spacing-lg);
}

#payment .payment_methods {
    padding: 0;
    margin: 0 0 var(--hammer-spacing-lg) 0;
    list-style: none;
}

#payment .payment_methods li {
    margin-bottom: var(--hammer-spacing-sm);
}

#payment .payment_methods li label {
    display: flex;
    align-items: center;
    gap: var(--hammer-spacing-sm);
    padding: var(--hammer-spacing-md);
    background-color: var(--hammer-white);
    border: 2px solid var(--hammer-gray-300);
    border-radius: var(--hammer-radius-md);
    cursor: pointer;
    transition: border-color var(--hammer-transition-fast);
}

#payment .payment_methods li.active label,
#payment .payment_methods li label:hover {
    border-color: var(--hammer-primary);
}

#payment .payment_methods li img {
    height: 24px;
    width: auto;
}

#payment .payment_box {
    padding: var(--hammer-spacing-md);
    background-color: var(--hammer-white);
    border-radius: var(--hammer-radius-md);
    margin-top: var(--hammer-spacing-sm);
    font-size: var(--hammer-text-sm);
    color: var(--hammer-gray-600);
}

#payment .place-order {
    padding-top: var(--hammer-spacing-lg);
}

#payment #place_order {
    width: 100%;
    font-size: var(--hammer-text-lg);
    padding: var(--hammer-spacing-md) var(--hammer-spacing-xl);
}

.woocommerce-terms-and-conditions-wrapper {
    margin-bottom: var(--hammer-spacing-lg);
    font-size: var(--hammer-text-sm);
}

.wc-block-components-order-summary .wc-block-components-order-summary-item {
    display: block;
}
.wc-block-components-order-summary .wc-block-components-order-summary-item {
    padding-bottom: 8px;
    margin: 4px;
    margin-bottom: 12px;
    border-bottom: 1px solid rgba(0, 0, 0, 0.03);
}

/* ==========================================================================
   My Account Page
   ========================================================================== */

.woocommerce-account .woocommerce-MyAccount-navigation {
    margin-bottom: var(--hammer-spacing-xl);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul {
    display: flex;
    flex-direction: column;
    gap: var(--hammer-spacing-xs);
    margin: 0;
    padding: 0;
    list-style: none;
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
    display: flex;
    align-items: center;
    gap: var(--hammer-spacing-sm);
    padding: var(--hammer-spacing-md);
    color: var(--hammer-gray-700);
    background-color: var(--hammer-gray-100);
    border-radius: var(--hammer-radius-md);
    transition: all var(--hammer-transition-fast);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
    color: var(--hammer-white);
    background-color: var(--hammer-primary);
}

.woocommerce-account .woocommerce-MyAccount-navigation ul li a svg {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
}

.woocommerce-account .woocommerce-MyAccount-content {
    background-color: var(--hammer-gray-100);
    padding: var(--hammer-spacing-xl);
    border-radius: var(--hammer-radius-md);
}

/* Orders Table */
.woocommerce-orders-table {
    width: 100%;
}

.woocommerce-orders-table th,
.woocommerce-orders-table td {
    padding: var(--hammer-spacing-md);
    text-align: left;
}

.woocommerce-orders-table th {
    background-color: var(--hammer-primary);
    color: var(--hammer-white);
}

.woocommerce-orders-table th:first-child {
    border-radius: var(--hammer-radius-md) 0 0 0;
}

.woocommerce-orders-table th:last-child {
    border-radius: 0 var(--hammer-radius-md) 0 0;
}

.woocommerce-orders-table td {
    background-color: var(--hammer-white);
    border-bottom: 1px solid var(--hammer-gray-200);
}

.woocommerce-orders-table .button {
    font-size: var(--hammer-text-xs);
    padding: 8px 16px;
}

/* Login/Register Forms */
.woocommerce-form-login,
.woocommerce-form-register {
    background-color: var(--hammer-gray-100);
    padding: var(--hammer-spacing-xl);
    border-radius: var(--hammer-radius-md);
}

.woocommerce-form-login h2,
.woocommerce-form-register h2 {
    font-size: var(--hammer-text-xl);
    margin-bottom: var(--hammer-spacing-lg);
}

/* ==========================================================================
   Widgets
   ========================================================================== */

.mobile-menu-widgets-area {
    border-top: 0;
    margin-top: 0;
}

.mobile-menu-widget ul {
    flex: 1;
}

/* Price Filter */
.widget_price_filter .price_slider_wrapper {
    padding: var(--hammer-spacing-md) 0;
}

.widget_price_filter .ui-slider {
    height: 6px;
    background-color: var(--hammer-gray-300);
    border-radius: var(--hammer-radius-full);
    position: relative;
}

.widget_price_filter .ui-slider .ui-slider-range {
    background-color: var(--hammer-accent);
    height: 100%;
    border-radius: var(--hammer-radius-full);
}

.widget_price_filter .ui-slider .ui-slider-handle {
    width: 20px;
    height: 20px;
    background-color: var(--hammer-primary);
    border-radius: var(--hammer-radius-full);
    border: 3px solid var(--hammer-white);
    box-shadow: var(--hammer-shadow-md);
    cursor: pointer;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}

.widget_price_filter .price_slider_amount {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--hammer-spacing-sm);
    margin-top: var(--hammer-spacing-md);
}

.widget_price_filter .price_slider_amount .price_label {
    font-weight: 600;
    color: var(--hammer-primary);
}

/* ==========================================================================
   PRODUCT CATEGORIES & SIDEBAR
   ========================================================================== */

/* Modern Block: .wp-block-woocommerce-product-categories */
.wp-block-woocommerce-product-categories.is-list {
    background-color: var(--hammer-gray-100);
    border-radius: var(--hammer-radius-md);
    margin-bottom: 0;
    padding: var(--hammer-spacing-lg);
}

aside .wp-block-woocommerce-product-categories.is-list {
    padding: 0;
}

.woocommerce-shop .page-description,
.wp-block-woocommerce-product-categories.is-list.alignfull {
    max-width: 100%;
}

/* Category Lists - Modern & Traditional */
.wc-block-product-categories-list,
.widget_product_categories ul.product-categories {
    display: flex;
    flex-direction: column;
    gap: var(--hammer-spacing-xs);
    margin: 0;
    padding: 0;
    list-style: none;
}

/* ==========================================================================
   Product List - Featured products list
   ========================================================================== */

/* Featured product carousel */

.hammer-featured-products-shortcode li .price {
    color: #958e09;
    display: block;
    font-weight: 400;
    margin-bottom: .5em;
    font-size: .857em;
    line-height: 1.2;
    font-family: var(--hammer-font-heading);
}


/* Product collection responsive grid (theme-specific) */
.wp-block-woocommerce-product-template.wc-block-product-template__responsive {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    /* default: 3 columns */
    gap: 1.5rem;
    /* space between items */
    align-items: start;
    list-style: none;
    margin: 0;
    padding: 0;
}

/* Product card */
.wp-block-woocommerce-product-template .wc-block-product {
    display: flex;
    flex-direction: column;
    background: transparent;
    /* change if you want a card bg */
    text-align: center;
    min-height: 100%;
}

/* Make product image area responsive and maintain aspect ratio */
.wp-block-woocommerce-product-template .wc-block-components-product-image img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: cover;
}

/* Title and price spacing */
.wp-block-woocommerce-product-template .wp-block-post-title {
    margin: 0.5rem 0 0.25rem;
    padding: 0 0.25rem;
}

/* Add-to-cart button alignment */
.wp-block-woocommerce-product-template .wc-block-components-product-button {
    margin-top: auto;
    /* push button to bottom for equal-height cards */
    padding: 0 0.25rem 0.5rem;
}

/* WooCommerce Blocks - Product Price Overrides */
.wc-block-components-product-price,
.wc-block-grid__product-price {
    font-size: var(--hammer-text-xl);
    align-items: center;
    justify-content: center;
}

.wc-block-components-product-price:not(:has(del)):not(:has(ins)) .woocommerce-Price-amount,
.wc-block-grid__product-price:not(:has(del)):not(:has(ins)) .woocommerce-Price-amount {
    height: 55px;
}

/* Responsive breakpoints */
/* Tablet / medium screens: 2 columns */
@media (max-width: 1023px) {
    .wp-block-woocommerce-product-template.wc-block-product-template__responsive {
        grid-template-columns: repeat(2, 1fr);
        gap: 1rem;
    }
}

/* Widget Title */
.widget_product_categories .widget-title {
    font-family: var(--hammer-font-heading);
    font-size: var(--hammer-text-lg);
    font-weight: 700;
    color: var(--hammer-primary);
    margin-bottom: var(--hammer-spacing-lg);
    padding-bottom: var(--hammer-spacing-sm);
    border-bottom: 2px solid var(--hammer-accent);
}

/* Category List Items - Modern & Traditional */
.wc-block-product-categories-list-item,
.widget_product_categories .cat-item {
    position: relative;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--hammer-spacing-xs);
    padding: var(--hammer-spacing-sm) var(--hammer-spacing-md);
    background-color: var(--hammer-white);
    border-left: 3px solid transparent;
    transition: all var(--hammer-transition-fast);
}

.wc-block-product-categories-list-item:hover,
.widget_product_categories .cat-item:hover {
    border-left-color: var(--hammer-accent);
}

/* Category Links */
.wc-block-product-categories-list-item>a,
.widget_product_categories .cat-item>a {
    flex: 1;
    color: var(--hammer-gray-700);
    font-family: var(--hammer-font-heading);
    font-size: var(--hammer-text-sm);
    font-weight: 500;
    line-height: 1.4;
    transition: color var(--hammer-transition-fast);
}

.category-submenu .wc-block-product-categories-list-item>a {
    flex: 1 0 auto;
}

.wc-block-product-categories-list.category-submenu {
    background-color: transparent !important;
    margin: 0 0 0 0;
    padding: 0 0 0 .5rem !important;
}

.wc-block-product-categories-list.category-submenu li {
    background-color: transparent;
    margin-left: 0;
}

.wc-block-product-categories-list-item>a:hover,
.widget_product_categories .cat-item>a:hover {
    color: var(--hammer-primary);
}

.wc-block-product-categories-list-item>a:focus,
.widget_product_categories .cat-item>a:focus {
    opacity: 0.5;
}

/* Category Names */
.wc-block-product-categories-list-item__name {
    flex: 1;
    font-family: var(--hammer-font-heading);
    font-size: var(--hammer-text-sm);
    line-height: 1.4;
}

/* Product Count Badges - Both Versions */
.wc-block-product-categories-list-item-count,
.widget_product_categories .count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 28px;
    height: 24px;
    padding: 0 var(--hammer-spacing-xs);
    font-size: var(--hammer-text-xs);
    font-weight: 600;
    color: var(--hammer-gray-600);
    border-radius: var(--hammer-radius-full);
    transition: all var(--hammer-transition-fast);
    speak: none;
    order: -1;
}

.wc-block-product-categories-list-item-count {
    color: var(--hammer-primary);
}

.widget_product_categories .cat-item:hover .count {
    background-color: var(--hammer-accent-light);
    color: var(--hammer-primary);
}

.widget_product_categories .cat-item .count {
    background-color: var(--hammer-gray-200);
}

/* Active/Current Categories */
.wc-block-product-categories-list-item.is-current-cat,
.wc-block-product-categories-list-item.current-cat,
.wc-block-product-categories-list-item.current-cat-parent,
.widget_product_categories .cat-item.current-cat,
.widget_product_categories .cat-item.current-cat-parent,
.widget_product_categories .cat-item.current-cat-ancestor {
    border-left-color: var(--hammer-accent);
}

.wc-block-product-categories-list-item.is-current-cat>a,
.wc-block-product-categories-list-item.current-cat>a,
.wc-block-product-categories-list-item.current-cat-parent>a,
.widget_product_categories .cat-item.current-cat>a,
.widget_product_categories .cat-item.current-cat-parent>a,
.widget_product_categories .cat-item.current-cat-ancestor>a {
    color: var(--hammer-white);
    font-weight: 600;
}

.widget_product_categories .cat-item.current-cat,
.widget_product_categories .cat-item.current-cat-parent,
.widget_product_categories .cat-item.current-cat-ancestor {
    background-color: var(--hammer-primary);
}

.widget_product_categories .cat-item.current-cat .count,
.widget_product_categories .cat-item.current-cat-parent .count,
.widget_product_categories .cat-item.current-cat-ancestor .count {
    background-color: var(--hammer-accent);
    color: var(--hammer-primary-dark);
}

/* Nested Categories - All Versions */
.wc-block-product-categories-list--depth-1,
.wc-block-product-categories-list--depth-2,
.wc-block-product-categories-list--depth-3,
.widget_product_categories ul.children {
    margin-top: var(--hammer-spacing-xs);
    margin-left: var(--hammer-spacing-md);
    padding-left: var(--hammer-spacing-md);
    gap: var(--hammer-spacing-xs);
}

/* Nested Item Overrides */
.wc-block-product-categories-list--depth-1 .wc-block-product-categories-list-item,
.wc-block-product-categories-list--depth-2 .wc-block-product-categories-list-item,
.wc-block-product-categories-list--depth-3 .wc-block-product-categories-list-item,
.widget_product_categories ul.children .cat-item {
    padding: var(--hammer-spacing-xs) var(--hammer-spacing-sm);
    font-size: var(--hammer-text-sm);
}

.wc-block-product-categories-list--depth-1 .wc-block-product-categories-list-item__name,
.wc-block-product-categories-list--depth-2 .wc-block-product-categories-list-item__name,
.wc-block-product-categories-list--depth-3 .wc-block-product-categories-list-item__name,
.widget_product_categories ul.children .cat-item>a {
    font-size: var(--hammer-text-xs);
}

.wc-block-product-categories-list--depth-1 .wc-block-product-categories-list-item.is-current-cat,
.wc-block-product-categories-list--depth-2 .wc-block-product-categories-list-item.is-current-cat,
.wc-block-product-categories-list--depth-3 .wc-block-product-categories-list-item.is-current-cat,
.widget_product_categories ul.children .cat-item.current-cat {
    border-left-width: 2px;
}

/* Rating Filter Widget */
.widget_rating_filter ul li {
    display: flex;
    align-items: center;
    gap: var(--hammer-spacing-sm);
}

.widget_rating_filter .star-rating {
    margin: 0;
}

/* ==========================================================================
   Mini Cart (Header Cart Dropdown)
   ========================================================================== */

.widget_shopping_cart_content {
    padding: var(--hammer-spacing-md);
}

.widget_shopping_cart_content ul.cart_list {
    max-height: 300px;
    overflow-y: auto;
}

.widget_shopping_cart_content ul.cart_list li {
    display: flex;
    gap: var(--hammer-spacing-sm);
    padding: var(--hammer-spacing-sm) 0;
    border-bottom: 1px solid var(--hammer-gray-200);
}

.widget_shopping_cart_content ul.cart_list li img {
    width: 60px;
    height: 60px;
    object-fit: cover;
    border-radius: var(--hammer-radius-sm);
}

.widget_shopping_cart_content ul.cart_list li a.remove {
    font-size: var(--hammer-text-lg);
    color: var(--hammer-gray-500);
    margin-left: auto;
}

.widget_shopping_cart_content .total {
    display: flex;
    justify-content: space-between;
    padding: var(--hammer-spacing-md) 0;
    font-weight: 600;
}

.widget_shopping_cart_content .buttons {
    display: flex;
    gap: var(--hammer-spacing-sm);
}

.widget_shopping_cart_content .buttons a {
    flex: 1;
    text-align: center;
}

/* ==========================================================================
   Product Search
   ========================================================================== */

.wp-theme-hammer-shop .woocommerce-product-search {
    position: relative;
}

.wp-theme-hammer-shop .woocommerce-product-search input[type="search"] {
    padding-right: 135px;
}

.wp-theme-hammer-shop .woocommerce-product-search button[type="submit"] {
    position: absolute;
    right: 9px;
    top: 10px;
}


/* ==========================================================================
   RESPONSIVE & MOBILE STYLES
   ========================================================================== */

/* Base Mobile Hidden Elements */
.hammer-main-banner {
    display: none;
}

/* -------- Tablet & Up (768px) -------- */
@media (min-width: 768px) {
    .hammer-main-banner-mobile {
        display: none;
    }

    .hammer-main-banner {
        display: block;
    }

    .single-product .product {
        grid-template-columns: 1fr 500px;
    }

    .woocommerce-checkout .form-row-first,
    .woocommerce-checkout .form-row-last {
        width: calc(50% - 8px);
    }

    .woocommerce-checkout .form-row-first {
        float: left;
    }

    .woocommerce-checkout .form-row-last {
        float: right;
    }

    .woocommerce-account .woocommerce {
        display: grid;
        grid-template-columns: 250px 1fr;
        gap: var(--hammer-spacing-xl);
    }

    .woocommerce-account .woocommerce-MyAccount-navigation {
        margin-bottom: 0;
    }

    .woocommerce-shop .wp-block-woocommerce-product-categories.is-list {
        display: none;
    }

    .woocommerce-shop aside .wp-block-woocommerce-product-categories.is-list {
        display: block;
    }

    .hammer-price-list-download .button {
        display: inline-flex;
        width: auto;
    }
}

/* -------- Desktop (1024px & Up) -------- */
@media (min-width: 1024px) {
    ul.products {
        grid-template-columns: repeat(3, 1fr);
    }

    .woocommerce-checkout-review-order {
        position: sticky;
        top: calc(var(--hammer-header-height) + var(--hammer-spacing-lg));
    }

    .woocommerce-cart .woocommerce-cart-form {
        margin-bottom: 0;
    }

    .cart_totals {
        position: sticky;
        top: calc(var(--hammer-header-height) + var(--hammer-spacing-lg));
    }
}

/* -------- Mobile Adjustments (max-width: 767px) -------- */
@media (max-width: 767px) {
    .woocommerce-shop aside {
        display: none;
    }

    .shop_table thead {
        display: none;
    }

    .shop_table tbody tr {
        display: flex;
        flex-wrap: wrap;
        padding: var(--hammer-spacing-md) 0;
        border-bottom: 1px solid var(--hammer-gray-200);
    }

    .shop_table tbody td {
        border: none;
        padding: var(--hammer-spacing-xs) var(--hammer-spacing-sm);
    }

    .shop_table .product-thumbnail {
        width: 80px;
    }

    .shop_table .product-name {
        flex: 1;
    }

    .shop_table .product-price,
    .shop_table .product-quantity,
    .shop_table .product-subtotal {
        width: 33.33%;
        text-align: center;
    }

    .shop_table .product-price::before,
    .shop_table .product-quantity::before,
    .shop_table .product-subtotal::before {
        content: attr(data-title);
        display: block;
        font-size: var(--hammer-text-xs);
        color: var(--hammer-gray-500);
        margin-bottom: var(--hammer-spacing-xs);
    }

    .shop_table .product-remove {
        position: absolute;
        top: var(--hammer-spacing-md);
        right: 0;
    }

    .shop_table .actions {
        flex-direction: column;
        gap: var(--hammer-spacing-md);
    }

    .shop_table .actions .coupon,
    .shop_table .actions button[name="update_cart"] {
        width: 100%;
        margin-left: 0;
    }

    .woocommerce-tabs ul.tabs {
        flex-direction: column;
    }

    .woocommerce-tabs ul.tabs li a {
        border-radius: 0;
    }

    .woocommerce-tabs ul.tabs li:first-child a {
        border-radius: var(--hammer-radius-md) var(--hammer-radius-md) 0 0;
    }

    .product-trust-badges {
        flex-direction: column;
    }

    .woocommerce-orders-table,
    .woocommerce-orders-table tbody,
    .woocommerce-orders-table th,
    .woocommerce-orders-table td,
    .woocommerce-orders-table tr {
        display: block;
    }

    .woocommerce-orders-table thead {
        display: none;
    }

    .woocommerce-orders-table tr {
        margin-bottom: var(--hammer-spacing-md);
        border: 1px solid var(--hammer-gray-200);
        border-radius: var(--hammer-radius-md);
        overflow: hidden;
    }

    .woocommerce-orders-table td {
        padding: var(--hammer-spacing-sm) var(--hammer-spacing-md);
        text-align: right;
        border-bottom: 1px solid var(--hammer-gray-200);
    }

    .woocommerce-orders-table td::before {
        content: attr(data-title);
        float: left;
        font-weight: 600;
    }

    .woocommerce-orders-table td:last-child {
        border-bottom: none;
    }

    .wc-block-product-categories-list-item,
    .widget_product_categories .cat-item {
        padding: var(--hammer-spacing-xs) var(--hammer-spacing-sm);
    }

    .wc-block-product-categories-list--depth-1,
    .wc-block-product-categories-list--depth-2,
    .wc-block-product-categories-list--depth-3,
    .widget_product_categories ul.children {
        margin-left: var(--hammer-spacing-sm);
        padding-left: var(--hammer-spacing-sm);
    }

    .single-product .mobile-sticky-cta {
        display: flex;
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        height: 56px;
        z-index: 999;
        background: var(--hammer-white);
        box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.1);
    }

    .single-product .site-main {
        padding-bottom: 70px;
    }

    .hammer-price-list-download .button {
        width: 100%;
        justify-content: center;
    }

    .mobile-sticky-cta--call-only {
        display: flex;
    }

    .mobile-cta-call--full {
        flex: 1;
        width: 100%;
    }
}

/* -------- Small Mobile (max-width: 420px) -------- */
@media (max-width: 420px) {
    ul.products {
        grid-template-columns: 1fr;
    }

    .woocommerce ul.products li.product .woocommerce-loop-category__title,
    .woocommerce ul.products li.product .woocommerce-loop-product__title,
    .woocommerce ul.products li.product h3 {
        display: block;
        -webkit-line-clamp: unset;
        -webkit-box-orient: unset;
        overflow: visible;
        text-overflow: unset;
        min-height: auto;
        max-height: none;
    }
}

/* Mobile Menu Widget */
.mobile-menu-widget a {
    border: none;
}

.mobile-menu-widget .wc-block-product-categories-list-item>a {
    flex: 0 1 calc(100% - 46px);
}

.mobile-menu-widget .wc-block-product-categories-list-item .category-toggle {
    top: 24px;
}

/* Mobile Sticky CTA - Product Pages */
.mobile-sticky-cta {
    display: none;
}

.mobile-cta-btn {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--hammer-spacing-sm);
    font-weight: 600;
    font-size: 1rem;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: all var(--hammer-transition-fast);
}

.mobile-cta-btn svg {
    flex-shrink: 0;
}

.mobile-cta-order {
    background: var(--hammer-accent);
    color: var(--hammer-primary-dark);
}

.mobile-cta-order:hover,
.mobile-cta-order:active {
    background: var(--hammer-accent-dark);
}

.mobile-cta-order:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.mobile-cta-call {
    background: var(--hammer-primary);
    color: var(--hammer-white);
}

.mobile-cta-call:hover,
.mobile-cta-call:active {
    background: var(--hammer-primary-light);
}

/* ==========================================================================
   CALL-ONLY PRODUCTS
   ========================================================================== */

.call-only-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--hammer-spacing-sm);
    background-color: var(--hammer-accent) !important;
    border-color: var(--hammer-accent) !important;
    color: var(--hammer-primary) !important;
    font-weight: 600;
    text-decoration: none;
    transition: all var(--hammer-transition-fast);
}

.call-only-button:hover {
    background-color: var(--hammer-primary) !important;
    border-color: var(--hammer-primary) !important;
    color: var(--hammer-white) !important;
}

.call-only-button:focus {
    outline: 2px solid var(--hammer-accent);
    outline-offset: 2px;
}

.call-only-button svg {
    position: absolute;
    left: 20px;
}

.call-only-button--loop {
    width: 100%;
    padding: 12px 24px;
    font-size: var(--hammer-text-sm);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.call-only-wrapper {
    margin-bottom: var(--hammer-spacing-lg);
    padding-bottom: var(--hammer-spacing-lg);
    border-bottom: 1px solid var(--hammer-gray-200);
}

.call-only-notice {
    display: flex;
    align-items: flex-start;
    gap: var(--hammer-spacing-sm);
    padding: var(--hammer-spacing-md);
    background-color: var(--hammer-gray-100);
    border-left: 4px solid var(--hammer-accent);
    border-radius: var(--hammer-radius-sm);
    margin-bottom: var(--hammer-spacing-md);
    font-size: var(--hammer-text-sm);
    color: var(--hammer-gray-700);
}

.call-only-notice svg {
    flex-shrink: 0;
    color: var(--hammer-accent);
    margin-top: 2px;
}

.call-only-button--single {
    width: 100%;
    padding-left: 56px!important;
}

.call-only-button:hover svg {
    animation: phone-ring 0.5s ease-in-out;
}

@keyframes phone-ring {

    0%,
    100% {
        transform: rotate(0deg);
    }

    10%,
    30%,
    50%,
    70%,
    90% {
        transform: rotate(-10deg);
    }

    20%,
    40%,
    60%,
    80% {
        transform: rotate(10deg);
    }
}

/* ==========================================================================
   SPECIAL PRODUCTS - PRICE RANGE & PDF PRICELIST
   ========================================================================== */

.hammer-price-list-download {
    margin: var(--hammer-spacing-lg) 0;
}

.woocommerce #primary .hammer-price-list-download .button {
    display: inline-flex;
    align-items: center;
    gap: var(--hammer-spacing-sm);
    background-color: var(--hammer-primary);
    color: #ffffff;
    border: 2px solid var(--hammer-primary);
    padding: var(--hammer-spacing-md) var(--hammer-spacing-xl);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.hammer-price-list-download .button svg {
    flex-shrink: 0;
}

/* ==========================================================================
   ORDER DETAILS - Card-Based Layout (Thank You / Order Received Page)
   ========================================================================== */

/* Section Title */
.woocommerce-order-details__title {
    font-family: var(--hammer-font-heading);
    font-size: var(--hammer-text-2xl);
    font-weight: 700;
    color: var(--hammer-primary);
    margin-bottom: var(--hammer-spacing-lg);
}

/* Card Wrapper */
.order-details-card {
    background-color: var(--hammer-white);
    border: 1px solid var(--hammer-gray-200);
    border-radius: var(--hammer-radius-lg);
    box-shadow: var(--hammer-shadow-sm);
    overflow: hidden;
}

/* Items Container */
.order-details-items {
    padding: var(--hammer-spacing-lg);
    display: flex;
    flex-direction: column;
    gap: var(--hammer-spacing-md);
}

/* Individual Item Card */
.order-item-card {
    display: flex;
    align-items: center;
    gap: var(--hammer-spacing-md);
    padding: var(--hammer-spacing-md);
    background-color: var(--hammer-gray-100);
    border-radius: var(--hammer-radius-md);
    transition: background-color var(--hammer-transition-fast);
}

.order-item-card:hover {
    background-color: var(--hammer-gray-200);
}

/* Item Thumbnail */
.order-item-thumbnail {
    flex-shrink: 0;
    width: 72px;
    height: 72px;
    border-radius: var(--hammer-radius-md);
    overflow: hidden;
}

.order-item-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.order-item-thumbnail a {
    display: block;
    line-height: 0;
}

/* Item Details */
.order-item-details {
    flex: 1;
    min-width: 0;
}

.order-item-name {
    font-family: var(--hammer-font-heading);
    font-size: var(--hammer-text-base);
    font-weight: 600;
    color: var(--hammer-primary);
    line-height: 1.4;
    margin-bottom: var(--hammer-spacing-xs);
}

.order-item-name a {
    color: inherit;
    text-decoration: none;
    transition: color var(--hammer-transition-fast);
}

.order-item-name a:hover {
    color: var(--hammer-accent);
}

.order-item-qty {
    font-family: var(--hammer-font-primary);
    font-size: var(--hammer-text-sm);
    font-weight: 500;
    color: var(--hammer-gray-600);
}

.order-item-details .wc-item-meta {
    margin-top: var(--hammer-spacing-xs);
    padding: 0;
    list-style: none;
}

.order-item-details .wc-item-meta li {
    font-size: var(--hammer-text-sm);
    color: var(--hammer-gray-600);
}

.order-item-details .wc-item-meta li strong {
    font-weight: 600;
}

/* Item Price */
.order-item-price {
    flex-shrink: 0;
    font-family: var(--hammer-font-heading);
    font-size: var(--hammer-text-lg);
    font-weight: 700;
    color: var(--hammer-primary);
    text-align: right;
    white-space: nowrap;
}

/* Purchase Note */
.order-item-purchase-note {
    padding: 0 var(--hammer-spacing-lg) var(--hammer-spacing-sm);
    font-size: var(--hammer-text-sm);
    color: var(--hammer-gray-600);
}

/* Divider */
.order-details-divider {
    height: 1px;
    background-color: var(--hammer-gray-200);
    margin: 0 var(--hammer-spacing-lg);
}

/* Actions Section */
.order-details-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--hammer-spacing-sm);
    padding: var(--hammer-spacing-lg);
    padding-bottom: 0;
}

/* Totals Section */
.order-details-totals {
    padding: var(--hammer-spacing-lg);
    display: flex;
    flex-direction: column;
    gap: var(--hammer-spacing-sm);
}

.order-details-total-row {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
}

.order-details-total-label {
    font-family: var(--hammer-font-primary);
    font-size: var(--hammer-text-sm);
    font-weight: 500;
    color: var(--hammer-gray-600);
}

.order-details-total-value {
    font-family: var(--hammer-font-primary);
    font-size: var(--hammer-text-sm);
    font-weight: 500;
    color: var(--hammer-gray-800);
    text-align: right;
}

/* Final Total Row */
.order-details-total-row--final {
    border-top: 2px solid var(--hammer-gray-200);
    padding-top: var(--hammer-spacing-md);
    margin-top: var(--hammer-spacing-sm);
}

.order-details-total-row--final .order-details-total-label {
    font-family: var(--hammer-font-heading);
    font-size: var(--hammer-text-lg);
    font-weight: 700;
    color: var(--hammer-primary);
}

.order-details-total-row--final .order-details-total-value {
    font-family: var(--hammer-font-heading);
    font-size: var(--hammer-text-xl);
    font-weight: 700;
    color: var(--hammer-primary);
}

/* Customer Note Row */
.order-details-note .order-details-total-value {
    max-width: 60%;
    text-align: right;
}

/* -------- Order Details Mobile (max-width: 767px) -------- */
@media (max-width: 767px) {
    .order-item-card {
        flex-wrap: wrap;
    }

    .order-item-thumbnail {
        width: 56px;
        height: 56px;
    }

    .order-item-price {
        width: 100%;
        text-align: right;
        padding-top: var(--hammer-spacing-sm);
        border-top: 1px dashed var(--hammer-gray-300);
        margin-top: var(--hammer-spacing-xs);
    }
}

/* -------- Order Details Small Mobile (max-width: 420px) -------- */
@media (max-width: 420px) {
    .order-details-items {
        padding: var(--hammer-spacing-md);
    }

    .order-item-card {
        padding: var(--hammer-spacing-sm);
        gap: var(--hammer-spacing-sm);
    }

    .order-item-name {
        font-size: var(--hammer-text-sm);
    }

    .order-item-price {
        font-size: var(--hammer-text-base);
    }

    .order-details-totals {
        padding: var(--hammer-spacing-md);
    }

    .order-details-divider {
        margin: 0 var(--hammer-spacing-md);
    }

    .order-details-total-row--final .order-details-total-label {
        font-size: var(--hammer-text-base);
    }

    .order-details-total-row--final .order-details-total-value {
        font-size: var(--hammer-text-lg);
    }
}
