/*
 * Card components — used by both the Query Loop archive AND the
 * featured-posts shortcode. Single source of truth for card styling.
 *
 * Spacing follows the 1:2 micro-to-macro ratio:
 *   --isjac-pad-md (16px) inside, --isjac-gap-default (24px) between.
 */

/* ---------- Shared card base ----------
 * Both `.isjac-featured-posts__card` (shortcode) and the Query Loop's
 * `.wp-block-query .wp-block-post-template > li` are styled together so
 * they can never drift visually. */
.wp-block-query .wp-block-post-template > li,
.isjac-featured-posts__card {
	background: #FFFFFF;
	border: 1px solid #DDE5EE;
	border-radius: var(--isjac-radius-md);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	transition: transform 200ms ease-out, box-shadow 200ms ease-out;
}

.wp-block-query .wp-block-post-template > li:hover,
.wp-block-query .wp-block-post-template > li:focus-within,
.isjac-featured-posts__card:hover,
.isjac-featured-posts__card:focus-within {
	transform: translateY(-2px);
	box-shadow: var(--isjac-shadow-card);
}

/* ---------- Card grid ---------- *
 * Responsive column count: 3 desktop → 2 tablet → 1 mobile.
 * Gutenberg's Query Loop bakes columnCount:3 into inline grid-template-columns,
 * so we explicitly redefine the template at each breakpoint. Cards become
 * unreadable below 320px wide; collapse before that happens. */
.wp-block-query .wp-block-post-template,
.isjac-featured-posts__grid {
	gap: var(--isjac-gap-default);
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 900px) {
	.wp-block-query .wp-block-post-template,
	.isjac-featured-posts__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 540px) {
	.wp-block-query .wp-block-post-template,
	.isjac-featured-posts__grid {
		grid-template-columns: minmax(0, 1fr);
	}
}

/* ---------- Featured image area ---------- */
.wp-block-query .wp-block-post-featured-image,
.isjac-featured-posts__media {
	margin: 0;
	display: block;
	line-height: 0;
}

.wp-block-query .wp-block-post-featured-image img,
.isjac-featured-posts__image {
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 9;
	object-fit: cover;
	border-radius: 0;
	display: block;
}

/* ---------- Inner card body container ----------
 * Reset Kadence/WP defaults on the inner group container, then set OUR
 * card-body padding. Source order matters: the reset must come first so
 * the styled rule below wins on same-specificity ties. */
.wp-block-query .wp-block-post-template > li > .wp-block-group {
	padding: 0;
	background: transparent;
	border: 0;
	border-radius: 0;
	height: 100%;
	display: flex;
	flex-direction: column;
}

/* Card body padding — 16px standard; 24px on wider viewports for editorial feel.
 * The inner group is the second child of <li> (figure is first), so target it
 * by structural position rather than `:not(:first-child)`, which would also
 * match ancestor-chain ambiguity in editor previews. */
.wp-block-query .wp-block-post-template > li > .wp-block-group + .wp-block-group,
.wp-block-query .wp-block-post-template > li > .wp-block-post-featured-image + .wp-block-group,
.wp-block-query .wp-block-post-template > li > .wp-block-group:only-of-type,
.isjac-featured-posts__body {
	padding: var(--isjac-pad-md);
	display: flex;
	flex-direction: column;
	gap: var(--isjac-pad-sm);
	flex: 1;
}

@media (min-width: 768px) {
	.wp-block-query .wp-block-post-template > li > .wp-block-group + .wp-block-group,
	.wp-block-query .wp-block-post-template > li > .wp-block-post-featured-image + .wp-block-group,
	.wp-block-query .wp-block-post-template > li > .wp-block-group:only-of-type,
	.isjac-featured-posts__body {
		padding: var(--isjac-pad-lg);
	}
}

/* ---------- Title ---------- */
.wp-block-query .wp-block-post-title,
.isjac-featured-posts__title {
	margin: 0;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.3;
}

.wp-block-query .wp-block-post-title a,
.isjac-featured-posts__title a {
	color: #020726;
	text-decoration: none;
}

.wp-block-query .wp-block-post-title a:hover,
.wp-block-query .wp-block-post-title a:focus-visible,
.isjac-featured-posts__title a:hover,
.isjac-featured-posts__title a:focus-visible {
	color: #15526F;
	text-decoration: underline;
	text-underline-offset: 0.2em;
}

/* ---------- Excerpt ---------- */
.wp-block-query .wp-block-post-excerpt,
.isjac-featured-posts__excerpt {
	margin: 0;
	color: #666666;
	font-size: 1rem;
	line-height: 1.55;
}

/* ---------- Read more affordance ---------- */
.wp-block-query .wp-block-post-excerpt__more-link,
.isjac-featured-posts__more {
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	color: #15526F;
	font-weight: 600;
	text-decoration: none;
	margin-top: var(--isjac-pad-sm);
}

.wp-block-query .wp-block-post-excerpt__more-link::after,
.isjac-featured-posts__more span {
	display: inline-block;
	transition: transform 150ms ease-out;
}

.wp-block-query .wp-block-post-excerpt__more-link::after {
	content: "→";
}

.wp-block-query .wp-block-post-template > li:hover .wp-block-post-excerpt__more-link::after,
.wp-block-query .wp-block-post-template > li:focus-within .wp-block-post-excerpt__more-link::after,
.isjac-featured-posts__card:hover .isjac-featured-posts__more span,
.isjac-featured-posts__card:focus-within .isjac-featured-posts__more span {
	transform: translateX(3px);
}

/* ---------- Date — pinned to card bottom for visual rhythm ---------- */
.wp-block-query .wp-block-post-date {
	font-size: 0.875rem;
	color: #888888;
	margin-top: auto;
	padding-top: var(--isjac-pad-sm);
}
