/*
Theme Name: Misa de Hoy
Theme URI: https://misadehoy.org
Author: misadehoy.org
Description: Tema propio de misadehoy.org — evangelio del día y buscador de iglesias de Latinoamérica. Diseño litúrgico, cálido y responsivo.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 7.0
Requires PHP: 7.4
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: misadehoy
*/

/* ============================================================
   Paleta y variables
   ============================================================ */
:root {
	--md-vino: #7a1f2b;
	--md-vino-osc: #5c1620;
	--md-oro: #c8a24a;
	--md-oro-osc: #a8832f;
	--md-crema: #f6efe4;
	--md-crema-2: #efe5d4;
	--md-tinta: #2a2422;
	--md-gris: #6f665f;
	--md-borde: #e2d8c7;
	--md-blanco: #fffdf9;
	--md-sombra: 0 10px 30px rgba(60, 30, 20, .10);
	--md-serif: "Playfair Display", Georgia, "Times New Roman", serif;
	--md-sans: "Source Sans 3", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	--md-radio: 16px;
}

/* ============================================================
   Base
   ============================================================ */
* { box-sizing: border-box; }

body {
	margin: 0;
	font-family: var(--md-sans);
	color: var(--md-tinta);
	background: var(--md-crema);
	line-height: 1.65;
	font-size: 18px;
	-webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 { font-family: var(--md-serif); line-height: 1.2; color: var(--md-vino); }

a { color: var(--md-vino); text-decoration: none; }
a:hover { text-decoration: underline; }

img { max-width: 100%; height: auto; }

.contenedor { width: min(1080px, 92vw); margin-inline: auto; }

.skip-link { position: absolute; left: -9999px; }
.skip-link:focus { left: 12px; top: 12px; background: #fff; padding: 8px 14px; z-index: 999; border-radius: 8px; }

/* ============================================================
   Encabezado
   ============================================================ */
.site-header {
	background: linear-gradient(180deg, var(--md-vino) 0%, var(--md-vino-osc) 100%);
	color: #fdf7ec;
	border-bottom: 4px solid var(--md-oro);
}
.site-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	padding: .9rem 0;
	flex-wrap: wrap;
}
.site-brand { display: flex; align-items: center; gap: .7rem; text-decoration: none; }
.site-brand:hover { text-decoration: none; }
.site-brand__mark {
	width: 46px; height: 46px; flex: 0 0 46px;
	display: grid; place-items: center;
	background: var(--md-oro);
	color: var(--md-vino-osc);
	border-radius: 50%;
	font-family: var(--md-serif);
	font-size: 1.5rem; font-weight: 700;
}
.site-brand__text { display: flex; flex-direction: column; line-height: 1.05; }
.site-brand__name { font-family: var(--md-serif); font-size: 1.5rem; color: #fff; font-weight: 700; }
.site-brand__tag { font-size: .72rem; letter-spacing: .16em; text-transform: uppercase; color: var(--md-oro); }

.nav-menu { list-style: none; display: flex; gap: 1.4rem; margin: 0; padding: 0; flex-wrap: wrap; }
.nav-menu a { color: #f3e7d4; font-size: .95rem; font-weight: 600; }
.nav-menu a:hover { color: #fff; text-decoration: none; border-bottom: 2px solid var(--md-oro); }

/* ============================================================
   Hero
   ============================================================ */
.hero {
	position: relative;
	background:
		radial-gradient(1100px 380px at 50% -140px, rgba(200,162,74,.22), transparent 70%),
		linear-gradient(180deg, var(--md-crema) 0%, var(--md-crema-2) 100%);
	text-align: center;
	padding: 3.6rem 0 2.8rem;
	border-bottom: 1px solid var(--md-borde);
	overflow: hidden;
}
/* Filigrana decorativa sutil arriba */
.hero::before {
	content: "";
	position: absolute;
	inset: 0 0 auto 0;
	height: 4px;
	background: linear-gradient(90deg, transparent, var(--md-oro), transparent);
}
.hero__cruz { color: var(--md-oro); font-size: 2.2rem; line-height: 1; margin-bottom: .5rem; }
.hero__titulo { font-size: clamp(2.2rem, 5.5vw, 3.4rem); font-weight: 800; letter-spacing: -.01em; margin: 0 0 .5rem; }
.hero__sub { font-size: 1.15rem; color: var(--md-gris); max-width: 640px; margin: 0 auto 1.1rem; }
.hero__fecha {
	display: inline-block;
	background: var(--md-blanco);
	border: 1px solid var(--md-borde);
	border-radius: 999px;
	padding: .4rem 1.2rem;
	font-size: .95rem;
	color: var(--md-vino);
	text-transform: capitalize;
	box-shadow: var(--md-sombra);
}

/* Barra de estadísticas del hero */
.hero__stats {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 1rem;
	margin-top: 1.8rem;
}
.hero__stat {
	background: var(--md-blanco);
	border: 1px solid var(--md-borde);
	border-radius: 14px;
	padding: .9rem 1.6rem;
	min-width: 130px;
	box-shadow: var(--md-sombra);
}
.hero__stat-num {
	display: block;
	font-family: var(--md-serif);
	font-weight: 800;
	font-size: 1.9rem;
	color: var(--md-vino);
	line-height: 1;
}
.hero__stat-lbl {
	display: block;
	margin-top: .25rem;
	font-size: .82rem;
	text-transform: uppercase;
	letter-spacing: .1em;
	color: var(--md-oro-osc);
	font-weight: 700;
}

/* ============================================================
   Secciones de la portada
   ============================================================ */
.seccion { padding: 3rem 0; }
.seccion--alt { background: var(--md-blanco); border-block: 1px solid var(--md-borde); }
.seccion__cabecera { text-align: center; max-width: 680px; margin: 0 auto 1.8rem; }
.seccion__eyebrow { text-transform: uppercase; letter-spacing: .18em; font-size: .78rem; color: var(--md-oro-osc); font-weight: 700; }
.seccion__titulo { font-size: clamp(1.6rem, 3.5vw, 2.2rem); margin: .3rem 0 .5rem; }
.seccion__texto { color: var(--md-gris); margin: 0; }

/* El plugin ya trae su propio estilo para el evangelio y el buscador;
   aquí solo ajustamos el ancho y algún detalle para que encaje. */
.seccion .misadehoy-evangelio,
.seccion .misadehoy-buscador { max-width: 820px; }

/* ============================================================
   Contenido general (páginas y entradas)
   ============================================================ */
.contenido { padding: 2.6rem 0 3.2rem; }
.entrada { background: var(--md-blanco); border: 1px solid var(--md-borde); border-radius: var(--md-radio); padding: 2rem 2.2rem; box-shadow: var(--md-sombra); }
.entrada__titulo { font-size: clamp(1.8rem, 4vw, 2.4rem); margin: 0 0 .6rem; }
.entrada__meta { color: var(--md-gris); font-size: .9rem; margin-bottom: 1.4rem; }
.entrada__cuerpo p { margin: 0 0 1rem; }
.entrada__cuerpo h2, .entrada__cuerpo h3 { margin-top: 1.6rem; }

/* ============================================================
   Ficha de iglesia (single-iglesia)
   ============================================================ */
.iglesia-hero { background: var(--md-crema-2); border-bottom: 1px solid var(--md-borde); padding: 2.2rem 0; }
.iglesia-hero__tag { color: var(--md-oro-osc); font-weight: 700; text-transform: uppercase; letter-spacing: .1em; font-size: .8rem; }
.iglesia-hero__titulo { font-size: clamp(1.8rem, 4vw, 2.6rem); margin: .3rem 0; }
.iglesia-hero__lugar { color: var(--md-gris); }
.iglesia-grid { display: grid; grid-template-columns: 1fr; gap: 1.4rem; padding: 2.4rem 0 3rem; }
@media (min-width: 800px) { .iglesia-grid { grid-template-columns: 1.4fr 1fr; } }
.ficha-card { background: var(--md-blanco); border: 1px solid var(--md-borde); border-radius: var(--md-radio); padding: 1.4rem 1.6rem; box-shadow: var(--md-sombra); }
.ficha-card h2 { font-size: 1.15rem; margin: 0 0 .8rem; padding-bottom: .5rem; border-bottom: 2px solid var(--md-oro); }
.ficha-dato { display: flex; gap: .6rem; margin-bottom: .7rem; }
.ficha-dato__ico { color: var(--md-vino); flex: 0 0 auto; }
.ficha-horarios { white-space: pre-line; background: var(--md-crema); border-radius: 10px; padding: .8rem 1rem; }
.btn-mapa { display: inline-block; background: var(--md-vino); color: #fff; padding: .6rem 1.1rem; border-radius: 10px; font-weight: 600; margin-top: .4rem; }
.btn-mapa:hover { background: var(--md-vino-osc); text-decoration: none; }

/* ============================================================
   Pie
   ============================================================ */
.site-footer {
	background: var(--md-vino-osc);
	color: #e9d9c4;
	padding: 2.4rem 0 1.4rem;
	border-top: 4px solid var(--md-oro);
	margin-top: 2rem;
}
.site-footer a { color: var(--md-oro); }
.site-footer__cols { display: grid; gap: 1.6rem; grid-template-columns: 1fr; }
@media (min-width: 720px) { .site-footer__cols { grid-template-columns: 2fr 1fr; } }
.footer-widget__title, .site-footer h3 { color: #fff; font-size: 1.1rem; margin: 0 0 .6rem; }
.site-footer__legal { border-top: 1px solid rgba(255,255,255,.15); margin-top: 1.6rem; padding-top: 1rem; font-size: .85rem; color: #d9c4ab; text-align: center; }

/* ============================================================
   Directorio de iglesias (archive-iglesia)
   ============================================================ */
.dir-pais { margin-bottom: 2.6rem; }
.dir-pais__titulo {
	font-size: 1.8rem;
	border-bottom: 3px solid var(--md-oro);
	padding-bottom: .4rem;
	margin: 0 0 1.2rem;
}
.dir-arq { margin-bottom: 1.6rem; }
.dir-arq__titulo {
	font-size: 1.15rem;
	color: var(--md-vino);
	display: flex; align-items: center; gap: .5rem;
	margin: 0 0 .7rem;
}
.dir-arq__conteo {
	background: var(--md-crema-2);
	color: var(--md-gris);
	border-radius: 999px;
	font-family: var(--md-sans);
	font-size: .75rem;
	font-weight: 700;
	padding: .1rem .55rem;
}
.dir-lista {
	list-style: none;
	margin: 0; padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: .5rem;
}
@media (min-width: 620px) { .dir-lista { grid-template-columns: 1fr 1fr; } }
@media (min-width: 980px) { .dir-lista { grid-template-columns: 1fr 1fr 1fr; } }
.dir-item {
	display: flex; align-items: center; gap: .4rem;
	background: var(--md-blanco);
	border: 1px solid var(--md-borde);
	border-radius: 10px;
	padding: .6rem .8rem;
}
.dir-item:hover { border-color: var(--md-oro); }
.dir-item a { display: flex; flex-direction: column; flex: 1; text-decoration: none; }
.dir-item a:hover .dir-item__nombre { text-decoration: underline; }
.dir-item__nombre { font-weight: 600; color: var(--md-tinta); font-size: .95rem; }
.dir-item__ciudad { font-size: .8rem; color: var(--md-gris); }
.dir-item__badge { flex: 0 0 auto; font-size: .9rem; }

/* Tarjetas del índice de arquidiócesis */
.dir-tarjetas {
	display: grid;
	grid-template-columns: 1fr;
	gap: .8rem;
}
@media (min-width: 620px) { .dir-tarjetas { grid-template-columns: 1fr 1fr; } }
@media (min-width: 980px) { .dir-tarjetas { grid-template-columns: 1fr 1fr 1fr; } }
.dir-tarjeta {
	display: flex; flex-direction: column; gap: .2rem;
	background: var(--md-blanco);
	border: 1px solid var(--md-borde);
	border-left: 4px solid var(--md-oro);
	border-radius: 12px;
	padding: 1rem 1.2rem;
	text-decoration: none;
	box-shadow: var(--md-sombra);
}
.dir-tarjeta:hover { border-left-color: var(--md-vino); text-decoration: none; transform: translateY(-2px); transition: .15s; }
.dir-tarjeta__nombre { font-family: var(--md-serif); font-weight: 700; color: var(--md-vino); font-size: 1.1rem; }
.dir-tarjeta__conteo { color: var(--md-gris); font-size: .9rem; }

/* Paginación del listado por arquidiócesis */
.dir-paginacion { margin-top: 2rem; text-align: center; }
.dir-paginacion .page-numbers {
	display: inline-block;
	padding: .45rem .8rem;
	margin: 0 .15rem;
	border: 1px solid var(--md-borde);
	border-radius: 8px;
	background: var(--md-blanco);
	color: var(--md-vino);
	text-decoration: none;
	font-weight: 600;
}
.dir-paginacion .page-numbers.current { background: var(--md-vino); color: #fff; border-color: var(--md-vino); }
.dir-paginacion .page-numbers:hover:not(.current) { border-color: var(--md-oro); }

/* ============================================================
   Utilidades / responsive
   ============================================================ */
.text-center { text-align: center; }
.mt-2 { margin-top: 2rem; }

@media (max-width: 600px) {
	body { font-size: 17px; }
	.site-header__inner { justify-content: center; text-align: center; }
	.nav-menu { justify-content: center; gap: 1rem; }
	.entrada { padding: 1.4rem 1.2rem; }
}
