*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	background: oklch(0.955 0.01 82);
	color: oklch(0.22 0.024 48);
	font-family: "MHBody", sans-serif;
}

a {
	color: inherit;
}

img {
	max-width: 100%;
	height: auto;
}

.ast-container {
	width: min(1120px, calc(100% - 32px));
	margin: 0 auto;
}

.site-header {
	position: sticky;
	top: 0;
	z-index: 20;
	background: oklch(0.985 0.008 82 / 0.86);
	border-bottom: 1px solid oklch(0.72 0.018 74 / 0.5);
	backdrop-filter: blur(16px);
}

.site-header-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	min-height: 72px;
}

.site-brand {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-weight: 700;
	text-decoration: none;
}

.site-brand img {
	display: block;
	width: 110px;
	height: auto;
}

.site-nav {
	display: flex;
	align-items: center;
	gap: 18px;
}

.site-nav a {
	font-size: 0.94rem;
	font-weight: 700;
	text-decoration: none;
	color: oklch(0.39 0.018 48);
}

.site-nav a:hover {
	color: oklch(0.22 0.024 48);
}

.not-found-page {
	display: grid;
	min-height: 100vh;
	place-items: center;
	padding: 24px;
	background:
		linear-gradient(145deg, oklch(0.23 0.025 49) 0%, oklch(0.29 0.03 63) 100%);
}

.not-found-main {
	display: grid;
	gap: 18px;
	width: min(620px, 100%);
	padding: 32px;
	border: 1px solid oklch(0.96 0.015 78 / 0.2);
	border-radius: 24px;
	color: oklch(0.965 0.01 82);
	background: oklch(0.965 0.01 82 / 0.08);
	box-shadow: 0 28px 80px oklch(0.19 0.015 40 / 0.28);
}

.not-found-main h1 {
	margin: 0;
	font-family: "MHDisplay", serif;
	font-size: 2.6rem;
	line-height: 1.08;
	letter-spacing: 0;
}

.not-found-main p {
	margin: 0;
	line-height: 1.8;
}

@font-face {
	font-family: "MHDisplay";
	src:
		local("Source Han Serif SC"),
		local("Noto Serif CJK SC"),
		local("Songti SC"),
		local("STZhongsong"),
		local("SimSun");
	font-display: swap;
}

@font-face {
	font-family: "MHBody";
	src:
		local("HarmonyOS Sans SC"),
		local("Source Han Sans SC"),
		local("Noto Sans CJK SC"),
		local("PingFang SC"),
		local("Microsoft YaHei");
	font-display: swap;
}

.mh-front-page-main {
	padding-top: clamp(20px, 3vw, 40px);
	padding-bottom: 0;
	background:
		radial-gradient(circle at top left, oklch(0.96 0.02 88) 0, transparent 34%),
		radial-gradient(circle at top right, oklch(0.94 0.03 38 / 0.48) 0, transparent 28%),
		linear-gradient(180deg, oklch(0.985 0.008 82) 0%, oklch(0.955 0.01 82) 58%, oklch(0.905 0.015 70) 100%);
}

.mh-home-wrap,
.mh-home-wrap * {
	box-sizing: border-box;
}

.mh-home-wrap {
	--mh-space-2xs: 4px;
	--mh-space-xs: 8px;
	--mh-space-sm: 12px;
	--mh-space-md: 16px;
	--mh-space-lg: 24px;
	--mh-space-xl: 32px;
	--mh-space-2xl: 48px;
	--mh-space-3xl: 64px;
	--mh-space-4xl: 96px;
	--mh-paper: oklch(0.985 0.008 82);
	--mh-paper-strong: oklch(0.955 0.013 78);
	--mh-paper-muted: oklch(0.926 0.012 82);
	--mh-ink: oklch(0.22 0.024 48);
	--mh-ink-soft: oklch(0.39 0.018 48);
	--mh-line: oklch(0.72 0.018 74 / 0.68);
	--mh-accent: oklch(0.61 0.13 41);
	--mh-accent-deep: oklch(0.42 0.084 38);
	--mh-olive: oklch(0.78 0.048 123);
	--mh-night: oklch(0.25 0.022 48);
	--mh-night-soft: oklch(0.33 0.024 60);
	--mh-shadow-soft: 0 18px 48px oklch(0.31 0.02 45 / 0.09);
	--mh-shadow-deep: 0 28px 80px oklch(0.19 0.015 40 / 0.18);
	--mh-radius-lg: 32px;
	--mh-radius-md: 24px;
	--mh-radius-sm: 18px;
	--mh-light-ink: oklch(0.965 0.01 82);
	position: relative;
	width: 100%;
	color: var(--mh-ink);
	font-family: "MHBody", sans-serif;
	container-type: inline-size;
}

.mh-home-wrap::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(to right, color-mix(in oklab, var(--mh-line) 34%, transparent) 1px, transparent 1px),
		linear-gradient(to bottom, color-mix(in oklab, var(--mh-line) 24%, transparent) 1px, transparent 1px);
	background-size: 100px 100px;
	opacity: 0.26;
	pointer-events: none;
	mask-image: linear-gradient(180deg, transparent 0%, #000 8%, #000 88%, transparent 100%);
}

.mh-home-wrap > * {
	position: relative;
	z-index: 1;
}

.mh-home-hero,
.mh-home-ribbon,
.mh-home-split,
.mh-home-projects,
.mh-home-section,
.mh-home-editorial,
.mh-home-contact,
.mh-bottom-footer {
	animation: mh-rise 720ms cubic-bezier(0.16, 1, 0.3, 1) both;
}

.mh-home-ribbon {
	animation-delay: 80ms;
}

.mh-home-split {
	animation-delay: 140ms;
}

.mh-home-projects {
	animation-delay: 180ms;
}

.mh-home-section {
	animation-delay: 220ms;
}

.mh-home-editorial {
	animation-delay: 300ms;
}

.mh-home-contact,
.mh-bottom-footer {
	animation-delay: 380ms;
}

.mh-home-hero {
	position: relative;
	display: grid;
	grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.9fr);
	gap: var(--mh-space-xl);
	padding: clamp(32px, 5vw, 56px);
	border-radius: var(--mh-radius-lg);
	background:
		radial-gradient(circle at top right, oklch(0.48 0.08 46 / 0.5) 0, transparent 30%),
		linear-gradient(145deg, oklch(0.23 0.025 49) 0%, oklch(0.29 0.03 63) 100%);
	box-shadow: var(--mh-shadow-deep);
	overflow: hidden;
}

.mh-home-hero::before,
.mh-home-hero::after {
	content: "";
	position: absolute;
	pointer-events: none;
}

.mh-home-hero::before {
	inset: 0;
	background:
		linear-gradient(120deg, transparent 0 55%, color-mix(in oklab, var(--mh-accent) 28%, transparent) 55% 57%, transparent 57% 100%),
		linear-gradient(180deg, transparent 0 78%, color-mix(in oklab, var(--mh-light-ink) 12%, transparent) 78% 79%, transparent 79% 100%);
	opacity: 0.5;
}

.mh-home-hero::after {
	width: 240px;
	height: 240px;
	right: -88px;
	bottom: -92px;
	border-radius: 50%;
	background: color-mix(in oklab, var(--mh-accent) 44%, transparent);
	filter: blur(6px);
	opacity: 0.34;
}

.mh-home-hero-copy {
	display: grid;
	align-content: start;
	gap: var(--mh-space-lg);
	max-width: 48rem;
	color: oklch(0.955 0.012 82);
}

.mh-home-kicker,
.mh-home-section-tag,
.mh-home-note-label,
.mh-home-aside-label {
	margin: 0;
	font-size: 0.78rem;
	letter-spacing: 0;
	text-transform: uppercase;
}

.mh-home-kicker {
	color: color-mix(in oklab, var(--mh-light-ink) 72%, var(--mh-accent));
}

.mh-home-section-tag,
.mh-home-note-label {
	color: color-mix(in oklab, var(--mh-accent-deep) 78%, var(--mh-ink));
}

.mh-home-aside-label {
	color: color-mix(in oklab, var(--mh-light-ink) 64%, var(--mh-accent));
}

.mh-home-title {
	margin: 0;
	max-width: 10ch;
	font-family: "MHDisplay", serif;
	font-size: 5.1rem;
	line-height: 1.04;
	letter-spacing: 0;
	color: oklch(0.98 0.008 82);
	text-wrap: balance;
}

.mh-home-lead {
	margin: 0;
	max-width: 38rem;
	font-size: 1.08rem;
	line-height: 1.92;
	color: color-mix(in oklab, var(--mh-light-ink) 82%, var(--mh-accent));
}

.mh-home-actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--mh-space-md);
}

.mh-home-btn,
.mh-home-inline-link {
	transition:
		transform 220ms cubic-bezier(0.16, 1, 0.3, 1),
		background-color 220ms ease,
		border-color 220ms ease,
		color 220ms ease,
		box-shadow 220ms ease;
}

.mh-home-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 52px;
	padding: 13px 22px;
	border-radius: 999px;
	border: 1px solid transparent;
	font-size: 0.95rem;
	font-weight: 700;
	text-decoration: none;
}

.mh-home-btn:hover,
.mh-home-inline-link:hover {
	transform: translateY(-2px);
}

.mh-home-btn:focus-visible,
.mh-home-inline-link:focus-visible,
.mh-contact-trigger:focus-visible,
.mh-bottom-footer-links a:focus-visible {
	outline: 2px solid color-mix(in oklab, var(--mh-accent) 82%, var(--mh-paper));
	outline-offset: 3px;
}

.mh-home-btn-primary {
	background: oklch(0.96 0.015 78);
	color: var(--mh-night);
	box-shadow: 0 10px 26px oklch(0.16 0.01 42 / 0.18);
}

.mh-home-btn-primary:hover {
	background: oklch(0.985 0.01 80);
}

.mh-home-btn-secondary {
	border-color: color-mix(in oklab, var(--mh-light-ink) 16%, transparent);
	background: color-mix(in oklab, var(--mh-night-soft) 52%, transparent);
	color: oklch(0.955 0.01 82);
}

.mh-home-btn-secondary:hover {
	background: color-mix(in oklab, var(--mh-light-ink) 8%, var(--mh-night-soft));
}

.mh-home-hero-aside {
	display: grid;
	align-content: start;
	gap: var(--mh-space-md);
}

.mh-home-aside-card,
.mh-home-aside-meta,
.mh-home-featured,
.mh-home-manifesto,
.mh-home-track,
.mh-home-note,
.mh-home-contact-panel {
	border: 1px solid var(--mh-line);
	box-shadow: var(--mh-shadow-soft);
}

.mh-home-aside-card {
	padding: var(--mh-space-xl);
	border-radius: 28px 28px 22px 22px;
	background:
		linear-gradient(180deg, color-mix(in oklab, var(--mh-light-ink) 10%, transparent) 0%, transparent 100%),
		oklch(0.95 0.015 82 / 0.08);
	color: oklch(0.95 0.01 82);
}

.mh-home-aside-card h2 {
	margin: var(--mh-space-sm) 0;
	font-family: "MHDisplay", serif;
	font-size: 2.2rem;
	line-height: 1.08;
	letter-spacing: 0;
}

.mh-home-aside-card p {
	margin: 0 0 var(--mh-space-lg);
	line-height: 1.8;
	color: color-mix(in oklab, var(--mh-light-ink) 84%, var(--mh-accent));
}

.mh-home-inline-link {
	display: inline-flex;
	align-items: center;
	gap: var(--mh-space-xs);
	color: oklch(0.95 0.018 75);
	font-weight: 700;
	text-decoration: none;
}

.mh-home-inline-link::after {
	content: "\2192";
	font-size: 1rem;
}

.mh-home-aside-meta {
	display: grid;
	gap: var(--mh-space-sm);
	padding: var(--mh-space-lg);
	border-radius: 22px;
	background: color-mix(in oklab, var(--mh-night-soft) 62%, transparent);
	color: oklch(0.94 0.01 82);
}

.mh-home-aside-meta div {
	display: grid;
	gap: var(--mh-space-2xs);
	padding-bottom: var(--mh-space-sm);
	border-bottom: 1px solid color-mix(in oklab, var(--mh-light-ink) 14%, transparent);
}

.mh-home-aside-meta div:last-child {
	padding-bottom: 0;
	border-bottom: 0;
}

.mh-home-aside-meta span {
	font-size: 0.78rem;
	letter-spacing: 0;
	text-transform: uppercase;
	color: color-mix(in oklab, var(--mh-light-ink) 56%, var(--mh-accent));
}

.mh-home-aside-meta strong {
	font-size: 1rem;
	line-height: 1.65;
	font-weight: 600;
}

.mh-home-ribbon {
	margin: var(--mh-space-lg) auto 0;
	padding: 0 var(--mh-space-xl);
}

.mh-home-ribbon p {
	margin: 0;
	padding: var(--mh-space-md) 0;
	border-top: 1px solid var(--mh-line);
	border-bottom: 1px solid var(--mh-line);
	font-size: 1.16rem;
	line-height: 1.6;
	letter-spacing: 0;
	color: var(--mh-ink-soft);
}

.mh-home-split,
.mh-home-projects,
.mh-home-editorial,
.mh-home-contact {
	display: grid;
	gap: var(--mh-space-lg);
	margin-top: var(--mh-space-xl);
}

.mh-home-split {
	grid-template-columns: minmax(0, 1.12fr) minmax(280px, 0.88fr);
}

.mh-home-featured,
.mh-home-manifesto {
	position: relative;
	padding: clamp(26px, 4vw, 38px);
	border-radius: 28px;
}

.mh-home-featured {
	background:
		radial-gradient(circle at top right, color-mix(in oklab, var(--mh-accent) 18%, transparent) 0, transparent 34%),
		var(--mh-paper);
}

.mh-home-featured::after {
	content: "";
	position: absolute;
	top: 22px;
	right: 22px;
	width: 88px;
	height: 88px;
	border-radius: 24px;
	border: 1px dashed color-mix(in oklab, var(--mh-accent) 58%, transparent);
	transform: rotate(11deg);
	opacity: 0.48;
}

.mh-home-manifesto {
	background:
		linear-gradient(180deg, color-mix(in oklab, var(--mh-olive) 22%, var(--mh-paper)) 0%, var(--mh-paper-strong) 100%);
	transform: translateY(24px);
}

.mh-home-featured h2,
.mh-home-manifesto h2,
.mh-home-heading-block h2,
.mh-home-editorial-intro h2,
.mh-home-contact-copy h2 {
	margin: var(--mh-space-sm) 0 var(--mh-space-md);
	font-family: "MHDisplay", serif;
	font-size: 3.05rem;
	line-height: 1.08;
	letter-spacing: 0;
	text-wrap: balance;
}

.mh-home-featured p,
.mh-home-manifesto p,
.mh-home-heading-block p,
.mh-home-editorial-intro p,
.mh-home-note p,
.mh-home-track p,
.mh-home-contact-copy p {
	margin: 0;
	max-width: 66ch;
	font-size: 1rem;
	line-height: 1.9;
	color: var(--mh-ink-soft);
}

.mh-home-points {
	display: grid;
	gap: var(--mh-space-sm);
	margin: var(--mh-space-lg) 0 var(--mh-space-xl);
	padding: 0;
	list-style: none;
}

.mh-home-points li {
	position: relative;
	padding-left: calc(var(--mh-space-lg) + var(--mh-space-xs));
	line-height: 1.8;
	color: var(--mh-ink);
}

.mh-home-points li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 0.62em;
	width: 13px;
	height: 13px;
	border-radius: 3px;
	background: color-mix(in oklab, var(--mh-accent) 72%, var(--mh-paper));
	box-shadow: 0 0 0 4px color-mix(in oklab, var(--mh-accent) 16%, transparent);
}

.mh-home-section {
	display: grid;
	gap: var(--mh-space-xl);
	margin-top: clamp(48px, 7vw, 84px);
}

.mh-home-projects {
	margin-top: clamp(52px, 8vw, 92px);
}

.mh-home-project-grid {
	display: grid;
	grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
	gap: var(--mh-space-lg);
	align-items: stretch;
}

.mh-home-project-card {
	display: grid;
	gap: var(--mh-space-md);
	padding: clamp(24px, 3vw, 34px);
	border: 1px solid var(--mh-line);
	border-radius: 28px;
	box-shadow: var(--mh-shadow-soft);
	position: relative;
	overflow: hidden;
}

.mh-home-project-card::after {
	content: "";
	position: absolute;
	inset: 14px;
	border: 1px solid color-mix(in oklab, var(--mh-line) 52%, transparent);
	border-radius: 20px;
	pointer-events: none;
}

.mh-home-project-card-story {
	background:
		linear-gradient(180deg, color-mix(in oklab, var(--mh-olive) 18%, var(--mh-paper)) 0%, var(--mh-paper) 100%);
	transform: translateY(18px);
}

.mh-home-project-card-panel {
	background:
		radial-gradient(circle at top right, color-mix(in oklab, var(--mh-accent) 18%, transparent) 0, transparent 38%),
		linear-gradient(145deg, var(--mh-night) 0%, var(--mh-night-soft) 100%);
	color: var(--mh-light-ink);
	box-shadow: var(--mh-shadow-deep);
}

.mh-home-project-card h3 {
	margin: 0;
	font-family: "MHDisplay", serif;
	font-size: 2.22rem;
	line-height: 1.08;
	letter-spacing: 0;
	text-wrap: balance;
}

.mh-home-project-card p {
	margin: 0;
	max-width: 60ch;
	font-size: 1rem;
	line-height: 1.88;
	color: var(--mh-ink-soft);
}

.mh-home-project-card-panel p,
.mh-home-project-card-panel h3 {
	color: var(--mh-light-ink);
}

.mh-home-project-card-panel .mh-home-note-label {
	color: color-mix(in oklab, var(--mh-light-ink) 68%, var(--mh-accent));
}

.mh-home-project-meta {
	display: flex;
	flex-wrap: wrap;
	gap: var(--mh-space-sm);
}

.mh-home-project-meta span {
	display: inline-flex;
	align-items: center;
	min-height: 34px;
	padding: 8px 12px;
	border-radius: 999px;
	font-size: 0.82rem;
	letter-spacing: 0;
	text-transform: uppercase;
	background: color-mix(in oklab, var(--mh-paper) 72%, transparent);
	color: var(--mh-ink-soft);
}

.mh-home-project-card-panel .mh-home-project-meta span {
	background: color-mix(in oklab, var(--mh-light-ink) 10%, transparent);
	color: color-mix(in oklab, var(--mh-light-ink) 88%, var(--mh-accent));
}

.mh-home-project-actions {
	display: flex;
	flex-wrap: wrap;
	gap: var(--mh-space-md);
	margin-top: auto;
}

.mh-home-btn-secondary-dark {
	border-color: color-mix(in oklab, var(--mh-light-ink) 20%, transparent);
	color: var(--mh-light-ink);
	background: color-mix(in oklab, var(--mh-light-ink) 8%, transparent);
}

.mh-home-btn-secondary-dark:hover {
	background: color-mix(in oklab, var(--mh-light-ink) 14%, transparent);
}

.mh-home-btn-admin {
	border-color: color-mix(in oklab, var(--mh-accent-deep) 28%, var(--mh-line));
	background: color-mix(in oklab, var(--mh-paper-strong) 88%, var(--mh-accent));
	color: var(--mh-ink);
	box-shadow: none;
	white-space: nowrap;
}

.mh-home-btn-admin:hover {
	background: color-mix(in oklab, var(--mh-paper-strong) 76%, var(--mh-accent));
}

.mh-home-heading-block {
	display: grid;
	gap: var(--mh-space-md);
	max-width: 54rem;
}

.mh-home-track-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--mh-space-lg);
	align-items: start;
}

.mh-home-track {
	position: relative;
	display: grid;
	gap: var(--mh-space-md);
	min-height: 280px;
	padding: clamp(22px, 3vw, 30px);
	border-radius: 26px;
	background: var(--mh-paper);
}

.mh-home-track:nth-child(2) {
	background: color-mix(in oklab, var(--mh-olive) 18%, var(--mh-paper));
	transform: translateY(22px);
}

.mh-home-track:nth-child(3) {
	background: color-mix(in oklab, var(--mh-accent) 10%, var(--mh-paper));
	transform: rotate(-1.3deg);
}

.mh-home-track::after {
	content: "";
	position: absolute;
	inset: 12px;
	border: 1px solid color-mix(in oklab, var(--mh-line) 60%, transparent);
	border-radius: 20px;
	pointer-events: none;
}

.mh-home-track-index {
	margin: 0;
	font-family: "MHDisplay", serif;
	font-size: 2.75rem;
	line-height: 1;
	color: color-mix(in oklab, var(--mh-accent-deep) 78%, var(--mh-ink));
}

.mh-home-track h3,
.mh-home-note h3 {
	margin: 0;
	font-family: "MHDisplay", serif;
	font-size: 1.78rem;
	line-height: 1.15;
	letter-spacing: 0;
}

.mh-home-editorial {
	grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
	align-items: start;
	margin-top: clamp(52px, 8vw, 92px);
}

.mh-home-editorial-intro {
	display: grid;
	gap: var(--mh-space-md);
	padding-right: var(--mh-space-xl);
}

.mh-home-editorial-stack {
	display: grid;
	gap: var(--mh-space-md);
}

.mh-home-note {
	display: grid;
	gap: var(--mh-space-sm);
	padding: clamp(22px, 3vw, 30px);
	border-radius: 24px;
	background: color-mix(in oklab, var(--mh-paper) 82%, var(--mh-light-ink));
}

.mh-home-note:nth-child(2) {
	margin-left: clamp(0px, 4vw, 38px);
	background: color-mix(in oklab, var(--mh-olive) 15%, var(--mh-paper));
}

.mh-home-note:nth-child(3) {
	margin-right: clamp(0px, 6vw, 48px);
	background: color-mix(in oklab, var(--mh-accent) 8%, var(--mh-paper));
}

.mh-home-admin-entry {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--mh-space-lg);
	margin-top: clamp(46px, 7vw, 78px);
	padding: var(--mh-space-lg) 0;
	border-top: 1px solid var(--mh-line);
	border-bottom: 1px solid var(--mh-line);
}

.mh-home-admin-entry > div {
	display: grid;
	gap: var(--mh-space-sm);
	max-width: 42rem;
}

.mh-home-admin-entry h2 {
	margin: 0;
	font-family: "MHDisplay", serif;
	font-size: 2rem;
	line-height: 1.12;
	letter-spacing: 0;
}

.mh-home-admin-entry p {
	margin: 0;
	font-size: 1rem;
	line-height: 1.8;
	color: var(--mh-ink-soft);
}

.mh-home-contact {
	grid-template-columns: minmax(0, 1fr) minmax(260px, 0.92fr);
	align-items: end;
	padding: clamp(26px, 4vw, 40px);
	border-radius: 30px;
	background:
		radial-gradient(circle at top right, color-mix(in oklab, var(--mh-accent) 34%, transparent) 0, transparent 28%),
		linear-gradient(145deg, var(--mh-night) 0%, var(--mh-night-soft) 100%);
	box-shadow: var(--mh-shadow-deep);
}

.mh-home-contact-copy {
	display: grid;
	gap: var(--mh-space-md);
	color: oklch(0.95 0.01 82);
}

.mh-home-contact-copy p {
	color: color-mix(in oklab, var(--mh-light-ink) 76%, var(--mh-accent));
}

.mh-home-contact-panel {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: var(--mh-space-md);
	padding: var(--mh-space-lg);
	border-radius: 24px;
	background: color-mix(in oklab, var(--mh-night-soft) 50%, transparent);
}

.mh-contact-item {
	position: relative;
}

.mh-contact-trigger {
	display: grid;
	justify-items: center;
	gap: var(--mh-space-sm);
	width: 100%;
	min-height: 134px;
	padding: var(--mh-space-lg) var(--mh-space-md);
	border: 1px solid color-mix(in oklab, var(--mh-light-ink) 14%, transparent);
	border-radius: 20px;
	background: color-mix(in oklab, var(--mh-light-ink) 6%, transparent);
	color: oklch(0.96 0.01 82);
	cursor: pointer;
	transition:
		transform 220ms cubic-bezier(0.16, 1, 0.3, 1),
		background-color 220ms ease,
		border-color 220ms ease,
		color 220ms ease;
}

.mh-contact-trigger:hover,
.mh-contact-trigger:focus-visible {
	transform: translateY(-3px);
	background: color-mix(in oklab, var(--mh-light-ink) 12%, transparent);
	border-color: color-mix(in oklab, var(--mh-light-ink) 24%, transparent);
}

.mh-contact-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: color-mix(in oklab, var(--mh-accent) 32%, transparent);
}

.mh-contact-icon svg {
	width: 22px;
	height: 22px;
}

.mh-contact-name {
	font-size: 0.96rem;
	font-weight: 700;
	letter-spacing: 0;
}

.mh-contact-popover {
	position: absolute;
	left: 50%;
	bottom: calc(100% + 14px);
	width: 172px;
	padding: var(--mh-space-sm);
	border-radius: 20px;
	background: oklch(0.975 0.008 82);
	border: 1px solid color-mix(in oklab, var(--mh-line) 76%, transparent);
	box-shadow: 0 18px 36px oklch(0.17 0.01 40 / 0.24);
	opacity: 0;
	visibility: hidden;
	transform: translateX(-50%) translateY(8px);
	transition:
		opacity 180ms ease,
		transform 180ms ease,
		visibility 180ms ease;
	z-index: 10;
	text-align: center;
}

.mh-contact-popover::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: -7px;
	width: 14px;
	height: 14px;
	background: oklch(0.975 0.008 82);
	border-right: 1px solid color-mix(in oklab, var(--mh-line) 76%, transparent);
	border-bottom: 1px solid color-mix(in oklab, var(--mh-line) 76%, transparent);
	transform: translateX(-50%) rotate(45deg);
}

.mh-contact-popover img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 12px;
}

.mh-contact-popover p {
	margin: var(--mh-space-sm) 0 0;
	font-size: 0.88rem;
	font-weight: 700;
	color: var(--mh-ink);
}

.mh-contact-item:hover .mh-contact-popover,
.mh-contact-item:focus-within .mh-contact-popover {
	opacity: 1;
	visibility: visible;
	transform: translateX(-50%) translateY(0);
}

.site-footer {
	display: none;
}

.mh-bottom-footer {
	margin-top: var(--mh-space-lg);
	padding: var(--mh-space-lg) 0 calc(var(--mh-space-lg) + var(--mh-space-sm));
	color: color-mix(in oklab, var(--mh-ink-soft) 88%, var(--mh-paper));
}

.mh-bottom-footer-content {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--mh-space-lg);
	padding-top: var(--mh-space-md);
	border-top: 1px solid var(--mh-line);
}

.mh-bottom-footer-copyright {
	font-size: 0.92rem;
	line-height: 1.6;
}

.mh-bottom-footer-links {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--mh-space-sm);
}

.mh-bottom-footer-links a {
	color: inherit;
	font-size: 0.92rem;
	text-decoration: none;
}

.mh-bottom-footer-links a:hover {
	color: var(--mh-ink);
}

.mh-bottom-footer-sep {
	color: color-mix(in oklab, var(--mh-ink-soft) 52%, var(--mh-paper));
}

@container (max-width: 1080px) {
	.mh-home-hero,
	.mh-home-split,
	.mh-home-project-grid,
	.mh-home-editorial,
	.mh-home-contact {
		grid-template-columns: 1fr;
	}

	.mh-home-manifesto,
	.mh-home-project-card-story,
	.mh-home-track:nth-child(2),
	.mh-home-track:nth-child(3),
	.mh-home-note:nth-child(2),
	.mh-home-note:nth-child(3) {
		transform: none;
		margin-left: 0;
		margin-right: 0;
	}

	.mh-home-contact-panel {
		grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
	}
}

@container (max-width: 840px) {
	.mh-home-track-grid {
		grid-template-columns: 1fr;
	}

	.mh-home-heading-block,
	.mh-home-editorial-intro {
		max-width: none;
		padding-right: 0;
	}

	.mh-home-title {
		max-width: 12ch;
		font-size: 4rem;
	}

	.mh-home-featured h2,
	.mh-home-manifesto h2,
	.mh-home-heading-block h2,
	.mh-home-editorial-intro h2,
	.mh-home-contact-copy h2 {
		font-size: 2.55rem;
	}
}

@container (max-width: 620px) {
	.mh-home-hero,
	.mh-home-featured,
	.mh-home-manifesto,
	.mh-home-project-card,
	.mh-home-track,
	.mh-home-note,
	.mh-home-contact {
		padding: 22px;
		border-radius: 24px;
	}

	.mh-home-ribbon {
		padding: 0;
	}

	.mh-home-ribbon p {
		font-size: 1rem;
	}

	.mh-home-title {
		font-size: 2.75rem;
	}

	.mh-home-aside-card h2,
	.mh-home-project-card h3 {
		font-size: 1.76rem;
	}

	.mh-home-featured h2,
	.mh-home-manifesto h2,
	.mh-home-heading-block h2,
	.mh-home-editorial-intro h2,
	.mh-home-contact-copy h2 {
		font-size: 2rem;
	}

	.mh-home-track-index {
		font-size: 2.2rem;
	}

	.mh-home-track h3,
	.mh-home-note h3 {
		font-size: 1.44rem;
	}

	.mh-home-actions {
		flex-direction: column;
		align-items: stretch;
	}

	.mh-home-admin-entry {
		align-items: stretch;
		flex-direction: column;
	}

	.mh-home-admin-entry h2 {
		font-size: 1.58rem;
	}

	.mh-home-btn {
		width: 100%;
	}

	.mh-home-contact-panel {
		grid-template-columns: 1fr;
	}

	.mh-contact-trigger {
		min-height: 110px;
	}

	.mh-bottom-footer-content {
		flex-direction: column;
		align-items: flex-start;
	}
}

@media (max-width: 620px) {
	.ast-container {
		width: min(100% - 24px, 1120px);
	}

	.site-header-inner {
		min-height: 64px;
	}

	.site-brand span {
		display: none;
	}

	.site-nav {
		gap: 12px;
	}

	.site-nav a {
		font-size: 0.88rem;
	}

	.not-found-main h1 {
		font-size: 2rem;
	}
}

@media (prefers-reduced-motion: reduce) {
	.mh-home-hero,
	.mh-home-ribbon,
	.mh-home-split,
	.mh-home-projects,
	.mh-home-section,
	.mh-home-editorial,
	.mh-home-contact,
	.mh-bottom-footer,
	.mh-home-btn,
	.mh-home-inline-link,
	.mh-contact-trigger,
	.mh-contact-popover {
		animation: none;
		transition: none;
	}
}

@keyframes mh-rise {
	from {
		opacity: 0;
		transform: translateY(18px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}
