/* INICA CSS HERO Slide*/
#contenido2 .cd-hero-slider .cd-btn {
	color: white;
}
h3.follow {
	color: #2c2c2c;
	font-family: 'Cormorant Infant';
	font-size: 30px;
	margin-bottom: 20px;
	position: relative;
}
.jumbo {
	/*font-family: 'Cormorant Infant';*/
	font-family: 'Playfair Display';
	font-size: 50px;
}

h3.test {
	color: #001e1e;
	font-family: 'Cormorant Infant';
	font-size: 30px;
	margin-top: -20px;

	margin-bottom: 30px;
	position: relative;
}

p.test {
	color: #445c7b;
	font-family: 'Raleway';
	font-size: 22px;
	font-weight: 500;
	line-height: 36px;
	margin-bottom: 50px;
}
h1.intro {
	color: #333;
	font-family: 'Playfair Display';
	font-size: 50px;
	font-weight: 500;
	line-height: 60px;
	margin-bottom: 30px;
	margin-left: 50px;
}
h1.intro:after {
	background: #800101;
	content: '';
	display: block;
	height: 2px;
	margin: 20px 0;
	width: 90%;
	/*margin-left:30px;*/
}
p.intro {
	color: #555;

	font-family: 'Playfair Display';
	font-size: 18px;
	line-height: 36px;
	margin-bottom: 15px;
	margin-left: 50px;
	text-justify: distribute;
}
p.intro2 {
	color: #555;

	font-family: 'Playfair Display';
	font-size: 18px;
	line-height: 36px;
	margin-bottom: 15px;
	margin-top: 30px;
	margin-right: 50px;
	margin-left: 50px;
	text-justify: distribute;
}
a.intro {
	color: #800101;
	border-bottom: 1px solid #800101;
	display: inline-block;
	line-height: 36px;
	text-decoration: none;
	margin-left: 50px;
}
a.intro:hover {
	color: #555;
	border-bottom: 1px solid #555;
}
#bg {
	background-image: url('/conciencia_garza/images/banner2.jpg');
	background-repeat: no-repeat;
	width: 100%;
	max-width: 1920px;
	height: 240px;
}
.responsive-video {
	width: 100%;
	max-width: 880px;
	height: 420px;
}
hr.style-eight {
	padding: 0;
	border: none;
	border-top: medium #999;
	color: #333;
	text-align: center;
}
hr.style-eight:after {
	content: '§';
	display: inline-block;
	position: relative;
	top: -0.7em;
	font-size: 1.5em;
	padding: 0 0.25em;
	background: white;
	color: #999;
}
.navbar {
	margin-bottom: 0px;
}
#slider_main .bx-wrapper2 .bx-viewport2 {
	background-color: #ffffff;
}

.div-img {
	display: block;
	margin-left: auto;
	margin-right: auto;
}
.div-img .img {
	display: block;
	margin-left: auto;
	margin-right: auto;
	width: 100%;
	max-width: 880px;
	transform: scale(1);
	-ms-transform: scale(1);
	-moz-transform: scale(1);
	-webkit-transform: scale(1);
	-o-transform: scale(1);
	-webkit-transition: all 500ms ease-in-out;
	-moz-transition: all 500ms ease-in-out;
	-ms-transition: all 500ms ease-in-out;
	-o-transition: all 500ms ease-in-out;
}
.div-img:hover .img {
	transform: scale(0.8);
	-ms-transform: scale(0.8);
	-moz-transform: scale(0.8);
	-webkit-transform: scale(0.8);
	-o-transform: scale(0.8);
	-webkit-border-radius: 10px;
	-moz-border-radius: 10px;
	border-radius: 10px;
}
/* FIN CSS HERO Slide*/

/*Calendario*/
#script-warning {
	display: none;
	background: #eee;
	border-bottom: 1px solid #ddd;
	padding: 0 10px;
	line-height: 40px;
	text-align: center;
	font-weight: bold;
	font-size: 12px;
	color: red;
}

#loading {
	display: none;
	position: absolute;
	top: 10px;
	right: 10px;
}

#calendar {
	max-width: 1100px;
	margin: 40px auto;
	padding: 0 10px;
}

/* carousel */
#quote-carousel {
	padding: 0 10px 30px 10px;
	margin-top: 30px;
	background-color: royalblue;
}

/* Control buttons  */
#quote-carousel .carousel-control {
	background: none;
	color: #222;
	/*font-size: 2.3em;*/
	text-shadow: none;
	margin-top: 30px;
}
/* Previous button  */
#quote-carousel .carousel-control.left {
	left: -12px;
}
/* Next button  */
#quote-carousel .carousel-control.right {
	right: -12px !important;
}
/* Changes the position of the indicators */
#quote-carousel .carousel-indicators {
	right: 50%;
	top: auto;
	bottom: 0px;
	margin-right: -19px;
}
/* Changes the color of the indicators */
#quote-carousel .carousel-indicators li {
	background: #c0c0c0;
}
#quote-carousel .carousel-indicators .active {
	background: #333333;
}
#quote-carousel img {
	width: 50%;
	height: auto;
}
/* End carousel */

.item blockquote {
	border-left: none;
	margin: 0;
}

.item blockquote img {
	margin-bottom: 10px;
}

.item blockquote p:before {
	content: '\f10d';
	font-family: 'Fontawesome';
	float: left;
	margin-right: 10px;
}

/**
  MEDIA QUERIES
*/

/* Small devices (tablets, 768px and up) */
@media (min-width: 768px) {
	#quote-carousel {
		margin-bottom: 0;
		padding: 0 40px 30px 40px;
	}
}

/* Small devices (tablets, up to 768px) */
@media (max-width: 768px) {
	/* Make the indicators larger for easier clicking with fingers/thumb on mobile */

	#quote-carousel .carousel-indicators {
		bottom: -20px !important;
	}
	#quote-carousel .carousel-indicators li {
		display: inline-block;
		margin: 0px 5px;
		width: 15px;
		height: 15px;
	}
	#quote-carousel .carousel-indicators li.active {
		margin: 0px 5px;
		width: 20px;
		height: 20px;
	}
}

/* === MODAL: Cerrado por defecto === */
#modal {
	display: none; /* <- clave: oculto por defecto */
	position: fixed;
	font-family: Arial, Helvetica, sans-serif;
	top: 0;
	left: 0;
	background: rgba(0, 0, 0, 0.8);
	z-index: 99999;
	height: 100%;
	width: 100%;
	pointer-events: none; /* <- evita capturar clics cuando está oculto */
}

/* Cuando quieras abrir el modal, agrega la clase .is-open vía JS */
#modal.is-open {
	display: block;
	pointer-events: auto; /* <- vuelve a permitir interacción */
}

.modalconent {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	background: #fff;
	width: 40%;
	padding: 5px;
}

/* Versión responsive del modal */
@media only screen and (max-width: 768px) {
	#modal {
		display: none; /* mantiene el estado por defecto en móvil */
		position: fixed;
		font-family: Arial, Helvetica, sans-serif;
		top: 0;
		left: 0;
		background: rgba(0, 0, 0, 0.8);
		z-index: 99999;
		height: 100%;
		width: 100%;
		pointer-events: none;
	}
	#modal.is-open {
		display: block;
		pointer-events: auto;
	}
	.modalconent {
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
		background: #fff;
		width: 75%;
		padding: 5px;
	}
}

.btn2 {
	padding: 10px 25px;
	color: #800101;
}
.btn2 {
	display: inline-block;
	padding: 6px 12px;
	margin-bottom: 0;
	margin: 2px;
	font-size: 12px;
	font-weight: 400;
	line-height: 1.42857143;
	text-align: center;
	white-space: nowrap;
	vertical-align: middle;
	-ms-touch-action: manipulation;
	touch-action: manipulation;
	cursor: pointer;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	background-image: none;
	color: none !important;
	border: 1px solid transparent;
	border-radius: 50px;
	box-shadow: 0 2px 5px 0 rgb(60, 59, 59), 0 2px 10px 0 rgba(0, 0, 0, 0.09);
	transition: 0.4s;
	opacity: 0.8;
	text-transform: uppercase;
}
.btn2:hover {
	transform: scale(1.1);
	transition: 0.4s;
	opacity: 1;
}
b {
	color: #444;
}
.capi::first-letter {
	font-size: 3em; /* Tamaño de la letra */
	font-weight: bold; /* Negrita */
	float: left; /* Flotar a la izquierda */
	margin-right: 0.01em; /* Espacio a la derecha */
	line-height: 1; /* Altura de línea */
}
/* Variables para colores y efectos */
:root {
	--glass-bg: rgba(255, 255, 255, 0.25);
	--glass-border: rgba(255, 255, 255, 0.18);
	--glass-shadow: rgba(31, 38, 135, 0.37);
}

.glass-container {
	background: var(--glass-bg);
	border-radius: 15px;
	box-shadow: 0 8px 32px 0 var(--glass-shadow);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border: 1px solid var(--glass-border);
	padding: 20px;
	margin: 20px;
	max-width: 90%;
	box-sizing: border-box;
	color: #fff;
}
.glass-container ul li {
	margin-bottom: 20px;
	line-height: 1.3;
}
.cc {
	color: #ffcb00 !important;
}
.title-event {
	background-color: #fff;
	color: #313131;
	padding: 10px 5px;
}
.fecha-event {
	text-align: left;
	padding-left: 20px;
	padding-top: 10px;
	padding-bottom: 20px;
}

/* Responsivo */
@media (max-width: 768px) {
	.glass-container {
		padding: 15px;
		margin: 10px;
	}
}
:root {
	/* Tamaños solicitados */
	--autonomia-card-size: 350px;
	--autonomia-gap: 25px;
}

/* Contenedor principal */
.autonomia_galeria {
	box-sizing: border-box;
	width: 100%;
	margin: 0 auto;
	padding: 0;
	margin-bottom: 50px;
}

/* Grid responsivo: mantiene gap de 25px y postales mín de 350px */
.autonomia_grid {
	display: grid;
	grid-template-columns: repeat(
		auto-fit,
		minmax(var(--autonomia-card-size), 1fr)
	);
	gap: var(--autonomia-gap);
	align-items: start;
}

/* Postal (cuadrada) */
.autonomia_poster {
	position: relative;
	width: 100%;
	max-width: var(--autonomia-card-size);
	aspect-ratio: 1 / 1; /* asegura 350x350 proporcionalmente */
	overflow: hidden;
	border-radius: 10px;
	box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08);
	background: #f7f7f7;
	margin: 0 auto; /* centra cuando la columna sea más ancha */
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.autonomia_poster:hover {
	transform: translateY(-2px);
	box-shadow: 0 10px 24px rgba(0, 0, 0, 0.12);
}

/* Enlace que abre Fancybox ocupa toda la tarjeta */
.autonomia_link {
	display: block;
	width: 100%;
	height: 100%;
	text-decoration: none;
	outline: none;
	border: 0;
	cursor: zoom-in;
}

/* Imagen se recorta para cubrir el cuadrado sin deformarse */
.autonomia_img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	-webkit-user-drag: none;
	user-select: none;
}

/* Accesibilidad: enfoque con teclado visible */
.autonomia_link:focus-visible {
	box-shadow: 0 0 0 3px rgba(0, 153, 255, 0.45);
}

/* Opcional: limitar ancho máximo total para exactamente 5 por fila en pantallas gigantes
       5 * 350 + 4 * 25 = 1850px */
.autonomia_galeria--max5 {
	max-width: 1850px;
}
/* ====== Cuenta Regresiva (UX) ====== */
/* Utilidad para ocultar el countdown cuando llegue la hora */
.autonomia_is-hidden {
	display: none !important;
}
.autonomia_countdown-row {
	margin: 30px 0 50px;
}
.autonomia_countdown {
	position: relative;
	/* border-radius: 16px; */
	overflow: hidden;
	background: linear-gradient(135deg, #800101 0%, #b11a1a 55%, #e24b3a 100%);
	color: #fff;
	box-shadow: 0 10px 28px rgba(0, 0, 0, 0.18);
}
.autonomia_countdown__content {
	position: relative;
	padding: 28px 18px;
}
.autonomia_countdown__header {
	text-align: center;
	margin-bottom: 12px;
}
.autonomia_countdown__title {
	font-family: 'Playfair Display', serif;
	font-weight: 700;
	font-size: 28px;
	margin: 0 0 4px;
	letter-spacing: 0.2px;
}
.autonomia_countdown__title span {
	border-bottom: 2px solid rgba(255, 255, 255, 0.7);
}
.autonomia_countdown__subtitle {
	font-family: 'Lora', serif;
	opacity: 0.9;
	margin: 0;
	font-size: 16px;
}

.autonomia_countdown__grid {
	margin: 18px auto 4px;
	display: grid;
	grid-template-columns: repeat(4, minmax(90px, 1fr));
	gap: 12px;
	max-width: 760px;
}
.autonomia_cd-box {
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.25);
	box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08) inset,
		0 8px 22px rgba(0, 0, 0, 0.08);
	border-radius: 14px;
	padding: 14px 10px;
	text-align: center;
	transition: transform 0.2s ease;
}
.autonomia_cd-box:hover {
	transform: translateY(-2px);
}
.autonomia_cd-value {
	font-family: 'Playfair Display', serif;
	font-size: 76px;
	font-weight: 700;
	line-height: 1;
}
.autonomia_cd-label {
	text-transform: uppercase;
	font-size: 12px;
	letter-spacing: 0.14em;
	opacity: 0.9;
	margin-top: 6px;
}
.autonomia_countdown__foot {
	text-align: center;
	margin-top: 10px;
	font-size: 14px;
	opacity: 0.95;
}
/* ===== Lista de videos (UX) ===== */
.autonomia_videoList {
	list-style: none;
	padding-left: 0;
	margin: 0;
	display: grid;
	gap: 12px;
}

.autonomia_videoItem {
	border-radius: 12px;
	background: linear-gradient(
		135deg,
		rgba(128, 1, 1, 0.12),
		rgba(128, 1, 1, 0.22)
	);
	border: 1px solid rgba(255, 255, 255, 0.18);
	box-shadow: 0 6px 16px rgba(0, 0, 0, 0.1) inset,
		0 6px 16px rgba(0, 0, 0, 0.08);
	transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease,
		border-color 0.18s ease;
}

.autonomia_videoItem:hover,
.autonomia_videoItem:focus-within {
	transform: translateY(-2px);
	background: linear-gradient(
		135deg,
		rgba(255, 203, 0, 0.2),
		rgba(255, 203, 0, 0.3)
	);
	border-color: rgba(255, 203, 0, 0.55);
	box-shadow: 0 10px 24px rgba(0, 0, 0, 0.14);
}

.autonomia_videoItem.autonomia_is-active {
	background: linear-gradient(
		135deg,
		rgba(255, 203, 0, 0.28),
		rgba(255, 203, 0, 0.42)
	);
	border-color: rgba(255, 203, 0, 0.75);
	box-shadow: 0 12px 28px rgba(0, 0, 0, 0.16);
	position: relative;
}
.autonomia_videoItem.autonomia_is-active::before {
	content: '';
	position: absolute;
	left: 0;
	top: 10px;
	bottom: 10px;
	width: 4px;
	border-radius: 4px;
	background: #ffcb00;
}

.autonomia_videoLink {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 12px 14px;
	color: #fff !important;
	text-decoration: none;
	outline: none;
}
.autonomia_videoLink:hover {
	color: #000;
}

.autonomia_videoLink:hover .autonomia_videoMeta,
.autonomia_videoLink:focus .autonomia_videoMeta {
	text-decoration: underline;
	color: #fff !important;
}

.autonomia_videoIcon {
	font-size: 22px;
	opacity: 0.9;
}

.autonomia_videoText {
	font-size: 18px;
	line-height: 1.3;
}

.autonomia_videoMeta {
	display: block;
	font-size: 13px;
	color: #ffcb00;
	margin-top: 2px;
}

/* Accesibilidad de foco con teclado */
.autonomia_videoLink:focus-visible {
	box-shadow: 0 0 0 3px rgba(255, 203, 0, 0.65);
	border-radius: 10px;
}

/* Responsive leve */
@media (max-width: 480px) {
	.autonomia_videoText {
		font-size: 16px;
	}
	.autonomia_videoIcon {
		font-size: 20px;
	}
}

/* Responsivo */
@media (max-width: 768px) {
	.autonomia_countdown__content {
		padding: 22px 14px;
	}
	.autonomia_countdown__grid {
		gap: 10px;
	}
	.autonomia_cd-value {
		font-size: 30px;
	}
}
@media (max-width: 420px) {
	.autonomia_countdown__grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* Ajustes pequeños de UX móvil */
@media (max-width: 380px) {
	:root {
		--autonomia-gap: 18px;
	}
	.autonomia_poster {
		border-radius: 8px;
	}
}
/* =========================================================
   MÓDULO: Galería de Postales (Carrusel)
   Estructura basada en Swiper + Fancybox
   ========================================================= */

/* ---------- Variables del módulo ---------- */
:root {
	/* Tamaño base de la tarjeta (puedes ajustarlo) */
	--autonomia-card-size: 350px;
	/* Separación visual entre tarjetas (el JS usará este valor) */
	--autonomia-gap: 25px;
}

/* ---------- Contenedor principal ---------- */
.autonomia_galeria {
	box-sizing: border-box;
	width: 100%;
	margin: 0 auto 50px auto;
	padding: 0;
}

/* Limita el ancho total (5 * card + 4 * gap = 1850px) en pantallas gigantes */
.autonomia_galeria--max5 {
	max-width: 1850px;
}

/* ---------- Carrusel (Swiper) ---------- */
.autonomia_carousel.swiper {
	position: relative;
	padding: 6px 48px; /* espacio para que no “tope” con los bordes y botones */
}

/* Cada slide contendrá una “postal” cuadrada */
.autonomia_carousel .swiper-slide {
	/* Si usas slidesPerView: 'auto' en JS,
     puedes fijar el ancho con la variable:
     width: var(--autonomia-card-size); */
	display: flex;
	align-items: center;
	justify-content: center;
}

/* ---------- Tarjeta/Postales ---------- */
.autonomia_poster {
	position: relative;
	width: 100%;
	max-width: var(--autonomia-card-size);
	aspect-ratio: 1 / 1; /* mantiene 1:1 */
	overflow: hidden;
	border-radius: 10px;
	box-shadow: 0 6px 18px rgba(0, 0, 0, 0.08);
	background: #f7f7f7;
	margin: 0 auto; /* centra dentro del slide */
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.autonomia_poster:hover {
	transform: translateY(-2px);
	box-shadow: 0 10px 24px rgba(0, 0, 0, 0.12);
}

/* Enlace que abre Fancybox ocupa toda la tarjeta */
.autonomia_link {
	display: block;
	width: 100%;
	height: 100%;
	text-decoration: none;
	outline: none;
	border: 0;
	cursor: zoom-in;
}
.autonomia_link:focus-visible {
	box-shadow: 0 0 0 3px rgba(0, 153, 255, 0.45);
}

/* Imagen recortada sin deformarse */
.autonomia_img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	-webkit-user-drag: none;
	user-select: none;
}

/* ---------- Controles prev/next ---------- */
.autonomia_nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 44px;
	height: 44px;
	border-radius: 9999px;
	background: rgba(0, 0, 0, 0.38);
	color: #fff;
	border: 1px solid rgba(255, 255, 255, 0.25);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	z-index: 5;
	cursor: pointer;
	transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
	box-shadow: 0 6px 16px rgba(0, 0, 0, 0.18);
}
.autonomia_prev {
	left: 8px;
}
.autonomia_next {
	right: 8px;
}

.autonomia_nav:hover,
.autonomia_nav:focus-visible {
	background: rgba(0, 0, 0, 0.6);
	transform: translateY(-50%) scale(1.04);
}

/* Oculta los botones cuando no hay overflow (Swiper lo hará luego via JS si quieres) */
/* .autonomia_nav[disabled] { opacity: .35; pointer-events: none; } */

/* ---------- Responsivo fino ---------- */
@media (max-width: 768px) {
	.autonomia_carousel.swiper {
		padding: 4px 40px;
	}
	.autonomia_poster {
		border-radius: 8px;
	}
}
@media (max-width: 380px) {
	:root {
		--autonomia-gap: 18px;
	}
}

/* =========================================================
   /MÓDULO: Galería de Postales (Carrusel)
   ========================================================= */
/* =========================================================
   MÓDULO: Boletines (Home) — lista SOLO 3 recientes
   ========================================================= */

/* ---------- Layout del bloque ---------- */
.autonomia_boletines {
	margin: 36px 0 44px;
}
.autonomia_boletines__header {
	text-align: center;
	margin-bottom: 14px;
}
.autonomia_boletines__title {
	/* font-family: 'Playfair Display', serif; */
	font-size: 28px;
	margin: 0;
	color: #333;
	font-weight: bold;
}
.autonomia_boletines__subtitle {
	margin: 4px 0 0;
	color: #666;
	font-size: 14px;
}

/* ---------- Grid de cards ---------- */
.autonomia_boletinGrid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}
@media (max-width: 992px) {
	.autonomia_boletinGrid {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (max-width: 600px) {
	.autonomia_boletinGrid {
		grid-template-columns: 1fr;
	}
}

/* ---------- Card ---------- */
.autonomia_boletinCard {
	background: #fff;
	border: 1px solid rgba(0, 0, 0, 0.06);
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 6px 16px rgba(0, 0, 0, 0.06);
	transition: transform 0.18s ease, box-shadow 0.18s ease,
		border-color 0.18s ease;
}
.autonomia_boletinCard:hover {
	transform: translateY(-2px);
	box-shadow: 0 12px 24px rgba(0, 0, 0, 0.1);
	border-color: rgba(128, 1, 1, 0.25);
}

/* Imagen con relación 16:9, recorte uniforme */
.autonomia_boletinFigure {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: #f7f7f7;
}
.autonomia_boletinFigure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Texto */
.autonomia_boletinLink {
	display: block;
	color: inherit;
	text-decoration: none;
}
.autonomia_boletinTitle {
	font-size: 18px;
	padding: 12px 14px 14px;
	line-height: 1.35;
	color: #222;
}

/* ---------- Footer del bloque ---------- */
.autonomia_boletines__footer {
	text-align: center;
	margin-top: 16px;
}
.autonomia_btn {
	display: inline-block;
	padding: 10px 16px;
	border-radius: 9999px;
	font-size: 14px;
	text-decoration: none;
	transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease,
		color 0.15s ease;
}
.autonomia_btn--ghost {
	background: transparent;
	color: #800101;
	border: 1px solid #800101;
}
.autonomia_btn--ghost:hover {
	background: #800101;
	color: #fff;
	box-shadow: 0 8px 18px rgba(128, 1, 1, 0.25);
	transform: translateY(-1px);
}
/* =========================================================
   /MÓDULO: Boletines (Home)
   ========================================================= */
/* =========================================================
       MÓDULO: Boletines (Página completa)
       Diseño en cards dentro de contenedor FLEX, responsivo
       ========================================================= */

/* ---------- Variables ---------- */
:root {
	--autonomia-gap: 18px; /* separación entre cards */
	--autonomia-card-min: 260px; /* ancho mínimo de card */
	--autonomia-card-ideal: 320px; /* base de flex-basis */
	--autonomia-radius: 12px;
	--autonomia-borde: rgba(0, 0, 0, 0.06);
	--autonomia-shadow: 0 6px 16px rgba(0, 0, 0, 0.06);
	--autonomia-shadow-hover: 0 12px 24px rgba(0, 0, 0, 0.1);
	--autonomia-color: #800101;
}

/* ---------- Cabecera de la página ---------- */
.autonomia_boletinesPage {
	max-width: 1200px;
	margin: 24px auto 40px;
	padding: 0 16px;
}
.autonomia_boletinesPage__header {
	text-align: center;
	margin-bottom: 18px;
}
.autonomia_boletinesPage__title {
	/* font-family: 'Playfair Display', serif; */
	font-size: 32px;
	font-weight: bold;
	line-height: 1.2;
	margin: 0;
	color: #333;
}
.autonomia_boletinesPage__subtitle {
	margin: 6px 0 0;
	color: #666;
	font-family: 'Lora', serif;
	font-size: 15px;
}

/* ---------- Contenedor FLEX de cards ---------- */
.autonomia_boletinFlex {
	display: grid;
	gap: var(--autonomia-gap, 18px);
	/* Desktop por defecto: 3 columnas */
	grid-template-columns: repeat(3, minmax(0, 1fr));
	align-items: stretch;
}

/* Breakpoints: 2 cols en tablet, 1 col en móvil */
@media (max-width: 992px) {
	.autonomia_boletinFlex {
		grid-template-columns: repeat(2, 1fr);
	}
}
@media (max-width: 600px) {
	.autonomia_boletinFlex {
		grid-template-columns: 1fr;
	}
}

/* El MÁS RECIENTE (primer article tras ordenar) ocupa todo el ancho */
.autonomia_boletinFlex > .autonomia_boletinCard:first-child {
	grid-column: 1 / -1; /* span en todas las columnas */
	display: block;
}

/* Ajuste visual: imagen más panorámica para el destacado */
.autonomia_boletinFlex
	> .autonomia_boletinCard:first-child
	.autonomia_boletinFigure {
	aspect-ratio: 21 / 9; /* más “hero” */
}
@media (max-width: 600px) {
	.autonomia_boletinFlex
		> .autonomia_boletinCard:first-child
		.autonomia_boletinFigure {
		aspect-ratio: 16 / 9; /* en móvil mantenemos 16:9 */
	}
}

/* ---------- Card ---------- */
.autonomia_boletinCard {
	flex: 1 1 var(--autonomia-card-ideal); /* base ideal */
	min-width: var(--autonomia-card-min); /* mínimo responsivo */
	max-width: 100%;
	background: #fff;
	border: 1px solid var(--autonomia-borde);
	border-radius: var(--autonomia-radius);
	overflow: hidden;
	box-shadow: var(--autonomia-shadow);
	transition: transform 0.18s ease, box-shadow 0.18s ease,
		border-color 0.18s ease;
}
.autonomia_boletinCard:hover {
	transform: translateY(-2px);
	box-shadow: var(--autonomia-shadow-hover);
	border-color: rgba(128, 1, 1, 0.25);
}

/* Imagen 16:9 */
.autonomia_boletinFigure {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 9;
	background: #f7f7f7;
	overflow: hidden;
}
.autonomia_boletinFigure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Texto */
.autonomia_boletinLink {
	display: block;
	color: inherit;
	text-decoration: none;
}
.autonomia_boletinTitle {
	font-size: 18px;
	line-height: 1.35;
	color: #222;
	padding: 12px 14px 14px;
	margin: 0;
	/* font-family: 'Lora', serif; */
}
.autonomia_boletinLink:focus-visible {
	outline: none;
	box-shadow: 0 0 0 3px rgba(0, 153, 255, 0.45);
	border-radius: calc(var(--autonomia-radius) - 2px);
}

/* ---------- Barra de acciones inferior (opcional) ---------- */
.autonomia_boletinesPage__actions {
	text-align: center;
	margin-top: 22px;
}
.autonomia_btn {
	display: inline-block;
	padding: 10px 16px;
	border-radius: 9999px;
	font-size: 14px;
	text-decoration: none;
	transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease,
		color 0.15s ease;
}
.autonomia_btn--ghost {
	background: transparent;
	color: var(--autonomia-color);
	border: 1px solid var(--autonomia-color);
}
.autonomia_btn--ghost:hover {
	background: var(--autonomia-color);
	color: #fff;
	box-shadow: 0 8px 18px rgba(128, 1, 1, 0.25);
	transform: translateY(-1px);
}

/* ---------- Responsivo fino ---------- */
@media (max-width: 480px) {
	.autonomia_boletinesPage {
		padding: 0 12px;
	}
	.autonomia_boletinTitle {
		font-size: 16px;
	}
}
/* =========================================================
   MÓDULO: Hero Episodios (full width, 430px)
   ========================================================= */

:root {
	--autonomia-hero-h: 430px; /* alto desktop */
}

/* Contenedor de fondo: imagen centrada, sin distorsión */
/* .autonomia_episodesHero {
	position: relative;
	width: 100%;
	height: var(--autonomia-hero-h);
	background-position: center center;
	background-size: cover; 
	background-repeat: no-repeat;
	isolation: isolate;
} */
/* .autonomia_episodesHero::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(
			110% 70% at 80% 50%,
			rgba(0, 0, 0, 0.35) 0%,
			rgba(0, 0, 0, 0) 55%
		),
		linear-gradient(180deg, rgba(0, 0, 0, 0.18), rgba(0, 0, 0, 0.18));
	z-index: 0;
} */

/* Wrapper de contenido (centra y separa extremos) */
/* .autonomia_episodesHero_inner {
	position: relative;
	z-index: 1;
	height: 100%;
	max-width: 1280px; 
	margin: 0 auto;
	padding: 0 24px;
	display: flex;
	align-items: center;
	justify-content: space-evenly;
} */
.autonomia_episodesHero {
	position: relative;
	width: 100%;
	height: var(--autonomia-hero-h);
	isolation: isolate; /* crea stacking context para capas */
}

/* Capa de oscurecido para mejorar contraste */
.autonomia_episodesHero::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(
			110% 70% at 80% 50%,
			rgba(0, 0, 0, 0.35) 0%,
			rgba(0, 0, 0, 0) 55%
		),
		linear-gradient(180deg, rgba(0, 0, 0, 0.18), rgba(0, 0, 0, 0.18));
	z-index: 1; /* sobre el video, bajo el contenido */
}
/* Video cubriendo el contenedor, centrado, sin distorsión */
.autonomia_episodesHero_video {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover; /* fill sin distorsionar */
	object-position: center; /* siempre centrado */
	z-index: 0;
	pointer-events: none; /* no interfiere con clics del botón/logo */
}

/* Contenido por encima del overlay */
.autonomia_episodesHero_inner {
	position: relative;
	z-index: 2;
	height: 100%;
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 24px;
	display: flex;
	align-items: center;
	justify-content: space-evenly;
}

/* Logo lado izquierdo */
.autonomia_episodesHero_logo {
	display: block;
	max-height: 330px;
	width: auto;
	/* filter: contrast(1.05) brightness(1);  */
}

/* Botón: transparente con borde blanco, hover invertido + pulso */
.autonomia_btnEpisode {
	display: inline-block;
	padding: 12px 22px;
	border-radius: 9999px;
	border: 2px solid #fff;
	color: #fff;
	background: transparent;
	text-decoration: none;
	font-weight: 600;
	letter-spacing: 0.02em;
	box-shadow: 0 6px 16px rgba(0, 0, 0, 0.22);
	transition: background 0.22s ease, color 0.22s ease, transform 0.12s ease,
		box-shadow 0.22s ease;
	font-size: 20px;
}
.autonomia_btnEpisode:hover,
.autonomia_btnEpisode:focus-visible {
	background: #fff;
	color: #111;
	transform: translateY(-1px);
	box-shadow: 0 10px 22px rgba(0, 0, 0, 0.28);
	outline: none;
}
.autonomia_btnEpisode:active {
	transform: translateY(0);
	box-shadow: 0 6px 16px rgba(0, 0, 0, 0.2);
}
.autonomia_episodesHero_media {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover; /* cubre sin deformar */
	object-position: center; /* siempre centrado */
	z-index: 0;
	pointer-events: none; /* no bloquea clics del botón */
}

/* Accesibilidad: respeta “reducir movimiento” mostrando solo el overlay y contenido */
@media (prefers-reduced-motion: reduce) {
	.autonomia_episodesHero_media {
		display: none;
	}
}

/* Pulso sutil para llamar la atención */
@keyframes autonomia_btnPulse {
	0% {
		box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.45);
		transform: scale(1);
	}
	70% {
		box-shadow: 0 0 0 16px rgba(255, 255, 255, 0);
		transform: scale(1.02);
	}
	100% {
		box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
		transform: scale(1);
	}
}
.autonomia_btnEpisode--pulse {
	animation: autonomia_btnPulse 2.6s ease-out infinite;
}
.autonomia_btnEpisode:hover.autonomia_btnEpisode--pulse {
	animation-play-state: paused; /* pausa el pulso cuando el usuario interactúa */
}

/* Responsivo */
@media (max-width: 992px) {
	.autonomia_episodesHero_logo {
		max-height: 300px;
	}
}
@media (max-width: 768px) {
	:root {
		--autonomia-hero-h: 380px;
	} /* un poco más bajo en tablet/móvil */
	.autonomia_episodesHero_inner {
		flex-direction: column; /* apila logo y botón */
		justify-content: center;
		gap: 16px;
		text-align: center;
	}
}
@media (max-width: 420px) {
	:root {
		--autonomia-hero-h: 340px;
	}
	.autonomia_btnEpisode {
		padding: 10px 18px;
	}
	.autonomia_episodesHero_logo {
		max-height: 200px;
	}
}
/* Respeto a usuarios con “reducir movimiento” */
@media (prefers-reduced-motion: reduce) {
	.autonomia_episodesHero_video {
		animation: none;
	}
}
/* =========================================================
   /MÓDULO: Hero Episodios
   ========================================================= */
/* =========================================================
   MÓDULO: YouTube Live (skin + 16:9 responsivo)
   ========================================================= */
:root {
	--autonomia-live-maxw: 1100px; /* ancho máx del player */
	--autonomia-live-radius: 14px;
	--autonomia-live-ink: #fff;
}

/* Contenedor centrado */
.autonomia_live .autonomia_liveShell {
	max-width: var(--autonomia-live-maxw);
	margin: 16px auto 28px;
	padding: 14px;
	position: relative;
	border-radius: calc(var(--autonomia-live-radius) + 6px);
	/* Marco degradado */
	background: linear-gradient(
				135deg,
				rgba(255, 255, 255, 0.08),
				rgba(255, 255, 255, 0.04)
			)
			padding-box,
		linear-gradient(135deg, #ffcb00, #ff7a00 40%, #b11a1a 75%, #800101)
			border-box;
	border: 2px solid transparent;
	box-shadow: 0 14px 40px rgba(0, 0, 0, 0.28);
	color: var(--autonomia-live-ink);
}

/* Header: badge + título + enlace YouTube */
.autonomia_liveHeader {
	display: flex;
	align-items: center;
	gap: 10px;
	justify-content: space-between;
	flex-wrap: wrap;
	margin: 6px 4px 10px;
}
.autonomia_liveBadge {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: rgba(255, 0, 0, 0.14);
	border: 1px solid rgba(255, 0, 0, 0.45);
	padding: 6px 10px;
	border-radius: 9999px;
	font-weight: 700;
	letter-spacing: 0.02em;
}
.autonomia_liveBadge .dot {
	width: 10px;
	height: 10px;
	border-radius: 9999px;
	background: #ff3b30;
	display: inline-block;
	box-shadow: 0 0 0 0 rgba(255, 59, 48, 0.6);
	animation: autonomia_pulse 1.8s ease-out infinite;
}
@keyframes autonomia_pulse {
	70% {
		box-shadow: 0 0 0 10px rgba(255, 59, 48, 0);
	}
	100% {
		box-shadow: 0 0 0 0 rgba(255, 59, 48, 0);
	}
}

.autonomia_liveTitle {
	flex: 1 1 auto;
	margin: 0;
	text-align: center;
	font-size: 20px;
	font-weight: 700;
}
.autonomia_liveOpen {
	display: inline-block;
	padding: 8px 12px;
	border-radius: 9999px;
	border: 1px solid rgba(255, 255, 255, 0.65);
	color: #fff;
	text-decoration: none;
	transition: background 0.18s ease, color 0.18s ease, transform 0.12s ease,
		box-shadow 0.18s ease;
}
.autonomia_liveOpen:hover,
.autonomia_liveOpen:focus-visible {
	background: #fff;
	color: #111;
	transform: translateY(-1px);
	box-shadow: 0 10px 22px rgba(0, 0, 0, 0.28);
	outline: none;
}

/* Wrapper 16:9 clásico (compat amplio) */
.autonomia_livePlayer {
	border-radius: var(--autonomia-live-radius);
	overflow: hidden;
	background: #000;
}
.autonomia_livePlayerInner {
	position: relative;
	width: 100%;
	height: 0;
	padding-bottom: 56.25%;
}
.autonomia_livePlayerInner iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
}

/* Responsivo fino */
@media (max-width: 480px) {
	.autonomia_liveTitle {
		font-size: 16px;
	}
	.autonomia_liveOpen {
		padding: 7px 10px;
	}
}
/* =========================================================
   /MÓDULO: YouTube Live
   ========================================================= */
