/* Hero promocional: fondo #00974C a ancho completo, sin radios en el contenedor. */
.calera-promo-hero {
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	padding: 0;
	box-sizing: border-box;
}

.calera-promo-hero__swiper {
	border-radius: 0;
	overflow: hidden;
}

.calera-promo-hero__slide {
	position: relative;
	min-height: clamp(320px, 28vw, 520px);
	background: #00974c;
}

/* Elimina cualquier pseudo-capa superpuesta que pueda oscurecer o tapar contenido. */
.calera-promo-hero__swiper::before,
.calera-promo-hero__swiper::after,
.calera-promo-hero__slide::before,
.calera-promo-hero__slide::after {
	content: none !important;
	display: none !important;
}

.calera-promo-hero__overlay-content {
	position: relative;
	z-index: 2;
	min-height: inherit;
	display: grid;
	grid-template-columns: 1fr minmax(280px, 42%);
	align-items: center;
	column-gap: clamp(20px, 3vw, 54px);
	padding: clamp(26px, 3.4vw, 58px) clamp(26px, 4vw, 72px) clamp(48px, 5.5vw, 88px);
	pointer-events: auto;
	user-select: none;
}

.calera-promo-hero__overlay-content--no-left {
	grid-template-columns: 1fr;
	justify-items: center;
}

.calera-promo-hero__overlay-content--no-right {
	grid-template-columns: 1fr;
	justify-items: center;
}

.calera-promo-hero__left {
	display: flex;
	align-items: flex-end;
	justify-content: center;
	min-height: 0;
}

.calera-promo-hero__left-image {
	width: min(100%, clamp(300px, 34vw, 620px));
	height: auto;
	display: block;
	-webkit-user-drag: none;
	user-select: none;
	pointer-events: none;
}

.calera-promo-hero__right {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	min-height: 0;
}

.calera-promo-hero__kicker {
	margin: 0;
	max-width: min(100%, 520px);
	color: #ffffff;
	font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	font-size: clamp(0.95rem, 1.5vw, 1.35rem);
	line-height: 1.35;
	font-weight: 500;
}

.calera-promo-hero__badge-wrap {
	margin-top: clamp(12px, 1.5vw, 24px);
	width: 100%;
	display: flex;
	justify-content: center;
}

.calera-promo-hero__badge {
	width: min(100%, 440px);
	max-width: 440px;
	height: auto;
	display: block;
	-webkit-user-drag: none;
	user-select: none;
	pointer-events: none;
}

.calera-promo-hero__button {
	margin-top: clamp(14px, 1.8vw, 28px);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: clamp(44px, 3vw, 56px);
	padding: 0 clamp(24px, 2.5vw, 48px);
	border-radius: 999px;
	background: #0aad5f;
	color: #ffffff;
	text-decoration: none;
	text-transform: uppercase;
	font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
	font-size: clamp(0.875rem, 1.05vw, 1.05rem);
	font-weight: 700;
	letter-spacing: 0.04em;
	cursor: pointer;
	transition: background-color 0.2s ease, transform 0.15s ease;
	user-select: none;
	pointer-events: auto;
}

.calera-promo-hero__button:hover,
.calera-promo-hero__button:focus-visible {
	background: #12c46d;
}

.calera-promo-hero__pagination {
	position: absolute;
	left: 0;
	right: 0;
	bottom: clamp(12px, 1.4vw, 22px);
	z-index: 4;
	display: flex;
	justify-content: center;
}

.calera-promo-hero .swiper-pagination-bullet {
	width: 9px;
	height: 9px;
	background: rgba(255, 255, 255, 0.45);
	opacity: 1;
}

.calera-promo-hero .swiper-pagination-bullet-active {
	background: #ffffff;
}

.calera-promo-hero__empty {
	margin: 1rem 0;
	padding: 12px 16px;
	background: #f0f0f0;
	color: #333;
	font-size: 0.9rem;
	border-radius: 6px;
}

@media (max-width: 1024px) {
	.calera-promo-hero__slide {
		min-height: auto;
	}

	.calera-promo-hero__overlay-content {
		grid-template-columns: 1fr;
		row-gap: clamp(16px, 3vw, 28px);
		padding-top: clamp(24px, 4vw, 40px);
		padding-bottom: clamp(52px, 8vw, 72px);
	}

	.calera-promo-hero__left {
		order: 1;
		align-items: center;
	}

	.calera-promo-hero__right {
		order: 2;
	}

	.calera-promo-hero__left-image {
		width: min(100%, 420px);
	}

	.calera-promo-hero__badge {
		width: min(100%, 440px);
		max-width: 440px;
	}
}

@media (max-width: 640px) {
	.calera-promo-hero__overlay-content {
		padding: 20px 16px 56px;
	}

	.calera-promo-hero__kicker {
		font-size: clamp(0.9rem, 4.2vw, 1.05rem);
	}

	.calera-promo-hero__button {
		min-height: 42px;
		font-size: 0.8125rem;
		width: 100%;
		max-width: 280px;
	}
}
