/* ── Puntos Ya: CTA banner (full-width clickable image) ──────────────────── */

.py-cta-banner {
	width: 100%;
	margin: 0 auto;
}

.py-cta-banner__link {
	display: block;
	position: relative;
	width: 100%;
	overflow: hidden;
	border-radius: var(--py-cta-radius, 20px);
	background: var(--py-black, #0d0d0d);
	text-decoration: none;
	line-height: 0;
	transition: box-shadow 0.35s var(--py-ease, ease), transform 0.35s var(--py-ease, ease);
}

.py-cta-banner__img {
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
	transition: transform 0.5s var(--py-ease, ease), filter 0.4s var(--py-ease, ease);
}

/* Soft dark veil that fades in on hover (used by overlay/shine effects). */
.py-cta-banner__overlay {
	position: absolute;
	inset: 0;
	opacity: 0;
	background: linear-gradient(90deg, rgba(0, 0, 0, 0.35) 0%, rgba(0, 0, 0, 0) 60%);
	transition: opacity 0.4s var(--py-ease, ease);
	pointer-events: none;
}

/* Sweeping light shine that crosses the image on hover. */
.py-cta-banner__link::after {
	content: "";
	position: absolute;
	top: 0;
	left: -75%;
	width: 50%;
	height: 100%;
	background: linear-gradient(100deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.35) 50%, rgba(255, 255, 255, 0) 100%);
	transform: skewX(-18deg);
	opacity: 0;
	pointer-events: none;
}

/* ── Effect: zoom (default) ── */
.py-cta-banner--zoom .py-cta-banner__link:hover .py-cta-banner__img {
	transform: scale(1.05);
}

/* ── Effect: overlay (darken + lift) ── */
.py-cta-banner--overlay .py-cta-banner__link:hover {
	transform: translateY(-4px);
	box-shadow: 0 18px 40px rgba(0, 0, 0, 0.22);
}
.py-cta-banner--overlay .py-cta-banner__link:hover .py-cta-banner__overlay {
	opacity: 1;
}
.py-cta-banner--overlay .py-cta-banner__link:hover .py-cta-banner__img {
	transform: scale(1.03);
}

/* ── Effect: shine (light sweep + slight zoom) ── */
.py-cta-banner--shine .py-cta-banner__link:hover .py-cta-banner__img {
	transform: scale(1.04);
}
.py-cta-banner--shine .py-cta-banner__link:hover::after {
	opacity: 1;
	left: 125%;
	transition: left 0.8s var(--py-ease, ease), opacity 0.1s ease;
}

/* ── Effect: lift only ── */
.py-cta-banner--lift .py-cta-banner__link:hover {
	transform: translateY(-5px);
	box-shadow: 0 20px 44px rgba(0, 0, 0, 0.25);
}

/* Editor placeholder when no image is set. */
.py-cta-banner__placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 240px;
	padding: 32px;
	border: 1px dashed #ccc;
	border-radius: var(--py-cta-radius, 20px);
	color: #6b6b6b;
	text-align: center;
	line-height: 1.5;
	background: #fafafa;
}

@media (max-width: 767px) {
	.py-cta-banner__link {
		border-radius: 14px;
	}
}
