/*
 * Layout layer:
 * Site-wide structural regions such as header, main content width, footer,
 * and broad page scaffolding. Reusable UI components belong in components.css.
 */

.site-header,
.site-footer {
	border-color: var(--vt-color-border);
}

.site-header {
	border-bottom: 1px solid var(--vt-color-border);
	background: var(--vt-color-bg);
}

.site-footer {
	border-top: 1px solid var(--vt-color-border);
	background: var(--vt-color-surface);
}

.site-header__inner,
.site-main__inner,
.site-footer__inner {
	width: min(100% - 32px, var(--vt-content-width));
	margin-inline: auto;
}

.site-header__inner,
.site-footer__inner {
	padding-block: 24px;
}

.site-branding {
	display: flex;
	align-items: center;
	gap: 16px;
}

.site-logo img {
	display: block;
	max-width: 180px;
	height: auto;
}

.site-main__inner {
	padding-block: 48px;
}

.site-title {
	margin: 0;
	font-size: 1.25rem;
	font-weight: 700;
}

.site-title a {
	color: var(--vt-color-main);
	text-decoration: none;
}

.site-nav-toggle {
	display: none;
	align-items: center;
	gap: 8px;
	min-height: 44px;
	margin-top: 16px;
	padding: 8px 12px;
	border: 1px solid var(--vt-color-border);
	border-radius: 6px;
	background: var(--vt-color-bg);
	color: var(--vt-color-text);
	font: inherit;
	line-height: 1;
	cursor: pointer;
}

.site-nav-toggle__label {
	font-size: 0.875rem;
	font-weight: 700;
}

.site-nav-toggle__icon {
	display: grid;
	gap: 4px;
	width: 18px;
}

.site-nav-toggle__line {
	display: block;
	height: 2px;
	background: currentColor;
}

.site-nav__list,
.footer-nav__list {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	margin: 16px 0 0;
	padding: 0;
	list-style: none;
}

.site-footer__company {
	margin-bottom: 24px;
}

.site-footer__logo {
	margin-bottom: 12px;
}

.site-footer__logo img {
	display: block;
	max-width: 180px;
	height: auto;
}

.site-footer__company-name {
	margin: 0 0 8px;
	font-weight: 700;
}

.site-footer__company-list {
	margin: 0;
	padding: 0;
	list-style: none;
	color: var(--vt-color-muted);
	font-size: 0.875rem;
}

.site-footer__company-item + .site-footer__company-item {
	margin-top: 4px;
}

.site-footer__copyright {
	margin: 16px 0 0;
	color: var(--vt-color-muted);
	font-size: 0.875rem;
}

.site-footer__copyright-note {
	margin: 4px 0 0;
	color: var(--vt-color-muted);
	font-size: 0.875rem;
}

@media (max-width: 719px) {
	.site-nav-toggle {
		display: inline-flex;
	}

	.variable-thema-navigation-ready .site-nav {
		display: none;
	}

	.variable-thema-navigation-ready .site-header.is-navigation-open .site-nav {
		display: block;
		max-height: calc(100vh - 96px);
		max-height: calc(100dvh - 96px);
		overflow-y: auto;
		overscroll-behavior: contain;
		-webkit-overflow-scrolling: touch;
	}

	.site-nav__list {
		display: grid;
		gap: 12px;
	}
}
