/* Shared site footer — injected by build-partials.py */
.site-footer {
	margin-top: 4rem;
	padding: 2.5rem 0 2rem;
	border-top: 1px solid var(--border, #e2e8f0);
	background: var(--light, #f7fafc);
	font-size: 0.88rem;
	color: var(--gray, #616e7c);
}
.site-footer .container {
	max-width: 1100px;
	margin: 0 auto;
	padding: 0 1.5rem;
}
.site-footer nav {
	display: flex;
	flex-wrap: wrap;
	gap: 1.25rem;
	margin-bottom: 1rem;
}
.site-footer nav a {
	color: var(--gray, #616e7c);
	text-decoration: none;
	transition: color 0.15s;
}
.site-footer nav a:hover {
	color: var(--navy, #1a1f36);
}
.site-footer .footer-social {
	margin-bottom: 1.25rem;
	gap: 0.5rem;
	align-items: center;
}
.site-footer .footer-social a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 38px;
	height: 38px;
	border-radius: 8px;
	color: var(--gray, #616e7c);
	transition: all 0.15s;
}
.site-footer .footer-social a:hover {
	color: var(--navy, #1a1f36);
	background: rgba(26, 31, 54, 0.06);
	transform: translateY(-1px);
}
.site-footer .footer-copy {
	font-size: 0.82rem;
	color: var(--gray, #616e7c);
	margin: 0;
}
.site-footer .footer-copy a {
	color: var(--gray, #616e7c);
}
.site-footer .footer-copy a:hover {
	color: var(--navy, #1a1f36);
}

/* Active nav state — set by build-partials.py via aria-current="page" */
.site-header nav a[aria-current="page"] {
	color: var(--gold, #c9a227);
	font-weight: 600;
}

/* Nav CTA — uses unified button tokens directly to avoid specificity wars */
.site-header nav a.nav-cta {
	background: var(--navy, #1a1f36);
	color: var(--white, #ffffff);
	border: var(--btn-border-width, 1.5px) solid var(--navy, #1a1f36);
	border-radius: var(--btn-radius, 8px);
	padding: var(--btn-py-sm, 0.5rem) var(--btn-px-sm, 1rem);
	margin-left: 1.5rem;
	font-size: var(--btn-font-size-sm, 0.85rem);
	font-weight: var(--btn-font-weight, 600);
	line-height: 1.2;
	transition: var(--btn-transition, all 0.2s ease);
}
.site-header nav a.nav-cta:hover {
	background: var(--navy-light, #2d3352);
	border-color: var(--navy-light, #2d3352);
	color: var(--white, #ffffff);
	transform: translateY(-1px);
}
@media (max-width: 768px) {
	.site-header nav a.nav-cta {
		margin-left: 0.85rem;
		padding: var(--btn-py-sm, 0.5rem) var(--btn-px-sm, 0.85rem);
	}
}
