/* Single post patterns
---------------------------------------------------------------------------- */

.single-post .cn-post-byline {
	align-items: flex-start;
	color: var(--cn-text-muted);
	display: flex;
	gap: 0.875rem;
	margin-top: clamp(0.75rem, 2vw, 1rem);
	max-width: min(100%, 44rem);
}

.single-post .cn-post-byline__avatar {
	background: var(--cn-bg-muted);
	border: 1px solid var(--cn-border);
	border-radius: 999px;
	flex: 0 0 auto;
	height: 3.25rem;
	overflow: hidden;
	width: 3.25rem;
}

.single-post .cn-post-byline__avatar img {
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.single-post .cn-post-byline__body {
	display: grid;
	gap: 0.25rem;
	min-width: 0;
}

.single-post .cn-post-byline__meta {
	align-items: center;
	color: var(--cn-text-muted);
	display: flex;
	flex-wrap: wrap;
	font-size: 0.92rem;
	font-weight: 620;
	gap: 0.35rem;
	line-height: 1.35;
}

.single-post .cn-post-byline__author {
	color: var(--cn-text);
	font-style: normal;
	margin: 0;
}

.single-post .cn-post-byline__author-link {
	color: inherit;
	text-decoration: none;
}

.single-post .cn-post-byline__author-link:hover,
.single-post .cn-post-byline__author-link:focus-visible {
	color: var(--cn-accent);
	text-decoration: underline;
	text-decoration-thickness: 0.08em;
	text-underline-offset: 0.18em;
}

.single-post .cn-post-byline__separator {
	color: var(--cn-text-muted);
}

.single-post .cn-post-byline__role {
	color: var(--cn-accent);
	font-family: var(--cn-font-mono);
	font-size: 0.78rem;
	font-weight: 650;
	line-height: 1.25;
	margin: 0;
	text-transform: uppercase;
}

.single-post .cn-post-byline__description {
	color: var(--cn-text-muted);
	font-size: 0.9rem;
	line-height: 1.55;
	margin: 0.05rem 0 0;
	max-width: 42rem;
}

.single-post .cn-post-toc {
	border-block: 1px solid var(--cn-border);
	color: var(--cn-text);
	margin: clamp(1.5rem, 4vw, 3rem) auto clamp(2rem, 5vw, 4rem);
	max-width: var(--wp--style--global--wide-size);
	padding-block: clamp(1.25rem, 3vw, 2rem);
	width: min(100%, calc(100vw - 2.5rem));
}

.single-post .cn-post-toc[hidden] {
	display: none;
}

.single-post .cn-post-toc__label {
	color: var(--cn-text-muted);
	font-family: var(--cn-font-mono);
	font-size: 0.8125rem;
	font-weight: 650;
	letter-spacing: 0;
	line-height: 1.2;
	margin: 0 0 1rem;
	text-transform: uppercase;
}

.single-post .cn-post-toc__list {
	counter-reset: cn-post-toc;
	display: grid;
	gap: 0.65rem 1.5rem;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	list-style: none;
	margin: 0;
	padding: 0;
}

.single-post .cn-post-toc__list li {
	counter-increment: cn-post-toc;
	margin: 0;
}

.single-post .cn-post-toc__list a {
	align-items: baseline;
	color: var(--cn-text);
	display: grid;
	font-size: clamp(0.95rem, 1.4vw, 1.05rem);
	font-weight: 520;
	gap: 0.75rem;
	grid-template-columns: 2ch minmax(0, 1fr);
	line-height: 1.35;
	text-decoration: none;
}

.single-post .cn-post-toc__list a::before {
	color: var(--cn-text-muted);
	content: counter(cn-post-toc, decimal-leading-zero);
	font-family: var(--cn-font-mono);
	font-size: 0.78em;
	font-weight: 650;
}

.single-post .cn-post-toc__list a:hover,
.single-post .cn-post-toc__list a:focus-visible {
	color: var(--cn-accent);
}

.single-post .cn-post-content h2 {
	scroll-margin-top: calc(var(--cn-header-height, 5rem) + 1.5rem);
}

@media (max-width: 700px) {
	.single-post .cn-post-byline {
		gap: 0.75rem;
	}

	.single-post .cn-post-byline__avatar {
		height: 2.75rem;
		width: 2.75rem;
	}

	.single-post .cn-post-byline__description {
		font-size: 0.875rem;
	}

	.single-post .cn-post-toc__list {
		grid-template-columns: 1fr;
	}
}
