/* ── EXISTING PAGE / PPC STYLES ─────────────────────────────────────────── */

.page-template-page-careers .site-main,
.page-architecture {
	margin-inline: auto;
	max-width: 72rem;
	padding-inline: 1rem;
}

.page-section {
	margin-block: 2rem;
}

.page-list {
	display: grid;
	gap: 0.75rem;
}

.ppc-landing {
	margin-inline: auto;
	max-width: 64rem;
	padding-inline: 1rem;
}

.ppc-landing__header,
.ppc-landing__section {
	margin-block: 2rem;
}

.ppc-landing__top-conversion {
	display: grid;
	gap: 1.5rem;
	margin-block: 2rem;
	padding-block: 1.5rem;
}

.ppc-landing__form {
	inline-size: 100%;
}

.ppc-landing__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	margin-block-start: 1.25rem;
}

.ppc-landing__button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 2.75rem;
	padding: 0.65rem 1rem;
	text-decoration: none;
}

.ppc-landing__list {
	display: grid;
	gap: 0.5rem;
	margin-block: 1rem;
}

.ppc-landing__faqs {
	display: grid;
	gap: 1rem;
}

@media (min-width: 48rem) {
	.ppc-landing__top-conversion {
		grid-template-columns: minmax(0, 0.9fr) minmax(18rem, 1.1fr);
		align-items: start;
	}
}


/* ── SHARED BUTTON SYSTEM ───────────────────────────────────────────────── */

.btn {
	align-items: center;
	border-radius: 0.5rem;
	display: inline-flex;
	font-family: var(--jsr-font-heading);
	font-size: 0.9rem;
	font-weight: 700;
	gap: 0.4rem;
	letter-spacing: 0.04em;
	line-height: 1.2;
	padding: 0.9rem 1.85rem;
	text-decoration: none;
	transition:
		background-color 160ms ease,
		border-color 160ms ease,
		color 160ms ease,
		transform 160ms ease;
}

.btn:hover,
.btn:focus-visible {
	transform: translateY(-1px);
}

.btn--mint {
	background: var(--jsr-color-teal-300);
	border: 1.5px solid var(--jsr-color-teal-300);
	color: var(--jsr-color-slate-800);
}

.btn--mint:hover,
.btn--mint:focus-visible {
	background: var(--jsr-color-teal-200);
	border-color: var(--jsr-color-teal-200);
	color: var(--jsr-color-slate-800);
}

.btn--ghost {
	background: transparent;
	border: 1.5px solid rgb(255 255 255 / 55%);
	color: #ffffff;
}

.btn--ghost:hover,
.btn--ghost:focus-visible {
	background: rgb(255 255 255 / 10%);
	border-color: rgb(255 255 255 / 80%);
	color: #ffffff;
}

.btn--ghost-dark {
	background: transparent;
	border: 1.5px solid var(--jsr-color-slate-800);
	color: var(--jsr-color-slate-800);
}

.btn--ghost-dark:hover,
.btn--ghost-dark:focus-visible {
	background: var(--jsr-color-slate-800);
	color: #ffffff;
}

.btn--dark {
	background: var(--jsr-color-slate-800);
	border: 1.5px solid var(--jsr-color-slate-800);
	color: #ffffff;
}

.btn--dark:hover,
.btn--dark:focus-visible {
	background: #2a333b;
	border-color: #2a333b;
	color: #ffffff;
}


/* ── SHARED SECTION UTILITIES ───────────────────────────────────────────── */

.home-eyebrow {
	color: var(--jsr-color-teal-700);
	display: block;
	font-family: var(--jsr-font-heading);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.22em;
	margin-block-end: 1.1rem;
	text-transform: uppercase;
}

.home-eyebrow--mint {
	color: var(--jsr-color-teal-300);
}

.home-section-title {
	color: var(--jsr-color-slate-800);
	font-size: clamp(2.25rem, 5.5vw, 4.5rem);
	line-height: 1.05;
	margin: 0 0 0.5rem;
}

.home-rule {
	block-size: 3px;
	inline-size: 100%;
	margin-block: 2rem 0;
}

.home-rule--mint {
	background: var(--jsr-color-teal-300);
}

.home-rule--slate {
	background: var(--jsr-color-slate-800);
}

.home-rule--faint {
	background: var(--jsr-color-gray-200);
}

/* Rule with breathing room above — section header divider */
.home-rule--spaced {
	margin-block: 2.5rem;
}


/* ── HOMEPAGE HERO ───────────────────────────────────────────────────────── */

.home-hero {
	background-color: var(--jsr-color-slate-800);
	background-position: center 30%;
	background-size: cover;
	display: grid;
	min-height: clamp(34rem, 78vh, 58rem);
	position: relative;
	width: 100%;
}

.home-hero__overlay {
	background: linear-gradient(
		108deg,
		rgb(59 71 82 / 82%) 0%,
		rgb(59 71 82 / 60%) 55%,
		rgb(59 71 82 / 20%) 100%
	);
	inset: 0;
	position: absolute;
}

.home-hero__content {
	align-self: flex-end;
	max-width: 56rem;
	padding: clamp(3.5rem, 8vw, 7rem) clamp(1.5rem, 6vw, 5.5rem) clamp(4rem, 9vw, 7.5rem);
	position: relative;
	z-index: 1;
}

.home-hero__title {
	color: #ffffff;
	font-size: clamp(3rem, 8.5vw, 7.5rem);
	line-height: 0.98;
	margin: 0 0 1.25rem;
}

.home-hero__sub {
	color: rgb(255 255 255 / 82%);
	font-size: clamp(1rem, 1.5vw, 1.15rem);
	line-height: 1.7;
	margin: 0 0 2.25rem;
	max-width: 40rem;
}

.home-hero__actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.85rem;
}


/* ── CREDIBILITY BAR ─────────────────────────────────────────────────────── */

.home-cred {
	background: #ffffff;
	border-top: 2px solid var(--jsr-color-teal-300);
	display: grid;
	gap: 2rem 5rem;
	grid-template-columns: auto 1fr;
	align-items: center;
	padding: clamp(2rem, 4.5vw, 3.5rem) clamp(1.5rem, 6vw, 5.5rem);
}

.home-cred__stats {
	align-items: stretch;
	display: flex;
	gap: 0;
}

.home-cred__stat {
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
	padding-inline: clamp(1.5rem, 3vw, 2.5rem);
}

.home-cred__stat:first-child {
	padding-inline-start: 0;
}

.home-cred__divider {
	background: rgb(59 71 82 / 42%);
	width: 3px;
	align-self: stretch;
	margin-block: 0.25rem;
}

.home-cred__num {
	color: var(--jsr-color-slate-800);
	font-family: var(--jsr-font-heading);
	font-size: clamp(2.25rem, 4.5vw, 3.75rem);
	font-weight: 700;
	line-height: 1;
}

.home-cred__label {
	color: var(--jsr-color-text-muted);
	font-size: 0.82rem;
	letter-spacing: 0.02em;
}

.home-cred__para {
	border-left: 2px solid var(--jsr-color-teal-300);
	color: var(--jsr-color-text-muted);
	font-size: 0.95rem;
	line-height: 1.7;
	margin: 0;
	max-width: 32rem;
	padding-left: 1.5rem;
}


/* ── SERVICES LIST ───────────────────────────────────────────────────────── */

.home-services {
	background: #ffffff;
	border-top: var(--jsr-divider);
	padding: clamp(4rem, 8vw, 7rem) clamp(1.5rem, 6vw, 5.5rem);
}

.home-services__inner {
	display: grid;
	gap: 0;
}

.home-services .home-section-title {
	margin-block-end: 1rem;
}

.home-services__list {
	border-top: var(--jsr-divider);
	list-style: none;
	margin: 1.5rem 0 0;
	padding: 0;
}

.home-services__item {
	align-items: center;
	border-bottom: var(--jsr-divider);
	display: grid;
	gap: 0.5rem 2.5rem;
	grid-template-columns: minmax(14rem, 28%) 1fr auto;
	padding: 1.35rem 0;
	transition: background-color 120ms ease;
}

.home-services__item:hover {
	background: #fafafa;
}

.home-services__name {
	color: var(--jsr-color-slate-800);
	font-family: var(--jsr-font-heading);
	font-size: clamp(1rem, 1.3vw, 1.15rem);
	font-weight: 700;
}

.home-services__desc {
	color: var(--jsr-color-text-muted);
	font-size: 0.9rem;
	line-height: 1.55;
}

.home-services__arrow {
	align-items: center;
	border: 1.5px solid var(--jsr-color-gray-200);
	border-radius: 50%;
	color: var(--jsr-color-slate-800);
	display: inline-flex;
	flex-shrink: 0;
	font-size: 1rem;
	height: 2.4rem;
	justify-content: center;
	text-decoration: none;
	transition:
		background-color 180ms ease,
		border-color 180ms ease,
		color 180ms ease,
		transform 220ms cubic-bezier(0.22, 1, 0.36, 1);
	width: 2.4rem;
}

.home-services__item:hover .home-services__arrow {
	background: var(--jsr-color-slate-800);
	border-color: var(--jsr-color-slate-800);
	color: #ffffff;
	transform: translateX(0.2rem);
}

.home-services__cta {
	margin-top: 2.5rem;
}


/* ── FEATURE DARK SECTION ────────────────────────────────────────────────── */

.home-feature {
	background: var(--jsr-color-slate-800);
	display: grid;
	grid-template-columns: 1fr 1fr;
	min-height: 38rem;
	overflow: hidden;
}

.home-feature__content {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: clamp(3.5rem, 7vw, 6rem) clamp(1.5rem, 6vw, 5.5rem);
}

.home-feature__title {
	color: var(--jsr-color-gray-100);
	font-size: clamp(2.25rem, 4.5vw, 4rem);
	line-height: 1.05;
	margin: 0.5rem 0 1.25rem;
}

.home-feature .home-rule {
	margin-block-end: 1.75rem;
}

.home-feature__body {
	color: rgb(235 235 237 / 72%);
	font-size: clamp(0.95rem, 1.2vw, 1.05rem);
	line-height: 1.75;
	margin: 0 0 1rem;
	max-width: 34rem;
}

.home-feature__stat {
	background: var(--jsr-color-teal-300);
	display: inline-flex;
	flex-direction: column;
	gap: 0.1rem;
	margin-top: 1.75rem;
	padding: 1rem 1.5rem;
}

.home-feature__stat-num {
	color: var(--jsr-color-slate-800);
	font-family: var(--jsr-font-heading);
	font-size: 1.4rem;
	font-weight: 700;
	line-height: 1;
}

.home-feature__stat-label {
	color: var(--jsr-color-slate-800);
	font-size: 0.78rem;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

.home-feature__media {
	background-position: center;
	background-size: cover;
	margin: 0;
	min-height: 24rem;
}


/* ── WHO WE SERVE CARDS ──────────────────────────────────────────────────── */

.home-serve {
	background: #ffffff;
	border-top: var(--jsr-divider);
	padding: clamp(4rem, 8vw, 7rem) clamp(1.5rem, 6vw, 5.5rem);
}

.home-serve__inner {
	align-items: start;
	display: grid;
	gap: 3rem 5rem;
	grid-template-columns: minmax(0, 1fr) minmax(0, 2.5fr);
}

.home-serve__header {
	position: sticky;
	top: calc(clamp(0.75rem, 2.8vw, 2.5rem) + clamp(4.5rem, 7vw, 6rem) + 1rem);
}

.home-serve__accent {
	background: var(--jsr-color-teal-300);
	block-size: 2px;
	inline-size: 2.5rem;
	margin-block-end: 0.75rem;
}

.home-serve__title {
	color: var(--jsr-color-slate-800);
	font-size: clamp(2rem, 4vw, 3.25rem);
	line-height: 1.08;
	margin: 0;
}

.home-serve__cards {
	align-items: start;
	display: grid;
	gap: 1.5rem;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.home-serve__card {
	display: flex;
	flex-direction: column;
}

.home-serve__card--mid {
	margin-top: 3rem;
}

.home-serve__card-img {
	aspect-ratio: 3 / 4;
	background-position: center;
	background-size: cover;
	display: block;
	margin: 0 0 0;
	overflow: hidden;
	width: 100%;
}

.home-serve__card-rule {
	background: var(--jsr-color-teal-300);
	block-size: 3px;
	inline-size: 100%;
	margin-block-end: 0.85rem;
}

.home-serve__card-cat {
	color: #2d7a6e; /* #33897d fails 4.5:1 AA on white; this passes at ~4.95:1 */
	display: block;
	font-family: var(--jsr-font-heading);
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.2em;
	margin-block-end: 0.5rem;
	text-transform: uppercase;
}

.home-serve__card-desc {
	color: var(--jsr-color-text-muted);
	flex: 1;
	font-size: 0.875rem;
	line-height: 1.65;
	margin: 0 0 0.85rem;
}

.home-serve__card-link {
	color: var(--jsr-color-slate-800);
	font-family: var(--jsr-font-heading);
	font-size: 0.82rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	text-decoration: none;
	text-transform: uppercase;
	transition: color 140ms ease;
}

.home-serve__card-link:hover {
	color: var(--jsr-color-teal-700);
}


/* ── PHOTO ROW ───────────────────────────────────────────────────────────── */

.home-photo-row {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	height: clamp(14rem, 22vw, 22rem);
}

.home-photo-row__img {
	background-position: center;
	background-size: cover;
	display: block;
	margin: 0;
}


/* ── TRUST / QUOTE ───────────────────────────────────────────────────────── */

.home-trust {
	background: #f7f6f3;
	border-top: var(--jsr-divider);
	border-bottom: var(--jsr-divider);
	padding: clamp(4rem, 8vw, 7rem) clamp(1.5rem, 6vw, 5.5rem);
}

.home-trust__inner {
	max-width: 54rem;
}

.home-trust__rule {
	background: var(--jsr-color-teal-300);
	block-size: 2px;
	inline-size: 3rem;
	margin-block-end: 2rem;
}

.home-trust__quote {
	border: 0;
	color: var(--jsr-color-slate-800);
	font-family: var(--jsr-font-heading);
	font-size: clamp(1.5rem, 3.5vw, 2.75rem);
	font-weight: 700;
	line-height: 1.25;
	margin: 0 0 1.25rem;
	padding: 0;
}

.home-trust__attr {
	color: var(--jsr-color-text-muted);
	font-size: 0.85rem;
	font-style: normal;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}


/* ── BOTTOM CTA ──────────────────────────────────────────────────────────── */

.home-cta {
	background: #ffffff;
	padding: clamp(4.5rem, 9vw, 8rem) clamp(1.5rem, 6vw, 5.5rem);
}

.home-cta__inner {
	max-width: 52rem;
}

.home-cta__title {
	color: var(--jsr-color-slate-800);
	font-size: clamp(3rem, 8.5vw, 7rem);
	line-height: 0.98;
	margin: 0 0 1.25rem;
}

.home-cta__sub {
	color: var(--jsr-color-text-muted);
	font-size: clamp(0.95rem, 1.3vw, 1.1rem);
	line-height: 1.65;
	margin: 0 0 2rem;
	max-width: 34rem;
}


/* ── FOOTER ──────────────────────────────────────────────────────────────── */

.jsr-footer {
	background: var(--jsr-color-slate-800);
	color: #ffffff;
}

.jsr-footer__inner {
	align-items: start;
	display: grid;
	gap: 3rem 5rem;
	grid-template-columns: minmax(0, 1.1fr) minmax(0, 2.2fr);
	padding: clamp(3.5rem, 6vw, 5.5rem) clamp(1.5rem, 6vw, 5.5rem) clamp(2.5rem, 5vw, 4rem);
}

.jsr-footer__logo {
	display: block;
	filter: brightness(0) invert(1);
	height: auto;
	margin-block-end: 1.25rem;
	max-width: clamp(10rem, 15vw, 14rem);
	opacity: 0.88;
}

.jsr-footer__logo-link {
	display: inline-block;
	text-decoration: none;
}

.jsr-footer__tagline {
	color: rgb(255 255 255 / 68%);
	font-size: 0.95rem;
	line-height: 1.6;
	margin: 0 0 1.5rem;
}

.jsr-footer__contact-list {
	display: flex;
	flex-direction: column;
	gap: 0.6rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.jsr-footer__contact-list li {
	color: rgb(255 255 255 / 68%);
	font-size: 0.875rem;
	line-height: 1.5;
}

.jsr-footer__contact-list a {
	color: #ffffff;
	font-weight: 700;
	text-decoration: none;
}

.jsr-footer__contact-list a:hover {
	color: var(--jsr-color-teal-300);
}

.jsr-footer__nav {
	display: grid;
	gap: 1.5rem 3rem;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.jsr-footer__col-head {
	color: var(--jsr-color-teal-300);
	font-family: var(--jsr-font-heading);
	font-size: 0.68rem;
	font-weight: 700;
	letter-spacing: 0.2em;
	margin: 0 0 0.85rem;
	text-transform: uppercase;
}

.jsr-footer__col ul {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.jsr-footer__col a {
	color: rgb(255 255 255 / 72%);
	font-size: 0.875rem;
	line-height: 1.4;
	text-decoration: none;
	transition: color 140ms ease;
}

.jsr-footer__col a:hover {
	color: #ffffff;
}

.jsr-footer__bar {
	align-items: center;
	border-top: 1px solid rgb(255 255 255 / 14%);
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 2rem;
	justify-content: space-between;
	padding: 1.25rem clamp(1.5rem, 6vw, 5.5rem);
}

.jsr-footer__bar-copy,
.jsr-footer__bar-service {
	color: rgb(255 255 255 / 65%);
	font-size: 0.78rem;
	margin: 0;
}


/* ── FULL-BLEED PAGE / SERVICE HERO ──────────────────────────────────────── */

.jsr-page-hero,
.service-hero {
	background-color: var(--jsr-color-slate-800);
	background-position: center 30%;
	background-size: cover;
	display: flex;
	align-items: flex-end;
	min-height: clamp(22rem, 48vh, 36rem);
	position: relative;
}

.jsr-page-hero::before,
.service-hero::before {
	background: linear-gradient(
		to top,
		rgb(59 71 82 / 88%) 0%,
		rgb(59 71 82 / 52%) 50%,
		rgb(59 71 82 / 18%) 100%
	);
	content: "";
	inset: 0;
	position: absolute;
}

.jsr-page-hero__content,
.service-hero__content {
	padding: clamp(2.5rem, 5vw, 4.5rem) clamp(1.5rem, 6vw, 5.5rem);
	position: relative;
	z-index: 1;
}

.jsr-page-hero__eyebrow {
	color: var(--jsr-color-teal-300);
	display: block;
	font-family: var(--jsr-font-heading);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.22em;
	margin-block-end: 0.75rem;
	text-transform: uppercase;
}

.jsr-page-hero__title,
.service-hero__title {
	color: #ffffff;
	font-size: clamp(2.5rem, 6vw, 5.5rem);
	line-height: 1.0;
	margin: 0 0 0.75rem;
	max-width: 18ch;
}

.jsr-page-hero__excerpt,
.service-hero__excerpt {
	color: rgb(255 255 255 / 80%);
	font-size: clamp(0.95rem, 1.3vw, 1.1rem);
	line-height: 1.65;
	margin: 0;
	max-width: 42rem;
}


/* ── MOBILE ──────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {

	.home-hero {
		min-height: clamp(26rem, 75vh, 42rem);
	}

	.home-cred {
		grid-template-columns: 1fr;
	}

	.home-cred__stats {
		flex-wrap: wrap;
		gap: 1.25rem;
	}

	.home-cred__stat:first-child {
		padding-inline-start: 0;
	}

	.home-cred__divider {
		display: none;
	}

	.home-cred__para {
		border-left: 0;
		border-top: var(--jsr-divider);
		max-width: 100%;
		padding-left: 0;
		padding-top: 1.25rem;
	}

	.home-services__item {
		grid-template-columns: 1fr auto;
	}

	.home-services__desc {
		display: none;
	}

	.home-feature {
		grid-template-columns: 1fr;
	}

	.home-feature__media {
		min-height: 18rem;
		order: -1;
	}

	.home-serve__inner {
		grid-template-columns: 1fr;
	}

	.home-serve__header {
		position: static;
	}

	.home-serve__cards {
		grid-template-columns: 1fr;
	}

	.home-serve__card-img {
		aspect-ratio: 16 / 9;
	}

	.home-serve__card--mid {
		margin-top: 0;
	}

	.home-photo-row {
		grid-template-columns: repeat(2, 1fr);
		height: 20rem;
	}

	.jsr-footer__inner {
		grid-template-columns: 1fr;
		gap: 2.5rem;
	}

	.jsr-footer__nav {
		grid-template-columns: 1fr 1fr;
	}

	.jsr-footer__bar {
		flex-direction: column;
		gap: 0.35rem;
	}
}

@media (max-width: 480px) {
	.jsr-footer__nav {
		grid-template-columns: 1fr;
	}
}


/* ── SHARED: FULL-BLEED PHOTO SECTION ───────────────────────────────────── */

.jsr-photo-section {
	background-color: var(--jsr-color-slate-800);
	background-position: center;
	background-size: cover;
	min-height: clamp(28rem, 50vh, 48rem);
	display: flex;
	align-items: center;
	position: relative;
}

.jsr-photo-section--short {
	min-height: clamp(20rem, 36vh, 32rem);
}

.jsr-photo-section__overlay {
	background: linear-gradient(
		135deg,
		rgb(59 71 82 / 88%) 0%,
		rgb(59 71 82 / 66%) 60%,
		rgb(59 71 82 / 42%) 100%
	);
	inset: 0;
	position: absolute;
}

.jsr-photo-section__overlay--light {
	background: linear-gradient(
		135deg,
		rgb(59 71 82 / 78%) 0%,
		rgb(59 71 82 / 50%) 100%
	);
}

.jsr-photo-section__content {
	position: relative;
	width: 100%;
	z-index: 1;
}

.jsr-photo-section__inner {
	max-width: 54rem;
	padding: clamp(4rem, 8vw, 7rem) clamp(1.5rem, 6vw, 5.5rem);
}

.jsr-photo-section__quote {
	border: 0;
	color: #ffffff;
	font-family: var(--jsr-font-heading);
	font-size: clamp(1.6rem, 3.5vw, 2.75rem);
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 1rem;
	padding: 0;
}

.jsr-photo-section__attr {
	color: rgb(255 255 255 / 65%);
	display: block;
	font-size: 0.82rem;
	font-style: normal;
	letter-spacing: 0.08em;
	margin-bottom: 1.25rem;
	text-transform: uppercase;
}

.jsr-photo-section__sub {
	color: rgb(255 255 255 / 75%);
	font-size: clamp(0.95rem, 1.3vw, 1.05rem);
	line-height: 1.7;
	margin: 0;
	max-width: 38rem;
}

.jsr-photo-section__h2 {
	color: #ffffff;
	font-size: clamp(2rem, 4.5vw, 3.75rem);
	line-height: 1.08;
	margin: 0 0 1rem;
}


/* ── ABOUT PAGE ──────────────────────────────────────────────────────────── */

.about-hero {
	min-height: clamp(30rem, 62vh, 52rem);
}

.about-intro {
	background: #f7f6f3;
	border-top: 3px solid var(--jsr-color-teal-300);
	padding: clamp(4rem, 8vw, 7rem) clamp(1.5rem, 6vw, 5.5rem);
}

.about-intro__inner {
	align-items: start;
	display: grid;
	gap: 4rem 6rem;
	grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.4fr);
}

.about-intro__stats {
	display: flex;
	flex-direction: column;
	gap: 2rem;
}

.about-intro__stat {
	border-top: var(--jsr-divider);
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	padding-top: 1.25rem;
}

.about-intro__stat:first-child {
	border-top: 0;
	padding-top: 0;
}

.about-intro__num {
	color: var(--jsr-color-slate-800);
	font-family: var(--jsr-font-heading);
	font-size: clamp(2.75rem, 5vw, 4.5rem);
	font-weight: 700;
	line-height: 1;
}

.about-intro__label {
	color: var(--jsr-color-text-muted);
	font-size: 0.85rem;
	line-height: 1.45;
}

.about-intro__heading {
	color: var(--jsr-color-slate-800);
	font-size: clamp(2rem, 4vw, 3.5rem);
	line-height: 1.1;
	margin: 0.65rem 0 1.5rem;
}

.about-intro__text p {
	color: var(--jsr-color-text-muted);
	font-size: clamp(0.95rem, 1.3vw, 1.05rem);
	line-height: 1.75;
	margin: 0 0 1rem;
	max-width: 38rem;
}

.about-intro__text .btn {
	margin-top: 0.75rem;
}

/* About values */
.about-values {
	background: #ffffff;
	border-top: var(--jsr-divider);
	padding: clamp(4rem, 8vw, 7rem) clamp(1.5rem, 6vw, 5.5rem);
}

.about-values__inner {
	max-width: 100%;
}

.about-values__header {
	margin-bottom: 3.5rem;
}

.about-values__heading {
	color: var(--jsr-color-slate-800);
	font-size: clamp(2rem, 4.5vw, 3.75rem);
	line-height: 1.1;
	margin: 0.5rem 0 0;
	max-width: 22ch;
}

.about-values__grid {
	display: grid;
	gap: 3rem 0;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.about-values__item {
	border-left: var(--jsr-divider);
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	padding: 2rem 2.5rem 2rem;
}

.about-values__item:nth-child(3n + 1) {
	border-left: 0;
	padding-left: 0;
}

.about-values__num {
	color: var(--jsr-color-coral-300);
	display: block;
	font-family: var(--jsr-font-heading);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.2em;
	margin-bottom: 0.25rem;
}

.about-values__title {
	color: var(--jsr-color-slate-800);
	font-size: clamp(1.15rem, 1.6vw, 1.35rem);
	margin: 0;
}

.about-values__body {
	color: var(--jsr-color-text-muted);
	font-size: 0.92rem;
	line-height: 1.7;
	margin: 0;
}

/* About photo strip — 5 images */
.about-photo-strip {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	height: clamp(12rem, 20vw, 20rem);
}

.about-photo-strip__img {
	background-position: center;
	background-size: cover;
	display: block;
	margin: 0;
}

/* About editorial: Blake section */
.about-blake {
	border-top: var(--jsr-divider);
	display: grid;
	grid-template-columns: 1fr 1fr;
	min-height: clamp(30rem, 55vh, 46rem);
	overflow: hidden;
}

.about-blake__photo {
	background-position: center;
	background-size: cover;
	display: block;
	margin: 0;
	min-height: 24rem;
}

.about-blake__content {
	background: #f7f6f3;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: clamp(3rem, 6vw, 5.5rem) clamp(2rem, 5vw, 4.5rem);
}

.about-blake__heading {
	color: var(--jsr-color-slate-800);
	font-size: clamp(2rem, 3.5vw, 3rem);
	line-height: 1.1;
	margin: 0.5rem 0 0;
}

.about-blake__content p {
	color: var(--jsr-color-text-muted);
	font-size: clamp(0.92rem, 1.2vw, 1rem);
	line-height: 1.75;
	margin: 0 0 1rem;
	max-width: 36rem;
}

.about-blake__credentials {
	border-top: var(--jsr-divider);
	display: flex;
	flex-direction: column;
	gap: 0.85rem;
	margin-top: 1.5rem;
	padding-top: 1.5rem;
}

.about-blake__cred {
	display: flex;
	flex-direction: column;
	gap: 0.15rem;
}

.about-blake__cred-label {
	color: var(--jsr-color-coral-300);
	font-family: var(--jsr-font-heading);
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.2em;
	text-transform: uppercase;
}

.about-blake__cred-value {
	color: var(--jsr-color-slate-800);
	font-size: 0.88rem;
	line-height: 1.45;
}


/* ── SERVICE ARCHIVE ─────────────────────────────────────────────────────── */

.archive-landing {
	background: #ffffff;
	overflow: clip;
}

.archive-landing--service {
	--archive-accent: var(--jsr-color-gold-400);
	--archive-accent-text: #7a5c00;
	--archive-dark: var(--jsr-color-slate-800);
	--archive-muted-bg: #f7f6f3;
}

.archive-landing--industry {
	--archive-accent: var(--jsr-color-teal-300);
	--archive-accent-text: var(--jsr-color-teal-700);
	--archive-dark: #1e2832;
	--archive-muted-bg: #f2f3f3;
}

.archive-hero {
	background: var(--archive-accent);
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
	min-height: clamp(30rem, 62vh, 46rem);
	overflow: hidden;
}

.archive-hero__content {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: clamp(3.25rem, 6vw, 5.75rem) clamp(1.5rem, 6vw, 5.5rem) clamp(3.25rem, 6vw, 5rem);
}

.archive-hero__eyebrow {
	color: rgb(59 71 82 / 66%);
	display: block;
	font-family: var(--jsr-font-heading);
	font-size: 0.7rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	margin-block-end: clamp(1.8rem, 4vw, 3rem);
	text-transform: uppercase;
}

.archive-hero__title {
	color: var(--jsr-color-slate-800);
	font-size: clamp(2.75rem, 6.2vw, 5.7rem);
	line-height: 1;
	margin: 0;
	max-width: 15ch;
}

.archive-hero__rule {
	background: rgb(59 71 82 / 30%);
	block-size: 1px;
	inline-size: min(100%, 34rem);
	margin-block: clamp(1.5rem, 3vw, 2.5rem);
}

.archive-hero__excerpt {
	color: rgb(59 71 82 / 80%);
	font-size: clamp(0.95rem, 1.35vw, 1.08rem);
	line-height: 1.7;
	margin: 0;
	max-width: 36rem;
}

.archive-hero__photo {
	background-position: center;
	background-size: cover;
	display: block;
	margin: 0;
	min-height: 100%;
	position: relative;
}

.archive-hero__photo::after {
	background: linear-gradient(to right, rgb(59 71 82 / 10%), rgb(30 40 50 / 22%));
	content: "";
	inset: 0;
	position: absolute;
}

.svc-archive-intro {
	align-items: center;
	background: var(--archive-dark, var(--jsr-color-slate-800));
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem 3rem;
	justify-content: space-between;
	padding: 1.4rem clamp(1.5rem, 6vw, 5.5rem);
}

.svc-archive-intro__text {
	color: rgb(255 255 255 / 72%);
	font-size: 0.88rem;
	line-height: 1.55;
	margin: 0;
	max-width: 38rem;
}

.svc-archive-intro__meta {
	align-items: center;
	color: rgb(255 255 255 / 45%);
	display: flex;
	flex-wrap: wrap;
	font-family: var(--jsr-font-heading);
	font-size: 0.72rem;
	font-weight: 700;
	gap: 0.4rem 0.75rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

/* Service cards — alternating editorial layout */
.svc-archive-grid {
	border-top: var(--jsr-divider);
}

.svc-archive-card {
	border-bottom: var(--jsr-divider);
	display: grid;
	grid-template-columns: 1fr 1fr;
	min-height: clamp(22rem, 38vw, 32rem);
	overflow: hidden;
}

.svc-archive-card--alt {
	direction: rtl;
}

.svc-archive-card--alt > * {
	direction: ltr;
}

.svc-archive-card__photo {
	background-position: center;
	background-size: cover;
	display: block;
	margin: 0;
	min-height: 100%;
	overflow: hidden;
	position: relative;
	transition: transform var(--jsr-motion-slow);
}

.svc-archive-card__photo::after {
	background: linear-gradient(135deg, rgb(30 40 50 / 8%), rgb(30 40 50 / 22%));
	content: "";
	inset: 0;
	position: absolute;
	transition: opacity var(--jsr-motion-medium);
}

.svc-archive-card__content {
	background: #ffffff;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: clamp(2.5rem, 5vw, 4.5rem) clamp(2rem, 5vw, 4.5rem);
}

.svc-archive-card--alt .svc-archive-card__content {
	background: var(--archive-muted-bg, #f7f6f3);
}

.svc-archive-card__tag {
	color: var(--archive-accent-text, var(--jsr-color-teal-700));
	display: block;
	font-family: var(--jsr-font-heading);
	font-size: 0.67rem;
	font-weight: 700;
	letter-spacing: 0.2em;
	margin-bottom: 0.75rem;
	text-transform: uppercase;
}

.svc-archive-card__name {
	color: var(--jsr-color-slate-800);
	font-size: clamp(1.65rem, 2.8vw, 2.4rem);
	line-height: 1.1;
	margin: 0 0 1rem;
}

.svc-archive-card__desc {
	color: var(--jsr-color-text-muted);
	font-size: clamp(0.9rem, 1.2vw, 1rem);
	line-height: 1.72;
	margin: 0 0 1.75rem;
	max-width: 34rem;
}

.svc-archive-card__link {
	align-self: flex-start;
}

.svc-archive-card:hover .svc-archive-card__photo {
	transform: scale(1.025);
}

.svc-archive-card:hover .svc-archive-card__photo::after {
	opacity: 0.58;
}

.archive-landing .btn--mint {
	background: var(--archive-accent);
	color: var(--jsr-color-slate-800);
}

.archive-landing .btn--mint:hover,
.archive-landing .btn--mint:focus-visible {
	background: var(--archive-dark);
	color: #ffffff;
}

.archive-landing .btn--ghost-dark {
	border-color: rgb(59 71 82 / 45%);
	color: var(--jsr-color-slate-800);
}

.archive-landing .btn--ghost-dark:hover,
.archive-landing .btn--ghost-dark:focus-visible {
	background: var(--archive-accent);
	border-color: var(--archive-accent);
	color: var(--jsr-color-slate-800);
	transform: translateY(-0.12rem);
}

.archive-landing .home-rule--mint {
	background: var(--archive-accent);
}

.archive-landing__photo-section .btn--mint {
	margin-top: 0.5rem;
}

/* Who We Serve teaser */
.svc-archive-serve {
	background: #ffffff;
	border-top: var(--jsr-divider);
	padding: clamp(4rem, 8vw, 7rem) clamp(1.5rem, 6vw, 5.5rem);
}

.svc-archive-serve__inner {
	align-items: start;
	display: grid;
	gap: 3rem 5rem;
	grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
}

.svc-archive-serve__photos {
	display: grid;
	gap: 1rem;
	grid-template-columns: 1fr;
}

.svc-archive-serve__photo {
	background-position: center;
	background-size: cover;
	border-radius: 0.4rem;
	display: block;
	margin: 0;
	min-height: 16rem;
}

.svc-archive-serve__photo--bot {
	margin-left: 2.5rem;
	min-height: 12rem;
}


/* ── MOBILE — ABOUT + SERVICES ARCHIVE ───────────────────────────────────── */

@media (max-width: 900px) {
	.archive-hero {
		grid-template-columns: 1fr;
		min-height: unset;
	}

	.archive-hero__photo {
		aspect-ratio: 16 / 9;
		min-height: unset;
		order: -1;
	}

	.about-intro__inner {
		grid-template-columns: 1fr;
		gap: 2.5rem;
	}

	.about-intro__stats {
		flex-direction: row;
		flex-wrap: wrap;
		gap: 1.5rem 3rem;
	}

	.about-intro__stat {
		border-left: 2px solid var(--jsr-color-teal-300);
		border-top: 0;
		padding-left: 1rem;
		padding-top: 0;
	}

	.about-intro__stat:first-child {
		border-left: 2px solid var(--jsr-color-teal-300);
		padding-left: 1rem;
	}

	.about-values__grid {
		grid-template-columns: 1fr;
	}

	.about-values__item {
		border-left: 0;
		border-top: var(--jsr-divider);
		padding: 1.5rem 0;
	}

	.about-values__item:first-child {
		border-top: 0;
		padding-top: 0;
	}

	.about-photo-strip {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		height: 14rem;
	}

	.about-photo-strip__img:nth-child(4),
	.about-photo-strip__img:nth-child(5) {
		display: none;
	}

	.about-blake {
		grid-template-columns: 1fr;
	}

	.about-blake__photo {
		min-height: 22rem;
		order: -1;
	}

	.svc-archive-card {
		grid-template-columns: 1fr;
	}

	.svc-archive-card--alt {
		direction: ltr;
	}

	.svc-archive-card__photo {
		min-height: 18rem;
	}

	.svc-archive-serve__inner {
		grid-template-columns: 1fr;
	}

	.svc-archive-serve__photos {
		grid-template-columns: 1fr 1fr;
	}

	.svc-archive-serve__photo--bot {
		margin-left: 0;
	}
}

@media (max-width: 600px) {
	.about-photo-strip {
		grid-template-columns: repeat(2, 1fr);
		height: 10rem;
	}

	.about-photo-strip__img:nth-child(3) {
		display: none;
	}

	.jsr-photo-section__inner {
		padding-block: clamp(3rem, 8vw, 5rem);
	}
}


/* ── CONTACT PAGE ────────────────────────────────────────────────────────── */

.contact-body {
	background: #ffffff;
	padding: clamp(4rem, 8vw, 7rem) clamp(1.5rem, 6vw, 5.5rem);
}

.contact-body__inner {
	display: grid;
	gap: 3rem 5rem;
	grid-template-columns: minmax(0, 1.6fr) minmax(0, 0.7fr);
	align-items: start;
	max-width: 100%;
}

.contact-success {
	background: #ecfdf5;
	border: 1.5px solid #6ee7b7;
	border-radius: 0.5rem;
	color: #065f46;
	margin-bottom: 1.75rem;
	padding: 1rem 1.25rem;
}

.contact-error {
	background: #fef2f2;
	border: 1.5px solid #fca5a5;
	border-radius: 0.5rem;
	color: #991b1b;
	margin-bottom: 1.75rem;
	padding: 1rem 1.25rem;
}

.contact-form {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.contact-form__row {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.contact-form__row--2col {
	flex-direction: row;
}

.contact-form__field {
	display: flex;
	flex: 1;
	flex-direction: column;
	gap: 0.4rem;
}

.contact-form__field label {
	color: var(--jsr-color-slate-800);
	font-family: var(--jsr-font-heading);
	font-size: 0.8rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.contact-form__field label span {
	color: var(--jsr-color-teal-700);
}

.contact-form__field input,
.contact-form__field textarea,
.contact-form__field select {
	background: #fafafa;
	border: 1.5px solid var(--jsr-color-gray-200);
	border-radius: 0.45rem;
	color: var(--jsr-color-slate-800);
	font-family: var(--jsr-font-body);
	font-size: 0.95rem;
	padding: 0.75rem 1rem;
	transition: border-color 160ms ease, box-shadow 160ms ease;
	width: 100%;
}

.contact-form__field input:focus,
.contact-form__field textarea:focus,
.contact-form__field select:focus {
	border-color: var(--jsr-color-teal-300);
	box-shadow: 0 0 0 3px rgb(159 205 195 / 22%);
	outline: none;
}

.contact-form__radio-group {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.contact-form__radio {
	align-items: center;
	border: 1.5px solid var(--jsr-color-gray-200);
	border-radius: 999px;
	cursor: pointer;
	display: inline-flex;
	font-family: var(--jsr-font-heading);
	font-size: 0.82rem;
	gap: 0.4rem;
	padding: 0.4rem 0.9rem;
	text-transform: none;
	transition: border-color 140ms ease, background 140ms ease;
}

.contact-form__radio input[type="radio"] {
	accent-color: var(--jsr-color-teal-700);
	height: auto;
	padding: 0;
	width: auto;
}

.contact-form__radio:has(input:checked) {
	background: var(--jsr-color-teal-300);
	border-color: var(--jsr-color-teal-300);
	color: var(--jsr-color-slate-800);
}

.contact-form__actions {
	align-items: center;
	display: flex;
	gap: 1.25rem;
	margin-top: 0.5rem;
}

.contact-form__note {
	color: var(--jsr-color-text-muted);
	font-size: 0.82rem;
}

/* Contact info sidebar */
.contact-info {
	background: #f7f6f3;
	border-top: 3px solid var(--jsr-color-teal-300);
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
	padding: 2rem;
	position: sticky;
	top: calc(var(--jsr-header-h) + 1.5rem);
}

.contact-info__label {
	color: var(--jsr-color-teal-700);
	display: block;
	font-family: var(--jsr-font-heading);
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.2em;
	margin-bottom: 0.2rem;
	text-transform: uppercase;
}

.contact-info__value {
	color: var(--jsr-color-slate-800);
	display: block;
	font-size: 0.95rem;
	line-height: 1.5;
	margin: 0;
	text-decoration: none;
}

a.contact-info__value:hover {
	color: var(--jsr-color-teal-700);
}

.contact-info__divider {
	background: var(--jsr-color-gray-200);
	height: 1px;
}

.contact-info__note {
	color: var(--jsr-color-text-muted);
	font-size: 0.82rem;
	line-height: 1.6;
	margin: 0;
}

@media (max-width: 768px) {
	.contact-body__inner {
		grid-template-columns: 1fr;
	}

	.contact-form__row--2col {
		flex-direction: column;
	}

	.contact-info {
		position: static;
	}
}
