/* ==========================================================================
   RN.MATES — WooCommerce
   Estilos de tienda (archive), toolbar, grilla, sale flash, paginación,
   breadcrumbs, selector de cantidad y DRAWER mini-cart off-canvas.
   Reutiliza tokens y clases rn-* de theme.css. NO modifica theme.css.
   ========================================================================== */

/* ============================ 1. WRAPPER TIENDA ======================== */
/* #main lo abre header.php; acá solo va el wrapper interno del shop. */
.rn-shop__inner { display: block; }
.rn-shop__main { width: 100%; }

/* Quitar listas/estilos heredados de WooCommerce que rompen la grilla. */
.rn-shop ul.products,
.rn-shop .products {
	list-style: none;
	margin: 0;
	padding: 0;
}

/* ============================ 2. HEADER DE TIENDA ====================== */
.rn-shop-header {
	margin-bottom: clamp(1.5rem, 4vw, 2.5rem);
	max-width: 70ch;
}
.rn-shop-header__title {
	font-size: var(--fs-h1);
	margin-bottom: var(--sp-3);
}
.rn-shop-header__desc {
	color: var(--c-tinta-2);
	font-size: 1.05rem;
}
.rn-shop-header__desc p { margin: 0; }
.rn-shop-header__desc p + p { margin-top: var(--sp-3); }

/* ============================ 3. TOOLBAR (result + ordering) =========== */
.rn-shop-toolbar {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--sp-4);
	padding-bottom: var(--sp-4);
	margin-bottom: clamp(1.5rem, 3vw, 2rem);
	border-bottom: 1px solid var(--c-linea);
}
.rn-result-count {
	margin: 0;
	font-size: var(--fs-sm);
	color: var(--c-tinta-3);
}
.rn-orderby { margin: 0; }
.rn-orderby__select {
	min-width: 220px;
	padding-right: 2.4rem;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235a5043' stroke-width='1.75' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6l6 -6'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 0.9rem center;
	background-size: 16px;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

/* Notices de WooCommerce dentro de la toolbar (mensajes ajax, cupones, etc.) */
.rn-shop-toolbar .woocommerce-message,
.rn-shop-toolbar .woocommerce-info,
.rn-shop-toolbar .woocommerce-error {
	flex: 1 0 100%;
	margin: 0 0 var(--sp-2);
}

/* ============================ 4. GRILLA DE PRODUCTOS =================== */
/* Reutiliza .rn-grid--4 / .rn-product de theme.css. WooCommerce imprime
   <ul class="products columns-4"> en el loop; lo convertimos en grilla. */
.rn-shop ul.products,
.rn-shop .products.columns-1,
.rn-shop .products.columns-2,
.rn-shop .products.columns-3,
.rn-shop .products.columns-4,
.rn-shop .products.columns-5,
.rn-shop .products.columns-6 {
	display: grid;
	gap: clamp(1rem, 2.5vw, 1.75rem);
	grid-template-columns: repeat(auto-fill, minmax(210px, 1fr));
}
.rn-shop ul.products > li,
.rn-shop .products > li {
	margin: 0;
	width: auto;
	float: none;
	list-style: none;
}

/* La tarjeta .rn-product ya viene estilada por theme.css; acá solo
   garantizamos que el enlace de imagen no agregue subrayado ni bordes. */
.rn-product__media-link {
	display: block;
	width: 100%;
	height: 100%;
}
.rn-product__media-link:focus-visible {
	outline-offset: -3px;
}
.rn-product .rn-rating__count { margin-left: 0.15rem; }

/* Estrella vacía del rating de WooCommerce (wc_get_rating_html usa .star-rating). */
.rn-product .star-rating {
	font-size: 0.9rem;
	color: var(--c-acento);
}

/* Botón add-to-cart "added"/loading: respeta el look del design system. */
.rn-product__foot .button.loading {
	opacity: 0.75;
	pointer-events: none;
}
.rn-product__foot .added_to_cart {
	display: inline-flex;
	margin-top: var(--sp-2);
	font-size: var(--fs-xs);
	color: var(--c-acento-700);
}

/* ============================ 5. SALE FLASH ============================ */
/* El sale-flash sale como <span class="onsale rn-badge rn-badge--sale">. El CSS
   por defecto de WooCommerce posiciona `span.onsale` en `absolute` con su propio
   estilo y GANA por especificidad (.woocommerce ul.products li.product .onsale),
   sacándolo del flujo: el "-15%" se montaba ENCIMA del badge "Nuevo".
   Dentro de la tarjeta lo forzamos a fluir en .rn-product__flags (columna flex)
   y a verse igual que los demás badges (.rn-badge--sale). !important para
   superar los selectores largos de WC. (El badge del producto individual usa
   .rn-single__sale y queda fuera de este scope.) */
.rn-product__flags .onsale {
	position: static !important;
	inset: auto !important;
	margin: 0 !important;
	min-width: 0 !important;
	min-height: 0 !important;
	width: auto !important;
	height: auto !important;
	display: inline-flex !important;
	align-items: center;
	padding: 0.3rem 0.7rem !important;
	font-size: var(--fs-xs) !important;
	font-weight: 500 !important;
	line-height: 1 !important;
	border-radius: var(--r-pill) !important;
	background: var(--c-acento-50) !important;
	color: var(--c-acento-700) !important;
	text-transform: uppercase;
}

/* ============================ 6. BREADCRUMBS =========================== */
/* Clases .rn-breadcrumbs del helper centralizado (inc/template-tags.php) y
   del filtro woocommerce_breadcrumb_defaults (inc/woocommerce.php). El rastro
   se muestra a ancho propio, por encima de la grilla. */
.rn-breadcrumbs {
	font-size: var(--fs-sm);
	color: var(--c-tinta-3);
	padding-top: clamp(1.25rem, 3vw, 2rem);
}
.rn-breadcrumbs a { color: var(--c-verde-700); }
.rn-breadcrumbs a:hover { color: var(--c-acento); }
.rn-breadcrumbs__sep {
	margin-inline: 0.5rem;
	color: var(--c-arena-2);
}
/* Cuando el rastro precede al wrapper del shop, recortamos el padding-top
   superior de la sección para que no quede un hueco doble. */
.rn-breadcrumbs + #primary.rn-shop .rn-section,
.rn-breadcrumbs + .rn-shop .rn-section {
	padding-top: clamp(1.5rem, 3vw, 2.25rem);
}

/* ============================ 7. PAGINACIÓN =========================== */
.rn-pagination {
	margin-top: clamp(2rem, 5vw, 3.5rem);
	display: flex;
	justify-content: center;
}
.rn-pagination ul.page-numbers {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
	list-style: none;
	margin: 0;
	padding: 0;
}
.rn-pagination .page-numbers {
	display: inline-grid;
	place-items: center;
	min-width: 44px;
	height: 44px;
	padding: 0 0.75rem;
	border: 1px solid var(--c-linea);
	border-radius: var(--r-pill);
	font-size: var(--fs-sm);
	color: var(--c-tinta);
	background: var(--c-crema);
	transition: background var(--tr), color var(--tr), border-color var(--tr);
}
.rn-pagination a.page-numbers:hover {
	border-color: var(--c-verde-600);
	color: var(--c-verde-700);
	background: var(--c-verde-50);
}
.rn-pagination .page-numbers.current {
	background: var(--c-verde-600);
	border-color: var(--c-verde-600);
	color: var(--c-crema);
}
.rn-pagination .page-numbers.dots {
	border-color: transparent;
	background: transparent;
}

/* Paginación de la TIENDA (WooCommerce).
   woocommerce-general.css (que conservamos) dibuja la paginación como una caja
   con borde y divisores (float + border en ul/li): rompe el diseño. La
   reseteamos y reaplicamos las mismas píldoras que .rn-pagination, con
   selectores que ganan por especificidad a los de WC. El blog sigue usando
   .rn-pagination de arriba. */
.woocommerce nav.woocommerce-pagination {
	text-align: center;
	margin-top: clamp(2rem, 5vw, 3.5rem);
}
.woocommerce nav.woocommerce-pagination ul,
.woocommerce nav.woocommerce-pagination ul li {
	border: 0;
	margin: 0;
	padding: 0;
	float: none;
	overflow: visible;
}
.woocommerce nav.woocommerce-pagination ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.4rem;
	list-style: none;
	white-space: normal;
}
.woocommerce nav.woocommerce-pagination ul li {
	display: inline-flex;
	line-height: normal;
}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
	display: inline-grid;
	place-items: center;
	min-width: 44px;
	height: 44px;
	padding: 0 0.85rem;
	margin: 0;
	border: 1px solid var(--c-linea);
	border-radius: var(--r-pill);
	font-size: var(--fs-sm);
	line-height: 1;
	color: var(--c-tinta);
	background: var(--c-crema);
	transition: background var(--tr), color var(--tr), border-color var(--tr);
}
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li a:focus {
	border-color: var(--c-verde-600);
	color: var(--c-verde-700);
	background: var(--c-verde-50);
}
.woocommerce nav.woocommerce-pagination ul li span.current {
	background: var(--c-verde-600);
	border-color: var(--c-verde-600);
	color: var(--c-crema);
}
.woocommerce nav.woocommerce-pagination ul li span.dots {
	border-color: transparent;
	background: transparent;
	min-width: auto;
	padding: 0 0.35rem;
}

/* ============================ 8. ESTADO VACÍO ========================= */
.rn-empty {
	text-align: center;
	padding-block: clamp(2.5rem, 7vw, 5rem);
}
.rn-empty__msg {
	margin: 0 auto var(--sp-5);
	max-width: 46ch;
	color: var(--c-tinta-2);
	font-size: 1.05rem;
}

/* ============================ 9. SELECTOR DE CANTIDAD ================== */
/* La base .rn-qty vive en theme.css. Acá afinamos los botones del override
   (rn_icon imprime SVG) y el modo readonly. */
.rn-qty__btn {
	width: 42px;
	height: 44px;
	display: grid;
	place-items: center;
	color: var(--c-cuero-700);
	flex: none;
}
.rn-qty__btn:hover { background: var(--c-crema-2); color: var(--c-acento); }
.rn-qty__btn svg { width: 16px; height: 16px; }
.rn-qty__btn:disabled { opacity: 0.4; cursor: not-allowed; }
.rn-qty--readonly .rn-qty__readonly-value {
	padding: 0 0.9rem;
	min-width: 44px;
	text-align: center;
}

/* ============================ 10. MINI-CART DRAWER ==================== */
/* Off-canvas a la derecha. Lo abre/cierra main.js con body.rn-minicart-open
   (contrato del loop principal). Marcado en footer.php. */
.rn-minicart {
	position: fixed;
	top: 0;
	right: 0;
	z-index: var(--z-modal);
	width: min(420px, 92vw);
	height: 100%;
	height: 100dvh;
	display: flex;
	flex-direction: column;
	background: var(--c-crema);
	box-shadow: var(--sh-lg);
	border-left: 1px solid var(--c-linea);
	transform: translateX(100%);
	transition: transform var(--tr-slow);
	will-change: transform;
	visibility: hidden;
}
body.rn-minicart-open .rn-minicart {
	transform: translateX(0);
	visibility: visible;
}

.rn-minicart__backdrop {
	position: fixed;
	inset: 0;
	z-index: var(--z-overlay);
	background: rgba(34, 42, 16, 0.42);
	backdrop-filter: blur(2px);
	-webkit-backdrop-filter: blur(2px);
	opacity: 0;
	visibility: hidden;
	transition: opacity var(--tr), visibility var(--tr);
}
body.rn-minicart-open .rn-minicart__backdrop {
	opacity: 1;
	visibility: visible;
}

.rn-minicart__head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--sp-3);
	padding: var(--sp-5) var(--sp-5) var(--sp-4);
	border-bottom: 1px solid var(--c-linea);
}
.rn-minicart__title {
	font-family: var(--font-display);
	font-size: 1.25rem;
	font-weight: 600;
	color: var(--c-verde-900);
}
.rn-minicart__close {
	width: 42px;
	height: 42px;
	display: grid;
	place-items: center;
	border-radius: var(--r-pill);
	color: var(--c-tinta);
}
.rn-minicart__close:hover { background: var(--c-crema-2); color: var(--c-acento); }
.rn-minicart__close svg { width: 22px; height: 22px; }

.rn-minicart__items {
	flex: 1;
	overflow-y: auto;
	padding: var(--sp-4) var(--sp-5);
	-webkit-overflow-scrolling: touch;
}

/* Lista interna que imprime woocommerce_mini_cart(). */
.rn-minicart .woocommerce-mini-cart {
	list-style: none;
	margin: 0;
	padding: 0;
}
/* La <img> de WooCommerce va DENTRO del <a> del producto, no como hijo directo.
   Por eso el ítem se arma como bloque y el <a> como fila flex (imagen + nombre). */
.rn-minicart .woocommerce-mini-cart-item {
	position: relative;
	padding: var(--sp-4) 2.1rem var(--sp-4) 0;
	border-bottom: 1px solid var(--c-linea);
}
.rn-minicart .woocommerce-mini-cart-item a:not(.remove) {
	display: flex;
	align-items: center;
	gap: var(--sp-3);
	color: var(--c-verde-900);
	font-weight: 500;
	font-size: var(--fs-sm);
	line-height: 1.3;
}
.rn-minicart .woocommerce-mini-cart-item img {
	flex: none;
	width: 56px !important;
	height: 70px !important;
	max-width: 56px;
	margin: 0 !important;
	float: none !important;
	object-fit: cover;
	border-radius: var(--r-sm);
	border: 1px solid var(--c-linea);
}
.rn-minicart .woocommerce-mini-cart-item .quantity {
	display: block;
	margin-top: 0.4rem;
	margin-left: calc(56px + var(--sp-3));
	font-size: var(--fs-sm);
	color: var(--c-tinta-3);
}
.rn-minicart .woocommerce-mini-cart-item .remove_from_cart_button {
	position: absolute;
	top: var(--sp-4);
	right: 0;
	width: 24px;
	height: 24px;
	display: grid;
	place-items: center;
	border-radius: var(--r-pill);
	color: var(--c-tinta-3);
	font-size: 0;
	background: var(--c-crema-2);
}
.rn-minicart .woocommerce-mini-cart-item .remove_from_cart_button::before {
	content: "\00d7";
	font-size: 18px;
	line-height: 1;
}
.rn-minicart .woocommerce-mini-cart-item .remove_from_cart_button:hover {
	background: var(--c-acento-50);
	color: var(--c-acento-700);
}

.rn-minicart .woocommerce-mini-cart__empty-message {
	color: var(--c-tinta-2);
	text-align: center;
	padding-block: var(--sp-6);
}

/* Subtotal + botones del mini-cart (los imprime woocommerce_mini_cart()). */
.rn-minicart .woocommerce-mini-cart__total {
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	margin: 0;
	padding: var(--sp-4) var(--sp-5);
	border-top: 1px solid var(--c-linea);
	font-weight: 500;
	color: var(--c-verde-900);
}
.rn-minicart .woocommerce-mini-cart__total .amount { font-size: 1.15rem; }
.rn-minicart .woocommerce-mini-cart__buttons {
	display: flex;
	flex-direction: column;
	gap: var(--sp-3);
	margin: 0;
	padding: 0 var(--sp-5) var(--sp-5);
}
.rn-minicart .woocommerce-mini-cart__buttons .button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	font-family: var(--font-sans);
	font-size: var(--fs-sm);
	font-weight: 500;
	line-height: 1;
	padding: 0.9rem 1.5rem;
	border-radius: var(--r-pill);
	border: 1.5px solid transparent;
	transition: background var(--tr), color var(--tr), border-color var(--tr);
}
/* Primer botón = "Ver carrito" (fantasma); el .checkout = primario. */
.rn-minicart .woocommerce-mini-cart__buttons .button {
	background: transparent;
	color: var(--c-verde-700);
	border-color: var(--c-verde-600);
}
.rn-minicart .woocommerce-mini-cart__buttons .button:hover {
	background: var(--c-verde-600);
	color: var(--c-crema);
}
.rn-minicart .woocommerce-mini-cart__buttons .button.checkout {
	background: var(--c-acento-600);
	color: #fff;
	border-color: transparent;
}
.rn-minicart .woocommerce-mini-cart__buttons .button.checkout:hover {
	background: var(--c-acento-700);
	color: #fff;
}

/* Accesibilidad de movimiento. */
@media (prefers-reduced-motion: reduce) {
	.rn-minicart { transition: none; }
	.rn-minicart__backdrop { transition: none; }
}

/* ============================ 11. SIDEBAR DE FILTROS (opcional) ======= */
/* Si en el futuro se agrega una columna de filtros, .rn-shop__inner pasa a
   grid de 2 columnas. Por defecto la tienda va a ancho completo. */
.rn-shop--has-filters .rn-shop__inner {
	display: grid;
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: start;
}
@media (min-width: 900px) {
	.rn-shop--has-filters .rn-shop__inner {
		grid-template-columns: 260px 1fr;
	}
}
.rn-shop__filters {
	position: sticky;
	top: calc(var(--header-h) + 1rem);
}
.rn-shop__filters .widget {
	margin-bottom: var(--sp-6);
	padding-bottom: var(--sp-5);
	border-bottom: 1px solid var(--c-linea);
}
.rn-shop__filters .widgettitle,
.rn-shop__filters .widget-title {
	font-family: var(--font-display);
	font-size: 1.05rem;
	color: var(--c-verde-900);
	margin-bottom: var(--sp-3);
}

/* ============================ 12. RESPONSIVE ========================== */
@media (max-width: 600px) {
	.rn-shop-toolbar {
		flex-direction: column;
		align-items: stretch;
	}
	.rn-orderby__select { width: 100%; }
}
