.site-footer {
	position: relative;
	overflow: hidden;
	background:
		radial-gradient(circle at 8% 18%, rgba(6, 216, 137, 0.055), transparent 26%),
		radial-gradient(circle at 94% 46%, rgba(6, 216, 137, 0.045), transparent 28%),
		linear-gradient(180deg, #030606 0%, #0b0b0f 52%, #111014 100%);
	border-top: 1px solid rgba(255, 255, 255, 0.075);
}

.site-footer::before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	background:
		repeating-linear-gradient(
			90deg,
			rgba(255, 255, 255, 0.014) 0,
			rgba(255, 255, 255, 0.014) 1px,
			transparent 1px,
			transparent 24px
		),
		repeating-linear-gradient(
			0deg,
			rgba(255, 255, 255, 0.01) 0,
			rgba(255, 255, 255, 0.01) 1px,
			transparent 1px,
			transparent 24px
		);
	opacity: 0.58;
}

.site-footer::after {
	content: "";
	position: absolute;
	right: -190px;
	bottom: -210px;
	width: 470px;
	height: 470px;
	border-radius: 50%;
	background: radial-gradient(circle, rgba(6, 216, 137, 0.075) 0%, rgba(6, 216, 137, 0.026) 34%, transparent 70%);
	pointer-events: none;
}

.site-footer > * {
	position: relative;
	z-index: 1;
}

.site-footer__main {
	padding: 88px 0 74px;
}

.site-footer__grid {
	display: grid;
	grid-template-columns: minmax(360px, 1.45fr) repeat(3, minmax(160px, 0.82fr));
	gap: 46px 72px;
	align-items: start;
}

.site-footer__column--brand {
	max-width: 520px;
	padding-right: 34px;
}

.site-footer__brand {
	display: inline-flex;
	align-items: center;
	margin-bottom: 28px;
}

.site-footer__brand .custom-logo-link,
.site-footer__brand .site-branding__text {
	display: inline-flex;
	align-items: center;
}

.site-footer__brand .custom-logo {
	width: auto;
	max-height: 56px;
}

.site-footer__text {
	margin: 0;
	max-width: 470px;
	font-size: 15px;
	font-weight: 300;
	line-height: 1.95;
	letter-spacing: 0.02em;
	color: rgba(216, 221, 231, 0.78);
}

.site-footer__contact-list {
	display: flex;
	flex-wrap: wrap;
	gap: 12px 20px;
	margin-top: 34px;
}

.site-footer__contact-link {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: 14px;
	font-weight: 700;
	line-height: 1.4;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	color: #ffffff;
}

.site-footer__contact-link::before {
	content: "";
	display: inline-block;
	width: 16px;
	height: 2px;
	background: var(--agency-color-accent);
	box-shadow: 0 0 14px rgba(6, 216, 137, 0.38);
	transition: width var(--agency-transition);
}

.site-footer__contact-link:hover {
	color: var(--agency-color-accent);
}

.site-footer__contact-link:hover::before {
	width: 26px;
}

.site-footer__title {
	position: relative;
	margin: 0 0 24px;
	padding-bottom: 14px;
	font-size: 18px;
	font-weight: 800;
	line-height: 1.25;
	letter-spacing: 0.02em;
	color: #ffffff;
}

.site-footer__title::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 34px;
	height: 2px;
	background: var(--agency-color-accent);
	box-shadow: 0 0 14px rgba(6, 216, 137, 0.32);
}

.site-footer__menu {
	margin: 0;
	padding: 0;
	list-style: none;
}

.site-footer__menu li {
	margin-bottom: 14px;
}

.site-footer__menu li:last-child {
	margin-bottom: 0;
}

.site-footer__menu a {
	position: relative;
	display: inline-flex;
	align-items: center;
	font-size: 15px;
	font-weight: 400;
	line-height: 1.62;
	color: rgba(216, 221, 231, 0.82);
}

.site-footer__menu a::before {
	content: "";
	width: 0;
	height: 1px;
	margin-right: 0;
	background: var(--agency-color-accent);
	opacity: 0;
	transition:
		width var(--agency-transition),
		margin-right var(--agency-transition),
		opacity var(--agency-transition);
}

.site-footer__menu a:hover {
	color: var(--agency-color-accent);
}

.site-footer__menu a:hover::before {
	width: 12px;
	margin-right: 8px;
	opacity: 1;
}

.site-footer__socials {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-top: 28px;
}

.site-footer__social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.04);
	color: #ffffff;
	transition:
		background-color var(--agency-transition),
		border-color var(--agency-transition),
		color var(--agency-transition),
		transform var(--agency-transition);
}

.site-footer__social-link:hover {
	background: var(--agency-color-accent);
	border-color: var(--agency-color-accent);
	color: #050808;
	transform: translateY(-2px);
}

.site-footer__social-link svg {
	width: 16px;
	height: 16px;
	display: block;
}

.site-footer__bottom {
	border-top: 1px solid rgba(255, 255, 255, 0.075);
	background: rgba(0, 0, 0, 0.18);
}

.site-footer__bottom-inner {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	padding: 22px 0;
}

.site-footer__copyright {
	margin: 0;
	font-size: 14px;
	font-weight: 400;
	line-height: 1.6;
	letter-spacing: 0.02em;
	color: rgba(216, 221, 231, 0.78);
}

@media (max-width: 1199px) {
	.site-footer__grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 46px 54px;
	}

	.site-footer__column--brand {
		max-width: none;
		padding-right: 0;
	}
}

@media (max-width: 991px) {
	.site-footer__main {
		padding: 66px 0 54px;
	}

	.site-footer__grid {
		grid-template-columns: 1fr;
		gap: 38px;
	}

	.site-footer__brand {
		margin-bottom: 22px;
	}

	.site-footer__text {
		max-width: 620px;
	}
}

@media (max-width: 767px) {
	.site-footer__main {
		padding: 52px 0 42px;
	}

	.site-footer__brand .custom-logo {
		max-height: 44px;
	}

	.site-footer__text,
	.site-footer__menu a,
	.site-footer__copyright {
		font-size: 14px;
	}

	.site-footer__contact-list {
		flex-direction: column;
		align-items: flex-start;
		gap: 12px;
		margin-top: 28px;
	}

	.site-footer__title {
		font-size: 17px;
		margin-bottom: 18px;
	}

	.site-footer__bottom-inner {
		padding: 18px 0;
	}
}