.hvv-footer {
	background: #F6FAFD;
	width: 100%;
	display: flex;
	flex-direction: column;
	gap: 105px;
	padding-top: 105px;
	font-family: Montserrat, sans-serif;
}

.hvv-footer__top {
	display: flex;
	justify-content: center;
	padding: 0 80px;
}

.hvv-footer__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 40px;
	width: 100%;
	max-width: 1760px;
	flex-wrap: wrap;
}

.hvv-footer__address {
	width: 277px;
	color: #000;
	font-size: 23px;
	font-weight: 400;
	line-height: normal;
}

.hvv-footer__address p {
	margin: 0;
}

.hvv-footer__address p + p {
	margin-top: 4px;
}

.hvv-footer__contact,
.hvv-footer__contact:link,
.hvv-footer__contact:visited {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	color: #000;
	font-size: 20px;
	font-weight: 400;
	line-height: normal;
	text-decoration: none;
	transition: color 0.3s ease;
}

.hvv-footer__contact:hover,
.hvv-footer__contact:focus,
.hvv-footer__contact:active {
	color: #1A8DA1;
}

.hvv-footer__contact-icon {
	width: 35px;
	height: 35px;
	flex-shrink: 0;
	display: block;
}

.hvv-footer__contact-icon--mail {
	color: #393737;
}

.hvv-footer__contact-icon--phone {
	color: #1A8DA1;
}

.hvv-footer__social-donate {
	display: flex;
	align-items: center;
	gap: 38px;
}

.hvv-footer__social,
.hvv-footer__social:link,
.hvv-footer__social:visited {
	width: 45px;
	height: 45px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: color 0.3s ease, transform 0.3s ease;
	text-decoration: none;
}

.hvv-footer__social svg {
	width: 45px;
	height: 45px;
	display: block;
}

.hvv-footer__social--fb,
.hvv-footer__social--fb:link,
.hvv-footer__social--fb:visited {
	color: #1877F2;
}

.hvv-footer__social--ig,
.hvv-footer__social--ig:link,
.hvv-footer__social--ig:visited {
	color: #E4405F;
}

.hvv-footer__social--fb:hover,
.hvv-footer__social--ig:hover {
	transform: translateY(-2px);
}

.hvv-footer__donate,
.hvv-footer__donate:link,
.hvv-footer__donate:visited {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 12px 19px;
	border-radius: 26px;
	background: #FC7405;
	color: #FFF;
	font-size: 24px;
	font-weight: 700;
	text-transform: uppercase;
	text-decoration: none;
	transition: background 0.3s ease;
	min-width: 108px;
	text-align: center;
}

.hvv-footer__donate:hover,
.hvv-footer__donate:focus,
.hvv-footer__donate:active {
	background: #d96604;
	color: #FFF;
}

.hvv-footer__bottom {
	background: #EBE9E9;
	width: 100%;
	min-height: 119px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 27px 20px;
	box-sizing: border-box;
}

.hvv-footer__legal {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 106px;
}

.hvv-footer__legal a,
.hvv-footer__legal a:link,
.hvv-footer__legal a:visited {
	color: #000;
	font-size: 16px;
	font-weight: 400;
	line-height: normal;
	text-decoration: none;
	transition: color 0.3s ease;
	white-space: nowrap;
}

.hvv-footer__legal a:hover,
.hvv-footer__legal a:focus,
.hvv-footer__legal a:active {
	color: #1A8DA1;
}

@media screen and (max-width: 1400px) {
	.hvv-footer__inner {
		gap: 60px;
	}
	.hvv-footer__legal {
		gap: 48px;
	}
}

@media screen and (max-width: 991px) {
	.hvv-footer {
		gap: 48px;
		padding-top: 48px;
	}
	.hvv-footer__top {
		padding: 0 20px;
	}
	.hvv-footer__inner {
		flex-direction: column;
		align-items: flex-start;
		gap: 24px;
	}
	.hvv-footer__address {
		font-size: 18px;
		width: auto;
	}
	.hvv-footer__contact {
		font-size: 16px;
	}
	.hvv-footer__contact-icon {
		width: 28px;
		height: 28px;
	}
	.hvv-footer__social-donate {
		margin-left: 0;
		padding: 0;
		gap: 20px;
	}
	.hvv-footer__social,
	.hvv-footer__social svg {
		width: 36px;
		height: 36px;
	}
	.hvv-footer__donate {
		font-size: 18px;
		padding: 10px 16px;
	}
	.hvv-footer__bottom {
		padding: 20px;
		min-height: 0;
	}
	.hvv-footer__legal {
		gap: 16px 24px;
		justify-content: center;
	}
	.hvv-footer__legal a {
		font-size: 14px;
	}
}

/* ----- Figma mobile (≤ 640px) — centered footer ----- */
@media screen and (max-width: 640px) {
	.hvv-footer { gap: 0 !important; padding-top: 20px !important; }
	.hvv-footer__top {
		padding: 4px 65px 14px !important;
		background: #F6FAFD;
	}
	.hvv-footer__inner {
		flex-direction: column !important;
		align-items: center !important;
		gap: 6px !important;
		text-align: center;
	}
	/* Figma order: email → phone → address → socials */
	.hvv-footer__contact:has(.hvv-footer__contact-icon--mail) { order: 1 !important; }
	.hvv-footer__contact:has(.hvv-footer__contact-icon--phone) { order: 2 !important; }
	.hvv-footer__address { order: 3 !important; }
	.hvv-footer__social-donate { order: 4 !important; }

	.hvv-footer__contact {
		font-size: 11px !important;
		justify-content: center !important;
		gap: 5px !important;
	}
	.hvv-footer__contact-icon {
		width: 17px !important;
		height: 17px !important;
	}
	.hvv-footer__address {
		font-size: 11px !important;
		text-align: center !important;
		width: auto !important;
		margin-top: 2px;
	}
	/* Collapse multi-line address into a single visual line */
	.hvv-footer__address p {
		display: inline !important;
		margin: 0 !important;
	}
	.hvv-footer__address br {
		display: none !important;
	}
	.hvv-footer__address p + p::before {
		content: ", ";
	}

	.hvv-footer__social-donate {
		justify-content: center !important;
		gap: 30px !important;
		padding: 12px !important;
		max-width: 280px;
		width: 100%;
		margin: 6px auto 0 !important;
	}
	/* Place DONATE between FB and IG */
	.hvv-footer__social--fb { order: 1 !important; }
	.hvv-footer__donate { order: 2 !important; }
	.hvv-footer__social--ig { order: 3 !important; }

	.hvv-footer__social,
	.hvv-footer__social svg {
		width: 24px !important;
		height: 24px !important;
	}
	.hvv-footer__donate {
		font-size: 12px !important;
		padding: 6px 12px !important;
		border-radius: 6px !important;
	}
	.hvv-footer__bottom {
		padding: 26px 20px 25px !important;
		background: #EBE9E9;
	}
	.hvv-footer__legal {
		flex-direction: column !important;
		gap: 11px !important;
		align-items: center !important;
		justify-content: center !important;
	}
	.hvv-footer__legal a,
	.hvv-footer__legal li,
	.hvv-footer__legal p {
		font-size: 9px !important;
		text-align: center;
	}
}
