/* ======================================================================
   Swatch · page chrome
   ====================================================================== */

.site-header {
	display: grid;
	grid-template-columns: auto 1fr;
	align-items: center;
	gap: var(--s-6);
	padding: var(--s-4) var(--gutter);
	border-bottom: 1px solid var(--border);
	position: sticky;
	top: 0;
	background: color-mix(in oklab, var(--bg) 88%, transparent);
	backdrop-filter: saturate(180%) blur(16px);
	-webkit-backdrop-filter: saturate(180%) blur(16px);
	z-index: 50;
	min-height: 56px;
}

.wordmark {
	display: inline-flex;
	align-items: baseline;
	gap: var(--s-2);
	border-bottom: 0 !important;
	color: var(--ink);
}
.wordmark__name {
	font-size: var(--fs-md);
	font-weight: 600;
	letter-spacing: -0.02em;
}
.wordmark__version {
	font-family: var(--font-mono);
	font-size: 0.6875rem;
	letter-spacing: 0;
	color: var(--ink-4);
	padding: 2px 6px;
	border: 1px solid var(--border);
	border-radius: 999px;
	transform: translateY(-1px);
}

.site-nav {
	justify-self: end;
	display: flex;
	align-items: center;
	gap: var(--s-5);
}
.site-nav a {
	font-size: var(--fs-sm);
	font-weight: 500;
	color: var(--ink-3);
	border-bottom: 0;
	padding: 6px 0;
	transition: color var(--dur) var(--ease);
}
.site-nav a:hover,
.site-nav a[aria-current="page"] {
	color: var(--ink);
}

.theme-toggle {
	width: 28px;
	height: 28px;
	border: 1px solid var(--border);
	border-radius: 999px;
	display: inline-grid;
	place-items: center;
	background: var(--bg);
	transition: border-color var(--dur) var(--ease),
		background var(--dur) var(--ease);
}
.theme-toggle:hover {
	border-color: var(--ink);
}
.theme-toggle__dot {
	display: block;
	width: 8px;
	height: 8px;
	border-radius: 999px;
	background: var(--ink);
	transition: background var(--dur) var(--ease);
}

/* Main ----------------------------------------------------------------- */
.site-main {
	flex: 1;
	width: 100%;
}

/* Footer --------------------------------------------------------------- */
.site-footer {
	margin-top: var(--s-9);
	padding: 0 var(--gutter) var(--s-7);
}
.site-footer__rule {
	height: 1px;
	background: var(--border);
	margin-bottom: var(--s-5);
}
.site-footer__row {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--s-5);
	flex-wrap: wrap;
	font-size: var(--fs-sm);
	color: var(--ink-4);
}
.site-footer a {
	color: var(--ink-4);
	border-bottom: 0;
}
.site-footer a:hover {
	color: var(--ink);
}

/* Toast ---------------------------------------------------------------- */
.toast {
	position: fixed;
	left: 50%;
	bottom: var(--s-6);
	transform: translate(-50%, 16px);
	background: var(--ink);
	color: var(--bg);
	padding: var(--s-2) var(--s-4);
	font-family: var(--font-mono);
	font-size: var(--fs-xs);
	border-radius: 999px;
	opacity: 0;
	pointer-events: none;
	transition: opacity var(--dur) var(--ease),
		transform var(--dur) var(--ease);
	z-index: 100;
	box-shadow: var(--shadow-2);
}
.toast.is-visible {
	opacity: 1;
	transform: translate(-50%, 0);
}

/* Reference layout ----------------------------------------------------- */
.reference-shell {
	display: grid;
	grid-template-columns: 15rem minmax(0, 1fr);
	gap: var(--s-8);
	max-width: var(--max-w);
	margin: 0 auto;
	padding: var(--s-8) var(--gutter) var(--s-9);
}

.reference-side {
	position: sticky;
	top: 5rem;
	align-self: start;
	max-height: calc(100dvh - 7rem);
	overflow-y: auto;
}
.reference-side h2 {
	font-family: var(--font-mono);
	font-size: var(--fs-xs);
	letter-spacing: var(--track-caps);
	text-transform: uppercase;
	color: var(--ink-4);
	margin: 0 0 var(--s-3);
	font-weight: 500;
}
.reference-side ol {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 2px;
}
.reference-side li { margin: 0; }
.reference-side a {
	display: block;
	border: 0;
	color: var(--ink-3);
	padding: var(--s-2) var(--s-3);
	font-size: var(--fs-sm);
	border-radius: var(--r-1);
	transition: color var(--dur) var(--ease),
		background var(--dur) var(--ease);
}
.reference-side a:hover {
	color: var(--ink);
	background: var(--surface);
}
.reference-side a[aria-current="page"] {
	color: var(--ink);
	background: var(--surface);
	font-weight: 500;
}

.reference-content {
	min-width: 0;
	max-width: 42rem;
}
.reference-content .reference-eyebrow {
	font-family: var(--font-mono);
	font-size: var(--fs-xs);
	letter-spacing: var(--track-caps);
	text-transform: uppercase;
	color: var(--ink-4);
	display: block;
	margin-bottom: var(--s-3);
}
.reference-content h1 {
	font-size: var(--fs-3xl);
	font-weight: 500;
	letter-spacing: -0.025em;
	margin-bottom: var(--s-6);
}
.reference-content h2 {
	font-size: var(--fs-xl);
	margin: var(--s-8) 0 var(--s-4);
	padding-top: var(--s-6);
	border-top: 1px solid var(--border);
}
.reference-content h2:first-of-type {
	border-top: 0;
	padding-top: 0;
	margin-top: var(--s-7);
}
.reference-content h3 {
	font-size: var(--fs-lg);
	margin: var(--s-6) 0 var(--s-3);
}
.reference-content .anchor {
	color: var(--ink);
	border-bottom: 0;
}
.reference-content .anchor:hover {
	color: var(--ink-3);
}

.reference-pager {
	margin-top: var(--s-9);
	padding-top: var(--s-5);
	border-top: 1px solid var(--border);
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--s-5);
}
.reference-pager a {
	border: 0;
	display: block;
	font-size: var(--fs-xs);
	color: var(--ink-4);
	font-family: var(--font-mono);
	text-transform: uppercase;
	letter-spacing: var(--track-caps);
}
.reference-pager a:hover strong {
	color: var(--ink-3);
}
.reference-pager strong {
	display: block;
	font-family: var(--font-sans);
	font-size: var(--fs-md);
	font-weight: 500;
	color: var(--ink);
	letter-spacing: -0.01em;
	text-transform: none;
	margin-top: var(--s-2);
	transition: color var(--dur) var(--ease);
}
.reference-pager .next {
	text-align: right;
}

@media (max-width: 900px) {
	.reference-shell {
		grid-template-columns: 1fr;
		gap: var(--s-5);
	}
	.reference-side {
		position: static;
		max-height: none;
		border-bottom: 1px solid var(--border);
		padding: 0 0 var(--s-5);
	}
}
