/* ========================================================================
   INDEX1 - Tokens de diseño + Estilos AVA + Popup destacado + App Download
   ======================================================================== */

/* ---------- TOKENS DE DISEÑO GMV ----------
   Prefijo --gmv-* para evitar colisiones con bootstrap u otros sistemas.
   Si en el futuro se usan en más páginas, mover a un css/gmv_tokens.css. */
:root {
	/* Paleta principal */
	--gmv-coral: #e65742;
	--gmv-coral-hover: #d04a36;
	--gmv-coral-dark: #b73c2a;
	--gmv-coral-soft: #fff5f3;
	--gmv-coral-soft-2: #ffe8e3;

	/* Gradiente histórico de la marca (admin uses this) */
	--gmv-gradient: linear-gradient(to right, #11376f, #5f3a7f, #9c367b, #cc3a65, #e65742);

	/* Acento dorado (oferta relámpago) */
	--gmv-gold: #f1c40f;
	--gmv-gold-dark: #d4a40c;

	/* Texto */
	--gmv-text: #2c3e50;
	--gmv-text-muted: #555;
	--gmv-text-light: #979797;
	--gmv-text-dark: #000;

	/* Fondos */
	--gmv-bg: #ffffff;
	--gmv-bg-soft: #f9f9f9;
	--gmv-bg-section: var(--gmv-coral-soft);

	/* Spacing scale (multiplos de 4px) */
	--gmv-space-xs: 4px;
	--gmv-space-sm: 8px;
	--gmv-space-md: 16px;
	--gmv-space-lg: 24px;
	--gmv-space-xl: 40px;
	--gmv-space-2xl: 64px;

	/* Radius */
	--gmv-radius-sm: 6px;
	--gmv-radius-md: 12px;
	--gmv-radius-lg: 16px;
	--gmv-radius-xl: 24px;
	--gmv-radius-pill: 999px;

	/* Sombras */
	--gmv-shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.08);
	--gmv-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.1);
	--gmv-shadow-lg: 0 12px 32px rgba(0, 0, 0, 0.12);
	--gmv-shadow-coral: 0 8px 24px rgba(230, 87, 66, 0.18);

	/* Transiciones */
	--gmv-transition-fast: 0.15s ease;
	--gmv-transition-base: 0.25s ease;
	--gmv-transition-slow: 0.4s ease;

	/* Tipografía */
	--gmv-font: 'Quicksand', sans-serif;

	/* Z-index scale */
	--gmv-z-ava: 9998;
	--gmv-z-popup: 10000;
}

/* ========================================================================
   HERO del paquete recomendado / oferta relámpago
   ======================================================================== */
.gmv-hero {
	margin: var(--gmv-space-2xl) 0 var(--gmv-space-2xl);
	font-family: var(--gmv-font);
}

/* ----- Encabezado (recomendado u oferta relámpago) ----- */
.gmv-hero__head {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--gmv-space-md);
	padding: var(--gmv-space-md) var(--gmv-space-lg);
	margin-bottom: var(--gmv-space-lg);
	background: var(--gmv-bg-section);
	border-radius: var(--gmv-radius-lg);
}

.gmv-hero__head-title {
	font-family: var(--gmv-font);
	font-weight: 700;
	font-size: 1.5rem;
	color: var(--gmv-coral);
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.gmv-hero__head-content {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 2px;
}

/* ============================================================
   OFERTA RELÁMPAGO — Cabecera dramática
   ============================================================ */
.gmv-hero__head--or {
	position: relative;
	padding: var(--gmv-space-lg) var(--gmv-space-xl);
	background: linear-gradient(135deg, #ff6b35 0%, #e65742 35%, #c73e2c 70%, #f5b301 100%);
	border: none;
	border-radius: var(--gmv-radius-xl);
	box-shadow:
		0 10px 30px rgba(230, 87, 66, 0.35),
		0 0 0 2px rgba(255, 217, 59, 0.4),
		inset 0 1px 0 rgba(255, 255, 255, 0.2);
	overflow: hidden;
	gap: var(--gmv-space-lg);
	justify-content: flex-start;
	flex-wrap: wrap;
	animation: orHeadGlow 3s ease-in-out infinite;
}

/* Patrón de líneas diagonales sutiles para dar textura */
.gmv-hero__head--or::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(
		45deg,
		transparent,
		transparent 14px,
		rgba(255, 255, 255, 0.06) 14px,
		rgba(255, 255, 255, 0.06) 28px
	);
	pointer-events: none;
	z-index: 0;
}

@keyframes orHeadGlow {
	0%, 100% {
		box-shadow:
			0 10px 30px rgba(230, 87, 66, 0.35),
			0 0 0 2px rgba(255, 217, 59, 0.4),
			inset 0 1px 0 rgba(255, 255, 255, 0.2);
	}
	50% {
		box-shadow:
			0 14px 38px rgba(230, 87, 66, 0.5),
			0 0 0 3px rgba(255, 217, 59, 0.7),
			inset 0 1px 0 rgba(255, 255, 255, 0.2);
	}
}

.gmv-hero__head--or .gmv-hero__head-content {
	position: relative;
	z-index: 1;
	flex: 1;
	min-width: 0;
}

.gmv-hero__head--or .gmv-hero__head-title {
	color: #fff;
	font-size: clamp(1.5rem, 3vw, 2.1rem);
	font-weight: 800;
	letter-spacing: 1px;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.25), 0 0 30px rgba(255, 217, 59, 0.5);
	line-height: 1.1;
	margin: 0;
}

.gmv-hero__head-subtitle {
	font-family: var(--gmv-font);
	font-size: 0.95rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.95);
	font-style: italic;
	margin: 2px 0 0;
	text-shadow: 0 1px 3px rgba(0, 0, 0, 0.25);
	line-height: 1.2;
}

/* Badge ⚡ con halo radiante y pulso intenso */
.gmv-hero__head-badge {
	position: relative;
	z-index: 1;
	width: 64px;
	height: 64px;
	border-radius: 50%;
	background: radial-gradient(circle at 30% 30%, #fff8d6 0%, #ffd93b 50%, #f5b301 100%);
	color: #c73e2c;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2rem;
	flex-shrink: 0;
	box-shadow:
		0 6px 16px rgba(0, 0, 0, 0.25),
		inset 0 1px 2px rgba(255, 255, 255, 0.6);
	animation: orBadgePulse 1.4s ease-in-out infinite;
}

/* Halo brillante alrededor del badge */
.gmv-hero__head-badge::before {
	content: '';
	position: absolute;
	inset: -8px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(255, 217, 59, 0.6) 0%, transparent 70%);
	z-index: -1;
	animation: orBadgeHalo 1.4s ease-in-out infinite;
}

@keyframes orBadgePulse {
	0%, 100% { transform: scale(1); }
	50% { transform: scale(1.08); }
}

@keyframes orBadgeHalo {
	0%, 100% { opacity: 0.5; transform: scale(1); }
	50% { opacity: 1; transform: scale(1.2); }
}

.gmv-hero__head--or .gmv-hero__head-badge i {
	filter: drop-shadow(0 1px 2px rgba(0, 0, 0, 0.15));
}

/* ----- Cuerpo del hero ----- */
.gmv-hero__body {
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: var(--gmv-space-xl);
	align-items: center;
}

/* Variante CON video: columna media compacta pero fluida */
.gmv-hero--video .gmv-hero__body {
	grid-template-columns: minmax(0, 0.7fr) minmax(0, 1.3fr);
	justify-content: center;
	justify-items: center;
}

/* Video acotado para no crecer demasiado en altura (9:16 puede ser muy vertical) */
.gmv-hero--video .gmv-hero__media {
	max-width: 320px;
	width: 100%;
	margin: 0 auto;
}

/* Variante con FOTO: layout horizontal clásico */
.gmv-hero--foto .gmv-hero__body {
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

/* ----- Media column ----- */
.gmv-hero__media {
	position: relative;
	width: 100%;
	background: transparent;
	/* overflow visible para que el logo pueda asomar fuera */
}

.gmv-hero__media-link {
	display: block;
	text-decoration: none;
	color: inherit;
	border-radius: var(--gmv-radius-lg);
	overflow: hidden;
	box-shadow: var(--gmv-shadow-lg);
	background: var(--gmv-bg-soft);
}

/* Logo GMV centrado abajo, mitad sobre la imagen y mitad fuera */
.gmv-hero__logo {
	position: absolute;
	left: 50%;
	bottom: -55px;
	transform: translateX(-50%);
	width: 110px;
	height: 110px;
	border-radius: 50%;
	background: #fff;
	padding: 3px;
	box-sizing: border-box;
	box-shadow: var(--gmv-shadow-md);
	object-fit: contain;
	z-index: 5;
}

/* Responsive: logo un poco más chico en mobile */
@media (max-width: 600px) {
	.gmv-hero__logo {
		width: 90px;
		height: 90px;
		bottom: -45px;
		padding: 2px;
	}
}

.gmv-hero__video {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 9 / 16;
	object-fit: cover;
	background: #000;
}

.gmv-hero__photo {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 3 / 2;
	object-fit: cover;
	transition: transform var(--gmv-transition-slow);
}

.gmv-hero__media:hover .gmv-hero__photo {
	transform: scale(1.03);
}

/* % OFF badge sobre el media */
.gmv-hero__pct-badge {
	position: absolute;
	top: var(--gmv-space-md);
	left: var(--gmv-space-md);
	background: var(--gmv-coral);
	color: #fff;
	padding: var(--gmv-space-xs) var(--gmv-space-md);
	border-radius: var(--gmv-radius-pill);
	font-weight: 700;
	font-size: 0.95rem;
	box-shadow: var(--gmv-shadow-coral);
	letter-spacing: 0.5px;
	z-index: 2;
}

/* Botón toggle sonido */
.gmv-hero__sound-btn {
	position: absolute;
	bottom: var(--gmv-space-md);
	right: var(--gmv-space-md);
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.85);
	color: var(--gmv-text-dark);
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	box-shadow: var(--gmv-shadow-md);
	transition: all var(--gmv-transition-base);
	backdrop-filter: blur(4px);
	-webkit-backdrop-filter: blur(4px);
	z-index: 2;
}

.gmv-hero__sound-btn:hover,
.gmv-hero__sound-btn:focus-visible {
	background: #fff;
	transform: scale(1.08);
	outline: none;
}

.gmv-hero__sound-btn.is-active {
	background: var(--gmv-coral);
	color: #fff;
}

.gmv-hero__sound-icon { display: none; }
.gmv-hero__sound-btn .gmv-hero__sound-icon--mute { display: block; }
.gmv-hero__sound-btn.is-active .gmv-hero__sound-icon--mute { display: none; }
.gmv-hero__sound-btn.is-active .gmv-hero__sound-icon--on { display: block; }

/* ----- Info column ----- */
.gmv-hero__info {
	display: flex;
	flex-direction: column;
	gap: var(--gmv-space-sm);
	padding: var(--gmv-space-md) 0;
}

.gmv-hero__chip {
	display: inline-flex;
	align-items: center;
	align-self: center;
	background: var(--gmv-coral);
	color: #fff;
	padding: 6px 14px;
	border-radius: var(--gmv-radius-pill);
	font-size: 0.75rem;
	line-height: 1;
	font-weight: 700;
	letter-spacing: 1.2px;
	text-transform: uppercase;
	box-shadow: var(--gmv-shadow-sm);
	min-height: 32px;
	box-sizing: border-box;
}

.gmv-hero__title {
	font-family: var(--gmv-font);
	font-weight: 700;
	font-size: clamp(1.7rem, 3.5vw, 2.6rem);
	color: var(--gmv-text);
	line-height: 1.1;
	margin: var(--gmv-space-xs) 0 0;
	text-transform: uppercase;
	letter-spacing: -0.5px;
}

.gmv-hero__subtitle {
	font-family: var(--gmv-font);
	font-weight: 500;
	font-size: 1.15rem;
	color: var(--gmv-coral);
	margin: 0;
	line-height: 1.35;
	font-style: italic;
}

/* ----- Meta (Salida + Noches) con iconos en pills ----- */
.gmv-hero__meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--gmv-space-sm);
	margin: var(--gmv-space-xs) 0;
}

.gmv-hero__meta-item {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: var(--gmv-coral-soft);
	color: var(--gmv-text);
	padding: 6px 12px;
	border-radius: var(--gmv-radius-pill);
	font-size: 0.9rem;
	font-weight: 500;
	border: 1px solid rgba(230, 87, 66, 0.15);
	min-height: 32px;
	box-sizing: border-box;
}

.gmv-hero__meta-item svg {
	color: var(--gmv-coral);
	flex-shrink: 0;
}

.gmv-hero__meta-item strong {
	color: var(--gmv-text);
	font-weight: 700;
}

.gmv-hero__desc {
	font-family: var(--gmv-font);
	color: var(--gmv-text-muted);
	font-size: 1rem;
	line-height: 1.55;
	margin: var(--gmv-space-xs) 0;
}

/* dto-overlay: chip de financiación encima de la imagen, top-right.
   Cuando hay un .gmv-hero__pct-badge (oferta relámpago) en top-left, el max-width 50%
   garantiza que no se superpongan ni en pantallas chicas. */
.gmv-hero__dto-overlay {
	position: absolute;
	top: var(--gmv-space-md);
	right: var(--gmv-space-md);
	max-width: calc(100% - 130px); /* deja siempre ≥130px libres a la izquierda para el % OFF */
	background: var(--gmv-coral);
	color: #fff;
	padding: 8px 14px;
	border-radius: var(--gmv-radius-pill);
	font-family: var(--gmv-font);
	font-weight: 700;
	font-size: 0.85rem;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	box-shadow: var(--gmv-shadow-coral);
	text-align: center;
	line-height: 1.2;
	z-index: 3;
}

@media (max-width: 600px) {
	.gmv-hero__dto-overlay {
		font-size: 0.7rem;
		padding: 6px 10px;
		max-width: calc(100% - 110px);
	}
}

/* ----- Bloque de precio mejorado ----- */
.gmv-hero__price-block {
	margin: var(--gmv-space-sm) 0;
	padding-top: var(--gmv-space-sm);
	border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.gmv-hero__price-before {
	margin: 0 0 4px;
	display: flex;
	align-items: baseline;
	gap: 6px;
	color: var(--gmv-text-light);
	font-size: 0.9rem;
}

.gmv-hero__price-before-label {
	text-transform: uppercase;
	font-weight: 600;
	letter-spacing: 0.5px;
	font-size: 0.75rem;
}

.gmv-hero__price-before-amount {
	text-decoration: line-through;
	font-weight: 600;
}

.gmv-hero__price-now {
	margin: 0;
	display: flex;
	align-items: baseline;
	gap: var(--gmv-space-xs);
	color: var(--gmv-coral);
	line-height: 1;
}

.gmv-hero__price-currency {
	font-size: 1.3rem;
	font-weight: 600;
}

.gmv-hero__price-amount {
	font-size: clamp(2.2rem, 5vw, 3.2rem);
	font-weight: 800;
	line-height: 1;
	letter-spacing: -1px;
}

.gmv-hero__price-legend {
	margin: 4px 0 0;
	font-size: 0.7rem;
	color: var(--gmv-text-light);
	text-transform: uppercase;
	letter-spacing: 0.8px;
	font-weight: 600;
}

/* ----- CTA: sin flecha, alineado derecha, anclado abajo ----- */
.gmv-hero__cta {
	display: inline-block;
	background: var(--gmv-coral);
	color: #fff;
	font-family: var(--gmv-font);
	font-weight: 700;
	font-size: 1.05rem;
	padding: 14px 32px;
	border-radius: var(--gmv-radius-pill);
	text-decoration: none;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	box-shadow: var(--gmv-shadow-coral);
	transition: all var(--gmv-transition-base);
	margin-top: auto;
	align-self: flex-end;
}

.gmv-hero__cta:hover,
.gmv-hero__cta:focus-visible {
	background: var(--gmv-coral-hover);
	transform: translateY(-2px);
	box-shadow: 0 12px 28px rgba(230, 87, 66, 0.3);
	color: #fff;
	text-decoration: none;
	outline: none;
}

/* ===== CTA modificador para Oferta Relámpago: mismo lenguaje del header ===== */
.gmv-hero__cta--or {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background: linear-gradient(135deg, #ff6b35 0%, #e65742 35%, #c73e2c 70%, #f5b301 100%);
	color: #fff;
	font-size: 1.15rem;
	font-weight: 800;
	letter-spacing: 0.8px;
	padding: 16px 36px;
	border: 2px solid rgba(255, 217, 59, 0.6);
	box-shadow:
		0 8px 24px rgba(230, 87, 66, 0.4),
		0 0 0 4px rgba(255, 217, 59, 0.15),
		inset 0 1px 0 rgba(255, 255, 255, 0.25);
	overflow: hidden;
	text-shadow: 0 1px 3px rgba(0, 0, 0, 0.25);
	animation: orCtaGlow 2.5s ease-in-out infinite;
}

/* Brillo "shimmer" que cruza el botón diagonalmente */
.gmv-hero__cta--or::before {
	content: '';
	position: absolute;
	top: 0;
	left: -100%;
	width: 60%;
	height: 100%;
	background: linear-gradient(
		120deg,
		transparent 0%,
		rgba(255, 255, 255, 0.35) 50%,
		transparent 100%
	);
	transform: skewX(-20deg);
	animation: orCtaShimmer 3.5s ease-in-out infinite;
	pointer-events: none;
}

/* Patrón de líneas diagonales sutiles, igual que el header */
.gmv-hero__cta--or::after {
	content: '';
	position: absolute;
	inset: 0;
	background-image: repeating-linear-gradient(
		45deg,
		transparent,
		transparent 10px,
		rgba(255, 255, 255, 0.05) 10px,
		rgba(255, 255, 255, 0.05) 20px
	);
	pointer-events: none;
}

.gmv-hero__cta--or > * {
	position: relative;
	z-index: 1;
}

.gmv-hero__cta-icon {
	color: #ffd93b;
	font-size: 1.4rem;
	filter: drop-shadow(0 0 6px rgba(255, 217, 59, 0.7));
	animation: orBadgePulse 1.4s ease-in-out infinite;
}

.gmv-hero__cta--or:hover,
.gmv-hero__cta--or:focus-visible {
	background: linear-gradient(135deg, #ff6b35 0%, #e65742 35%, #c73e2c 70%, #f5b301 100%);
	color: #fff;
	transform: translateY(-3px) scale(1.02);
	box-shadow:
		0 14px 36px rgba(230, 87, 66, 0.55),
		0 0 0 5px rgba(255, 217, 59, 0.25),
		inset 0 1px 0 rgba(255, 255, 255, 0.3);
	outline: none;
}

@keyframes orCtaGlow {
	0%, 100% {
		box-shadow:
			0 8px 24px rgba(230, 87, 66, 0.4),
			0 0 0 4px rgba(255, 217, 59, 0.15),
			inset 0 1px 0 rgba(255, 255, 255, 0.25);
	}
	50% {
		box-shadow:
			0 10px 30px rgba(230, 87, 66, 0.55),
			0 0 0 5px rgba(255, 217, 59, 0.35),
			inset 0 1px 0 rgba(255, 255, 255, 0.25);
	}
}

@keyframes orCtaShimmer {
	0% { left: -100%; }
	50%, 100% { left: 150%; }
}

/* ----- Responsive ----- */
@media (max-width: 991px) {
	.gmv-hero__body,
	.gmv-hero--video .gmv-hero__body,
	.gmv-hero--foto .gmv-hero__body {
		grid-template-columns: 1fr;
		gap: 75px; /* dejar espacio para que el logo asomando no tape el título */
		justify-items: stretch;
	}
	.gmv-hero__media {
		max-width: 480px;
		margin: 0 auto;
	}
	/* En tablet/mobile, el video también acotado para no quedar gigante (9:16 es muy vertical) */
	.gmv-hero--video .gmv-hero__media {
		max-width: 300px;
	}
	/* Padding lateral para que el texto del info no se pegue al borde del viewport */
	.gmv-hero__info {
		align-items: flex-start;
		padding: 0 var(--gmv-space-md);
	}
	.gmv-hero__cta {
		align-self: stretch;
	}
}

@media (max-width: 600px) {
	.gmv-hero__head {
		flex-direction: column;
		text-align: center;
		padding: var(--gmv-space-md);
	}
	.gmv-hero__head-content {
		align-items: center;
	}
	.gmv-hero__head--or .gmv-hero__head-title {
		font-size: 1.4rem;
	}
	.gmv-hero__title {
		font-size: 1.5rem;
	}
	.gmv-hero__subtitle {
		font-size: 1rem;
	}
}

/* ========================================================================
   CARRUSEL "Nuestras propuestas"
   ======================================================================== */
.gmv-slider {
	margin: var(--gmv-space-lg) 0 var(--gmv-space-lg);
	font-family: var(--gmv-font);
}

.gmv-slider__header {
	text-align: center;
	margin-bottom: var(--gmv-space-lg);
}

.gmv-slider__eyebrow {
	display: inline-block;
	background: var(--gmv-coral);
	color: #fff;
	padding: 4px 14px;
	border-radius: var(--gmv-radius-pill);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 1.2px;
	text-transform: uppercase;
	margin-bottom: var(--gmv-space-sm);
}

.gmv-slider__title {
	font-family: var(--gmv-font);
	font-weight: 700;
	font-size: clamp(1.6rem, 3vw, 2.2rem);
	color: var(--gmv-text);
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.gmv-slider__swiper {
	padding: var(--gmv-space-sm);
	height: 520px;
}

.gmv-slider__swiper .swiper-wrapper {
	height: 480px !important;
}

.gmv-slider__card {
	display: flex;
	flex-direction: column;
	background: var(--gmv-bg);
	border-radius: var(--gmv-radius-lg);
	overflow: hidden;
	box-shadow: var(--gmv-shadow-md);
	transition: transform var(--gmv-transition-base), box-shadow var(--gmv-transition-base);
	text-decoration: none;
	color: inherit;
	height: 460px;
}

/* Forzar a los slides a NO estirarse al más alto.
   align-items: flex-start hace que cada slide tome su altura natural
   y no se sincronice con el más alto del wrapper */
.gmv-slider__swiper .swiper-wrapper {
	align-items: flex-start !important;
}
.gmv-slider__swiper .swiper-slide {
	height: auto !important;
	align-self: flex-start !important;
}

.gmv-slider__card:hover,
.gmv-slider__card:focus-visible {
	transform: translateY(-6px);
	box-shadow: var(--gmv-shadow-lg);
	text-decoration: none;
	color: inherit;
	outline: none;
}

.gmv-slider__media {
	position: relative;
	overflow: hidden;
	height: 230px;
	background: var(--gmv-bg-soft);
	flex-shrink: 0;
}

.gmv-slider__img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--gmv-transition-slow);
}

.gmv-slider__card:hover .gmv-slider__img {
	transform: scale(1.06);
}

.gmv-slider__badge-video {
	position: absolute;
	top: 10px;
	right: 10px;
	background: var(--gmv-coral);
	color: #fff;
	width: 26px;
	height: 26px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: var(--gmv-shadow-coral);
	border: 1.5px solid #fff;
	z-index: 2;
}

.gmv-slider__body {
	display: flex;
	flex-direction: column;
	gap: var(--gmv-space-xs);
	padding: 12px 14px 14px;
	flex: 1;
	min-height: 0;
	overflow: hidden;
}

.gmv-slider__card-title {
	font-family: var(--gmv-font);
	font-size: 1.1rem;
	font-weight: 700;
	color: var(--gmv-text);
	text-transform: uppercase;
	letter-spacing: 0.3px;
	line-height: 1.2;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	position: relative;
	padding-bottom: 10px;
}

/* Detalle decorativo: línea coral corta debajo del título */
.gmv-slider__card-title::after {
	content: '';
	position: absolute;
	left: 0;
	bottom: 0;
	width: 36px;
	height: 3px;
	background: var(--gmv-coral);
	border-radius: 2px;
}

.gmv-slider__card-desc {
	font-family: var(--gmv-font);
	font-size: 0.95rem;
	color: var(--gmv-text-light);
	line-height: 1.4;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.gmv-slider__cta {
	display: inline-block;
	background: var(--gmv-coral);
	color: #fff;
	font-family: var(--gmv-font);
	font-weight: 700;
	font-size: 0.9rem;
	padding: 9px 18px;
	border-radius: var(--gmv-radius-pill);
	text-decoration: none;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-top: auto;
	align-self: flex-end;
	transition: background var(--gmv-transition-fast);
}

.gmv-slider__card:hover .gmv-slider__cta {
	background: var(--gmv-coral-hover);
}

/* Bullets del swiper en coral */
.gmv-slider__swiper .swiper-pagination-bullet-active {
	background: var(--gmv-coral);
}

/* ========================================================================
   CATEGORÍAS DESTINOS - "Descubrí más"
   ======================================================================== */
.gmv-cats {
	margin: var(--gmv-space-2xl) 0 var(--gmv-space-2xl);
	font-family: var(--gmv-font);
}

.gmv-cats__header {
	text-align: center;
	margin-bottom: var(--gmv-space-lg);
}

.gmv-cats__eyebrow {
	display: inline-block;
	background: var(--gmv-coral);
	color: #fff;
	padding: 4px 14px;
	border-radius: var(--gmv-radius-pill);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 1.2px;
	text-transform: uppercase;
	margin-bottom: var(--gmv-space-sm);
}

.gmv-cats__title {
	font-family: var(--gmv-font);
	font-weight: 700;
	font-size: clamp(1.6rem, 3vw, 2.2rem);
	color: var(--gmv-text);
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.gmv-cats__grid {
	margin: 0;
}

.gmv-cats__col {
	padding: var(--gmv-space-sm);
}

.gmv-cats__card {
	position: relative;
	display: block;
	border-radius: var(--gmv-radius-lg);
	overflow: hidden;
	height: 200px;
	box-shadow: var(--gmv-shadow-md);
	transition: transform var(--gmv-transition-slow), box-shadow var(--gmv-transition-slow);
	cursor: pointer;
	text-decoration: none;
	color: inherit;
}

.gmv-cats__card:hover,
.gmv-cats__card:focus-visible {
	transform: translateY(-8px);
	box-shadow: var(--gmv-shadow-lg);
	text-decoration: none;
	color: inherit;
	outline: none;
}

.gmv-cats__img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--gmv-transition-slow);
}

.gmv-cats__card:hover .gmv-cats__img {
	transform: scale(1.1);
}

.gmv-cats__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0) 50%, rgba(230, 87, 66, 0.55) 100%);
	transition: background var(--gmv-transition-slow);
}

.gmv-cats__card:hover .gmv-cats__overlay {
	background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.1) 50%, rgba(230, 87, 66, 0.75) 100%);
}

.gmv-cats__content {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	padding: var(--gmv-space-md);
	text-align: center;
	z-index: 2;
}

.gmv-cats__icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	background: #fff;
	border-radius: 50%;
	margin-bottom: var(--gmv-space-sm);
	color: var(--gmv-coral);
	font-size: 1.4rem;
	opacity: 0;
	transform: translateY(10px);
	transition: opacity var(--gmv-transition-base), transform var(--gmv-transition-base);
	box-shadow: var(--gmv-shadow-md);
}

.gmv-cats__card:hover .gmv-cats__icon {
	opacity: 1;
	transform: translateY(0);
}

.gmv-cats__name {
	font-family: var(--gmv-font);
	font-weight: 700;
	font-size: 1.4rem;
	color: #fff;
	text-transform: uppercase;
	letter-spacing: 1px;
	margin: 0 0 4px;
	text-shadow: 0 2px 4px rgba(0, 0, 0, 0.35);
	line-height: 1.1;
}

.gmv-cats__count {
	font-family: var(--gmv-font);
	font-weight: 500;
	font-size: 0.85rem;
	color: rgba(255, 255, 255, 0.9);
	margin: 0;
}

@media (max-width: 768px) {
	.gmv-cats__card {
		height: 160px;
	}
	.gmv-cats__name {
		font-size: 1.15rem;
	}
	.gmv-cats__icon {
		width: 40px;
		height: 40px;
		font-size: 1.2rem;
	}
}

/* ========================================================================
   TARJETAS X3 - "Más propuestas"
   ======================================================================== */
.gmv-x3 {
	margin: var(--gmv-space-2xl) 0 var(--gmv-space-2xl);
	font-family: var(--gmv-font);
}

.gmv-x3__header {
	text-align: center;
	margin-bottom: var(--gmv-space-lg);
}

.gmv-x3__eyebrow {
	display: inline-block;
	background: var(--gmv-coral);
	color: #fff;
	padding: 4px 14px;
	border-radius: var(--gmv-radius-pill);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 1.2px;
	text-transform: uppercase;
	margin-bottom: var(--gmv-space-sm);
}

.gmv-x3__title {
	font-family: var(--gmv-font);
	font-weight: 700;
	font-size: clamp(1.5rem, 2.8vw, 2rem);
	color: var(--gmv-text);
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.gmv-x3__col {
	padding: var(--gmv-space-sm);
	margin-bottom: var(--gmv-space-md);
	display: flex;
}

.gmv-x3__card {
	display: flex;
	flex-direction: column;
	background: var(--gmv-bg);
	border-radius: var(--gmv-radius-lg);
	overflow: hidden;
	box-shadow: var(--gmv-shadow-md);
	transition: transform var(--gmv-transition-base), box-shadow var(--gmv-transition-base);
	text-decoration: none;
	color: inherit;
	width: 100%;
}

.gmv-x3__card:hover,
.gmv-x3__card:focus-visible {
	transform: translateY(-6px);
	box-shadow: var(--gmv-shadow-lg);
	text-decoration: none;
	color: inherit;
	outline: none;
}

.gmv-x3__media {
	position: relative;
	overflow: hidden;
	height: 200px;
	background: var(--gmv-bg-soft);
	flex-shrink: 0;
}

.gmv-x3__img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--gmv-transition-slow);
}

.gmv-x3__card:hover .gmv-x3__img {
	transform: scale(1.06);
}

/* DTO overlay sobre la imagen (top-right) */
.gmv-x3__dto-overlay {
	position: absolute;
	top: 10px;
	right: 10px;
	max-width: calc(100% - 70px);
	background: var(--gmv-coral);
	color: #fff;
	padding: 5px 10px;
	border-radius: var(--gmv-radius-pill);
	font-weight: 700;
	font-size: 0.7rem;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	text-align: center;
	box-shadow: var(--gmv-shadow-coral);
	line-height: 1.2;
	z-index: 3;
}

/* Badge video en top-left para no chocar con dto-overlay en top-right */
.gmv-x3__badge-video {
	position: absolute;
	top: 10px;
	left: 10px;
	background: var(--gmv-coral);
	color: #fff;
	width: 26px;
	height: 26px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	box-shadow: var(--gmv-shadow-coral);
	border: 1.5px solid #fff;
	z-index: 2;
}

.gmv-x3__body {
	display: flex;
	flex-direction: column;
	gap: var(--gmv-space-sm);
	padding: var(--gmv-space-md);
	flex: 1;
}

.gmv-x3__name {
	font-family: var(--gmv-font);
	font-weight: 700;
	font-size: 1.05rem;
	color: var(--gmv-text);
	text-transform: uppercase;
	letter-spacing: -0.2px;
	line-height: 1.2;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Meta como pills con iconos (igual al hero) */
.gmv-x3__meta {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin: 0;
}

.gmv-x3__meta-item {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	background: var(--gmv-coral-soft);
	color: var(--gmv-text);
	padding: 4px 10px;
	border-radius: var(--gmv-radius-pill);
	font-size: 0.75rem;
	font-weight: 500;
	border: 1px solid rgba(230, 87, 66, 0.15);
	min-height: 26px;
	box-sizing: border-box;
}

.gmv-x3__meta-item svg {
	color: var(--gmv-coral);
	flex-shrink: 0;
}

.gmv-x3__meta-item strong {
	color: var(--gmv-text);
	font-weight: 700;
}

.gmv-x3__chip {
	display: inline-flex;
	align-items: center;
	align-self: center;
	background: var(--gmv-coral);
	color: #fff;
	padding: 4px 10px;
	border-radius: var(--gmv-radius-pill);
	font-size: 0.65rem;
	line-height: 1;
	font-weight: 700;
	letter-spacing: 1px;
	text-transform: uppercase;
	box-shadow: var(--gmv-shadow-sm);
	min-height: 26px;
	box-sizing: border-box;
}

.gmv-x3__desc {
	font-family: var(--gmv-font);
	font-size: 0.85rem;
	color: var(--gmv-text-muted);
	line-height: 1.4;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Bloque de precio con jerarquía mejorada (igual al hero) */
.gmv-x3__price-block {
	margin: var(--gmv-space-xs) 0 0;
	padding-top: var(--gmv-space-sm);
	border-top: 1px solid rgba(0, 0, 0, 0.08);
}

.gmv-x3__price-before {
	margin: 0 0 2px;
	display: flex;
	align-items: baseline;
	gap: 5px;
	color: var(--gmv-text-light);
	font-size: 0.75rem;
}

.gmv-x3__price-before-label {
	text-transform: uppercase;
	font-weight: 600;
	letter-spacing: 0.4px;
	font-size: 0.65rem;
}

.gmv-x3__price-before-amount {
	text-decoration: line-through;
	font-weight: 600;
}

.gmv-x3__price-now {
	margin: 0;
	display: flex;
	align-items: baseline;
	gap: 4px;
	color: var(--gmv-coral);
	line-height: 1;
}

.gmv-x3__price-currency {
	font-size: 0.95rem;
	font-weight: 600;
}

.gmv-x3__price-amount {
	font-size: 1.8rem;
	font-weight: 800;
	line-height: 1;
	letter-spacing: -0.5px;
}

.gmv-x3__price-legend {
	margin: 3px 0 0;
	font-size: 0.62rem;
	color: var(--gmv-text-light);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	font-weight: 600;
}

/* CTA: pill coral, sin flecha, anclado abajo-derecha */
.gmv-x3__cta {
	display: inline-block;
	background: var(--gmv-coral);
	color: #fff;
	font-family: var(--gmv-font);
	font-weight: 700;
	font-size: 0.85rem;
	padding: 9px 18px;
	border-radius: var(--gmv-radius-pill);
	text-decoration: none;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-top: auto;
	align-self: flex-end;
	transition: background var(--gmv-transition-fast);
}

.gmv-x3__card:hover .gmv-x3__cta {
	background: var(--gmv-coral-hover);
}

@media (max-width: 768px) {
	.gmv-x3__col {
		margin-bottom: var(--gmv-space-lg);
	}
}

/* ========================================================================
   SERVICIOS ADICIONALES (Visa / Grupales)
   ======================================================================== */
.gmv-extras {
	margin: var(--gmv-space-lg) 0 var(--gmv-space-lg);
	font-family: var(--gmv-font);
}

.gmv-extras__header {
	text-align: center;
	margin-bottom: var(--gmv-space-lg);
}

.gmv-extras__eyebrow {
	display: inline-block;
	background: var(--gmv-coral);
	color: #fff;
	padding: 4px 14px;
	border-radius: var(--gmv-radius-pill);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 1.2px;
	text-transform: uppercase;
	margin-bottom: var(--gmv-space-sm);
}

.gmv-extras__title {
	font-family: var(--gmv-font);
	font-weight: 700;
	font-size: clamp(1.5rem, 2.8vw, 2rem);
	color: var(--gmv-text);
	margin: 0;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.gmv-extras__col {
	padding: var(--gmv-space-sm);
	margin-bottom: var(--gmv-space-md);
}

.gmv-extras__card {
	display: flex;
	flex-direction: column;
	background: var(--gmv-bg);
	border-radius: var(--gmv-radius-lg);
	overflow: hidden;
	box-shadow: var(--gmv-shadow-md);
	transition: transform var(--gmv-transition-base), box-shadow var(--gmv-transition-base);
	text-decoration: none;
	color: inherit;
}

.gmv-extras__card:hover,
.gmv-extras__card:focus-visible {
	transform: translateY(-6px);
	box-shadow: var(--gmv-shadow-lg);
	text-decoration: none;
	color: inherit;
	outline: none;
}

.gmv-extras__media {
	position: relative;
	overflow: hidden;
	height: 200px;
	background: var(--gmv-bg-soft);
}

.gmv-extras__img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--gmv-transition-slow);
}

.gmv-extras__card:hover .gmv-extras__img {
	transform: scale(1.06);
}

.gmv-extras__body {
	display: flex;
	flex-direction: column;
	gap: var(--gmv-space-sm);
	padding: var(--gmv-space-md) var(--gmv-space-lg) var(--gmv-space-lg);
}

.gmv-extras__name {
	font-family: var(--gmv-font);
	font-weight: 700;
	font-size: 1.2rem;
	color: var(--gmv-text);
	margin: 0;
	line-height: 1.2;
}

.gmv-extras__desc {
	font-family: var(--gmv-font);
	font-size: 0.9rem;
	color: var(--gmv-text-muted);
	line-height: 1.45;
	margin: 0;
}

.gmv-extras__cta {
	display: inline-block;
	background: var(--gmv-coral);
	color: #fff;
	font-family: var(--gmv-font);
	font-weight: 700;
	font-size: 0.85rem;
	padding: 8px 18px;
	border-radius: var(--gmv-radius-pill);
	text-decoration: none;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-top: var(--gmv-space-xs);
	align-self: flex-end;
	transition: background var(--gmv-transition-fast);
}

.gmv-extras__card:hover .gmv-extras__cta {
	background: var(--gmv-coral-hover);
}

/* ========================================================================
   BLOQUE DE MENSAJES INTERMEDIOS
   Wrapper para los dos bloques mensaje1/2 y mensaje3/4 del home.
   No toca las clases internas MensajeIndex1/2 (usadas también en otras páginas).
   ======================================================================== */
.gmv-message-band {
	max-width: 900px;
	margin-left: auto;
	margin-right: auto;
	padding: var(--gmv-space-lg) var(--gmv-space-md);
	text-align: center;
	position: relative;
}

.gmv-message-band::before,
.gmv-message-band::after {
	content: '';
	display: block;
	width: 60px;
	height: 3px;
	background: var(--gmv-coral);
	border-radius: var(--gmv-radius-pill);
	margin: 0 auto;
	opacity: 0.7;
}

.gmv-message-band::before {
	margin-bottom: var(--gmv-space-md);
}

.gmv-message-band::after {
	margin-top: var(--gmv-space-md);
}

/* ---------- AVA - Asistente Virtual ---------- */
.ava-container {
	position: fixed;
	bottom: 30px;
	right: 30px;
	z-index: 9998;
	cursor: pointer;
	transition: transform 0.3s ease;
}

.ava-container:hover {
	transform: scale(1.05);
}

.ava-image {
	width: 85px;
	height: 100px;
	background: transparent;
	border-radius: 30%;
	padding: 1px;
	animation: pulse 2s infinite;
	transition: all 0.3s ease;
}

@keyframes pulse {
	0%, 100% { transform: scale(1); }
	50% { transform: scale(1.05); }
}

.ava-bubble {
	position: absolute;
	bottom: 105px;
	right: 0;
	background: white;
	padding: 15px 20px;
	border-radius: 20px;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
	width: 320px;
	opacity: 0;
	transform: translateY(10px);
	pointer-events: none;
	font-family: 'Quicksand', sans-serif;
	font-size: 14px;
	line-height: 1.4;
	color: #333;
	font-weight: 500;
	transition: all 0.3s ease;
}

.ava-bubble::after {
	content: '';
	position: absolute;
	bottom: -8px;
	right: 35px;
	width: 0;
	height: 0;
	border-left: 10px solid transparent;
	border-right: 10px solid transparent;
	border-top: 10px solid white;
}

.ava-bubble.show {
	opacity: 1;
	transform: translateY(0);
	pointer-events: auto;
}

.ava-bubble.hide {
	opacity: 0;
	transform: translateY(10px);
	pointer-events: none;
}

.ava-container:hover .ava-bubble {
	opacity: 1 !important;
	transform: translateY(0) !important;
	pointer-events: auto !important;
}

@media (max-width: 768px) {
	.ava-container {
		bottom: 20px;
		right: 20px;
	}
	.ava-image {
		width: 72px;
		height: 85px;
		border-radius: 30%;
		padding: 1px;
	}
	.ava-bubble {
		bottom: 95px;
		width: 280px;
		padding: 12px 16px;
		font-size: 13px;
	}
}

@media (max-width: 480px) {
	.ava-container {
		bottom: 15px;
		right: 15px;
	}
	.ava-image {
		width: 60px;
		height: 70px;
		border-radius: 30%;
		padding: 1px;
	}
	.ava-bubble {
		bottom: 80px;
		width: 250px;
		padding: 10px 14px;
		font-size: 12px;
		right: -10px;
	}
	.ava-bubble::after {
		right: 30px;
	}
}


/* ========================================================================
   VENTANA EMERGENTE / POPUP DESTACADO
   Mismo lenguaje visual que el hero: media + info, chip, logo asomando, CTA pill.
   ======================================================================== */

/* Overlay (fondo oscuro semi-transparente) */
.gmv-popup-overlay {
	position: fixed;
	inset: 0;
	width: 100vw;
	height: 100vh;
	background: rgba(0, 0, 0, 0.55);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	z-index: var(--gmv-z-popup, 10000);
	display: none;
	padding: var(--gmv-space-md);
	overflow-y: auto;
	font-family: var(--gmv-font);
}

.gmv-popup-overlay.gmv-active {
	display: flex;
	align-items: center;
	justify-content: center;
	animation: gmv-popup-overlay-in 0.25s ease-out;
}

@keyframes gmv-popup-overlay-in {
	from { opacity: 0; }
	to { opacity: 1; }
}

/* Bloquear scroll del body cuando el popup está activo */
body.gmv-popup-open {
	overflow: hidden;
	position: fixed;
	width: 100%;
	height: 100%;
	left: 0;
	right: 0;
}

/* Caja del popup */
.gmv-popup-box {
	position: relative;
	background: var(--gmv-bg);
	border-radius: var(--gmv-radius-xl);
	width: 100%;
	max-width: 920px;
	max-height: 92vh;
	overflow: visible;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
	animation: gmv-popup-box-in 0.35s cubic-bezier(0.2, 0.9, 0.3, 1.2);
}

@keyframes gmv-popup-box-in {
	from { transform: scale(0.92) translateY(20px); opacity: 0; }
	to { transform: scale(1) translateY(0); opacity: 1; }
}

/* Botón cerrar */
.gmv-popup-close {
	position: absolute;
	top: -16px;
	right: -16px;
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--gmv-bg);
	color: var(--gmv-text);
	font-size: 28px;
	font-weight: 300;
	line-height: 1;
	cursor: pointer;
	border: none;
	box-shadow: var(--gmv-shadow-md);
	display: flex;
	align-items: center;
	justify-content: center;
	z-index: 10;
	transition: all var(--gmv-transition-base);
}

.gmv-popup-close:hover,
.gmv-popup-close:focus-visible {
	background: var(--gmv-coral);
	color: #fff;
	transform: scale(1.1) rotate(90deg);
	outline: none;
}

/* Link envolvente */
.gmv-popup-link {
	display: grid;
	grid-template-columns: 1fr 1fr;
	overflow: hidden;
	border-radius: var(--gmv-radius-xl);
	text-decoration: none;
	color: inherit;
	min-height: 400px;
}

/* Variante con video: media más angosta (9:16) y la modal entera más compacta */
.gmv-popup--video .gmv-popup-box {
	max-width: 720px;
}

.gmv-popup--video .gmv-popup-link {
	grid-template-columns: minmax(0, 280px) 1fr;
}

/* MEDIA */
.gmv-popup-media {
	position: relative;
	background: var(--gmv-bg-soft);
	overflow: hidden;
}

.gmv-popup-img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--gmv-transition-slow);
}

.gmv-popup-link:hover .gmv-popup-img {
	transform: scale(1.04);
}

.gmv-popup-video {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	background: #000;
}

/* DTO overlay sobre la imagen, top-right */
.gmv-popup-dto-overlay {
	position: absolute;
	top: var(--gmv-space-md);
	right: var(--gmv-space-md);
	max-width: calc(100% - 32px);
	background: var(--gmv-coral);
	color: #fff;
	padding: 6px 12px;
	border-radius: var(--gmv-radius-pill);
	font-weight: 700;
	font-size: 0.75rem;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	text-align: center;
	box-shadow: var(--gmv-shadow-coral);
	line-height: 1.2;
	z-index: 3;
}

/* INFO */
.gmv-popup-info {
	display: flex;
	flex-direction: column;
	gap: var(--gmv-space-sm);
	padding: var(--gmv-space-xl);
	background: var(--gmv-bg);
}

.gmv-popup-chip {
	align-self: flex-start;
	display: inline-flex;
	align-items: center;
	background: var(--gmv-coral);
	color: #fff;
	padding: 6px 14px;
	border-radius: var(--gmv-radius-pill);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	box-shadow: var(--gmv-shadow-sm);
	line-height: 1;
	min-height: 28px;
}

.gmv-popup-title {
	font-family: var(--gmv-font);
	font-weight: 700;
	font-size: clamp(1.4rem, 2.5vw, 1.9rem);
	color: var(--gmv-text);
	line-height: 1.15;
	margin: var(--gmv-space-xs) 0 0;
	text-transform: uppercase;
	letter-spacing: -0.5px;
}

.gmv-popup-subtitle {
	font-family: var(--gmv-font);
	font-weight: 500;
	font-size: 1rem;
	color: var(--gmv-coral);
	font-style: italic;
	line-height: 1.35;
	margin: 0;
}

.gmv-popup-desc {
	font-family: var(--gmv-font);
	color: var(--gmv-text-muted);
	font-size: 0.95rem;
	line-height: 1.5;
	margin: var(--gmv-space-xs) 0;
	display: -webkit-box;
	-webkit-line-clamp: 5;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.gmv-popup-cta {
	display: inline-block;
	background: var(--gmv-coral);
	color: #fff;
	font-weight: 700;
	font-size: 1rem;
	padding: 12px 28px;
	border-radius: var(--gmv-radius-pill);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	box-shadow: var(--gmv-shadow-coral);
	margin-top: auto;
	align-self: flex-end;
	transition: all var(--gmv-transition-base);
}

.gmv-popup-link:hover .gmv-popup-cta {
	background: var(--gmv-coral-hover);
	transform: translateY(-2px);
	box-shadow: 0 12px 28px rgba(230, 87, 66, 0.3);
}

/* ----- Responsive ----- */
@media (max-width: 768px) {
	.gmv-popup-overlay {
		padding: var(--gmv-space-sm);
		align-items: flex-start;
	}
	.gmv-popup-box {
		max-height: 95vh;
		margin: var(--gmv-space-md) 0;
	}
	.gmv-popup-link,
	.gmv-popup--video .gmv-popup-link {
		grid-template-columns: 1fr;
		min-height: auto;
	}
	.gmv-popup-media {
		aspect-ratio: 16 / 10;
	}
	.gmv-popup--video .gmv-popup-media {
		aspect-ratio: 9 / 14;
		max-height: 60vh;
	}
	.gmv-popup-info {
		padding: var(--gmv-space-xl) var(--gmv-space-md) var(--gmv-space-lg);
	}
	.gmv-popup-close {
		top: 8px;
		right: 8px;
		width: 40px;
		height: 40px;
		font-size: 24px;
		background: rgba(255, 255, 255, 0.95);
	}
	.gmv-popup-desc {
		-webkit-line-clamp: 4;
	}
}

@media (max-width: 480px) {
	.gmv-popup-title {
		font-size: 1.3rem;
	}
	.gmv-popup-cta {
		padding: 11px 24px;
		font-size: 0.9rem;
	}
}

/* ---------- App Download Section ---------- */
.app-download-section {
	margin: 40px 10px 70px;
	padding: 45px 30px;
	background: linear-gradient(135deg, #fff5f3 0%, #ffe8e3 100%);
	border-radius: 16px;
	box-shadow: 0 4px 20px rgba(230, 87, 66, 0.08);
	border: 1px solid rgba(230, 87, 66, 0.15);
}
.app-download-container {
	max-width: 1100px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 40px;
	flex-wrap: wrap;
}
.app-download-text {
	flex: 1 1 380px;
}
.app-download-eyebrow {
	display: inline-block;
	font-family: 'Quicksand', sans-serif;
	font-size: 12px;
	font-weight: 700;
	color: #e65742;
	letter-spacing: 1.5px;
	margin-bottom: 10px;
}
.app-download-title {
	font-family: 'Quicksand', sans-serif;
	font-size: 30px;
	font-weight: 700;
	color: #2c3e50;
	margin: 0 0 12px;
	line-height: 1.2;
}
.app-download-title span {
	color: #e65742;
}
.app-download-subtitle {
	font-family: 'Quicksand', sans-serif;
	font-size: 16px;
	color: #555;
	margin: 0;
	line-height: 1.5;
}
.app-download-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	align-items: center;
}
.app-download-badges a {
	display: inline-block;
	line-height: 0;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.app-download-badges a:hover {
	transform: translateY(-3px);
	box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15);
}
.app-download-badges img {
	height: 60px;
	width: auto;
	display: block;
	border-radius: 8px;
}
@media (max-width: 768px) {
	.app-download-section {
		padding: 35px 20px;
		margin: 30px 10px 55px;
	}
	.app-download-container {
		gap: 25px;
		justify-content: center;
		text-align: center;
	}
	.app-download-title {
		font-size: 24px;
	}
	.app-download-subtitle {
		font-size: 14px;
	}
	.app-download-badges {
		justify-content: center;
	}
	.app-download-badges img {
		height: 52px;
	}
}
@media (max-width: 480px) {
	.app-download-badges img {
		height: 46px;
	}
}

/* ========================================================================
   AUDITORÍA RESPONSIVE - Ajustes finales para todos los dispositivos
   ======================================================================== */

/* ---------- TABLET (≤ 991px) ---------- */
@media (max-width: 991px) {
	/* Reducir márgenes verticales gigantes entre secciones */
	.gmv-hero {
		margin: var(--gmv-space-xl) 0 var(--gmv-space-xl);
	}
	.gmv-cats,
	.gmv-x3,
	.gmv-extras,
	.gmv-slider {
		margin: var(--gmv-space-xl) 0 var(--gmv-space-xl);
	}

	/* Hero info en tablet: padding lateral para no pegar el texto al borde
	   (el padding-top 0 se sobreescribe abajo en la regla específica del hero) */
	.gmv-hero__info {
		padding-top: 0;
		padding-bottom: 0;
	}

	/* Header de sección más compacto */
	.gmv-slider__header,
	.gmv-cats__header,
	.gmv-x3__header,
	.gmv-extras__header {
		margin-bottom: var(--gmv-space-md);
	}
}

/* ---------- MOBILE LARGE (≤ 768px) ---------- */
@media (max-width: 768px) {
	/* Carrusel: cards más compactas, menos altura */
	.gmv-slider__swiper {
		height: 450px;
	}
	.gmv-slider__swiper .swiper-wrapper {
		height: 410px !important;
	}
	.gmv-slider__card {
		height: 390px;
	}
	.gmv-slider__media {
		height: 200px;
	}
	.gmv-slider__card-title {
		font-size: 1rem;
	}
	.gmv-slider__card-desc {
		font-size: 0.85rem;
	}

	/* Hero: title clamp ya hace su parte, pero meta más compacto */
	.gmv-hero__meta {
		gap: 6px;
	}
	.gmv-hero__meta-item {
		font-size: 0.8rem;
		padding: 5px 10px;
		min-height: 28px;
	}
	.gmv-hero__chip {
		font-size: 0.7rem;
		min-height: 28px;
	}

	/* Mensajes intermedios: padding ajustado */
	.gmv-message-band {
		padding: var(--gmv-space-md) var(--gmv-space-sm);
	}
	.gmv-message-band::before,
	.gmv-message-band::after {
		width: 50px;
	}
}

/* ---------- MOBILE (≤ 600px) ---------- */
@media (max-width: 600px) {
	/* Márgenes verticales aún más compactos en mobile chico */
	.gmv-hero {
		margin: var(--gmv-space-lg) 0 var(--gmv-space-lg);
	}
	.gmv-cats,
	.gmv-x3,
	.gmv-extras,
	.gmv-slider {
		margin: var(--gmv-space-lg) 0 var(--gmv-space-lg);
	}

	/* Carrusel en mobile chico: una sola card visible */
	.gmv-slider__swiper {
		height: 440px;
	}

	/* Hero: meta items pueden wrap, pero achicar gap */
	.gmv-hero__meta {
		flex-direction: row;
		gap: 5px;
	}

	/* CTA del hero en mobile = full width centrado */
	.gmv-hero__cta {
		text-align: center;
		font-size: 0.95rem;
		padding: 12px 22px;
	}

	/* CTA "or" (oferta relámpago) — el efecto shimmer puede romper en chico */
	.gmv-hero__cta--or {
		font-size: 1rem;
		padding: 14px 24px;
		gap: 8px;
	}
	.gmv-hero__cta-icon {
		font-size: 1.2rem;
	}

	/* Bloque precio compacto */
	.gmv-hero__price-currency {
		font-size: 1.1rem;
	}

	/* Header oferta relámpago en mobile chico */
	.gmv-hero__head-badge {
		width: 52px;
		height: 52px;
		font-size: 1.6rem;
	}
	.gmv-hero__head-subtitle {
		font-size: 0.85rem;
	}

	/* X3 cards: pills y precio compactos */
	.gmv-x3__price-amount {
		font-size: 1.5rem;
	}
	.gmv-x3__name {
		font-size: 0.95rem;
	}
}

/* ---------- MOBILE PEQUEÑO (≤ 380px) ---------- */
@media (max-width: 380px) {
	/* Carrusel: aún más compacto */
	.gmv-slider__swiper {
		height: 420px;
	}
	.gmv-slider__card {
		height: 360px;
	}
	.gmv-slider__media {
		height: 180px;
	}

	/* Hero foto: aspect-ratio menos exigente en pantallas muy chicas */
	.gmv-hero__photo {
		aspect-ratio: 16 / 11;
	}

	/* Pills meta en una línea de a 2 si es posible */
	.gmv-hero__meta-item,
	.gmv-hero__chip {
		font-size: 0.7rem;
		padding: 4px 8px;
		min-height: 24px;
	}
	.gmv-hero__meta-item svg {
		width: 12px;
		height: 12px;
	}
}
