:root {
	--about-max-width: 56rem;
	--about-gutter: 20px;
}

.about-context-shell {
	background: #ffffff;
	max-width: var(--about-max-width);
	margin: 0 auto;
	padding: 24px var(--about-gutter) 12px;
}

.about-context-shell.about-context-new,
.about-context-shell.about-context-legacy {
	max-width: var(--about-max-width);
	margin: 0 auto;
}

.about-context-new-frame {
	max-width: none;
	margin: 0;
}

.about-context-container {
	width: 100%;
	max-width: none;
	margin: 0;
	padding: 0;
}

.about-context-container-new {
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
	padding: 0 !important;
}

.about-local-nav {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 12px;
	margin: 0 0 16px;
	padding: 0 0 12px;
	border-bottom: 1px solid #dfe4e8;
}

.about-local-nav-title {
	font: 700 11px/1 "Montserrat", Arial, sans-serif;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: #4e5054;
}

.about-local-nav ul {
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 8px;
}

.about-local-nav li {
	margin: 0;
	padding: 0;
}

.about-local-nav li a {
	display: inline-block;
	padding: 8px 13px;
	border-radius: 999px;
	border: 1px solid #c9cecb;
	background: #ffffff;
	font: 600 12px/1 "Montserrat", Arial, sans-serif;
	letter-spacing: .02em;
	color: #4e5054;
	text-decoration: none;
	transition: all .2s ease;
}

.about-local-nav li a:hover {
	border-color: #63bd6b;
	color: #2a4f2d;
	background: #eff9f0;
}

.about-local-nav li.active a {
	border-color: #63bd6b;
	background: #63bd6b;
	color: #ffffff;
}

.about-page-banner {
	padding: 6px 0 2px;
	border: 0;
	border-radius: 0;
	background: transparent;
}

.about-page-eyebrow {
	margin: 0 0 5px;
	font: 700 11px/1.1 "Montserrat", Arial, sans-serif;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: #4e5054;
}

.about-page-banner h1 {
	margin: 0;
	font: 800 clamp(30px, 4vw, 44px)/1.05 "Montserrat", "Helvetica Neue", Helvetica, sans-serif;
	color: #212223;
	letter-spacing: -0.01em;
}

.about-page-banner p {
	margin: 8px 0 0;
	max-width: 72ch;
	font: 400 15px/1.55 "Open Sans", "Helvetica Neue", Helvetica, sans-serif;
	color: #4e5b68;
}

/* Landing-template about pages had oversized hero blocks; hide after unified context */
.about-context-shell + #hero {
	display: none;
}

/* Staff page has a duplicate section header immediately after unified context */
.about-context-shell.about-context-staff + section.py-5.mt-90 {
	display: none;
}

/* Normalize top spacing for new-template About pages so content starts consistently */
.about-context-shell.about-context-new ~ main .page-section:first-of-type {
	padding-top: 24px !important;
}

/* Keep all About-page body content on the same width rhythm as the About header block */
.about-context-shell ~ main .container,
.about-context-shell ~ main .container-sm,
.about-context-shell ~ main .container-md,
.about-context-shell ~ main .container-lg,
.about-context-shell ~ main .container-xl,
.about-context-shell ~ main .container-xxl {
	width: 100% !important;
	max-width: var(--about-max-width) !important;
	padding-left: var(--about-gutter) !important;
	padding-right: var(--about-gutter) !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

/* Some About pages use bootstrap's col-lg-8 mx-auto, which makes content too narrow */
.about-context-shell ~ main .col-lg-8.mx-auto {
	flex: 0 0 100% !important;
	max-width: 100% !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

/* Foundation About pages: keep content row width aligned to the same 56rem rhythm */
.about-context-shell + .content > .row[data-equalizer] {
	max-width: var(--about-max-width) !important;
	padding-left: var(--about-gutter) !important;
	padding-right: var(--about-gutter) !important;
	box-sizing: border-box !important;
}

.about-context-shell + .content > .row[data-equalizer] > .columns.content-bg {
	padding-left: 0 !important;
	padding-right: 0 !important;
	border-right: 0 !important;
}

.about-context-shell + .content > .row[data-equalizer] > .columns.content-bg > .content-holder {
	margin: 0 !important;
	padding: 24px 0 0 !important;
}

.about-context-shell.about-context-history ~ .content .history-hero-copy h1 {
	display: none;
}

@media (max-width: 900px) {
	:root {
		--about-gutter: 14px;
	}

	.about-context-shell {
		padding: 20px var(--about-gutter) 12px;
	}

	.about-context-shell.about-context-new {
		padding-top: 20px;
	}

	.about-context-shell.about-context-legacy {
		padding-top: 20px;
	}

	.about-context-shell.about-context-new ~ main .page-section:first-of-type {
		padding-top: 18px !important;
	}

	.about-context-shell ~ main .container,
	.about-context-shell ~ main .container-sm,
	.about-context-shell ~ main .container-md,
	.about-context-shell ~ main .container-lg,
	.about-context-shell ~ main .container-xl,
	.about-context-shell ~ main .container-xxl {
		padding-left: var(--about-gutter) !important;
		padding-right: var(--about-gutter) !important;
	}
}

@media (max-width: 640px) {
	.about-local-nav {
		margin: 0 0 12px;
		padding: 0 0 10px;
	}

	.about-local-nav li a {
		padding: 7px 10px;
		font-size: 11px;
	}

	.about-page-banner h1 {
		font-size: 30px;
	}

	.about-page-banner p {
		font-size: 14px;
		line-height: 1.45;
	}

	.about-context-shell.about-context-new,
	.about-context-shell.about-context-legacy {
		padding-top: 20px;
	}
}
