.ns-builders-page,
.ns-builder-page {
	background:
		radial-gradient(circle at top left, rgba(var(--color-sky-blue-rgb), 0.08), transparent 26rem),
		linear-gradient(180deg, var(--color-surface) 0%, var(--color-white) 20%, var(--color-surface) 100%);
	padding: 2rem 1rem 4rem;
}

.ns-builders-shell,
.ns-builder-shell {
	margin: 0 auto;
	max-width: 76rem;
}

.ns-builders-hero,
.ns-builder-section,
.ns-builders-empty,
.ns-builder-hero-copy,
.ns-builder-hero-media {
	padding: 1.35rem;
}

.ns-builders-kicker {
	color: var(--color-navy);
	font-size: 0.88rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	margin: 0 0 0.5rem;
	text-transform: uppercase;
}

.ns-builders-hero h1,
.ns-builder-hero-copy h1 {
	color: var(--color-text);
	font-size: clamp(2rem, 5vw, 3.25rem);
	line-height: 1.05;
	margin: 0 0 0.9rem;
}

.ns-builders-intro,
.ns-builder-intro,
.ns-builder-card-excerpt,
.ns-builder-richtext {
	color: var(--color-muted-text);
	line-height: 1.75;
}

.ns-builders-results,
.ns-builder-models {
	margin-top: 1.5rem;
}

.ns-builders-results-bar,
.ns-builder-models-header {
	align-items: baseline;
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1rem;
	justify-content: space-between;
	margin-bottom: 1rem;
}

.ns-builders-results-count,
.ns-builder-models-header h2,
.ns-builder-models-header p {
	margin: 0;
}

.ns-builders-results-count,
.ns-builder-models-header h2 {
	color: var(--color-text);
	font-weight: 700;
}

.ns-builder-models-header h2,
.ns-builder-section h2 {
	font-size: clamp(1.5rem, 3vw, 2rem);
}

.ns-builder-models-header p {
	color: var(--color-muted-text);
}

.ns-builders-grid {
	display: grid;
	gap: 1.35rem;
}

.ns-builder-card {
	display: grid;
	overflow: hidden;
	padding: 0;
}

.ns-builder-card-media {
	align-items: center;
	aspect-ratio: 16 / 10;
	background:
		linear-gradient(180deg, var(--color-surface) 0%, var(--color-surface-muted) 100%);
	display: flex;
	justify-content: center;
	overflow: hidden;
	padding: 1.4rem;
}

.ns-builder-card-media img {
	display: block;
	max-height: 100%;
	max-width: 100%;
	object-fit: contain;
	width: auto;
}

.ns-builder-card-media-empty,
.ns-builder-hero-media-empty {
	color: var(--color-muted-text);
	text-align: center;
}

.ns-builder-card-body {
	display: grid;
	gap: 0.85rem;
	grid-template-rows: auto minmax(0, 1fr) auto auto;
	padding: 1.25rem;
}

.ns-builder-card-title,
.ns-builder-card-count {
	margin: 0;
}

.ns-builder-card-title {
	font-size: 1.45rem;
	line-height: 1.1;
	min-height: 3.2rem;
}

.ns-builder-card-title a {
	color: var(--color-text);
	text-decoration: none;
}

.ns-builder-card-title a:hover,
.ns-builder-card-title a:focus-visible {
	color: var(--color-navy);
}

.ns-builder-card-excerpt {
	display: -webkit-box;
	margin: 0;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 4;
}

.ns-builder-card-count {
	color: var(--color-text);
	font-size: 0.95rem;
	font-weight: 700;
	min-height: 1.35rem;
}

.ns-builder-card-actions .ns-button--primary {
	box-sizing: border-box;
	width: 100%;
}

.ns-builder-hero {
	display: grid;
	gap: 1.5rem;
}

.ns-builder-hero-copy,
.ns-builder-hero-media {
	border-radius: var(--radius-card);
}

.ns-builder-hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-top: 1.1rem;
}

.ns-builder-meta {
	display: grid;
	gap: 0.5rem;
	margin-top: 1rem;
}

.ns-builder-meta p {
	color: var(--color-muted-text);
	margin: 0;
}

.ns-builder-hero-media {
	align-items: center;
	display: flex;
	justify-content: center;
	min-height: 18rem;
}

.ns-builder-logo,
.ns-builder-hero-image {
	display: block;
	max-height: 100%;
	max-width: 100%;
	object-fit: contain;
	width: auto;
}

.ns-builder-richtext p:first-child {
	margin-top: 0;
}

.ns-builder-richtext p:last-child {
	margin-bottom: 0;
}

.ns-builder-model-grid {
	margin-top: 0;
}

@media (min-width: 680px) {
	.ns-builders-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 960px) {
	.ns-builders-page,
	.ns-builder-page {
		padding: 3rem 1.5rem 5rem;
	}

	.ns-builders-hero,
	.ns-builder-section,
	.ns-builders-empty,
	.ns-builder-hero-copy,
	.ns-builder-hero-media {
		padding: 1.5rem;
	}

	.ns-builder-hero {
		align-items: stretch;
		grid-template-columns: minmax(0, 1.4fr) minmax(18rem, 0.9fr);
	}

	.ns-builders-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.ns-builder-card-body {
		gap: 0.78rem;
		padding: 1.1rem;
	}

	.ns-builder-card-title {
		font-size: 1.3rem;
		min-height: 2.9rem;
	}

	.ns-builder-card-excerpt {
		font-size: 0.92rem;
		line-height: 1.6;
		min-height: 5.9rem;
	}

	.ns-builder-card-count {
		font-size: 0.9rem;
	}
}
