/* Variables */

:root {
	--burnt-orange: #CC5500;
	--warm-cream: #F5F0E1;
	--deep-brown: #3B2314;
	--teal: #2E6B6A;
	--goldenrod: #DAA520;
	--off-white: #FAF8F3;
	--lime: #96DC96;

	--font-display: 'Fraunces', serif;
	--font-body: 'Source Serif 4', serif;
	--font-heading: 'Inter', sans-serif;
	--font-mono: 'IBM Plex Mono', monospace;

	--measure: 48rem;
	--measure-wide: 80rem;
	--nav-height: 50px;
	--page-padding: 1.5rem;
}

/* Base */

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

body {
	margin: 0;
	font-family: var(--font-body);
	color: #000;
	background: #fff;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--font-heading);
	color: #000;
}

code, pre code, kbd, samp {
	font-family: var(--font-mono);
}

a {
	color: var(--teal);
}

/* Site Nav */

.site-nav {
	position: fixed;
	inset-block-start: 0;
	inset-inline: 0;
	z-index: 50;
	background: #fff;
	border-block-end: 1px solid rgb(0 0 0 / 0.1);

	& > div {
		display: flex;
		align-items: center;
		max-width: var(--measure);
		margin-inline: auto;
		padding-block: 0.75rem;
		padding-inline: 1.5rem;
	}

	& .site-title {
		flex: 1;
		margin: 0;
		font-family: var(--font-display);
		font-size: 1.25rem;
		font-weight: 700;

		& a {
			color: #000;
			text-decoration: none;
			transition: opacity 0.2s;

			&:hover { opacity: 0.7; }
		}
	}

	& ul {
		display: flex;
		gap: 1.5rem;
		align-items: center;
		list-style: none;
		margin: 0;
		padding: 0;
		font-family: var(--font-body);
		font-size: 0.875rem;
		letter-spacing: 0.025em;
	}

	& ul a {
		color: #000;
		text-decoration: underline;
		text-underline-offset: 4px;
		text-decoration-color: rgb(0 0 0 / 0.3);
		transition: text-decoration-color 0.2s;

		&:hover { text-decoration-color: #000; }
		&.active { text-decoration-color: #000; }
	}
}


/* Page Layout (Home) */

.page {
	max-width: var(--measure);
	margin-inline: auto;
	padding-inline: var(--page-padding);
	padding-block-end: 2rem;
}

/* Hero */

.hero {
	margin-block-start: var(--nav-height);
	padding-block: 2.5rem;
	padding-inline: var(--page-padding);
	background: rgb(80, 82, 72);

	@media (min-width: 768px) {
		padding-block: 3.5rem;
	}

	& > div {
		max-width: calc(var(--measure) - 2 * var(--page-padding));
		margin-inline: auto;
	}

	& h1 {
		font-family: var(--font-display);
		font-size: clamp(3.75rem, 8vw, 6rem);
		font-weight: 900;
		letter-spacing: -0.025em;
		line-height: 1;
		margin: 0;
		color: rgb(216, 239, 218);
	}

	& p {
		font-family: var(--font-body);
		font-size: clamp(1.25rem, 3vw, 1.5rem);
		color: rgb(216, 239, 218);
		margin-block-start: 1.5rem;
		margin-block-end: 0;
		max-width: 36rem;
		line-height: 1.6;
	}
}

/* Home Content */

.home-content {
	font-size: 1.125rem;
	color: #000;

	& h2 {
		font-size: 1.75rem;
		font-weight: 700;
		margin-block-start: 3.5rem;
		margin-block-end: 1.25rem;
	}

	& p {
		line-height: 1.8;
		margin-block-end: 1.25rem;
	}

	& a {
		color: var(--teal);
		text-decoration: underline;
		text-decoration-color: rgb(46 107 106 / 0.3);
		text-underline-offset: 3px;
		transition: text-decoration-color 0.2s;

		&:hover { text-decoration-color: var(--teal); }
	}

	& pre {
		background: var(--warm-cream);
		border: none;
		border-inline-start: 4px solid var(--lime);
		border-radius: 0;
		padding: 1.5rem;
		margin-block: 2rem;
		margin-inline: calc(-1 * var(--page-padding));
		overflow-x: auto;
	}

	& pre code {
		color: #000;
		font-size: 0.875rem;
		line-height: 1.7;
		background: transparent;
	}

	& .hljs { background: transparent; color: #000; }
	& .hljs-string, & .hljs-number { color: var(--burnt-orange); }
	& .hljs-keyword, & .hljs-built_in { color: var(--teal); }
	& .hljs-attr { color: #8B6914; }
	& .hljs-comment { color: #8B7B6B; font-style: italic; }

	& :not(pre) > code {
		background: var(--warm-cream);
		color: var(--burnt-orange);
		padding: 0.15em 0.4em;
		border-radius: 2px;
		font-size: 0.875em;
	}

	& ul {
		margin-block: 1.25rem;
		padding-inline-start: 1.5rem;
		list-style: none;
	}

	& ul li {
		position: relative;
		padding-inline-start: 0.25rem;
	}

	& ul li::before {
		content: '';
		position: absolute;
		inset-inline-start: -1.1rem;
		top: 0.65em;
		width: 0.5rem;
		height: 0.5rem;
		background: var(--lime);
	}

	& ol {
		margin-block: 1.25rem;
		padding-inline-start: 1.5rem;
	}

	& li {
		line-height: 1.8;
		margin-block-end: 0.5rem;
	}
}

/* Feature Boxes */

.feature-boxes {
	display: grid;
	gap: 1.5rem;
	margin-block: 3rem;

	@media (min-width: 768px) {
		grid-template-columns: repeat(3, 1fr);
	}
}

.feature-box {
	background: var(--warm-cream);
	padding: 1.5rem;

	& h3 {
		font-family: var(--font-heading);
		font-size: 1rem;
		font-weight: 600;
		margin: 0 0 0.5rem;
	}

	& p {
		font-size: 0.9375rem;
		line-height: 1.6;
		margin: 0;
		color: #333;
	}

	& code {
		background: #fff;
		color: var(--burnt-orange);
		padding: 0.1em 0.3em;
		border-radius: 2px;
		font-size: 0.875em;
	}
}

/* Artifact Callouts */

.artifact-callouts {
	display: grid;
	gap: 1rem;
	margin-block: 2.5rem;
	grid-template-columns: repeat(2, 1fr);

	@media (min-width: 768px) {
		grid-template-columns: repeat(4, 1fr);
	}
}

.artifact-callouts--pair {
	margin-block: 1.5rem;

	@media (min-width: 768px) {
		grid-template-columns: repeat(2, 1fr);
	}
}

.artifact {
	display: block;
	padding: 1rem;
	border: 1px solid rgb(0 0 0 / 0.1);
	text-decoration: none;
	transition: border-color 0.2s;

	&:hover {
		border-color: var(--teal);
	}

	& strong {
		display: block;
		font-family: var(--font-heading);
		font-size: 1.125rem;
		font-weight: 600;
		color: #000;
	}

	& span {
		display: block;
		font-family: var(--font-mono);
		font-size: 0.875rem;
		color: #666;
		margin-block-start: 0.25rem;
	}
}

/* CTA Links */

.cta-links {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem 1.5rem;
	margin-block-start: 2.5rem;
}

/* Docs Layout */

.docs-page {
	max-width: var(--measure);
	margin-inline: auto;
	margin-block-start: calc(var(--nav-height) + 1.5rem);
	padding-inline: var(--page-padding);
	padding-block: 2rem;
	min-height: 80vh;

	@media (min-width: 75rem) {
		position: relative;
	}
}

/* Sidebar */

.sidebar {
	margin-block-end: 2rem;

	@media (min-width: 75rem) {
		position: absolute;
		inset-inline-start: calc(-13rem - 1rem);
		width: 13rem;
	}

	& h2 {
		font-size: 1rem;
		font-weight: 600;
	}

	& h2 + ul { margin-block: 0.25rem; }
	& h2:not(:first-child) { margin-block-start: 1rem; }

	& ul {
		list-style: none;
		padding-inline-start: 0.5rem;
		margin: 0;
	}

	& a {
		text-decoration: none;
		&:hover { text-decoration: underline; }
		&.active { color: #000; text-decoration: underline; }
	}
}

/* Docs Content */

.docs-content {
	font-size: 1.125rem;
	color: #000;

	& h1, & h2, & h3, & h4 {
		font-family: var(--font-heading);
		color: #000;
	}

	& h1 { font-size: 2rem; margin-block-end: 1rem; }
	& h2 { font-size: 1.75rem; font-weight: 700; margin-block-start: 3.5rem; margin-block-end: 1.25rem; }
	& h3 { font-size: 1.25rem; margin-block-start: 2rem; margin-block-end: 0.5rem; }

	& p {
		line-height: 1.8;
		margin-block-end: 1.25rem;
	}

	& a {
		color: var(--teal);
		text-decoration: underline;
		text-decoration-color: rgb(46 107 106 / 0.3);
		text-underline-offset: 3px;
		transition: text-decoration-color 0.2s;

		&:hover { text-decoration-color: var(--teal); }
	}

	& pre {
		background: var(--warm-cream);
		border: none;
		border-inline-start: 4px solid var(--lime);
		border-radius: 0;
		padding: 1.5rem;
		margin-block: 2rem;
		overflow-x: auto;
	}

	& pre code {
		color: #000;
		font-size: 0.875rem;
		line-height: 1.7;
		background: transparent;
	}

	& .hljs { background: transparent; color: #000; }
	& .hljs-string, & .hljs-number { color: var(--burnt-orange); }
	& .hljs-keyword, & .hljs-built_in { color: var(--teal); }
	& .hljs-attr { color: #8B6914; }
	& .hljs-comment { color: #8B7B6B; font-style: italic; }

	& :not(pre) > code {
		background: var(--warm-cream);
		color: var(--burnt-orange);
		padding: 0.15em 0.4em;
		border-radius: 2px;
		font-size: 0.875em;
	}

	& ul {
		margin-block: 1.25rem;
		padding-inline-start: 1.5rem;
		list-style: none;
	}

	& ul li {
		position: relative;
		padding-inline-start: 0.25rem;
	}

	& ul li::before {
		content: '';
		position: absolute;
		inset-inline-start: -1.1rem;
		top: 0.65em;
		width: 0.5rem;
		height: 0.5rem;
		background: var(--lime);
	}

	& ol {
		margin-block: 1.25rem;
		padding-inline-start: 1.5rem;
	}

	& li {
		line-height: 1.8;
		margin-block-end: 0.5rem;
	}

	& blockquote {
		border-inline-start: 3px solid var(--lime);
		margin-inline: 0;
		padding-inline-start: 1rem;
		color: #555;
		font-style: italic;
	}

	& img, & iframe { max-width: 100%; }
}

.video-embed {
	width: 100%;
	aspect-ratio: 16 / 9;
}

/* Embed Layout */

.embed-page {
	margin-block-start: var(--nav-height);
	height: calc(100vh - var(--nav-height));
}

.embed-frame {
	width: 100%;
	height: 100%;
	border: none;
}
