/* ==========================================================================
   SHOP LAYOUT
   ========================================================================== */

.shop-page { padding-block: var(--space-8) var(--space-16); }

/* Page hero: eyebrow + h1 para shop, cart, checkout, categorias */
.page-hero { margin-bottom: var(--space-8); }
.page-hero h1 { font-size: var(--font-size-3xl); font-weight: var(--font-weight-extrabold); letter-spacing: -.02em; line-height: 1.1; margin-bottom: 0; }

.shop-layout {
    display: grid;
    grid-template-columns: 240px 1fr;
    gap: var(--space-8);
    align-items: start;
}

/* ==========================================================================
   SIDEBAR
   ========================================================================== */

.shop-sidebar { position: sticky; top: calc(var(--promo-bar-height) + var(--header-height) + var(--space-4)); }
.shop-sidebar__inner { display: flex; flex-direction: column; gap: var(--space-6); }

.sidebar-widget { background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: var(--radius-lg); padding: var(--space-5); }
.sidebar-widget__title { font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold); color: var(--color-text-muted); margin-bottom: var(--space-4); text-transform: uppercase; letter-spacing: .08em; }

.sidebar-cat-list { display: flex; flex-direction: column; gap: 2px; }
.sidebar-cat-link { display: flex; align-items: center; justify-content: space-between; gap: var(--space-2); padding: var(--space-2) var(--space-3); font-size: var(--font-size-sm); color: var(--color-text-secondary); border-radius: var(--radius-md); transition: color var(--transition-fast), background-color var(--transition-fast); }
.sidebar-cat-link:hover { color: var(--color-text); background: var(--glass-bg-hover); }
.sidebar-cat-link.is-active { color: var(--color-accent); background: var(--color-accent-subtle); font-weight: var(--font-weight-medium); }
.sidebar-cat-count { font-size: var(--font-size-xs); color: var(--color-text-muted); margin-left: auto; }
.sidebar-cat-children { padding-left: var(--space-3); margin-top: 2px; display: flex; flex-direction: column; gap: 2px; }
.sidebar-cat-link--child { font-size: var(--font-size-xs); }

/* WC Price Filter */
.widget_price_filter .ui-slider { position: relative; background: var(--color-border); height: 4px; border: none; border-radius: 2px; margin-block: var(--space-4); }
.widget_price_filter .ui-slider-range { position: absolute; height: 100%; top: 0; background: var(--color-accent); }
.widget_price_filter .ui-slider-handle { position: absolute; margin-left: -8px; background: var(--color-accent); border: 2px solid var(--color-bg); border-radius: var(--radius-full); width: 16px; height: 16px; top: -6px; cursor: pointer; outline: none; }
.widget_price_filter .price_label { font-size: var(--font-size-xs); color: var(--color-text-secondary); display: flex; justify-content: space-between; margin-bottom: var(--space-3); }
.widget_price_filter .from,
.widget_price_filter .to { color: var(--color-text); font-weight: var(--font-weight-medium); }
.widget_price_filter button { display: block; width: 100%; padding: var(--space-2) var(--space-3); background: var(--color-accent); color: #fff; border-radius: var(--radius-md); font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold); cursor: pointer; border: none; transition: background-color var(--transition-fast); }
.widget_price_filter button:hover { background: var(--color-accent-hover); }

/* ==========================================================================
   SHOP HEADER
   ========================================================================== */

.shop-header { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); margin-bottom: var(--space-6); padding-bottom: var(--space-4); border-bottom: 1px solid var(--color-border); }
.woocommerce-result-count { font-size: var(--font-size-sm); color: var(--color-text-muted); margin: 0; }
.woocommerce-ordering select { background: var(--glass-bg); border: 1px solid var(--color-border-strong); border-radius: var(--radius-md); color: var(--color-text); font-size: var(--font-size-sm); padding: var(--space-2) 2.5rem var(--space-2) var(--space-3); -webkit-appearance: none; appearance: none; cursor: pointer; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23ffffff60' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right .75rem center; }
/* El menu desplegable nativo se abre con fondo blanco (SO); sin esto las opciones quedan blanco sobre blanco */
.woocommerce-ordering select option { color: #111; background: #fff; }

/* ==========================================================================
   PRODUCTS GRID
   ========================================================================== */

.products-grid,
.featured-products__grid,
ul.products { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: var(--space-4); list-style: none; padding: 0; margin: 0; }

/* ==========================================================================
   PRODUCT CARD
   ========================================================================== */

.product-card { display: flex; flex-direction: column; width: 100%; max-width: 100%; box-sizing: border-box; background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: var(--radius-xl); overflow: hidden; transition: background-color var(--transition-base), border-color var(--transition-base), transform var(--transition-base), box-shadow var(--transition-base); }
.product-card:hover { background: var(--glass-bg-hover); border-color: rgba(255,255,255,.12); transform: translateY(-3px); box-shadow: var(--shadow-md); }
.product-card__inner { display: flex; flex-direction: column; flex: 1; text-decoration: none; color: inherit; }
.product-card__image { position: relative; width: 100% !important; aspect-ratio: 1/1 !important; background: #1a1a1a; overflow: hidden; padding: 0 !important; margin: 0 !important; }
.product-card__image img { width: 100% !important; height: 100% !important; object-fit: contain !important; object-position: center !important; padding: 0 !important; margin: 0 !important; transition: transform var(--transition-base); }
.product-card:hover .product-card__image img { transform: scale(1.04); }
.product-card__no-image {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, rgba(255,94,20,.06) 0%, rgba(255,255,255,.02) 100%);
    background-image:
        linear-gradient(135deg, rgba(255,94,20,.06) 0%, rgba(255,255,255,.02) 100%),
        radial-gradient(circle, rgba(255,255,255,.05) 1px, transparent 1px);
    background-size: 100% 100%, 18px 18px;
}
.product-card__no-image::after {
    content: '';
    display: block;
    width: 48px; height: 48px;
    border-radius: var(--radius-lg);
    background: var(--color-accent-subtle);
    border: 1px solid var(--color-border-accent);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23FF5E14' stroke-width='1.5'%3E%3Crect x='2' y='3' width='20' height='14' rx='2'/%3E%3Cpath d='M8 21h8M12 17v4'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 24px 24px;
}
.product-card__badge { position: absolute; top: var(--space-3); right: var(--space-3); }
.product-card__body { flex: 1; padding: var(--space-4); display: flex; flex-direction: column; gap: var(--space-2); }
.product-card__type { align-self: flex-start; }
.product-card__title { font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold); line-height: 1.35; color: var(--color-text); word-break: break-word; hyphens: auto; }
.product-card__pc-count { font-size: var(--font-size-xs); color: var(--color-text-muted); display: block; margin-top: 2px; font-weight: var(--font-weight-normal); }
.product-card__duracion { font-size: var(--font-size-xs); color: var(--color-text-muted); }
.product-card__price { margin-top: auto; padding-top: var(--space-2); }
.product-card__price .price { display: flex; flex-direction: column; gap: 1px; }
.product-card__price .price del { font-size: var(--font-size-xs); color: var(--color-text-muted); text-decoration: line-through; }
.product-card__price .price del .woocommerce-Price-amount { text-decoration: line-through; }
.product-card__price .price ins,
.product-card__price .price ins *,
.woocommerce ins, ins { text-decoration: none !important; }
.product-card__price ins .woocommerce-Price-amount,
.product-card__price > .woocommerce-Price-amount,
.product-card__price .price > .woocommerce-Price-amount { font-size: var(--font-size-xl); font-weight: var(--font-weight-extrabold); color: var(--color-accent); text-decoration: none !important; }
.product-card__footer { padding: var(--space-3) var(--space-4) var(--space-4); display: flex; flex-direction: column; align-items: stretch; gap: var(--space-2); width: 100%; box-sizing: border-box; }
.product-card__footer .btn,
.product-card__footer a { width: 100%; text-align: center; display: flex; align-items: center; justify-content: center; padding: var(--space-2) var(--space-4); border-radius: var(--radius-md); font-size: var(--font-size-sm); font-weight: var(--font-weight-semibold); transition: background-color var(--transition-fast), transform var(--transition-fast); text-decoration: none; }
.product-card__footer a.button:not(.added_to_cart),
.product-card__footer .btn:not(.added_to_cart) { background: var(--color-accent); color: #fff; }
.product-card__footer a.button:not(.added_to_cart):hover,
.product-card__footer .btn:not(.added_to_cart):hover { background: var(--color-accent-hover); transform: translateY(-1px); }
/* "Ver carrito" que aparece tras agregar */
.product-card__footer a.added_to_cart { background: transparent; color: var(--color-accent); border: 1px solid var(--color-border-accent); }
.product-card__footer a.added_to_cart:hover { background: var(--color-accent-subtle); transform: translateY(-1px); }

/* ==========================================================================
   CATEGORY HERO (branded)
   ========================================================================== */

.cat-hero { position: relative; overflow: hidden; margin-bottom: var(--space-8); padding: var(--space-8); background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: var(--radius-xl); backdrop-filter: var(--glass-blur); -webkit-backdrop-filter: var(--glass-blur); }
.cat-hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 60% 130% at 0% 0%, rgba(255,94,20,.16) 0%, transparent 58%); pointer-events: none; }
.cat-hero > * { position: relative; }
.cat-hero .sp-breadcrumb { margin-bottom: var(--space-5); }

.cat-hero__top { display: flex; align-items: center; gap: var(--space-5); flex-wrap: wrap; }
.cat-hero__icon { flex-shrink: 0; width: 60px; height: 60px; display: flex; align-items: center; justify-content: center; font-size: 1.75rem; line-height: 1; background: var(--color-accent-subtle); border: 1px solid var(--color-border-accent); border-radius: var(--radius-lg); }
.cat-hero__head { flex: 1; min-width: 0; }
.cat-hero__eyebrow { display: block; font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold); text-transform: uppercase; letter-spacing: .1em; color: var(--color-accent); margin-bottom: var(--space-1); }
.cat-hero__title { font-size: var(--font-size-4xl); font-weight: var(--font-weight-extrabold); letter-spacing: -.02em; line-height: 1.1; }
.cat-hero__count { flex-shrink: 0; align-self: center; }
.cat-hero__desc { color: var(--color-text-secondary); margin-top: var(--space-4); max-width: 620px; line-height: var(--line-height-relaxed); }

.cat-hero__benefits { display: flex; flex-wrap: wrap; gap: var(--space-3) var(--space-5); margin-top: var(--space-6); padding-top: var(--space-6); border-top: 1px solid var(--color-border); }
.cat-benefit { display: inline-flex; align-items: center; gap: var(--space-2); font-size: var(--font-size-sm); color: var(--color-text-secondary); }
.cat-benefit svg { flex-shrink: 0; width: 16px; height: 16px; color: var(--color-success); }

.cat-subcats { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-top: var(--space-6); }
.cat-subcat-pill { padding: var(--space-2) var(--space-4); background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: var(--radius-full); font-size: var(--font-size-sm); color: var(--color-text-secondary); transition: color var(--transition-fast), background-color var(--transition-fast), border-color var(--transition-fast); }
.cat-subcat-pill:hover { color: var(--color-accent); background: var(--color-accent-subtle); border-color: var(--color-border-accent); }

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

.single-product-page { padding-block: var(--space-8) var(--space-16); }
.sp-breadcrumb { display: flex; align-items: center; gap: var(--space-2); font-size: var(--font-size-sm); color: var(--color-text-muted); margin-bottom: var(--space-6); flex-wrap: wrap; }
.sp-breadcrumb a { color: var(--color-text-secondary); transition: color var(--transition-fast); }
.sp-breadcrumb a:hover { color: var(--color-accent); }

.single-product__wrap { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-10); padding: var(--space-8); margin-bottom: var(--space-8); }
.single-product__gallery { position: relative; }
.single-product__main-img { background: #1a1a1a; border-radius: var(--radius-lg); overflow: hidden; }
.single-product__main-img img { width: 100%; aspect-ratio: 1; object-fit: contain; padding: var(--space-6); border-radius: var(--radius-lg); }
.single-product__no-img { aspect-ratio: 1; display: flex; align-items: center; justify-content: center; font-size: 5rem; background: rgba(255,94,20,.05); border-radius: var(--radius-lg); }
.single-product__discount-badge { position: absolute; top: var(--space-4); right: var(--space-4); font-size: var(--font-size-sm); padding: var(--space-1) var(--space-3); }
.single-product__mini-trust { display: flex; flex-direction: column; gap: var(--space-2); margin-top: var(--space-5); padding: var(--space-4); background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: var(--radius-lg); }
.mini-trust-item { display: flex; align-items: center; gap: var(--space-2); font-size: var(--font-size-sm); color: var(--color-text-secondary); }
.mini-trust-item svg { color: var(--color-success); flex-shrink: 0; }

.single-product__info { display: flex; flex-direction: column; gap: var(--space-4); }
.sp-cat-link { font-size: var(--font-size-xs); font-weight: var(--font-weight-semibold); text-transform: uppercase; letter-spacing: .08em; color: var(--color-accent); }
.single-product__title { font-size: var(--font-size-3xl); font-weight: var(--font-weight-extrabold); line-height: 1.15; letter-spacing: -.02em; }
.sp-attributes { display: flex; flex-wrap: wrap; gap: var(--space-2); }

.sp-price .price { display: flex; flex-direction: column; gap: var(--space-1); }
.sp-price .price del { text-decoration: line-through; }
.sp-price .price del .woocommerce-Price-amount { font-size: var(--font-size-lg); color: var(--color-text-muted); font-weight: var(--font-weight-normal); text-decoration: line-through; }
.sp-price .price ins,
.sp-price .price ins * { text-decoration: none; }
.sp-price .price ins .woocommerce-Price-amount,
.sp-price .price > .woocommerce-Price-amount { font-size: var(--font-size-4xl); font-weight: var(--font-weight-extrabold); color: var(--color-accent); text-decoration: none; }
.sp-price__savings { font-size: var(--font-size-sm); color: var(--color-success); }

.sp-bacs-hint { display: flex; align-items: center; gap: var(--space-2); padding: var(--space-3) var(--space-4); background: var(--color-accent-subtle); border: 1px solid var(--color-border-accent); border-radius: var(--radius-md); font-size: var(--font-size-sm); color: var(--color-text-secondary); }
.sp-bacs-hint svg { color: var(--color-success); flex-shrink: 0; }
.sp-bacs-hint strong { color: var(--color-text); }

.sp-add-to-cart form.cart { display: flex; gap: var(--space-3); align-items: center; }
.sp-add-to-cart .quantity input[type=number] { width: 72px; background: var(--glass-bg); border: 1px solid var(--color-border-strong); border-radius: var(--radius-md); color: var(--color-text); padding: var(--space-3); text-align: center; font-size: var(--font-size-base); font-weight: var(--font-weight-semibold); }
.sp-add-to-cart .single_add_to_cart_button { flex: 1; background: var(--color-accent); color: #fff; border: none; border-radius: var(--radius-md); padding: var(--space-4) var(--space-6); font-size: var(--font-size-base); font-weight: var(--font-weight-semibold); cursor: pointer; transition: background-color var(--transition-fast), box-shadow var(--transition-fast); }
.sp-add-to-cart .single_add_to_cart_button:hover { background: var(--color-accent-hover); box-shadow: var(--shadow-accent); }

.sp-short-desc { padding: var(--space-4); background: var(--glass-bg); border: 1px solid var(--glass-border); border-radius: var(--radius-lg); font-size: var(--font-size-sm); color: var(--color-text-secondary); line-height: var(--line-height-relaxed); }
.sp-description { padding: var(--space-8); margin-bottom: var(--space-8); }
.sp-description h2 { font-size: var(--font-size-xl); margin-bottom: var(--space-5); }
.sp-description p { font-size: var(--font-size-sm); color: var(--color-text-secondary); }
.sp-related { margin-bottom: var(--space-8); }
.sp-related h2 { font-size: var(--font-size-xl); margin-bottom: var(--space-6); }

/* ==========================================================================
   PAGE STATE (busqueda vacia / 404)
   ========================================================================== */

.page-state { max-width: 560px; margin: var(--space-16) auto; padding: var(--space-10); text-align: center; }
.page-state--404 { margin-block: var(--space-20); }
.page-state__code { display: block; font-size: clamp(3rem, 12vw, 5rem); font-weight: var(--font-weight-extrabold); line-height: 1; letter-spacing: -.04em; color: var(--color-accent); margin-bottom: var(--space-4); }
.page-state__title { font-size: var(--font-size-2xl); font-weight: var(--font-weight-extrabold); margin-bottom: var(--space-3); }
.page-state__text { color: var(--color-text-secondary); line-height: var(--line-height-relaxed); margin-bottom: var(--space-8); }
.page-state__actions { display: flex; gap: var(--space-3); justify-content: center; flex-wrap: wrap; }

/* ==========================================================================
   PAGINATION
   ========================================================================== */

.woocommerce-pagination { margin-top: var(--space-8); }
.woocommerce-pagination ul { display: flex; gap: var(--space-2); justify-content: center; flex-wrap: wrap; }
.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span { display: flex; align-items: center; justify-content: center; min-width: 36px; height: 36px; border-radius: var(--radius-md); font-size: var(--font-size-sm); background: var(--glass-bg); border: 1px solid var(--glass-border); color: var(--color-text-secondary); transition: color var(--transition-fast), background-color var(--transition-fast); }
.woocommerce-pagination ul li a:hover { color: var(--color-text); background: var(--glass-bg-hover); }
.woocommerce-pagination ul li span.current { background: var(--color-accent); border-color: var(--color-accent); color: #fff; font-weight: var(--font-weight-semibold); }

/* ==========================================================================
   CART
   ========================================================================== */

.woocommerce-cart .emporio-main,
.woocommerce-checkout .emporio-main { padding-block: var(--space-10); }
table.shop_table { width: 100%; border-collapse: collapse; font-size: var(--font-size-sm); }
table.shop_table th { text-align: left; padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--color-border); color: var(--color-text-muted); font-weight: var(--font-weight-semibold); font-size: var(--font-size-xs); text-transform: uppercase; letter-spacing: .06em; }
table.shop_table td { padding: var(--space-4); border-bottom: 1px solid var(--color-border); vertical-align: middle; color: var(--color-text-secondary); }
table.shop_table .product-name a { color: var(--color-text); font-weight: var(--font-weight-medium); }
table.shop_table .product-name a:hover { color: var(--color-accent); }
table.shop_table .product-subtotal .woocommerce-Price-amount,
table.shop_table .product-price .woocommerce-Price-amount { color: var(--color-accent); font-weight: var(--font-weight-semibold); }
.cart_totals h2 { font-size: var(--font-size-xl); margin-bottom: var(--space-5); }
.cart_totals table tr th,
.cart_totals table tr td { padding: var(--space-3) 0; border-bottom: 1px solid var(--color-border); font-size: var(--font-size-sm); }
.cart_totals .order-total .woocommerce-Price-amount { font-size: var(--font-size-xl); font-weight: var(--font-weight-extrabold); color: var(--color-accent); }
.quantity input[type=number] { width: 64px; background: var(--glass-bg); border: 1px solid var(--color-border-strong); border-radius: var(--radius-md); color: var(--color-text); padding: var(--space-2); text-align: center; }
.product-remove a { color: var(--color-error) !important; font-size: var(--font-size-lg); text-decoration: none; }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

@media (max-width: 1023px) {
    .shop-layout { grid-template-columns: 1fr; }
    .shop-sidebar { position: static; display: none; }
    .single-product__wrap { grid-template-columns: 1fr; gap: var(--space-6); }
}
@media (max-width: 639px) {
    .products-grid, .featured-products__grid, ul.products { grid-template-columns: repeat(2, 1fr); gap: var(--space-3); }
    .product-card__image { aspect-ratio: 4/3 !important; }
    .cat-hero { padding: var(--space-6); }
    .cat-hero__title { font-size: var(--font-size-2xl); }
    .cat-hero__icon { width: 48px; height: 48px; font-size: 1.4rem; }
    .cat-hero__count { order: 3; }

    /* shop_table se aplica a la tabla de totales del carrito (woocommerce_cart_totals) */
    table.shop_table { width: 100%; }
}

/* ==========================================================================
   MEJORA 2 — CUOTAS MP + STOCK INDICATOR EN PRODUCT CARD
   ========================================================================== */

.product-card__cuotas {
    font-size: 11px;
    color: var(--color-success);
    font-weight: var(--font-weight-medium);
    display: flex;
    align-items: center;
    gap: 4px;
    margin-top: 2px;
}
.product-card__cuotas::before {
    content: '';
    display: inline-block;
    width: 14px;
    height: 14px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2322C55E' stroke-width='2'%3E%3Crect x='1' y='4' width='22' height='16' rx='2'/%3E%3Cline x1='1' y1='10' x2='23' y2='10'/%3E%3C/svg%3E");
    background-size: contain;
    background-repeat: no-repeat;
    flex-shrink: 0;
}

.product-card__stock {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 10px;
    color: var(--color-text-muted);
    margin-top: 4px;
}
.product-card__stock-dot {
    width: 6px;
    height: 6px;
    border-radius: var(--radius-full);
    background: var(--color-success);
    flex-shrink: 0;
}
.product-card__stock-dot--backorder { background: var(--color-warning, #f0ad37); }
.product-card__stock-dot--out { background: var(--color-error); }
.product-card__stock--backorder,
.product-card__stock--out { color: var(--color-text-muted); }
.product-card__stock--out { color: var(--color-error); }

/* BACS hint en card (descuento transferencia) */
.product-card__bacs-hint {
    display: flex;
    align-items: center;
    gap: 4px;
    font-size: 10px;
    color: var(--color-accent);
    font-weight: var(--font-weight-medium);
    margin-top: 3px;
}

/* SP cuotas en single product */
.sp-cuotas {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-3) var(--space-4);
    background: var(--color-success-subtle);
    border: 1px solid rgba(34,197,94,.2);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    color: var(--color-success);
    font-weight: var(--font-weight-medium);
}
.sp-cuotas svg { flex-shrink: 0; width: 16px; height: 16px; }

/* ==========================================================================
   WOOCOMMERCE NOTICES
   ========================================================================== */

.woocommerce-message,
.woocommerce-info,
.woocommerce-notice,
.woocommerce-error {
    background: var(--glass-bg);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    padding: var(--space-4);
    margin-bottom: var(--space-4);
    font-size: var(--font-size-sm);
    color: var(--color-text);
}
.woocommerce-message { border-color: var(--color-success); }
.woocommerce-info { border-color: var(--color-border-accent); }
.woocommerce-error { border-color: var(--color-error); }

/* ==========================================================================
   WIPE OUT WOOCOMMERCE IMAGE CROP & NATIVE PADDING HACKS
   ========================================================================== */

/* 1. Anular contenedores (forzar dimensiones lógicas sin cortes ni hacks de ratio)
   .product-card__image NO se incluye — ya tiene reglas propias en lineas 67-68
   que funcionan correctamente con display:block + overflow:hidden */
.woocommerce-LoopProduct-link { display: none !important; }
.product-image,
.wp-post-image-wrapper {
    height: auto !important;
    min-height: auto !important;
    max-height: 100% !important;
    padding-top: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative !important;
    overflow: visible !important;
}

/* 2. Forzar el contenedor principal de la imagen a un cuadrado perfecto
   .product-card__image NO se incluye — ya tiene aspect-ratio:1/1 en linea 67 */
.woocommerce-product-gallery__image,
.woocommerce-product-gallery__wrapper {
    aspect-ratio: 1/1 !important;
    width: 100% !important;
    background-color: transparent !important;
}

/* 3. Etiqueta img forzada a contener la imagen 100% sin recortar */
.product-card__image img,
.woocommerce-product-gallery__image img,
img.wp-post-image,
img.attachment-woocommerce_thumbnail,
img.attachment-woocommerce_single {
    width: 100% !important;
    height: 100% !important;
    max-height: 100% !important;
    max-width: 100% !important;
    object-fit: contain !important;
    object-position: center !important;
    padding: 0 !important;
    margin: 0 !important;
    position: static !important;
}

/* ==========================================================================
   MI CUENTA (WooCommerce My Account)
   ========================================================================== */

/* Navegacion como pestañas */
.woocommerce-account .woocommerce-MyAccount-navigation ul {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
    list-style: none;
    padding: 0 0 var(--space-5);
    margin: 0 0 var(--space-8);
    border-bottom: 1px solid var(--color-border);
}
.woocommerce-account .woocommerce-MyAccount-navigation li a {
    display: inline-flex;
    align-items: center;
    padding: var(--space-2) var(--space-4);
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-medium);
    color: var(--color-text-secondary);
    background: rgba(255, 255, 255, .03);
    border: 1px solid var(--color-border);
    transition: color var(--transition-fast), background-color var(--transition-fast), border-color var(--transition-fast);
}
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover { color: var(--color-text); background: var(--glass-bg-hover); }
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a { background: var(--color-accent); color: #fff; border-color: var(--color-accent); }

/* Contenido */
.woocommerce-account .woocommerce-MyAccount-content { font-size: var(--font-size-sm); color: var(--color-text-secondary); }
.woocommerce-account .woocommerce-MyAccount-content p { margin-bottom: var(--space-4); line-height: var(--line-height-relaxed); }
.woocommerce-account .woocommerce a:not(.button) { color: var(--color-accent); }
.woocommerce-account .woocommerce-MyAccount-content mark { background: var(--color-accent-subtle); color: var(--color-text); padding: 0 4px; border-radius: var(--radius-sm); }

/* Login / Registro */
.woocommerce-account #customer_login.col2-set { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-8); }
.woocommerce-account #customer_login h2 { font-size: var(--font-size-xl); margin-bottom: var(--space-5); }
.woocommerce-account .woocommerce-form-login,
.woocommerce-account .woocommerce-form-register {
    background: rgba(255, 255, 255, .03);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
}

/* Formularios (login, registro, cuenta, direcciones) */
.woocommerce-account .form-row { margin-bottom: var(--space-4); display: flex; flex-direction: column; }
.woocommerce-account label { font-size: var(--font-size-sm); font-weight: var(--font-weight-medium); color: var(--color-text-secondary); margin-bottom: var(--space-2); }
.woocommerce-account .woocommerce-form__label-for-checkbox { display: flex; flex-direction: row; align-items: center; gap: var(--space-2); cursor: pointer; }
.woocommerce-account .woocommerce-form__label-for-checkbox input { width: auto; }

/* Nombre/apellido lado a lado (detalles de la cuenta y direcciones) */
.woocommerce-account .woocommerce-EditAccountForm,
.woocommerce-account .woocommerce-address-fields__field-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-4) var(--space-5);
}
.woocommerce-account .woocommerce-EditAccountForm > p.form-row,
.woocommerce-account .woocommerce-address-fields__field-wrapper > p.form-row { margin-bottom: 0; }
.woocommerce-account .form-row-first { grid-column: 1; }
.woocommerce-account .form-row-last { grid-column: 2; }
.woocommerce-account .woocommerce-EditAccountForm > p.form-row:not(.form-row-first):not(.form-row-last),
.woocommerce-account .woocommerce-EditAccountForm > fieldset,
.woocommerce-account .woocommerce-address-fields__field-wrapper > p.form-row:not(.form-row-first):not(.form-row-last) { grid-column: 1 / -1; }
.woocommerce-account input[type=text],
.woocommerce-account input[type=email],
.woocommerce-account input[type=password],
.woocommerce-account input[type=tel],
.woocommerce-account select {
    width: 100%;
    padding: var(--space-3) var(--space-4);
    background: rgba(255, 255, 255, .06);
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-md);
    color: var(--color-text);
    font-size: var(--font-size-base);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.woocommerce-account input:focus,
.woocommerce-account select:focus { border-color: var(--color-accent); box-shadow: 0 0 0 3px var(--color-accent-glow); outline: none; }
.woocommerce-account .woocommerce-form-login__rememberme { font-size: var(--font-size-sm); color: var(--color-text-secondary); }

/* Botones */
.woocommerce-account .button,
.woocommerce-account button[type=submit] {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--space-3) var(--space-5);
    background: var(--color-accent);
    color: #fff;
    border: none;
    border-radius: var(--radius-md);
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-semibold);
    cursor: pointer;
    transition: background-color var(--transition-fast);
    text-decoration: none;
}
.woocommerce-account .button:hover,
.woocommerce-account button[type=submit]:hover { background: var(--color-accent-hover); color: #fff; }

/* Tabla de pedidos */
.woocommerce-account .woocommerce-orders-table { width: 100%; border-collapse: collapse; font-size: var(--font-size-sm); }
.woocommerce-account .woocommerce-orders-table th { text-align: left; padding: var(--space-3); color: var(--color-text-muted); font-size: var(--font-size-xs); text-transform: uppercase; letter-spacing: .06em; border-bottom: 1px solid var(--color-border); }
.woocommerce-account .woocommerce-orders-table td { padding: var(--space-3); border-bottom: 1px solid var(--color-border); color: var(--color-text-secondary); vertical-align: middle; }
.woocommerce-account .woocommerce-orders-table .button { padding: var(--space-1) var(--space-3); font-size: var(--font-size-xs); }

/* Direcciones */
.woocommerce-account .woocommerce-Addresses { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); margin-top: var(--space-4); }
.woocommerce-account .woocommerce-Address { background: rgba(255, 255, 255, .03); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-5); }
.woocommerce-account .woocommerce-Address-title { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); margin-bottom: var(--space-3); }
.woocommerce-account .woocommerce-Address-title h3 { font-size: var(--font-size-base); }
.woocommerce-account .woocommerce-Address address { font-style: normal; color: var(--color-text-secondary); line-height: var(--line-height-relaxed); }

@media (max-width: 639px) {
    .woocommerce-account #customer_login.col2-set,
    .woocommerce-account .woocommerce-Addresses,
    .woocommerce-account .woocommerce-EditAccountForm,
    .woocommerce-account .woocommerce-address-fields__field-wrapper { grid-template-columns: 1fr; }
    .woocommerce-account .form-row-first,
    .woocommerce-account .form-row-last { grid-column: 1; }
    .woocommerce-account .woocommerce-orders-table { display: block; overflow-x: auto; }
}
