/* ── Typography ──────────────────────────────────────────────── */
html { font-size: 18px; }

body {
	font-family: var(--font-base);
	font-size: var(--text-base);
	font-weight: 400;
	line-height: 1.7;
	color: var(--color-text);
	background: var(--color-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* ── Headings ─────────────────────────────────────────────────── */
h1 { font-size: 2.444rem;        font-weight: 800; line-height: 1.15; letter-spacing: -0.025em; } /* ~44px */
h2 { font-size: 1.667rem;        font-weight: 700; line-height: 1.28; letter-spacing: -0.015em; } /* ~30px */
h3 { font-size: var(--text-xl);  font-weight: 600; line-height: 1.38; letter-spacing: -0.01em; }
h4 { font-size: var(--text-lg);  font-weight: 600; line-height: 1.45; }
h5 { font-size: var(--text-base);font-weight: 600; line-height: 1.5; }
h6 { font-size: var(--text-sm);  font-weight: 600; line-height: 1.5; text-transform: uppercase; letter-spacing: .06em; color: var(--color-text-muted); }

/* ── Body text ────────────────────────────────────────────────── */
p { margin-bottom: var(--space-5); }
p:last-child { margin-bottom: 0; }

a {
	color: var(--color-accent);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
	transition: color var(--trans-fast);
}
a:hover  { color: var(--color-accent-hover); }
a:visited { color: var(--color-accent-visited); }

strong, b { font-weight: 700; }
em, i      { font-style: italic; }
small      { font-size: var(--text-sm); }
mark       { background: var(--color-highlight); padding: 0 2px; border-radius: 2px; }

abbr[title] { cursor: help; text-decoration: underline dotted; }

/* ── Lists ────────────────────────────────────────────────────── */
.hsk-content ul,
.hsk-content ol {
	margin: 0 0 var(--space-5) var(--space-6);
}
.hsk-content ul { list-style: disc; }
.hsk-content ol { list-style: decimal; }
.hsk-content li { margin-bottom: var(--space-2); }

/* ── Blockquote ───────────────────────────────────────────────── */
.hsk-content blockquote {
	border-left: 3px solid var(--color-border-strong);
	margin: var(--space-6) 0;
	padding: var(--space-4) var(--space-6);
	color: var(--color-text-muted);
	font-style: italic;
}
.hsk-content blockquote p:last-child { margin-bottom: 0; }

/* ── Code ─────────────────────────────────────────────────────── */
code, kbd, samp {
	font-family: var(--font-mono);
	font-size: .85em;
	background: var(--color-bg-soft);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	padding: 1px 5px;
}
pre {
	font-family: var(--font-mono);
	font-size: .85em;
	background: var(--color-bg-soft);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: var(--space-5);
	overflow-x: auto;
	margin: 0 0 var(--space-5);
	line-height: 1.6;
}
pre code { background: none; border: none; padding: 0; font-size: 1em; }

/* ── Tables ───────────────────────────────────────────────────── */
.hsk-content table {
	width: 100%;
	border-collapse: collapse;
	font-size: var(--text-sm);
	margin: 0 0 var(--space-6);
}
.hsk-content th {
	background: var(--color-bg-soft);
	font-weight: 600;
	text-align: left;
	padding: var(--space-3) var(--space-4);
	border: 1px solid var(--color-border);
}
.hsk-content td {
	padding: var(--space-3) var(--space-4);
	border: 1px solid var(--color-border);
	vertical-align: top;
}
.hsk-content tr:nth-child(even) td { background: var(--color-bg-soft); }

/* ── HR ───────────────────────────────────────────────────────── */
.hsk-content hr {
	border: none;
	border-top: 1px solid var(--color-border);
	margin: var(--space-8) 0;
}

/* ── Images ───────────────────────────────────────────────────── */
.hsk-content img {
	max-width: 100%;
	height: auto;
	border-radius: var(--radius-md);
}

/* ── Article headings spacing ─────────────────────────────────── */
.hsk-article-body h2 { margin: var(--space-12) 0 var(--space-4); scroll-margin-top: 80px; }
.hsk-article-body h3 { margin: var(--space-8) 0 var(--space-3); scroll-margin-top: 80px; }
.hsk-article-body h4 { margin: var(--space-6) 0 var(--space-2); scroll-margin-top: 80px; }
.hsk-article-body h2:first-child,
.hsk-article-body h3:first-child { margin-top: 0; }
