/* vexel/imagenes-texto-color-band */

.vexel-imagenes-texto-color-band {
	position: relative;
	overflow: hidden;
	padding-block: var(--wp--preset--spacing--70);
	padding-inline: var(--wp--preset--spacing--40);
	color: #ffffff;
}

/* Band colour variants. The `--band-fg` and `--band-fg-muted` are read by
   nested elements so the whole block adapts to the chosen background. */
.vexel-imagenes-texto-color-band.is-band-navy {
	background: var(--wp--preset--color--navy);
	--band-fg: #ffffff;
	--band-fg-muted: rgba(255, 255, 255, 0.78);
	--band-kicker: var(--wp--preset--color--accent);
	--band-cta-bg: var(--wp--preset--color--bg);
	--band-cta-fg: var(--wp--preset--color--navy);
	--band-cta-bg-hover: rgba(255, 255, 255, 0.92);
	--band-cta-secondary-fg: #ffffff;
	--band-cta-secondary-border: rgba(255, 255, 255, 0.55);
	--band-decor-color: rgba(255, 255, 255, 0.12);
}

.vexel-imagenes-texto-color-band.is-band-primary {
	background: var(--wp--preset--color--primary);
	--band-fg: #ffffff;
	--band-fg-muted: rgba(255, 255, 255, 0.82);
	--band-kicker: rgba(255, 255, 255, 0.95);
	--band-cta-bg: var(--wp--preset--color--bg);
	--band-cta-fg: var(--wp--preset--color--primary);
	--band-cta-bg-hover: rgba(255, 255, 255, 0.92);
	--band-cta-secondary-fg: #ffffff;
	--band-cta-secondary-border: rgba(255, 255, 255, 0.55);
	--band-decor-color: rgba(255, 255, 255, 0.14);
}

.vexel-imagenes-texto-color-band.is-band-accent {
	background: var(--wp--preset--color--accent);
	--band-fg: var(--wp--preset--color--navy);
	--band-fg-muted: rgba(12, 35, 64, 0.78);
	--band-kicker: var(--wp--preset--color--navy);
	--band-cta-bg: var(--wp--preset--color--navy);
	--band-cta-fg: #ffffff;
	--band-cta-bg-hover: var(--wp--preset--color--primary-hover);
	--band-cta-secondary-fg: var(--wp--preset--color--navy);
	--band-cta-secondary-border: rgba(12, 35, 64, 0.4);
	--band-decor-color: rgba(12, 35, 64, 0.14);
}

.vexel-imagenes-texto-color-band.is-band-dark {
	background: #0a1628;
	--band-fg: #ffffff;
	--band-fg-muted: rgba(255, 255, 255, 0.72);
	--band-kicker: var(--wp--preset--color--accent);
	/* WCAG 2.1 AA fix (F6.4f2): the previous combo navy text on accent
	   (#0C2340 on #2B80FF) measured 4.16:1, below the 4.5:1 normal-text
	   threshold. Switching to white background with navy text matches the
	   `is-band-navy` and `is-band-primary` variants and yields ~13.6:1. */
	--band-cta-bg: var(--wp--preset--color--bg);
	--band-cta-fg: var(--wp--preset--color--navy);
	--band-cta-bg-hover: rgba(255, 255, 255, 0.92);
	--band-cta-secondary-fg: #ffffff;
	--band-cta-secondary-border: rgba(255, 255, 255, 0.45);
	--band-decor-color: rgba(255, 255, 255, 0.08);
}

.vexel-imagenes-texto-color-band.is-band-soft {
	background: var(--wp--preset--color--bg-soft);
	--band-fg: var(--wp--preset--color--navy);
	--band-fg-muted: var(--wp--preset--color--text-muted);
	--band-kicker: var(--wp--preset--color--primary);
	--band-cta-bg: var(--wp--preset--color--primary);
	--band-cta-fg: #ffffff;
	--band-cta-bg-hover: var(--wp--preset--color--primary-hover);
	--band-cta-secondary-fg: var(--wp--preset--color--navy);
	--band-cta-secondary-border: var(--wp--preset--color--border);
	--band-decor-color: rgba(12, 35, 64, 0.08);
}

/* Decorative SVG layer. */
.vexel-imagenes-texto-color-band__decor {
	position: absolute;
	inset: 0;
	pointer-events: none;
	color: var(--band-decor-color, rgba(255, 255, 255, 0.12));
	overflow: hidden;
	opacity: 0.85;
}

.vexel-imagenes-texto-color-band__decor svg {
	position: absolute;
	width: clamp(14rem, 32vw, 26rem);
	height: auto;
}

.vexel-imagenes-texto-color-band.is-image-right .vexel-imagenes-texto-color-band__decor svg {
	left: -3rem;
	bottom: -3rem;
}

.vexel-imagenes-texto-color-band.is-image-left .vexel-imagenes-texto-color-band__decor svg {
	right: -3rem;
	top: -3rem;
}

/* Inner grid. */
.vexel-imagenes-texto-color-band__inner {
	position: relative;
	z-index: 1;
	display: grid;
	gap: var(--wp--preset--spacing--60);
	max-width: var(--wp--style--global--wide-size);
	margin-inline: auto;
	align-items: center;
}

.vexel-imagenes-texto-color-band.is-ratio-balanced .vexel-imagenes-texto-color-band__inner {
	grid-template-columns: 1fr 1fr;
}

.vexel-imagenes-texto-color-band.is-ratio-text-heavy .vexel-imagenes-texto-color-band__inner {
	grid-template-columns: 1.3fr 1fr;
}

.vexel-imagenes-texto-color-band.is-ratio-image-heavy .vexel-imagenes-texto-color-band__inner {
	grid-template-columns: 1fr 1.3fr;
}

.vexel-imagenes-texto-color-band.alignfull {
	padding-inline: clamp(var(--wp--preset--spacing--40), 6vw, var(--wp--preset--spacing--70));
}

/* Image / content placement: image is column 2 by default (right). When the
   image is on the left, swap columns via `order`. */
.vexel-imagenes-texto-color-band.is-image-right .vexel-imagenes-texto-color-band__content {
	order: 1;
}

.vexel-imagenes-texto-color-band.is-image-right .vexel-imagenes-texto-color-band__media {
	order: 2;
}

.vexel-imagenes-texto-color-band.is-image-left .vexel-imagenes-texto-color-band__content {
	order: 2;
}

.vexel-imagenes-texto-color-band.is-image-left .vexel-imagenes-texto-color-band__media {
	order: 1;
}

/* Vertical alignment of content vs. image. */
.vexel-imagenes-texto-color-band.is-valign-top .vexel-imagenes-texto-color-band__inner {
	align-items: start;
}

.vexel-imagenes-texto-color-band.is-valign-middle .vexel-imagenes-texto-color-band__inner {
	align-items: center;
}

.vexel-imagenes-texto-color-band.is-valign-bottom .vexel-imagenes-texto-color-band__inner {
	align-items: end;
}

/* Media side. */
.vexel-imagenes-texto-color-band__media {
	width: 100%;
	overflow: hidden;
	background: rgba(0, 0, 0, 0.06);
	box-shadow: var(--wp--custom--shadow--lg);
}

.vexel-imagenes-texto-color-band.is-image-style-rounded .vexel-imagenes-texto-color-band__media {
	border-radius: var(--wp--custom--radius--lg);
}

.vexel-imagenes-texto-color-band.is-image-style-sharp .vexel-imagenes-texto-color-band__media {
	border-radius: 0;
	box-shadow: none;
}

.vexel-imagenes-texto-color-band.is-image-style-framed .vexel-imagenes-texto-color-band__media {
	border-radius: var(--wp--custom--radius--md);
	border: 4px solid var(--band-fg);
	box-shadow: var(--wp--custom--shadow--lg);
}

.vexel-imagenes-texto-color-band.is-aspect-square .vexel-imagenes-texto-color-band__media {
	aspect-ratio: 1 / 1;
}

.vexel-imagenes-texto-color-band.is-aspect-portrait .vexel-imagenes-texto-color-band__media {
	aspect-ratio: 3 / 4;
}

.vexel-imagenes-texto-color-band.is-aspect-landscape .vexel-imagenes-texto-color-band__media {
	aspect-ratio: 4 / 3;
}

.vexel-imagenes-texto-color-band.is-aspect-wide .vexel-imagenes-texto-color-band__media {
	aspect-ratio: 16 / 9;
}

.vexel-imagenes-texto-color-band__image {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.vexel-imagenes-texto-color-band__image--placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--band-fg-muted);
	min-height: 16rem;
	height: 100%;
	background: rgba(255, 255, 255, 0.08);
}

.vexel-imagenes-texto-color-band.is-band-soft .vexel-imagenes-texto-color-band__image--placeholder,
.vexel-imagenes-texto-color-band.is-band-accent .vexel-imagenes-texto-color-band__image--placeholder {
	background: rgba(12, 35, 64, 0.06);
}

.vexel-imagenes-texto-color-band__image--placeholder svg {
	width: clamp(4rem, 12vw, 8rem);
	height: auto;
	opacity: 0.7;
}

/* Content side. */
.vexel-imagenes-texto-color-band__content {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--30);
	color: var(--band-fg);
	max-width: 36rem;
}

.vexel-imagenes-texto-color-band.is-image-right .vexel-imagenes-texto-color-band__content {
	margin-right: auto;
}

.vexel-imagenes-texto-color-band.is-image-left .vexel-imagenes-texto-color-band__content {
	margin-left: auto;
}

.vexel-imagenes-texto-color-band__kicker {
	margin: 0;
	font-size: var(--wp--preset--font-size--sm);
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--band-kicker);
}

.vexel-imagenes-texto-color-band__heading {
	margin: 0;
	font-family: var(--wp--preset--font-family--display);
	font-size: var(--wp--preset--font-size--3xl);
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: -0.02em;
	color: var(--band-fg);
	text-wrap: balance;
}

.vexel-imagenes-texto-color-band__body {
	color: var(--band-fg-muted);
	font-size: var(--wp--preset--font-size--lg);
	line-height: 1.6;
}

.vexel-imagenes-texto-color-band__body p {
	margin: 0 0 var(--wp--preset--spacing--20);
}

.vexel-imagenes-texto-color-band__body p:last-child {
	margin-bottom: 0;
}

.vexel-imagenes-texto-color-band__body a {
	color: var(--band-fg);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}

/* Actions row. */
.vexel-imagenes-texto-color-band__actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--wp--preset--spacing--20);
	margin: var(--wp--preset--spacing--30) 0 0;
	align-items: center;
}

.vexel-imagenes-texto-color-band__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	font-weight: 600;
	font-size: var(--wp--preset--font-size--md);
	text-decoration: none;
	transition: background-color 120ms ease, color 120ms ease, transform 120ms ease, border-color 120ms ease;
	white-space: nowrap;
}

/* Primary CTA — solid pill that reads against the band. */
.vexel-imagenes-texto-color-band__cta--primary {
	background: var(--band-cta-bg);
	color: var(--band-cta-fg);
	border-radius: var(--wp--custom--radius--md);
	padding: 0.875rem 1.75rem;
	box-shadow: var(--wp--custom--shadow--sm);
	border: 0;
}

.vexel-imagenes-texto-color-band__cta--primary:hover,
.vexel-imagenes-texto-color-band__cta--primary:focus-visible {
	background: var(--band-cta-bg-hover);
	color: var(--band-cta-fg);
	transform: translateY(-1px);
}

.vexel-imagenes-texto-color-band__cta--primary:focus-visible {
	outline: 3px solid var(--wp--preset--color--accent);
	outline-offset: 3px;
}

/* Secondary CTA — ghost / underline arrow style. */
.vexel-imagenes-texto-color-band__cta--secondary {
	background: transparent;
	color: var(--band-cta-secondary-fg);
	border: 1.5px solid var(--band-cta-secondary-border);
	border-radius: var(--wp--custom--radius--md);
	padding: 0.75rem 1.25rem;
}

.vexel-imagenes-texto-color-band__cta--secondary:hover,
.vexel-imagenes-texto-color-band__cta--secondary:focus-visible {
	background: rgba(255, 255, 255, 0.08);
	border-color: var(--band-cta-secondary-fg);
	color: var(--band-cta-secondary-fg);
}

.vexel-imagenes-texto-color-band.is-band-soft .vexel-imagenes-texto-color-band__cta--secondary:hover,
.vexel-imagenes-texto-color-band.is-band-accent .vexel-imagenes-texto-color-band__cta--secondary:hover,
.vexel-imagenes-texto-color-band.is-band-soft .vexel-imagenes-texto-color-band__cta--secondary:focus-visible,
.vexel-imagenes-texto-color-band.is-band-accent .vexel-imagenes-texto-color-band__cta--secondary:focus-visible {
	background: rgba(12, 35, 64, 0.06);
}

.vexel-imagenes-texto-color-band__cta--secondary:focus-visible {
	outline: 3px solid var(--wp--preset--color--accent);
	outline-offset: 3px;
}

.vexel-imagenes-texto-color-band__cta-icon {
	width: 1rem;
	height: 1rem;
	transition: transform 160ms ease;
}

.vexel-imagenes-texto-color-band__cta--secondary:hover .vexel-imagenes-texto-color-band__cta-icon,
.vexel-imagenes-texto-color-band__cta--secondary:focus-visible .vexel-imagenes-texto-color-band__cta-icon {
	transform: translateX(3px);
}

/* When there is no image: stretch content to the full inner grid so the
   band keeps its editorial rhythm. */
.vexel-imagenes-texto-color-band.has-no-image .vexel-imagenes-texto-color-band__inner {
	grid-template-columns: 1fr;
}

.vexel-imagenes-texto-color-band.has-no-image .vexel-imagenes-texto-color-band__media {
	display: none;
}

.vexel-imagenes-texto-color-band.has-no-image .vexel-imagenes-texto-color-band__content {
	max-width: 48rem;
	margin-inline: auto;
	text-align: center;
	align-items: center;
}

.vexel-imagenes-texto-color-band.has-no-image .vexel-imagenes-texto-color-band__actions {
	justify-content: center;
}

/* Tablet — collapse asymmetric ratios to balanced. */
@media (max-width: 1100px) {
	.vexel-imagenes-texto-color-band.is-ratio-text-heavy .vexel-imagenes-texto-color-band__inner,
	.vexel-imagenes-texto-color-band.is-ratio-image-heavy .vexel-imagenes-texto-color-band__inner {
		grid-template-columns: 1fr 1fr;
	}

	.vexel-imagenes-texto-color-band__heading {
		font-size: var(--wp--preset--font-size--2xl);
	}
}

/* Mobile — stack: image on top, content below. Keep the band visual
   weight by reducing vertical padding slightly. */
@media (max-width: 800px) {
	.vexel-imagenes-texto-color-band {
		padding-block: var(--wp--preset--spacing--60);
	}

	.vexel-imagenes-texto-color-band__inner {
		grid-template-columns: 1fr !important;
		gap: var(--wp--preset--spacing--40);
	}

	.vexel-imagenes-texto-color-band.is-image-right .vexel-imagenes-texto-color-band__content,
	.vexel-imagenes-texto-color-band.is-image-left .vexel-imagenes-texto-color-band__content {
		order: 2;
		margin-inline: 0;
		max-width: none;
	}

	.vexel-imagenes-texto-color-band.is-image-right .vexel-imagenes-texto-color-band__media,
	.vexel-imagenes-texto-color-band.is-image-left .vexel-imagenes-texto-color-band__media {
		order: 1;
	}

	.vexel-imagenes-texto-color-band__heading {
		font-size: var(--wp--preset--font-size--2xl);
	}

	.vexel-imagenes-texto-color-band__actions {
		flex-direction: column;
		align-items: stretch;
	}

	.vexel-imagenes-texto-color-band__cta {
		width: 100%;
	}
}
