.panel-footer {
	--surface-foreground: var(--primary-color-700);
	--surface-background: var(--primary-color-900);
	--text: var(--gray-100);

	color: var(--text);
	background: var(--brown);
	position: relative;
	margin-top: 52px;

	&:after {
		content: '';
		position: absolute;
		inset: 0;
		height: 105px;
		width: 105px;
		pointer-events: none;
		background-image: url(/includes/client_public/assets/shared/logos/travel-wyoming.png);
		background-size: cover;
		margin-inline: auto;
		pointer-events: none;
		translate: 0 -50%;
	}

	@media (min-width: 64em) {
		& {
			margin-top: 72px;
		}
		&:after {
			height: 145px;
			width: 145px;
		}
	}
}

.panel-footer .cta-container {
	background-color: var(--surface-background);
	padding: var(--space-20) 19px var(--space-12);
	position: relative;

	.wrapped-ctas {
		display: flex;
		flex-direction: column;
		gap: 30px;
	}
	& > h2 {
		font-weight: 700;
		color: #ffffff;
		font-size: var(--text-4xl);
		line-height: var(--leading-none);
		margin-bottom: var(--space-6);
		position: relative;
		z-index: 1;
	}

	.background-img {
		position: absolute;
		inset: 0;
		pointer-events: none;

		img {
			height: 100%;
			width: 100%;
			object-fit: cover;
		}

		&:after {
			content: '';
			position: absolute;
			top: 0;
			left: 0;
			height: 100%;
			width: 100%;
			pointer-events: none;
			background: linear-gradient(0deg, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.5) 100%);
		}
	}

	@media (min-width: 64em) {
		& > h2 {
			font-size: 2.625rem;
			line-height: var(--leading-none);
		}
		.wrapped-ctas {
			flex-direction: row;
			justify-content: space-between;
		}

		.plan-your-trip-cta .content {
			gap: 5px;
		}
	}
}

.panel-footer .cta-container > div:not(:first-child) {
	position: relative;
}

@media (min-width: 64em) {
	.panel-footer .cta-container {
		display: flex;
		flex-direction: column;
		padding-block: 53px 31px;
		border-bottom: 1px solid #fff;

		& > h2,
		& > .wrapped-ctas {
			position: relative;
			z-index: 1;
			max-width: 1261px;
			margin-inline: auto;
			padding-inline: var(--space-5);
			width: 100%;
		}
	}

	.panel-footer .cta-container > div {
		flex: 1 1 0;
	}

	.panel-footer .cta-container > div:not(:first-child)::before {
		left: 0;
		top: 50%;
		translate: 0 -50%;
		width: 2px;
		height: calc(100% - var(--space-10));
	}
}

.panel-footer .footer-content-container,
.panel-footer .attribution-content-container {
	margin: 0 auto;
	padding: 0 var(--space-5);
	max-width: 1260px;
	text-align: center;
}

.panel-footer .footer-content-container {
	display: grid;
	gap: var(--space-5);
	padding-block: var(--space-6) var(--space-12);
}

@media (min-width: 64em) {
	.panel-footer .footer-content-container {
		grid-template-columns: minmax(0, 1fr) minmax(0, 630px);
		text-align: left;
		justify-content: space-between;
		align-items: center;
		padding-block: var(--space-10);
	}
}

.panel-footer .contentRender_name_plugins_core_textbox {
	margin: 0;
	padding: 0;
	max-width: none;
}

.panel-footer .client-details {
	display: grid;
	grid-auto-rows: min-content;
	gap: var(--space-6);
	place-items: center;
}

@media (min-width: 64em) {
	.panel-footer .client-details {
		place-items: flex-start;
		gap: var(--space-3);
	}
}

.contentRender_name_plugins_common_logo_footer,
.panel-footer .logo-footer a {
	display: block;
	width: 220px;
}

.panel-footer .logo-footer img {
	display: block;
	width: 100%;
	height: auto;
}

.panel-footer .client-details p {
	font-weight: 400;
	color: #ffffff;
	font-size: 0.6875rem;
	line-height: 1.909;
}

.panel-footer .social-media {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 28px;
	align-items: flex-start;
}

.panel-footer .attribution-content-container p {
	font-size: var(--text-sm);
	line-height: var(--leading-snug);
}

.panel-footer .made-by-sv {
	display: block;
	width: 150px;
}

.panel-footer .made-by-sv img {
	display: block;
	width: 100%;
	height: auto;
}

/* Mobile Bottom Fixed Container */
.panel-footer .mobile-fixed {
	position: fixed;
	bottom: 0px;
	width: 100%;
	z-index: 9999;
}

.panel-footer .featuring-logos {
	display: flex;
	gap: 32px;

	@media (max-width: 63.9375em) {
		.thatswy-logo {
			max-width: 91px;
		}
		.usa-logo {
			max-width: 61px;
		}
	}
}

.panel-footer .navigation-footer,
.panel-footer .quick-links {
	text-align: left;
}
.panel-footer .quick-links {
	display: block;
	padding: 0;
}
.panel-footer .navigation-footer li {
	line-height: 1;
}
.panel-footer .navigation-footer a,
.panel-footer .quick-links a {
	font-family: var(--font-body);
	font-weight: 500;
	color: #ffffff;
	font-size: 0.8125rem;
	line-height: 1.615;
	text-decoration: none;
	max-width: 20ch;
	display: block;
}
.panel-footer .logos {
	display: grid;
	justify-content: center;
	justify-items: center;
	gap: var(--space-6);
	margin-bottom: var(--space-2);
}
.panel-footer .social-links {
	gap: var(--space-5);

	a {
		font-size: 1.75rem;
		color: #fff;
	}
}
.panel-footer .vw-app-logo {
	margin-block: var(--space-2);

	p {
		text-align: left;
		font-size: 0.875rem;
		text-transform: uppercase;
		font-weight: 700;
		margin-bottom: var(--space-4);
	}

	.app-logos {
		display: flex;
		gap: 10px;
	}

	@media (min-width: 64em) {
		& {
			margin-block: var(--space-2) 30px;
		}
		p {
			text-align: right;
			margin-bottom: 14px;
		}
		.app-logos {
			justify-content: flex-end;
		}
	}
}

.panel-footer .footer-ctas {
	background: #f9f7f2;
	display: flex;
	gap: 1px;
	flex-direction: column;

	.call-to-action {
		.inner {
			padding: 19px var(--space-5);
			background-color: var(--teal);
		}
		.title {
			font-family: var(--font-body);
			font-weight: 700;
			color: var(--gold-lighter);
			font-size: var(--text-sm);
			line-height: var(--leading-normal);
			text-transform: uppercase;

			.call-to-action:hover & {
				text-decoration: underline;
				color: var(--white);
			}
		}
		.icon {
			color: var(--white);
			font-size: 1.5rem;
		}
		.read-more {
			font-size: var(--text-sm);
			margin-left: 7px;
			display: inline-block;
		}
	}
	@media (min-width: 64em) {
		& {
			flex-direction: row;

			> div {
				flex-basis: 50%;
			}
		}
		.call-to-action {
			.inner {
				gap: var(--space-5);
			}
			.icon {
				font-size: 1.75rem;
			}
		}
	}
}
.panel-footer .footer-nav-weapper {
	display: grid;
	gap: var(--space-5);
}

@media (hover: hover) {
	.panel-footer .quick-links a:hover {
		text-decoration: none;
	}
}

@media (min-width: 64em) {
	.panel-footer .navigation-footer a,
	.panel-footer .quick-links a {
		font-size: 0.875rem;
		line-height: 1.515;
	}
	.panel-footer .navigation-footer {
		column-width: unset;
	}
	.panel-footer .footer-nav-weapper {
		display: flex;
		justify-content: flex-end;
		margin-bottom: 27px;
		gap: 96px;
	}
	.contentRender_name_plugins_common_logo_footer,
	.panel-footer .logo-footer a {
		width: 261px;
	}
	.panel-footer .logos {
		justify-items: start;
	}
	.panel-footer .client-details p {
		font-size: var(--text-xs);
		line-height: 1.75;
	}
	.panel-footer .made-by-sv {
		margin-left: auto;
	}
	.panel-footer .social-media {
		gap: var(--space-5);
	}
}
@media (max-width: 63.9375em) {
	.panel-footer .footer-nav,
	.panel-footer .client-details {
		display: contents;
	}

	.panel-footer .client-details .logos,
	.footer-nav-weapper {
		order: -1;
	}
}
