/* ==========================================================================
   Theme — main.css
   Variables CSS, reset suave, layout magazine, dark/light.
   ========================================================================== */

/* Reset suave */
*,
*::before,
*::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
	margin: 0;
	font-family: var(--ppnl-font-body);
	font-size: var(--ppnl-font-size-base, 17px);
	line-height: 1.6;
	color: var(--ppnl-color-text);
	background: var(--ppnl-color-bg);
	transition: background-color .2s ease, color .2s ease;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: var(--ppnl-color-accent); text-decoration: none; }
a:hover { text-decoration: underline; }
h1, h2, h3, h4, h5, h6 {
	font-family: var(--ppnl-font-heading);
	color: var(--ppnl-color-primary);
	line-height: 1.2;
	margin: 0 0 .6em;
	font-weight: 700;
}
/* Muchos titulares de las variantes son <span>/<div> (no h1-h6): que también
   usen la fuente de títulos del paquete tipográfico seleccionado. */
[class*="title"] { font-family: var(--ppnl-font-heading); }
[data-scheme="dark"] h1,
[data-scheme="dark"] h2,
[data-scheme="dark"] h3,
[data-scheme="dark"] h4,
[data-scheme="dark"] h5,
[data-scheme="dark"] h6 { color: var(--ppnl-color-text); }
p { margin: 0 0 1em; }

/* A11y skip link */
.screen-reader-text {
	border: 0; clip: rect(1px,1px,1px,1px);
	clip-path: inset(50%);
	height: 1px; margin: -1px; overflow: hidden;
	padding: 0; position: absolute; width: 1px; word-wrap: normal !important;
}
.ppnl-skip-link:focus {
	clip: auto; clip-path: none;
	background: var(--ppnl-color-primary); color: #fff;
	display: block; font-size: 14px; padding: 12px 16px;
	position: absolute; top: 8px; left: 8px; z-index: 1000; width: auto; height: auto;
}

/* Layout helpers */
.ppnl-container {
	width: 100%;
	max-width: var(--ppnl-container, 1280px);
	margin-inline: auto;
	padding-inline: 20px;
}
.ppnl-wrapper { min-height: 100vh; display: flex; flex-direction: column; }
.ppnl-site { flex: 1; }
.ppnl-site-content { padding: 32px 0 64px; }

/* Banda del hero de portada: ancho completo pero capada a 1440 centrado */
.ppnl-hero-wrap { width: 100%; max-width: 1440px; margin-inline: auto; padding: 24px 20px 0; }
@media (max-width: 600px) { .ppnl-hero-wrap { padding: 12px 0 0; } }

/* Bandas del home tipo revista (secciones de noticias y por categoría) */
.ppnl-band { width: 100%; max-width: 1440px; margin-inline: auto; padding-inline: 20px; }
@media (max-width: 600px) { .ppnl-band { padding-inline: 0; } }
/* En el home tipo revista el contenido va en bandas; el contenedor base se colapsa */
.ppnl-magazine-home .ppnl-site-content { padding: 0; }

/* Imagen destacada a sangre completa arriba del contenido (single 3/7/9): debajo
   van el texto y la barra lateral en columnas. */
.ppnl-single-topimg { width: 100vw; max-width: 100vw; margin-inline: calc(50% - 50vw); margin-bottom: 36px; }
.ppnl-single-topimg img { width: 100%; height: clamp(300px, 46vh, 560px); object-fit: cover; display: block; }
@media (max-width: 900px) {
	.ppnl-single-topimg { margin-bottom: 24px; }
	.ppnl-single-topimg img { height: clamp(220px, 40vh, 360px); }
}
/* Layout con barra lateral.
   #primary (post) y #secondary (sidebar) son ambos hijos directos de #content,
   así que la rejilla de 2 columnas va en #content. :has(#secondary) hace que las
   2 columnas solo apliquen cuando la barra existe (páginas sin barra → 1 columna). */
.ppnl-layout-sidebar-right .ppnl-main-content:has( #secondary ),
.ppnl-layout-sidebar-left .ppnl-main-content:has( #secondary ) {
	display: grid;
	gap: 40px;
	align-items: start;
}
.ppnl-layout-sidebar-right .ppnl-main-content:has( #secondary ) {
	grid-template-columns: minmax(0, 1fr) 320px;
}
.ppnl-layout-sidebar-left .ppnl-main-content:has( #secondary ) {
	grid-template-columns: 320px minmax(0, 1fr);
}
.ppnl-layout-sidebar-left .ppnl-main-content:has( #secondary ) #primary { order: 2; }
.ppnl-layout-sidebar-left .ppnl-main-content:has( #secondary ) #secondary { order: 1; }
@media (max-width: 900px) {
	.ppnl-main-content:has( #secondary ) { grid-template-columns: 1fr; }
}

/* Topbar */
.ppnl-topbar {
	border-bottom: 1px solid color-mix(in srgb, var(--ppnl-color-text) 12%, transparent);
	font-size: .85em;
	padding: 6px 0;
}
.ppnl-topbar .ppnl-menu { display: flex; gap: 16px; list-style: none; margin: 0; padding: 0; flex-wrap: wrap; }
.ppnl-topbar .ppnl-menu a { color: var(--ppnl-color-text); opacity: .8; }
.ppnl-topbar .ppnl-menu a:hover { opacity: 1; }

/* ==========================================================================
   Header — base compartida (cada variante trae su propio CSS inline)
   ========================================================================== */
.ppnl-sticky-header .ppnl-site-header { position: sticky; top: 0; z-index: 50; }
.ppnl-logo-img { display: block; }

/* Cluster de herramientas de cabecera (solo contiene la hamburguesa) */
.ppnl-tools { display: inline-flex; align-items: center; }

/* Hamburguesa (abre el panel off-canvas) — SOLO visible en móvil (<=900px) */
.ppnl-burger { display: none; flex-direction: column; gap: 4px; background: none; border: 0; cursor: pointer; padding: 8px; color: inherit; }
.ppnl-burger span { display: block; width: 22px; height: 2px; background: currentColor; }
@media (max-width: 900px) { .ppnl-burger { display: inline-flex; } }

/* Cambio de iconos sol/luna en el botón de tema */
.ppnl-scheme-toggle .ppnl-icon--moon { display: none; }
[data-scheme="dark"] .ppnl-scheme-toggle .ppnl-icon--sun { display: none; }
[data-scheme="dark"] .ppnl-scheme-toggle .ppnl-icon--moon { display: inline-block; }

/* Search drawer */
.ppnl-header-search { padding: 16px 0; border-top: 1px solid color-mix(in srgb, var(--ppnl-color-text) 8%, transparent); }
.ppnl-search-form { display: flex; gap: 8px; }
.ppnl-search-field {
	flex: 1; padding: 10px 14px;
	border: 1px solid color-mix(in srgb, var(--ppnl-color-text) 20%, transparent);
	border-radius: 8px;
	background: transparent; color: inherit;
	font: inherit;
}
.ppnl-search-submit { padding: 0 14px; background: var(--ppnl-color-accent); color: #fff; border: 0; border-radius: 8px; cursor: pointer; }

/* Offcanvas */
.ppnl-offcanvas {
	position: fixed; inset: 0 auto 0 0; width: min(320px, 85vw);
	background: var(--ppnl-color-bg);
	box-shadow: 4px 0 24px rgba(0,0,0,.2);
	padding: 24px 20px; z-index: 100;
	transform: translateX(-100%);
	transition: transform .25s ease;
}
.ppnl-offcanvas.is-open { transform: translateX(0); }
.ppnl-offcanvas[hidden] { display: block !important; }
.ppnl-offcanvas__close {
	position: absolute; top: 12px; right: 12px;
	background: none; border: 0; font-size: 28px; line-height: 1; cursor: pointer;
	color: inherit;
}
.ppnl-offcanvas .ppnl-menu { display: flex; flex-direction: column; gap: 12px; margin-top: 32px; }
.ppnl-offcanvas .ppnl-menu a { color: var(--ppnl-color-text); font-weight: 600; }

/* ==========================================================================
   Featured / Hero magazine
   ========================================================================== */
.ppnl-featured { margin-bottom: 48px; }
.ppnl-featured__grid {
	display: grid;
	gap: 32px;
	grid-template-columns: 1fr;
}
@media (min-width: 900px) {
	.ppnl-featured__grid--3,
	.ppnl-featured__grid--4,
	.ppnl-featured__grid--5 {
		grid-template-columns: 1.4fr 1fr;
		grid-template-rows: auto auto;
		grid-auto-flow: dense;
	}
	.ppnl-featured__grid--3 .ppnl-featured__item--main,
	.ppnl-featured__grid--4 .ppnl-featured__item--main,
	.ppnl-featured__grid--5 .ppnl-featured__item--main {
		grid-row: span 2;
	}
}
.ppnl-featured__item { display: flex; flex-direction: column; gap: 16px; }
.ppnl-featured__thumb { display: block; overflow: hidden; border-radius: 12px; }
.ppnl-featured__thumb img { width: 100%; object-fit: cover; transition: transform .4s ease; }
.ppnl-featured__item:hover .ppnl-featured__thumb img { transform: scale(1.03); }

.ppnl-featured__item--main .ppnl-featured__thumb img { aspect-ratio: 16/10; }
.ppnl-featured__item--side .ppnl-featured__thumb img { aspect-ratio: 16/9; }

.ppnl-featured__title {
	font-family: var(--ppnl-font-heading);
	line-height: 1.15;
	margin: 6px 0 4px;
}
.ppnl-featured__item--main .ppnl-featured__title { font-size: clamp(1.8rem, 3.5vw, 2.8rem); }
.ppnl-featured__item--side .ppnl-featured__title { font-size: 1.25rem; }
.ppnl-featured__title a { color: var(--ppnl-color-primary); text-decoration: none; }
[data-scheme="dark"] .ppnl-featured__title a { color: var(--ppnl-color-text); }
.ppnl-featured__title a:hover { color: var(--ppnl-color-accent); }

.ppnl-featured__excerpt {
	font-size: 1.05em;
	color: color-mix(in srgb, var(--ppnl-color-text) 80%, transparent);
	margin-bottom: 4px;
}

.ppnl-featured__body { display: flex; flex-direction: column; gap: 4px; }
.ppnl-featured__body .ppnl-card__cat {
	font-size: .75em;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--ppnl-color-accent);
	text-decoration: none;
}

/* Grid 1: solo el main, fullwidth */
.ppnl-featured__grid--1 { grid-template-columns: 1fr; }
.ppnl-featured__grid--1 .ppnl-featured__item--main .ppnl-featured__thumb img { aspect-ratio: 21/9; }

/* Grid 2: dos columnas iguales */
@media (min-width: 900px) {
	.ppnl-featured__grid--2 { grid-template-columns: 1fr 1fr; }
}

/* Archive grid */
.ppnl-posts-area__main {
	display: grid;
	gap: 32px;
}
.ppnl-archive-grid {
	grid-template-columns: repeat(var(--ppnl-cols-mb, 1), minmax(0, 1fr));
}
.ppnl-posts-area__main[data-pc] { grid-template-columns: repeat(var(--ppnl-cols, 3), minmax(0, 1fr)); }
.ppnl-posts-area__main { --ppnl-cols: attr(data-mb number, 1); }
@media (min-width: 600px) { .ppnl-posts-area__main[data-tb="1"] { grid-template-columns: 1fr; } .ppnl-posts-area__main[data-tb="2"] { grid-template-columns: repeat(2, 1fr); } .ppnl-posts-area__main[data-tb="3"] { grid-template-columns: repeat(3, 1fr); } .ppnl-posts-area__main[data-tb="4"] { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 900px) { .ppnl-posts-area__main[data-lt="1"] { grid-template-columns: 1fr; } .ppnl-posts-area__main[data-lt="2"] { grid-template-columns: repeat(2, 1fr); } .ppnl-posts-area__main[data-lt="3"] { grid-template-columns: repeat(3, 1fr); } .ppnl-posts-area__main[data-lt="4"] { grid-template-columns: repeat(4, 1fr); } }
@media (min-width: 1200px) { .ppnl-posts-area__main[data-pc="1"] { grid-template-columns: 1fr; } .ppnl-posts-area__main[data-pc="2"] { grid-template-columns: repeat(2, 1fr); } .ppnl-posts-area__main[data-pc="3"] { grid-template-columns: repeat(3, 1fr); } .ppnl-posts-area__main[data-pc="4"] { grid-template-columns: repeat(4, 1fr); } }
.ppnl-archive-list { grid-template-columns: 1fr; }
.ppnl-archive-full { grid-template-columns: 1fr; }
.ppnl-archive-list .ppnl-card { display: grid; grid-template-columns: 200px 1fr; gap: 24px; align-items: center; }
@media (max-width: 600px) { .ppnl-archive-list .ppnl-card { grid-template-columns: 1fr; } }

/* Card */
.ppnl-card { display: flex; flex-direction: column; gap: 12px; }
.ppnl-card__thumb { display: block; overflow: hidden; border-radius: 12px; }
.ppnl-card__thumb img { width: 100%; aspect-ratio: 16/9; object-fit: cover; transition: transform .4s ease; }
.ppnl-card:hover .ppnl-card__thumb img { transform: scale(1.04); }
.ppnl-card__cat {
	display: inline-block;
	font-size: .75em; font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--ppnl-color-accent);
	text-decoration: none;
}
.ppnl-card__title {
	font-size: 1.25rem;
	margin: 4px 0;
	line-height: 1.25;
}
.ppnl-card__title a { color: var(--ppnl-color-primary); text-decoration: none; }
[data-scheme="dark"] .ppnl-card__title a { color: var(--ppnl-color-text); }
.ppnl-card__title a:hover { color: var(--ppnl-color-accent); }
.ppnl-card__excerpt { color: color-mix(in srgb, var(--ppnl-color-text) 80%, transparent); font-size: .95em; }

/* Entry meta */
.ppnl-entry-meta { display: flex; gap: 8px; flex-wrap: wrap; font-size: .8em; opacity: .75; align-items: center; }
.ppnl-entry-meta a { color: inherit; text-decoration: none; }
.ppnl-entry-meta a:hover { color: var(--ppnl-color-accent); }
.ppnl-entry-meta__sep { opacity: .5; }

/* Singular */
.ppnl-singular { max-width: 760px; margin-inline: auto; }
.ppnl-layout-full-width .ppnl-singular,
.ppnl-layout-no-sidebar .ppnl-singular { max-width: 760px; }
.ppnl-singular__header { text-align: center; margin-bottom: 32px; }
.ppnl-singular__cat {
	display: inline-block; color: var(--ppnl-color-accent);
	font-size: .8em; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; text-decoration: none;
	margin-bottom: 12px;
}
.ppnl-singular__title {
	font-size: clamp(1.8rem, 4vw, 3rem);
	margin: 0 0 16px;
}
.ppnl-singular__thumb { margin: 0 -10vw 32px; }
@media (max-width: 1024px) { .ppnl-singular__thumb { margin-inline: 0; } }
.ppnl-singular__thumb img { width: 100%; border-radius: 12px; }
/* Con barra lateral, la imagen no hace breakout (si no, se encimaría sobre el sidebar).
   El post conserva su ancho de lectura estándar (760px). */
.ppnl-main-content:has( #secondary ) .ppnl-singular__thumb { margin-inline: 0; }
.ppnl-singular__content { font-size: 1.08em; line-height: 1.75; }
.ppnl-singular__content > * { margin-bottom: 1.2em; }
.ppnl-singular__tags { margin-top: 24px; font-size: .85em; opacity: .8; }
.ppnl-singular__tags a { display: inline-block; padding: 4px 10px; border: 1px solid currentColor; border-radius: 999px; margin: 0 4px 4px 0; text-decoration: none; color: inherit; }
.ppnl-tags__label { font-weight: 700; }

/* Author + share */
.ppnl-author-box {
	display: grid; grid-template-columns: 96px 1fr; gap: 20px;
	padding: 24px; border-radius: 12px;
	background: color-mix(in srgb, var(--ppnl-color-text) 5%, transparent);
	margin-top: 40px;
}
.ppnl-author-box__avatar img { border-radius: 50%; }
.ppnl-author-box__name { margin: 0 0 6px; font-size: 1.1rem; }
.ppnl-author-box__bio { margin: 0 0 8px; font-size: .95em; opacity: .85; }
.ppnl-share { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 32px; align-items: center; }
.ppnl-share__label { font-weight: 700; font-size: .9em; }
.ppnl-share__link {
	font-size: .85em; padding: 6px 12px;
	border: 1px solid color-mix(in srgb, var(--ppnl-color-text) 20%, transparent);
	border-radius: 999px; color: inherit; text-decoration: none;
}
.ppnl-share__link:hover { background: var(--ppnl-color-accent); color: #fff; border-color: var(--ppnl-color-accent); }

/* Sidebar widgets */
.ppnl-widget-area { display: flex; flex-direction: column; gap: 32px; }
.ppnl-widget__title {
	font-size: 1rem; text-transform: uppercase; letter-spacing: .08em;
	padding-bottom: 8px;
	border-bottom: 2px solid var(--ppnl-color-accent);
	margin: 0 0 16px;
}

/* Pagination */
.ppnl-posts-area__pagination { margin-top: 40px; display: flex; justify-content: center; gap: 8px; }
.ppnl-posts-area__pagination a, .ppnl-posts-area__pagination span {
	display: inline-block; padding: 8px 14px; border-radius: 8px;
	border: 1px solid color-mix(in srgb, var(--ppnl-color-text) 15%, transparent);
	color: inherit; text-decoration: none;
}
.ppnl-posts-area__pagination .current { background: var(--ppnl-color-accent); color: #fff; border-color: var(--ppnl-color-accent); }

/* Buttons */
.ppnl-button, .ppnl-load-more {
	display: inline-block; cursor: pointer;
	background: var(--ppnl-color-primary);
	color: #fff; padding: 12px 24px;
	border: 0; border-radius: 8px; font-weight: 600;
	font: inherit; font-weight: 600;
	text-decoration: none;
}
.ppnl-button:hover, .ppnl-load-more:hover { background: var(--ppnl-color-accent); color: #fff; text-decoration: none; }
.ppnl-load-more-wrap { display: flex; justify-content: center; margin-top: 40px; }

/* Footer */
.ppnl-site-footer { background: var(--ppnl-color-primary); color: #fff; margin-top: 64px; }
.ppnl-site-footer a { color: #fff; }
.ppnl-footer-widgets { padding: 64px 0; }
.ppnl-footer-widgets__grid { display: grid; gap: 32px; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.ppnl-footer-widgets .ppnl-widget__title { color: #fff; border-color: rgba(255,255,255,.3); }
.ppnl-footer-bottom { padding: 20px 0; border-top: 1px solid rgba(255,255,255,.15); font-size: .9em; }
.ppnl-footer-bottom__inner { display: flex; flex-wrap: wrap; gap: 16px; justify-content: space-between; align-items: center; }
.ppnl-menu--footer { display: flex; gap: 20px; flex-wrap: wrap; }

/* Back to top */
.ppnl-to-top {
	position: fixed; right: 20px; bottom: 20px;
	width: 44px; height: 44px;
	border-radius: 50%; border: 0; cursor: pointer;
	background: var(--ppnl-color-primary); color: #fff;
	display: flex; align-items: center; justify-content: center;
	opacity: 0; pointer-events: none; transition: opacity .2s, transform .2s;
	transform: translateY(20px); z-index: 40;
}
.ppnl-to-top.is-visible { opacity: 1; pointer-events: auto; transform: translateY(0); }

/* Page header (archive/search/404) */
.ppnl-page-header { padding: 32px 0 24px; text-align: center; border-bottom: 1px solid color-mix(in srgb, var(--ppnl-color-text) 10%, transparent); margin-bottom: 32px; }
.ppnl-page-title { font-size: clamp(1.6rem, 3vw, 2.4rem); margin: 0; }

/* Comments */
.ppnl-comments-area { margin-top: 56px; }
.ppnl-comments-title { font-size: 1.4rem; margin-bottom: 24px; }
.ppnl-comment-list { list-style: none; padding: 0; margin: 0 0 32px; display: flex; flex-direction: column; gap: 24px; }
.ppnl-comment-list .comment { padding: 16px; border-radius: 12px; background: color-mix(in srgb, var(--ppnl-color-text) 4%, transparent); }
.ppnl-comment-list .children { list-style: none; padding-left: 24px; margin-top: 16px; }

/* Block editor compat */
.alignwide { max-width: 1100px; margin-left: auto; margin-right: auto; }
.alignfull { width: 100vw; max-width: 100vw; margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); }
.wp-block-button__link { background: var(--ppnl-color-accent); color: #fff; border-radius: 8px; }
