.site-footer {
	scroll-margin-top: 96px;
	border-top: 0;
	background: var(--tss-cream);
	color: var(--tss-black);
}

.tss-site-footer {
	position: relative;
	overflow: hidden;
	background:
		linear-gradient(180deg, rgba(255, 247, 223, 0.98), rgba(255, 247, 223, 1) 42%),
		var(--tss-cream);
	color: var(--tss-black);
	isolation: isolate;
}

.tss-site-footer::before {
	position: absolute;
	top: 34px;
	right: max(20px, calc((100vw - 1410px) / 2));
	z-index: -1;
	width: 96px;
	height: 66px;
	border-top: 3px solid rgba(16, 16, 16, 0.18);
	border-right: 3px solid rgba(16, 16, 16, 0.12);
	border-radius: 0 32px 0 0;
	content: "";
	transform: rotate(6deg);
	pointer-events: none;
}

.tss-site-footer__inner {
	width: min(1410px, calc(100% - 48px));
	margin: 0 auto;
}

.tss-site-footer__desk {
	position: relative;
	padding: clamp(32px, 3.6vw, 46px) 0 clamp(84px, 7vw, 112px);
	background:
		linear-gradient(180deg, transparent 0 calc(100% - 122px), rgba(255, 246, 186, 0.24) calc(100% - 64px), rgba(255, 246, 186, 0.08) 100%),
		linear-gradient(90deg, rgba(255, 246, 186, 0.28), transparent 36%),
		var(--tss-yellow);
	border-top: 2px solid var(--tss-black);
	border-bottom: 2px solid var(--tss-black);
	isolation: isolate;
}

.tss-site-footer__desk::before,
.tss-site-footer__desk::after {
	position: absolute;
	top: 50%;
	width: 30px;
	height: 30px;
	border: 2px solid var(--tss-black);
	border-radius: 999px;
	background: var(--tss-cream);
	content: "";
	transform: translateY(-50%);
}

.tss-site-footer__desk::before {
	left: -17px;
}

.tss-site-footer__desk::after {
	right: -17px;
}

.tss-site-footer__desk-inner {
	position: relative;
	z-index: 2;
	display: grid;
	grid-template-columns: minmax(300px, 450px) minmax(420px, 600px);
	justify-content: center;
	width: min(1120px, calc(100% - 64px));
	gap: clamp(28px, 4vw, 54px);
	align-items: center;
}

.tss-site-footer__promenade {
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 1;
	height: clamp(94px, 8vw, 124px);
	overflow: hidden;
	pointer-events: none;
	--tss-footer-park-cream: #fffdf4;
	--tss-footer-park-path: #f6f0d9;
	--tss-footer-park-sage: #dfe9c8;
	--tss-footer-park-sage-dark: #c5d8ad;
	--tss-footer-park-sage-deep: #a9bf8f;
	--tss-footer-park-pine: #a9bf8f;
	--tss-footer-park-pine-dark: #7f9f70;
	--tss-footer-park-flower: #ffd633;
	--tss-footer-park-flower-soft: #fff4bf;
}

.tss-site-footer__promenade::before {
	position: absolute;
	right: -5%;
	bottom: -26px;
	left: -5%;
	z-index: 1;
	height: clamp(72px, 6.6vw, 96px);
	border-top: 2px solid rgba(16, 16, 16, 0.22);
	background:
		radial-gradient(88px 28px at 8% 29%, rgba(255, 253, 244, 0.58) 0 62%, transparent 64%),
		radial-gradient(126px 34px at 24% 24%, rgba(197, 216, 173, 0.56) 0 62%, transparent 64%),
		radial-gradient(180px 44px at 78% 28%, rgba(223, 233, 200, 0.66) 0 62%, transparent 64%),
		radial-gradient(68px 22px at 91% 34%, rgba(255, 214, 51, 0.15) 0 60%, transparent 62%),
		linear-gradient(180deg, rgba(238, 244, 229, 0.96), rgba(202, 222, 183, 0.96));
	border-radius: 56% 44% 0 0 / 88% 76% 0 0;
	box-shadow: inset 0 12px 0 rgba(255, 253, 244, 0.28);
	content: "";
	transform: rotate(-0.5deg);
}

.tss-site-footer__promenade::after {
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 6;
	height: 18px;
	background: linear-gradient(180deg, transparent, rgba(16, 16, 16, 0.06));
	content: "";
}

.tss-site-footer__promenade-horizon,
.tss-site-footer__promenade-path {
	position: absolute;
	display: block;
}

.tss-site-footer__promenade-horizon {
	right: -6%;
	bottom: 54px;
	left: -6%;
	z-index: 1;
	height: clamp(58px, 5.6vw, 78px);
	background:
		radial-gradient(180px 54px at 10% 78%, rgba(197, 216, 173, 0.42) 0 64%, transparent 66%),
		radial-gradient(240px 66px at 46% 84%, rgba(223, 233, 200, 0.48) 0 66%, transparent 68%),
		radial-gradient(180px 50px at 86% 78%, rgba(197, 216, 173, 0.36) 0 62%, transparent 64%);
	opacity: 0.86;
}

.tss-site-footer__promenade-path {
	right: -6%;
	bottom: 24px;
	left: -6%;
	z-index: 3;
	height: clamp(34px, 3.2vw, 46px);
	border-top: 2px solid rgba(16, 16, 16, 0.28);
	border-bottom: 2px solid rgba(16, 16, 16, 0.16);
	background:
		radial-gradient(52px 18px at 13% 18%, rgba(255, 214, 51, 0.18) 0 62%, transparent 64%),
		radial-gradient(46px 16px at 82% 24%, rgba(0, 124, 120, 0.1) 0 60%, transparent 62%),
		linear-gradient(180deg, rgba(255, 253, 244, 0.94), rgba(244, 236, 207, 0.9));
	border-radius: 52% 48% 0 0 / 100% 88% 0 0;
	box-shadow:
		0 7px 0 rgba(16, 16, 16, 0.04),
		0 -10px 0 rgba(255, 253, 244, 0.18);
	transform: rotate(-0.35deg);
}

.tss-site-footer__promenade-path::before,
.tss-site-footer__promenade-path::after {
	position: absolute;
	content: "";
}

.tss-site-footer__promenade-path::before {
	top: 19px;
	right: 10%;
	left: 10%;
	height: 3px;
	border-radius: 999px;
	background: repeating-linear-gradient(90deg, rgba(16, 16, 16, 0.24) 0 15px, transparent 15px 31px);
	opacity: 0.74;
}

.tss-site-footer__promenade-path::after {
	top: 8px;
	right: 23%;
	width: 36px;
	height: 15px;
	border: 2px solid rgba(16, 16, 16, 0.24);
	border-radius: 7px;
	background: rgba(255, 253, 244, 0.72);
	transform: rotate(-6deg);
}

.tss-site-footer__promenade-pine,
.tss-site-footer__promenade-tree,
.tss-site-footer__promenade-shrub,
.tss-site-footer__promenade-flower,
.tss-site-footer__promenade-marker,
.tss-site-footer__promenade-signal {
	position: absolute;
	display: block;
}

.tss-site-footer__promenade-pine {
	bottom: 48px;
	z-index: 2;
	width: 38px;
	height: 66px;
	transform: scale(var(--tss-footer-pine-scale, 1));
	transform-origin: 50% 100%;
}

.tss-site-footer__promenade-pine::before {
	position: absolute;
	bottom: 0;
	left: 16px;
	width: 6px;
	height: 25px;
	border: 2px solid rgba(16, 16, 16, 0.52);
	border-bottom: 0;
	background: #c8ae79;
	content: "";
}

.tss-site-footer__promenade-pine::after {
	position: absolute;
	top: 0;
	left: 0;
	width: 38px;
	height: 54px;
	border: 2px solid rgba(16, 16, 16, 0.34);
	border-radius: 3px 3px 13px 13px;
	background:
		linear-gradient(135deg, transparent 0 30%, var(--tss-footer-park-pine) 31% 68%, transparent 69%),
		linear-gradient(155deg, transparent 0 25%, var(--tss-footer-park-pine-dark) 26% 64%, transparent 65%),
		linear-gradient(25deg, transparent 0 28%, #dfe9c8 29% 66%, transparent 67%);
	clip-path: polygon(50% 0, 88% 34%, 72% 34%, 100% 70%, 66% 70%, 86% 100%, 14% 100%, 34% 70%, 0 70%, 28% 34%, 12% 34%);
	content: "";
}

.tss-site-footer__promenade-pine--one {
	left: max(22px, calc((100vw - 1120px) / 2 + 18px));
	--tss-footer-pine-scale: 0.74;
}

.tss-site-footer__promenade-pine--two {
	right: max(48px, calc((100vw - 1120px) / 2 + 92px));
	bottom: 50px;
	--tss-footer-pine-scale: 0.64;
}

.tss-site-footer__promenade-tree {
	bottom: 42px;
	z-index: 2;
	width: 34px;
	height: 72px;
	transform: scale(var(--tss-footer-tree-scale, 1));
	transform-origin: 50% 100%;
}

.tss-site-footer__promenade-tree::before {
	position: absolute;
	bottom: 0;
	left: 14px;
	width: 8px;
	height: 32px;
	border: 2px solid rgba(16, 16, 16, 0.58);
	border-bottom: 0;
	background: #c8ae79;
	content: "";
}

.tss-site-footer__promenade-tree::after {
	position: absolute;
	top: 0;
	left: 0;
	width: 34px;
	height: 52px;
	border: 2px solid rgba(16, 16, 16, 0.4);
	border-radius: 22px 22px 15px 15px;
	background: var(--tss-footer-park-sage);
	box-shadow:
		-11px 16px 0 -5px var(--tss-footer-park-sage-dark),
		10px 19px 0 -6px #eef4e5;
	content: "";
}

.tss-site-footer__promenade-tree--left {
	left: max(72px, calc((100vw - 1120px) / 2 + 96px));
	--tss-footer-tree-scale: 0.72;
}

.tss-site-footer__promenade-tree--right {
	right: max(92px, calc((100vw - 1120px) / 2 + 142px));
	bottom: 40px;
	--tss-footer-tree-scale: 0.64;
}

.tss-site-footer__promenade-shrub {
	bottom: 29px;
	z-index: 4;
	width: 72px;
	height: 28px;
	border: 2px solid rgba(16, 16, 16, 0.24);
	border-radius: 999px 999px 0 0;
	background:
		radial-gradient(circle at 22% 62%, #eef4e5 0 12px, transparent 13px),
		radial-gradient(circle at 52% 48%, var(--tss-footer-park-sage-dark) 0 16px, transparent 17px),
		radial-gradient(circle at 80% 66%, var(--tss-footer-park-sage) 0 12px, transparent 13px);
	transform: scale(var(--tss-footer-shrub-scale, 1));
	transform-origin: 50% 100%;
}

.tss-site-footer__promenade-shrub--one {
	left: max(142px, calc((100vw - 1120px) / 2 + 188px));
	--tss-footer-shrub-scale: 0.78;
}

.tss-site-footer__promenade-shrub--two {
	left: 48%;
	bottom: 27px;
	opacity: 0.72;
	--tss-footer-shrub-scale: 0.62;
}

.tss-site-footer__promenade-shrub--three {
	right: max(132px, calc((100vw - 1120px) / 2 + 210px));
	bottom: 30px;
	--tss-footer-shrub-scale: 0.7;
}

.tss-site-footer__promenade-flower {
	bottom: 25px;
	z-index: 5;
	width: 8px;
	height: 8px;
	border: 1px solid rgba(16, 16, 16, 0.24);
	border-radius: 999px;
	background: var(--tss-footer-park-flower);
	box-shadow:
		9px -3px 0 -1px var(--tss-footer-park-flower-soft),
		18px 1px 0 -1px var(--tss-footer-park-sage-deep),
		28px -2px 0 -1px var(--tss-footer-park-flower),
		38px 2px 0 -1px var(--tss-footer-park-flower-soft);
}

.tss-site-footer__promenade-flower--one {
	left: max(28px, calc((100vw - 1120px) / 2 + 44px));
}

.tss-site-footer__promenade-flower--two {
	left: 33%;
	bottom: 23px;
	transform: scale(0.8);
}

.tss-site-footer__promenade-flower--three {
	right: max(42px, calc((100vw - 1120px) / 2 + 58px));
	bottom: 24px;
	transform: scale(0.84);
}

.tss-site-footer__promenade-marker {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	bottom: 68px;
	z-index: 4;
	width: auto;
	min-width: 58px;
	min-height: 20px;
	padding: 0 8px;
	border: 2px solid rgba(16, 16, 16, 0.58);
	border-radius: 7px;
	background:
		linear-gradient(135deg, transparent 0 42%, rgba(16, 16, 16, 0.18) 43% 48%, transparent 49%),
		rgba(255, 253, 244, 0.92);
	color: rgba(16, 16, 16, 0.82);
	font-size: 9px;
	font-weight: 950;
	line-height: 1;
	text-transform: uppercase;
	white-space: nowrap;
	box-shadow: 2px 2px 0 rgba(16, 16, 16, 0.13);
}

.tss-site-footer__promenade-marker > span {
	display: block;
}

.tss-site-footer__promenade-marker::before {
	position: absolute;
	top: 100%;
	left: 50%;
	width: 2px;
	height: 19px;
	background: rgba(16, 16, 16, 0.62);
	content: "";
	transform: translateX(-50%);
}

.tss-site-footer__promenade-marker::after {
	position: absolute;
	top: 50%;
	right: 5px;
	width: 4px;
	height: 4px;
	border-radius: 999px;
	background: rgba(16, 16, 16, 0.42);
	content: "";
	transform: translateY(-50%);
}

.tss-site-footer__promenade-marker--left {
	left: max(40px, calc((100vw - 1120px) / 2 + 52px));
	transform: rotate(-3deg);
}

.tss-site-footer__promenade-marker--right {
	right: max(28px, calc((100vw - 1120px) / 2 + 36px));
	border-color: var(--tss-black);
	background:
		linear-gradient(135deg, transparent 0 42%, rgba(16, 16, 16, 0.18) 43% 48%, transparent 49%),
		var(--tss-yellow);
	color: var(--tss-black);
	transform: rotate(2deg);
}

.tss-site-footer__promenade-signal {
	right: clamp(118px, 26vw, 420px);
	bottom: 42px;
	z-index: 5;
	width: 11px;
	height: 11px;
	border: 2px solid rgba(16, 16, 16, 0.42);
	border-radius: 999px;
	background: var(--tss-yellow);
	opacity: 0.48;
	box-shadow:
		0 0 0 5px rgba(255, 253, 244, 0.34),
		0 0 0 10px rgba(0, 124, 120, 0.1);
}

.tss-site-footer__desk:focus-within .tss-site-footer__promenade-signal {
	animation: tss-footer-promenade-signal 960ms ease-out 1 both;
}

@keyframes tss-footer-promenade-signal {
	0% {
		opacity: 0.36;
		transform: translateX(-12px) scale(0.86);
	}

	45% {
		opacity: 0.9;
		transform: translateX(0) scale(1.1);
		box-shadow:
			0 0 0 7px rgba(255, 253, 244, 0.5),
			0 0 0 14px rgba(0, 124, 120, 0.16);
	}

	100% {
		opacity: 0.52;
		transform: translateX(0) scale(1);
	}
}

@media (prefers-reduced-motion: reduce) {
	.tss-site-footer__desk:focus-within .tss-site-footer__promenade-signal {
		animation: none;
	}
}

.tss-site-footer__desk-copy {
	max-width: 480px;
}

.tss-site-footer__eyebrow,
.tss-site-footer__search-label {
	display: inline-flex;
	align-items: center;
	width: fit-content;
	min-height: 24px;
	margin: 0;
	padding: 0 10px;
	border: 1px solid var(--tss-black);
	border-radius: 999px;
	background: var(--tss-cream);
	color: var(--tss-black);
	font-size: 11px;
	font-weight: 850;
	line-height: 1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.tss-site-footer h2,
.tss-site-footer h3,
.tss-site-footer p,
.tss-site-footer ul {
	margin-top: 0;
}

.tss-site-footer h2 {
	max-width: 480px;
	margin: 10px 0 10px;
	font-size: 46px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0;
}

.tss-site-footer__desk-copy p:last-child {
	max-width: 390px;
	margin-bottom: 0;
	color: rgba(16, 16, 16, 0.78);
	font-size: 17px;
	line-height: 1.42;
}

.tss-site-footer__desk-tools {
	position: relative;
	display: grid;
	width: 100%;
	max-width: 620px;
	align-self: stretch;
	align-content: center;
	padding: 14px 0 0;
}

.tss-site-footer__search-label {
	position: absolute;
	top: calc(50% - 54px);
	left: 22px;
	z-index: 2;
	background: var(--tss-black);
	color: var(--tss-yellow);
}

.tss-site-footer__search {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 8px;
	padding: 8px;
	border: 2px solid var(--tss-black);
	border-radius: 21px;
	background: var(--tss-cream);
	box-shadow: 7px 7px 0 rgba(16, 16, 16, 0.14);
	transform: rotate(-0.2deg);
}

.tss-site-footer__search input[type="search"],
.tss-site-footer__search input[type="email"] {
	width: 100%;
	min-height: 52px;
	padding: 0 18px;
	border: 0;
	border-radius: 14px;
	background: #fffdf4;
	color: var(--tss-black);
	font-size: 16px;
	font-weight: 750;
}

.tss-site-footer__search button {
	min-width: 132px;
	min-height: 52px;
	border: 0;
	border-radius: 14px;
	background: var(--tss-black);
	color: #fff;
	font-size: 14px;
	font-weight: 850;
}

.tss-site-footer__search button:hover,
.tss-site-footer__search button:focus {
	background: var(--tss-teal);
	color: #fff;
}

.tss-site-footer .tss-site-footer__signup-note,
.tss-site-footer .tss-site-footer__signup-status {
	max-width: 600px;
	margin: 24px 0 0;
	color: rgba(16, 16, 16, 0.62);
	font-size: 12px;
	font-weight: 650;
	line-height: 1.45;
}

.tss-site-footer__signup-note a {
	color: var(--tss-black);
	font-weight: 850;
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 3px;
}

.tss-site-footer .tss-site-footer__signup-status {
	width: fit-content;
	margin-top: 8px;
	padding: 7px 10px;
	border: 1px solid rgba(16, 16, 16, 0.28);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.36);
	color: var(--tss-black);
}

.tss-site-footer__signup-status--success {
	border-color: rgba(0, 124, 120, 0.32);
	background: rgba(0, 124, 120, 0.1);
}

.tss-site-footer__main {
	position: relative;
	display: grid;
	grid-template-columns: minmax(210px, 0.72fr) minmax(500px, 1.46fr) minmax(260px, 0.82fr);
	gap: clamp(26px, 3.5vw, 54px);
	align-items: start;
	padding: clamp(48px, 5vw, 72px) 0 clamp(44px, 5vw, 66px);
}

.tss-site-footer__main::before {
	position: absolute;
	top: 38px;
	right: 0;
	left: 0;
	z-index: -1;
	height: 2px;
	background: linear-gradient(90deg, transparent, rgba(16, 16, 16, 0.12), transparent);
	content: "";
}

.tss-site-footer__brand {
	position: relative;
	display: grid;
	justify-items: center;
	text-align: center;
}

.tss-site-footer__brand img {
	display: block;
	width: min(190px, 78%);
	height: auto;
	margin: 0 auto 18px;
	filter: drop-shadow(0 10px 16px rgba(16, 16, 16, 0.14));
	transform: rotate(-1.6deg);
}

.tss-site-footer__brand p,
.tss-site-footer__bottom p,
.tss-site-footer__notes li {
	color: rgba(16, 16, 16, 0.7);
	font-size: 14px;
	line-height: 1.55;
}

.tss-site-footer__brand p {
	max-width: 260px;
	margin-bottom: 18px;
	margin-right: auto;
	margin-left: auto;
	font-weight: 700;
}

.tss-site-footer__brand-tags {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 7px;
	max-width: 260px;
	margin-right: auto;
	margin-left: auto;
}

.tss-site-footer__brand-tags span {
	display: inline-flex;
	align-items: center;
	min-height: 28px;
	padding: 0 10px;
	border: 1px dashed rgba(16, 16, 16, 0.32);
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.38);
	color: rgba(16, 16, 16, 0.76);
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
}

.tss-site-footer__directory {
	position: relative;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: clamp(18px, 2.2vw, 34px);
	padding: 34px clamp(24px, 3vw, 38px) 28px;
	border: 2px solid var(--tss-black);
	border-radius: 10px;
	background:
		linear-gradient(90deg, rgba(255, 214, 51, 0.13) 0 1px, transparent 1px 100%),
		#fffdf4;
	background-size: 26px 100%;
	box-shadow: 9px 9px 0 rgba(16, 16, 16, 0.11);
	counter-reset: tss-footer-column;
}

.tss-site-footer__directory::before {
	position: absolute;
	top: -14px;
	left: 24px;
	padding: 6px 12px;
	border: 2px solid var(--tss-black);
	border-radius: 999px;
	background: var(--tss-yellow);
	color: var(--tss-black);
	content: "Quick shelf";
	font-size: 11px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
}

.tss-site-footer__directory::after {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 42px;
	height: 28px;
	border-top: 2px solid rgba(16, 16, 16, 0.18);
	border-right: 2px solid rgba(16, 16, 16, 0.18);
	border-radius: 0 18px 0 0;
	content: "";
}

.tss-site-footer__column h3,
.tss-site-footer__notes h3 {
	margin-bottom: 18px;
	font-size: 13px;
	font-weight: 900;
	line-height: 1.1;
	text-transform: uppercase;
	letter-spacing: 0;
}

.tss-site-footer__column h3 {
	display: flex;
	gap: 9px;
	align-items: center;
}

.tss-site-footer__column h3::before {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 999px;
	background: var(--tss-black);
	color: var(--tss-yellow);
	content: "0" counter(tss-footer-column);
	counter-increment: tss-footer-column;
	font-size: 10px;
	font-weight: 900;
	line-height: 1;
}

.tss-site-footer__column ul,
.tss-site-footer__notes ul {
	display: grid;
	gap: 11px;
	margin-bottom: 0;
	padding: 0;
	list-style: none;
}

.tss-site-footer__column a {
	position: relative;
	display: inline-flex;
	align-items: center;
	color: rgba(16, 16, 16, 0.74);
	font-size: 14px;
	font-weight: 750;
	line-height: 1.35;
	text-decoration: none;
}

.tss-site-footer__column a::before {
	width: 0;
	height: 2px;
	margin-right: 0;
	background: var(--tss-teal);
	content: "";
	transition: width 160ms ease, margin-right 160ms ease;
}

.tss-site-footer__column a:hover,
.tss-site-footer__column a:focus {
	color: var(--tss-black);
}

.tss-site-footer__column a:hover::before,
.tss-site-footer__column a:focus::before {
	width: 14px;
	margin-right: 7px;
}

.tss-site-footer__notes {
	position: relative;
	padding: 28px 22px 22px;
	border: 2px solid var(--tss-black);
	border-radius: 10px;
	background: #fffdf4;
	box-shadow: 7px 7px 0 rgba(0, 124, 120, 0.16);
	transform: rotate(0.45deg);
}

.tss-site-footer__notes::before {
	position: absolute;
	top: -14px;
	left: 18px;
	padding: 6px 11px;
	border: 2px solid var(--tss-black);
	border-radius: 999px;
	background: var(--tss-yellow);
	color: var(--tss-black);
	content: "Before you go";
	font-size: 10px;
	font-weight: 900;
	line-height: 1;
	text-transform: uppercase;
}

.tss-site-footer__notes::after {
	position: absolute;
	top: 14px;
	right: 14px;
	width: 14px;
	height: 14px;
	border: 2px solid rgba(16, 16, 16, 0.22);
	border-radius: 999px;
	background: var(--tss-cream);
	content: "";
}

.tss-site-footer__notes h3 {
	margin-top: 2px;
}

.tss-site-footer__notes li {
	position: relative;
	padding-left: 18px;
}

.tss-site-footer__notes li::before {
	position: absolute;
	top: 0.68em;
	left: 0;
	width: 6px;
	height: 6px;
	border-radius: 999px;
	background: var(--tss-teal);
	content: "";
}

.tss-site-footer__bottom {
	background: var(--tss-black);
	color: var(--tss-cream);
}

.tss-site-footer__bottom-inner {
	display: grid;
	grid-template-columns: max-content minmax(220px, max-content) minmax(280px, 720px);
	align-items: center;
	justify-content: space-between;
	gap: 10px clamp(24px, 4vw, 56px);
	padding: clamp(18px, 2vw, 24px) 0 clamp(20px, 2.4vw, 28px);
}

.tss-site-footer__bottom p {
	margin-bottom: 0;
	color: rgba(255, 247, 223, 0.78);
	max-width: 72ch;
}

.tss-site-footer__bottom p:first-child {
	color: var(--tss-yellow);
	font-weight: 850;
	white-space: nowrap;
}

.tss-site-footer__company-id {
	font-weight: 760;
}

.tss-site-footer__company-id span {
	white-space: nowrap;
}

.tss-site-footer__company-id span::before {
	content: "|";
	display: inline-block;
	margin: 0 8px;
	color: rgba(255, 214, 51, 0.8);
}

.tss-site-footer__legal-note {
	justify-self: end;
	text-align: right;
}

.tss-company-details-note {
	max-width: 1180px;
	margin: clamp(24px, 3vw, 36px) auto 0;
	border: 1px solid rgba(16, 16, 16, 0.12);
	border-radius: 10px;
	padding: clamp(18px, 2.4vw, 26px);
	background:
		linear-gradient(135deg, rgba(255, 214, 51, 0.14), rgba(223, 244, 242, 0.38)),
		#fffdf4;
	box-shadow: 0 2px 0 rgba(16, 16, 16, 0.08);
}

.tss-company-details-note h2 {
	margin: 0 0 8px;
	color: var(--tss-black);
	font-size: clamp(20px, 2vw, 26px);
	font-weight: 900;
	line-height: 1.1;
}

.tss-company-details-note p {
	max-width: 72ch;
	margin: 0;
	color: var(--tss-ink-soft);
	font-size: 14px;
	font-weight: 680;
	line-height: 1.5;
}

@media (max-width: 960px) {
	.tss-site-footer__bottom-inner {
		align-items: start;
		grid-template-columns: 1fr;
		gap: 8px;
		justify-content: start;
	}

	.tss-site-footer__legal-note {
		justify-self: start;
		text-align: left;
	}

	.tss-site-footer__company-id span {
		display: block;
		white-space: normal;
	}

	.tss-site-footer__company-id span::before {
		display: none;
	}
}

@media (max-width: 1180px) {
	.tss-site-footer__desk-inner,
	.tss-site-footer__main {
		grid-template-columns: 1fr;
	}

	.tss-site-footer__desk-inner {
		width: min(760px, calc(100% - 48px));
		gap: 24px;
		justify-items: center;
		text-align: center;
	}

	.tss-site-footer__desk-copy {
		max-width: 620px;
	}

	.tss-site-footer__desk-copy p:last-child {
		max-width: 430px;
		margin-right: auto;
		margin-left: auto;
	}

	.tss-site-footer__eyebrow {
		margin-right: auto;
		margin-left: auto;
	}

	.tss-site-footer__desk-tools {
		align-self: center;
		justify-self: center;
	}

	.tss-site-footer__search-label {
		top: 0;
		left: 50%;
		white-space: nowrap;
		transform: translateX(-50%);
	}

	.tss-site-footer h2 {
		font-size: 42px;
	}

	.tss-site-footer__directory {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}

	.tss-site-footer__brand {
		display: grid;
		grid-template-columns: minmax(0, 360px);
		align-items: center;
		justify-content: center;
		justify-items: center;
		text-align: center;
	}

	.tss-site-footer__brand img {
		width: 170px;
		margin: 0 auto 16px;
	}
}

@media (max-width: 820px) {
	.tss-site-footer__inner {
		width: min(100% - 32px, 680px);
	}

	.tss-site-footer__desk {
		padding-top: 32px;
		padding-bottom: 86px;
	}

	.tss-site-footer__promenade {
		height: 86px;
	}

	.tss-site-footer__promenade-horizon {
		bottom: 42px;
		height: 54px;
	}

	.tss-site-footer__promenade-path {
		bottom: 18px;
		height: 34px;
	}

	.tss-site-footer__promenade-pine--one {
		left: 24px;
		--tss-footer-pine-scale: 0.6;
	}

	.tss-site-footer__promenade-tree--left {
		left: 72px;
		--tss-footer-tree-scale: 0.56;
	}

	.tss-site-footer__promenade-tree--right {
		right: 78px;
		--tss-footer-tree-scale: 0.52;
	}

	.tss-site-footer__promenade-shrub--one {
		left: 132px;
		--tss-footer-shrub-scale: 0.62;
	}

	.tss-site-footer__promenade-shrub--three {
		right: 118px;
		--tss-footer-shrub-scale: 0.58;
	}

	.tss-site-footer__promenade-marker {
		bottom: 54px;
	}

	.tss-site-footer h2 {
		font-size: 36px;
		line-height: 1.02;
	}

	.tss-site-footer__main {
		gap: 28px;
		padding-top: 48px;
		padding-bottom: 40px;
	}

	.tss-site-footer__brand {
		display: block;
		text-align: center;
	}

	.tss-site-footer__brand img {
		width: 154px;
		margin: 0 auto 16px;
	}

	.tss-site-footer__brand p {
		margin-right: auto;
		margin-left: auto;
	}

	.tss-site-footer__brand-tags {
		justify-content: center;
		margin-right: auto;
		margin-left: auto;
	}

	.tss-site-footer__directory {
		grid-template-columns: 1fr;
		gap: 26px;
		padding: 32px 22px 26px;
	}

	.tss-site-footer__notes {
		transform: none;
	}
}

@media (max-width: 767px) {
	.tss-site-footer__notes {
		display: none;
	}
}

@media (max-width: 480px) {
	.tss-site-footer__desk {
		padding-top: 26px;
		padding-bottom: 72px;
	}

	.tss-site-footer__promenade {
		height: 64px;
	}

	.tss-site-footer__promenade::before {
		bottom: -21px;
		height: 52px;
	}

	.tss-site-footer__promenade::after {
		height: 12px;
	}

	.tss-site-footer__promenade-horizon {
		bottom: 31px;
		height: 42px;
	}

	.tss-site-footer__promenade-path {
		bottom: 14px;
		height: 24px;
		background:
			radial-gradient(42px 14px at 18% 18%, rgba(255, 214, 51, 0.16) 0 62%, transparent 64%),
			linear-gradient(180deg, rgba(255, 253, 244, 0.96), rgba(244, 236, 207, 0.9));
	}

	.tss-site-footer__promenade-path::before {
		top: 12px;
		right: 9%;
		left: 9%;
		height: 2px;
		background: repeating-linear-gradient(90deg, rgba(16, 16, 16, 0.22) 0 10px, transparent 10px 22px);
	}

	.tss-site-footer__promenade-path::after,
	.tss-site-footer__promenade-pine,
	.tss-site-footer__promenade-marker,
	.tss-site-footer__promenade-tree--right,
	.tss-site-footer__promenade-shrub--two,
	.tss-site-footer__promenade-flower--two,
	.tss-site-footer__promenade-signal {
		display: none;
	}

	.tss-site-footer__promenade-tree--left {
		left: 18px;
		bottom: 28px;
		--tss-footer-tree-scale: 0.44;
	}

	.tss-site-footer__promenade-shrub {
		bottom: 18px;
	}

	.tss-site-footer__promenade-shrub--one {
		left: 70px;
		--tss-footer-shrub-scale: 0.52;
	}

	.tss-site-footer__promenade-shrub--three {
		right: 52px;
		bottom: 19px;
		--tss-footer-shrub-scale: 0.48;
	}

	.tss-site-footer__promenade-flower--one {
		left: 44%;
		bottom: 16px;
		transform: scale(0.72);
	}

	.tss-site-footer__promenade-flower--three {
		right: 16px;
		bottom: 17px;
		transform: scale(0.64);
	}

	.tss-site-footer__desk-tools {
		max-width: 342px;
		padding-top: 14px;
	}

	.tss-site-footer__search {
		grid-template-columns: minmax(0, 1fr) 118px;
		gap: 6px;
		padding: 6px;
		border-radius: 18px;
		box-shadow: 4px 4px 0 rgba(16, 16, 16, 0.14);
		transform: none;
	}

	.tss-site-footer__search input[type="search"],
	.tss-site-footer__search input[type="email"] {
		min-height: 46px;
		padding: 0 14px;
		border-radius: 12px;
		font-size: 14px;
	}

	.tss-site-footer__search button {
		width: auto;
		min-width: 118px;
		min-height: 46px;
		border-radius: 12px;
		font-size: 13px;
	}

	.tss-site-footer .tss-site-footer__signup-note,
	.tss-site-footer .tss-site-footer__signup-status {
		margin-right: auto;
		margin-left: auto;
		font-size: 10px;
		text-align: center;
	}

	.tss-site-footer h2 {
		max-width: 320px;
		font-size: 30px;
	}

	.tss-site-footer__desk-copy p:last-child {
		max-width: 310px;
		font-size: 16px;
	}

	.tss-site-footer__search-label {
		left: 12px;
		max-width: calc(100% - 24px);
		min-height: 22px;
		font-size: 10px;
		transform: none;
	}

	.tss-site-footer__brand-tags {
		max-width: none;
	}

	.tss-site-footer__bottom-inner {
		padding-top: 20px;
		padding-bottom: 24px;
	}

	.tss-site-footer__bottom p {
		font-size: 13px;
		line-height: 1.5;
	}
}

@media (max-width: 360px) {
	.tss-site-footer__search {
		grid-template-columns: minmax(0, 1fr) 104px;
	}

	.tss-site-footer__search input[type="search"],
	.tss-site-footer__search input[type="email"] {
		padding: 0 12px;
		font-size: 13px;
	}

	.tss-site-footer__search button {
		min-width: 104px;
		font-size: 12px;
	}
}
