/**
 * Single post / insight layout.
 *
 * Tokens come from theme.json — palette presets (`--wp--preset--color--*`),
 * custom colours (`--wp--custom--color--*`), layout widths
 * (`--wp--custom--layout--*`), spacing (`--wp--preset--spacing--*`),
 * font sizes (`--wp--preset--font-size--*`), radii (`--wp--custom--border--radius--*`),
 * line-heights (`--wp--custom--line-height--*`).
 *
 * Scope: `.single-post` article wrapper + its descendants. `.wrap`,
 * `.page-hero`, `.eyebrow`, `.bar`, `.lede`, `.card`, and `.btn-pill`
 * live in main.css — this file only adds post-specific composition.
 */

/* -------------------------------------------------------------------------- */
/*  Hero — single-post variant                                                */
/* -------------------------------------------------------------------------- */

.page-hero--post h1 {
	font-size: var(--wp--preset--font-size--colossal);
	letter-spacing: -0.02em;
	line-height: var(--wp--custom--line-height--tiny);
	max-width: 22ch;
}

.page-hero--post .post-hero-nav {
	margin-bottom: var(--wp--preset--spacing--medium);
}

.page-hero--post .post-hero-nav .back {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: var(--wp--preset--font-size--tiny);
	font-weight: 500;
	color: var(--i-ink-soft);
	text-decoration: none;
	transition: color 0.2s ease;
}

.page-hero--post .post-hero-nav .back:hover {
	color: var(--i-pink);
}

.page-hero--post .post-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px;
	font-size: var(--wp--preset--font-size--tiny);
	color: var(--i-ink-soft);
	margin-bottom: var(--wp--preset--spacing--medium);
}

.page-hero--post .post-meta-author {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	color: var(--i-ink);
	font-weight: 500;
}

.page-hero--post .post-meta-author a {
	color: inherit;
	text-decoration: none;
}

.page-hero--post .post-meta-author a:hover {
	color: var(--i-pink);
}

.page-hero--post .post-meta-avatar {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	object-fit: cover;
}

.page-hero--post .post-meta-sep {
	color: var(--i-line);
}

/* Share row — anatomy lives in main.css `.btn-pill`; only the copied-state
   override is post-specific. */

.page-hero--post .post-share {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--wp--preset--spacing--tiny);
}

.page-hero--post .post-share-btn.is-copied {
	border-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--primary);
}

/* -------------------------------------------------------------------------- */
/*  Featured image                                                            */
/* -------------------------------------------------------------------------- */

.single-post .post-featured {
}

.single-post .post-featured .wrap {
	max-width: var(--wp--custom--layout--wide);
	margin-top: calc(var(--wp--preset--spacing--x-large) * -1);
}

.single-post .post-featured-figure {
	position: relative;
	aspect-ratio: 21 / 9;
	border-radius: var(--wp--custom--border--radius--medium);
	overflow: hidden;
	margin: 0;
	background: var(--wp--preset--color--grey);
}

.single-post .post-featured-img,
.single-post .post-featured-figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}

.single-post .post-featured-stripes {
	position: absolute;
	inset: 0;
	pointer-events: none;
	opacity: 0.08;
	background-image: repeating-linear-gradient(
		45deg,
		var(--wp--preset--color--white) 0,
		var(--wp--preset--color--white) 2px,
		transparent 2px,
		transparent 10px
	);
}

.single-post .post-featured-tint {
	position: absolute;
	inset: 0;
	pointer-events: none;
	opacity: 0.15;
	mix-blend-mode: multiply;
	background: var(--wp--preset--color--primary);
}

/* -------------------------------------------------------------------------- */
/*  Body + sidebar                                                            */
/* -------------------------------------------------------------------------- */

.single-post .post-body {
	padding-block: var(--wp--preset--spacing--x-large);
	background: var(--wp--preset--color--white);
}

.single-post .post-body-grid {
	display: grid;
	grid-template-columns: minmax(0, 1fr);
	gap: var(--wp--preset--spacing--x-large);
	max-width: var(--wp--custom--layout--small-content);
	margin-inline: auto;
}

.single-post .post-body-grid--has-sidebar {
	grid-template-columns: minmax(0, 1fr) var(--wp--custom--layout--sidebar);
	max-width: var(--wp--custom--layout--content);
}

.single-post .post-body-content {
	min-width: 0;
	font-size: var(--wp--preset--font-size--normal);
	line-height: var(--wp--custom--line-height--loose);
	color: var(--wp--preset--color--charcoal);
}

.single-post .post-body-content > *:first-child {margin-top:0;}

.single-post .post-body-content > * + * {
	margin-top: 1.1em;
}

.single-post .post-body-content h2 {
	font-size: var(--wp--preset--font-size--big);
	font-weight: 600;
	line-height: var(--wp--custom--line-height--small);
	margin-top: 2em;
	margin-bottom: 0.4em;
	color: var(--wp--preset--color--charcoal);
}

.single-post .post-body-content h3 {
	font-size: var(--wp--preset--font-size--large);
	font-weight: 600;
	line-height: var(--wp--custom--line-height--tight);
	margin-top: 1.8em;
	margin-bottom: 0.4em;
}

.single-post .post-body-content a {
	color: var(--wp--preset--color--primary);
	text-decoration: underline;
	text-underline-offset: 2px;
}

.single-post .post-body-content blockquote {
	margin-inline: 0;
	padding: var(--wp--preset--spacing--small) var(--wp--preset--spacing--medium);
	border-left: 4px solid var(--wp--preset--color--primary);
	background: var(--wp--preset--color--tertiary-50);
	border-radius: 0 var(--wp--custom--border--radius--small) var(--wp--custom--border--radius--small) 0;
	font-style: italic;
}

.single-post .post-tags {
	margin-top: var(--wp--preset--spacing--large);
	display: flex;
	flex-wrap: wrap;
	gap: var(--wp--preset--spacing--tiny);
}

.single-post .post-tag {
	display: inline-flex;
	align-items: center;
	padding: 6px 12px;
	border-radius: var(--wp--custom--border--radius--pill);
	background: var(--wp--preset--color--tertiary-50);
	color: var(--wp--preset--color--charcoal);
	font-size: var(--wp--preset--font-size--min);
	text-decoration: none;
	transition: all 0.2s ease;
}

.single-post .post-tag:hover {
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--white);
}

/* Sidebar rail */

.single-post .post-sidebar {
	min-width: 0;
}

.single-post .post-sidebar-inner {
	position: sticky;
	top: calc(var(--site-header-h) + var(--wp--preset--spacing--small));
}

.single-post .post-sidebar-inner .block-area > :first-child {
	margin-top: 0;
}

.single-post .post-sidebar-inner .block-area > :last-child {
	margin-bottom: 0;
}

.single-post .post-sidebar-inner .wp-block-latest-posts li {
	position: relative;
	padding: 3px 0 0 23px;
}

.single-post .post-sidebar-inner .wp-block-latest-posts li::before {
	content: "";
	position: absolute;
	left: -10px;
	top: 5px;
	border: 2px solid color-mix(in srgb, var(--wp--preset--color--tertiary) 25%, transparent);
	width: 22px;
	height: 22px;
	border-radius: 50%;
}

.single-post .post-sidebar-inner .wp-block-latest-posts li::after {
	content: "";
	position: absolute;
	left: -2px;
	top: 13px;
	background: var(--wp--preset--color--tertiary);
	width: 6px;
	height: 6px;
	border-radius: 50%;
}

/* -------------------------------------------------------------------------- */
/*  Author card                                                               */
/* -------------------------------------------------------------------------- */

.single-post .post-author-card {
	padding-block: 0 var(--wp--preset--spacing--x-large);
	background: var(--wp--preset--color--white);
}

.single-post .post-author-inner {
	position: relative;
	display: grid;
	grid-template-columns: 160px minmax(0, 1fr);
	gap: var(--wp--preset--spacing--medium);
	align-items: center;
	padding: var(--wp--preset--spacing--large);
	border-radius: var(--wp--custom--border--radius--medium);
	background: var(--wp--preset--color--charcoal);
	color: var(--wp--preset--color--white);
	overflow: hidden;
	isolation: isolate;
}

.single-post .post-author-inner::before,
.single-post .post-author-inner::after {
	content: "";
	position: absolute;
	width: 320px;
	height: 320px;
	border-radius: 50%;
	filter: blur(80px);
	pointer-events: none;
	z-index: -1;
}

.single-post .post-author-inner::before {
	top: -160px;
	right: -120px;
	background: var(--wp--preset--color--primary);
	opacity: 0.3;
}

.single-post .post-author-inner::after {
	bottom: -180px;
	left: -100px;
	background: var(--wp--preset--color--secondary);
	opacity: 0.18;
}

.single-post .post-author-avatar img {
	width: 160px;
	height: 160px;
	border-radius: 50%;
	object-fit: cover;
	display: block;
	border: 3px solid var(--wp--custom--color--ink-line);
}

.single-post .post-author-body .eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-family: var(--wp--preset--font-family--mono);
	font-size: var(--wp--preset--font-size--min);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--wp--preset--color--secondary);
	margin-bottom: 12px;
}

.single-post .post-author-body .eyebrow .bar {
	width: 28px;
	height: 3px;
	background: var(--wp--preset--color--secondary);
	border-radius: 2px;
}

.single-post .post-author-name {
	font-size: var(--wp--preset--font-size--big);
	margin: 0 0 var(--wp--preset--spacing--tiny);
	color: var(--wp--preset--color--white);
}

.single-post .post-author-bio {
	font-size: var(--wp--preset--font-size--normal);
	line-height: var(--wp--custom--line-height--normal);
	color: var(--wp--custom--color--ink-text-soft);
	margin: 0 0 var(--wp--preset--spacing--small);
	max-width: 60ch;
}

.single-post .post-author-link {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	color: var(--wp--preset--color--secondary);
	text-decoration: none;
	font-weight: 500;
	font-size: var(--wp--preset--font-size--tiny);
}

.single-post .post-author-link:hover {
	text-decoration: underline;
}

/* -------------------------------------------------------------------------- */
/*  Related posts                                                             */
/* -------------------------------------------------------------------------- */

.single-post .post-related {
	padding-block: var(--wp--preset--spacing--x-large);
	background: var(--wp--preset--color--tertiary-50);
}

.single-post .post-related-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	font-family: var(--wp--preset--font-family--mono);
	font-size: var(--wp--preset--font-size--min);
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--wp--preset--color--charcoal);
	margin-bottom: 12px;
}

.single-post .post-related-eyebrow .bar {
	width: 32px;
	height: 3px;
	background: var(--wp--preset--color--primary);
	border-radius: 2px;
}

.single-post .post-related-heading {
	font-size: var(--wp--preset--font-size--huge);
	font-weight: 600;
	line-height: var(--wp--custom--line-height--snug);
	margin: 0 0 var(--wp--preset--spacing--medium);
	color: var(--wp--preset--color--charcoal);
}

/* Related-posts grid uses the shared .card / .card.type-post anatomy from
   main.css — this file only owns the container layout. */
.single-post .post-related-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--wp--preset--spacing--medium);
}

.single-post .post-related-grid .card-badge {
	position: absolute;
	top: 12px;
	left: 12px;
}

/* -------------------------------------------------------------------------- */
/*  Entry footer (after-post block area)                                      */
/* -------------------------------------------------------------------------- */

.single-post > .entry-footer:empty {
	display: none;
}

.single-post > .entry-footer .block-area-after-post {
	padding-block: var(--wp--preset--spacing--x-large);
}

/* -------------------------------------------------------------------------- */
/*  Responsive                                                                */
/* -------------------------------------------------------------------------- */

@media (max-width: 1024px) {
	.single-post .post-body-grid--has-sidebar {
		grid-template-columns: minmax(0, 1fr);
	}

	.single-post .post-sidebar-inner {
		position: static;
	}

	.single-post .post-related-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 720px) {
	.single-post .post-author-inner {
		grid-template-columns: minmax(0, 1fr);
		text-align: left;
	}

	.single-post .post-author-avatar img {
		width: 96px;
		height: 96px;
	}

	.single-post .post-related-grid {
		grid-template-columns: minmax(0, 1fr);
	}

	.page-hero--post h1 {
		max-width: none;
	}
}
