/**
 * Recent Actions Grid (ACF) – Card grid with rectangle and circle image cards
 * Vars: --rag-gap, --rag-radius, --rag-circle-d, --rag-card-h, --rag-title-color, --rag-kicker-color, --rag-text-color, --rag-border-color, --rag-bg
 */

.rag {
	background-color: var(--rag-bg, #ffffff);
	padding: 3rem 0;
}

.rag__container {
	margin: 0 auto;
	padding: 0 1.5rem;
}

.rag__container--wide {
	max-width: 1280px;
}

.rag__container--normal {
	max-width: 960px;
}

/* ---------- Header ---------- */
.rag__head {
	text-align: center;
	margin-bottom: 2.5rem;
}

.rag__kicker {
	font-size: 0.75rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--rag-kicker-color, #9a9a9a);
	margin-bottom: 0.5rem;
}

.rag__title {
	font-size: clamp(1.5rem, 4vw, 2rem);
	font-weight: 700;
	color: var(--rag-title-color, #111111);
	margin: 0 0 0.75rem;
	line-height: 1.2;
}

.rag__intro {
	font-size: 0.95rem;
	color: var(--rag-kicker-color, #9a9a9a);
	max-width: 42em;
	margin: 0 auto;
	line-height: 1.5;
}

.rag__intro p {
	margin: 0 0 0.5rem;
}

/* ---------- Grid (Flexbox) ---------- */
.rag__grid {
	display: flex;
	flex-wrap: wrap;
	gap: var(--rag-gap, 36px);
	padding-top: var(--rag-grid-pt, 0);
}

/* 3 columns: each card flex basis (100% minus 2 gaps) / 3 */
.rag__grid--layout_6 .rag-card,
.rag__grid--layout_3 .rag-card,
.rag__grid--layout_9 .rag-card {
	flex: 0 1 calc((100% - 2 * var(--rag-gap, 36px)) / 3);
	min-width: 0;
}

/* ---------- Card ---------- */
.rag-card {
	background: #fff;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	margin-top: var(--rag-mt, 0);
}

.rag-card:not(.rag-card--circle) {
	border: 1px solid var(--rag-border-color, #d9d9d9);
}

.rag-card__link {
	display: flex;
	flex-direction: column;
	height: 100%;
	text-decoration: none;
	color: inherit;
	transition: opacity 0.25s ease, transform 0.25s ease;
}

.rag-card__link:hover {
	opacity: 0.92;
}

.rag-card__link:focus {
	outline: none;
}

.rag-card__link:focus-visible {
	outline: 2px solid currentColor;
	outline-offset: 2px;
}

@media (prefers-reduced-motion: no-preference) {
	.rag-card__link:hover {
		transform: translateY(-2px);
	}
}

/* Rectangle card: image on top with 4/3 aspect */
.rag-card--rect .rag-card__media {
	position: relative;
	aspect-ratio: 3 / 4;
	overflow: hidden;
	background: #e8e8e8;
}

.rag-card--rect .rag-card__img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	vertical-align: middle;
}

.rag__grid--contain .rag-card--rect .rag-card__img {
	object-fit: contain;
}

.rag-card--rect .rag-card__body {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 1.25rem 1rem;
	min-height: 0;
}

/* Circle card: circular image centered, then body */
.rag-card--circle .rag-card__media {
	display: flex;
	align-items: center;
	justify-content: center;
	padding-top: 1.5rem;
	flex-shrink: 0;
}

.rag-card--circle .rag-card__img {
	width: var(--rag-circle-d, 220px);
	height: var(--rag-circle-d, 220px);
	border-radius: 50%;
	object-fit: cover;
	display: block;
	background: #e8e8e8;
}

.rag__grid--contain .rag-card--circle .rag-card__img {
	object-fit: contain;
}

.rag-card--circle .rag-card__img--placeholder {
	background: #ddd;
}

.rag-card--circle .rag-card__body {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: flex-start;
	text-align: center;
	padding: 1rem 1rem 1.25rem;
	min-height: 0;
}

.rag-card__label {
	font-size: 0.8rem;
	color: var(--rag-text-color, #2b2b2b);
	margin-bottom: 0.35rem;
}

.rag-card__title {
	font-size: 1rem;
	font-weight: 700;
	color: var(--rag-text-color, #2b2b2b);
	margin: 0 0 0.5rem;
	line-height: 1.3;
}

.rag-card__excerpt {
	font-size: 0.85rem;
	color: var(--rag-text-color, #2b2b2b);
	line-height: 1.4;
	margin: 0 0 0.5rem;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.rag-card__more {
	font-size: 0.7rem;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: var(--rag-kicker-color, #9a9a9a);
	margin-top: 15px;
}

/* ---------- CTA ---------- */
.rag__cta-wrap {
	text-align: center;
	margin-top: 2rem;
}

.rag__cta {
	display: inline-block;
	padding: 0.75rem 1.5rem;
	background-color: var(--rag-title-color, #111111);
	color: #fff;
	text-decoration: none;
	font-size: 0.85rem;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	border-radius: var(--rag-radius, 0);
	transition: opacity 0.2s ease;
}

.rag__cta:hover {
	opacity: 0.9;
}

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
	/* 2 columns */
	.rag__grid--layout_6 .rag-card,
	.rag__grid--layout_3 .rag-card,
	.rag__grid--layout_9 .rag-card {
		flex: 0 1 calc((100% - var(--rag-gap, 36px)) / 2);
	}

	.rag-card {
		margin-top: var(--rag-mt-t, 0);
	}

	.rag-card--circle .rag-card__img {
		width: min(var(--rag-circle-d, 220px), 180px);
		height: min(var(--rag-circle-d, 220px), 180px);
	}
}

@media (max-width: 640px) {
	.rag {
		padding: 2rem 0;
	}

	/* 1 column */
	.rag__grid--layout_6 .rag-card,
	.rag__grid--layout_3 .rag-card,
	.rag__grid--layout_9 .rag-card {
		flex: 0 1 100%;
	}

	.rag__grid {
		gap: 24px;
	}

	.rag-card {
		margin-top: var(--rag-mt-m, 0);
		height: auto;
		min-height: 300px;
	}

	.rag-card--circle .rag-card__img {
		width: min(var(--rag-circle-d, 220px), 160px);
		height: min(var(--rag-circle-d, 220px), 160px);
	}
}

@media (prefers-reduced-motion: reduce) {
	.rag-card__link:hover {
		transform: none;
	}
}
