/* Extracted from lib.css — loaded conditionally via functions.php */

/* ── Blog section ────────────────────────────────────────────── */

.lib-blog-section { background: var(--white); }

/* Grid — works for both shortcode output and Query Loop block */

.lib-blog-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.75rem;
	margin-top: 0.5rem;
}

/* Query Loop: post-template renders as <ul> — reset list styles */

ul.lib-blog-grid,
.lib-blog-grid.wp-block-post-template {
	list-style: none !important;
	padding: 0 !important;
	margin-top: 0.5rem !important;
}

/* Query Loop: each <li> needs to stack like a flex column so card fills height */

.lib-blog-grid.wp-block-post-template > li {
	display: flex;
	flex-direction: column;
}

@media (min-width: 580px) {
	.lib-blog-grid { grid-template-columns: 1fr 1fr; }
}

/* Card — works for both <a class="lib-blog-card"> and <div class="wp-block-group lib-blog-card"> */

.lib-blog-card {
	display: block;
	border-radius: 16px;
	overflow: hidden;
	background: var(--off-white);
	border: 1px solid var(--border);
	transition: transform 0.25s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.25s ease;
	position: relative; /* needed for stretched-link */
	height: 100%;
}

.lib-blog-card:hover {
	transform: translateY(-4px);
	box-shadow: 0 12px 40px rgba(249,130,119,0.14);
}

/* Featured image wrapper — archive.php <div class="lib-blog-card-image"> */

.lib-blog-card-image {
	height: 180px;
	overflow: hidden;
}

.lib-blog-card-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

/* Featured image — shortcode <img> */

.lib-blog-card-img {
	width: 100%;
	height: 180px;
	object-fit: cover;
	display: block;
}

/* Featured image — Query Loop <figure class="wp-block-post-featured-image"> */

.lib-blog-card .wp-block-post-featured-image,
.lib-blog-card .wp-block-post-featured-image a {
	display: block;
	margin: 0;
}

.lib-blog-card .wp-block-post-featured-image img {
	width: 100%;
	height: 180px;
	object-fit: cover;
	display: block;
}

.lib-blog-card-placeholder {
	width: 100%;
	height: 180px;
	background: linear-gradient(135deg, var(--salmon-light) 0%, #fdecd4 100%);
}

.lib-blog-card-body { padding: 1.25rem; }

/* Category — shortcode <p> and Query Loop <div class="wp-block-post-terms"> */

.lib-blog-card-cat,
.lib-blog-card-cat a {
	font-family: var(--font-body) !important;
	font-size: 0.65rem !important;
	font-weight: 600 !important;
	letter-spacing: 0.1em !important;
	text-transform: uppercase !important;
	color: var(--salmon) !important;
	margin: 0 0 0.45rem !important;
	text-decoration: none !important;
}

/* Title — shortcode <h3> and Query Loop <h3 class="wp-block-post-title"> */

.lib-blog-card-title,
.lib-blog-card-title a {
	font-family: var(--font-display) !important;
	font-size: 1rem !important;
	font-weight: 700 !important;
	color: var(--primary) !important;
	line-height: 1.35 !important;
	margin: 0 0 0.55rem !important;
	text-decoration: none !important;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Stretched link — makes the whole card clickable via the title link */

.lib-blog-card-title a::after {
	content: '';
	position: absolute;
	inset: 0;
}

/* Excerpt — shortcode <p> and Query Loop <div class="wp-block-post-excerpt"> */

.lib-blog-card-excerpt,
.lib-blog-card-excerpt p {
	font-family: var(--font-body) !important;
	font-size: 0.83rem !important;
	color: var(--mid-grey) !important;
	line-height: 1.55 !important;
	margin: 0 !important;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* Hide Query Loop's auto-generated "Read more" link inside cards */

.lib-blog-card .wp-block-post-excerpt__more-link { display: none; }

.lib-blog-more {
	text-align: center;
	margin-top: 2rem;
}

/* ─── Block template overrides for blog archive ─────────────── */

/* Neutralise is-layout-flow gaps inside archive card context */

.lib-blog-card.wp-block-group > *,
.lib-blog-card-body.wp-block-group > * {
	margin-block-start: 0 !important;
	margin-block-end: 0 !important;
}

/* Featured image in block template — match archive.php 180px height */

.lib-blog-card .wp-block-post-featured-image {
	height: 180px;
	overflow: hidden;
	aspect-ratio: unset !important;
}

.lib-blog-card .wp-block-post-featured-image a {
	height: 100%;
}

.lib-blog-card .wp-block-post-featured-image img {
	aspect-ratio: unset !important;
	height: 100% !important;
	object-fit: cover;
}

/* Post date block inside card — match .lib-blog-card-meta style */

.lib-blog-card .wp-block-post-date {
	font-family: var(--font-body) !important;
	font-size: 0.7rem !important;
	font-weight: 600 !important;
	letter-spacing: 0.08em !important;
	text-transform: uppercase !important;
	color: var(--salmon) !important;
	margin-bottom: 0.35rem !important;
}

/* Post title block inside card — match .lib-blog-card-title style */

.lib-blog-card .wp-block-post-title {
	font-family: var(--font-display) !important;
	font-size: 1rem !important;
	font-weight: 700 !important;
	color: var(--primary) !important;
	line-height: 1.35 !important;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
	margin-bottom: 0.5rem !important;
}

.lib-blog-card .wp-block-post-title a {
	color: inherit !important;
	text-decoration: none !important;
}

/* Post excerpt block inside card — match .lib-blog-card-excerpt style */

.lib-blog-card .wp-block-post-excerpt {
	font-family: var(--font-body) !important;
	font-size: 0.83rem !important;
	color: var(--mid-grey) !important;
	line-height: 1.55 !important;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	margin-bottom: 0.75rem !important;
}

.lib-blog-card .wp-block-post-excerpt p {
	margin: 0 !important;
}

/* Read more button inside card */

.lib-blog-card .wp-block-read-more {
	display: inline-block;
}

/* ── Program card extensions (base = lib-blog-card + lib-blog-grid) ── */

/* Card body needs flex column for meta + button push-down */

.lib-programs-card .lib-blog-card-body {
	display: flex;
	flex-direction: column;
	flex: 1;
}

@media (min-width: 900px) {
	.lib-blog-grid { grid-template-columns: repeat(3, 1fr); }
	.lib-blog-section .lib-container { max-width: 960px; }
}
