/**
 * Zenth Toolkit — Reseñas (widget "Zenth Reseñas").
 *
 * Grid/carousel de cards de testimonio. El contenido se gestiona desde el CPT
 * cr_review; el header de la sección (eyebrow + título) se arma en Elementor.
 * Standalone: usa var(--cr-*, fallback) para funcionar sin el theme. Prefijo
 * `zenth-reviews__*` para no colisionar con `.cr-testimonial-*` (theme).
 *
 * ─────────────────────────────────────────────────────────────────────────
 * ÍNDICE
 *   §1  Wrapper / base    → anti-colapso + .zenth-reviews (tokens) + glow ::before
 *   §2  Barra de agregado → __aggregate ("★ 4.9 · 24 reseñas")
 *   §3  Grid              → __grid
 *   §4  Card              → __card + head/avatar/id/name/chip/text/foot/stars/date
 *   §5  Carrusel          → __carousel / __viewport / __track / __dots
 *                           (arrastrable + infinito, sin flechas; dots = JS)
 *   §6  CTA               → __cta-wrap / __cta ("Déjanos tu reseña en Google")
 *   §7  Bloque producto   → .zenth-reviews-product (schema visible)
 *   §8  Responsive        → TODOS los @media de tamaño consolidados acá
 *   §9  Accesibilidad     → prefers-reduced-motion
 * ─────────────────────────────────────────────────────────────────────────
 * BREAKPOINTS (desktop es la base, sin media query)
 *   Tablet        → max-width: 1024px   (grid/carousel pasan a 2 columnas)
 *   Mobile        → max-width: 767px     (1 columna, alineado a Elementor)
 *
 *   Los @media de tamaño viven en §8, de más ancho a más angosto. La media
 *   de accesibilidad (prefers-reduced-motion) va aparte en §9 y NO se
 *   consolida con las de tamaño.
 * ─────────────────────────────────────────────────────────────────────────
 * Tokens locales (definidos en .zenth-reviews)
 *   --zrev-cols-desktop / --zrev-cols-tablet / --zrev-cols-mobile
 *   --zrev-gap            gap del grid/carousel
 *   --zrev-card-bg        fondo de la card (default --cr-color-darker)
 *   --zrev-card-border    borde de la card
 *   --zrev-star           color de la estrella activa
 * ─────────────────────────────────────────────────────────────────────────
 */


/* ═══════════════════════════════════════════════════════════════════════
   §1 · WRAPPER / BASE
   ═══════════════════════════════════════════════════════════════════════ */

/* Anti-colapso: el widget puede vivir dentro de un contenedor flex con
   align-items:center (p. ej. .cr-section--center), que encogería su wrapper. */
.elementor-widget-zenth_reviews {
	width: 100% !important;
}

.zenth-reviews {
	--zrev-cols-desktop: 3;
	--zrev-cols-tablet: 2;
	--zrev-cols-mobile: 1;
	--zrev-gap: 24px;
	--zrev-card-bg: var(--cr-color-darker, #0f0f0f);
	--zrev-card-border: rgba(255, 255, 255, 0.08);
	--zrev-star: #f5a623;

	position: relative;
	box-sizing: border-box;
	width: 100%;
	max-width: min(1200px, 100%);
	margin-inline: auto;
	padding-inline: var(--cr-container-pad, 32px);
}

.zenth-reviews *,
.zenth-reviews *::before,
.zenth-reviews *::after {
	box-sizing: border-box;
}

/* Glow rojo radial detrás de la fila de cards (como el mockup). */
.zenth-reviews::before {
	content: '';
	position: absolute;
	left: 50%;
	top: 55%;
	transform: translate(-50%, -50%);
	width: min(960px, 92%);
	height: 80%;
	background: radial-gradient(ellipse at center, rgba(192, 0, 0, 0.22), rgba(192, 0, 0, 0) 68%);
	pointer-events: none;
	z-index: 0;
}


/* ═══════════════════════════════════════════════════════════════════════
   §2 · BARRA DE AGREGADO ("★ 4.9 · 24 reseñas")
   ═══════════════════════════════════════════════════════════════════════ */

.zenth-reviews__aggregate {
	position: relative;
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 10px;
	margin: 0 0 32px;
	color: var(--cr-color-text, #fff);
	font-family: var(--cr-font-body, system-ui, sans-serif);
}

.zenth-reviews__aggregate-score {
	font-size: 1.5rem;
	font-weight: 800;
	line-height: 1;
}

.zenth-reviews__aggregate-count {
	color: var(--cr-color-text-muted, #81817f);
	font-size: 0.9375rem;
}


/* ═══════════════════════════════════════════════════════════════════════
   §3 · GRID
   ═══════════════════════════════════════════════════════════════════════ */

.zenth-reviews__grid {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: repeat(var(--zrev-cols-desktop), minmax(0, 1fr));
	gap: var(--zrev-gap);
}


/* ═══════════════════════════════════════════════════════════════════════
   §4 · CARD
   ═══════════════════════════════════════════════════════════════════════ */

.zenth-reviews__card {
	display: flex;
	flex-direction: column;
	gap: 18px;
	padding: 26px 26px 22px;
	background: var(--zrev-card-bg);
	border: 1px solid var(--zrev-card-border);
	border-radius: 16px;
	transition: transform var(--cr-transition-base, 250ms ease),
				border-color var(--cr-transition-base, 250ms ease),
				box-shadow var(--cr-transition-base, 250ms ease);
}

.zenth-reviews__card:hover {
	transform: translateY(-4px);
	border-color: var(--cr-color-primary, #c00000);
	box-shadow: 0 16px 40px rgba(0, 0, 0, 0.45);
}

/* Header: avatar + nombre/subtítulo + chip de servicio. */
.zenth-reviews__head {
	display: flex;
	align-items: flex-start;
	gap: 12px;
}

.zenth-reviews__avatar {
	flex: 0 0 auto;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	object-fit: cover;
	background: #1a1a1a;
}

.zenth-reviews__avatar--initials {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-family: var(--cr-font-body, system-ui, sans-serif);
	font-size: 0.95rem;
	font-weight: 700;
	background: linear-gradient(135deg, var(--cr-color-primary, #c00000) 0%, var(--cr-color-primary-dark, #8b0000) 100%);
}

.zenth-reviews__id {
	flex: 1 1 auto;
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.zenth-reviews__name {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: var(--cr-color-text, #fff);
	font-family: var(--cr-font-body, system-ui, sans-serif);
	font-size: 0.95rem;
	font-weight: 700;
	line-height: 1.2;
}

.zenth-reviews__verified {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 16px;
	height: 16px;
	border-radius: 50%;
	color: #fff;
	background: var(--cr-color-primary, #c00000);
}

.zenth-reviews__verified svg {
	width: 10px;
	height: 10px;
}

.zenth-reviews__subtitle {
	color: var(--cr-color-text-muted, #81817f);
	font-family: var(--cr-font-body, system-ui, sans-serif);
	font-size: 0.8125rem;
	line-height: 1.3;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

/* Chip de servicio (pill roja, arriba a la derecha). */
.zenth-reviews__chip {
	flex: 0 0 auto;
	align-self: flex-start;
	padding: 5px 12px;
	border-radius: 999px;
	background: var(--cr-color-primary, #c00000);
	color: #fff;
	font-family: var(--cr-font-body, system-ui, sans-serif);
	font-size: 0.6875rem;
	font-weight: 600;
	line-height: 1.2;
	white-space: nowrap;
}

/* Texto de la reseña. */
.zenth-reviews__text {
	flex: 1 1 auto;
	color: var(--cr-color-text-dim, rgba(255, 255, 255, 0.78));
	font-family: var(--cr-font-body, system-ui, sans-serif);
	font-size: 0.9375rem;
	line-height: 1.6;
}

.zenth-reviews__text > :first-child {
	margin-top: 0;
}

.zenth-reviews__text > :last-child {
	margin-bottom: 0;
}

/* Footer: estrellas + fecha. */
.zenth-reviews__foot {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin-top: auto;
}

.zenth-reviews__stars {
	display: inline-flex;
	gap: 2px;
	font-size: 1rem;
	line-height: 1;
	letter-spacing: 1px;
}

.zenth-reviews__star {
	color: rgba(255, 255, 255, 0.18);
}

.zenth-reviews__star.is-on {
	color: var(--zrev-star);
}

.zenth-reviews__date {
	color: var(--cr-color-text-muted, #81817f);
	font-family: var(--cr-font-body, system-ui, sans-serif);
	font-size: 0.8125rem;
}


/* ═══════════════════════════════════════════════════════════════════════
   §5 · CARRUSEL
   ═══════════════════════════════════════════════════════════════════════ */

/* Carrusel arrastrable + infinito + dots (sin flechas). El track lo mueve el
   JS con translateX; el viewport recorta. NO usa scroll nativo. */
.zenth-reviews__carousel {
	position: relative;
	z-index: 1;
}

/* Viewport: ventana que recorta el track. */
.zenth-reviews__viewport {
	overflow: hidden;
	width: 100%;
}

/* Track: fila de cards. transform + transition los maneja el JS. */
.zenth-reviews__track {
	display: flex;
	gap: var(--zrev-gap);
	will-change: transform;
	cursor: grab;
	touch-action: pan-y;   /* drag horizontal = carrusel; vertical = scroll de la página */
	transition: transform var(--cr-transition-slow, 400ms cubic-bezier(0.4, 0, 0.2, 1));
}

.zenth-reviews__track.is-dragging {
	cursor: grabbing;
	transition: none;      /* el drag sigue al puntero sin animación */
	-webkit-user-select: none;
	        user-select: none;
}

/* Card del carrusel: ancho = N columnas, SIN peek. Mobile (1 col) = 100%
   (= una card centrada). Las basis por dispositivo van en §8.
   touch-action: pan-y → el drag horizontal lo maneja el JS; el scroll
   vertical de la página sigue funcionando sobre las cards. */
.zenth-reviews--carousel .zenth-reviews__card {
	flex: 0 0 calc((100% - (var(--zrev-cols-desktop) - 1) * var(--zrev-gap)) / var(--zrev-cols-desktop));
	touch-action: pan-y;
}

/* Clones del loop infinito: idénticas pero fuera del foco/lectores. */
.zenth-reviews__card.is-clone {
	pointer-events: none;
}

/* En carrusel el viewport recorta (overflow:hidden), así que el hover NO debe
   levantar ni proyectar sombra (se cortaría). Mantenemos solo el borde rojo. */
.zenth-reviews--carousel .zenth-reviews__card:hover {
	transform: none;
	box-shadow: none;
}


/* Dots — mismo estilo que el widget Razones. Los genera reviews.js. */
.zenth-reviews__dots {
	position: relative;
	z-index: 1;
	display: flex;
	justify-content: center;
	gap: 8px;
	margin-top: clamp(20px, 2.5vw, 32px);
}

.zenth-reviews__dot {
	-webkit-appearance: none;
	appearance: none;
	width: 9px;
	height: 9px;
	padding: 0;
	border: 0;
	border-radius: 999px;
	background: #474747;
	cursor: pointer;
	transition: background 250ms ease, width 250ms ease;
}

.zenth-reviews__dot.is-active {
	width: 26px;
	background: var(--cr-color-primary, #c00000);
}

.zenth-reviews__dot:focus-visible {
	outline: 2px solid var(--cr-color-white, #fff);
	outline-offset: 2px;
}

/* Reset del fondo "rosado" del tema padre en :focus/:hover (son <button type=button>). */
button.zenth-reviews__dot:focus,
button.zenth-reviews__dot:hover { background-color: #474747; }
button.zenth-reviews__dot.is-active:focus,
button.zenth-reviews__dot.is-active:hover { background-color: var(--cr-color-primary, #c00000); }


/* ═══════════════════════════════════════════════════════════════════════
   §6 · CTA "Déjanos tu reseña en Google"
   ═══════════════════════════════════════════════════════════════════════ */

.zenth-reviews__cta-wrap {
	position: relative;
	z-index: 1;
	display: flex;
	justify-content: center;
	margin-top: 40px;
}

.zenth-reviews__cta {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 14px 28px;
	border: 1.5px solid rgba(255, 255, 255, 0.25);
	border-radius: 999px;
	background: transparent;
	color: var(--cr-color-text, #fff);
	font-family: var(--cr-font-body, system-ui, sans-serif);
	font-size: 0.875rem;
	font-weight: 600;
	text-decoration: none;
	transition: background var(--cr-transition-base, 250ms ease),
				border-color var(--cr-transition-base, 250ms ease),
				transform var(--cr-transition-base, 250ms ease);
}

.zenth-reviews__cta:hover {
	background: var(--cr-color-primary, #c00000);
	border-color: var(--cr-color-primary, #c00000);
	transform: translateY(-2px);
}

.zenth-reviews__cta-icon {
	color: var(--zrev-star);
}

.zenth-reviews__cta:hover .zenth-reviews__cta-icon {
	color: #fff;
}


/* ═══════════════════════════════════════════════════════════════════════
   §7 · BLOQUE EN LA PÁGINA DE PRODUCTO (schema visible)
   ═══════════════════════════════════════════════════════════════════════ */

.zenth-reviews-product {
	margin: 48px 0;
}

.zenth-reviews-product__title {
	margin: 0 0 28px;
	text-align: center;
	color: var(--cr-color-text, #fff);
	font-family: var(--cr-font-display, var(--cr-font-heading, sans-serif));
	font-size: clamp(1.75rem, 1.2rem + 2vw, 2.75rem);
	font-weight: 400;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}


/* ═══════════════════════════════════════════════════════════════════════
   §8 · RESPONSIVE — todos los @media de tamaño, de más ancho a más angosto
   ───────────────────────────────────────────────────────────────────────
   Tiers:  Tablet (≤1024) → Mobile (≤767)
   El cascade max-width va de mayor a menor.
   ═══════════════════════════════════════════════════════════════════════ */

/* ───────────────────────── TABLET · max-width: 1024px ─────────────────── */
@media (max-width: 1024px) {
	.zenth-reviews__grid {
		grid-template-columns: repeat(var(--zrev-cols-tablet), minmax(0, 1fr));
	}

	.zenth-reviews--carousel .zenth-reviews__card {
		flex-basis: calc((100% - (var(--zrev-cols-tablet) - 1) * var(--zrev-gap)) / var(--zrev-cols-tablet));
	}
}

/* ───────────────────────── MOBILE · max-width: 767px ──────────────────── */
@media (max-width: 767px) {
	.zenth-reviews__grid {
		grid-template-columns: repeat(var(--zrev-cols-mobile), minmax(0, 1fr));
	}

	/* Carrusel mobile: UNA card al ancho del viewport (sin peek), centrada. */
	.zenth-reviews--carousel .zenth-reviews__card {
		flex-basis: calc((100% - (var(--zrev-cols-mobile) - 1) * var(--zrev-gap)) / var(--zrev-cols-mobile));
	}
}


/* ═══════════════════════════════════════════════════════════════════════
   §9 · ACCESIBILIDAD — prefers-reduced-motion
   ═══════════════════════════════════════════════════════════════════════ */

@media (prefers-reduced-motion: reduce) {
	.zenth-reviews__card,
	.zenth-reviews__cta,
	.zenth-reviews__track,
	.zenth-reviews__dot {
		transition: none;
	}
}
