.site-footer {
	position: relative;
	background: var(--color-accent-dark);
	color: #fffaf0;
	overflow: hidden;
}

.site-footer__top {
	position: relative;
	border-top: 0.5rem solid #c89b4f;
	background: var(--header-gradient);
}

.site-footer__top::before {
	position: absolute;
	inset: 0;
	background: url("../img/bavaria-pattern.svg") center / cover no-repeat;
	content: "";
	opacity: 0.1;
	pointer-events: none;
}

.site-footer__inner {
	display: grid;
	position: relative;
	grid-template-columns: minmax(0, 1fr) minmax(12rem, 0.28fr) minmax(12rem, 0.28fr);
	gap: 4rem;
	align-items: start;
	width: min(100% - (var(--container-gutter) * 2), var(--content-width));
	margin-inline: auto;
	padding-block: 3rem 2rem;
}

.site-footer__title {
	max-width: 42rem;
	margin: 0;
	font-family: var(--font-family-base);
	font-size: clamp(2.5rem, 5vw, 4rem);
	font-weight: var(--font-weight-400);
	line-height: 0.92;
}

.footer-navigation__title {
	margin: 0 0 1rem;
	color: #fffaf0;
	font-size: var(--text-m);
	font-weight: var(--font-weight-700);
	line-height: 1.2;
	text-transform: uppercase;
}

.footer-menu,
.footer-social__list {
	display: grid;
	gap: 0.75rem;
	padding: 0;
	margin: 0;
	list-style: none;
}

.footer-social__list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.footer-menu .menu-link,
.footer-social__link {
	display: inline-flex;
	align-items: center;
	min-height: 2rem;
	color: rgba(255, 250, 240, 0.86);
	font-size: var(--text-s);
	font-weight: var(--font-weight-700);
	line-height: 1.2;
	text-decoration: none;
	text-transform: uppercase;
	transition: color 180ms ease-in-out;
}

.footer-social__link {
	justify-content: center;
	width: 3.5rem;
	min-height: 3.5rem;
	text-transform: none;
}

.footer-social__icon {
	display: grid;
	flex: 0 0 auto;
	place-items: center;
	width: 3.5rem;
	aspect-ratio: 1;
	border: 0.125rem solid rgba(245, 221, 122, 0.55);
	border-radius: 999px;
	color: #f5dd7a;
	transition: border-color 180ms ease-in-out, background-color 180ms ease-in-out, color 180ms ease-in-out, transform 180ms ease-in-out;
}

.footer-social__icon svg {
	display: block;
	width: 1.5rem;
	height: 1.5rem;
}

.footer-menu .menu-link:hover,
.footer-menu .menu-link:focus-visible,
.footer-social__link:hover,
.footer-social__link:focus-visible {
	color: #f5dd7a;
}

.footer-menu .menu-link:focus-visible,
.footer-social__link:focus-visible {
	outline: 0.1875rem solid transparent;
	box-shadow: 0 0 0 0.1875rem rgba(245, 221, 122, 0.55);
}

.footer-social__link:hover .footer-social__icon,
.footer-social__link:focus-visible .footer-social__icon {
	border-color: #f5dd7a;
	background: #f5dd7a;
	color: #22180f;
	transform: translateY(-0.125rem);
}

.site-footer__copyright {
	grid-column: 1 / -1;
	margin: 0;
	padding-top: 1rem;
	border-top: 0.0625rem solid rgba(255, 250, 240, 0.2);
	color: rgba(255, 250, 240, 0.72);
	font-size: var(--text-xs);
}

@media (prefers-reduced-motion: reduce) {
	.footer-menu .menu-link,
	.footer-social__link,
	.footer-social__icon {
		transition: none;
	}
}

@media (max-width: 760px) {
	.site-footer__inner {
		grid-template-columns: 1fr;
		gap: 2rem;
		padding-block: 2.5rem 2rem;
	}

	.site-footer__title {
		font-size: clamp(1.875rem, 10vw, 2.75rem);
	}
}
