/* Component: materials-grid — owned by its pattern rebuild. Enqueued after main.css. */

/* Grid: 3-4 cols desktop, 2 tablet, 1 mobile. Overrides the post-template
   grid so the layout stays fluid and matches the reference image-card look. */
.scs-matgrid .wp-block-post-template.is-layout-grid,
.scs-matgrid .scs-matgrid__tpl {
	display: grid;
	gap: clamp(1rem, 2vw, 1.5rem);
	grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (max-width: 1100px) {
	.scs-matgrid .wp-block-post-template.is-layout-grid,
	.scs-matgrid .scs-matgrid__tpl {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 860px) {
	.scs-matgrid .wp-block-post-template.is-layout-grid,
	.scs-matgrid .scs-matgrid__tpl {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 540px) {
	.scs-matgrid .wp-block-post-template.is-layout-grid,
	.scs-matgrid .scs-matgrid__tpl {
		grid-template-columns: 1fr;
	}
}

/* Image card variant — reuses the .scs-card look (radius, shadow, surface),
   but turns the card into an edge-to-edge photo with a bold name label. */
.scs-matcard {
	position: relative;
	display: flex;
	flex-direction: column;
	padding: 0;
	margin: 0;
	overflow: hidden;
	background: var(--scs-surface-2, #EBEBEB);
	border: 1px solid var(--scs-surface-2, #EBEBEB);
	border-radius: var(--scs-radius, 8px);
	box-shadow: var(--scs-shadow);
	transition: transform .18s ease, box-shadow .18s ease;
}

.scs-matcard:hover {
	transform: translateY(-4px);
	box-shadow: 0 16px 40px rgba(40, 44, 47, .16);
}

/* Media fills the top of the card, no inner radius (card clips it). */
.scs-matcard .scs-matcard__media {
	margin: 0;
}

.scs-matcard .scs-matcard__media,
.scs-matcard .scs-matcard__media a,
.scs-matcard .scs-matcard__media img {
	display: block;
	width: 100%;
	border-radius: 0;
}

.scs-matcard .scs-matcard__media img {
	aspect-ratio: 4 / 3;
	object-fit: cover;
	transition: transform .35s ease;
}

.scs-matcard:hover .scs-matcard__media img {
	transform: scale(1.04);
}

/* Name label sits directly beneath the photo as a bold caption bar. */
.scs-matcard .scs-matcard__body {
	margin: 0;
	padding: .85rem 1rem 1rem;
	background: #fff;
	border-top: 1px solid var(--scs-surface-2, #EBEBEB);
}

.scs-matcard .scs-matcard__title {
	margin: 0;
	font-family: "Inter Tight", system-ui, sans-serif;
	font-weight: 700;
	font-size: 1.05rem;
	line-height: 1.25;
	letter-spacing: -0.01em;
	color: var(--scs-ink, #101010);
}

.scs-matcard .scs-matcard__title a {
	color: inherit;
	text-decoration: none;
	display: block;
}

.scs-matcard .scs-matcard__title a:hover {
	color: var(--scs-red, #24E35A);
}

/* Make the whole media region feel clickable. */
.scs-matcard .scs-matcard__media a::after {
	content: "";
}

/* Centered outline CTA below the grid. */
.scs-matgrid__cta {
	margin-top: clamp(1.5rem, 3vw, 2.25rem);
}

.scs-matgrid__cta .wp-block-button__link {
	font-family: "Inter Tight", system-ui, sans-serif;
	font-weight: 700;
	letter-spacing: .01em;
	border: 2px solid var(--scs-ink, #101010);
	color: var(--scs-ink, #101010);
	background: transparent;
	border-radius: var(--scs-radius, 8px);
	padding: .7rem 1.6rem;
	transition: background .15s ease, color .15s ease, border-color .15s ease;
}

.scs-matgrid__cta .wp-block-button__link:hover,
.scs-matgrid__cta .wp-block-button__link:focus-visible {
	background: var(--scs-ink, #101010);
	color: #fff;
	border-color: var(--scs-ink, #101010);
}
