/**
 * Zenth Toolkit · Shop App — catálogo de productos (REST + JS)
 *
 * Estilos de la app de tienda: toolbar (filtros/búsqueda/orden), grid con
 * skeletons, cards de producto, paginación, estado vacío y el rebrand CR
 * "catálogo unificado" (.zenth-shop-catalog / .zenth-shop-card--catalog) que
 * pinta la versión oscura con tokens del theme. Incluye también los swatches
 * de color. El CSS usa var(--cr-*, #fallback) para funcionar standalone.
 *
 * Convive con DOS paletas: la propia del shop (--zsa-*, definida en §1) para
 * la versión base, y los tokens del theme (--cr-*) para el rebrand del §8.
 *
 * ─────────────────────────────────────────────────────────────────────────
 * ÍNDICE
 *   §1  Tokens (:root)        → paleta --zsa-* del shop
 *   §2  Toolbar               → filtros / búsqueda / orden / chips
 *   §3  Grid                  → grid de items + loading + reset [hidden]
 *   §4  Card                  → card de producto + badges + ATC + skeleton
 *   §5  Estado vacío          → .zenth-shop-grid__empty
 *   §6  Paginación            → .zenth-shop-pagination__*
 *   §7  Fallback sin WooComm  → .zenth-shop-grid--no-woo
 *   §8  Catálogo unificado    → rebrand CR (.zenth-shop-catalog / --catalog)
 *   §9  Swatches de color     → .zenth-shop-card__swatch*
 *   §10 Responsive            → TODOS los @media consolidados acá + a11y
 * ─────────────────────────────────────────────────────────────────────────
 * BREAKPOINTS usados acá:  1024 (tablet) · 767 (mobile catálogo) · 640 (mobile base)
 *   Los @media de TAMAÑO viven en §10, ordenados de más ancho a más angosto
 *   (1024 → 767 → 640). Al final, subsección de ACCESIBILIDAD/CAPACIDAD que
 *   NO se consolida: (hover: hover) and (pointer: fine) para el CTA flotante
 *   del catálogo + dos prefers-reduced-motion (catálogo y swatches).
 * ─────────────────────────────────────────────────────────────────────────
 */


/* ═══════════════════════════════════════════════════════════════════════
   §1 · TOKENS (:root) — paleta --zsa-* del shop
   ═══════════════════════════════════════════════════════════════════════ */

:root {
	/* Paleta del shop. Se puede sobrescribir desde el child theme
	   con .cr-shop-page :root { --zsa-red: ... } si Kevin quisiera. */
	--zsa-red: #E8001D;
	--zsa-red-dark: #B80017;
	--zsa-black: #0A0A0A;
	--zsa-white: #FFFFFF;
	--zsa-bg: #FFFFFF;
	--zsa-bg-alt: #F7F7F8;
	--zsa-border: #E5E7EB;
	--zsa-border-strong: #D1D5DB;
	--zsa-text: #111111;
	--zsa-text-soft: #6B7280;
	--zsa-text-mute: #9CA3AF;
	--zsa-radius: 4px;
	--zsa-radius-lg: 8px;
	--zsa-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
	--zsa-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.08);
	--zsa-shadow-hover: 0 12px 28px rgba(232, 0, 29, 0.12);
	--zsa-trans-fast: 150ms ease;
	--zsa-trans-mid: 250ms ease;
	--zsa-trans-slow: 400ms ease;
	--zsa-font-display: 'Bebas Neue', 'Barlow Condensed', sans-serif;
	--zsa-font-body: 'Barlow', system-ui, -apple-system, sans-serif;
}


/* ═══════════════════════════════════════════════════════════════════════
   §2 · TOOLBAR — filtros / búsqueda / orden / chips
   ═══════════════════════════════════════════════════════════════════════ */

.zenth-shop-toolbar {
	display: flex;
	flex-direction: column;
	gap: 12px;
	width: 100%;
	padding: 16px 0;
	border-top: 1px solid var(--zsa-border);
	border-bottom: 1px solid var(--zsa-border);
	font-family: var(--zsa-font-body);
}

.zenth-shop-toolbar__row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 12px;
}

.zenth-shop-toolbar__filters-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 16px;
	background: var(--zsa-white);
	color: var(--zsa-text);
	border: 1.5px solid var(--zsa-border-strong);
	border-radius: var(--zsa-radius);
	font-family: var(--zsa-font-body);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.02em;
	cursor: pointer;
	transition: border-color var(--zsa-trans-fast), background var(--zsa-trans-fast), color var(--zsa-trans-fast);
	position: relative;
}

.zenth-shop-toolbar__filters-btn:hover,
.zenth-shop-toolbar__filters-btn:focus-visible {
	border-color: var(--zsa-black);
	outline: none;
}

.zenth-shop-toolbar__filters-btn svg {
	flex-shrink: 0;
}

.zenth-shop-toolbar__filters-label {
	text-transform: uppercase;
}

.zenth-shop-toolbar__filters-badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 20px;
	height: 20px;
	padding: 0 6px;
	background: var(--zsa-red);
	color: var(--zsa-white);
	border-radius: 999px;
	font-size: 11px;
	font-weight: 700;
	line-height: 1;
}

.zenth-shop-toolbar__count {
	flex: 1 1 auto;
	min-width: 0;
	font-size: 13px;
	color: var(--zsa-text-soft);
}

.zenth-shop-toolbar__count-text {
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.zenth-shop-toolbar__search {
	position: relative;
	display: flex;
	align-items: center;
	min-width: 240px;
}

.zenth-shop-toolbar__search-icon {
	position: absolute;
	left: 12px;
	color: var(--zsa-text-mute);
	pointer-events: none;
}

.zenth-shop-toolbar__search-input {
	width: 100%;
	padding: 10px 36px 10px 38px;
	background: var(--zsa-bg-alt);
	border: 1.5px solid transparent;
	border-radius: var(--zsa-radius);
	font-family: var(--zsa-font-body);
	font-size: 14px;
	color: var(--zsa-text);
	transition: border-color var(--zsa-trans-fast), background var(--zsa-trans-fast);
}

.zenth-shop-toolbar__search-input::placeholder {
	color: var(--zsa-text-mute);
}

.zenth-shop-toolbar__search-input:focus {
	background: var(--zsa-white);
	border-color: var(--zsa-black);
	outline: none;
}

.zenth-shop-toolbar__search-clear {
	position: absolute;
	right: 8px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	background: transparent;
	border: none;
	color: var(--zsa-text-soft);
	cursor: pointer;
	border-radius: 50%;
	transition: background var(--zsa-trans-fast), color var(--zsa-trans-fast);
}

.zenth-shop-toolbar__search-clear:hover {
	background: var(--zsa-border);
	color: var(--zsa-text);
}

.zenth-shop-toolbar__sort {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.zenth-shop-toolbar__sort-label {
	font-size: 13px;
	color: var(--zsa-text-soft);
	white-space: nowrap;
}

.zenth-shop-toolbar__sort-select {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	padding: 10px 32px 10px 14px;
	background: var(--zsa-white);
	border: 1.5px solid var(--zsa-border-strong);
	border-radius: var(--zsa-radius);
	font-family: var(--zsa-font-body);
	font-size: 14px;
	font-weight: 500;
	color: var(--zsa-text);
	cursor: pointer;
	transition: border-color var(--zsa-trans-fast);
}

.zenth-shop-toolbar__sort-select:hover,
.zenth-shop-toolbar__sort-select:focus-visible {
	border-color: var(--zsa-black);
	outline: none;
}

.zenth-shop-toolbar__sort-chevron {
	position: absolute;
	right: 12px;
	color: var(--zsa-text-soft);
	pointer-events: none;
}

.zenth-shop-toolbar__chips {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}


/* ═══════════════════════════════════════════════════════════════════════
   §3 · GRID — grid de items + loading + reset [hidden]
   ═══════════════════════════════════════════════════════════════════════ */

.zenth-shop-grid {
	position: relative;
	width: 100%;
	margin: 32px 0;
	font-family: var(--zsa-font-body);
}

.zenth-shop-grid__items {
	display: grid;
	grid-template-columns: repeat(var(--zsg-cols, 4), 1fr);
	gap: 24px;
	transition: opacity var(--zsa-trans-mid);
}

.zenth-shop-grid__loading {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	display: grid;
	grid-template-columns: repeat(var(--zsg-cols, 4), 1fr);
	gap: 24px;
	pointer-events: none;
	z-index: 2;
}

/* CRÍTICO: el atributo hidden debe ganar sobre display:grid/flex.
   Sin esto, los skeletons quedan visibles tapando el grid real. */
.zenth-shop-grid__loading[hidden],
.zenth-shop-grid__empty[hidden],
[data-zenth-shop-search-clear][hidden],
[data-zenth-shop-filters-count][hidden],
[data-zenth-shop-chips][hidden] {
	display: none !important;
}


/* ═══════════════════════════════════════════════════════════════════════
   §4 · CARD — card de producto + badges + ATC + skeleton
   ═══════════════════════════════════════════════════════════════════════ */

.zenth-shop-card {
	display: flex;
	flex-direction: column;
	background: var(--zsa-white);
	transition: transform var(--zsa-trans-mid), box-shadow var(--zsa-trans-mid);
	position: relative;
}

.zenth-shop-card:hover {
	transform: translateY(-4px);
}

.zenth-shop-card__media-link {
	display: block;
	text-decoration: none;
	color: inherit;
}

.zenth-shop-card__media {
	position: relative;
	overflow: hidden;
	aspect-ratio: var(--zsg-aspect, 1/1);
	background: var(--zsa-bg-alt);
	border-radius: var(--zsa-radius-lg);
	margin-bottom: 12px;
}

.zenth-shop-card__img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: opacity var(--zsa-trans-slow), transform var(--zsa-trans-slow);
}

.zenth-shop-card__img--primary {
	opacity: 1;
	z-index: 1;
}

.zenth-shop-card__img--secondary {
	opacity: 0;
	z-index: 2;
}

.zenth-shop-card--has-secondary:hover .zenth-shop-card__img--primary {
	opacity: 0;
}

.zenth-shop-card--has-secondary:hover .zenth-shop-card__img--secondary {
	opacity: 1;
}

.zenth-shop-card:hover .zenth-shop-card__img {
	transform: scale(1.05);
}

.zenth-shop-card__badge {
	position: absolute;
	top: 12px;
	left: 12px;
	z-index: 3;
	display: inline-flex;
	align-items: center;
	height: 26px;
	padding: 0 10px;
	font-family: var(--zsa-font-display);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	border-radius: var(--zsa-radius);
	color: var(--zsa-white);
}

.zenth-shop-card__badge--sale {
	background: var(--zsa-red);
}

.zenth-shop-card__badge--new {
	background: var(--zsa-black);
}

.zenth-shop-card__stock-badge {
	position: absolute;
	top: 12px;
	right: 12px;
	z-index: 3;
	display: inline-flex;
	align-items: center;
	height: 26px;
	padding: 0 10px;
	background: rgba(10, 10, 10, 0.85);
	color: var(--zsa-white);
	font-family: var(--zsa-font-display);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	border-radius: var(--zsa-radius);
}

.zenth-shop-card__body {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 4px 4px 12px;
}

.zenth-shop-card__title {
	margin: 0;
	font-family: var(--zsa-font-body);
	font-size: 14px;
	font-weight: 500;
	line-height: 1.35;
	color: var(--zsa-text);
}

.zenth-shop-card__title a {
	color: inherit;
	text-decoration: none;
	transition: color var(--zsa-trans-fast);
}

.zenth-shop-card__title a:hover {
	color: var(--zsa-red);
}

.zenth-shop-card__price {
	font-family: var(--zsa-font-body);
	font-size: 16px;
	font-weight: 700;
	color: var(--zsa-text);
	line-height: 1.2;
	margin-top: 2px;
}

.zenth-shop-card__price del {
	color: var(--zsa-text-mute);
	font-weight: 400;
	margin-right: 6px;
	font-size: 13px;
}

.zenth-shop-card__price ins {
	text-decoration: none;
	color: var(--zsa-red);
}

.zenth-shop-card__price .woocommerce-Price-amount {
	white-space: nowrap;
}

.zenth-shop-card__atc {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	margin-top: 8px;
	padding: 10px 14px;
	background: var(--zsa-black);
	color: var(--zsa-white);
	border: none;
	border-radius: var(--zsa-radius);
	font-family: var(--zsa-font-body);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	text-decoration: none;
	cursor: pointer;
	transition: background var(--zsa-trans-fast), color var(--zsa-trans-fast);
}

.zenth-shop-card__atc:hover {
	background: var(--zsa-red);
	color: var(--zsa-white);
}

.zenth-shop-card__atc--variable:hover {
	background: var(--zsa-red);
}

.zenth-shop-card__atc--loading {
	opacity: 0.7;
	pointer-events: none;
	position: relative;
}

.zenth-shop-card__atc--loading::after {
	content: '';
	position: absolute;
	right: 14px;
	top: 50%;
	width: 12px;
	height: 12px;
	margin-top: -6px;
	border: 2px solid rgba(255, 255, 255, 0.3);
	border-top-color: var(--zsa-white);
	border-radius: 50%;
	animation: zenth-shop-spin 600ms linear infinite;
}

.zenth-shop-card__atc--added {
	background: #10B981;
	color: var(--zsa-white);
}

.zenth-shop-card__atc--disabled {
	background: var(--zsa-bg-alt);
	color: var(--zsa-text-mute);
	cursor: not-allowed;
}

.zenth-shop-card__atc--disabled:hover {
	background: var(--zsa-bg-alt);
	color: var(--zsa-text-mute);
}

@keyframes zenth-shop-spin {
	to { transform: rotate(360deg); }
}

/* Stock agotado: opacity en card */
.zenth-shop-card--out-of-stock .zenth-shop-card__img--primary,
.zenth-shop-card--out-of-stock .zenth-shop-card__img--secondary {
	opacity: 0.6;
}

.zenth-shop-card--out-of-stock:hover .zenth-shop-card__img--primary,
.zenth-shop-card--out-of-stock:hover .zenth-shop-card__img--secondary {
	opacity: 0.6;
}

.zenth-shop-card--skeleton {
	pointer-events: none;
}

.zenth-shop-card--skeleton .zenth-shop-card__media {
	background: linear-gradient(90deg, var(--zsa-bg-alt) 0%, #EFEFF1 50%, var(--zsa-bg-alt) 100%);
	background-size: 200% 100%;
	animation: zenth-shop-shimmer 1.4s infinite;
}

.zenth-shop-card__skeleton-line {
	height: 14px;
	margin: 6px 0;
	background: linear-gradient(90deg, var(--zsa-bg-alt) 0%, #EFEFF1 50%, var(--zsa-bg-alt) 100%);
	background-size: 200% 100%;
	border-radius: var(--zsa-radius);
	animation: zenth-shop-shimmer 1.4s infinite;
}

.zenth-shop-card__skeleton-line--title { width: 80%; }
.zenth-shop-card__skeleton-line--price { width: 40%; height: 18px; }

@keyframes zenth-shop-shimmer {
	0%   { background-position: 200% 0; }
	100% { background-position: -200% 0; }
}


/* ═══════════════════════════════════════════════════════════════════════
   §5 · ESTADO VACÍO — .zenth-shop-grid__empty
   ═══════════════════════════════════════════════════════════════════════ */

.zenth-shop-grid__empty {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 12px;
	padding: 64px 24px;
	text-align: center;
	color: var(--zsa-text-soft);
}

.zenth-shop-grid__empty svg {
	color: var(--zsa-text-mute);
	margin-bottom: 4px;
}

.zenth-shop-grid__empty-title {
	margin: 0;
	font-family: var(--zsa-font-display);
	font-size: 24px;
	font-weight: 700;
	letter-spacing: 0.02em;
	text-transform: uppercase;
	color: var(--zsa-text);
}

.zenth-shop-grid__empty-text {
	margin: 0;
	font-size: 14px;
	max-width: 380px;
}

.zenth-shop-grid__empty-btn {
	margin-top: 8px;
	padding: 10px 24px;
	background: var(--zsa-black);
	color: var(--zsa-white);
	border: none;
	border-radius: var(--zsa-radius);
	font-family: var(--zsa-font-body);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background var(--zsa-trans-fast);
}

.zenth-shop-grid__empty-btn:hover {
	background: var(--zsa-red);
}


/* ═══════════════════════════════════════════════════════════════════════
   §6 · PAGINACIÓN — .zenth-shop-pagination__*
   ═══════════════════════════════════════════════════════════════════════ */

.zenth-shop-grid__pagination {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
	margin-top: 40px;
	flex-wrap: wrap;
}

.zenth-shop-grid__pagination:empty {
	margin-top: 0;
}

.zenth-shop-pagination__btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 10px;
	background: var(--zsa-white);
	color: var(--zsa-text);
	border: 1.5px solid var(--zsa-border);
	border-radius: var(--zsa-radius);
	font-family: var(--zsa-font-body);
	font-size: 14px;
	font-weight: 600;
	cursor: pointer;
	transition: background var(--zsa-trans-fast), border-color var(--zsa-trans-fast), color var(--zsa-trans-fast);
}

.zenth-shop-pagination__btn:hover {
	border-color: var(--zsa-black);
}

.zenth-shop-pagination__btn--active {
	background: var(--zsa-black);
	color: var(--zsa-white);
	border-color: var(--zsa-black);
	pointer-events: none;
}

.zenth-shop-pagination__btn--prev,
.zenth-shop-pagination__btn--next {
	color: var(--zsa-text-soft);
}

.zenth-shop-pagination__btn--prev:hover,
.zenth-shop-pagination__btn--next:hover {
	color: var(--zsa-text);
}

.zenth-shop-pagination__ellipsis {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 20px;
	height: 40px;
	color: var(--zsa-text-mute);
	font-size: 14px;
	user-select: none;
}


/* ═══════════════════════════════════════════════════════════════════════
   §7 · FALLBACK SIN WOOCOMMERCE — .zenth-shop-grid--no-woo
   ═══════════════════════════════════════════════════════════════════════ */

.zenth-shop-grid--no-woo {
	padding: 40px;
	text-align: center;
	background: var(--zsa-bg-alt);
	border: 1px dashed var(--zsa-border-strong);
	border-radius: var(--zsa-radius-lg);
	color: var(--zsa-text-soft);
}


/* ═══════════════════════════════════════════════════════════════════════
   §8 · CATÁLOGO UNIFICADO — rebrand CR (.zenth-shop-catalog / --catalog)
   ───────────────────────────────────────────────────────────────────────
   Estilo CR estilo target: toolbar liviano + cards 4:5 con
   CTA flotante en hover + paginación pill centrada.
   Solo aplica cuando hay un .zenth-shop-catalog wrapper.
   ═══════════════════════════════════════════════════════════════════════ */

.zenth-shop-catalog {
	width: 100%;
	max-width: var(--cr-container-max, 1440px);
	margin: 0 auto;
	padding: 0 var(--cr-container-pad, 32px);
	box-sizing: border-box;
}

/* Grid del catálogo: gap más generoso estilo target */
.zenth-shop-catalog .zenth-shop-grid__items {
	gap: clamp(20px, 2.2vw, 32px);
}

/* ---------------------------------------------------------
   TOOLBAR INLINE — versión liviana CR
   Sin recuadros, solo texto + iconos. Centrado el contador.
   --------------------------------------------------------- */
.zenth-shop-catalog .zenth-shop-toolbar--inline {
	background: transparent;
	border: none;
	padding: 0;
	margin-bottom: clamp(24px, 3vw, 40px);
}

.zenth-shop-catalog .zenth-shop-toolbar--inline .zenth-shop-toolbar__row {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 16px;
	padding: 0;
}

/* Botón Filtros — sin recuadro, texto + ícono */
.zenth-shop-toolbar__filters-btn--inline {
	justify-self: start;
	background: transparent !important;
	border: none !important;
	padding: 8px 0 !important;
	color: var(--cr-color-text, #fff) !important;
	font-family: var(--cr-font-body, 'Montserrat', sans-serif);
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 0.02em;
	display: inline-flex;
	align-items: center;
	gap: 10px;
	cursor: pointer;
	text-transform: none;
	transition: opacity 200ms ease, color 200ms ease;
}

.zenth-shop-toolbar__filters-btn--inline:hover,
.zenth-shop-toolbar__filters-btn--inline:focus-visible {
	background: transparent !important;
	border: none !important;
	color: var(--cr-color-primary, #c00000) !important;
	outline: none;
}

.zenth-shop-toolbar__filters-btn--inline svg {
	width: 16px;
	height: 16px;
}

.zenth-shop-toolbar__filters-btn--inline .zenth-shop-toolbar__filters-label {
	order: -1;
}

/* Badge contador del botón filtros */
.zenth-shop-toolbar__filters-btn--inline .zenth-shop-toolbar__filters-badge {
	min-width: 18px;
	height: 18px;
	background: var(--cr-color-primary, #c00000);
	color: #fff;
	border-radius: 50%;
	font-size: 10px;
	font-weight: 700;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0 5px;
}

/* Contador centrado */
.zenth-shop-catalog .zenth-shop-toolbar__count {
	justify-self: center;
	color: var(--cr-color-text-muted, rgba(255, 255, 255, 0.55));
	font-size: 13px;
	font-family: var(--cr-font-body, 'Montserrat', sans-serif);
	letter-spacing: 0.01em;
}

/* Sort — sin recuadro */
.zenth-shop-toolbar__sort--inline {
	justify-self: end;
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.zenth-shop-toolbar__sort--inline .zenth-shop-toolbar__sort-label {
	color: var(--cr-color-text, #fff);
	font-size: 14px;
	font-family: var(--cr-font-body, 'Montserrat', sans-serif);
	font-weight: 500;
}

.zenth-shop-toolbar__sort--inline .zenth-shop-toolbar__sort-select {
	background: transparent !important;
	border: none !important;
	color: var(--cr-color-text, #fff) !important;
	padding: 4px 22px 4px 0 !important;
	font-size: 14px !important;
	font-family: var(--cr-font-body, 'Montserrat', sans-serif) !important;
	cursor: pointer;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	font-weight: 500;
}

.zenth-shop-toolbar__sort--inline .zenth-shop-toolbar__sort-select:hover,
.zenth-shop-toolbar__sort--inline .zenth-shop-toolbar__sort-select:focus-visible {
	background: transparent !important;
	border: none !important;
	color: var(--cr-color-primary, #c00000) !important;
	outline: none;
}

.zenth-shop-toolbar__sort--inline .zenth-shop-toolbar__sort-chevron {
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	pointer-events: none;
	width: 12px;
	height: 12px;
	color: var(--cr-color-text, #fff);
}

/* Las options del select sí tienen fondo para que se lean */
.zenth-shop-toolbar__sort--inline .zenth-shop-toolbar__sort-select option {
	background: #1a1a1a;
	color: #fff;
}


/* ---------------------------------------------------------
   GRID — Mantiene comportamiento existente; sin overrides.
   --------------------------------------------------------- */


/* ---------------------------------------------------------
   CARD ESTILO CATÁLOGO CR
   Aspect ratio configurable, badge sutil, CTA flotante hover.
   --------------------------------------------------------- */

/* Card sin padding ni borde, imagen full bleed */
.zenth-shop-card--catalog {
	background: transparent;
	border: none;
	border-radius: 0;
	overflow: hidden;
	position: relative;
	display: flex;
	flex-direction: column;
}

/* Media wrap — usa el aspect del data attribute */
.zenth-shop-card--catalog .zenth-shop-card__media-link {
	display: block;
	position: relative;
	overflow: hidden;
}

.zenth-shop-card--catalog .zenth-shop-card__media {
	position: relative;
	width: 100%;
	aspect-ratio: var(--zsg-aspect, 4/5);
	overflow: hidden;
	background: #0f0f0f;
}

.zenth-shop-card--catalog .zenth-shop-card__img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 600ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.zenth-shop-card--catalog:hover .zenth-shop-card__img--primary {
	transform: scale(1.04);
}

/* Badge "Nuevo" — estilo target: semi-transparente blanco con corners redondeados */
.zenth-shop-card--catalog .zenth-shop-card__badge {
	position: absolute;
	top: 14px;
	left: 14px;
	background: rgba(255, 255, 255, 0.92);
	color: #050505;
	font-family: var(--cr-font-body, 'Montserrat', sans-serif);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: capitalize;
	padding: 4px 10px;
	border-radius: 4px;
	z-index: 3;
	pointer-events: none;
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
}

.zenth-shop-card--catalog .zenth-shop-card__badge--sale {
	background: #16A34A;
	color: #fff;
}

.zenth-shop-card--catalog .zenth-shop-card__badge--out,
.zenth-shop-card--catalog .zenth-shop-card__stock-badge {
	background: rgba(20, 20, 20, 0.85);
	color: #fff;
}

/* CTA flotante en hover: barra completa bajo la imagen, compacta */
.zenth-shop-card__hover-cta {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: 0;
	z-index: 4;
	pointer-events: none;
	display: flex;
	justify-content: stretch;
}

.zenth-shop-card__hover-cta > * {
	pointer-events: auto;
	flex: 1;
}

.zenth-shop-card--catalog .zenth-shop-card__atc {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 10px 14px;
	background: var(--cr-color-primary, #c00000);
	color: #fff;
	border: none;
	border-radius: 0;
	font-family: var(--cr-font-body, 'Montserrat', sans-serif);
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	cursor: pointer;
	text-decoration: none;
	white-space: nowrap;
	width: 100%;
	transition: background 200ms ease, transform 280ms cubic-bezier(0.4, 0, 0.2, 1),
		opacity 280ms cubic-bezier(0.4, 0, 0.2, 1);
}

.zenth-shop-card--catalog .zenth-shop-card__atc:hover,
.zenth-shop-card--catalog .zenth-shop-card__atc:focus-visible {
	background: var(--cr-color-primary-hover, #e60000);
	color: #fff;
	outline: none;
}

.zenth-shop-card--catalog .zenth-shop-card__atc svg {
	flex-shrink: 0;
}

/* Body de la card — limpio, sin botón debajo */
.zenth-shop-card--catalog .zenth-shop-card__body {
	padding: 14px 0 0;
	background: transparent;
}

.zenth-shop-card--catalog .zenth-shop-card__title {
	font-family: var(--cr-font-body, 'Montserrat', sans-serif);
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 0.005em;
	text-transform: none;
	color: var(--cr-color-text, #fff);
	margin: 0 0 6px;
	line-height: 1.3;
}

.zenth-shop-card--catalog .zenth-shop-card__title a {
	color: inherit;
	text-decoration: none;
}

.zenth-shop-card--catalog .zenth-shop-card__title a:hover {
	color: var(--cr-color-primary, #c00000);
}

.zenth-shop-card--catalog .zenth-shop-card__price {
	font-family: var(--cr-font-body, 'Montserrat', sans-serif);
	font-size: 14px;
	font-weight: 700;
	color: var(--cr-color-text, #fff);
	letter-spacing: 0.01em;
}

.zenth-shop-card--catalog .zenth-shop-card__price * {
	color: inherit;
}

.zenth-shop-card--catalog .zenth-shop-card__price del {
	opacity: 0.5;
	margin-right: 6px;
}

.zenth-shop-card--catalog .zenth-shop-card__price ins {
	text-decoration: none;
}

/* ---------------------------------------------------------
   PAGINACIÓN PILL — estilo target
   Container negro pill centrado abajo con flechas + números.
   --------------------------------------------------------- */
.zenth-shop-grid__pagination--pill {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	padding: 8px 14px;
	background: rgba(255, 255, 255, 0.03);
	border-radius: 999px;
	margin: 32px auto 0;
}

.zenth-shop-catalog .zenth-shop-grid__pagination--pill:empty {
	display: none;
}

/* Wrapper centrado */
.zenth-shop-catalog .zenth-shop-grid {
	display: flex;
	flex-direction: column;
}

.zenth-shop-catalog .zenth-shop-grid__items {
	width: 100%;
}

.zenth-shop-catalog .zenth-shop-grid__pagination--pill {
	align-self: center;
}

/* Botones de la paginación pill — sin recuadros, solo texto */
.zenth-shop-grid__pagination--pill .zenth-shop-pagination__btn {
	min-width: 32px;
	height: 32px;
	background: transparent;
	border: none;
	border-radius: 50%;
	color: var(--cr-color-text-muted, rgba(255, 255, 255, 0.6));
	font-family: var(--cr-font-body, 'Montserrat', sans-serif);
	font-size: 13px;
	font-weight: 500;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background 200ms ease, color 200ms ease;
	padding: 0;
}

.zenth-shop-grid__pagination--pill .zenth-shop-pagination__btn:hover:not(:disabled):not(.is-disabled) {
	background: transparent;
	color: var(--cr-color-text, #fff);
}

/* Página activa: número subrayado */
.zenth-shop-grid__pagination--pill .zenth-shop-pagination__btn--active {
	color: var(--cr-color-text, #fff);
	font-weight: 700;
	position: relative;
}

.zenth-shop-grid__pagination--pill .zenth-shop-pagination__btn--active::after {
	content: "";
	position: absolute;
	left: 25%;
	right: 25%;
	bottom: 6px;
	height: 2px;
	background: var(--cr-color-text, #fff);
}

/* Botones prev/next con icono */
.zenth-shop-grid__pagination--pill .zenth-shop-pagination__btn--prev,
.zenth-shop-grid__pagination--pill .zenth-shop-pagination__btn--next {
	color: var(--cr-color-text, #fff);
}

.zenth-shop-grid__pagination--pill .zenth-shop-pagination__btn--prev:hover:not(:disabled):not(.is-disabled),
.zenth-shop-grid__pagination--pill .zenth-shop-pagination__btn--next:hover:not(:disabled):not(.is-disabled) {
	background: var(--cr-color-primary, #c00000);
	color: #fff;
}

.zenth-shop-grid__pagination--pill .zenth-shop-pagination__btn--prev.is-disabled,
.zenth-shop-grid__pagination--pill .zenth-shop-pagination__btn--next.is-disabled,
.zenth-shop-grid__pagination--pill .zenth-shop-pagination__btn:disabled {
	opacity: 0.3;
	cursor: not-allowed;
}

.zenth-shop-grid__pagination--pill .zenth-shop-pagination__ellipsis {
	color: var(--cr-color-text-muted, rgba(255, 255, 255, 0.4));
	padding: 0 4px;
}


/* ═══════════════════════════════════════════════════════════════════════
   §9 · SWATCHES DE COLOR
   ───────────────────────────────────────────────────────────────────────
   Solo se renderizan si el producto tiene atributo pa_color.
   ═══════════════════════════════════════════════════════════════════════ */

.zenth-shop-card__swatches {
	display: flex;
	align-items: center;
	gap: 7px;
	margin-top: 10px;
	flex-wrap: wrap;
}

.zenth-shop-card__swatch {
	width: 14px;
	height: 14px;
	border-radius: 50%;
	border: 1px solid rgba(255, 255, 255, 0.25);
	background: var(--swatch-color, #888);
	display: inline-block;
	flex-shrink: 0;
	cursor: default;
	transition: transform 200ms ease, border-color 200ms ease;
}

.zenth-shop-card__swatch:hover {
	transform: scale(1.18);
	border-color: rgba(255, 255, 255, 0.6);
}

/* Para colores claros (blanco), el borde necesita ser más oscuro */
.zenth-shop-card__swatch--light {
	border-color: rgba(255, 255, 255, 0.35);
}

/* Si hay más de N colores, mostrar contador "+N" */
.zenth-shop-card__swatch--more {
	background: transparent;
	border-color: rgba(255, 255, 255, 0.3);
	color: rgba(255, 255, 255, 0.6);
	font-family: var(--cr-font-body, 'Montserrat', sans-serif);
	font-size: 9px;
	font-weight: 700;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: auto;
	min-width: 22px;
	height: 14px;
	border-radius: 999px;
	padding: 0 6px;
}


/* ═══════════════════════════════════════════════════════════════════════
   §10 · RESPONSIVE — todos los @media, de más ancho a más angosto
   ───────────────────────────────────────────────────────────────────────
   Tiers:  Tablet (≤1024) → Mobile catálogo (≤767) → Mobile base (≤640)
   El cascade max-width va de mayor a menor. Las reglas base de cada
   componente quedan ANTES (en §1–§9). Al final, subsección de
   ACCESIBILIDAD/CAPACIDAD (hover + 2× prefers-reduced-motion), que NO son
   breakpoints de tamaño y NO se consolidan.
   ═══════════════════════════════════════════════════════════════════════ */

/* ───────────────────────── TABLET · max-width: 1024px ─────────────────── */
@media (max-width: 1024px) {
	/* §3 · Grid base + §2 · Toolbar base: menos columnas, search a fila propia */
	.zenth-shop-grid__items,
	.zenth-shop-grid__loading {
		grid-template-columns: repeat(var(--zsg-cols-tablet, 3), 1fr);
		gap: 20px;
	}

	.zenth-shop-toolbar__row {
		gap: 10px;
	}

	.zenth-shop-toolbar__search {
		min-width: 200px;
		flex: 1 1 100%;
		order: 99;
	}
}

/* §8 · Catálogo (card) en TABLET — títulos/precios un punto más chicos */
@media (max-width: 1024px) {
	.zenth-shop-card--catalog .zenth-shop-card__title {
		font-size: 13px;
	}
	.zenth-shop-card--catalog .zenth-shop-card__price {
		font-size: 13px;
	}
}


/* ───────────────────────── MOBILE · max-width: 767px ──────────────────── */
@media (max-width: 767px) {
	/* §8 · Toolbar inline: stack vertical en mobile, contador centrado abajo */
	.zenth-shop-catalog .zenth-shop-toolbar--inline .zenth-shop-toolbar__row {
		grid-template-columns: 1fr 1fr;
		grid-template-areas:
			"filters sort"
			"count count";
		gap: 12px 16px;
	}

	.zenth-shop-toolbar__filters-btn--inline {
		grid-area: filters;
	}

	.zenth-shop-catalog .zenth-shop-toolbar__count {
		grid-area: count;
		justify-self: center;
		font-size: 12px;
	}

	.zenth-shop-toolbar__sort--inline {
		grid-area: sort;
	}

	/* §8 · Card content tighter en mobile */
	.zenth-shop-card--catalog .zenth-shop-card__body {
		padding-top: 10px;
	}

	.zenth-shop-card--catalog .zenth-shop-card__title {
		font-size: 12px;
	}

	.zenth-shop-card--catalog .zenth-shop-card__price {
		font-size: 12px;
	}

	/* §8 · CTA siempre visible en touch (sin hover) */
	.zenth-shop-card__hover-cta {
		padding: 10px;
	}

	.zenth-shop-card--catalog .zenth-shop-card__atc {
		padding: 8px 12px;
		font-size: 10px;
	}

	/* §8 · Paginación pill compacta */
	.zenth-shop-grid__pagination--pill {
		padding: 6px 10px;
	}

	.zenth-shop-grid__pagination--pill .zenth-shop-pagination__btn {
		min-width: 28px;
		height: 28px;
		font-size: 12px;
	}
}


/* ─────────────────────────── MOBILE · max-width: 640px ────────────────── */
@media (max-width: 640px) {
	/* §3 · Grid base: 2 columnas */
	.zenth-shop-grid {
		margin: 24px 0;
	}

	.zenth-shop-grid__items,
	.zenth-shop-grid__loading {
		grid-template-columns: repeat(var(--zsg-cols-mobile, 2), 1fr);
		gap: 12px;
	}

	/* §2 · Toolbar base compacta */
	.zenth-shop-toolbar {
		padding: 12px 0;
	}

	.zenth-shop-toolbar__row {
		gap: 8px;
	}

	.zenth-shop-toolbar__filters-btn {
		padding: 8px 12px;
		font-size: 13px;
	}

	.zenth-shop-toolbar__count {
		flex: 1 1 100%;
		order: 100;
		font-size: 12px;
	}

	.zenth-shop-toolbar__search {
		min-width: 0;
	}

	.zenth-shop-toolbar__sort-label {
		display: none;
	}

	.zenth-shop-toolbar__sort-select {
		padding: 8px 28px 8px 10px;
		font-size: 13px;
	}

	/* §4 · Cards más compactas en mobile */
	.zenth-shop-card__title {
		font-size: 13px;
	}

	.zenth-shop-card__price {
		font-size: 14px;
	}

	.zenth-shop-card__atc {
		padding: 8px 10px;
		font-size: 12px;
	}

	.zenth-shop-card__atc-label {
		display: none;
	}

	.zenth-shop-card__atc--variable .zenth-shop-card__atc-label,
	.zenth-shop-card__atc--disabled {
		display: inline;
	}

	/* §6 · Paginación compacta en mobile */
	.zenth-shop-pagination__btn {
		min-width: 36px;
		height: 36px;
		font-size: 13px;
	}
}


/* ───────────────────────────────────────────────────────────────────────
   ACCESIBILIDAD / CAPACIDAD — NO consolidar, contenido intacto
   ─────────────────────────────────────────────────────────────────────── */

/* §8 · Hover real (no touch): CTA del catálogo oculta por default, aparece
   en hover. La regla base (§8) deja el ATC visible; esta media lo esconde
   solo en dispositivos con hover+puntero fino. */
@media (hover: hover) and (pointer: fine) {
	.zenth-shop-card--catalog .zenth-shop-card__atc {
		opacity: 0;
		transform: translateY(10px);
		pointer-events: none;
	}

	.zenth-shop-card--catalog:hover .zenth-shop-card__atc,
	.zenth-shop-card--catalog:focus-within .zenth-shop-card__atc {
		opacity: 1;
		transform: translateY(0);
		pointer-events: auto;
	}
}

/* §8 · Reduce motion: corta transiciones/scale del catálogo */
@media (prefers-reduced-motion: reduce) {
	.zenth-shop-card--catalog .zenth-shop-card__img,
	.zenth-shop-card--catalog .zenth-shop-card__atc,
	.zenth-shop-pagination__btn {
		transition: none !important;
	}
	.zenth-shop-card--catalog:hover .zenth-shop-card__img--primary {
		transform: none !important;
	}
}

/* §9 · Reduce motion: corta la transición del swatch */
@media (prefers-reduced-motion: reduce) {
	.zenth-shop-card__swatch {
		transition: none !important;
	}
}
