:root {
	--paper:   #f4f3ed;
	--paper-2: #eeece3;
	--ink:     #1d231f;
	--muted:   #6b736b;
	--faint:   #9098906e;
	--line:    rgba(29, 35, 31, 0.14);
	--accent:  #6f9c83;   /* lightened brand green */
	--ease:    cubic-bezier(0.22, 1, 0.36, 1);
	--pad:     clamp(1.4rem, 5vw, 4.5rem);
	--mono:    ui-monospace, "SFMono-Regular", "SF Mono", Menlo, Consolas, "Liberation Mono", monospace;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
	font-family: "Inter", -apple-system, "Helvetica Neue", Arial, sans-serif;
	background: var(--paper);
	color: var(--ink);
	line-height: 1.65;
	font-weight: 300;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

.skip-link {
	position: absolute; left: 0; top: -3rem;
	background: var(--ink); color: var(--paper);
	padding: .6rem 1rem; z-index: 60;
	transition: top .2s var(--ease);
}
.skip-link:focus { top: 0; }
:focus-visible { outline: 1px solid var(--accent); outline-offset: 4px; }

.label {
	font-family: var(--mono);
	font-size: .68rem;
	letter-spacing: .22em;
	text-transform: uppercase;
	color: var(--muted);
	font-weight: 400;
}

.wrap { max-width: 1180px; margin: 0 auto; }

/* ---------------- Top bar (over hero image) ---------------- */
.topbar {
	position: absolute; top: 0; left: 0; right: 0; z-index: 10;
	display: flex; align-items: center; justify-content: space-between;
	padding: clamp(1.5rem, 3.5vw, 2.4rem) var(--pad);
}
.topbar__logo img { height: clamp(40px, 5.3vw, 52px); width: auto; }
.topbar__right { display: flex; align-items: center; gap: clamp(1rem, 3vw, 2.2rem); }
.greeting { color: rgba(255,255,255,0.72); }
@media (max-width: 560px) { .greeting { display: none; } }

.contact-link {
	font-family: var(--mono);
	font-size: .68rem; letter-spacing: .22em; text-transform: uppercase;
	color: #fff; font-weight: 400;
	padding-bottom: 4px;
	border-bottom: 1px solid rgba(255,255,255,0.28);
	transition: border-color .35s var(--ease);
}
.contact-link:hover { border-color: #fff; }

/* ---------------- Hero ---------------- */
.hero {
	position: relative;
	min-height: calc(100vh - 33px);
	min-height: calc(100svh - 33px);
	overflow: hidden;
}
.hero__media {
	position: absolute; inset: 0;
	/* real image on top, tiny inline blurred placeholder underneath (no grey flash) */
	background-image:
		url("../images/wyoming2.webp"),
		url("data:image/webp;base64,UklGRtYAAABXRUJQVlA4IMoAAADwBQCdASogABIAPu1qrE8ppiQiMBgIATAdiUAU5elRTlgPd4sDZGh4GfB06xndDFzFwXst3tn9YAD+6/sT5FHpztfrzeO5vSXu/I6Rcls4oj0SPM38ZSoE7BpoQsmoj07hwY+f2QszT1l5DWZOlKSfnSGgI4/g86ae2Yn3sVUSuw7kpRckvIW5M/uEOOJL4eee0l02A3YDo2AFQGhVhJIpc0rNt7dZIVnoTgcxdcQJGySpWzPjGxnbFwDX6xy1nkmazUkhFMXbZnAA");
	background-position: center 50%, center 50%;
	background-size: cover, cover;
	background-repeat: no-repeat, no-repeat;
	filter: grayscale(0.06) brightness(0.82) saturate(1.0);
}
/* dark only at the very top (for the white logo) — fades to paper at the bottom */
.hero__overlay {
	position: absolute; inset: 0;
	background: linear-gradient(180deg,
		rgba(17,23,19,0.46) 0%,
		rgba(17,23,19,0.12) 13%,
		rgba(17,23,19,0.00) 36%);
}

/* green divider bar below the hero */
.hero-bar { height: 33px; background: #3E5C50; }

/* ---------------- Intro statement ---------------- */
.intro { padding: clamp(3.5rem, 8vw, 6rem) var(--pad) clamp(3rem, 7vw, 5rem); }
.intro__eyebrow { color: var(--accent); margin-bottom: 1.4rem; }
.intro__statement {
	font-weight: 300;
	font-size: clamp(1.6rem, 3.6vw, 2.8rem);
	line-height: 1.26;
	letter-spacing: -0.012em;
	max-width: 18ch;
	color: var(--ink);
}

/* ---------------- Focus ---------------- */
.section { padding: clamp(2rem, 5vw, 3rem) var(--pad) clamp(5rem, 11vw, 8rem); }

.about {
	max-width: 820px;
	font-size: clamp(1.05rem, 1.7vw, 1.28rem);
	font-weight: 300;
	line-height: 1.85;
	color: var(--ink);
}
.about .muted { color: var(--muted); }

.focus { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; }
.focus__item {
	padding: 1.8rem 1.8rem 0 0;
	border-top: 1px solid var(--line);
}
.focus__num { color: var(--accent); margin-bottom: 1rem; }
.focus__name { font-size: 1.05rem; font-weight: 400; margin-bottom: .5rem; letter-spacing: -0.005em; }
.focus__desc { font-size: .92rem; color: var(--muted); font-weight: 300; line-height: 1.6; max-width: 26ch; }

@media (max-width: 720px) {
	.focus { grid-template-columns: 1fr; }
	.focus__item { padding: 1.5rem 0 0; }
	.focus__desc { max-width: none; }
}

/* ---------------- Footer ---------------- */
.footer {
	border-top: 1px solid var(--line);
	padding: clamp(3rem, 6vw, 4.5rem) var(--pad);
	background: var(--paper-2);
}
.footer__grid {
	display: flex; flex-wrap: wrap; gap: 2.2rem 4rem;
	align-items: flex-start; justify-content: space-between;
}
/* white wordmark recolored to brand green via mask */
.footer__logo {
	display: block;
	height: 38px;
	aspect-ratio: 1326 / 312;
	margin-bottom: 1.5rem;
	background-color: #3E5C50;
	-webkit-mask: url("../images/trajan.png") left center / contain no-repeat;
	        mask: url("../images/trajan.png") left center / contain no-repeat;
}
.footer__contact a {
	border-bottom: 1px solid var(--line);
	transition: border-color .35s var(--ease);
	font-weight: 400;
}
.footer__contact a:hover { border-color: var(--accent); }
.footer__meta {
	font-family: var(--mono);
	font-size: .72rem; line-height: 2; letter-spacing: .04em;
	color: var(--muted); text-align: right;
}
.footer__meta .name { color: var(--ink); }

.footer__bottom {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: baseline;
	gap: .6rem 2rem;
	margin-top: clamp(2.5rem, 5vw, 3.5rem);
	padding-top: 1.5rem;
	border-top: 1px solid var(--line);
	font-family: var(--mono);
	font-size: .72rem; letter-spacing: .04em;
	color: var(--muted);
}
.footer__bottom .name { color: var(--ink); }
.footer__bottom .sep { opacity: .45; margin: 0 .35em; }
.footer__bottom a {
	border-bottom: 1px solid var(--line);
	transition: border-color .35s var(--ease);
}
.footer__bottom a:hover { border-color: var(--accent); }
@media (max-width: 560px) {
	.footer__grid { flex-direction: column; }
	.footer__meta { text-align: left; }
}

/* ---------------- Reserved entrance ---------------- */
.reveal { opacity: 0; transform: translateY(14px); transition: opacity 1.1s var(--ease), transform 1.1s var(--ease); }
.reveal.is-in { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { transition-duration: .001ms !important; animation: none !important; }
	.reveal { opacity: 1; transform: none; }
	html { scroll-behavior: auto; }
}
