/*
Theme Name: Salud Plena 50
Theme URI: https://saludplena50.com
Author: Isabel Navarro
Description: Tema personalizado para el blog de salud y bienestar Salud Plena 50, estilo editorial, pensado para adultos de 50 años en adelante: alto contraste, fuentes grandes y navegación simple.
Version: 1.2
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: saludplena50
*/

:root {
	--oscuro: #22262B;
	--verde-matcha: #AAB448;
	--verde-matcha-oscuro: #6E7A2E;
	--verde-matcha-claro: #EEF0DA;
	--crema: #F8F6F0;
	--blanco: #FFFFFF;
	--texto: #23292B;
	--texto-suave: #6B7280;
	--borde: #E7E3D8;
	--radio: 14px;
	--sombra: 0 4px 14px rgba(35, 41, 43, 0.08);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
	margin: 0;
	background: var(--crema);
	color: var(--texto);
	font-family: 'Inter', Arial, sans-serif;
	font-size: 18px;
	line-height: 1.7;
}

h1, h2, h3, h4, h5, h6 {
	font-family: 'Lora', Georgia, serif;
	color: var(--texto);
	line-height: 1.3;
	margin-top: 1.4em;
	margin-bottom: 0.5em;
	font-weight: 700;
}

h1 { font-size: 2.3rem; }
h2 { font-size: 1.7rem; }
h3 { font-size: 1.3rem; }
h4 { font-size: 1.1rem; }

a { color: var(--verde-matcha-oscuro); text-decoration: underline; }
a:hover { color: var(--verde-matcha); }

img { max-width: 100%; height: auto; border-radius: var(--radio); }

.container { max-width: 1140px; margin: 0 auto; padding: 0 20px; }

/* Botones / CTA */
.btn, .wp-block-button__link, input[type="submit"] {
	display: inline-block;
	background: var(--verde-matcha);
	color: #fff !important;
	padding: 14px 28px;
	border-radius: 50px;
	text-decoration: none;
	font-family: 'Inter', Arial, sans-serif;
	font-weight: 600;
	font-size: 1.05rem;
	border: none;
	cursor: pointer;
	transition: transform .15s ease, opacity .15s ease;
}
.btn:hover, .wp-block-button__link:hover { opacity: .9; transform: translateY(-2px); color: #fff !important; }

/* Header */
.site-header { background: #fff; box-shadow: var(--sombra); position: sticky; top: 0; z-index: 100; }
.header-inner { display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 16px 20px; flex-wrap: wrap; }
.site-logo { display: inline-flex; align-items: center; font-family: 'Lora', serif; font-size: 1.4rem; font-weight: 700; color: var(--texto); text-decoration: none; }
.logo-icon { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; background: var(--oscuro); color: var(--verde-matcha); border-radius: 50%; margin-right: 10px; font-size: .9rem; font-style: normal; }
.site-nav ul { list-style: none; display: flex; gap: 22px; margin: 0; padding: 0; flex-wrap: wrap; }
.site-nav a { color: var(--texto); text-decoration: none; font-weight: 600; font-size: .95rem; }
.site-nav a:hover { color: var(--verde-matcha-oscuro); }
.site-search input { border: 1px solid var(--borde); border-radius: 50px; padding: 8px 16px; font-size: 1rem; }

/* Hero (post en destaque dinámico) */
.hero { background-size: cover; background-position: center; padding: 90px 20px; text-align: left; color: #fff; position: relative; }
.hero::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(34,38,43,.93) 0%, rgba(34,38,43,.6) 100%); }
.hero-content { position: relative; max-width: 640px; margin: 0 auto; }
.hero-badge { display: inline-block; background: var(--verde-matcha); color: #fff; padding: 6px 16px; border-radius: 50px; font-size: .8rem; font-weight: 700; margin-bottom: 18px; }
.hero h1 { color: #fff; font-size: 2.4rem; margin-top: 0; }
.hero h1 a { color: #fff; text-decoration: none; }
.hero p { font-size: 1.1rem; color: rgba(255,255,255,.92); }
.hero-meta { font-size: .9rem; color: rgba(255,255,255,.8); margin-bottom: 26px; }

/* Franja de categorías (pills) */
.categorias-pills { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; padding: 26px 0; border-bottom: 1px solid var(--borde); margin-bottom: 10px; }
.pill { background: #fff; border: 1px solid var(--borde); color: var(--texto); padding: 10px 20px; border-radius: 50px; text-decoration: none; font-weight: 600; font-size: .9rem; }
.pill:hover { border-color: var(--verde-matcha); color: var(--verde-matcha-oscuro); }

/* Grid de posts */
.posts-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 28px; margin: 30px 0; }
.post-card { background: #fff; border-radius: var(--radio); box-shadow: var(--sombra); overflow: hidden; }
.post-card img { border-radius: 0; aspect-ratio: 16 / 10; object-fit: cover; }
.post-card-body { padding: 18px 20px; }
.post-card h3 { margin: 6px 0; font-size: 1.2rem; }
.post-card p { color: var(--texto-suave); }
.post-card a { text-decoration: none; color: inherit; }
.post-card-meta { color: var(--texto-suave); font-size: .85rem; margin: 0; }

.tag-pill { display: inline-block; padding: 4px 12px; border-radius: 50px; font-size: .75rem; font-weight: 700; }

/* Bloque autor */
.bloque-autor { display: flex; align-items: center; gap: 24px; background: var(--verde-matcha-claro); border-radius: var(--radio); padding: 30px; margin: 50px 0; flex-wrap: wrap; }
.bloque-autor img { width: 110px; height: 110px; object-fit: cover; border-radius: 50%; }
.bloque-autor h3 { margin: 0 0 8px; }

/* Secciones */
.seccion { padding: 50px 0; }
.seccion-titulo { text-align: left; margin-bottom: 10px; }

/* Newsletter */
.newsletter { background: var(--oscuro); color: #fff; text-align: center; padding: 50px 20px; border-radius: var(--radio); }
.newsletter h2 { color: #fff; }
.newsletter-form { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin: 22px 0 10px; }
.newsletter-form input { padding: 14px 22px; border-radius: 50px; border: none; min-width: 260px; font-size: 1rem; }
.newsletter-nota { font-size: .8rem; opacity: .75; margin: 0; }

/* Artículo individual */
.entry-header { text-align: center; margin-bottom: 20px; }
.entry-meta { color: var(--texto-suave); font-size: .95rem; }
.entry-content { max-width: 760px; margin: 0 auto; }
.entry-content p { margin: 0 0 1.2em; }

/* Tabla de contenidos (generada por JS) */
.toc-index { background: #fff; border: 1px solid var(--borde); border-radius: var(--radio); padding: 20px 26px; margin: 0 auto 30px; max-width: 760px; }
.toc-title { font-family: 'Lora', serif; font-weight: 700; color: var(--verde-matcha-oscuro); margin: 0 0 10px; }
.toc-index ul { margin: 0; padding-left: 20px; }
.toc-index li.h3 { margin-left: 16px; list-style: circle; }
.toc-index a { text-decoration: none; }

/* Caja destacada (datos/estadísticas) — clase CSS adicional en Gutenberg */
.caja-destacada { background: var(--verde-matcha-claro); border-left: 6px solid var(--verde-matcha); border-radius: var(--radio); padding: 20px 24px; margin: 30px 0; }

/* Producto destacado (afiliados) — clase CSS adicional en Gutenberg */
.producto-destacado { background: #fff; border: 1px solid var(--borde); border-radius: var(--radio); padding: 24px; margin: 30px 0; text-align: center; }
.producto-destacado img { max-width: 200px; margin: 0 auto 16px; }

/* FAQ — clase CSS adicional en cada bloque de pregunta+respuesta */
.faq-item { border-bottom: 1px solid var(--borde); padding: 16px 0; }
.faq-item h3 { margin: 0 0 8px; color: var(--texto); }

.relacionados { margin: 60px 0; }

/* Categoría (archivo) */
.categoria-banner { background: var(--oscuro); color: #fff; text-align: center; padding: 60px 20px; }
.categoria-banner h1 { color: #fff; }

/* Footer */
.site-footer { background: var(--crema); border-top: 1px solid var(--borde); color: var(--texto); margin-top: 60px; }
.footer-inner { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px,1fr)); gap: 30px; padding: 50px 20px; }
.footer-logo { margin-bottom: 10px; }
.site-footer h4 { color: var(--texto); text-transform: uppercase; font-size: .8rem; letter-spacing: .06em; font-family: 'Inter', sans-serif; }
.site-footer ul { list-style: none; padding: 0; margin: 0; }
.site-footer li { margin-bottom: 8px; }
.site-footer a { color: var(--texto-suave); text-decoration: none; }
.site-footer a:hover { color: var(--verde-matcha-oscuro); }
.footer-bottom { text-align: center; padding: 18px; border-top: 1px solid var(--borde); font-size: .8rem; color: var(--texto-suave); }

/* Accesibilidad / mobile-first (público 50+) */
@media (max-width: 640px) {
	body { font-size: 17px; }
	.hero h1 { font-size: 1.9rem; }
	.bloque-autor { flex-direction: column; text-align: center; }
}
