/*
 * WOOCOMMERCE — plantillas del tema (content-product.php) + capa de
 * tokens sobre el resto de plantillas WC. Solo se encola en tienda.
 */

/* ---- Botones WC → sistema del tema -------------------------------- */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce-page .checkout-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	padding: var(--space-2) var(--space-5);
	border-radius: var(--radius-sm);
	font-weight: var(--weight-semibold);
	background-color: var(--color-primary);
	color: var(--color-on-primary);
	transition: background-color var(--duration-fast) var(--ease-out);
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
	background-color: var(--color-primary-hover);
	color: var(--color-on-primary);
}

.woocommerce a.button.disabled,
.woocommerce button.button:disabled {
	opacity: 0.5;
}

/* ---- Grid del loop: nuestra card, nuestra grid ----------------------- */
.woocommerce ul.products {
	display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(min(16rem, 100%), 1fr));
	gap: var(--space-5);
	margin: 0;
	padding: 0;
	list-style: none;
	container-type: inline-size;
}

.woocommerce ul.products li.product.card {
	width: auto;
	float: none;
	margin: 0;
}

.woocommerce ul.products li.product .card__media {
	position: relative;
	display: block;
}

.woocommerce ul.products li.product .card__media img {
	width: 100%;
	aspect-ratio: 1;
	object-fit: cover;
	margin: 0;
}

.card__price {
	font-weight: var(--weight-bold);
	color: var(--color-primary);
}

.card__price del {
	color: var(--color-ink-soft);
	font-weight: var(--weight-regular);
	margin-inline-end: var(--space-2);
}

.card__price ins {
	text-decoration: none;
}

/* El overlay de la card no debe tapar el botón de compra. */
.card__actions {
	position: relative;
	z-index: 1;
}

.card__actions .added_to_cart {
	margin-inline-start: var(--space-3);
	font-size: var(--text-sm);
}

/* Ordenación y contador de resultados */
.woocommerce .woocommerce-result-count {
	color: var(--color-ink-soft);
	font-size: var(--text-sm);
}

.woocommerce .woocommerce-ordering select {
	width: auto;
	min-height: 40px;
}

.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering {
	margin-block-end: var(--space-5);
}

/* ---- Badge de oferta -------------------------------------------------- */
.woocommerce span.onsale {
	position: absolute;
	inset-block-start: var(--space-3);
	inset-inline-start: var(--space-3);
	z-index: 1;
	background-color: var(--color-accent);
	color: var(--color-on-accent);
	border-radius: 99px;
	padding: var(--space-1) var(--space-3);
	min-height: 0;
	min-width: 0;
	line-height: var(--leading-base);
	font-weight: var(--weight-semibold);
}

/* ---- Ficha de producto --------------------------------------------------- */
.woocommerce div.product .woocommerce-product-gallery img {
	border-radius: var(--radius-lg);
}

.woocommerce div.product .product_title {
	font-size: var(--text-2xl);
}

.woocommerce div.product p.price {
	color: var(--color-primary);
	font-weight: var(--weight-bold);
	font-size: var(--text-xl);
}

.woocommerce div.product form.cart {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-3);
	align-items: center;
	margin-block: var(--space-5);
}

.woocommerce div.product form.cart div.quantity .qty {
	width: 5rem;
	min-height: 44px;
	text-align: center;
}

.woocommerce div.product .product_meta {
	color: var(--color-ink-soft);
	font-size: var(--text-sm);
}

/* Tabs de producto → look de tabs del tema */
.woocommerce div.product .woocommerce-tabs ul.tabs {
	display: flex;
	gap: var(--space-1);
	padding: 0;
	margin: 0 0 var(--space-5);
	border-block-end: 1px solid var(--color-line);
	overflow: visible;
}

.woocommerce div.product .woocommerce-tabs ul.tabs::before,
.woocommerce div.product .woocommerce-tabs ul.tabs::after,
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after {
	display: none;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
	background: none;
	border: none;
	border-radius: 0;
	margin: 0;
	padding: 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	padding: var(--space-3) var(--space-4);
	font-weight: var(--weight-medium);
	color: var(--color-ink-soft);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active {
	position: relative;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
	color: var(--color-ink);
	font-weight: var(--weight-semibold);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li.active::after {
	content: '';
	display: block;
	position: absolute;
	inset-inline: var(--space-4);
	inset-block-end: -1px;
	height: 2px;
	background-color: var(--color-accent);
}

.woocommerce div.product .related.products > h2,
.woocommerce div.product .woocommerce-tabs .panel > h2 {
	font-size: var(--text-xl);
	margin-block-end: var(--space-5);
}

/* Valoraciones */
.woocommerce .star-rating span::before,
.woocommerce p.stars a {
	color: var(--color-accent);
}

/* ---- Carrito y checkout ----------------------------------------------------- */
.woocommerce table.shop_table {
	border: 1px solid var(--color-line);
	border-radius: var(--radius-md);
	border-collapse: separate;
	border-spacing: 0;
}

.woocommerce table.shop_table th,
.woocommerce table.shop_table td {
	border-block-start: none;
	border-inline: none;
	border-block-end: 1px solid var(--color-line);
	padding: var(--space-3) var(--space-4);
}

.woocommerce table.shop_table tr:last-child td {
	border-block-end: none;
}

.woocommerce-cart table.cart img {
	width: 64px;
	border-radius: var(--radius-sm);
}

.woocommerce-cart table.cart td.actions .coupon .input-text {
	width: 12rem;
	min-height: 44px;
}

.woocommerce .cart_totals h2,
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout .woocommerce-billing-fields > h3 {
	font-size: var(--text-xl);
}

.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	min-height: 44px;
	padding: var(--space-2) var(--space-3);
	border: 1.5px solid var(--color-line);
	border-radius: var(--radius-sm);
	background-color: var(--color-base);
	color: var(--color-ink);
}

.woocommerce form .form-row.woocommerce-invalid input.input-text {
	border-color: var(--color-error);
}

#add_payment_method #payment,
.woocommerce-cart #payment,
.woocommerce-checkout #payment {
	background-color: var(--color-surface);
	border-radius: var(--radius-md);
}

/* ---- Avisos --------------------------------------------------------------------- */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	border-top-color: var(--color-primary);
	background-color: var(--color-surface);
	border-radius: var(--radius-sm);
	color: var(--color-ink);
}

.woocommerce-error {
	border-top-color: var(--color-error);
}

.woocommerce-message::before,
.woocommerce-info::before {
	color: var(--color-primary);
}

.woocommerce-error::before {
	color: var(--color-error);
}

/* ---- Breadcrumb WC ----------------------------------------------------------------- */
.woocommerce .woocommerce-breadcrumb {
	color: var(--color-ink-soft);
	font-size: var(--text-sm);
	margin-block-end: var(--space-5);
}

.woocommerce .woocommerce-breadcrumb a {
	color: var(--color-ink-soft);
}
