.footer {
	background: #F8F9FB;
    color: #000;
    display: flex;
    align-content: flex-start;
    align-items: flex-start;
    justify-content: center;
    flex-direction: column;
	border-top-left-radius: 90px;
	border-top-right-radius: 90px;
	position: relative;
    z-index: 5;
    transform: translate(0, 30%);
	overflow: hidden;
}
.footer-ellipse {
	transition: transform 1.5s linear;
	position: absolute;
	z-index: 0;
}
.footer a,
.footer a:hover,
.footer a:active,
.footer a:focus {
	text-decoration: none;
    color: inherit;
}
.footer-container {
	width: 100%;
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    gap: 40px;
    max-width: 1600px;
    margin: 0 auto;
	padding: 100px 40px 15px;
	z-index: 4;
}
.pre-footer-container {
	width: 100%;
    max-width: 1600px;
    margin: 0 auto;
    display: flex;
    align-content: center;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    gap: 10px;
	padding: 6em 0 5em;
	z-index: 4;
}
.footer .divider {
	border-bottom: 1.5px solid #ABBCC3;
	width: 100%;
	padding: 0;
	margin: 0;
}
.pre-footer-container .subtitle {
    font-family: 'General Sans Semibold', sans-serif;
    font-size: var(--fs-sm-md);
    line-height: 1.1em;
	color: #17343F;
	padding: 0;
    margin: 0;
}
.pre-footer-container .title {
    font-family: 'General Sans Semibold', sans-serif;
    font-size: var(--fs-title);
    line-height: 1.1em;
	color: #17343F;
	padding: 0;
    margin: 0 0 30px;
}
.footer-column {
	text-align: left;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    align-content: flex-start;
    justify-content: flex-start;
	gap: 25px;
}
.footer-column:first-child {
	max-width: 551px;
}
.footer-column .title {
    font-family: 'General Sans Semibold', sans-serif;
    font-size: var(--fs-sm);
    line-height: 1.3em;
	color: #17343F;
	padding: 0;
    margin: 0;
    margin-bottom: 10px;
}
.footer-column ul {
    list-style: none;
    padding: 0;
	transform: translate(0, -20px);
}
.footer-column ul li {
    margin-bottom: 8px;
}
.footer-column ul li a {
    text-decoration: none;
    transition: color 0.3s;
}
.footer-column ul li a:hover {
    color: #3BFF6C;
}
.footer-logo {
    max-width: 313px;
    margin-bottom: 10px;
}
.social-icons {
    display: flex;
    gap: 10px;
}
.social-icons a img {
    width: 24px;
    height: 24px;
}
.footer-bottom {
    text-align: center;
    margin-top: 20px;
    display: flex;
    justify-content: space-between;
    max-width: 1600px;
    margin: 20px auto 0;
	width: 100%;
	padding: 10px 40px 15px;
	z-index: 4;
}
.useful-links {
	width: 100%;
	max-width: 1600px;
    margin: 0 auto;
	display: flex;
	gap: 30px;
	transform: translate(0, -70px);
	padding: 0 40px;
	z-index: 4;
}
.footer-column .content,
.footer-bottom .content,
.footer-column ul li a,
.footer-column ul li a:hover,
.footer-column ul li a:active,
.footer-column ul li a:focus,
.useful-links a,
.useful-links a:hover,
.useful-links a:active,
.useful-links a:focus {
    font-family: 'General Sans', sans-serif;
    font-size: var(--fs-ssm);
    line-height: 1.1em;
    font-weight: 400;
	color: #17343F;
	padding: 0;
    margin: 0;
	text-decoration: none;
}
.footer-column ul li a,
.footer-column ul li a:hover,
.footer-column ul li a:active,
.footer-column ul li a:focus {
    line-height: 1.8em;
}
#ellipse21 {
    top: -24%;
    left: 0;
}
#ellipse22 {
	bottom: -10%;
    right: -30%;
}
#ellipse23 {
	top: 20%;
    left: -28%;
}
@media (max-width: 1600px) {
	#ellipse21 {
		top: -28%;
		left: -7%;
	}
	#ellipse22 {
		bottom: -10%;
		right: -37%;
	}
	#ellipse23 {
		top: 20%;
		left: -33%;
	}
}
@media (max-width: 1440px) {
	#ellipse21 {
		top: -33%;
		left: -18%;
	}
	#ellipse22 {
		bottom: -10%;
		right: -60%;
	}
	#ellipse23 {
		top: 10%;
		left: -51%;
	}
}
@media (max-width: 1280px) {
	#ellipse21 {
		top: -33%;
		left: -27%;
	}
	#ellipse22 {
		bottom: -10%;
		right: -75%;
	}
	#ellipse23 {
        top: 5%;
        left: -68%;
	}
}
@media (max-width: 1024px) {
	.useful-links {
		transform: translate(0, 0);
		margin: 40px 0 0;
	}
    .footer-container {
        grid-template-columns: repeat(2, 1fr);
    }
	#ellipse21 {
		top: -23%;
        left: -27%;
	}
	#ellipse22 {
		bottom: -4%;
        right: -84%;
	}
	#ellipse23 {
        top: 14%;
        left: -73%;
	}
}
@media (max-width: 800px) {
	#ellipse21 {
        top: -23%;
        left: -37%;
	}
	#ellipse22 {
        bottom: 9%;
        right: -97%;
	}
	#ellipse23 {
        top: 13%;
        left: -81%;
	}
}
@media (max-width: 768px) {
    .footer-container {
        grid-template-columns: 1fr;
        text-align: center;
		padding: 50px 40px 15px;
    }
    .social-icons {
        justify-content: center;
    }
    .footer-bottom {
        flex-direction: column;
        text-align: center;
        gap: 5px;
    }
	#ellipse21 {
        top: -20%;
        left: -58%;
	}
	#ellipse22 {
		bottom: 13%;
        right: -130%;
	}
	#ellipse23 {
        top: 12%;
        left: -122%;
	}
}
@media (max-width: 500px) {
	.useful-links {
		gap: 15px;
	}
	#ellipse21 {
        top: -22%;
        left: -70%;
	}
	#ellipse22 {
        bottom: 13%;
        right: -185%;
	}
	#ellipse23 {
        top: 12%;
        left: -158%;
	}
}
@media (max-width: 475px) {
	#ellipse21 {
        top: -23%;
        left: -90%;
	}
	#ellipse22 {
        bottom: 13%;
        right: -208%;
	}
	#ellipse23 {
        top: 12%;
        left: -190%;
	}
	.footer-logo {
        max-width: 270px;
	}
}
@media (max-width: 440px) {
	#ellipse21 {
        top: -23%;
        left: -90%;
	}
	#ellipse22 {
        bottom: 0%;
        right: -247%;
	}
	#ellipse23 {
        top: 12%;
        left: -220%;
	}
}