body {
	letter-spacing: 0.01em;
}

a:focus-visible,
button:focus-visible,
.button:focus-visible {
	outline: 2px solid #ffffff;
	outline-offset: 4px;
}

#header .content .inner {
	padding: 3rem 2rem;
}

#header .content p,
#main p,
#main li {
	text-transform: none;
	letter-spacing: 0.02em;
}

#header .content .eyebrow {
	margin-bottom: 0.75rem;
	font-size: 0.78rem;
	font-weight: 600;
	letter-spacing: 0.24rem;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.7);
}

#header .content .brand-mark {
	font-family: "Frank Ruhl Libre", serif;
	font-weight: 500;
	letter-spacing: 0.25rem;
	text-transform: none;
}

#header .content .hero-copy {
	max-width: 44rem;
	margin: 0 auto 1.25rem auto;
	font-size: 1.05rem;
	line-height: 1.8;
}

.hero-highlights {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.75rem;
	list-style: none;
	padding: 0;
	margin: 0 0 1.75rem 0;
}

.hero-highlights li {
	padding: 0.65rem 0.9rem;
	border: 1px solid rgba(255, 255, 255, 0.28);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.05);
	font-size: 0.82rem;
}

.hero-actions {
	justify-content: center;
	margin-top: 0.5rem;
}

#header nav ul li a {
	padding: 0 1.2rem;
}

.grid-metrics,
.service-list {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 1rem;
}

.metric-card,
.service-card,
.contact-panel {
	padding: 1.25rem;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 0.5rem;
	background: rgba(255, 255, 255, 0.04);
}

.metric-card strong,
.service-card h3 {
	display: block;
	margin-bottom: 0.5rem;
}

.metric-card strong {
	font-size: 1.15rem;
	letter-spacing: 0.08rem;
}

.metric-card span,
.service-card p,
.section-note,
.contact-panel p,
.process-list li {
	color: rgba(255, 255, 255, 0.82);
}

.service-card h3 {
	font-size: 0.95rem;
	letter-spacing: 0.16rem;
}

.section-note {
	margin: 1.5rem 0 0 0;
}

.process-list {
	padding-left: 1.3rem;
}

.process-list li {
	margin-bottom: 1rem;
	line-height: 1.8;
}

.contact-panel {
	margin-bottom: 1.5rem;
}

#main article .close {
	border: 0;
	background: transparent;
	cursor: pointer;
}

#main article .close .label {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

@media screen and (max-width: 980px) {
	.grid-metrics,
	.service-list {
		grid-template-columns: 1fr;
	}

	#header nav ul {
		flex-wrap: wrap;
	}
}

@media screen and (max-width: 736px) {
	#header .content .inner {
		padding: 2.25rem 1.25rem;
	}

	#header .content .hero-copy {
		font-size: 0.98rem;
	}

	.hero-highlights {
		gap: 0.5rem;
	}

	.hero-highlights li {
		width: 100%;
		border-radius: 0.5rem;
	}
}
