
/* ==========================================================================
   CONFIGURACIÓN GLOBAL Y VARIABLES
   ========================================================================== */
:root {
	/* PALETA DE COLORES: INSPIRACIÓN CUERNAVACA (BUGAMBILIA Y FRESCURA) */
	--color-marca-principal-bugambilia: #C2185B;
	--color-marca-secundario-oscuro:    #880E4F;
	--color-texto-principal:            #263238; /* Gris azulado oscuro para mejor lectura */
	--color-texto-secundario:           #546E7A;
	--color-fondo-sitio:                #F4F6F8; /* Gris muy tenue, casi blanco */
	--color-fondo-tarjeta:              #FFFFFF;
	--color-borde-suave:                #ECEFF1;

	/* TIPOGRAFÍA */
	--fuente-principal-lectura:         system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	--fuente-titulos-marca:             "Playfair Display", Georgia, "Times New Roman", serif;

	/* ESPACIADO Y SOMBRAS */
	--sombra-tarjeta-suave:             0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
	--sombra-tarjeta-hover:             0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
	--radio-borde-tarjeta:              12px;
}

/* ==========================================================================
   ESTILOS BASE
   ========================================================================== */
body {
	font-family: var(--fuente-principal-lectura);
	background-color: var(--color-fondo-sitio);
	color: var(--color-texto-principal);
	margin: 0;
	padding: 0;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased; /* Renderizado de fuente más nítido */
}

/* ==========================================================================
   ENCABEZADO (HEADER)
   ========================================================================== */
header {
	background-color: var(--color-fondo-tarjeta);
	border-bottom: 1px solid var(--color-borde-suave);
	padding: 20px 0px 0px 0px;
	text-align: center;
	color: var(--color-texto-principal);
	box-shadow: 0 2px 4px rgba(0,0,0,0.02);
	position: sticky; /* Mantiene el header visible al hacer scroll */
	top: 0;
	z-index: 1000;
}

.cabecera-superior {
	font-size: 11px;
	color: var(--color-texto-secundario);
	text-transform: uppercase;
	padding-bottom: 10px;
	width: 90%;
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	display: flex;
	justify-content: space-between;
	letter-spacing: 0.5px;
	border-bottom: 1px solid var(--color-borde-suave);
	margin-bottom: 15px;
}

h1.logo-sitio {
	font-family: var(--fuente-titulos-marca);
	font-size: 42px;
	margin: 0;
	text-transform: uppercase;
	letter-spacing: -1px;
	color: var(--color-marca-principal-bugambilia); /* Color Bugambilia para identidad */
	font-weight: 900;
	line-height: 1;
}

.slogan-sitio {
	font-family: var(--fuente-principal-lectura);
	font-weight: 300;
	color: var(--color-texto-secundario);
	margin-top: 5px;
	font-size: 13px;
	letter-spacing: 1px;
	text-transform: uppercase;
}

/* ==========================================================================
   NAVEGACIÓN PRINCIPAL
   ========================================================================== */
nav.menu-principal {
	background-color: var(--color-fondo-tarjeta); /* Fondo blanco limpio */
	color: var(--color-texto-principal);
	text-align: center;
	padding: 15px 0;
	margin-top: 0;
	border-bottom: none;
}

nav.menu-principal a {
	color: var(--color-texto-principal);
	text-decoration: none;
	margin: 0 12px;
	font-weight: 600;
	text-transform: uppercase;
	font-size: 13px;
	transition: all 0.3s ease;
	padding-bottom: 4px;
	border-bottom: 2px solid transparent;
}

nav.menu-principal a:hover {
	color: var(--color-marca-principal-bugambilia);
	border-bottom-color: var(--color-marca-principal-bugambilia);
}

/* ==========================================================================
   LAYOUT Y CONTENEDORES
   ========================================================================== */
.contenedor-principal {
	width: 90%;
	max-width: 1200px; /* Ancho máximo aumentado para pantallas modernas */
	margin: 40px auto;
	background-color: transparent; /* Eliminamos la caja blanca contenedora gigante */
	padding: 0;
	box-shadow: none; /* Eliminamos la sombra global antigua */
	display: block;
}

.barra-lateral {
	border-left: none; /* Quitamos la línea divisoria antigua */
	padding-left: 0;
	background-color: var(--color-fondo-tarjeta);
	padding: 25px;
	border-radius: var(--radio-borde-tarjeta);
	box-shadow: var(--sombra-tarjeta-suave);
}

/* ==========================================================================
   COMPONENTES: TARJETAS Y NOTICIAS
   ========================================================================== */
article.tarjeta-resumen {
	border-bottom: none;
	padding: 30px;
	margin-bottom: 30px;
	background-color: var(--color-fondo-tarjeta);
	border-radius: var(--radio-borde-tarjeta);
	box-shadow: var(--sombra-tarjeta-suave);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

article.tarjeta-resumen:hover {
	transform: translateY(-2px);
	box-shadow: var(--sombra-tarjeta-hover);
}

article.tarjeta-resumen h2 {
	font-family: var(--fuente-principal-lectura);
	font-weight: 800; /* Extra bold para titulares modernos */
	font-size: 26px;
	margin-bottom: 12px;
	line-height: 1.3;
	letter-spacing: -0.5px;
}

article.tarjeta-resumen h2 a {
	color: var(--color-texto-principal);
	text-decoration: none;
	background-image: linear-gradient(120deg, transparent 0%, transparent 100%);
	background-repeat: no-repeat;
	background-size: 100% 0.2em;
	background-position: 0 88%;
	transition: background-size 0.25s ease-in;
}

article.tarjeta-resumen h2 a:hover {
	color: var(--color-marca-principal-bugambilia);
	text-decoration: none;
}

.meta-datos {
	font-size: 11px;
	color: var(--color-marca-principal-bugambilia);
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	display: inline-block;
	background-color: rgba(194, 24, 91, 0.11); /* Fondo sutil magenta */
	padding: 6px 8px;
	border-radius: 4px;
}

.resumen-texto {
	font-size: 16px;
	line-height: 1.7;
	color: var(--color-texto-secundario);
	margin-bottom: 20px;
}

.leer-mas {
	display: inline-flex;
	align-items: center;
	margin-top: 10px;
	color: var(--color-marca-principal-bugambilia);
	font-weight: 700;
	text-decoration: none;
	font-size: 14px;
	border-bottom: none;
}

.leer-mas:after {
	content: "→";
	margin-left: 5px;
	transition: margin-left 0.2s;
}

.leer-mas:hover:after {
	margin-left: 10px;
}

/* ==========================================================================
   PÁGINA DE ARTÍCULO COMPLETO
   ========================================================================== */
.articulo-completo h1 {
	font-family: var(--fuente-principal-lectura);
	font-size: 48px;
	margin-bottom: 20px;
	line-height: 1.1;
	color: var(--color-texto-principal);
	font-weight: 800;
	letter-spacing: -1px;
}

.articulo-completo .bajada {
	font-size: 20px;
	font-weight: 400;
	color: var(--color-texto-secundario);
	margin-bottom: 30px;
	line-height: 1.5;
	font-style: normal;
	border-left: 4px solid var(--color-marca-principal-bugambilia);
	padding-left: 20px;
}

.cuerpo-articulo {
	font-size: 18px;
	line-height: 1.8;
	font-family: var(--fuente-titulos-marca); /* Serif para el cuerpo de lectura larga */
	color: #333;
}

/* ==========================================================================
   PIE DE PÁGINA (FOOTER)
   ========================================================================== */
footer {
	background-color: #1a1a1a;
	color: #90a4ae;
	text-align: center;
	padding: 60px 0;
	margin-top: 80px;
	font-size: 14px;
	border-top: 4px solid var(--color-marca-principal-bugambilia);
}

/* ==========================================================================
   PUBLICIDAD Y GRID DE FICHAS
   ========================================================================== */
.publicidad {
	background-color: var(--color-fondo-sitio);
	border: 2px dashed var(--color-borde-suave);
	padding: 40px;
	text-align: center;
	margin-bottom: 30px;
	border-radius: var(--radio-borde-tarjeta);
	font-weight: 600;
	color: var(--color-texto-secundario);
}

.contenedor-grid-fichas {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); /* Tarjetas más anchas */
	gap: 30px;
	padding-bottom: 40px;
}

.ficha-noticia {
	background-color: var(--color-fondo-tarjeta);
	border: none;
	border-radius: var(--radio-borde-tarjeta);
	padding: 0; /* Padding controlado internamente */
	box-shadow: var(--sombra-tarjeta-suave);
	display: block;
	transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275), box-shadow 0.3s;
	overflow: hidden; /* Para contener contenido interno */
}

.encabezado-seccion-index {
	text-align: center;
}

.encabezado-seccion-categoria {
	text-align: center;
}

/* Contenedor interno para dar padding, simulando estructura de tarjeta moderna */
.ficha-noticia > * {
	padding-left: 20px;
	padding-right: 20px;
}

.ficha-noticia h2 {
	padding-top: 5px;
	font-family: var(--fuente-principal-lectura);
	font-weight: 700;
	font-size: 18px;
}

.ficha-noticia:hover {
	transform: translateY(-5px);
	box-shadow: var(--sombra-tarjeta-hover);
	border-color: transparent; /* Eliminamos cambio de borde, usamos sombra */
}

.boton-leer-mas {
	align-self: flex-start;
	background-color: var(--color-marca-principal-bugambilia);
	color: white;
	text-decoration: none;
	padding: 10px 20px;
	margin: 20px;
	font-size: 12px;
	font-weight: 700;
	border-radius: 50px; /* Botón píldora moderno */
	text-transform: uppercase;
	letter-spacing: 1px;
	transition: background-color 0.2s, transform 0.1s;
	box-shadow: 0 4px 6px rgba(194, 24, 91, 0.11);
}

.boton-leer-mas:hover {
	background-color: var(--color-marca-secundario-oscuro);
	color: white;
	transform: scale(1.05);
}

