/* =============================================================
   404.css — Page not found
   ============================================================= */

.error-404 {
	background-color: var(--color-cream);
	min-height: 60vh;
	display: flex;
	align-items: center;
}

.error-404__inner {
	padding-top: var(--section-py);
	padding-bottom: var(--section-py);
	text-align: center;
}

.error-404__code {
	font-family: var(--font-primary);
	font-size: clamp(6rem, 20vw, 12rem);
	font-weight: var(--weight-medium);
	color: var(--color-primary);
	opacity: 0.12;
	line-height: 1;
	margin-bottom: var(--gap-sm);
}

.error-404__heading {
	font-family: var(--font-primary);
	font-size: var(--text-h1);
	font-weight: var(--weight-regular);
	color: var(--color-primary);
	line-height: var(--lh-tight);
	margin-bottom: var(--gap-lg);
}

.error-404__message {
	font-family: var(--font-primary);
	font-size: var(--text-body-lg);
	color: var(--color-text);
	line-height: var(--lh-body);
	max-width: 520px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: var(--gap-xl);
}

.error-404__nav {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: var(--gap-md);
}

.error-404__link {
	display: inline-block;
	padding: 0.75rem 2rem;
	font-family: var(--font-primary);
	font-size: var(--text-body-sm);
	font-weight: var(--weight-medium);
	border: 1.5px solid var(--color-primary);
	border-radius: 2px;
	color: var(--color-primary);
	transition: background-color 0.2s, color 0.2s;
}

.error-404__link:hover {
	background-color: var(--color-primary);
	color: var(--color-white);
}

.error-404__link--primary {
	background-color: var(--color-primary);
	color: var(--color-white);
}

.error-404__link--primary:hover {
	opacity: 0.85;
	background-color: var(--color-primary);
	color: var(--color-white);
}

@media (max-width: 768px) {
	.error-404__nav {
		flex-direction: column;
		align-items: center;
	}

	.error-404__link {
		width: 100%;
		max-width: 280px;
		text-align: center;
	}
}
