@font-face {
	font-family: "SkyPlannerFooterNeueKabel";
	src: url("../../Fonts/NeueKabel.woff2") format("woff2");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "SkyPlannerFooterNeueKabel";
	src: url("../../Fonts/NeueKabel-Medium.woff2") format("woff2");
	font-weight: 500;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "SkyPlannerFooterNeueKabel";
	src: url("../../Fonts/NeueKabel-Bold.woff2") format("woff2");
	font-weight: 700;
	font-style: normal;
	font-display: swap;
}

@font-face {
	font-family: "SkyPlannerFooterJost";
	src: url("../../Fonts/Jost.woff2") format("woff2");
	font-weight: 400;
	font-style: normal;
	font-display: swap;
}

.site-footer .spf {
	--sp-blue: #303AF2;
	--sp-ink: #1F1F33;
	--sp-green: #00BA70;
	--sp-green-600: #00A663;
	--sp-bg-alt: #F9F9FD;
	--sp-white: #FFFFFF;
	--sp-border: #DDEDFF;
	--sp-text: #1F1F33;
	--sp-text-muted: #5A5A6E;
	--sp-radius-lg: 24px;
	--sp-radius-pill: 35px;
	--sp-radius-full: 9999px;
	--sp-font-display: "SkyPlannerFooterNeueKabel", "Jost", system-ui, sans-serif;
	--sp-font-body: "SkyPlannerFooterJost", "Jost", system-ui, -apple-system, sans-serif;
	--sp-h4: 700 clamp(20px, 2vw, 24px)/1.3 var(--sp-font-display);
	--sp-body-lg: 400 20px/30px var(--sp-font-body);
	--sp-body-sm: 400 16px/23px var(--sp-font-body);
	--sp-caption: 400 15px/22px var(--sp-font-body);

	position: relative;
	overflow: hidden;
	background: linear-gradient(180deg, #3641F4 0%, #2A33D8 100%);
	color: #fff;
	margin: 0;
}

.site-footer .spf,
.site-footer .spf * {
	box-sizing: content-box;
}

.site-footer .spf p,
.site-footer .spf figure,
.site-footer .spf ul {
	margin: 0;
}

.site-footer .spf .wp-block-group__inner-container {
	max-width: none;
	padding: 0;
	margin: 0;
	width: 100%;
}

.site-footer .spf__inner {
	position: relative;
	z-index: 2;
	max-width: 1280px;
	margin: 0 auto;
	padding: clamp(56px, 6vw, 84px) clamp(24px, 5vw, 56px) 30px;
}

.site-footer .spf__inner > .wp-block-group__inner-container {
	position: relative;
	z-index: 2;
	max-width: none;
	margin: 0 auto;
	padding: 0;
	width: 100%;
}

.site-footer .spf__top {
	display: block;
	padding-bottom: 52px;
	border-bottom: 1px solid rgba(255,255,255,0.16);
}

.site-footer .spf__top > .wp-block-group__inner-container {
	display: grid;
	grid-template-columns: minmax(0, 1.25fr) minmax(0, 1fr);
	gap: 48px 40px;
	align-items: center;
	width: 100%;
}

.site-footer .spf__brand {
	max-width: 440px;
}

.site-footer .spf__logo {
	height: 40px;
	width: auto;
	display: block;
	margin-bottom: 22px;
}

.site-footer .spf__tag {
	font: var(--sp-body-lg);
	font-family: var(--sp-font-display);
	font-weight: 500;
	color: #fff;
	margin: 0 0 20px !important;
	line-height: 1.35;
	text-wrap: balance;
	max-width: 36ch;
}

.site-footer .spf__pills {
	display: block;
}

.site-footer .spf__pills > .wp-block-group__inner-container {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	width: 100%;
}

.site-footer .spf__pill {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: rgba(255,255,255,0.10);
	border: 1px solid rgba(255,255,255,0.18);
	border-radius: var(--sp-radius-full);
	padding: 7px 14px;
	font: var(--sp-caption);
	color: rgba(255,255,255,0.92);
	white-space: nowrap;
	width: fit-content;
}

.site-footer .spf__pill svg {
	width: 15px;
	height: 15px;
	flex: none;
	color: #fff;
	opacity: .9;
}

.site-footer .spf__cta {
	justify-self: end;
	max-width: 360px;
	width: auto;
	display: block;
}

.site-footer .spf__cta > .wp-block-group__inner-container {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 14px;
	width: auto;
}

.site-footer .spf__cta-h {
	font: var(--sp-h4) !important;
	font-family: var(--sp-font-display) !important;
	font-weight: 700 !important;
	color: #fff;
	margin: 0;
}

.site-footer .spf__cta-sub {
	font: var(--sp-caption);
	color: rgba(255,255,255,0.78);
	margin: 0;
}

.site-footer .spf__cta-row {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 4px;
}

.site-footer .spf__cta-row > .wp-block-button {
	margin: 0;
	padding: 0;
}

.site-footer .spf__btn .wp-block-button__link,
.site-footer .spf__btn.wp-block-button__link {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	border-radius: var(--sp-radius-pill);
	padding: 13px 24px;
	font: 700 16px/1 var(--sp-font-display);
	text-decoration: none;
	white-space: nowrap;
	width: auto !important;
	height: auto !important;
	transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
	border: 0;
}

.site-footer .spf__btn svg {
	width: 17px;
	height: 17px;
	flex: none;
	transition: transform .18s ease;
}

.site-footer .spf__btn--primary .wp-block-button__link,
.site-footer .spf__btn--primary.wp-block-button__link {
	background: var(--sp-green);
	color: #fff;
	box-shadow: 0 10px 26px rgba(0,186,112,0.42);
}

.site-footer .spf__btn--primary .wp-block-button__link:hover,
.site-footer .spf__btn--primary .wp-block-button__link:focus {
	background: var(--sp-green-600);
	color: #fff;
	transform: translateY(-2px);
}

.site-footer .spf__btn--primary .wp-block-button__link:hover svg,
.site-footer .spf__btn--primary .wp-block-button__link:focus svg {
	transform: translateX(3px);
}

.site-footer .spf__btn--ghost .wp-block-button__link,
.site-footer .spf__btn--ghost.wp-block-button__link {
	background: rgba(255,255,255,0.08);
	color: #fff;
	border: 1px solid rgba(255,255,255,0.28);
}

.site-footer .spf__btn--ghost .wp-block-button__link:hover,
.site-footer .spf__btn--ghost .wp-block-button__link:focus {
	background: rgba(255,255,255,0.16);
	color: #fff;
	transform: translateY(-2px);
}

.site-footer .spf__btn .wp-block-button__link:focus-visible,
.site-footer .spf a:focus-visible {
	outline: 2px solid #fff;
	outline-offset: 2px;
}

.site-footer .spf__cols {
	display: block;
	padding: 48px 0 44px;
}

.site-footer .spf__cols > .wp-block-group__inner-container {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 40px;
	width: 100%;
}

.site-footer .spf__col h4 {
	font: 700 14px/1 var(--sp-font-display) !important;
	letter-spacing: 1.4px;
	text-transform: uppercase;
	color: rgba(255,255,255,0.62);
	margin: 0 0 18px;
}

.site-footer .spf__col ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.site-footer .spf__col li {
	margin: 0;
	padding: 0;
	line-height: 0;
}

.site-footer .spf__col a {
	color: rgba(255,255,255,0.92);
	text-decoration: none;
	font: var(--sp-body-sm);
	display: inline-flex;
	align-items: center;
	gap: 8px;
	width: fit-content;
	transition: color .15s ease, transform .15s ease;
}

.site-footer .spf__col a:hover,
.site-footer .spf__col a:focus {
	color: #fff;
	transform: translateX(3px);
}

.site-footer .spf__col--contact .spf__contact a {
	word-break: break-word;
}

.site-footer .spf__bottom {
	display: block;
	padding-top: 26px;
	border-top: 1px solid rgba(255,255,255,0.16);
}

.site-footer .spf__bottom > .wp-block-group__inner-container {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 18px 28px;
	width: 100%;
}

.site-footer .spf__legal {
	display: block;
}

.site-footer .spf__legal > .wp-block-group__inner-container {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px 20px;
	font: var(--sp-caption);
	color: rgba(255,255,255,0.72);
	width: 100%;
}

.site-footer .spf__legal p,
.site-footer .spf__legal a {
	font: inherit;
	line-height: inherit;
	color: rgba(255,255,255,0.72);
	text-decoration: none;
}

.site-footer .spf__legal a:hover,
.site-footer .spf__legal a:focus {
	color: #fff;
	text-decoration: underline;
}

.site-footer .spf__dot {
	opacity: .4;
}

.site-footer .spf__cookie {
	appearance: none;
	background: none;
	border: 0;
	padding: 0;
	cursor: pointer;
	font: var(--sp-caption);
	color: rgba(255,255,255,0.72);
	display: inline-flex;
	align-items: center;
	gap: 6px;
	text-decoration: underline;
	text-decoration-style: dotted;
	text-underline-offset: 3px;
	transition: color .15s ease;
}

.site-footer .spf__cookie:hover,
.site-footer .spf__cookie:focus {
	color: #fff;
}

.site-footer .spf__lang {
	display: inline-flex;
	align-items: center;
	gap: 7px;
	color: rgba(255,255,255,0.72);
}

.site-footer .spf__lang svg {
	width: 15px;
	height: 15px;
	flex: none;
	opacity: .85;
}

.site-footer .spf__social {
	display: flex;
	align-items: center;
	gap: 10px;
}

.site-footer .spf__social a {
	width: 38px;
	height: 38px;
	border-radius: 50%;
	background: rgba(255,255,255,0.10);
	border: 1px solid rgba(255,255,255,0.18);
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	transition: background .15s ease, transform .15s ease;
}

.site-footer .spf__social a:hover,
.site-footer .spf__social a:focus {
	background: rgba(255,255,255,0.22);
	transform: translateY(-2px);
}

.site-footer .spf__social svg {
	width: 18px;
	height: 18px;
}

@media (max-width: 900px) {
	.site-footer .spf__top > .wp-block-group__inner-container {
		grid-template-columns: 1fr;
		align-items: start;
		gap: 36px;
	}

	.site-footer .spf__cta {
		justify-self: start;
		max-width: none;
	}

	.site-footer .spf__cols > .wp-block-group__inner-container {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 36px 32px;
	}
}

@media (max-width: 560px) {
	.site-footer .spf {
		--sp-body-lg: 400 17px/24px var(--sp-font-body);
		--sp-body-sm: 400 16px/23px var(--sp-font-body);
	}

	.site-footer .spf__cols > .wp-block-group__inner-container {
		grid-template-columns: 1fr;
		gap: 30px;
	}

	.site-footer .spf__bottom > .wp-block-group__inner-container {
		flex-direction: column;
		align-items: flex-start;
		gap: 20px;
	}

	.site-footer .spf__btn {
		flex: 1 1 auto;
	}

	.site-footer .spf__btn .wp-block-button__link {
		justify-content: center;
		width: 100%;
	}

	.site-footer .spf__cta-row {
		width: 100%;
	}
}
