/**
 * WooCommerce overrides for Monte UY
 *
 * Maps WooCommerce defaults to Monte Hierros structure.
 *
 * @package monte-uy
 */

/* Nav menu - ul as flex child */
.nav-menu ul.nav-menu-list {
	display: contents;
	list-style: none;
	margin: 0;
	padding: 0;
}

.nav-menu .nav-menu-list li {
	display: contents;
}

/* Cart count badge on header icon */
.header-actions .icon-button {
	position: relative;
}

.header-actions .cart-count {
	position: absolute;
	top: -4px;
	right: -4px;
	background: var(--accent-sage);
	color: var(--bg-primary);
	font-size: 0.65rem;
	font-weight: 600;
	min-width: 18px;
	height: 18px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
}

/* Product loop — grid real (WooCommerce fuerza width % + float en li; rompe el layout) */
.woocommerce ul.products.products-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--space-xl);
	list-style: none;
	margin: 0;
	padding: 0;
	width: 100%;
	clear: both;
}

.woocommerce ul.products.products-grid::before,
.woocommerce ul.products.products-grid::after {
	display: none !important;
	content: none !important;
}

.woocommerce ul.products.products-grid li.product {
	list-style: none;
	width: 100% !important;
	max-width: none !important;
	float: none !important;
	clear: none !important;
	margin: 0 !important;
	min-width: 0;
}

/*
 * Tarjetas del catálogo / relacionados (li.product.type-product.product-card)
 * Mismo criterio que .product-card en producto.html: paddings, título, precio sin subrayado, hover “Ver detalle”.
 */
.woocommerce ul.products li.product.product-card {
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
	padding: var(--space-md);
	border-radius: 8px;
	border: 1px solid transparent;
	box-sizing: border-box;
	transition:
		border-color var(--transition-base),
		background var(--transition-base),
		transform var(--transition-base),
		box-shadow var(--transition-base);
}

.woocommerce ul.products li.product.product-card:hover {
	border-color: var(--border-color);
	background: rgba(26, 26, 26, 0.5);
	transform: translateY(-4px);
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.25);
}

.woocommerce ul.products li.product.product-card .product-image {
	flex-shrink: 0;
	margin-bottom: var(--space-sm);
	text-decoration: none;
	border: none;
	box-shadow: none;
}

.woocommerce ul.products li.product.product-card .product-info {
	display: flex;
	flex-direction: column;
	gap: var(--space-xs);
	width: 100%;
	min-width: 0;
	flex: 1;
}

.woocommerce ul.products li.product.product-card .product-category {
	margin: 0;
	color: var(--accent-sage);
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
}

.woocommerce ul.products li.product.product-card .product-title {
	font-family: var(--font-serif);
	font-size: 1.3rem;
	font-weight: 600;
	line-height: 1.28;
	margin: 0;
	padding: 0;
	color: var(--text-primary);
}

.woocommerce ul.products li.product.product-card .product-title a {
	color: inherit;
	text-decoration: none !important;
	border: none;
	box-shadow: none;
}

.woocommerce ul.products li.product.product-card .product-price {
	margin: 0;
	line-height: 1.45;
}

.woocommerce ul.products li.product.product-card .product-price .price {
	display: inline;
	color: var(--text-secondary);
	font-size: 1.1rem;
	font-weight: 500;
	text-decoration: none !important;
}

.woocommerce ul.products li.product.product-card .product-price a {
	color: inherit;
	text-decoration: none !important;
	border: none;
	box-shadow: none;
}

/* Oferta: tachado del precio anterior, sin subrayado de enlace */
.woocommerce ul.products li.product.product-card .product-price del {
	opacity: 0.7;
	text-decoration: line-through;
	text-decoration-thickness: 1px;
}

.woocommerce ul.products li.product.product-card .product-price ins {
	text-decoration: none !important;
	font-weight: 600;
}

.woocommerce ul.products li.product.product-card .product-link {
	display: inline-block;
	align-self: flex-start;
	margin-top: var(--space-sm);
	text-decoration: none !important;
	border: none;
	box-shadow: none;
	color: var(--accent-sage);
	font-size: 0.9rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	opacity: 0.8;
	transition:
		color var(--transition-fast),
		opacity var(--transition-fast),
		transform var(--transition-fast);
}

.woocommerce ul.products li.product.product-card:hover .product-link {
	opacity: 1;
	color: var(--accent-light);
}

.woocommerce ul.products li.product.product-card .product-link:hover,
.woocommerce ul.products li.product.product-card .product-link:focus-visible {
	color: var(--accent-rust);
	opacity: 1;
	transform: translateX(3px);
}

.woocommerce ul.products li.product.product-card .product-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--transition-slow);
}

.woocommerce ul.products li.product.product-card:hover .product-image img {
	transform: scale(1.06);
}

/* Botón añadir al carrito en listados / relacionados */
.woocommerce ul.products.products-grid li.product .button,
.woocommerce ul.products.products-grid li.product a.add_to_cart_button,
.woocommerce ul.products.products-grid li.product .added_to_cart {
	width: 100%;
	max-width: 100%;
	box-sizing: border-box;
	white-space: normal;
	line-height: 1.35;
	text-align: center;
}

@media (max-width: 900px) {
	.woocommerce ul.products.products-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 600px) {
	.woocommerce ul.products.products-grid {
		grid-template-columns: 1fr;
	}
}

/* ---------- Single product (producto.html) ---------- */
.product-single-wrapper {
	max-width: 100%;
}

.product-single .product-single-inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-2xl);
	align-items: start;
	padding-bottom: var(--space-lg);
}

@media (max-width: 768px) {
	.product-single .product-single-inner {
		grid-template-columns: 1fr;
	}
}

/* Ocultar botón lupa / zoom de WooCommerce (por si el JS lo inserta) */
.woocommerce-product-gallery__trigger,
.monte-product-gallery .woocommerce-product-gallery__trigger {
	display: none !important;
}

/* Galería Monte + WC */
.product-gallery .monte-gallery-layout {
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
}

.product-gallery .product-gallery-main {
	position: relative;
	aspect-ratio: 4/5;
	overflow: hidden;
	border-radius: 6px;
	background: var(--bg-secondary);
	margin-bottom: 0;
}

.product-gallery .product-gallery-main .woocommerce-product-gallery__image,
.product-gallery .product-gallery-main .woocommerce-product-gallery__image--placeholder {
	width: 100%;
	height: 100%;
	margin: 0;
}

.product-gallery .product-gallery-main .woocommerce-product-gallery__image a {
	display: block;
	width: 100%;
	height: 100%;
}

.product-gallery .product-gallery-main img,
.product-gallery .product-gallery-main .wp-post-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.product-gallery .product-gallery-thumbs {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
	margin-top: var(--space-sm);
}

.product-gallery .product-gallery-thumbs .thumb {
	padding: 0;
	border: 2px solid transparent;
	border-radius: 4px;
	overflow: hidden;
	background: var(--bg-secondary);
	cursor: pointer;
	opacity: 0.75;
	transition: opacity var(--transition-fast), border-color var(--transition-fast);
	line-height: 0;
}

.product-gallery .product-gallery-thumbs .thumb:hover,
.product-gallery .product-gallery-thumbs .thumb.is-active,
.product-gallery .product-gallery-thumbs .thumb.active {
	opacity: 1;
	border-color: var(--accent-sage);
}

.product-gallery .product-gallery-thumbs .thumb img {
	width: 96px;
	height: 96px;
	max-width: 100%;
	object-fit: cover;
	display: block;
}

/* Miniaturas: todas visibles (varias filas si hace falta) */
.product-gallery .product-gallery-thumbs {
	align-items: flex-start;
	justify-content: flex-start;
}

/* Resumen / detalles */
.product-details .summary {
	border: none;
	padding: 0;
	margin: 0;
}

.product-details .product_title,
.product-details .product-single-title {
	font-family: var(--font-serif);
	font-size: clamp(2rem, 3vw, 2.5rem);
	font-weight: 400;
	margin-bottom: var(--space-sm);
}

.product-details .price,
.product-details .product-single-price {
	font-size: 1.5rem;
	font-weight: 600;
	color: var(--accent-sage);
	margin-bottom: var(--space-lg);
}

.product-details .woocommerce-product-details__short-description,
.product-details .product-single-desc {
	color: var(--text-secondary);
	line-height: 1.8;
	margin-bottom: var(--space-lg);
}

/* Variaciones: select estilo Monte */
.product-details .monte-variations {
	display: flex;
	flex-direction: column;
	gap: 0;
	margin-bottom: var(--space-lg);
}

.product-details .monte-variations .variant-group {
	margin-bottom: var(--space-md);
	margin-right: 0;
}

.product-details .monte-variation-select,
.product-details .variations select {
	width: 100%;
	max-width: 320px;
	padding: var(--space-sm) var(--space-md);
	background: var(--bg-secondary);
	border: 2px solid var(--border-color);
	border-radius: 4px;
	color: var(--text-primary);
	font-size: 0.9rem;
	cursor: pointer;
	appearance: auto;
}

.product-details .variant-options .reset_variations {
	display: inline-block;
	margin-top: var(--space-sm);
	font-size: 0.85rem;
	color: var(--accent-sage);
	text-decoration: underline;
}

/* Cantidad + Añadir al carrito */
.product-details .product-actions,
.product-details .monte-simple-cart,
.product-details .monte-variation-cart {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--space-md);
	margin-bottom: var(--space-xl);
	margin-top: var(--space-md);
}

.product-details .product-actions .quantity,
.product-details .monte-variation-cart .quantity {
	display: none;
}

.product-details .product-actions .quantity input.qty,
.product-details .monte-variation-cart .quantity input.qty {
	width: 70px;
	padding: var(--space-sm);
	background: var(--bg-secondary);
	border: 1px solid var(--border-color);
	border-radius: 4px;
	color: var(--text-primary);
	text-align: center;
	font-size: 1rem;
}

/* Botón WC + clases .btn (anula estilos por defecto del plugin) */
body.single-product .product-details button.single_add_to_cart_button,
body.single-product .product-details .single_add_to_cart_button.button.alt {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: var(--space-sm) var(--space-xl);
	min-height: 48px;
	font-size: 0.95rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	border-radius: 6px;
	border: 2px solid var(--accent-sage);
	background-color: var(--accent-sage);
	color: var(--bg-primary);
	cursor: pointer;
	transition: all var(--transition-base);
	line-height: 1.2;
}

body.single-product .product-details button.single_add_to_cart_button:hover,
body.single-product .product-details .single_add_to_cart_button.button.alt:hover {
	background-color: var(--accent-sage-light);
	border-color: var(--accent-sage-light);
	transform: translateY(-2px);
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
	color: var(--bg-primary);
}

.product-details p.stock {
	margin-bottom: var(--space-md);
	font-size: 0.9rem;
}

/* Detalle de la pieza en columna de resumen (encima de envío) */
.product-details .monte-product-extended-summary.product-extended {
	max-width: none;
	margin: 0;
	padding: 0;
}

.product-details .monte-product-extended-summary {
	margin-top: var(--space-lg);
	padding-top: var(--space-lg);
	border-top: 1px solid var(--border-color);
}

.product-details .monte-product-extended-summary .product-extended-inner {
	max-width: none;
	padding-top: 0;
	border-top: none;
}

/* Bloques envío / especificaciones dentro del resumen */
.product-details .monte-shipping-block,
.product-details .product-specs {
	margin-top: var(--space-lg);
	padding-top: var(--space-lg);
	border-top: 1px solid var(--border-color);
}

.product-details .product-specs-title {
	font-family: var(--font-serif);
	font-size: 1.1rem;
	margin-bottom: var(--space-md);
}

/* Descripción larga (detalle pieza) */
.product-single .product-long-desc {
	color: var(--text-secondary);
	line-height: 1.8;
}

.product-single .product-long-desc p {
	margin-bottom: var(--space-md);
}

/* Relacionados — mismo criterio visual que producto.html (section-header + .products-grid) */
.product-related.related.products {
	margin-top: var(--space-3xl);
	padding-top: var(--space-2xl);
	border-top: 1px solid var(--border-color);
	max-width: 1400px;
	margin-left: auto;
	margin-right: auto;
	padding-left: var(--space-lg);
	padding-right: var(--space-lg);
	box-sizing: border-box;
}

/* Cabecera: hereda .section-header global (centrado, tipografía grande) */
.product-related .section-header {
	text-align: center;
	margin-bottom: var(--space-3xl);
}

.product-related .section-header .section-label {
	display: inline-block;
	letter-spacing: 0.25em;
	font-weight: 600;
}

.product-related .section-header h2 {
	font-size: clamp(2rem, 4vw, 2.75rem);
	font-weight: 700;
	letter-spacing: -0.01em;
}

/* Contenedor tipo producto.html: grid en el div; el <ul> no compite con el layout WC */
.product-related .monte-related-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--space-xl);
	width: 100%;
}

.product-related .monte-related-grid ul.products.products-grid {
	display: contents;
	margin: 0;
	padding: 0;
	list-style: none;
}

.product-related .monte-related-grid ul.products.products-grid::before,
.product-related .monte-related-grid ul.products.products-grid::after {
	display: none !important;
	content: none !important;
}

@media (max-width: 900px) {
	.product-related .monte-related-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 600px) {
	.product-related .monte-related-grid {
		grid-template-columns: 1fr;
	}
}

/* Up-sells: mismo criterio que relacionados */
.upsells.products {
	margin-top: var(--space-3xl);
	padding-top: var(--space-2xl);
	border-top: 1px solid var(--border-color);
}

.upsells.products > h2 {
	font-family: var(--font-serif);
	font-size: clamp(1.5rem, 2.5vw, 2rem);
	margin-bottom: var(--space-xl);
}

.upsells.products ul.products.products-grid {
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

/* Breadcrumb */
.woocommerce-breadcrumb {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0;
	font-size: 0.8rem;
	color: var(--text-muted);
	margin-bottom: var(--space-lg);
	padding: var(--space-2xl) var(--space-lg) 0;
	max-width: 1400px;
	margin-left: auto;
	margin-right: auto;
}

.woocommerce-breadcrumb a {
	color: var(--text-secondary);
	text-decoration: none;
	transition: color var(--transition-fast);
}

.woocommerce-breadcrumb a:hover {
	color: var(--accent-sage);
}

.woocommerce-breadcrumb .breadcrumb-sep,
.woocommerce-breadcrumb .separator {
	margin: 0 var(--space-xs);
	opacity: 0.6;
}

/* Cart summary / collaterals */
.cart-summary .cart_totals {
	background: var(--bg-secondary);
	border: 1px solid var(--border-color);
	border-radius: 8px;
	padding: var(--space-lg);
	margin-bottom: var(--space-lg);
}

.cart-summary .cart_totals h2,
.cart-summary .cart-summary-title {
	font-family: var(--font-serif);
	font-size: 1.25rem;
	margin-bottom: var(--space-lg);
}

.cart-summary .shop_table {
	border: none;
	margin: 0;
}

.cart-summary .shop_table th,
.cart-summary .shop_table td {
	border: none;
	padding: var(--space-sm) 0;
	vertical-align: top;
}

.cart-summary .shop_table .order-total th,
.cart-summary .shop_table .order-total td {
	font-size: 1.2rem;
	font-weight: 600;
	padding-top: var(--space-md);
	border-top: 1px solid var(--border-color);
}

.cart-summary .btn-block {
	display: block;
	width: 100%;
	text-align: center;
	margin-bottom: var(--space-sm);
}

/* Quantity input - Monte qty-input */
.cart-item-qty .quantity,
.cart-item-qty .qty-input {
	width: 60px;
	padding: var(--space-xs) var(--space-sm);
	text-align: center;
	background: var(--bg-secondary);
	border: 1px solid var(--border-color);
	border-radius: 4px;
	color: var(--text-primary);
	font-size: 0.95rem;
}

.cart-item-qty input.qty-input,
.cart-item-qty input.qty {
	width: 60px;
	padding: var(--space-xs) var(--space-sm);
}

/* WooCommerce messages */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	padding: var(--space-md) var(--space-lg);
	margin-bottom: var(--space-lg);
	border-radius: 8px;
	border-left: 4px solid var(--accent-sage);
	background: var(--bg-secondary);
}

.woocommerce-error {
	border-left-color: #c0392b;
}

.woocommerce-info {
	border-left-color: var(--text-muted);
}
