/* CSS para casos - casos.css */

.bloque-casos + div {
	margin: 3rem 0;
}

/* Títulos H1 */
.bloque-titulo h1 {
	padding: 1rem 1.5rem 1.4rem 1.5rem;
	border: 1px solid #1b1b1a;
	border-radius: 10px;
	color: #1B1B1A;
	font-family: "Founders Grotesk", sans-serif;
	font-size: 3rem;
	font-weight: 700;
	line-height: 3rem;
	letter-spacing: 0;
	margin: 0;
}

/* Títulos H2 */
.bloque-texto-imagen h2 {
	color: #1B1B1A;
	font-family: "Open Sauce Two", sans-serif;
	font-size: 1.6875rem; /* 27px */
	font-style: normal;
	font-weight: 400;
	line-height: 140%;
	margin-top: 3rem;
	margin-bottom: 0;
	padding-right: 4rem;
	letter-spacing: 0;
}

/* Párrafos */
.bloque-texto-imagen p,
.bloque-textos p {
	color: #1B1B1A;
	font-family: "Open Sauce Two", sans-serif;
	font-size: 1.0625rem; /* 17px */
	font-style: normal;
	font-weight: 400;
	line-height: 160%;
	margin: 0;
}

/* Contenedor principal de bloques */
.bloque-titulo {
	margin-bottom: 8px;
}

.bloque-imagen-completa {
	margin-bottom: 0.5rem;
}

.bloque-imagen-completa img,
.bloque-imagen-completa video {
	width: 100%;
	border-radius: 8px;
	object-fit: cover;
	aspect-ratio: 1920/1080;
}

/* Bloque texto e imagen */
.bloque-texto-imagen {
	display: flex;
	gap: 0.5rem;
	margin-bottom: 0.5rem;
	align-items: flex-start;
}

.bloque-texto-imagen-normal {
	display: flex;
	margin-bottom: 0.5rem;
	align-items: center;
}

.bloque-texto-imagen .contenido-texto {
	flex: 1;
}

.bloque-texto-imagen .contenido-texto .parrafo {
	padding-right: 4rem;
}

.bloque-texto-imagen .contenido-imagen {
	flex: 1;
}

.bloque-texto-imagen .contenido-imagen img,
.bloque-texto-imagen .contenido-imagen video {
	width: 100%;
	height: auto;
	border-radius: 8px;
	object-fit: cover;
	aspect-ratio: 1080/1350;
}

/* Tags */
.bloque-texto-imagen .tags {
	margin: 3rem 0;
}

.bloque-texto-imagen .tags span {
	display: inline-block;
	background: #E0E1F0;
	padding: 0.75rem 1.5rem;
	border-radius: 10px;
	margin-right: 0.5rem;
	margin-bottom: 0.5rem;
	font-size: 0.9rem;
	font-family: "Open Sauce Two", sans-serif;
}

/* enlace */
.contenido-texto a {
	font-size: 0.875rem;
	color: #1b1b1a;
	text-decoration: none;
	width: 90%;
	margin-top: 3rem;
}

/* Bloque dos imágenes */
.bloque-dos-imagenes {
	display: flex;
	gap: 0.5rem;
	margin-bottom: 0.5rem;
}

.bloque-dos-imagenes > div {
	flex: 1;
}

.bloque-dos-imagenes img,
.bloque-dos-imagenes video {
	width: 100%;
	min-height: 300px;
	border-radius: 8px;
	object-fit: cover;
	aspect-ratio: 1080/1350;
}

/* Bloque tres imágenes */
.bloque-tres-imagenes {
	display: flex;
	gap: 0.5rem;
	margin-bottom: 0.5rem;
}

.bloque-tres-imagenes > div {
	flex: 1;
}

.bloque-tres-imagenes img,
.bloque-tres-imagenes video {
	width: 100%;
	min-height: 250px;
	border-radius: 8px;
	object-fit: cover;
	aspect-ratio: 1080/1920;
}

/* Bloque de textos */
.bloque-textos {
	margin: 6rem 0;
	line-height: 1.6;
	padding-right: 6rem;
}

.bloque-textos .parrafo-principal p {
	font-size: 2rem;
	line-height: 150%;
}

.flex-data {
	display: flex;
	margin-top: 6rem;
}

.hijo {
	flex: 1;
}

.datos {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.datos h3 {
	font-size: 1.5rem;
	line-height: 100%;
	color: #1B1B1A;
	font-family: "Founders Grotesk", sans-serif;
	margin: 0;
}

.bloque-textos p,
.bloque-textos li {
	color: #1B1B1A;
	font-family: "Open Sauce Two", sans-serif;
	font-size: 1.0625rem; /* 17px */
	font-style: normal;
	font-weight: 400;
	line-height: 160%;
}

/* Responsive - Mobile */
@media (max-width: 767px) {
	.bloque-casos + div {
		margin: 48px 0;
	}

	.bloque-titulo {
		margin-bottom: 0;
	}
	
	.bloque-texto-imagen .contenido-imagen {
		order: 1;
	}
	
	.bloque-texto-imagen .contenido-texto {
		order: 2;
	}

	/* H1 en móvil */
	.bloque-titulo h1 {
		padding: 16px;
		font-size: 27px;
		line-height: 110%;
		letter-spacing: -0.54px;
		margin-bottom: 24px;
	}

	/* H2 en móvil */
	.bloque-texto-imagen h2 {
		font-size: 20px;
		line-height: 150%;
		margin-top: 0;
	}

	/* Párrafos en móvil */
	.bloque-texto-imagen p,
	.bloque-textos p {
		font-size: 17px;
		line-height: 160%;
	}

	/* Bloque texto e imagen en columna */
	.flex-data {
		flex-direction: column;
		margin-top: 0;
	}
	
	.datos {
		gap: 16px;
		margin: 0 0 32px 0;
	}
	
	.datos h3 {
		font-size: 24px;
	}
	
	.bloque-texto-imagen {
		flex-direction: column;
		margin-bottom: 8px;
	}

	.bloque-imagen-completa {
		margin-bottom: 8px;	
	}

	.bloque-imagen-completa img,
	.bloque-imagen-completa video {
		height: auto;
	}

	.contenido-texto {
		margin-top: 80px;
	}

	.contenido-texto a {
		font-size: 12px;
		width: 100%;
		margin-top: 32px;
	}

	.bloque-texto-imagen .tags {
		margin: 32px 0;
	}

	.bloque-texto-imagen .tags span {
		display: inline-block;
		background: #E0E1F0;
		padding: 8px 12px;
		margin-right: 8px;
		margin-bottom: 8px;
		font-size: 14px;
		font-family: "Open Sauce Two", sans-serif;
	}
	
	.bloque-textos .parrafo-principal p {
		font-size: 20px !important;
		line-height: 150% !important;
	}

	/* Dos imágenes en columna en móvil */
	.bloque-dos-imagenes {
		flex-direction: column;
		gap: 8px;
		margin-bottom: 8px;
	}

	.bloque-dos-imagenes img,
	.bloque-dos-imagenes video {
		min-height: 200px;
	}

	/* Tres imágenes en carrusel horizontal en móvil */
	.bloque-tres-imagenes {
		flex-direction: row;
		gap: 8px;
		margin-bottom: 8px;
		overflow-x: auto;
		overflow-y: hidden;
		-webkit-overflow-scrolling: touch;
		scroll-snap-type: x mandatory;
	}

	.bloque-tres-imagenes > div {
		flex: 0 0 80%; /* Cada imagen ocupa 80% del ancho, así se ve parte de la siguiente */
		scroll-snap-align: start;
	}

	.bloque-tres-imagenes img {
		min-height: 180px;
		height: auto;
	}

	/* Ocultar scrollbar completamente */
	.bloque-tres-imagenes::-webkit-scrollbar {
		display: none;
	}

	.bloque-tres-imagenes {
		-ms-overflow-style: none;  /* IE y Edge */
		scrollbar-width: none;  /* Firefox */
	}

	/* Textos en móvil */
	.bloque-textos {
		max-width: 100%;
		padding-right: 0;
		margin: 64px 0;
	}

	.bloque-textos .parrafo-principal {
		margin-bottom: 32px;
	}
	
	.bloque-textos .parrafo-secundario {
		margin-top: 32px;
	}

	.bloque-textos p,
	.bloque-textos li {
		font-size: 17px !important;
		line-height: 160% !important;
	}
}