/* ============================================================
   Tarjetas de resultados (ediciones / festivales)
   Overlay con info al hover. Mobile: chip persistente.
   ============================================================ */

.resultado-post,
.resultado-festival {
	position: relative;
	overflow: hidden;
	aspect-ratio: 4 / 5;
	background: var(--navy, #0f151b);
	transition: transform .35s cubic-bezier(.2, .8, .2, 1),
	            box-shadow .35s ease;
	will-change: transform;
}

.resultado-post:hover,
.resultado-festival:hover,
.resultado-post:focus-within,
.resultado-festival:focus-within {
	box-shadow: 0 12px 28px -10px rgba(0, 0, 0, .45);
}

.resultado-imagen {
	width: 100%;
	height: 100%;
	position: relative;
}

.resultado-imagen > a {
	display: block;
	position: relative;
	width: 100%;
	height: 100%;
	color: #fff;
	text-decoration: none;
	outline-offset: 4px;
}

.resultado-imagen img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform .55s cubic-bezier(.2, .8, .2, 1);
}

/* ---------- Overlay ---------- */

.edicion-overlay {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: flex-end;
	padding: 18px;
	background: linear-gradient(
		to top,
		rgba(15, 21, 27, .94) 0%,
		rgba(15, 21, 27, .65) 45%,
		rgba(15, 21, 27, 0) 78%
	);
	opacity: 0;
	transition: opacity .35s ease;
	pointer-events: none;
}

.edicion-overlay-inner {
	width: 100%;
	transform: translateY(14px);
	transition: transform .4s cubic-bezier(.2, .8, .2, 1) .08s;
}

.edicion-title {
	margin: 0 0 8px;
	font-family: "Oswald", sans-serif;
	font-size: 1.15rem;
	line-height: 1.2;
	color: #fff;
	text-shadow: 0 1px 2px rgba(0, 0, 0, .35);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.edicion-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 4px 10px;
	margin-bottom: 10px;
	font-family: "Montserrat", sans-serif;
	font-size: .85rem;
	color: rgba(255, 255, 255, .92);
}

.edicion-fechas {
	font-weight: 600;
	color: var(--blue-2, #01D8E2);
	letter-spacing: .2px;
}

.edicion-ubicacion {
	position: relative;
}

.edicion-meta > .edicion-ubicacion::before {
	content: "·";
	margin-right: 10px;
	opacity: .6;
}

.edicion-meta > .edicion-ubicacion:first-child::before {
	content: none;
}

.edicion-disciplinas {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.edicion-disciplina-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 24px;
	height: 24px;
	filter: drop-shadow(0 1px 2px rgba(0, 0, 0, .4));
}

.edicion-disciplina-icon svg {
	width: 100%;
	height: 100%;
	fill: #fff;
}

.edicion-disciplina-icon svg path,
.edicion-disciplina-icon svg circle,
.edicion-disciplina-icon svg rect {
	fill: #fff;
}

/* ---------- Hover/focus (solo dispositivos con puntero) ---------- */

@media (hover: hover) {
	.resultado-post:hover .edicion-overlay,
	.resultado-festival:hover .edicion-overlay,
	.resultado-post:focus-within .edicion-overlay,
	.resultado-festival:focus-within .edicion-overlay {
		opacity: 1;
	}

	.resultado-post:hover .edicion-overlay-inner,
	.resultado-festival:hover .edicion-overlay-inner,
	.resultado-post:focus-within .edicion-overlay-inner,
	.resultado-festival:focus-within .edicion-overlay-inner {
		transform: translateY(0);
	}

	.resultado-post:hover .resultado-imagen img,
	.resultado-festival:hover .resultado-imagen img,
	.resultado-post:focus-within .resultado-imagen img,
	.resultado-festival:focus-within .resultado-imagen img {
		transform: scale(1.06);
	}
}

/* ---------- Táctil: chip persistente con título + fechas ---------- */

@media (hover: none) {
	.edicion-overlay {
		opacity: 1;
		background: linear-gradient(
			to top,
			rgba(15, 21, 27, .88) 0%,
			rgba(15, 21, 27, .35) 45%,
			rgba(15, 21, 27, 0) 70%
		);
	}

	.edicion-overlay-inner {
		transform: translateY(0);
	}

	.edicion-disciplinas {
		display: none;
	}
}

/* ---------- Accesibilidad: respeta reduce-motion ---------- */

@media (prefers-reduced-motion: reduce) {
	.resultado-post,
	.resultado-festival,
	.resultado-imagen img,
	.edicion-overlay,
	.edicion-overlay-inner {
		transition: none;
	}

	.resultado-post:hover .resultado-imagen img,
	.resultado-festival:hover .resultado-imagen img {
		transform: none;
	}
}
