/* ---------------------------------------------------------------------
 * PMBO - Blog (front-end + home strip)
 * ---------------------------------------------------------------------
 * Astra renders the actual post markup. We layer a polished card grid
 * on top for the home-page "From the blog" strip and a calmer
 * single-post + archive style for the blog itself.
 */

/* ============= HOME STRIP ============= */
.pmbo-blog-strip {
	background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
}
.pmbo-blog-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 1.4rem;
	margin-top: 1.5rem;
}
.pmbo-blog-card {
	background: #fff;
	border: 1px solid #e2e8f0;
	border-radius: 16px;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
	position: relative;
}
.pmbo-blog-card:hover {
	transform: translateY(-4px);
	border-color: #c7d2fe;
	box-shadow: 0 22px 50px -22px rgba(67, 56, 202, .35);
}
.pmbo-blog-card-thumb {
	display: block;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: linear-gradient(135deg, #eef2ff, #fdf2f8);
	color: #94a3b8;
	position: relative;
}
.pmbo-blog-card-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .6s ease;
}
.pmbo-blog-card:hover .pmbo-blog-card-thumb img { transform: scale(1.04); }
.pmbo-blog-card-fallback {
	position: absolute;
	inset: 0;
	display: grid;
	place-items: center;
}
.pmbo-blog-card-fallback svg {
	width: 64px;
	height: 64px;
}
.pmbo-blog-card-body {
	padding: 1.1rem 1.15rem 1.25rem;
	display: flex;
	flex-direction: column;
	gap: .55rem;
	flex: 1;
}
.pmbo-blog-card-cat {
	align-self: flex-start;
	background: #eef2ff;
	color: #4338ca;
	font-size: .68rem;
	font-weight: 700;
	letter-spacing: .08em;
	text-transform: uppercase;
	padding: .15rem .55rem;
	border-radius: 999px;
}
.pmbo-blog-card h3 {
	font-size: 1.05rem;
	line-height: 1.35;
	margin: 0;
	color: #0f172a;
	font-weight: 700;
	letter-spacing: -.01em;
}
.pmbo-blog-card h3 a {
	color: inherit;
	text-decoration: none;
	background-image: linear-gradient(currentColor, currentColor);
	background-size: 0 1px;
	background-repeat: no-repeat;
	background-position: 0 95%;
	transition: background-size .35s ease;
}
.pmbo-blog-card:hover h3 a { background-size: 100% 1px; }
.pmbo-blog-card p {
	color: #475569;
	line-height: 1.55;
	font-size: .92rem;
	margin: 0;
	flex: 1;
}
.pmbo-blog-card small {
	color: #94a3b8;
	font-size: .78rem;
	letter-spacing: .02em;
}
.pmbo-blog-strip-cta {
	display: flex;
	justify-content: center;
	margin-top: 1.5rem;
}

@media (max-width: 900px) {
	.pmbo-blog-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 600px) {
	.pmbo-blog-grid { grid-template-columns: 1fr; gap: 1.1rem; }
	.pmbo-blog-card-body { padding: .95rem 1rem 1.1rem; }
}

/* ============= ARCHIVE / SINGLE POST POLISH (Astra) ============= */
.single-post .entry-content,
.blog .ast-article-post .entry-content,
.archive .ast-article-post .entry-content {
	line-height: 1.7;
}
.single-post .entry-content p,
.blog .ast-article-post .entry-content p {
	color: #334155;
}
.single-post .entry-content h2,
.single-post .entry-content h3 {
	color: #0f172a;
	letter-spacing: -.01em;
}
.single-post .entry-content blockquote {
	border-left: 4px solid #6366f1;
	background: #eef2ff;
	border-radius: 0 12px 12px 0;
	padding: 1rem 1.2rem;
	margin: 1.5rem 0;
	color: #1e293b;
}

.single-post .entry-content a:not(.wp-block-button__link),
.blog .ast-article-post .entry-content a:not(.wp-block-button__link) {
	color: #4338ca;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
	.pmbo-blog-card,
	.pmbo-blog-card-thumb img,
	.pmbo-blog-card h3 a {
		transition: none !important;
	}
	.pmbo-blog-card:hover { transform: none; }
}
