/* Inner page and 404 styles (THEME-006). */

.page-title-banner {
	background: var(--color-surface-low);
	padding: 4rem 0;
	text-align: center;
	box-shadow: var(--shadow-soft);
}

.page-title {
	font-family: var(--font-display);
	font-size: var(--font-size-headline-lg);
	font-weight: var(--font-weight-headline-lg);
	line-height: var(--line-height-headline-lg);
	color: var(--color-charcoal);
}

.page-content {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 4rem var(--gutter);
}

.page-content > *:first-child {
	margin-top: 0;
}

.page-content > *:last-child {
	margin-bottom: 0;
}

.page-content p {
	line-height: 1.75;
	margin-bottom: 1.25rem;
}

.page-content img,
.page-content figure img {
	max-width: 100%;
	height: auto;
}

.page-content figure {
	margin: 0 0 1.5rem;
}

.page-content h1,
.page-content h2,
.page-content h3,
.page-content h4 {
	font-family: var(--font-heading);
	color: var(--color-charcoal);
	margin: 2rem 0 1rem;
	line-height: var(--line-height-headline-md);
}

.page-content h1 {
	font-family: var(--font-display);
	font-size: var(--font-size-headline-lg);
	font-weight: var(--font-weight-headline-lg);
	line-height: var(--line-height-headline-lg);
}

.page-content h2 {
	font-size: var(--font-size-headline-md);
	font-weight: var(--font-weight-headline-md);
}

.page-content ul,
.page-content ol {
	margin: 0 0 1.25rem 1.5rem;
	line-height: 1.75;
}

.page-content a {
	text-decoration: underline;
	text-underline-offset: 0.15em;
}

.page-content a:hover,
.page-content a:focus-visible {
	color: var(--color-primary);
}

/* 404 */
.error-404__content {
	max-width: var(--container-max);
	margin: 0 auto;
	padding: 6rem var(--gutter);
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.5rem;
}

.error-404__title {
	font-family: var(--font-display);
	font-size: var(--font-size-headline-lg);
	font-weight: var(--font-weight-headline-lg);
	line-height: var(--line-height-headline-lg);
	color: var(--color-charcoal);
}

.error-404__message {
	font-size: var(--font-size-body-lg);
	line-height: var(--line-height-body);
	color: var(--color-on-surface-variant);
	max-width: 36rem;
}

.error-404__content .btn-primary {
	min-height: 44px;
	min-width: 44px;
}

@media (max-width: 768px) {
	.page-title-banner {
		padding: var(--section-pad-mobile) var(--gutter-mobile);
	}

	.page-title,
	.page-content h1 {
		font-size: var(--font-size-headline-lg-mobile);
		line-height: var(--line-height-headline-lg);
	}

	.page-content {
		padding: var(--section-pad-mobile) var(--gutter-mobile);
	}

	.error-404__content {
		padding: var(--section-pad-mobile) var(--gutter-mobile);
		gap: 1.25rem;
	}

	.error-404__title {
		font-size: var(--font-size-headline-lg-mobile);
		line-height: var(--line-height-headline-lg);
	}
}

@media (max-width: 480px) {
	.page-title-banner {
		padding-top: 3rem;
		padding-bottom: 3rem;
	}

	.page-title,
	.page-content h1 {
		font-size: 28px;
	}

	.page-content {
		padding-top: 3rem;
		padding-bottom: 3rem;
	}

	.error-404__content {
		padding-top: 3rem;
		padding-bottom: 3rem;
	}
}
