:root {
	--fg: #f8f8f2;
	--fg-muted: #8a8fae;
	--bg: #15161b;
	--bg-alt: #1c1d26;
	--accent: #7dd3fc;
	--accent-fg: #15161b;
	--border: #2a2c39;
	--code-bg: #0b0b10;
	--code-fg: #f8f8f2;
	--st-idle: #6272a4;
	--st-init: #f1fa8c;
	--st-run: #50fa7b;
	--st-stopping: #ffb86c;
	--st-stopped: #383a4c;
	--st-error: #ff5555;
	--st-panic: #ff79c6;
	--mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
	--sans: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

* { box-sizing: border-box; }

html { font-family: var(--sans); color: var(--fg); background: var(--bg); }
body { margin: 0; line-height: 1.55; }

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

.site-header,
.site-footer {
	max-width: 1180px;
	margin: 0 auto;
	padding: 1rem 1.25rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}
.site-header { border-bottom: 1px solid var(--border); }
.site-footer { border-top: 1px solid var(--border); color: var(--fg-muted); font-size: 0.9rem; }

.brand { font-weight: 700; font-family: var(--mono); }
.site-header nav { display: flex; gap: 1rem; font-size: 0.95rem; }

.layout {
	max-width: 1180px;
	margin: 0 auto;
	padding: 1.5rem 1.25rem;
	display: grid;
	grid-template-columns: 220px minmax(0, 1fr);
	gap: 2rem;
}
main { min-width: 0; }

.sidebar { position: sticky; top: 1rem; align-self: start; font-size: 0.92rem; }
.sidebar .tree { list-style: none; padding: 0; margin: 0; }
.sidebar .tree li { line-height: 1.7; }
.sidebar .tree ul { list-style: none; padding-left: 0.9rem; margin: 0.1rem 0 0.4rem; border-left: 1px solid var(--border); }
.sidebar .tree a { color: var(--fg); display: block; padding: 0.05rem 0.4rem; border-radius: 3px; }
.sidebar .tree a:hover { background: var(--bg-alt); text-decoration: none; }
.sidebar .tree .section > a { font-family: var(--mono); font-weight: 600; }
.sidebar .tree ul li a { font-family: var(--mono); color: var(--fg-muted); }
.sidebar .tree ul li.active > a,
.sidebar .tree .section.active > a {
	color: var(--accent);
	background: var(--bg-alt);
}

@media (max-width: 720px) {
	.layout {
		grid-template-columns: 1fr;
		padding: 1rem;
	}
	.sidebar {
		position: static;
		padding-bottom: 0.5rem;
		border-bottom: 1px solid var(--border);
		margin-bottom: 0.5rem;
	}
	.sidebar .tree { display: flex; flex-wrap: wrap; gap: 0.25rem 0.75rem; }
	.sidebar .tree ul { padding-left: 0; border-left: none; display: flex; flex-wrap: wrap; gap: 0.25rem 0.5rem; }
}

.hero { text-align: left; padding: 0 0 2rem; }
.hero h1 { font-size: clamp(1.75rem, 4vw, 2.6rem); margin: 0 0 0.6rem; }
.hero .tagline { color: var(--fg-muted); max-width: 42rem; font-size: 1.05rem; }
.install { margin: 1.5rem 0; }
pre, code { font-family: var(--mono); }
pre { background: var(--code-bg); color: var(--code-fg); padding: 1rem 1.25rem; border-radius: 6px; overflow-x: auto; }
code { font-size: 0.95rem; }
.hero-links { margin-top: 1.25rem; display: flex; gap: 0.75rem; flex-wrap: wrap; }
.btn { display: inline-block; padding: 0.55rem 1rem; border-radius: 6px; background: var(--accent); color: var(--accent-fg); font-weight: 600; }
.btn:hover { text-decoration: none; filter: brightness(1.1); }
.btn-secondary { background: transparent; color: var(--accent); border: 1px solid var(--accent); }

.cards {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 1rem;
	margin-top: 2rem;
}
.card {
	background: var(--bg-alt);
	border: 1px solid var(--border);
	border-radius: 8px;
	padding: 1.25rem;
}
.card h2 { margin: 0 0 0.5rem; font-size: 1.15rem; }
.card p { margin: 0 0 0.75rem; color: var(--fg-muted); }
.card-status {
	display: inline-block;
	font-size: 0.8rem;
	font-family: var(--mono);
	color: var(--fg-muted);
	background: var(--bg);
	border: 1px dashed var(--border);
	padding: 0.15rem 0.5rem;
	border-radius: 999px;
}

.why { margin: 2rem 0; }
.why h2 { font-size: 1.4rem; margin: 0 0 0.4rem; }
.why .lead { color: var(--fg-muted); max-width: 48rem; margin: 0 0 1rem; }
.why-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.why-item {
	background: var(--bg-alt);
	border: 1px solid var(--border);
	border-radius: 8px;
	padding: 1rem 1.1rem;
}
.why-item h3 { margin: 0 0 0.4rem; font-size: 0.95rem; font-family: var(--mono); color: var(--accent); }
.why-item p { margin: 0; color: var(--fg-muted); font-size: 0.9rem; line-height: 1.55; }
.why-item code { color: var(--fg); background: var(--bg); padding: 0.05rem 0.3rem; border-radius: 3px; font-size: 0.9em; }

@media (max-width: 720px) {
	.why-grid { grid-template-columns: 1fr; }
}

.example { margin: 2.5rem 0 1rem; }
.example h2 { font-size: 1.4rem; margin: 0 0 0.4rem; }
.example .lead { color: var(--fg-muted); max-width: 48rem; margin: 0 0 1rem; }
.example .lead code { color: var(--fg); background: var(--bg-alt); padding: 0.05rem 0.3rem; border-radius: 3px; font-size: 0.9em; }

/* All chroma blocks share the same background; specific contexts adjust padding. */
body .chroma {
	background: var(--code-bg);
	color: var(--code-fg);
	border-radius: 6px;
	padding: 1rem 1.25rem;
	overflow-x: auto;
	font-size: 0.85rem;
	line-height: 1.55;
}

/* Package and catalog pages */

.page-head { margin: 0 0 1.5rem; }
.page-head h1 { font-family: var(--mono); font-size: 1.6rem; margin: 0.3rem 0 0.4rem; word-break: break-all; }
.page-head .tagline { color: var(--fg-muted); margin: 0; }
.crumbs { color: var(--fg-muted); font-size: 0.9rem; margin: 0 0 0.3rem; }
.meta { font-size: 0.9rem; color: var(--fg-muted); display: flex; flex-wrap: wrap; gap: 0.75rem; align-items: center; margin: 0.5rem 0; }
.tag { background: var(--bg-alt); border: 1px solid var(--border); padding: 0.1rem 0.5rem; border-radius: 4px; }
.meta-link { font-family: var(--mono); }

.tag-picker { display: inline-flex; align-items: center; gap: 0.4rem; }
.tag-picker label { font-size: 0.85rem; }
.tag-picker select {
	font-family: var(--mono);
	font-size: 0.85rem;
	color: var(--fg);
	background: var(--bg-alt);
	border: 1px solid var(--border);
	border-radius: 4px;
	padding: 0.15rem 0.4rem;
}

.doc-block { margin: 2rem 0; }
.doc-block > h2 {
	font-size: 1.15rem;
	font-family: var(--mono);
	border-bottom: 1px solid var(--border);
	padding-bottom: 0.3rem;
	margin: 0 0 1rem;
}
.doc-block p { margin: 0.5rem 0; }
.doc-block ol, .doc-block ul { padding-left: 1.4rem; }
.doc-block li { margin: 0.2rem 0; }

.decl { margin: 1.2rem 0; padding: 0.6rem 0; border-top: 1px solid var(--border); }
.decl:first-child { border-top: none; padding-top: 0; }
.decl h3 { font-family: var(--mono); font-size: 1rem; margin: 0 0 0.5rem; }
.decl h4 { font-family: var(--mono); font-size: 0.95rem; margin: 0.8rem 0 0.4rem; color: var(--fg-muted); }
.sig .chroma {
	padding: 0.5rem 0.75rem;
	border-radius: 4px;
}
.method { margin-left: 1rem; padding-left: 0.75rem; border-left: 2px solid var(--border); border-top: none; }

.doc-block .example { margin: 1.2rem 0; }
.doc-block .example h3 { font-family: var(--mono); font-size: 1rem; margin: 0 0 0.5rem; }

.readme h1, .readme h2, .readme h3 { font-family: var(--sans); }
.readme img { max-width: 100%; }
.readme pre { font-size: 0.9rem; }
.readme :not(pre) > code { background: var(--bg-alt); padding: 0.05rem 0.3rem; border-radius: 3px; font-size: 0.9em; }
