/**
 * shop.css — Estilos específicos de la tienda WooCommerce
 * Extiende el design system principal (style.css)
 */

/* ============================================================
   TIENDA — Layout principal
   ============================================================ */
.section--shop {
    padding-block: var(--space-16);
}

/* Título de la tienda */
.woocommerce-products-header__title {
    font-family: var(--font-serif);
    font-size: clamp(1.75rem, 4vw, var(--text-5xl));
    font-weight: 400;
    color: var(--color-text-primary);
    margin-bottom: var(--space-8);
}

/* ============================================================
   GRID DE PRODUCTOS
   ============================================================ */
.woocommerce ul.products {
    display: grid !important;
    grid-template-columns: repeat( auto-fill, minmax( 280px, 1fr ) ) !important;
    gap: var(--space-6) !important;
    float: none !important;
    width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    list-style: none !important;
}

.woocommerce ul.products li.product {
    float: none !important;
    width: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    background: var(--color-bg-card);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-lg);
    overflow: hidden;
    transition: all var(--transition-base);
    display: flex !important;
    flex-direction: column;
}

.woocommerce ul.products li.product:hover {
    transform: translateY(-3px);
    box-shadow: var(--shadow-lg);
    border-color: var(--color-duna);
}

/* Imagen del producto */
.woocommerce ul.products li.product a img {
    width: 100% !important;
    height: 220px !important;
    object-fit: cover !important;
    border-radius: 0 !important;
    transition: transform var(--transition-slow);
}

.woocommerce ul.products li.product:hover a img {
    transform: scale(1.04);
}

/* Badge "Nuevo" */
.product-badge {
    display: inline-block;
    font-size: var(--text-xs);
    font-weight: 500;
    padding: 4px 10px;
    border-radius: var(--radius-full);
    margin: var(--space-4) var(--space-5) 0;
}

.product-badge--new {
    background-color: var(--color-arena);
    color: var(--color-tierra);
}

/* Categorías del producto */
.product-cats {
    display: block;
    font-size: var(--text-xs);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-miel);
    padding: var(--space-4) var(--space-5) 0;
}

/* Título y precio */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
    padding: var(--space-3) var(--space-5) var(--space-2) !important;
}

/* ============================================================
   PÁGINA DE PRODUCTO INDIVIDUAL
   ============================================================ */
.woocommerce div.product {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-12);
    align-items: start;
}

.woocommerce div.product .woocommerce-product-gallery {
    position: sticky;
    top: calc( var(--header-height) + var(--space-6) );
}

.woocommerce div.product .woocommerce-product-gallery__image img {
    border-radius: var(--radius-lg);
}

.woocommerce div.product .product_title {
    font-family: var(--font-serif);
    font-size: clamp(1.75rem, 3vw, var(--text-5xl));
    font-weight: 400;
    margin-bottom: var(--space-4);
}

.woocommerce div.product p.price {
    font-size: var(--text-2xl);
    color: var(--color-tierra);
    margin-bottom: var(--space-6);
}

.woocommerce div.product .woocommerce-product-details__short-description {
    font-size: var(--text-base);
    color: var(--color-text-secondary);
    line-height: 1.8;
    margin-bottom: var(--space-6);
    padding-bottom: var(--space-6);
    border-bottom: 1px solid var(--color-border-light);
}

/* ============================================================
   CARRITO
   ============================================================ */
.woocommerce-cart-form table.cart {
    border-collapse: collapse;
    width: 100%;
}

.woocommerce-cart-form table.cart td,
.woocommerce-cart-form table.cart th {
    padding: var(--space-4);
    border-bottom: 1px solid var(--color-border-light);
    vertical-align: middle;
}

.woocommerce-cart-form table.cart .product-thumbnail img {
    border-radius: var(--radius-md);
    width: 80px;
    height: 80px;
    object-fit: cover;
}

/* ============================================================
   CHECKOUT
   ============================================================ */
.woocommerce-checkout .woocommerce {
    display: grid;
    grid-template-columns: 1.4fr 1fr;
    gap: var(--space-10);
    align-items: start;
}

.woocommerce form .form-row label {
    font-size: var(--text-sm);
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: var(--space-1);
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row select {
    border: 1.5px solid var(--color-border-light);
    border-radius: var(--radius-md);
    padding: var(--space-3) var(--space-4);
    font-family: var(--font-sans);
    color: var(--color-text-primary);
    background: var(--color-lino);
    width: 100%;
    transition: border-color var(--transition-fast);
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row select:focus {
    outline: none;
    border-color: var(--color-miel);
    box-shadow: 0 0 0 3px rgba(196, 149, 106, 0.15);
}

/* Order review */
.woocommerce-checkout-review-order {
    background: var(--color-bg-alt);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    border: 1px solid var(--color-border-light);
}

/* ============================================================
   RESPONSIVE TIENDA
   ============================================================ */
@media (max-width: 768px) {
    .woocommerce div.product {
        grid-template-columns: 1fr;
    }

    .woocommerce div.product .woocommerce-product-gallery {
        position: static;
    }

    .woocommerce-checkout .woocommerce {
        grid-template-columns: 1fr;
    }
}
