/**
 * Blog — capa visual moderna.
 *
 * Reglas:
 *  - Aditivo. Las clases existentes (.blog-hero, .post-grid, .post-card,
 *    .post-featured, .blog-sidebar, .blog-widget) se redefinen con MAYOR
 *    especificidad usando .blog-21 como contenedor para no romper otros
 *    sitios que reusen las mismas clases.
 *  - Cero colores nuevos: tokens existentes.
 */

/* =========================================================
   HERO de blog — orbes + search hero + filter pills
   ========================================================= */
.blog-21-hero {
	position: relative;
	isolation: isolate;
	overflow: clip;
	padding-block: var(--space-3xl) var(--space-2xl);
	text-align: center;
}

.blog-21-hero__announce {
	display: inline-flex;
	align-items: center;
	gap: var(--space-sm);
	padding: 6px 14px 6px 6px;
	background: var(--bg-card);
	border: 1px solid var(--divider);
	border-radius: 999px;
	font-size: var(--text-xs);
	font-weight: 600;
	color: var(--text-secondary);
	margin-bottom: var(--space-lg);
}

.blog-21-hero__announce-pill {
	font-size: 10px;
	font-weight: 700;
	letter-spacing: .5px;
	text-transform: uppercase;
	padding: 3px 9px;
	border-radius: 999px;
	background: var(--accent-blue);
	color: #fff;
}

.blog-21-hero h1 {
	font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl));
	letter-spacing: -0.025em;
	line-height: 1.1;
	margin-bottom: var(--space-md);
}

.blog-21-hero h1 .accent {
	background: linear-gradient(120deg, var(--accent-blue), var(--nav-active) 60%, var(--accent-green));
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

.blog-21-hero__lede {
	color: var(--text-secondary);
	max-width: 60ch;
	margin: 0 auto var(--space-xl);
	font-size: var(--text-base);
}

/* Search bar */
.blog-21-search {
	max-width: 560px;
	margin: 0 auto var(--space-xl);
	display: flex;
	align-items: center;
	gap: 0;
	background: var(--bg-primary);
	border: 1px solid var(--divider);
	border-radius: 999px;
	padding: 6px 6px 6px 18px;
	box-shadow: 0 4px 24px -8px rgba(0,0,0,0.05);
	transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.blog-21-search:focus-within {
	border-color: var(--accent-blue);
	box-shadow: 0 0 0 3px rgba(45, 91, 255, 0.10);
}

.blog-21-search__icon {
	width: 18px;
	height: 18px;
	color: var(--text-secondary);
	flex-shrink: 0;
}

.blog-21-search input[type="search"] {
	flex: 1;
	border: none;
	background: transparent;
	font-size: var(--text-sm);
	font-family: var(--font);
	color: var(--text-primary);
	padding: 8px 12px;
	min-height: 36px;
	outline: none;
	box-shadow: none;
}

.blog-21-search input[type="search"]:focus { box-shadow: none; }

.blog-21-search button {
	flex-shrink: 0;
	min-height: 40px;
	padding: 0 18px;
	border-radius: 999px;
	background: var(--accent-blue);
	color: #fff;
	font-size: var(--text-sm);
	font-weight: 600;
	border: none;
	cursor: pointer;
	font-family: var(--font);
	transition: opacity var(--transition-fast);
}

.blog-21-search button:hover { opacity: .9; }

/* Category filter pills (chips) */
.blog-21-filters {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
	justify-content: center;
	margin-block: var(--space-lg) 0;
}

.blog-21-filters__chip {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 14px;
	border-radius: 999px;
	background: var(--bg-card);
	border: 1px solid var(--divider);
	font-size: var(--text-xs);
	font-weight: 600;
	color: var(--text-secondary);
	cursor: pointer;
	text-decoration: none;
	transition: background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);
}

.blog-21-filters__chip:hover {
	color: var(--text-primary);
	border-color: var(--text-secondary);
	transform: translateY(-1px);
}

.blog-21-filters__chip.is-active {
	background: var(--accent-blue);
	color: #fff;
	border-color: var(--accent-blue);
}

.blog-21-filters__count {
	font-size: 10px;
	background: rgba(0, 0, 0, 0.10);
	padding: 1px 6px;
	border-radius: 999px;
	font-weight: 700;
}

.blog-21-filters__chip.is-active .blog-21-filters__count {
	background: rgba(255, 255, 255, 0.22);
}

/* =========================================================
   FEATURED POST — card grande con gradient overlay
   ========================================================= */
.blog-21 .post-featured {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
	gap: var(--space-2xl);
	background: var(--bg-card);
	border: 1px solid var(--divider);
	border-radius: var(--radius-card);
	overflow: hidden;
	margin-bottom: var(--space-3xl);
	transition: border-color var(--transition-normal), box-shadow var(--transition-normal);
	isolation: isolate;
}

.blog-21 .post-featured:hover {
	border-color: rgba(45, 91, 255, 0.35);
	box-shadow:
		0 24px 48px -16px rgba(45, 91, 255, 0.18),
		0 12px 24px -8px rgba(0, 0, 0, 0.06);
}

.blog-21 .post-featured__media {
	position: relative;
	display: block;
	aspect-ratio: 4 / 3;
	overflow: hidden;
	margin: 0;
	border-radius: 0;
}

.blog-21 .post-featured__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 600ms cubic-bezier(.25,.46,.45,.94);
}

.blog-21 .post-featured:hover .post-featured__media img { transform: scale(1.04); }

.blog-21 .post-featured__media::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(135deg, transparent 50%, rgba(45, 91, 255, 0.20) 100%);
	pointer-events: none;
}

.blog-21 .post-featured__body {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: var(--space-2xl);
	gap: var(--space-md);
}

.blog-21 .post-featured__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 10px;
	font-weight: 800;
	letter-spacing: .5px;
	text-transform: uppercase;
	color: var(--accent-blue);
	background: rgba(45, 91, 255, 0.10);
	padding: 4px 10px;
	border-radius: 999px;
	align-self: flex-start;
}

.blog-21 .post-featured__title {
	font-size: clamp(var(--text-2xl), 3.2vw, var(--text-4xl));
	letter-spacing: -0.02em;
	line-height: 1.15;
	margin: 0;
}

.blog-21 .post-featured__title a {
	color: var(--text-primary);
	background-image: linear-gradient(120deg, var(--accent-blue), var(--accent-green));
	background-size: 0% 2px;
	background-repeat: no-repeat;
	background-position: 0 100%;
	transition: background-size 350ms ease;
}

.blog-21 .post-featured__title a:hover { background-size: 100% 2px; }

.blog-21 .post-featured__excerpt {
	color: var(--text-secondary);
	font-size: var(--text-base);
	line-height: 1.6;
	margin: 0;
}

.blog-21 .post-featured__meta {
	display: flex;
	align-items: center;
	gap: var(--space-md);
	margin-top: var(--space-md);
}

.blog-21 .post-featured__cta {
	margin-left: auto;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--accent-blue);
}

.blog-21 .post-featured__cta::after { content: "→"; transition: transform var(--transition-fast); }
.blog-21 .post-featured:hover .post-featured__cta::after { transform: translateX(4px); }

@media (max-width: 900px) {
	.blog-21 .post-featured { grid-template-columns: 1fr; gap: 0; }
	.blog-21 .post-featured__media { aspect-ratio: 16 / 9; }
}

/* =========================================================
   POST GRID — bento ligero
   ========================================================= */
.blog-21 .post-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
	gap: var(--space-xl);
}

.blog-21 .post-card {
	position: relative;
	display: flex;
	flex-direction: column;
	background: var(--bg-card);
	border: 1px solid var(--divider);
	border-radius: var(--radius-card);
	overflow: hidden;
	transition: border-color var(--transition-normal), transform var(--transition-normal), box-shadow var(--transition-normal);
	isolation: isolate;
}

.blog-21 .post-card:hover {
	transform: translateY(-2px);
	border-color: rgba(45, 91, 255, 0.30);
	box-shadow:
		0 16px 32px -16px rgba(45, 91, 255, 0.16),
		0 8px 16px -8px rgba(0, 0, 0, 0.06);
}

.blog-21 .post-card__thumbnail {
	position: relative;
	display: block;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: var(--bg-pill);
}

.blog-21 .post-card__thumbnail img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 500ms ease;
}

.blog-21 .post-card:hover .post-card__thumbnail img { transform: scale(1.06); }

.blog-21 .post-card__thumbnail-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--text-secondary);
	background:
		linear-gradient(135deg, var(--bg-pill), var(--bg-card)),
		var(--bg-pill);
}

/* Reading-time chip flotando sobre la miniatura */
.blog-21 .post-card__chip {
	position: absolute;
	top: 10px;
	right: 10px;
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-size: 10px;
	font-weight: 700;
	letter-spacing: .3px;
	padding: 4px 9px;
	border-radius: 999px;
	background: rgba(0, 0, 0, 0.65);
	color: #fff;
	backdrop-filter: blur(6px);
}

.blog-21 .post-card__body {
	padding: var(--space-lg);
	display: flex;
	flex-direction: column;
	gap: var(--space-sm);
	flex: 1;
}

.blog-21 .post-card__title {
	font-size: var(--text-lg);
	letter-spacing: -0.01em;
	line-height: 1.3;
	margin: 0;
}

.blog-21 .post-card__title a {
	color: var(--text-primary);
	background-image: linear-gradient(90deg, var(--accent-blue), var(--accent-blue));
	background-size: 0% 1px;
	background-repeat: no-repeat;
	background-position: 0 100%;
	transition: background-size 250ms ease;
}

.blog-21 .post-card__title a:hover { background-size: 100% 1px; color: var(--accent-blue); }

.blog-21 .post-card__excerpt {
	color: var(--text-secondary);
	font-size: var(--text-sm);
	line-height: 1.6;
	margin: 0;
}

.blog-21 .post-card__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-sm);
	margin-top: auto;
	padding-top: var(--space-md);
	border-top: 1px solid var(--divider);
}

.blog-21 .post-card__byline {
	display: flex;
	align-items: center;
	gap: var(--space-sm);
	font-size: var(--text-xs);
	color: var(--text-secondary);
	min-width: 0;
}

.blog-21 .post-card__avatar {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	flex-shrink: 0;
}

.blog-21 .post-card__avatar--placeholder {
	background: linear-gradient(135deg, var(--accent-blue), var(--nav-active));
	color: #fff;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: var(--text-xs);
}

.blog-21 .post-card__byline strong {
	display: block;
	color: var(--text-primary);
	font-weight: 600;
	font-size: var(--text-xs);
}

.blog-21 .post-card__cta {
	font-size: var(--text-xs);
	font-weight: 700;
	color: var(--accent-blue);
	display: inline-flex;
	align-items: center;
	gap: 4px;
}

.blog-21 .post-card__cta-text::after {
	content: "";
	display: inline-block;
}

/* =========================================================
   SECTION HEADING entre featured y resto
   ========================================================= */
.blog-21 .blog-section-heading {
	font-size: var(--text-2xl);
	letter-spacing: -0.01em;
	margin: var(--space-3xl) 0 var(--space-xl);
	display: flex;
	align-items: center;
	gap: var(--space-md);
}

.blog-21 .blog-section-heading::after {
	content: "";
	flex: 1;
	height: 1px;
	background: linear-gradient(90deg, var(--divider), transparent);
}

/* =========================================================
   SIDEBAR mejorada
   ========================================================= */
.blog-21 .blog-sidebar {
	display: flex;
	flex-direction: column;
	gap: var(--space-xl);
}

.blog-21 .blog-widget {
	background: var(--bg-card);
	border: 1px solid var(--divider);
	border-radius: var(--radius-card);
	padding: var(--space-xl);
}

.blog-21 .blog-widget__title {
	font-size: var(--text-sm);
	font-weight: 700;
	letter-spacing: .3px;
	text-transform: uppercase;
	color: var(--text-secondary);
	margin: 0 0 var(--space-md);
}

.blog-21 .blog-widget__posts {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: var(--space-md);
}

.blog-21 .blog-widget__posts a {
	display: flex;
	gap: var(--space-md);
	align-items: center;
	color: var(--text-primary);
	text-decoration: none;
	transition: opacity var(--transition-fast);
}

.blog-21 .blog-widget__posts a:hover { opacity: .85; }

.blog-21 .blog-widget__thumb {
	flex-shrink: 0;
	width: 56px;
	height: 56px;
	border-radius: 8px;
	overflow: hidden;
	background: var(--bg-pill);
}

.blog-21 .blog-widget__thumb img { width: 100%; height: 100%; object-fit: cover; }

.blog-21 .blog-widget__thumb--placeholder {
	background: linear-gradient(135deg, var(--bg-pill), var(--divider));
}

.blog-21 .blog-widget__info {
	min-width: 0;
	display: flex;
	flex-direction: column;
	gap: 2px;
}

.blog-21 .blog-widget__info strong {
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--text-primary);
	line-height: 1.3;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.blog-21 .blog-widget__info time {
	font-size: var(--text-xs);
	color: var(--text-secondary);
}

/* CTA widget — fondo gradient distintivo */
.blog-21 .blog-widget--cta {
	background:
		radial-gradient(120% 120% at 0% 0%, rgba(45, 91, 255, 0.10), transparent 60%),
		radial-gradient(120% 120% at 100% 100%, rgba(48, 209, 88, 0.10), transparent 60%),
		var(--bg-card);
	border-color: rgba(45, 91, 255, 0.20);
}

.blog-21 .blog-widget--cta p {
	color: var(--text-secondary);
	font-size: var(--text-sm);
	margin-bottom: var(--space-md);
}

/* =========================================================
   PAGINACIÓN moderna
   ========================================================= */
.blog-21 .blog-pagination {
	margin-top: var(--space-3xl);
	display: flex;
	justify-content: center;
	gap: 6px;
}

.blog-21 .blog-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 36px;
	height: 36px;
	padding: 0 12px;
	border-radius: 8px;
	font-size: var(--text-sm);
	font-weight: 600;
	color: var(--text-primary);
	background: var(--bg-card);
	border: 1px solid var(--divider);
	text-decoration: none;
	transition: background-color var(--transition-fast), color var(--transition-fast);
}

.blog-21 .blog-pagination .page-numbers:hover {
	background: var(--bg-pill);
}

.blog-21 .blog-pagination .page-numbers.current {
	background: var(--accent-blue);
	color: #fff;
	border-color: var(--accent-blue);
}

@media (prefers-reduced-motion: reduce) {
	.blog-21 .post-featured__media img,
	.blog-21 .post-card__thumbnail img,
	.blog-21 .post-featured__cta::after,
	.blog-21 .post-featured__title a,
	.blog-21 .post-card__title a { transition: none !important; }
}

/* =========================================================
   BLOG — base (sin contenedor .blog-21)
   Trasladado desde style.css (MA-M17, sesión 2026-05-19).
   Estas reglas sirven a archive.php, search.php, single.php
   (related posts), index.php, home.php y blog-page.php.
   ========================================================= */
.blog-hero {
	padding-block: var(--space-4xl) var(--space-2xl);
	text-align: center;
}

/* Eyebrow pill arriba del título (📝 Blog · KuakLabs) — match wp-theme. */
.blog-hero__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.6px;
	text-transform: uppercase;
	color: var(--accent-blue);
	padding: 5px 12px;
	border-radius: var(--radius-pill);
	background: color-mix(in srgb, var(--accent-blue) 10%, transparent);
	margin-bottom: var(--space-md);
}

.blog-hero h1 {
	font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl));
	font-weight: 800;
	letter-spacing: -0.025em;
	max-width: 760px;
	margin: 0 auto var(--space-md);
	line-height: 1.05;
}

.blog-hero h1 .accent {
	background: linear-gradient(120deg, var(--accent-blue), var(--nav-active) 60%, var(--accent-green));
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
}

.blog-hero p {
	color: var(--text-secondary);
	font-size: var(--text-lg);
	max-width: 580px;
	margin: 0 auto;
	line-height: var(--leading-relaxed);
}

.post-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: var(--space-3xl);
}

.post-card {
	display: flex;
	flex-direction: column;
	background: var(--bg-primary);
	border-radius: var(--radius-card);
	box-shadow: var(--shadow-card);
	overflow: hidden;
	transition: box-shadow var(--transition-normal), transform var(--transition-normal);
}

.post-card:hover { box-shadow: var(--shadow-card-hover); transform: translateY(-2px); }

.post-card__thumbnail { aspect-ratio: 16/9; overflow: hidden; background: var(--bg-card); }
.post-card__thumbnail img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--transition-normal); }
.post-card:hover .post-card__thumbnail img { transform: scale(1.03); }

.post-card__body { flex: 1; padding: var(--space-2xl); display: flex; flex-direction: column; gap: var(--space-sm); }
.post-card__cats  { display: flex; flex-wrap: wrap; gap: var(--space-xs); }
.post-card__cat   {
	font-size: var(--text-xs);
	font-weight: 600;
	color: var(--accent-blue);
	background: rgba(45,91,255,0.10);
	padding: 2px 10px;
	border-radius: var(--radius-pill);
	text-decoration: none;
}
.post-card__cat:hover { background: rgba(45,91,255,0.16); color: var(--accent-blue-hover); }

.post-card__title { font-size: var(--text-lg); font-weight: 700; margin: 0; }
.post-card__title a { color: var(--text-primary); text-decoration: none; }
.post-card__title a:hover { color: var(--accent-blue); }

.post-card__excerpt { font-size: var(--text-sm); color: var(--text-secondary); line-height: var(--leading-relaxed); flex: 1; margin: 0; }
.post-card__meta    { font-size: var(--text-xs); color: var(--text-secondary); display: flex; gap: var(--space-sm); align-items: center; }

.post-card__thumbnail-placeholder {
	display: flex; align-items: center; justify-content: center;
	width: 100%; height: 100%;
	background: var(--bg-card);
	color: var(--text-secondary);
}
.post-card__footer {
	display: flex; align-items: center; justify-content: space-between;
	gap: var(--space-md);
	margin-top: auto;
	padding-top: var(--space-md);
	border-top: 1px solid var(--divider);
}
.post-card__byline { display: flex; gap: var(--space-sm); align-items: center; min-width: 0; }
.post-card__byline strong { display: block; font-size: var(--text-xs); color: var(--text-primary); line-height: 1.2; }
.post-card__avatar { border-radius: 50%; flex-shrink: 0; }
.post-card__cta {
	font-size: var(--text-sm); font-weight: 600; color: var(--accent-blue);
	text-decoration: none; white-space: nowrap;
	transition: color var(--transition-fast);
}
.post-card__cta:hover { color: var(--accent-blue-hover); }
.dot { margin-inline: 2px; opacity: 0.5; }

/* ── Blog hero / filter / featured / layout / sidebar ── */
.blog-hero--rich { padding-block: var(--space-section) var(--space-4xl); }
.blog-hero--rich h1 { font-size: clamp(var(--text-3xl), 5vw, var(--text-5xl)); line-height: var(--leading-tight); margin: var(--space-md) 0; }
.blog-hero__lede    { font-size: var(--text-lg); max-width: 62ch; margin-inline: auto; color: var(--text-secondary); }

.blog-search {
	display: flex; gap: var(--space-sm); max-width: 560px;
	margin: var(--space-2xl) auto 0;
	background: var(--bg-primary);
	border: 1px solid var(--divider);
	border-radius: var(--radius-pill);
	padding: 6px 6px 6px var(--space-md);
	box-shadow: var(--shadow-card);
}
.blog-search input[type="search"] {
	flex: 1; border: 0; background: transparent; outline: 0;
	font-size: var(--text-base); color: var(--text-primary);
	padding: var(--space-sm) 0;
}
.blog-search input[type="search"]::placeholder { color: var(--text-secondary); }
.blog-search .btn { border-radius: var(--radius-pill); padding: 0 var(--space-2xl); min-height: 40px; }

.blog-filter {
	background: var(--bg-primary);
	border-bottom: 1px solid var(--divider);
	padding-block: var(--space-md);
	position: sticky; top: 0; z-index: 20;
	backdrop-filter: saturate(1.2) blur(6px);
}
.blog-filter__scroll {
	display: flex; gap: var(--space-sm);
	overflow-x: auto;
	scrollbar-width: none;
	-webkit-overflow-scrolling: touch;
	padding-bottom: 2px;
}
.blog-filter__scroll::-webkit-scrollbar { display: none; }
.blog-filter__chip {
	display: inline-flex; align-items: center; gap: var(--space-xs);
	padding: 6px 14px;
	border-radius: var(--radius-pill);
	font-size: var(--text-sm); font-weight: 600;
	color: var(--text-secondary);
	background: var(--bg-pill);
	border: 1px solid transparent;
	text-decoration: none;
	white-space: nowrap;
	transition: color var(--transition-fast), background var(--transition-fast);
}
.blog-filter__chip:hover { color: var(--text-primary); }
.blog-filter__chip.is-active {
	background: var(--accent-blue);
	color: #fff;
	border-color: var(--accent-blue);
}
.blog-filter__count {
	display: inline-block; min-width: 20px; padding: 0 6px; text-align: center;
	font-size: 11px; font-weight: 700;
	background: rgba(0,0,0,0.06); color: inherit; border-radius: var(--radius-pill);
}
.blog-filter__chip.is-active .blog-filter__count { background: rgba(255,255,255,0.25); }

.blog-main { padding-block: var(--space-3xl) var(--space-section); }

.blog-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 320px;
	gap: var(--space-4xl);
	align-items: start;
}
@media (max-width: 960px) {
	.blog-layout { grid-template-columns: 1fr; }
	.blog-sidebar { order: 2; }
}

.blog-section-heading {
	font-size: var(--text-xl);
	margin: var(--space-4xl) 0 var(--space-2xl);
	padding-bottom: var(--space-sm);
	border-bottom: 1px solid var(--divider);
	font-weight: 700;
}

.blog-pagination { margin-top: var(--space-4xl); }

/* Featured post card — apilada (imagen banner arriba, texto a ancho completo
   abajo). Antes era una rejilla side-by-side `1.1fr 1fr` que dentro del layout
   del blog (main col compartida con un sidebar de 320px) dejaba la columna de
   texto extremadamente estrecha — el título envolvía a 1-2 palabras por línea
   en ES (palabras largas como "automatizar" forzaban wrap a cada token). */
/* Featured post — layout adaptativo: si NO hay imagen destacada, una sola
   columna full-width (no dejamos un cuadrado vacío al lado). Si SÍ hay
   imagen, en desktop se reparte 1.2fr (texto) / 1fr (imagen); en mobile
   ambas variantes se apilan. Las modifier classes las aplica el template
   (.post-featured--with-media | .post-featured--text-only). */
.post-featured {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0;
	border-radius: var(--radius-card);
	background: var(--bg-primary);
	box-shadow: var(--shadow-card);
	overflow: hidden;
	margin-bottom: var(--space-md);
	transition: box-shadow var(--transition-normal);
}
.post-featured:hover { box-shadow: var(--shadow-card-hover); }

@media (min-width: 1024px) {
	/* Solo cuando hay media nos vamos a 2 columnas. text-only se queda en 1
	   columna ancho completo independientemente del breakpoint. */
	.post-featured--with-media {
		grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
		align-items: stretch;
	}
}

.post-featured__media {
	display: block;
	background: var(--bg-card);
	overflow: hidden;
	min-height: 0;   /* permite que la imagen no fuerce altura del row grid */
}
.post-featured__media img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	aspect-ratio: 16/10;
	transition: transform var(--transition-normal);
}
@media (min-width: 1024px) {
	/* En 2 columnas, la imagen rellena la columna completa — sin aspect-ratio
	   forzado, así matchea la altura del body (texto largo) y no deja gap. */
	.post-featured--with-media .post-featured__media img {
		aspect-ratio: auto;
	}
}
.post-featured:hover .post-featured__media img { transform: scale(1.02); }

.post-featured__body {
	padding: var(--space-3xl);
	display: flex; flex-direction: column; gap: var(--space-md);
}
.post-featured__eyebrow {
	display: inline-flex; align-items: center; gap: 7px;
	font-size: 10px; font-weight: 700; letter-spacing: .8px; text-transform: uppercase;
	color: var(--text-secondary);
}
.post-featured__eyebrow::before {
	content: ''; display: inline-block;
	width: 3px; height: 12px;
	background: var(--accent-blue); border-radius: 2px;
}
.post-featured__title { font-size: clamp(var(--text-2xl), 2.4vw, var(--text-4xl)); line-height: var(--leading-tight); margin: 0; }
.post-featured__title a { color: var(--text-primary); text-decoration: none; }
.post-featured__title a:hover { color: var(--accent-blue); }
.post-featured__excerpt { font-size: var(--text-base); line-height: var(--leading-relaxed); color: var(--text-secondary); margin: 0; }

.post-featured__meta {
	display: flex; align-items: center; gap: var(--space-md);
	margin-top: var(--space-sm);
	padding-top: var(--space-md);
	border-top: 1px solid var(--divider);
}
.post-featured__avatar { border-radius: 50%; flex-shrink: 0; }
.post-featured__byline { flex: 1; font-size: var(--text-sm); color: var(--text-secondary); }
.post-featured__byline strong { display: block; color: var(--text-primary); font-size: var(--text-sm); line-height: 1.3; }
.post-featured__cta { font-weight: 600; color: var(--accent-blue); text-decoration: none; white-space: nowrap; }
.post-featured__cta:hover { color: var(--accent-blue-hover); }

/* Sidebar widgets */
.blog-sidebar { position: sticky; top: var(--space-section); display: flex; flex-direction: column; gap: var(--space-2xl); }
@media (max-width: 960px) { .blog-sidebar { position: static; } }

.blog-widget {
	background: var(--bg-card);
	border-radius: var(--radius-card);
	padding: var(--space-2xl);
}
.blog-widget__title {
	display: inline-flex; align-items: center; gap: 7px;
	font-size: 10px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .8px;
	color: var(--text-secondary);
	margin: 0 0 var(--space-md);
}
.blog-widget__title::before {
	content: ''; display: inline-block;
	width: 3px; height: 12px;
	background: var(--accent-blue); border-radius: 2px;
}

.blog-widget__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 2px; }
.blog-widget__list a {
	display: flex; align-items: center; justify-content: space-between;
	padding: var(--space-sm) var(--space-md);
	color: var(--text-primary); text-decoration: none;
	border-radius: var(--radius-button);
	font-size: var(--text-sm); font-weight: 500;
	transition: background var(--transition-fast), color var(--transition-fast);
}
.blog-widget__list a:hover { background: var(--bg-primary); color: var(--accent-blue); }
.blog-widget__count {
	font-size: var(--text-xs); color: var(--text-secondary);
	background: var(--bg-pill); padding: 2px 8px; border-radius: var(--radius-pill);
}
.blog-widget__list a:hover .blog-widget__count { background: rgba(45,91,255,0.10); color: var(--accent-blue); }

.blog-widget__posts { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-md); }
.blog-widget__posts a { display: flex; gap: var(--space-md); text-decoration: none; color: var(--text-primary); }
.blog-widget__thumb {
	flex-shrink: 0;
	width: 64px; height: 64px;
	border-radius: var(--radius-button);
	overflow: hidden;
	background: var(--bg-pill);
}
.blog-widget__thumb img { width: 100%; height: 100%; object-fit: cover; }
.blog-widget__thumb--placeholder { background: var(--bg-pill); }
.blog-widget__info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.blog-widget__info strong {
	font-size: var(--text-sm); line-height: var(--leading-snug);
	color: var(--text-primary); font-weight: 600;
	display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.blog-widget__posts a:hover strong { color: var(--accent-blue); }
.blog-widget__info time { font-size: var(--text-xs); color: var(--text-secondary); }

/* Widget CTA — fondo accent-blue plano (sin gradiente) */
.blog-widget--cta {
	background: var(--accent-blue);
	color: #fff;
}
.blog-widget--cta .blog-widget__title { color: rgba(255,255,255,0.85); }
.blog-widget--cta .blog-widget__title::before { background: #fff; }
.blog-widget--cta p { font-size: var(--text-sm); color: rgba(255,255,255,0.9); margin: 0 0 var(--space-md); line-height: var(--leading-relaxed); }
.blog-widget--cta .btn--full { width: 100%; text-align: center; background: #fff; color: var(--accent-blue); border-color: #fff; }
.blog-widget--cta .btn--full:hover { background: var(--bg-card); color: var(--accent-blue-hover); }

/* =========================================================
   POST DETAIL LAYOUT — usado por single.php y por page.php rama A
   (páginas categorizadas que se renderizan como entrada de blog).
   Match wp-theme/puente-blog/style.css para que la portada del blog
   y los singles/pages se vean idénticos.
   ========================================================= */
.post-layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 280px;
	gap: 48px;
	padding: 28px 0 96px;
	align-items: start;
}
@media (max-width: 980px) {
	.post-layout { grid-template-columns: 1fr; }
}
.post-article { min-width: 0; }

.post-title {
	font-size: clamp(var(--text-3xl), 4.5vw, var(--text-5xl));
	font-weight: 800;
	letter-spacing: -0.025em;
	line-height: 1.08;
	margin: 0 0 10px;
}
.post-lead {
	font-size: var(--text-xl);
	color: var(--text-secondary);
	line-height: var(--leading-snug);
	text-wrap: pretty;
	margin: 0 0 var(--space-lg);
}
.post-cover {
	margin: 0 0 var(--space-3xl);
}
.post-cover img {
	width: 100%;
	aspect-ratio: 16/9;
	object-fit: cover;
	border-radius: var(--radius-card);
	display: block;
}

/* =========================================================
   PB-SIDE — Sidebar sticky para single.php y page.php rama A.
   Fallback por si el plugin Puente Bridge no carga su CSS
   (escenario: la página no contiene shortcodes pb_* pero sí
   tiene categoría asignada y el tema activa la rama A).
   ========================================================= */
.pb-side {
	display: flex;
	flex-direction: column;
	gap: var(--space-lg);
	position: sticky;
	top: calc(var(--header-h, 72px) + 18px);
	align-self: start;
}
@media (max-width: 980px) {
	.pb-side { position: static; }
}

.pb-side-card {
	background: var(--bg-card);
	border: 1px solid var(--divider);
	border-radius: var(--radius-card);
	padding: 18px;
}
.pb-side-card h5 {
	display: inline-flex; align-items: center; gap: 6px;
	font-size: 10px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .5px;
	color: var(--text-secondary);
	margin: 0 0 var(--space-md);
}

.pb-side-toc {
	display: flex;
	flex-direction: column;
	gap: 4px;
}
.pb-side-toc a {
	display: block;
	padding: 7px 10px;
	border-radius: var(--radius-button);
	font-size: 13px;
	font-weight: 500;
	color: var(--text-secondary);
	text-decoration: none;
	line-height: 1.35;
	transition: background-color .15s, color .15s;
}
.pb-side-toc a:hover {
	background: var(--bg-pill);
	color: var(--text-primary);
}
.pb-side-toc a.is-active {
	background: color-mix(in srgb, var(--accent-blue) 12%, transparent);
	color: var(--accent-blue);
	font-weight: 600;
}
.pb-side-toc a.is-h3 {
	padding-left: 22px;
	font-size: 12px;
}
