/* Dark theme */
.dark {
	--bg-color: #1e1f34;
	--text-color: #fff;
	--border-color: #ffffff33;
	--code-bg: #16172a;
	--cell-bg: #262840;
	--link-color: hsl(219, 85%, 72%);
}

/* Light theme */
.light {
	--bg-color: #f5f5f7;
	--text-color: #1a1a1a;
	--border-color: #00000022;
	--code-bg: #e8e8ec;
	--cell-bg: #ffffff;
	--link-color: hsl(219, 85%, 48%);
}

body {
	font-family: Poppins, sans-serif;
	background-color: var(--bg-color);
	color: var(--text-color);
	padding: 24px 32px;
	margin: 0;
}

h1 {
	margin-bottom: 4px;
}

h2 {
	border-top: 1px solid var(--border-color);
	padding-top: 20px;
	margin-top: 32px;
}

h3 {
	margin-bottom: 8px;
}

.subtitle {
	margin-top: 0;
	opacity: 0.6;
	font-size: 0.95rem;
}

.grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(420px, 1fr));
	gap: 24px;
	margin-top: 16px;
}

.cell {
	background: var(--cell-bg);
	border-radius: 12px;
	padding: 16px;
}

canvas {
	width: 100% !important;
	max-height: 320px;
}

pre {
	background: var(--code-bg);
	border-radius: 8px;
	padding: 12px 16px;
	font-size: 0.82rem;
	overflow-x: auto;
	line-height: 1.5;
}

.color-row {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	margin: 12px 0;
}

.swatch {
	width: 48px;
	height: 48px;
	border-radius: 8px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 0.7rem;
	font-weight: 600;
	color: #fff;
	text-shadow: 0 0 2px rgba(0, 0, 0, 0.65);
}

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