@font-face {
	font-family: "Source Sans 3";
	font-style: normal;
	font-weight: 200 900;
	font-display: swap;
	src: url("assets/fonts/SourceSans3VF-Upright.woff2") format("woff2");
}

@layer reset, base, document, utilities;

@layer reset {
	*,
	*::before,
	*::after {
		box-sizing: border-box;
	}

	body,
	h1,
	h2,
	h3,
	p {
		margin: 0;
	}
}

@layer base {
	:root {
		color-scheme: light;
		--page: #eef3f7;
		--paper: #ffffff;
		--ink: #172231;
		--text: #2f3d4c;
		--muted: #657284;
		--rule: #cfd9e3;
		--rule-soft: #e7edf2;
		--accent: #9a5b2e;
		--accent-soft: #f4e8dc;
		--focus: #2f6f9f;
		--paper-width: 960px;
	}

	body {
		min-width: 320px;
		background: var(--page);
		color: var(--text);
		font-family: "Source Sans 3", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
		font-size: 0.97rem;
		line-height: 1.38;
		text-rendering: optimizeLegibility;
	}

	a {
		color: inherit;
		text-underline-offset: 0.16em;
	}

	:focus-visible {
		outline: 3px solid color-mix(in oklch, var(--focus) 70%, white);
		outline-offset: 3px;
	}
}

@layer document {
	.resume {
		width: min(var(--paper-width), calc(100% - 2rem));
		margin: 1.25rem auto;
		padding: clamp(1.25rem, 2.6vw, 2rem);
		background: var(--paper);
		border: 1px solid var(--rule);
		box-shadow: 0 18px 44px rgb(23 34 49 / 0.10);
	}

	.resume-header {
		display: grid;
		grid-template-columns: minmax(0, 1fr) max-content;
		gap: 1rem;
		align-items: end;
		padding-block-end: 0.8rem;
		border-block-end: 2px solid var(--ink);
	}

	.eyebrow,
	.contact-note,
	h2 {
		font-size: 0.78rem;
		font-weight: 760;
		letter-spacing: 0.075em;
		line-height: 1.2;
		text-transform: uppercase;
	}

	.eyebrow {
		color: var(--accent);
		margin-block-end: 0.18rem;
	}

	.contact-note {
		color: var(--muted);
		text-align: right;
	}

	h1,
	h2,
	h3 {
		color: var(--ink);
		letter-spacing: 0;
	}

	h1 {
		font-size: clamp(2.7rem, 7vw, 4.35rem);
		font-weight: 760;
		line-height: 0.9;
	}

	section {
		display: grid;
		grid-template-columns: 9.5rem minmax(0, 1fr);
		gap: 1.25rem;
		padding-block: 0.88rem;
		border-block-end: 1px solid var(--rule-soft);
	}

	section:last-child {
		border-block-end: 0;
		padding-block-end: 0;
	}

	h2 {
		padding-block-start: 0.12rem;
		color: var(--accent);
	}

	h3 {
		font-size: 1.02rem;
		font-weight: 730;
		line-height: 1.16;
	}

	.summary p {
		max-width: 74ch;
		color: var(--ink);
		font-size: 1.04rem;
		line-height: 1.36;
	}

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

	.skill-grid div {
		padding-block-start: 0.48rem;
		border-block-start: 1px solid var(--rule-soft);
	}

	.skill-grid h3 {
		margin-block-end: 0.12rem;
	}

	.skill-grid p,
	.role p,
	.small-note,
	.work-placeholder p {
		color: var(--text);
		font-size: 0.95rem;
	}

	.experience-list {
		display: grid;
		gap: 0.58rem;
	}

	.role {
		display: grid;
		grid-template-columns: minmax(13rem, 0.44fr) minmax(0, 1fr);
		gap: 1rem;
		padding-block-end: 0.58rem;
		border-block-end: 1px solid var(--rule-soft);
	}

	.role:last-child {
		padding-block-end: 0;
		border-block-end: 0;
	}

	.role header p {
		margin-block-start: 0.14rem;
		color: var(--muted);
		font-size: 0.88rem;
		font-weight: 610;
		line-height: 1.25;
	}

	.compact-role h3 {
		font-size: 0.98rem;
	}

	.work-placeholder {
		padding: 0.62rem 0.75rem;
		background: linear-gradient(90deg, var(--accent-soft), white 72%);
		border-inline-start: 3px solid var(--accent);
	}

	.small-note {
		max-width: 68ch;
		color: var(--muted);
	}
}

@layer utilities {
	@media (max-width: 760px) {
		.resume {
			width: min(100%, calc(100% - 1rem));
			margin-block: 0.5rem;
		}

		.resume-header,
		section,
		.role {
			grid-template-columns: 1fr;
		}

		.resume-header,
		section {
			gap: 0.5rem;
		}

		.contact-note {
			text-align: left;
		}

		h1 {
			font-size: clamp(2.65rem, 16vw, 3.8rem);
		}

		.skill-grid {
			grid-template-columns: 1fr;
		}
	}

	@media print {
		body {
			background: white;
			font-size: 9.5pt;
		}

		.resume {
			width: auto;
			margin: 0;
			padding: 0;
			border: 0;
			box-shadow: none;
		}
	}
}
