/* ── Shared subpage block styles ───────────────────────────────────────────── */
/* Used by: subpage-twoCol, subpage-callouts, subpage-list */

/* Section wrappers */
.sp-section {
	background: var(--color-background, #fff);
	padding-top: 5rem;
	padding-bottom: 5rem;
}

.sp-section--alt {
	background: var(--color-surface, #f9fafb);
}

@media (min-width: 1024px) {
	.sp-section,
	.sp-section--alt {
		padding-top: 6rem;
		padding-bottom: 6rem;
	}
}

/* ── Two-column layout ─────────────────────────────────────────────────────── */

.sp-twocol {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2.5rem;
}

@media (min-width: 1024px) {
	.sp-twocol {
		grid-template-columns: repeat(12, 1fr);
		gap: 4rem;
	}
	.sp-twocol__heading { grid-column: span 5; }
	.sp-twocol__body    { grid-column: span 7; }
}

.sp-twocol__body {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.sp-twocol__body p {
	color: rgba(0,0,0,0.7);
	font-size: 1rem;
	line-height: 1.7;
	margin: 0;
}

@media (min-width: 1024px) {
	.sp-twocol__body p { font-size: 1.125rem; }
}

/* Stat aside */
.sp-aside {
	margin-top: 2rem;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1px;
	background: var(--color-border, #e5e7eb);
	border: 1px solid var(--color-border, #e5e7eb);
}

.sp-aside__cell {
	background: #fff;
	padding: 1.25rem;
}

.sp-aside__label {
	margin: 0 0 0.5rem;
}

.sp-aside__value {
	margin: 0;
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 1.25rem;
	font-variant-numeric: tabular-nums;
}

/* ── Callouts ──────────────────────────────────────────────────────────────── */

.sp-callouts {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1px;
	background: var(--color-border, #e5e7eb);
	border: 1px solid var(--color-border, #e5e7eb);
}

@media (min-width: 768px) {
	.sp-callouts { grid-template-columns: repeat(3, 1fr); }
}

.sp-callouts__cell {
	background: var(--color-background, #fff);
	padding: 2rem 2.5rem;
}

.sp-callouts__cell--alt {
	background: var(--color-surface, #f9fafb);
}

.sp-callouts__title {
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 1.25rem;
	margin: 0 0 0.75rem;
}

.sp-callouts__body {
	color: #6b7280;
	line-height: 1.65;
	margin: 0;
}

/* ── List ──────────────────────────────────────────────────────────────────── */

.sp-list__header {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
	margin-bottom: 3rem;
}

@media (min-width: 1024px) {
	.sp-list__header {
		grid-template-columns: repeat(12, 1fr);
		gap: 2.5rem;
		align-items: start;
	}
	.sp-list__heading { grid-column: span 5; }
	.sp-list__intro   { grid-column: span 7; }
}

.sp-list__heading {
	margin: 0;
}

.sp-list__intro {
	color: rgba(0,0,0,0.7);
	font-size: 1rem;
	line-height: 1.7;
	margin: 0;
}

@media (min-width: 1024px) {
	.sp-list__intro { font-size: 1.125rem; }
}

.sp-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: 1px;
	background: var(--color-border, #e5e7eb);
	border: 1px solid var(--color-border, #e5e7eb);
}

@media (min-width: 768px) {
	.sp-list { grid-template-columns: 1fr 1fr; }
}

.sp-list__cell {
	background: var(--color-background, #fff);
	padding: 1.75rem 2rem;
}

.sp-list__cell--alt {
	background: var(--color-surface, #f9fafb);
}

.sp-list__item-title {
	font-family: var(--font-display);
	font-weight: 600;
	font-size: 1.125rem;
	margin: 0 0 0.5rem;
}

.sp-list__item-body {
	color: #6b7280;
	line-height: 1.65;
	margin: 0;
}
