/*--------------------------------------------------------------
# Casos de éxito — listado (page-casos-exito.php)
--------------------------------------------------------------*/

.casos-grid-wrap {
	width: 100%;
	min-width: 0;
	margin: 0;
	padding: 0;
}

/* En Casos de éxito, el gap tras cabecera usa 80px en todos los breakpoints. */
.gap-L.casos-exito__gap-header {
	height: 80px;
}

/*
 * Grid de tarjetas (page-casos-exito.php): .casos-grid-wrap (capa) > .casos-grid, dentro de .contenedor.
 * Huecos: 30px entre columnas, 60px entre filas (--casos-grid-* en variables.css).
 * Móvil <768px: 1 columna. Tablet ≥768px: 2. Desktop ≥992px: 3.
 */
.casos-grid {
	display: grid;
	width: 100%;
	grid-auto-flow: row;
	grid-auto-rows: auto;
	grid-template-columns: minmax(0, 1fr);
	column-gap: var(--casos-grid-column-gap);
	row-gap: var(--casos-grid-row-gap);
	margin: 0;
	padding: 0;
	list-style: none;
}

@media (min-width: 768px) {
	.casos-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 992px) {
	.casos-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.caso-item {
	margin: 0;
	min-width: 0;
	display: flex;
	flex-direction: column;
	height: 100%;
	row-gap: 1rem;
}

.caso-item__media {
	display: block;
	text-decoration: none;
	color: inherit;
}

.caso-item__body {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	align-items: start;
	column-gap: 1rem;
	row-gap: 0;
	flex: 1;
	min-width: 0;
}

.caso-item__text-col {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	min-width: 0;
}

.caso-item__text-col .entry-title {
	margin: 0;
	padding: 0;
	max-width: 100%;
}

.caso-item__text-col .entry-title.title-XS,
.caso-item__text-col .entry-title.title-XS a {
	color: var(--body-text-100);
}

.caso-item__text-col .entry-title a {
	text-decoration: none;
}

.caso-item__text-col .entry-title a:hover,
.caso-item__text-col .entry-title a:focus-visible {
	color: var(--secondary-100);
}

.caso-item__cta {
	align-self: start;
}

.caso-item--sin-enlace {
	cursor: default;
}

/* Mismo estado hover que .boton-card.primary.dark:hover (botones.css) al pasar por la tarjeta. */
.caso-item:hover .caso-item__cta.boton-card.primary.dark,
.caso-item:focus-within .caso-item__cta.boton-card.primary.dark {
	background-color: var(--accent-100);
	border-color: var(--accent-100);
	color: var(--black-100);
	opacity: 1;
}

.caso-item:hover .caso-item__cta.boton-card::after,
.caso-item:focus-within .caso-item__cta.boton-card::after {
	transform: rotate(45deg);
}

/* Sin imagen: no enlace; el botón decorativo mantiene el aspecto en reposo. */
.caso-item--sin-enlace:hover .caso-item__cta--inactivo.boton-card.primary.dark,
.caso-item--sin-enlace:focus-within .caso-item__cta--inactivo.boton-card.primary.dark {
	background-color: var(--secondary-100);
	border-color: var(--secondary-100);
	color: var(--white-100);
}

.caso-item--sin-enlace:hover .caso-item__cta--inactivo.boton-card::after,
.caso-item--sin-enlace:focus-within .caso-item__cta--inactivo.boton-card::after {
	transform: none;
}

/* Ancho = columna del grid; ratio por defecto 16/9 (variables). Foto = background (cover, center). */
.caso-thumbnail {
	width: 100%;
	aspect-ratio: var(--media-aspect-x) / var(--media-aspect-y);
	height: auto;
	min-height: 0;
	border-radius: 20px;
	background-color: var(--gray-light-20);
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	overflow: hidden;
	filter: grayscale(1);
	transition: filter 0.45s ease;
}

/* Listado CPT caso_exito (y tax servicio): miniatura 1/1, no 16/9. Las noticias usan `.noticia-card`. */
.caso-item:not(.noticia-item) .caso-thumbnail {
	aspect-ratio: 1 / 1;
}

.caso-item:hover .caso-thumbnail,
.caso-item:focus-within .caso-thumbnail {
	filter: grayscale(0);
}

.caso-thumbnail--placeholder {
	background-color: var(--primary-20, #e9f2f5);
	background-image: none;
	filter: none;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 1rem;
	box-sizing: border-box;
}

.caso-item:hover .caso-thumbnail--placeholder,
.caso-item:focus-within .caso-thumbnail--placeholder {
	filter: none;
}

.caso-thumbnail__prox {
	margin: 0;
	text-transform: uppercase;
	color: var(--body-text-100);
	letter-spacing: 0.02em;
}

@media (prefers-reduced-motion: reduce) {
	.caso-thumbnail {
		transition-duration: 0.15s;
	}
}

.caso-item__cliente {
	margin: 0;
	padding: 0;
	max-width: 100%;
	color: var(--secondary-60);
	text-transform: uppercase;
}

