/* Single post typography overrides. Loaded after theme styles, no build required. */

.single-post-content {
	padding-top: clamp(6.5rem, 10vw, 8.5rem);
}

.thinking-post {
	max-width: 56rem;
}

.thinking-post-header {
	margin-bottom: 2rem;
	padding-bottom: 1.25rem;
	border-bottom: 1px solid var(--glass-border);
}

.thinking-post-header h1 {
	font-family: var(--font-display);
	font-size: clamp(2rem, 7vw, 5.25rem);
	line-height: 1.02;
	letter-spacing: -0.015em;
	text-wrap: balance;
	word-break: break-word;
	margin: 0 0 1rem;
}

.thinking-post-header .card-date {
	font-family: var(--font-mono);
	font-size: 0.75rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--graphite-600);
	margin: 0;
}

.thinking-post-body {
	color: var(--graphite-400);
	font-size: clamp(1rem, 1.7vw, 1.25rem);
	line-height: 1.75;
}

.thinking-post-body > * {
	margin-top: 0;
	margin-bottom: 1.5rem;
}

.thinking-post-body h2,
.thinking-post-body h3,
.thinking-post-body h4 {
	color: var(--mist-white);
	line-height: 1.15;
	letter-spacing: -0.01em;
	margin-top: 2.5rem;
	margin-bottom: 0.9rem;
}

.thinking-post-body h2 {
	font-size: clamp(1.45rem, 4.2vw, 2.4rem);
}

.thinking-post-body h3 {
	font-size: clamp(1.15rem, 3.2vw, 1.8rem);
}

.thinking-post-body a {
	color: var(--mist-white);
	text-decoration-color: var(--glow-blue-30);
	text-underline-offset: 0.16em;
}

.thinking-post-body a:hover {
	color: var(--glow-blue);
	text-decoration-color: var(--glow-blue);
}

.thinking-post-body ul,
.thinking-post-body ol {
	padding-left: 1.2em;
}

.thinking-post-body li + li {
	margin-top: 0.45rem;
}

.thinking-post-body blockquote {
	margin: 2rem 0;
	padding: 0.2rem 0 0.2rem 1rem;
	border-left: 2px solid var(--glow-blue-30);
	color: var(--mist-white);
	font-family: var(--font-serif);
	font-style: italic;
}

.thinking-post-body img {
	margin: 2rem auto;
	border-radius: 0.25rem;
}

@media (max-width: 767px) {
	.single-post-content {
		padding-top: 6rem;
	}

	.thinking-post {
		padding-left: 1rem;
		padding-right: 1rem;
	}

	.thinking-post-body {
		line-height: 1.7;
	}
}

body.admin-bar .single-post-content {
	padding-top: calc(clamp(6.5rem, 10vw, 8.5rem) + 32px);
}

@media (max-width: 782px) {
	body.admin-bar .single-post-content {
		padding-top: calc(6rem + 46px);
	}
}

/* Homepage interaction + low-copy emphasis (loaded after main theme CSS). */
.front-page .section-header p,
.front-page .studio-body p,
.front-page .contact-body {
	max-width: 30rem;
	font-size: 0.98rem;
	color: var(--graphite-400);
}

.front-page .studio-body {
	margin-bottom: 2.25rem;
}

.front-page .hero-words {
	gap: 1.25rem;
}

.front-page .hero-word {
	animation: whimsical-drift 7s ease-in-out infinite;
	will-change: transform, opacity;
}

.front-page .hero-word:nth-child(2) {
	animation-duration: 8.5s;
	animation-delay: 0.6s;
}

.front-page .hero-word:nth-child(3) {
	animation-duration: 6.8s;
	animation-delay: 1.2s;
}

.front-page .hero-word:nth-child(4) {
	animation-duration: 9.2s;
	animation-delay: 0.9s;
}

.front-page .principle-item {
	transition: transform 0.25s ease, border-color 0.25s ease;
}

.front-page .principle-item p {
	opacity: 0.76;
	transition: opacity 0.2s ease;
}

.front-page .principle-item:hover {
	transform: translateY(-3px);
	border-left-color: var(--glow-blue);
}

.front-page .principle-item:hover p {
	opacity: 1;
}

.front-page .capability-badge {
	transition: transform 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.front-page .capability-badge:hover {
	transform: translateY(-2px) scale(1.03);
	border-color: var(--glow-blue);
	color: var(--mist-white);
}

.front-page .thinking-card,
.front-page .project-card {
	transition: transform 0.25s ease, border-color 0.25s ease, background 0.25s ease;
}

.front-page .thinking-card:hover,
.front-page .project-card:hover {
	transform: translateY(-4px);
}

@keyframes whimsical-drift {
	0% { transform: translateY(0) rotate(0deg); }
	25% { transform: translateY(-4px) rotate(-0.6deg); }
	50% { transform: translateY(-1px) rotate(0.4deg); }
	75% { transform: translateY(-3px) rotate(-0.2deg); }
	100% { transform: translateY(0) rotate(0deg); }
}

@media (max-width: 767px) {
	.front-page .section-header p,
	.front-page .studio-body p,
	.front-page .contact-body {
		font-size: 0.92rem;
	}

	.front-page .hero-words {
		gap: 0.8rem;
	}
}

/* Ambient fractal layers beyond hero */
.front-page .studio-section,
.front-page .thinking-section {
	position: relative;
	isolation: isolate;
	overflow: hidden;
}

.front-page .ambient-fractal {
	position: absolute;
	inset: -14% -18%;
	pointer-events: none;
	z-index: 0;
	mix-blend-mode: screen;
	opacity: 0.65;
	filter: saturate(1.08);
}

.front-page .ambient-fractal .fractal-canvas-wrap {
	position: absolute;
	inset: 0;
}

.front-page .ambient-fractal .fractal-canvas {
	width: 100%;
	height: 100%;
}

.front-page .ambient-fractal-studio {
	mask-image: radial-gradient(circle at 20% 40%, rgba(0, 0, 0, 0.95) 0%, rgba(0, 0, 0, 0.35) 46%, transparent 78%);
	-webkit-mask-image: radial-gradient(circle at 20% 40%, rgba(0, 0, 0, 0.95) 0%, rgba(0, 0, 0, 0.35) 46%, transparent 78%);
}

.front-page .ambient-fractal-thinking {
	inset: -22% -16%;
	mask-image: radial-gradient(circle at 80% 30%, rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0.3) 44%, transparent 74%);
	-webkit-mask-image: radial-gradient(circle at 80% 30%, rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0.3) 44%, transparent 74%);
}

.front-page .studio-section > *:not(.ambient-fractal),
.front-page .thinking-section > *:not(.ambient-fractal) {
	position: relative;
	z-index: 1;
}

@media (max-width: 767px) {
	.front-page .ambient-fractal {
		inset: -30% -42%;
		opacity: 0.5;
	}

	.front-page .ambient-fractal-thinking {
		inset: -35% -48%;
	}
}
