/**
 * Carrusel prevención incendios — página DirSer (page-DIRSER.php).
 */

.vr-dirser-incendios-carousel {
	position: relative;
	overflow: hidden;
	background-color: #e2e6ee;
}

.vr-dirser-incendios-carousel__viewport {
	position: relative;
}

.vr-dirser-incendios-carousel .swiper-dirser-carrusel-prevencion {
	overflow: hidden;
	position: relative;
	--swiper-theme-color: #fff;
	--swiper-navigation-color: #fff;
	--swiper-pagination-color: #fff;
	--swiper-pagination-bullet-inactive-color: #fff;
	--swiper-pagination-bullet-inactive-opacity: 1;
}

.vr-dirser-incendios-carousel__slide {
	position: relative;
	min-height: 360px;
	display: flex;
	flex-direction: column;
	box-sizing: border-box;
}

.vr-dirser-incendios-carousel__slide > .vr-dirser-incendios-carousel__layout {
	flex: 1 1 auto;
	min-height: 0;
}

.vr-dirser-incendios-carousel__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	z-index: 0;
}

.vr-dirser-incendios-carousel__scrim {
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(
		90deg,
		rgba(0, 0, 0, 0.35) 0%,
		rgba(0, 0, 0, 0.25) 45%,
		rgba(0, 0, 0, 0.2) 100%
	);
	pointer-events: none;
}

.vr-dirser-incendios-carousel__layout {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
	width: 100%;
	padding: 2.5rem clamp(1rem, 4vw, 1.5rem) 3.5rem;
	color: #fff;
	box-sizing: border-box;
}

/* Título: blanco completo, sin línea de sección DirSer ni color primario global */
#main-content.dirser > section.vr-dirser-incendios-carousel h2.vr-dirser-incendios-carousel__title,
main.dirser > section.vr-dirser-incendios-carousel h2.vr-dirser-incendios-carousel__title {
	margin: 0;
	padding-bottom: 0;
	color: #fff;
}

#main-content.dirser > section.vr-dirser-incendios-carousel h2.vr-dirser-incendios-carousel__title::after,
main.dirser > section.vr-dirser-incendios-carousel h2.vr-dirser-incendios-carousel__title::after {
	display: none !important;
	content: none !important;
}

/* Anular color DirSer en spans del título (main.dirser > section h2 span.fw) */
#main-content.dirser > section.vr-dirser-incendios-carousel h2.vr-dirser-incendios-carousel__title span.fw,
#main-content.dirser > section.vr-dirser-incendios-carousel h2.vr-dirser-incendios-carousel__title span.lw,
main.dirser > section.vr-dirser-incendios-carousel h2.vr-dirser-incendios-carousel__title span.fw,
main.dirser > section.vr-dirser-incendios-carousel h2.vr-dirser-incendios-carousel__title span.lw,
.vr-dirser-incendios-carousel__title span.fw,
.vr-dirser-incendios-carousel__title span.lw,
.vr-dirser-incendios-carousel__title strong,
.vr-dirser-incendios-carousel__title b,
.vr-dirser-incendios-carousel__title em {
	color: #fff !important;
}

.vr-dirser-incendios-carousel__title {
	font-size: 1.65rem;
	font-weight: 800;
	line-height: 1.2;
	text-shadow: 0 1px 4px rgba(0, 0, 0, 0.35);
	max-width: 20rem;
}

.vr-dirser-incendios-carousel__col-left {
	min-width: 0;
}

.vr-dirser-incendios-carousel__panel {
	border-radius: 16px;
	background-color: rgba(255, 255, 255, 0.09);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	padding: 1.35rem 1.25rem;
	color: #fff;
	max-width: 100%;
	flex: 1 1 auto;
	min-height: 0;
	display: flex;
	align-items: center;
}

.vr-dirser-incendios-carousel__panel-inner {
	font-size: 0.95rem;
	line-height: 1.5;
	text-align: left;
	width: 100%;
	color: #fff;
}

.vr-dirser-incendios-carousel__panel-inner a {
	color: #fff;
	text-decoration: underline;
	text-underline-offset: 2px;
}

.vr-dirser-incendios-carousel__panel-inner p:last-child {
	margin-bottom: 0;
}

.vr-dirser-incendios-carousel__actions {
	margin-top: 0;
}

.vr-dirser-incendios-carousel__actions .btn.btn-primary {
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
	margin-top: 2rem;
}

.vr-dirser-incendios-carousel__btn {
	width: 100%;
	max-width: 17rem;
}

/* Paginación: puntos blancos (forzar sobre estilos Swiper / tema) */
.vr-dirser-incendios-carousel .swiper-pagination {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 1.25rem;
	z-index: 5;
	margin: 0;
}

.vr-dirser-incendios-carousel .swiper-pagination-bullet {
	border: 2px solid #fff !important;
	background: transparent !important;
	opacity: 1 !important;
	width: 10px;
	height: 10px;
}

.vr-dirser-incendios-carousel .swiper-pagination-bullet-active {
	background: #fff !important;
	opacity: 1 !important;
}

/* Prev fantasma (Swiper lo exige) */
.vr-dirser-incendios-carousel__nav-prev {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
	opacity: 0;
	pointer-events: none;
}

/* Flecha siguiente sobre la imagen (dentro del swiper) */
.vr-dirser-incendios-carousel__nav-next,
.vr-dirser-incendios-carousel__nav-next::after {
	color: #fff !important;
}

.vr-dirser-incendios-carousel__nav-next::after {
	font-family: "Material Symbols Outlined";
	content: "arrow_forward";
	font-size: 2rem;
}

@media screen and (max-width: 991px) {
	.vr-dirser-incendios-carousel__layout {
		display: flex;
		flex-direction: column;
	}

	/* Orden: título → panel → botón (el botón va después del panel aunque esté en col-left en el DOM) */
	.vr-dirser-incendios-carousel__col-left {
		display: contents;
	}

	.vr-dirser-incendios-carousel__title {
		order: 1;
	}

	.vr-dirser-incendios-carousel__panel {
		order: 2;
	}

	.vr-dirser-incendios-carousel__actions {
		order: 3;
	}

	/* Sin panel (p. ej. slide sin descripción): título + CTA centrados en la altura del slide */
	.vr-dirser-incendios-carousel__layout:not(:has(.vr-dirser-incendios-carousel__panel)) {
		justify-content: center;
	}

	.vr-dirser-incendios-carousel__nav-next {
		display: none !important;
	}

	.vr-dirser-incendios-carousel .swiper-pagination {
		bottom: 1rem;
	}
}

@media screen and (min-width: 992px) {
	.vr-dirser-incendios-carousel__slide {
		min-height: 460px;
	}

	/* Misma estructura de rejilla que antes: título y CTA en celdas distintas; col-left aporta hijos vía contents */
	.vr-dirser-incendios-carousel__layout {
		display: grid;
		grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
		grid-template-rows: auto auto;
		column-gap: 2.5rem;
		row-gap: 1.5rem;
		align-items: center;
		padding: 3.5rem 2.75rem 4.5rem;
	}

	.vr-dirser-incendios-carousel__col-left {
		display: contents;
	}

	.vr-dirser-incendios-carousel__title {
		grid-column: 1;
		grid-row: 1;
		align-self: end;
		font-size: clamp(1.85rem, 2.5vw, 2.65rem);
		max-width: none;
		width: 100%;
		padding-inline-end: 0.5rem;
		box-sizing: border-box;
	}

	.vr-dirser-incendios-carousel__actions {
		grid-column: 1;
		grid-row: 2;
		align-self: start;
		width: 100%;
		max-width: 15rem;
		margin-top: 0;
		padding-top: 0;
	}

	.vr-dirser-incendios-carousel__btn {
		width: 100%;
		max-width: 15rem;
		min-height: 2.45rem;
		padding-left: 1.35rem;
		padding-right: 1.35rem;
		font-size: 0.95rem;
	}

	.vr-dirser-incendios-carousel__panel {
		grid-column: 2;
		grid-row: 1 / span 2;
		align-self: stretch;
		padding: 2rem 1.75rem;
	}

	/* Solo panel o solo columna izquierda: ancho completo */
	.vr-dirser-incendios-carousel__panel:only-child,
	.vr-dirser-incendios-carousel__col-left:only-child {
		grid-column: 1 / -1;
	}

	.vr-dirser-incendios-carousel .swiper-pagination {
		bottom: 1.5rem;
	}

	.vr-dirser-incendios-carousel__nav-next {
		position: absolute;
		top: 50%;
		right: clamp(0.5rem, 2vw, 1.25rem);
		transform: translateY(-50%);
		z-index: 6;
		display: flex;
		align-items: center;
		justify-content: center;
		width: auto;
		height: auto;
		margin: 0;
		padding: 0.35rem;
		background: none !important;
		border: none !important;
		box-shadow: none !important;
		border-radius: 0;
	}

	.vr-dirser-incendios-carousel__nav-next::after {
		filter: drop-shadow(0 1px 3px rgba(0, 0, 0, 0.45));
	}

	.swiper-dirser-carrusel-prevencion.swiper-locked .vr-dirser-incendios-carousel__nav-next {
		display: none !important;
	}
}
