/* Slider hero section-1: mismo aspecto que imagen única (primer-bloque / container-background) */
.section-1 .container-background > .hero-slider {
	position: relative;
	z-index: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
}

/* Ancho del carril y flex de cada slide los fija JS (evita translate % sobre un carril muy ancho, que en varios navegadores no anima y “salta”). */
.section-1 .hero-slider-track {
	display: flex;
	height: 100%;
	transform: translate3d(0, 0, 0);
	backface-visibility: hidden;
	transition: transform 0.75s cubic-bezier(0.14, 1.12, 0.67, 0.99);
	-webkit-transition: -webkit-transform 0.75s cubic-bezier(0.14, 1.12, 0.67, 0.99);
	will-change: transform;
}

.section-1 .hero-slide {
	flex-shrink: 0;
	height: 100%;
	min-width: 0;
}

.section-1 .hero-slide img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 50%;
	filter: brightness(80%);
}

/* Paneles de texto apilados (misma celda que .primera original) */
.section-1 .hero-panels {
	display: grid;
	grid-template: 1fr / 1fr;
	align-items: start;
	justify-items: stretch;
	pointer-events: none;
	margin-left: var(--size-grid002);
	margin-right: var(--size-grid002);
}

@media (min-width: 560px) {
	.section-1 .hero-panels {
		margin-right: var(--size-grid006);
	}
}

@media (min-width: 960px) {
	.section-1 .hero-panels {
		margin-right: var(--size-grid008);
	}
}

@media (min-width: 1280px) {
	.section-1 .hero-panels {
		margin-right: var(--size-grid010);
	}
}

.section-1 .hero-panels .primera.hero-panel {
	/* ~26% del tamaño del título hero: mismo valor entre líneas y entre subtítulo y CTA */
	--hero-text-gap: calc(var(--textappearances-headline450-fontsize) * 0.88 * 0.26);
	grid-area: 1 / 1;
	pointer-events: none;
	margin-left: 0;
	margin-right: 0;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.5s cubic-bezier(0.14, 1.12, 0.67, 0.99),
		visibility 0.5s step-end;
}

.section-1 .hero-panels .primera.hero-panel.is-active {
	pointer-events: all;
	opacity: 1;
	visibility: visible;
	transition: opacity 0.5s cubic-bezier(0.14, 1.12, 0.67, 0.99),
		visibility 0s step-start;
	z-index: 1;
}

/* Dos niveles de título siempre blancos */
.section-1 .hero-panel .titulo,
.section-1 .hero-panel .titulo .capsula,
.section-1 .hero-panel .titulo b {
	color: #fff;
}

/* Jerarquía: bloque algo más chico que el headline por defecto; 1ª línea destacada; 2ª más chica y liviana */
.section-1 .hero-panel .titulo {
	font-size: calc(var(--textappearances-headline450-fontsize) * 0.88);
	line-height: 1.2;
	margin-top: 0;
	margin-bottom: 0;
}

.section-1 .hero-panel .titulo .capsula {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: var(--hero-text-gap);
	font-size: 1em;
}

.section-1 .hero-panel .titulo .hero-titulo-principal {
	display: block;
	font-weight: 600;
	font-size: 1em;
	line-height: 1.26;
	letter-spacing: var(--textappearances-headline450-letterspacing);
}

.section-1 .hero-panel .titulo .hero-titulo-sub {
	display: block;
	margin-top: 0;
	font-family: var(--font-family-text, vw-text, Helvetica, Arial, sans-serif);
	font-size: 0.74em;
	font-weight: 300;
	line-height: 1.28;
	letter-spacing: 0.01em;
	opacity: 0.92;
}

/* Sustituye el padding grande del theme entre título y botón por el mismo hueco que entre líneas */
.section-1 .hero-panel .container-link {
	padding-top: var(--hero-text-gap);
}

/* Fila inferior del hero: por encima del fondo para que los puntos reciban clic */
.section-1 .tercera {
	position: relative;
	z-index: 5;
	pointer-events: auto;
}

/* Indicadores: forma real en <span> (evita ::after en <button>, poco fiable + estilos de reboot) */
.section-1 .hero-slider-dots {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 12px;
	pointer-events: auto;
	padding: 0 12px 10px;
	margin: 0;
	position: relative;
	z-index: 6;
	list-style: none;
}

.section-1 button.hero-slider-dot {
	appearance: none !important;
	-webkit-appearance: none !important;
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	margin: 0;
	min-width: 44px;
	min-height: 44px;
	padding: 0;
	border: 0 !important;
	border-radius: 0 !important;
	background: transparent !important;
	background-color: transparent !important;
	box-shadow: none !important;
	color: transparent !important;
	font-size: 0 !important;
	line-height: 0;
	cursor: pointer;
	outline: none;
	vertical-align: middle;
}

.section-1 button.hero-slider-dot .hero-slider-dot-shape {
	display: block;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background-color: rgba(255, 255, 255, 0.38);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.45);
	transition: width 0.35s cubic-bezier(0.14, 1.12, 0.67, 0.99),
		height 0.35s cubic-bezier(0.14, 1.12, 0.67, 0.99),
		border-radius 0.35s cubic-bezier(0.14, 1.12, 0.67, 0.99),
		background-color 0.25s ease,
		box-shadow 0.25s ease;
	flex-shrink: 0;
}

.section-1 button.hero-slider-dot:hover .hero-slider-dot-shape,
.section-1 button.hero-slider-dot:focus-visible .hero-slider-dot-shape {
	background-color: rgba(255, 255, 255, 0.65);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.55);
}

.section-1 button.hero-slider-dot:focus-visible {
	outline: 2px solid #4cc7f4 !important;
	outline-offset: 2px;
}

/* Activo: píldora redondeada (~3 círculos de ancho), mismo alto que el punto */
.section-1 button.hero-slider-dot.is-active .hero-slider-dot-shape {
	width: 30px;
	height: 10px;
	border-radius: 999px;
	background-color: rgba(255, 255, 255, 0.98);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.85),
		0 1px 4px rgba(0, 0, 0, 0.25);
}

@media (prefers-reduced-motion: reduce) {
	.section-1 .hero-slider-track {
		transition: none;
	}

	.section-1 .hero-panels .primera.hero-panel {
		transition: none;
	}

	.section-1 button.hero-slider-dot .hero-slider-dot-shape {
		transition: none;
	}
}
