
@charset "UTF-8";

:root {
	font-size: 62.5%;
	--font-size: calc(1.7rem + .3 * var(--fluid-scale));
	--font-size-lg: calc(2.3rem + .5 * var(--fluid-scale));
	--font-size-md: calc(1.8rem + .6 * var(--fluid-scale));
	--font-size-sm: 1.6rem;
	--font-size-xs: 1.4rem;
	--font-body: "HKGrotesk", sans-serif;
	--font-heading: "HKGrotesk", sans-serif;
	--layout: 1680px;
	--gutter: calc(2.25rem + 11.25 * var(--fluid-scale));
	--gutters: calc(var(--gutter) * 2);
	--header-height: 75px;
	--shadow-sm: 0px 10px 15px -3px rgba(0, 0, 0, .1), 0px 4px 6px -4px rgba(0, 0, 0, .1);
	--shadow-lg: 0px 20px 50px -12px rgba(0, 0, 0, .25);
	--fluid-min-width: 375;
	--fluid-max-width: 1680;
	--fluid-screen: clamp(calc(var(--fluid-min-width) / 10 * 1rem), calc(var(--fluid-max-width) / 10 * 1rem), 100vw);
	--fluid-scale: calc(( var(--fluid-screen) - var(--fluid-min-width) / 10 * 1rem ) / ( ( var(--fluid-max-width) - var(--fluid-min-width) ) / 10 ));
	--image-ratio: .667;
	--c-red: #82292f;
	--c-red-dark: #441519;
	--c-red-light: #b13840;
	--c-gray-dark: #808080;
	--c-gray-darker: #3e3e3e;
	--c-gray-darkest: #1d1d1d;
	--c-gray-light: #bdbdbd;
	--c-gray-light-alt: #d9d9d9;
	--c-gray-lighter: #ebebeb;
	--c-gray-lightest: #f8f8f8;
	--c-green: #115e59;
	--c-black: #000;
	--c-white: #fff;
	--s-1-min: 10;
	--s-1-max: 10;
	--s-2-min: var(--s-1-min) * 1.375;
	--s-2-max: var(--s-1-max) * 1.565;
	--s-3-min: var(--s-2-min) * 1.375;
	--s-3-max: var(--s-2-max) * 1.565;
	--s-4-min: var(--s-3-min) * 1.375;
	--s-4-max: var(--s-3-max) * 1.565;
	--s-5-min: var(--s-4-min) * 1.375;
	--s-5-max: var(--s-4-max) * 1.565;
	--s-6-min: var(--s-5-min) * 1.375;
	--s-6-max: var(--s-5-max) * 1.565;
	--s-7-min: var(--s-6-min) * 1.375;
	--s-7-max: var(--s-6-max) * 1.565;
	--s-8-min: var(--s-7-min) * 1.375;
	--s-8-max: var(--s-7-max) * 1.565;
	--s-1: calc(( var(--s-1-min) / 10 * 1rem ) + ( ( var(--s-1-max) - var(--s-1-min) ) / 10 ) * var(--fluid-scale));
	--s-2: calc(( var(--s-2-min) / 10 * 1rem ) + ( ( var(--s-2-max) - var(--s-2-min) ) / 10 ) * var(--fluid-scale));
	--s-3: calc(( var(--s-3-min) / 10 * 1rem ) + ( ( var(--s-3-max) - var(--s-3-min) ) / 10 ) * var(--fluid-scale));
	--s-4: calc(( var(--s-4-min) / 10 * 1rem ) + ( ( var(--s-4-max) - var(--s-4-min) ) / 10 ) * var(--fluid-scale));
	--s-5: calc(( var(--s-5-min) / 10 * 1rem ) + ( ( var(--s-5-max) - var(--s-5-min) ) / 10 ) * var(--fluid-scale));
	--s-6: calc(( var(--s-6-min) / 10 * 1rem ) + ( ( var(--s-6-max) - var(--s-6-min) ) / 10 ) * var(--fluid-scale));
	--s-7: calc(( var(--s-7-min) / 10 * 1rem ) + ( ( var(--s-7-max) - var(--s-7-min) ) / 10 ) * var(--fluid-scale));
	--s-8: calc(( var(--s-8-min) / 10 * 1rem ) + ( ( var(--s-8-max) - var(--s-8-min) ) / 10 ) * var(--fluid-scale));
	--theme-background: #fff;
	--theme-text: #3e3e3e;
}

.theme-gray {
	--theme-background: #d9d9d9;
	background-color: var(--theme-background);
	color: var(--theme-text);
}

.theme-dark {
	--theme-background: #141a21;
	--theme-text: #fff;
	background-color: var(--theme-background);
	color: var(--theme-text);
}

*, *:before, *:after {
	box-sizing: border-box;
	border: 0;
	margin: 0;
	padding: 0;
}

html, body {
	height: 100%;
}

body {
	-webkit-tap-highlight-color: transparent;
	-webkit-text-size-adjust: none;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	-moz-text-size-adjust: none;
	text-size-adjust: none;
}

img, picture, video, canvas, iframe, svg {
	display: block;
	max-width: 100%;
}

h1, h2, h3, h4, h5, h6, blockquote, p {
	overflow-wrap: break-word;
}

input, button, textarea, select {
	font: inherit;
	border-radius: 0;
}

address {
	font-style: normal;
}

button {
	background-color: transparent;
	outline: none;
	cursor: pointer;
	color: inherit;
}

button[disabled] {
	pointer-events: none;
}

ol, ul {
	list-style: none;
}

table {
	border-collapse: collapse;
}

img {
	height: auto;
	object-fit: cover;
}

input[type=search]::-webkit-search-decoration, input[type=search]::-webkit-search-cancel-button {
	-webkit-appearance: none;
}

input::-webkit-outer-spin-button, input::-webkit-inner-spin-button {
	-webkit-appearance: none;
}

input[type=number] {
	-moz-appearance: textfield;
}

[tabindex]:not(input):not(textarea):focus, a:focus, button:focus {
	outline: 1px dotted rgba(128, 128, 128, .5);
}

:focus:not(:focus-visible) {
	outline: none;
}

@media (prefers-reduced-motion: reduce) {
	* {
		scroll-behavior: auto !important;
		animation-duration: .01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: .01ms !important;
	}
}

@media print {
	body * {
		display: none !important;
	}
	
	body:after {
		position: absolute;
		left: 50%;
		top: 50%;
		transform: translate(-50%, -50%);
		content: "Please don\'t waste paper";
	}
}

:root {
	--ease-in-quad: cubic-bezier(.55, .085, .68, .53);
	--ease-in-cubic: cubic-bezier(.55, .055, .675, .19);
	--ease-in-quart: cubic-bezier(.895, .03, .685, .22);
	--ease-in-quint: cubic-bezier(.755, .05, .855, .06);
	--ease-in-sine: cubic-bezier(.47, 0, .745, .715);
	--ease-in-expo: cubic-bezier(.95, .05, .795, .035);
	--ease-in-circ: cubic-bezier(.6, .04, .98, .335);
	--ease-in-back: cubic-bezier(.6, -.28, .735, .045);
	--ease-out-quad: cubic-bezier(.25, .46, .45, .94);
	--ease-out-cubic: cubic-bezier(.215, .61, .355, 1);
	--ease-out-quart: cubic-bezier(.165, .84, .44, 1);
	--ease-out-quint: cubic-bezier(.23, 1, .32, 1);
	--ease-out-sine: cubic-bezier(.39, .575, .565, 1);
	--ease-out-expo: cubic-bezier(.19, 1, .22, 1);
	--ease-out-circ: cubic-bezier(.075, .82, .165, 1);
	--ease-out-back: cubic-bezier(.175, .885, .32, 1.275);
	--ease-in-out-quad: cubic-bezier(.455, .03, .515, .955);
	--ease-in-out-cubic: cubic-bezier(.645, .045, .355, 1);
	--ease-in-out-quart: cubic-bezier(.77, 0, .175, 1);
	--ease-in-out-quint: cubic-bezier(.86, 0, .07, 1);
	--ease-in-out-sine: cubic-bezier(.445, .05, .55, .95);
	--ease-in-out-expo: cubic-bezier(1, 0, 0, 1);
	--ease-in-out-circ: cubic-bezier(.785, .135, .15, .86);
	--ease-in-out-back: cubic-bezier(.68, -.55, .265, 1.55);
}

@keyframes fade-in {
	0% {
		opacity: 0;
	}
	
	to {
		opacity: 1;
	}
}

@keyframes fade-out {
	0% {
		opacity: 1;
	}
	
	to {
		opacity: 0;
	}
}

@keyframes spin {
	0% {
		transform: rotate(0);
	}
	
	to {
		transform: rotate(360deg);
	}
}

::selection {
	background-color: rgba(128, 128, 128, .3);
}

html {
	scroll-behavior: smooth;
	scroll-padding-top: 74px;
}

body {
	font: 400 var(--font-size)/1.4 var(--font-body);
	color: var(--c-gray-darker);
	overflow-x: hidden;
}

p {
	margin-bottom: 1em;
}

p:last-child {
	margin-bottom: 0;
}

a {
	color: var(--c-red);
	text-decoration: none;
	transition: color .15s;
}

a:hover {
	color: var(--c-red-light);
}

hr {
	width: 100%;
	height: 1px;
	margin: calc(var(--font-size) * 3) 0;
	background-color: currentColor;
	line-height: 0;
	opacity: .25;
	border: none;
}

blockquote {
	position: relative;
	padding-left: 1.65em;
	color: var(--c-gray-dark);
}

blockquote:before {
	content: "";
	position: absolute;
	width: 2px;
	height: 94%;
	top: 3%;
	left: 0;
	background-color: var(--c-red);
}

blockquote>div {
	margin-top: 2em;
	font-size: var(--font-size-xs);
}

blockquote>div>span:before {
	content: " ";
	display: inline-block;
	margin: 0 .9em 0 .55em;
	font-size: .65em;
	background-image: linear-gradient(90deg, transparent calc(50% - .5px), currentColor 0, currentColor calc(50% + .5px), transparent 0);
	transform: translateY(-20%);
}

:root {
	--font-size-h3: calc(2.4rem + .4 * var(--fluid-scale));
}

h1, .h1, h2, .h2, h3, .h3, h4, .h4 {
	font-family: var(--font-heading);
	font-weight: 700;
	line-height: 1.125;
}

h1, .h1 {
	font-size: calc(3.5rem + 1.3 * var(--fluid-scale));
	margin-bottom: .667em;
}

.h1-xl {
	font-size: calc(5rem + 1.4 * var(--fluid-scale));
}

.h1-2xl {
	font-size: calc(4rem + 1.4 * var(--fluid-scale));
	text-wrap: balance;
}

@media (min-width: 1200px) {
	.h1-2xl {
		font-size: calc(6.5rem + 1.5 * var(--fluid-scale));
	}
}

h2, .h2 {
	font-size: calc(2.6rem + .6 * var(--fluid-scale));
	margin-bottom: .33em;
}

h3, .h3 {
	font-size: var(--font-size-h3);
	margin-bottom: .4em;
	line-height: 1.3;
}

.h3-sm {
	font-size: min(var(--font-size-h3), 2.4rem);
}

h4, .h4 {
	font-size: 2rem;
	margin-bottom: .33em;
	line-height: 1.3;
}

h5, .h5 {
	font-size: var(--font-size-sm);
}

.prehead {
	font-size: var(--font-size-xs);
	color: var(--c-gray-dark);
	margin-bottom: var(--s-3);
}

.lead {
	font-size: var(--font-size-lg);
	line-height: 1.3;
	margin-bottom: 1.25em;
}

.text-base {
	font-size: var(--font-size-sm);
	line-height: 1.4;
}

.bento-grid {
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	gap: 16px;
}

.bento-grid img {
	aspect-ratio: .77/1;
}

@media (min-width: 768px) {
	.bento-grid {
		grid-template-columns: repeat(12, minmax(0, 1fr));
		grid-template-rows: repeat(3, minmax(0, auto));
		gap: 32px;
	}
	
	.bento-grid>:first-child {
		grid-column: 1/span 6;
		grid-row: 1/1;
	}
	
	.bento-grid>:first-child img {
		aspect-ratio: 1.15/1;
	}
	
	.bento-grid>:nth-child(2) {
		grid-column: 7/span 6;
		grid-row: 1/span 2;
	}
	
	.bento-grid>:nth-child(2) img {
		aspect-ratio: .77/1;
	}
	
	.bento-grid>:nth-child(3) {
		grid-column: 1/span 6;
		grid-row: 2/span 2;
	}
	
	.bento-grid>:nth-child(3) img {
		aspect-ratio: .77/1;
	}
	
	.bento-grid>:nth-child(4) {
		grid-column: 7/span 6;
		grid-row: 3/span 1;
	}
	
	.bento-grid>:nth-child(4) img {
		aspect-ratio: 1.15/1;
	}
}

.bento-grid--image {
	position: relative;
	width: 100%;
	height: max-content;
}

.bento-grid--image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.bento-grid--image h3 {
	font-size: var(--font-size);
}

.bento-grid--image p {
	font-weight: 400;
}

.bento-grid--image:after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(179deg, rgba(0, 0, 0, 0) 61.05%, rgba(0, 0, 0, .6) 83.5%);
}

.bento-grid--image-caption {
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 2;
	width: 100%;
	padding: 24px;
	color: #fff;
	font-weight: 700;
}

@media (min-width: 998px) {
	.bento-grid--image-caption {
		padding: 48px;
	}
}

.billboard {
	--cluster-gap: 1.5rem;
	display: flex;
	position: relative;
	min-height: clamp(450px, 66.67vmin, 900px);
	color: #fff;
}

.billboard .container {
	padding-top: calc(10rem + 5 * var(--fluid-scale));
	padding-bottom: calc(10rem + 5 * var(--fluid-scale));
}

.billboard .container>* {
	max-width: 550px;
}

.billboard .h1-xl {
	margin-bottom: .3em;
}

.billboard .lead {
	margin-bottom: .5em;
}

.billboard:after {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	content: "";
	background-image: linear-gradient(90deg, #000, rgba(0, 0, 0, 0));
	opacity: .3;
}

.button {
	--bg: transparent;
	--b: currentColor;
	--c: var(--c-red);
	display: inline-flex;
	gap: 1rem;
	align-items: center;
	justify-content: center;
	padding: 1em 1.5em .9em;
	min-width: 100px;
	font-size: var(--font-size-sm);
	font-family: var(--font-heading);
	font-weight: 400;
	line-height: 1.2;
	background-color: var(--bg);
	border: 1px solid var(--b);
	color: var(--c) !important;
	outline: none;
	text-decoration: none;
	user-select: none;
	appearance: none;
	transition: .2s;
	transition-property: background-color, border-color, color;
}

.button .icon {
	flex: none;
}

.button .icon\:arrow-down {
	--icon-scale: 1.125;
}

.button:where(:hover, :focus) {
	--bg: var(--c-red);
	--b: var(--c-red);
	--c: var(--c-white);
}

.button\:inverted {
	--bg: var(--c-white);
	--b: var(--c-white);
	--c: var(--c-black);
}

.button\:inverted:where(:hover, :focus) {
	--bg: var(--c-red);
	--b: var(--c-red);
	--c: var(--c-white);
}

.button\:outlined {
	--b: var(--c-white);
	--c: var(--c-white);
}

.button\:outlined:where(:hover, :focus) {
	--bg: var(--c-white);
	--c: var(--c-red);
}

.button\:outlined:disabled {
	--bg: transparent;
	--b: var(--c-gray-light);
	--c: var(--c-gray-light);
}

.button\:ghost {
	--bg: transparent;
	--b: transparent;
	--c: var(--c-black);
	padding: 1em 0;
}

.button\:ghost:where(:hover, :focus) {
	--c: var(--c-red);
}

.callout {
	--callout-split: .485;
	--callout-break: 80rem;
	--callout-gap-x: min(5vw, var(--s-6));
	--callout-gap-y: var(--s-4);
	--image-ratio: .667;
	--image-min-height: 300px;
	--image-max-height: 600px;
	display: flex;
	flex-wrap: wrap;
	flex-direction: var(--callout-direction, row);
	gap: var(--callout-gap-y) var(--callout-gap-x);
}

.callout\:reverse {
	--callout-direction: row-reverse;
}

.callout\:row {
	--callout-direction: column;
}

.callout\:row-reverse {
	--callout-direction: column-reverse;
}

.callout\:row-reverse>:first-child {
	align-self: center;
	width: 100%;
	max-width: 626px;
}

.callout>* {
	flex-grow: 1;
	flex-basis: calc(( var(--callout-break) - 100% ) * 999);
}

.callout>:first-child {
	min-width: calc(var(--callout-split) * 100%);
}

.callout>:first-child.span-three {
	min-width: calc(var(--callout-split) * 100% * 1.35);
}

.callout>:last-child {
	align-self: center;
}

.callout p:not([class]), .callout li:not([class]) {
	font-size: var(--font-size);
}

.callout p.lead {
	color: var(--c-red);
}

.callout-link {
	--callout-link-align: left;
	margin-top: var(--s-5);
	text-align: var(--callout-link-align, left);
}

.callout-link\:center {
	--callout-link-align: center;
}

.callout-link\:right {
	--callout-link-align: right;
}

.card {
	--p: 2rem;
	position: relative;
	z-index: 1;
	cursor: pointer;
}

.card:after {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	content: "";
	z-index: -1;
	opacity: 0;
	background-color: var(--c-white);
	box-shadow: var(--shadow-sm);
	transition: opacity .25s var(--ease-out-quad);
}

.card-header {
	position: relative;
	background-color: var(--c-gray-lightest);
}

.card-badge {
	position: absolute;
	right: 0;
	top: 0;
	padding: .5em .75em;
	font-size: var(--font-size-xs);
	background-color: var(--c-red);
	color: var(--c-white);
}

.card-utils {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	z-index: 2;
	display: flex;
	flex-direction: column;
	gap: 10px;
	width: max-content;
	max-width: 100%;
}

.card-utils>* {
	opacity: 0;
	transition: opacity .3s var(--ease-out-quad);
}

.card-title {
	font-size: var(--font-size-sm);
	margin-bottom: 0;
}

.card-title-wrapper {
	display: flex;
	flex-direction: row;
	align-items: center;
	gap: .8rem;
}

.card-title-line {
	font-size: var(--font-size-sm);
	font-weight: 700;
	color: var(--c-white);
	padding: .8rem;
	border-radius: 4px;
}

.card-title-line\:mozaix {
	display: none;
}

.card-title-line\:agilis, .card-title-line\:protero {
	background-color: #2f5565;
}

.card-title-line\:silentia-dimensional, .card-title-line\:silentia-profile {
	background-color: #177e6d;
}

.card-title-line\:tignum {
	background-color: #63503e;
}

.card-title:last-child {
	margin-bottom: 0;
}

.card-details {
	display: flex;
	flex-wrap: wrap;
	margin-top: .5em;
}

.card-details span {
	font-size: var(--font-size-xs);
	color: var(--c-gray-dark);
	line-height: 1.25;
}

.card p {
	font-size: var(--font-size-xs);
	line-height: 1.25;
	max-width: 50ch;
	color: var(--c-gray-dark);
}

.card a:not(.cta-link) {
	color: var(--c-black);
}

.card>div:last-child {
	padding: 2.25rem var(--p);
	transform: translate(calc(var(--p) * -1));
	transition: transform .25s var(--ease-out-quad);
}

.has-hover .card:hover:after, .has-hover .card:focus:after, .has-hover .card:focus-within:after, .has-hover .card:hover .card-utils>*, .has-hover .card:hover>div:last-child, .has-hover .card:focus .card-utils>*, .has-hover .card:focus-within>div:last-child {
	opacity: 1;
	transform: none;
}

.no-hover .card-utils {
	--space: .8rem;
	flex-direction: row;
	flex-wrap: wrap;
	gap: var(--space);
	inset: auto var(--space) var(--space) var(--space);
	transform: none;
}

.no-hover .card-utils>* {
	flex: 1 1 auto;
	opacity: 1;
}

.no-hover .card-utils .icon {
	display: none;
}

.card\:finish {
	--p: 1.5rem;
	--image-ratio: 1;
	pointer-events: none;
}

.card\:finish .card-title {
	font-size: var(--font-size);
	margin-bottom: .25em;
}

.card-result-category {
	margin-bottom: 0;
}

.card-result-category:not(:first-of-type) {
	margin-left: .8rem;
}

.card\:market.card\:coming-soon {
	cursor: not-allowed !important;
}

.card\:market .card-title {
	font-size: 24px;
	line-height: 1.25;
	font-weight: 700;
}

.card\:market p {
	font-size: 18px;
	margin-bottom: 0;
}

.card\:market .card-content {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 16px;
}

.card-grid {
	--bg-color: var(--c-white);
	--text-color: var(--c-black);
	background-color: var(--bg-color);
	color: var(--text-color);
}

.card-grid.theme-light {
	--bg-color: var(--c-white);
	--text-color: var(--c-black);
}

.card-grid.theme-dark {
	--bg-color: var(--c-gray-darkest);
	--text-color: var(--c-white);
}

.card-grid.theme-gray {
	--bg-color: var(--c-gray-light-alt);
	--text-color: var(--c-black);
}

.card-grid.theme-green {
	--bg-color: var(--c-green);
	--text-color: var(--c-white);
}

.card-grid.theme-red {
	--bg-color: var(--c-red);
	--text-color: var(--c-white);
}

.card-grid--layout-wrapper {
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	gap: 16px;
	margin-block-start: 24px;
}

@media (min-width: 767px) {
	.card-grid--layout-wrapper {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 24px;
		margin-block-start: 48px;
	}
}

@media (min-width: 1200px) {
	.card-grid--layout-wrapper {
		grid-template-columns: repeat(3, minmax(0, 1fr));
		gap: 32px;
		margin-block-start: 64px;
	}
}

.card-grid--card {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: space-between;
	gap: 24px;
	width: 100%;
	height: auto;
	aspect-ratio: 427/279;
	padding: 24px;
	background-color: rgba(255, 255, 255, .05);
}

.card-grid--card-icon {
	aspect-ratio: 1/1;
	width: 60px;
	height: 60px;
}

.card-grid .header-textblock {
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	gap: 1em;
}

.card-grid .header-textblock div>*+* {
	margin-block-start: 16px;
}

.card-grid .header-textblock h2 {
	margin: 0;
}

@media (min-width: 767px) {
	.card-grid .header-textblock {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

.carousel {
	overflow: hidden;
}

.carousel-track {
	display: flex;
}

.carousel-slide {
	position: relative;
	flex: 1 0 100%;
}

@media (min-width: 988px) {
	.carousel-slide[data-aspect=video] {
		flex: 1 0 75%;
	}
}

.carousel-slide[data-aspect=video] img {
	width: 100%;
	height: auto;
	aspect-ratio: 16/9;
	object-fit: cover;
}

.carousel-actions {
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	align-items: center;
	gap: 16px;
}

@media (min-width: 768px) {
	.carousel-actions {
		grid-template-columns: repeat(12, minmax(0, 1fr));
	}
}

.carousel-captions {
	grid-column: 1/-1;
	position: relative;
}

@media (min-width: 768px) {
	.carousel-captions {
		grid-column: 1/span 6;
	}
}

.carousel-caption {
	position: absolute;
	top: 0;
	margin: 0;
	opacity: 0;
	transform: translateY(16px);
	transition-property: opacity, transform;
	transition-duration: .2s, .25s;
	transition-timing-function: ease;
	transition-delay: 0ms, 50ms;
}

.carousel-caption.is-active {
	position: relative;
	opacity: 1;
	transform: translateY(0);
}

.carousel-buttons {
	grid-column: 1/-1;
}

@media (min-width: 768px) {
	.carousel-buttons {
		grid-column: 7/-1;
		justify-self: end;
	}
}

.carousel-buttons>* {
	width: max-content;
	min-width: auto;
}

.carousel-dots {
	display: flex;
	gap: 1rem;
	pointer-events: none;
}

.carousel-dots li {
	flex: 1 1 auto;
	max-width: 40px;
	height: 2px;
	position: relative;
}

.carousel-dots li:before {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	content: "";
	background-color: rgba(255, 255, 255, .2);
}

.carousel-dots li:after {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	content: "";
	background-color: #fff;
	transform-origin: 0 0;
	opacity: 0;
	transform: scaleX(var(--progress, 1));
	transition: opacity .25s;
	will-change: opacity, transform;
}

.carousel-dots li.active:after {
	opacity: 1;
}

.contact-link {
	display: inline-flex;
	font-size: var(--font-size-xs);
	align-items: center;
	gap: 1.2rem;
}

.contact-link:before {
	content: "";
	width: 1em;
	height: 1em;
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	background-image: var(--icon);
}

.contact-link[href^="tel:"]:before {
	--icon: url("data:image/svg+xml,%3Csvg xmlns=\'http://www.w3.org/2000/svg\' fill=\'none\' viewBox=\'0 0 14 14\'%3E%3Cpath fill=\'%2382292F\' d=\'m12.29 8.64-2.6-1.12a1.15 1.15 0 0 0-1.31.36L7.52 8.9a8.29 8.29 0 0 1-3.18-3.18l1.04-.84c.38-.33.51-.88.3-1.34L4.6.94C4.37.45 3.8.17 3.28.3L.88.85C.37.95 0 1.4 0 1.96 0 8.2 5.05 13.24 11.27 13.24c.56 0 1.02-.36 1.15-.9l.53-2.38c.13-.53-.15-1.09-.66-1.32Zm-.69 3.53a.33.33 0 0 1-.33.28A10.5 10.5 0 0 1 .81 1.96c0-.17.1-.3.26-.33l2.38-.55c.03 0 .05-.03.08-.03.13 0 .25.1.33.23l1.1 2.56c.04.16.02.3-.11.41L3.58 5.29a.4.4 0 0 0-.1.5 8.73 8.73 0 0 0 3.98 3.97c.16.1.36.05.49-.1l1.04-1.27c.1-.13.25-.15.4-.1l2.57 1.09c.15.07.25.23.2.4l-.56 2.4Z\'/%3E%3C/svg%3E");
}

.contact-link[href^="mailto:"]:before {
	--icon: url("data:image/svg+xml,%3Csvg xmlns=\'http://www.w3.org/2000/svg\' fill=\'none\' viewBox=\'0 0 13 11\'%3E%3Cpath fill=\'%2382292F\' d=\'M11.38.86H1.62C.72.86 0 1.6 0 2.5v6.5c0 .91.71 1.62 1.63 1.62h9.75c.88 0 1.62-.7 1.62-1.62v-6.5c0-.89-.74-1.63-1.63-1.63Zm-9.76.82h9.75c.44 0 .82.38.82.8v.95L7.2 7.13c-.43.33-1.01.33-1.45 0L.81 3.4V2.5c0-.43.36-.81.81-.81Zm10.57 7.3c0 .47-.38.82-.81.82H1.62A.8.8 0 0 1 .82 9V4.42l4.46 3.35c.36.28.79.43 1.22.43.4 0 .84-.15 1.22-.43l4.47-3.35v4.57Z\'/%3E%3C/svg%3E");
}

.content *+:where(h2, h3, h4) {
	margin-top: 1.5em;
}

.content .prehead+:where(h2, h3, h4) {
	margin-top: 0;
}

.content h2 {
	margin-bottom: .5em;
}

.content *+p>.button {
	margin-top: 1em;
}

.content :where(ul, ol):not([class]) {
	margin: 2em 0 2em 1.75em;
}

.content :where(ul):not([class]) {
	list-style-type: square;
}

.content :where(ol):not([class]) {
	list-style-type: decimal;
}

.content :where(ul, ol):not([class]) li+li {
	margin-top: .5em;
}

.content blockquote {
	margin-top: 2.5em;
	margin-bottom: 2.5em;
}

.content a:not([class]) {
	text-decoration: underline;
}

.content a:not([class]):hover {
	text-decoration: none;
}

.content>*:first-child {
	margin-top: 0;
}

.content>*:last-child {
	margin-bottom: 0;
}

.content .wp-caption {
	margin: 3em auto;
}

.content .wp-caption\:aligncenter {
	max-width: 700px;
}

.content .wp-caption-text {
	font-size: var(--font-size-xs);
	margin-top: 1em;
	color: var(--c-gray-dark);
}

.cta-bar {
	--p: min(var(--s-5), 3.5rem);
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: start;
	padding: var(--p);
	gap: var(--s-4) 5rem;
}

.cta-bar>div {
	flex: 1;
}

.cta-bar h3 {
	margin-bottom: .4em;
}

.cta-bar p {
	max-width: 85ch;
}

@media (min-width: 900px) {
	.cta-bar {
		flex-direction: row;
		align-items: center;
	}
	
	.cta-bar\:samples {
		--p: min(var(--s-5), 3rem);
		padding-left: calc(12rem + var(--p));
	}
	
	.cta-bar\:samples:before {
		content: "";
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		width: 12rem;
		height: 100%;
		background: url("https://cdn-ildmbnd.nitrocdn.com/YatFPIMlfmdYopQgmHsUDzYmBdXvEpZU/assets/images/optimized/rev-9974f79/maxxitgroup.com/wp-content/themes/maxxit/images/samples-cta-tile.jpg") center/cover;
	}
}

.cta-brochure .container {
	display: flex;
	flex-direction: column;
	align-items: center;
}

.cta-brochure-image {
	display: flex;
	position: relative;
	width: 70vw;
	max-width: 360px;
	margin-top: var(--s-7);
	transform: rotate(3deg) translate3d(8%, 0, 0);
}

.cta-brochure-image img {
	box-shadow: var(--shadow-lg);
	z-index: 3;
}

.cta-brochure-image:before, .cta-brochure-image:after {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	content: "";
	background: url("https://cdn-ildmbnd.nitrocdn.com/YatFPIMlfmdYopQgmHsUDzYmBdXvEpZU/assets/images/optimized/rev-9974f79/maxxitgroup.com/wp-content/themes/maxxit/images/brochure.png") center/cover no-repeat;
	box-shadow: var(--shadow-lg);
}

.cta-brochure-image:before {
	transform: rotate(-3deg) translate(-9%, 1%);
	z-index: 2;
}

.cta-brochure-image:after {
	transform: rotate(-6deg) translate(-15.5%, 2%);
	z-index: 1;
}

.cta-brochure-intro {
	padding-top: var(--s-6);
	padding-bottom: var(--s-6);
	text-align: center;
}

.cta-brochure-intro p {
	font-size: var(--font-size-md);
	margin-bottom: 1.5em;
}

@media (min-width: 1000px) {
	.cta-brochure {
		overflow: hidden;
	}
	
	.cta-brochure .container {
		--layout: 1168px;
		flex-direction: row;
	}
	
	.cta-brochure-image {
		margin-top: 0;
		width: 100%;
		max-width: min(25vw, 345px);
		transform: rotate(-15deg) translate3d(30%, calc(10% - 20% * var(--progress)), 0);
	}
	
	.cta-brochure-intro {
		max-width: 410px;
		margin-left: auto;
		margin-right: var(--s-3);
		text-align: left;
	}
}

.cta-link {
	font-size: var(--font-size-xs);
	text-decoration: none;
	display: inline-flex;
	align-items: baseline;
	gap: .5em;
}

.cta-link:after {
	content: "";
	--size: calc(13 / 14 * 1em);
	width: var(--size);
	height: var(--size);
	background-image: url("data:image/svg+xml,%3Csvg xmlns=\'http://www.w3.org/2000/svg\' viewBox=\'0 0 12 12\'%3E%3Cpath fill=\'%2382292F\' d=\'m5.48.56-.17.18a.3.3 0 0 0 0 .43L9.83 5.7H.3A.3.3 0 0 0 0 6v.26c0 .18.13.3.3.3h9.53L5.3 11.1a.3.3 0 0 0 0 .43l.17.18c.13.13.3.13.44 0l5.35-5.36a.3.3 0 0 0 0-.43L5.92.56a.3.3 0 0 0-.44 0Z\'/%3E%3C/svg%3E");
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	transform: translateY(1px);
	transition: transform .3s var(--ease-out-quart);
}

.cta-link:hover:after {
	transform: translate(3px, 1px);
}

.cta-section {
	--py: clamp(8rem, 5.5352rem + 6.5728vw, 15rem);
	padding-top: var(--py);
	padding-bottom: var(--py);
}

.cta-section h2 {
	max-width: 50ch;
}

.call-to-action__image {
	width: 100%;
}

.call-to-action__image img {
	width: 100%;
	aspect-ratio: 16/9;
	object-fit: cover;
}

@media (min-width: 992px) {
	.call-to-action__image img {
		aspect-ratio: 16/4;
	}
}

.dropdown {
	position: relative;
	z-index: 5;
}

.dropdown-menu {
	position: absolute;
	left: 0;
	top: 100%;
	min-width: 100%;
	width: max-content;
	max-width: calc(100vw - var(--gutters));
	background-color: #fff;
	box-shadow: var(--shadow-sm);
	visibility: hidden;
	transform: translate(var(--tx, 0), 3px);
	opacity: 0;
	transition: all .25s;
}

.dropdown-menu\:center {
	left: 50%;
	--tx: -50%;
}

.dropdown.is-active {
	z-index: 6;
}

.dropdown.is-active .dropdown-button {
	color: var(--c-red);
}

.dropdown.is-active .dropdown-menu {
	visibility: visible;
	transform: translate(var(--tx, 0));
	opacity: 1;
}

.dropdown-menu:is(ul) {
	font-size: var(--font-size-xs);
	padding: .5em;
}

.dropdown-menu>li {
	max-width: 100%;
	overflow: hidden;
	text-overflow: ellipsis;
}

.dropdown-menu>li a {
	--icon-scale: .85;
	display: flex;
	gap: 1em;
	align-items: center;
	justify-content: space-between;
	white-space: nowrap;
	min-width: max-content;
	padding: .5em 1em;
	color: var(--c-black);
}

.dropdown-menu>li a:hover {
	color: var(--c-red-light);
	background-color: var(--c-gray-lightest);
}

.dropdown-menu>li a .icon {
	flex: none;
}

.filters {
	display: flex;
}

.filters>* {
	flex: 1;
}

.filters .dropdown>button {
	--icon-scale: 13/14;
	display: flex;
	gap: 1rem;
	align-items: center;
	justify-content: center;
	width: 100%;
	padding: 1.667em;
	font-size: var(--font-size-xs);
	line-height: 1;
	color: var(--c-black);
	border: currentColor 1px solid;
}

@media (max-width: 999px) {
	.filters {
		flex-direction: column;
	}
	
	.filters>:not(:last-child) {
		margin-bottom: -1px;
	}
	
	.filters .dropdown>button {
		justify-content: space-between;
	}
}

@media (min-width: 1000px) {
	.filters>:not(:first-child) {
		margin-left: -1px;
	}
}

.form-input, #content select, #content textarea, #content input:not([type=radio], [type=checkbox], [type=button], [type=submit]), #gform_wrapper_1 select, #gform_wrapper_1 textarea, #gform_wrapper_1 input:not([type=radio], [type=checkbox], [type=button], [type=submit]), #gform_wrapper_2 select, #gform_wrapper_2 textarea, #gform_wrapper_2 input:not([type=radio], [type=checkbox], [type=button], [type=submit]), select, textarea, input:not([type=radio], [type=checkbox], [type=button], [type=submit]) {
	max-width: 100%;
	font-size: 1.6rem;
	line-height: 1;
	padding: .7em .9em;
	outline: none;
	border: 1px solid #a0acac;
	border-radius: 3px;
	color: var(--c-black);
	background-color: transparent;
	transition: border-color .2s, box-shadow .2s;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

.form-input::placeholder, #content select::placeholder, #content textarea::placeholder, #content input:not([type=radio], [type=checkbox], [type=button], [type=submit])::placeholder, #gform_wrapper_1 select::placeholder, #gform_wrapper_1 textarea::placeholder, #gform_wrapper_1 input:not([type=radio], [type=checkbox], [type=button], [type=submit])::placeholder, #gform_wrapper_2 select::placeholder, #gform_wrapper_2 textarea::placeholder, #gform_wrapper_2 input:not([type=radio], [type=checkbox], [type=button], [type=submit])::placeholder, select::placeholder, textarea::placeholder, input:not([type=radio], [type=checkbox], [type=button], [type=submit])::placeholder {
	color: #a0acac;
}

.form-input:focus, #content select:focus, #content textarea:focus, #content input:focus:not([type=radio], [type=checkbox], [type=button], [type=submit]), #gform_wrapper_1 select:focus, #gform_wrapper_1 textarea:focus, #gform_wrapper_1 input:focus:not([type=radio], [type=checkbox], [type=button], [type=submit]), #gform_wrapper_2 select:focus, #gform_wrapper_2 textarea:focus, #gform_wrapper_2 input:focus:not([type=radio], [type=checkbox], [type=button], [type=submit]), select:focus, textarea:focus, input:not([type=radio], [type=checkbox], [type=button], [type=submit]):focus {
	border-color: var(--c-red);
}

.form-checkbox {
	display: flex;
	align-items: center;
	gap: 1rem;
	font-size: var(--font-size-xs);
	line-height: 1.2;
	padding: .9em 1.25em;
	outline: none;
	color: var(--c-black);
	cursor: pointer;
}

.form-checkbox:hover {
	background-color: var(--c-gray-lightest);
}

.form-checkbox:not(:first-child) {
	border-top: 1px solid var(--c-gray-lighter);
}

.form-checkbox input[type=checkbox] {
	display: grid;
	place-content: center;
	border: 1px solid var(--c-gray-light);
	border-radius: .2em;
	background-color: #fff;
	-webkit-appearance: none;
	appearance: none;
}

.form-checkbox input[type=checkbox]:before {
	content: "";
	width: 1.5rem;
	height: 1.5rem;
	background: var(--c-red) url("data:image/svg+xml,%3Csvg xmlns=\'http://www.w3.org/2000/svg\' viewBox=\'0 0 34 34\'%3E%3Cpath fill=\'%23FFF\' fill-rule=\'nonzero\' d=\'m12.6 26.6-8.53-8.7a1.36 1.36 0 0 1 0-1.9l1.86-1.9a1.3 1.3 0 0 1 1.85 0l5.75 5.87L25.84 7.39a1.3 1.3 0 0 1 1.86 0l1.85 1.9c.52.52.52 1.37 0 1.9L14.45 26.6a1.3 1.3 0 0 1-1.85 0Z\'/%3E%3C/svg%3E") center/cover no-repeat;
	opacity: 0;
	transition: opacity .1s;
}

.form-checkbox input[type=checkbox]:focus {
	border-color: var(--c-red);
}

.form-checkbox input[type=checkbox]:checked {
	border-color: var(--c-red);
}

.form-checkbox input[type=checkbox]:checked:before {
	opacity: 1;
}

.form-checkbox input[type=checkbox]:checked+* {
	color: var(--c-red);
}

.form-group {
	display: flex;
	flex-direction: column;
	gap: var(--s-5);
}

.form-group__image {
	flex: 1 0 0%;
	aspect-ratio: 3/4;
}

.form-group__image img {
	width: 100%;
}

.form-group__form {
	flex: 1 0 0%;
}

@media (min-width: 943px) {
	.form-group {
		flex-direction: row;
	}
}

#content select, #gform_wrapper_1 select, #gform_wrapper_2 select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns=\'http://www.w3.org/2000/svg\' fill=\'none\' viewBox=\'0 0 13 8\'%3E%3Cpath fill=\'%23808080\' d=\'M12.2 1.3l-.5-.5c-.1-.1-.3-.1-.4 0l-5 5-5-5c0-.1-.3-.1-.4 0l-.6.5v.5l5.8 5.7c0 .2.3.2.4 0l5.7-5.7c.2-.1.2-.3 0-.5z\'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 1.125em top 50%;
	background-size: .85em auto;
	line-height: 1.45;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

#content select::-ms-expand, #gform_wrapper_1 select::-ms-expand, #gform_wrapper_2 select::-ms-expand {
	display: none;
}

#content input[type=checkbox], #gform_wrapper_1 input[type=checkbox], #gform_wrapper_2 input[type=checkbox] {
	accent-color: var(--c-red-light);
}

#content select.nitro-lazy, #gform_wrapper_1 select.nitro-lazy, #gform_wrapper_2 select.nitro-lazy {
	background-image: none !important;
}

#content .gfield_label, #gform_wrapper_1 .gfield_label, #gform_wrapper_2 .gfield_label {
	font-size: var(--font-size-sm);
	font-weight: 400;
}

#content .gform_fields, #gform_wrapper_1 .gform_fields, #gform_wrapper_2 .gform_fields {
	grid-row-gap: 1.2rem;
}

#content .gform_required_legend, #gform_wrapper_1 .gform_required_legend, #gform_wrapper_2 .gform_required_legend {
	display: none;
}

#content .gform_footer, #gform_wrapper_1 .gform_footer, #gform_wrapper_2 .gform_footer {
	margin: 2.5rem 0 0;
	padding: 0;
}

#content .gfield_header_item, #content .gform_fileupload_rules, #content .ginput_complex label, #content .description, #content .gfield_description, #content .gsection_description, #content .instruction, #gform_wrapper_1 .gfield_header_item, #gform_wrapper_1 .gform_fileupload_rules, #gform_wrapper_1 .ginput_complex label, #gform_wrapper_1 .description, #gform_wrapper_1 .gfield_description, #gform_wrapper_1 .gsection_description, #gform_wrapper_1 .instruction, #gform_wrapper_2 .gfield_header_item, #gform_wrapper_2 .gform_fileupload_rules, #gform_wrapper_2 .ginput_complex label, #gform_wrapper_2 .description, #gform_wrapper_2 .gfield_description, #gform_wrapper_2 .gsection_description, #gform_wrapper_2 .instruction {
	font-size: var(--font-size-xs);
	padding-top: 0;
	color: var(--c-gray-dark);
}

#content .ginput_complex label, #gform_wrapper_1 .ginput_complex label, #gform_wrapper_2 .ginput_complex label {
	margin-top: .5rem;
}

#content .gfield_checkbox:where([id=input_2_5], [id=input_1_9], [id=input_4_14]), #gform_wrapper_1 .gfield_checkbox:where([id=input_2_5], [id=input_1_9], [id=input_4_14]), #gform_wrapper_2 .gfield_checkbox:where([id=input_2_5], [id=input_1_9], [id=input_4_14]) {
	display: flex;
	flex-wrap: wrap;
	gap: 1.2rem;
}

#content .gfield_checkbox:where([id=input_2_5], [id=input_1_9], [id=input_4_14]) .gchoice, #gform_wrapper_1 .gfield_checkbox:where([id=input_2_5], [id=input_1_9], [id=input_4_14]) .gchoice, #gform_wrapper_2 .gfield_checkbox:where([id=input_2_5], [id=input_1_9], [id=input_4_14]) .gchoice {
	flex-grow: 1;
	flex-basis: calc(( 50rem - 100% ) * 999);
	padding: .5em 1em;
	border: 1px solid #a0acac;
	position: relative;
}

#content .gfield_checkbox:where([id=input_2_5], [id=input_1_9], [id=input_4_14]) .gchoice:hover, #gform_wrapper_1 .gfield_checkbox:where([id=input_2_5], [id=input_1_9], [id=input_4_14]) .gchoice:hover, #gform_wrapper_2 .gfield_checkbox:where([id=input_2_5], [id=input_1_9], [id=input_4_14]) .gchoice:hover {
	background-color: var(--c-gray-lightest);
}

#content .gfield_checkbox:where([id=input_2_5], [id=input_1_9], [id=input_4_14]) label, #gform_wrapper_1 .gfield_checkbox:where([id=input_2_5], [id=input_1_9], [id=input_4_14]) label, #gform_wrapper_2 .gfield_checkbox:where([id=input_2_5], [id=input_1_9], [id=input_4_14]) label {
	font-size: var(--font-size-xs);
	padding-left: .25rem;
}

#content .gfield_checkbox:where([id=input_2_5], [id=input_1_9], [id=input_4_14]) label:before, #gform_wrapper_1 .gfield_checkbox:where([id=input_2_5], [id=input_1_9], [id=input_4_14]) label:before, #gform_wrapper_2 .gfield_checkbox:where([id=input_2_5], [id=input_1_9], [id=input_4_14]) label:before {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	content: "";
}

#content #input_1_1>span, #content #input_2_1>span, #gform_wrapper_1 #input_1_1>span, #gform_wrapper_1 #input_2_1>span, #gform_wrapper_2 #input_1_1>span, #gform_wrapper_2 #input_2_1>span {
	padding: 0;
	flex: 100%;
}

#content #input_1_1 .name_first, #content #input_2_1 .name_first, #gform_wrapper_1 #input_1_1 .name_first, #gform_wrapper_1 #input_2_1 .name_first, #gform_wrapper_2 #input_1_1 .name_first, #gform_wrapper_2 #input_2_1 .name_first {
	margin-bottom: 1.2rem;
}

#content #input_1_1 .name_last, #content #input_2_1 .name_last, #gform_wrapper_1 #input_1_1 .name_last, #gform_wrapper_1 #input_2_1 .name_last, #gform_wrapper_2 #input_1_1 .name_last, #gform_wrapper_2 #input_2_1 .name_last {
	margin-bottom: 0;
}

#content .gform_validation_errors, #gform_wrapper_1 .gform_validation_errors, #gform_wrapper_2 .gform_validation_errors {
	margin-top: 0;
	margin-bottom: 2.5rem;
	border: 1px solid var(--c-red-light);
	border-radius: 3px;
	box-shadow: none;
}

#content .gform_validation_errors>h2, #gform_wrapper_1 .gform_validation_errors>h2, #gform_wrapper_2 .gform_validation_errors>h2 {
	color: var(--c-red-light);
	font-size: var(--font-size-xs);
}

#content .validation_message, #gform_wrapper_1 .validation_message, #gform_wrapper_2 .validation_message {
	margin-top: .5rem;
	padding: 0;
	border: 0;
	font-size: var(--font-size-xs);
	background-color: transparent;
	color: var(--c-red);
}

#content .gfield_error input:not([type=checkbox]):not([type=radio]), #content .gfield_error textarea, #gform_wrapper_1 .gfield_error input:not([type=checkbox]):not([type=radio]), #gform_wrapper_1 .gfield_error textarea, #gform_wrapper_2 .gfield_error input:not([type=checkbox]):not([type=radio]), #gform_wrapper_2 .gfield_error textarea {
	border: var(--c-red-light) 1px solid;
}

#content #gf_form_focus, #gform_wrapper_1 #gf_form_focus, #gform_wrapper_2 #gf_form_focus {
	outline: none;
}

#content .gform_ajax_spinner, #gform_wrapper_1 .gform_ajax_spinner, #gform_wrapper_2 .gform_ajax_spinner {
	display: none !important;
}

#gform_wrapper_1 #field_1_9 {
	margin-bottom: var(--s-2);
}

#gform_wrapper_1 #field_1_10 {
	max-width: 550px;
}

#gform_wrapper_2 {
	--px: calc(2.5rem + 4 * var(--fluid-scale));
	--py: calc(4rem + 2 * var(--fluid-scale));
	padding: var(--py) var(--px);
}

#gform_wrapper_2 .gform_description {
	display: block;
	font-size: var(--font-size-sm);
	margin-bottom: 2em;
}

#gform_wrapper_2 #field_2_5 {
	margin: var(--s-2) 0;
}

.gform_ajax_spinner {
	display: none !important;
}

.gform_button {
	cursor: pointer !important;
}

.home-hero {
	position: relative;
	background-color: #29080b;
	color: var(--c-white);
	border-bottom: var(--c-gray-light) 5px solid;
}

.home-hero>* {
	opacity: 0;
	transition: opacity .7s;
}

.home-hero.loaded>* {
	opacity: 1;
}

.home-hero h2 {
	margin-bottom: .15em;
}

.home-hero p {
	font-size: var(--font-size-md);
	margin-bottom: 1.5em;
}

.home-hero img, .home-hero video {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: var(--position, 50% 50%);
}

.home-hero .carousel-track {
	height: clamp(400px, var(--vh, 1vh) * 100 - var(--header-height), 1100px);
}

.home-hero .carousel-slide {
	overflow: hidden;
}

.home-hero .carousel-dots {
	position: absolute;
	left: 50%;
	transform: translate(-50%);
	z-index: 3;
	width: calc(100% - var(--gutters));
	bottom: calc(var(--s-7) / 2);
}

.home-hero article {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: flex-end;
	position: relative;
}

.home-hero article:before {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	content: "";
	z-index: 1;
	opacity: .5;
	background-image: linear-gradient(0deg, #000, rgba(0, 0, 0, 0) 75%);
}

.home-hero article>div {
	padding-bottom: var(--s-7);
	user-select: none;
	position: relative;
	z-index: 2;
}

.home-hero article>div>* {
	max-width: 760px;
}

@media (min-width: 1024px) {
	.home-hero article>div {
		padding-bottom: var(--s-5);
	}
	
	.home-hero .carousel-dots {
		bottom: var(--s-5);
		justify-content: flex-end;
	}
}

.icon {
	display: inline-flex;
	width: calc(var(--icon-scale, 1) * 1em);
	height: calc(var(--icon-scale, 1) * 1em);
	max-width: 100%;
	max-height: 100%;
	fill: var(--icon-color, currentColor);
	pointer-events: none;
}

.icon-grid {
	--grid-item-min: 100px;
	--grid-item-max: 125px;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(var(--grid-item-min), var(--grid-item-max)));
	place-content: center;
	place-items: center;
	gap: var(--s-4);
}

.icon-grid__link {
	--callout-link-align: left;
	text-align: var(--callout-link-align, left);
}

.icon-grid__link\:center {
	--callout-link-align: center;
}

.icon-grid__link\:right {
	--callout-link-align: right;
}

.js-open-search {
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
}

.search-box-wrap {
	position: fixed;
	overflow-y: scroll;
	top: 0;
	right: 0;
	display: flex;
	flex-direction: column;
	align-items: start;
	justify-content: start;
	background-color: #fff;
	width: 100%;
	height: 100%;
	opacity: 0;
	visibility: hidden;
	transition: opacity .3s ease-in-out, visibility .3s ease-in-out;
}

.search-box-wrap input {
	min-height: 74px;
	width: 100%;
	border: none;
}

.search-box-wrap .js-close-search {
	font-size: 1.6rem;
	line-height: 1;
	padding: .7em 0;
	outline: none;
}

.search-hits, .search-hits-resources {
	margin-top: 32px;
}

.search-is-open {
	overflow: hidden;
}

.search-is-open .search-box-wrap {
	opacity: 1;
	visibility: visible;
	z-index: 10;
}

.search-is-open .search-hits-wrap {
	opacity: 1;
	visibility: visible;
	display: block;
}

.search-hits-header {
	display: flex;
	flex-direction: column;
	align-items: start;
	justify-content: space-between;
}

@media (min-width: 767px) {
	.search-hits-header {
		flex-direction: row;
		align-items: center;
	}
}

.search-pagination-wrap {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
}

@media (min-width: 767px) {
	.search-pagination-wrap {
		align-items: center;
		justify-content: flex-end;
	}
}

.ais-Hits-list {
	display: grid;
	grid-template-columns: repeat(1fr);
	gap: 32px;
}

@media (min-width: 767px) {
	.ais-Hits-list {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1200px) {
	.ais-Hits-list {
		grid-template-columns: repeat(4, 1fr);
	}
}

.ais-Hits-item mark {
	background-color: #ffe8e9;
	color: #000;
}

.search-hits-resources .ais-Hits-list {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.search-hits-resources .ais-Hits-list .resource {
	padding: 1.644em .85em;
}

.search-hits-resources .ais-Hits-list .resource:first-of-type {
	border-top: none;
}

.image {
	position: relative;
	display: block;
	min-height: var(--image-min-height, 0);
	max-height: var(--image-max-height, none);
	background-color: var(--c-gray-lightest);
}

.image:before {
	content: "";
	display: block;
	padding-bottom: calc(var(--image-ratio, .5625) * 100%);
}

.image>img, .image>video {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: var(--image-fit, cover);
	object-position: var(--image-position, 50% 50%);
}

.image.object-contain {
	--image-fit: contain;
	background-color: var(--c-white);
}

.image.object-cover {
	--image-fit: cover;
}

.line-header {
	display: grid;
	background-color: var(--color);
	color: var(--c-white);
}

.line-header:before {
	content: "";
	grid-area: 1/-1;
}

@media (min-width: 1100px) {
	.line-header:before {
		padding-bottom: calc(var(--image-ratio) * 100%);
	}
}

.line-header>div {
	grid-area: 1/-1;
	padding: var(--s-5);
}

.line-header h2:not(:first-child) {
	margin-top: var(--s-4);
}

.line-header p:not(:last-child) {
	margin-bottom: var(--s-4);
}

.line-header .button:hover {
	--c: var(--color);
}

.masked-parallax {
	--gradient-color-1: #141a21;
	--gradient-color-2: #d9d9d5;
	background: linear-gradient(180deg, var(--gradient-color-1) 50%, var(--gradient-color-2) 50%);
}

.masked-image {
	width: 100%;
	height: auto;
	scale: 1.25 !important;
}

.mask {
	position: relative;
	overflow: hidden;
	width: 100%;
	height: 100%;
	aspect-ratio: 16/9;
	object-fit: cover;
	--webkit-mask-image: var(--mask-url);
	--webkit-mask-size: contain;
	--webkit-mask-repeat: no-repeat;
	mask-image: var(--mask-url);
	mask-size: contain;
	mask-repeat: no-repeat;
}

.mask-content {
	position: absolute;
	bottom: 72px;
	left: 0;
	z-index: 1;
	max-width: 15ch;
}

.mask-content.outside {
	position: relative;
	bottom: auto;
	left: auto;
	z-index: auto;
	max-width: none;
	margin-top: 14px;
}

.mask-content.outside h2 {
	color: var(--c-gray-darkest);
}

@media (min-width: 1200px) {
	.mask-content.outside {
		position: absolute;
		bottom: 72px;
		left: 0;
		z-index: 1;
		max-width: 450px;
	}
	
	.mask-content.outside h2 {
		color: var(--c-white);
	}
}

@media (min-width: 998px) {
	.mask-content {
		max-width: 450px;
	}
}

.mask-content h2 {
	margin: 0;
	font-weight: 400;
	color: var(--c-white);
}

@media (min-width: 1198px) {
	.mask-content h2:not(.f-base) {
		font-size: calc(6.5rem + 2.5 * var(--fluid-scale));
	}
}

.meta {
	font-size: var(--font-size-sm);
	color: var(--c-gray-dark);
}

.meta li {
	display: inline;
}

.meta li:not(:first-child):before {
	content: " ";
	display: inline-block;
	margin: 0 .9em 0 .55em;
	font-size: .65em;
	background-image: linear-gradient(90deg, transparent calc(50% - .5px), currentColor 0, currentColor calc(50% + .5px), transparent 0);
	transform: translateY(-10%);
}

.modal {
	overflow-y: auto;
	-webkit-overflow-scrolling: touch;
	display: none;
	position: fixed;
	z-index: 1000;
	inset: 0;
}

.modal-overlay {
	display: table;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, .7);
}

.modal-wrapper {
	display: table-cell;
	vertical-align: middle;
	padding: min(var(--gutter), 5rem) max(2.5vw, 1rem);
}

.modal-content {
	position: relative;
	width: 100%;
	max-width: var(--modal-width, 800px);
	margin: auto;
	padding: var(--modal-padding, var(--s-5));
	background-color: #fff;
}

.modal-content .gform_confirmation_wrapper {
	display: flex;
	align-items: center;
	justify-content: center;
	width: calc(100% - var(--gutters));
	height: 100%;
	min-height: 250px;
	margin: 0 auto;
}

@media (min-width: 1024px) {
	.modal-content .gform_confirmation_wrapper {
		width: 100%;
		min-height: 360px;
		padding: 0 24px;
	}
}

.modal-close {
	position: absolute;
	z-index: 2;
	right: 0;
	top: 0;
	width: 5rem;
	height: 5rem;
	font-size: 1.5rem;
	background: var(--c-white);
	color: var(--c-black);
	line-height: 0;
}

.modal-close:where(:hover, :focus) {
	background-color: var(--c-red-light);
	color: var(--c-white);
}

.modal.is-open {
	display: block;
}

.modal[aria-hidden=false] {
	animation: fade-in .25s var(--ease-out-quad);
}

.modal[aria-hidden=true] {
	animation: fade-out .25s var(--ease-out-quad);
}

.modal\:video {
	--modal-width: 1100px;
	--modal-padding: 0;
	font-size: 0;
}

.modal\:video .modal-content {
	position: relative;
}

.modal\:video .modal-content:before {
	content: "";
	display: block;
	width: 100%;
	padding-top: 56.25%;
}

.modal\:video .modal-content iframe {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

.modal\:video .modal-close {
	transform: translateY(-100%);
}

.modal\:samples-form {
	--modal-width: 1380px;
	--modal-padding: 0;
	--image-ratio: .35;
	--image-min-height: 250px;
}

.modal\:samples-form .modal-content {
	display: flex;
	flex-flow: row-reverse wrap;
}

.modal\:samples-form .modal-content>* {
	flex-grow: 1;
	flex-basis: calc(( 98rem - 100% ) * 999);
}

.nav-toggle {
	display: flex;
	align-items: center;
	position: relative;
	z-index: 10;
}

.nav-toggle svg {
	flex: none;
	width: 1em;
	height: 1em;
}

.nav-toggle rect {
	transform-origin: 50% 50%;
	transform-box: fill-box;
}

.nav-toggle rect:nth-child(1) {
	transform: translateY(-330%);
}

.nav-toggle rect:nth-child(3) {
	transform: translateY(330%);
}

.nav-toggle[aria-expanded=true] rect:nth-child(1) {
	transform: rotate(45deg) translateY(0);
}

.nav-toggle[aria-expanded=true] rect:nth-child(2) {
	opacity: 0;
}

.nav-toggle[aria-expanded=true] rect:nth-child(3) {
	transform: rotate(-45deg) translateY(0);
}

@media (min-width: 1024px) {
	.nav-toggle {
		display: none !important;
	}
}

.nav-utils {
	font-size: 2rem;
	display: flex;
	align-items: center;
	gap: 1em;
}

.nav-utils>* {
	display: flex;
	align-items: center;
	position: relative;
	color: var(--c-white);
}

.nav-utils>*:before {
	content: "";
	position: absolute;
	width: 200%;
	height: 200%;
	left: -50%;
	top: -50%;
}

@media (max-width: 1023px) {
	.nav {
		position: fixed;
		left: 0;
		top: 0;
		width: 100%;
		height: 100%;
		overflow: hidden;
		background-color: var(--c-red);
		color: var(--c-white);
		transition: .3s;
		transition-property: visibility, opacity;
		visibility: hidden;
		opacity: 0;
	}
	
	.nav.active {
		visibility: visible;
		opacity: 1;
		height: 100dvh;
	}
	
	.nav:before {
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		height: 100%;
		height: var(--header-height);
		content: "";
		z-index: 1;
		background-color: var(--c-red);
	}
	
	.nav a {
		color: currentColor;
	}
	
	.nav-wrap {
		height: 100%;
		padding: calc(var(--header-height) + 2rem) var(--gutter) var(--gutters) var(--gutter);
		overflow-y: scroll;
	}
	
	.nav-menu {
		display: flex;
		flex-direction: column;
		gap: .75em;
	}
	
	.nav-link {
		font-size: var(--font-size-lg);
		font-weight: 700;
	}
	
	.nav-submenu {
		display: flex;
		flex-direction: column;
		gap: .5em;
		font-size: var(--font-size-sm);
		margin: 1em 0 .5em 1em;
	}
	
	.nav-submenu\:products {
		display: none;
	}
}

@media (min-width: 1024px) {
	.nav {
		display: flex;
		align-items: center;
	}
	
	.nav-wrap>.button {
		display: none;
	}
	
	.nav-menu {
		display: flex;
		gap: 1.5rem;
		font-size: var(--font-size-sm);
	}
	
	.nav-item {
		position: relative;
	}
	
	.nav-link {
		display: inline-flex;
		flex-direction: column;
		align-items: center;
		padding: .25em .75em;
		color: var(--c-white);
		text-decoration: none;
		line-height: 1;
	}
	
	.nav-link:after {
		content: attr(data-text);
		content: attr(data-text)/"";
		height: 0;
		visibility: hidden;
		overflow: hidden;
		user-select: none;
		pointer-events: none;
		font-weight: 700;
	}
}

@media speech and (min-width: 1024px) {
	.nav-link:after {
		display: none;
	}
}

@media (min-width: 1024px) {
	.nav-link:hover, .nav-link.is-current, .nav-item.has-submenu.is-active>.nav-link {
		color: var(--c-white);
		font-weight: 700;
	}
	
	.nav-item.has-submenu.is-active>.nav-submenu {
		visibility: visible;
		opacity: 1;
		transform: translate(-50%);
	}
	
	.nav-submenu {
		position: absolute;
		top: calc(100% + 1rem);
		left: 50%;
		min-width: 150px;
		padding: 2em;
		white-space: nowrap;
		background-color: var(--c-white);
		box-shadow: var(--shadow-lg);
		transform: translate(-50%, 3px);
		visibility: hidden;
		opacity: 0;
		transition: .25s;
		transition-property: transform, visibility, opacity;
		will-change: opacity;
	}
	
	.nav-submenu>li+li {
		margin-top: 1em;
	}
	
	.nav-submenu a {
		display: block;
		color: var(--c-black);
		position: relative;
	}
	
	.nav-submenu a:before {
		position: absolute;
		width: 100%;
		width: calc(100% + 2em);
		height: 100%;
		height: calc(100% + .65em);
		content: "";
		left: -1em;
		top: -.35em;
		z-index: -1;
	}
	
	.nav-submenu a:hover {
		color: var(--c-red-light);
	}
	
	.nav-submenu a:hover:before {
		background-color: var(--c-gray-lightest);
	}
	
	.nav-submenu\:products {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		gap: 2em 0;
	}
	
	.nav-submenu\:products>:is(a, a:hover) {
		background-color: transparent;
		grid-column: 1/-1;
	}
	
	.nav-submenu\:products div {
		padding-right: 3rem;
	}
	
	.nav-submenu\:products div:nth-child(3), .nav-submenu\:products div:last-child {
		padding-left: 3rem;
		border-left: var(--c-gray-lighter) 1px solid;
	}
	
	.nav-submenu\:products div:last-child a:before {
		width: calc(100% + 4em);
	}
	
	.nav-submenu\:products li {
		margin-top: .5em;
	}
}

.next-post {
	position: relative;
}

.next-post\:m_project {
	margin-bottom: var(--s-6);
}

.next-post>div {
	margin-top: var(--s-3);
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--s-5);
}

.next-post h3 {
	max-width: 42ch;
}

.next-post a {
	color: var(--c-black);
}

.next-post a:hover {
	color: var(--c-red-light);
}

.next-post .icon {
	flex: none;
	--icon-scale: 1.5;
	--icon-color: var(--c-red);
}

.page-header {
	--p: calc(5rem + 2.5 * var(--fluid-scale));
	padding-top: var(--p);
	padding-bottom: var(--p);
}

.page-hero {
	--cluster-gap: 1.5rem;
}

.page-hero-image, .page-hero-image__full {
	--image-min-height: 400px;
	--image-max-height: 600px;
	background-color: var(--c-gray-lighter);
	position: relative;
	overflow: hidden;
}

.page-hero-image figcaption {
	position: absolute;
	bottom: 2rem;
	left: 2rem;
}

.page-hero-intro {
	padding: var(--s-6) var(--gutter);
}

.page-hero\:product .page-hero-intro {
	padding-bottom: 0;
}

.page-hero-intro h1+span {
	display: block;
	font-size: var(--font-size-sm);
	margin-bottom: var(--s-2);
	color: var(--color);
}

.page-hero-intro p {
	max-width: 60ch;
}

.page-hero ul[aria-label] {
	margin-top: var(--s-4);
	margin-bottom: var(--s-4);
	display: flex;
	flex-direction: column;
	gap: .625em;
	font-size: var(--font-size-sm);
}

.page-hero ul[aria-label] li {
	line-height: 1.25;
}

.page-hero ul[aria-label]:before {
	content: attr(aria-label);
	display: block;
	font-weight: 700;
}

.page-hero\:product-line {
	z-index: 1;
}

.page-hero\:product-line:after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 4;
	background: linear-gradient(0deg, rgba(0, 0, 0, .6) 5%, rgba(0, 0, 0, 0));
}

.page-hero\:product-line .page-hero-image__full {
	height: 100%;
}

.page-hero\:product-line .product-line-content {
	position: absolute;
	left: 50%;
	bottom: 0;
	z-index: 5;
	transform: translate(-50%);
	padding-inline-end: var(--gutter);
	width: calc(100% - var(--gutters));
	max-width: var(--layout);
}

.page-hero\:product-line .product-line-content img {
	width: 100%;
	max-width: calc(14rem + 27.6 * var(--fluid-scale));
}

.page-hero\:product-line .product-line-content .product-line-description {
	padding-block: 24px;
}

.page-hero\:product-line .product-line-content .product-line-description h2 {
	font-size: 20px;
}

@media (min-width: 768px) {
	.page-hero\:product-line .product-line-content .product-line-description {
		padding-block: 48px;
	}
	
	.page-hero\:product-line .product-line-content .product-line-description h2 {
		font-size: var(--font-size-h3);
	}
}

.page-hero\:product-line .product-line-content .product-line-links {
	padding-bottom: 24px;
}

@media (min-width: 1264px) {
	.page-hero\:product-line .product-line-content .product-line-links {
		display: none;
	}
}

.page-hero.page-hero\:bento {
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	grid-gap: 16px;
	height: auto;
	width: calc(100% - var(--gutters));
	max-height: none;
	max-width: var(--layout);
	margin-inline: auto;
	padding-block: var(--s-7);
}

.page-hero.page-hero\:bento .page-hero-intro {
	padding: 0;
	order: -1;
}

.page-hero.page-hero\:bento .page-hero-image {
	aspect-ratio: 4/3;
}

.page-hero.page-hero\:bento .bento-grid-image {
	position: relative;
	overflow: hidden;
}

.page-hero.page-hero\:bento .bento-grid-image img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: var(--image-fit, cover);
	object-position: var(--image-position, 50% 50%);
}

.page-hero.page-hero\:bento .bento-grid-image:nth-child(odd) {
	aspect-ratio: 4/3;
}

.page-hero.page-hero\:bento .bento-grid-image:nth-child(2n) {
	aspect-ratio: 1;
}

@media (min-width: 1200px) {
	.page-hero.page-hero\:bento {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		column-gap: 32px;
		row-gap: 24px;
	}
	
	.page-hero.page-hero\:bento .page-hero-intro {
		grid-column: 1;
		grid-row: 1;
	}
	
	.page-hero.page-hero\:bento .page-hero-image {
		grid-column: 2;
	}
}

@media (max-width: 600px) {
	.page-hero .cluster>* {
		flex-grow: 1;
		flex-basis: 100%;
	}
	
	.page-hero .cluster .button {
		text-align: left;
		justify-content: space-between;
	}
}

@media (min-width: 1200px) {
	.page-hero {
		display: flex;
		height: calc(100vh - var(--header-height));
		max-height: 1100px;
	}
	
	.page-hero>* {
		flex: 1 1 50%;
	}
	
	.page-hero-image {
		--image-max-height: none;
		max-width: 50vw;
	}
	
	.page-hero-image__full {
		--image-max-height: none;
	}
	
	.page-hero-intro {
		padding: var(--s-5) var(--gutter);
		padding-left: clamp(7rem, -5.5rem + 10.4167vw, 12rem);
		max-width: calc(var(--layout) / 2);
		align-self: center;
	}
}

.page-hero.page-hero\:market {
	height: auto;
	background-color: var(--c-gray-lightest);
}

@media (min-width: 1024px) {
	.page-hero.page-hero\:market {
		padding-block: 6.4rem;
	}
}

.page-hero.page-hero\:market .wrapper {
	flex: none;
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
}

@media (min-width: 1024px) {
	.page-hero.page-hero\:market .wrapper {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		grid-gap: 32px;
		width: calc(100% - var(--gutters));
		max-width: var(--layout);
		margin-inline: auto;
	}
}

.page-hero.page-hero\:market .page-hero-intro {
	order: 2;
}

.page-hero.page-hero\:market .page-hero-intro p {
	font-size: 1.6rem;
}

@media (min-width: 1024px) {
	.page-hero.page-hero\:market .page-hero-intro {
		order: -1;
		align-self: flex-start;
		max-width: 580px;
		padding: 0;
	}
}

@media (min-width: 1440px) {
	.page-hero.page-hero\:market .page-hero-intro {
		padding-inline-start: var(--gutter);
	}
}

.page-hero.page-hero\:market .page-hero-image {
	--image-min-height: auto;
	--image-max-height: auto;
	height: max-content;
}

.page-hero.page-hero\:market .page-hero-image .image {
	width: 100%;
	height: auto;
	aspect-ratio: 4/3;
}

.page-hero.page-hero\:market .page-hero-image .image:before {
	content: none;
}

.pagination {
	margin-top: var(--s-5);
	display: flex;
	justify-content: center;
}

.pagination li {
	display: inline;
	margin: 0;
	padding: 0;
}

.pagination a, .pagination span {
	float: left;
	display: block;
	height: 100%;
	position: relative;
	padding: .667em 1em;
	font-size: var(--font-size-sm);
	font-weight: 700;
	line-height: 1;
}

.pagination span:where([aria-label]) {
	float: none;
	display: inline;
	position: static;
	padding: 0;
}

.pagination a:where(.prev, .next) {
	padding-left: 1.25em;
	padding-right: 1.25em;
}

.pagination a:not(.prev, .next) {
	color: var(--c-gray-dark);
}

.pagination a:hover, .pagination .current {
	color: var(--c-red);
}

.pagination svg {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 50%;
	height: 50%;
}

.post-header {
	--p: calc(5rem + 2.5 * var(--fluid-scale));
	padding-top: var(--p);
	padding-bottom: var(--p);
}

.post-header .container>div:last-child {
	display: flex;
	flex-wrap: wrap;
	gap: var(--s-4);
}

.post-header .container>div:last-child>:first-child {
	margin-right: auto;
}

.product-assembly a {
	display: flex;
	align-items: flex-start;
	gap: .8rem;
	margin-top: var(--s-2);
	font-size: var(--font-size-sm);
}

.product-assembly a:not(:hover) {
	color: currentColor;
}

.product-assembly .icon {
	flex: none;
	transform: translateY(.2em);
}

.product-details dl {
	column-count: 3;
	column-width: 300px;
	column-gap: var(--s-5);
	font-size: var(--font-size-xs);
	color: var(--c-gray-darkest);
}

.product-details dl>div {
	break-inside: avoid;
}

.product-details dt {
	break-before: always;
	display: inline-block;
	font-weight: 700;
	margin-bottom: .5em;
}

.product-details dd {
	margin-bottom: 1.5em;
}

.product-details dd ul {
	list-style-type: square;
	margin-left: 1em;
}

.product-details dd li+li {
	margin-top: .5em;
}

.product-finishes {
	--grid-n: 6;
	--grid-w: 170px;
}

@media (max-width: 600px) {
	.product-finishes {
		--grid-w: 150px;
	}
}

.finishes-grid {
	--grid-w: 208px;
	display: grid;
	grid-gap: 3.2rem;
	grid-template-columns: repeat(auto-fit, minmax(var(--grid-w), 1fr));
}

.product-gallery {
	--grid-gap: min(3rem, 2.5vw);
	--px: min(var(--gutter), 3rem);
	padding-left: var(--px);
	padding-right: var(--px);
}

.product-line--logo {
	width: 100%;
	max-width: 170px;
	min-height: 26px;
}

@media (min-width: 998px) {
	.product-line--logo {
		max-width: 200px;
	}
}

.product-line--logo img {
	width: 100%;
	height: auto;
}

.product-line--heading-grid {
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	gap: 16px;
}

@media (min-width: 998px) {
	.product-line--heading-grid {
		grid-template-columns: repeat(12, minmax(0, 1fr));
	}
	
	.product-line--heading-grid :first-child {
		grid-column: 1/span 6;
	}
	
	.product-line--heading-grid :first-child:only-child {
		grid-column: 1/span 7;
	}
	
	.product-line--heading-grid :last-child:not(:only-child) {
		grid-column: 8/span 5;
		justify-self: end;
		align-self: flex-end;
	}
}

.product-line--heading-grid a {
	max-width: max-content;
	height: max-content;
}

.card-title .card-result-type {
	text-transform: uppercase;
	font-size: var(--font-size-xs);
	font-weight: 400;
	color: var(--c-gray-dark);
	margin-top: .5rem;
}

.ais-Pagination-list {
	gap: 1rem;
}

.ais-Pagination-item a {
	color: var(--c-gray-dark);
}

.ais-Pagination-item a:hover, .ais-Pagination-item--selected a {
	color: var(--c-red);
}

.share {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	min-width: max-content;
}

.share[aria-label]:before {
	content: attr(aria-label);
	font-size: var(--font-size-sm);
	line-height: 1;
	margin-right: .5rem;
	color: var(--c-black);
}

.share a {
	position: relative;
	display: flex;
	color: var(--c-black);
}

.share a:before {
	content: "";
	position: absolute;
	width: 170%;
	height: 170%;
	left: -35%;
	top: -35%;
}

.share a:hover {
	color: var(--c-red-light);
}

.site-footer {
	padding-top: calc(5rem + 5 * var(--fluid-scale));
	padding-bottom: var(--s-5);
}

.site-footer a {
	color: inherit;
}

.site-footer a:hover {
	color: var(--c-red-light);
}

.site-footer a[href="#top"] {
	font-size: 2rem;
	padding: 1.5rem;
	line-height: 0;
}

.site-footer .logo-mark {
	width: 6.8rem;
}

.site-footer-tier-2 {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: var(--s-5) var(--s-6);
}

.site-footer-tier-2 li {
	margin-bottom: .5em;
}

.site-footer-tier-2 .gform_wrapper {
	width: 100%;
	max-width: 450px;
}

.site-footer-tier-2 .gform_wrapper form {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-end;
	width: 100%;
	gap: 1.5rem;
}

.site-footer-tier-2 .gform_wrapper form .gform-body {
	width: 100%;
	max-width: 330px;
}

.site-footer-tier-2 .gform_wrapper form .gfield_required {
	display: none;
}

.site-footer-tier-2 .gform_wrapper form .top_label {
	padding: 0;
	margin: 0;
}

.site-footer-tier-2 .gform_wrapper form .top_label button {
	margin: 0;
}

@media (min-width: 996px) {
	.site-footer-tier-2 .gform_wrapper form {
		flex-wrap: nowrap;
	}
	
	.site-footer-tier-2 .gform_wrapper form input {
		margin-bottom: 0 !important;
	}
}

.site-footer-tier-2 form label {
	width: 100%;
	font-weight: 700;
}

.site-footer-tier-2 form input {
	min-height: 45px;
}

.site-footer-tier-2 .gform_confirmation_wrapper {
	display: flex;
	align-items: center;
	max-width: 450px;
}

@media (min-width: 600px) {
	.site-footer-tier-2 ul {
		columns: 2 16rem;
		column-gap: 2.5rem;
	}
	
	.site-footer-tier-2 form {
		max-width: 450px;
	}
}

@media (min-width: 1200px) {
	.site-footer-tier-2 {
		flex-direction: row;
		justify-content: space-between;
	}
	
	.site-footer-tier-2 form label {
		font-weight: 400;
	}
}

.site-footer-tier-3 {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 2em 4em;
}

.site-footer-tier-3>div:last-child {
	display: flex;
	gap: 1em;
}

.site-header {
	position: sticky;
	z-index: 10;
	top: 0;
	padding-top: 2.4rem;
	padding-bottom: 2.4rem;
	background-color: var(--c-red);
}

.site-header>div {
	display: flex;
	align-items: center;
	justify-content: space-between;
}

.site-header .site-logo {
	position: relative;
	z-index: 1;
	display: block;
	width: 36%;
	max-width: 159px;
	color: var(--c-white);
}

.site-header .site-logo:before {
	content: "";
	display: block;
	width: 100%;
	padding-top: 16.3522012579%;
}

.site-header .site-logo svg {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

.site {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}

.js.is-loading .site {
	opacity: 0;
}

.site-content {
	flex: 1;
}

body>a[href="#content"] {
	position: absolute;
	left: -9999px;
	top: 1em;
	padding: 1em;
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1;
	text-decoration: none;
	background-color: var(--c-red-dark);
	color: #fff;
}

body>a[href="#content"]:focus {
	left: 1em;
	z-index: 1000;
}

.social {
	display: flex;
	align-items: center;
	gap: 1.5em;
	font-size: 2rem;
}

.social a {
	position: relative;
	display: flex;
	align-items: center;
	color: currentColor;
	line-height: 0;
}

.social a:before {
	content: "";
	position: absolute;
	width: 200%;
	height: 200%;
	left: -50%;
	top: -50%;
}

.social a:hover {
	color: var(--c-red-light);
}

.sticky-nav {
	display: none;
}

@media (min-width: 998px) {
	.sticky-nav {
		display: block;
		position: sticky;
		top: 74px;
		z-index: 5;
		padding-block: 16px;
		background-color: #141a21;
	}
	
	.sticky-nav>div>:nth-child(2) {
		display: none;
	}
	
	.sticky-nav ul {
		display: flex;
		gap: 32px;
	}
	
	.sticky-nav a {
		font-size: 16px;
		color: var(--c-white);
	}
}

@media (min-width: 1264px) {
	.sticky-nav>div>:nth-child(2) {
		display: flex;
	}
}

.tabs {
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	--tab-width: 0;
	--tab-x: 0;
	padding-bottom: .5rem;
}

.tabs>* {
	display: flex;
	gap: .8em;
	position: relative;
}

.tabs>*:before {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: var(--tab-width);
	height: 1px;
	background-color: var(--c-red-light);
	transform: translate(var(--tab-x));
	transition: .3s var(--ease-out-quart);
	will-change: width;
}

.tabs a {
	display: block;
	padding: 1rem 0;
	font-size: var(--font-size-sm);
	text-decoration: none;
	color: var(--c-black);
	white-space: nowrap;
}

.tabs a:where(:hover, .is-active) {
	color: var(--c-red-light);
}

.tag {
	display: inline-flex;
	align-items: center;
	gap: .8rem;
	padding: .8em 1.125em;
	background-color: var(--c-gray-lighter);
	border-radius: .25em;
	font-size: var(--font-size-xs);
	line-height: 1;
	white-space: nowrap;
	user-select: none;
	color: inherit;
	transition: background-color .15s;
}

.tag[type]:hover, .tag[href]:hover, .tag.reset:hover {
	color: var(--c-red-light);
	background-color: var(--c-gray-lightest);
}

.tag[type=reset], .tag.reset {
	color: inherit;
	background-color: transparent;
}

.tag[aria-current=page], .tag[aria-current=page]:hover {
	color: var(--c-white);
	background-color: var(--c-red);
}

.vertical-tabs {
	--blue--400: #02d1ff;
	--scale-x: 0;
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	gap: 16px;
}

@media (min-width: 998px) {
	.vertical-tabs {
		grid-template-columns: repeat(12, minmax(0, 1fr));
		gap: 32px;
	}
	
	.vertical-tabs>:first-child {
		grid-column: 1/span 7;
	}
	
	.vertical-tabs>:last-child:not(:only-child) {
		grid-column: 9/span 4;
	}
}

.vertical-tabs--image-wrapper {
	position: relative;
	width: 100%;
}

.vertical-tabs--image {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: auto;
	opacity: 0;
	transform: translateY(20px);
	transition-property: opacity, transform;
	transition-duration: .2s, .25s;
	transition-timing-function: ease-in-out, ease-in-out;
	transition-delay: 0ms, 50ms;
}

.vertical-tabs--image.is-active {
	position: relative;
	opacity: 1;
	transform: translateY(0);
}

.vertical-tabs--descriptions {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 16px;
}

@media (min-width: 998px) {
	.vertical-tabs--descriptions {
		gap: 32px;
	}
}

.vertical-tabs--description {
	position: relative;
	display: flex;
	align-items: start;
	text-align: initial;
	gap: 8px;
	padding-top: 24px;
	font-size: 18px;
	border-top: 1px solid rgba(2, 209, 255, .4196078431);
}

.vertical-tabs--description:before {
	content: "";
	position: absolute;
	top: -1px;
	left: 0;
	width: 100%;
	height: 1px;
	background-color: var(--blue--400);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 90ms ease-out;
}

.vertical-tabs--description>* {
	opacity: .5;
	transition: opacity .2s ease-in-out;
}

.vertical-tabs--description.is-active:before {
	transform: scaleX(var(--scale-x));
}

.vertical-tabs--description.is-active>* {
	opacity: 1;
}

@media (min-width: 998px) {
	.vertical-tabs--description {
		font-size: 24px;
	}
}

.vertical-tabs--index {
	font-weight: 700;
	color: var(--blue--400);
}

.page-7 .partners {
	--grid-n: 5;
	--grid-w: 140px;
	--grid-gap: 4rem;
	max-width: 1180px;
	margin-left: auto;
	margin-right: auto;
}

.page-7 .partners li {
	display: grid;
	place-items: center;
}

.page-7 .partners li:before {
	content: "";
	display: block;
	padding-bottom: 66.67%;
	grid-area: 1/1/2/2;
}

.page-7 .partners img {
	grid-area: 1/1/2/2;
	width: 30vw;
	max-width: 140px;
	max-height: 60px;
	object-fit: contain;
	transform: scale(var(--scale, 1));
}

.page-7 .partners [src*=GHA] {
	--scale: 1.1;
}

.page-7 .partners [src*=IBI] {
	--scale: 1.2;
}

.page-7 .partners [src*=Tim-Hortons] {
	--scale: 1.1;
}

.page-7 .partners [src*=Alliance-Bernstein], .page-7 .partners [src*=Centennial], .page-7 .partners [src*=TD-Bank] {
	--scale: 1.2;
}

.page-7 .partners [src*=Boston-Consulting-Group] {
	--scale: .8;
}

.page-7 .partners [src*=Canes] {
	--scale: .95;
}

.page-7 .partners [src*=Whole-Foods-Market] {
	--scale: 1.3;
}

.page-7 .partners [src*=Pizza-Hut] {
	--scale: 1.25;
}

.page-7 .process {
	--p: calc(3rem + 1 * var(--fluid-scale));
	display: flex;
	flex-direction: column;
	overflow: hidden;
	min-height: 500px;
	counter-reset: steps;
}

.page-7 .process-step {
	counter-increment: steps;
	position: relative;
	color: var(--c-black);
	background-color: var(--c-gray-lightest);
}

.page-7 .process-step-image {
	height: 20rem;
	position: relative;
	cursor: pointer;
	background-color: var(--c-black);
}

.page-7 .process-step-image img {
	width: 100%;
	height: 100%;
	transition: opacity .25s;
}

.page-7 .process-step-image span {
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	font-size: var(--font-size-lg);
	font-weight: 700;
	color: var(--c-white);
	text-align: center;
	z-index: 1;
	text-shadow: 0 0 30px rgba(0, 0, 0, .5);
}

.page-7 .process-step-image span:before {
	content: counter(steps);
	display: block;
	font-size: 2.25em;
	line-height: 1;
}

.page-7 .process-step-intro {
	display: grid;
	place-content: center;
	padding: var(--p);
	text-align: center;
	cursor: default;
}

.page-7 .process-step-intro p {
	max-width: 70ch;
}

@media (min-width: 1200px) {
	.page-7 .process {
		flex-direction: row;
	}
	
	.page-7 .process[data-step="1"]>:nth-child(3) {
		--t: -50%;
	}
	
	.page-7 .process[data-step="2"]>:nth-child(2) {
		--t: -50%;
	}
	
	.page-7 .process[data-step="2"]>:nth-child(3) {
		--t: -50%;
	}
	
	.page-7 .process[data-step="3"]>:nth-child(2) {
		--t: -50%;
	}
	
	.page-7 .process[data-step="3"]>:nth-child(3) {
		--t: -100%;
	}
	
	.page-7 .process-step {
		flex: 1 0 50%;
		display: flex;
		transition: transform .6s cubic-bezier(.23, 1, .32, 1);
		will-change: transform;
		transform: translate(var(--t));
	}
	
	.page-7 .process-step>* {
		width: 50%;
	}
	
	.page-7 .process-step-image {
		height: 100%;
	}
	
	.page-7 .process-step-intro {
		text-align: left;
	}
}

.page-8 .contact-header {
	--image-ratio: 1;
	--image-min-height: 250px;
	--image-max-height: min(45vw, 600px);
	--switcher-gap: var(--s-5);
}

.page-8 .contact-header .image {
	align-self: start;
}

.page-8 .contact-support ul {
	margin-left: auto;
	margin-right: auto;
	row-gap: var(--s-5);
}

.page-8 .contact-region li, .page-8 .contact-support li {
	font-size: var(--font-size-sm);
	display: flex;
	flex-direction: column;
	gap: .75rem;
}

.page-8 .contact-support .container {
	display: flex;
	flex-direction: column;
	gap: var(--s-5);
}

@media (min-width: 1000px) {
	.page-8 .contact-support .container {
		flex-direction: row;
		justify-content: space-between;
	}
}

.page-8 .contact-support .container>* {
	flex: 1;
}

.page-8 .contact-support .container .grid {
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.page-8 .contact-regions-map {
	position: relative;
}

.page-8 .contact-regions-map span {
	position: absolute;
	font-size: var(--font-size-xs);
	font-weight: 700;
	line-height: 1;
	border-radius: 4px;
	color: var(--c-white);
	background-color: var(--c-black);
	padding: .85em 1em;
	user-select: none;
	transform: translate(-50%, -50%);
	left: calc(var(--x) / 1100 * 100%);
	top: calc(var(--y) / 556 * 100%);
}

.page-8 .contact-regions-map span:nth-of-type(1) {
	--x: 808;
	--y: 115;
}

.page-8 .contact-regions-map span:nth-of-type(2) {
	--x: 626;
	--y: 252;
}

.page-8 .contact-regions-map span:nth-of-type(3) {
	--x: 625;
	--y: 405;
}

.page-8 .contact-regions-map span:nth-of-type(4) {
	--x: 372;
	--y: 255;
}

@media (min-width: 1000px) {
	.page-8 .contact-regions-map span:before {
		content: "Region ";
	}
}

.page-8 .contact-regions>div:last-child {
	--switcher-gap: var(--s-4);
	--switcher-break: 90rem;
}

.page-8 .contact-regions>div:last-child>* {
	display: inline-block;
}

.page-8 .contact-regions h3 {
	margin-bottom: .5rem;
}

.page-8 .contact-regions li+li {
	margin-top: var(--s-3);
}

.page-8 .contact-regions address {
	font-size: var(--font-size-xs);
	margin-bottom: .5em;
}

.page-8 .gform_anchor {
	display: none;
}

.page-8 .gform_confirmation_message {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
}

.home .featured-content .callout .image {
	flex-grow: 1.75;
}

.home .featured-content .switcher {
	--switcher-break: 80rem;
}

.market-header {
	position: relative;
	height: clamp(400px, var(--vh, 1vh) * 100 - var(--header-height), 1100px);
	width: 100%;
}

.market-header figure {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	object-fit: cover;
	object-position: var(--position, 50% 50%);
}

.market-header figure:after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0, 0, 0, 0) 1.05%, rgba(0, 0, 0, .65));
	z-index: 2;
}

.market-header img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.market-header .container {
	position: absolute;
	bottom: 0;
	z-index: 3;
	left: 50%;
	transform: translate(-50%);
	color: var(--c-white);
	padding-bottom: 48px;
}

.market-header .container * {
	margin-bottom: 0;
}

.market-header .wrapper {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 16px;
	max-width: 624px;
}

@media (min-width: 1024px) {
	.market-header .wrapper {
		gap: 24px;
	}
}

.market-video .image {
	aspect-ratio: 16/9;
}

.market-video .image:before {
	content: none;
}

.featured-market {
	background-color: var(--c-white);
	padding: 48px 0;
}

.featured-market .container {
	display: grid;
	grid-template-columns: 1fr;
	align-items: flex-start;
	gap: 16px;
}

.featured-market .content p {
	font-size: 16px;
	max-width: 376px;
}

@media (min-width: 1024px) {
	.featured-market {
		padding: 64px 0;
	}
	
	.featured-market .container {
		grid-template-columns: 1fr 1fr;
		align-items: center;
		gap: 32px;
	}
}

.markets-grid {
	background-color: var(--c-gray-lightest);
	padding: 48px 0;
}

.markets-grid .container {
	display: grid;
	grid-template-columns: 1fr;
	gap: 16px;
}

@media (min-width: 1024px) {
	.markets-grid .container {
		grid-template-columns: repeat(2, 1fr);
	}
}

.market-list-item--wrapper {
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	gap: 16px;
}

@media (min-width: 1024px) {
	.market-list-item--wrapper {
		grid-template-columns: 360px 1fr;
		gap: 32px;
	}
}

.market-list ol {
	counter-reset: item;
}

.market-list li {
	display: flex;
	align-items: flex-start;
	gap: .8rem;
	padding-block: 2.4rem;
	border-top: 1px solid var(--c-gray-light);
}

.market-list li:before {
	content: counter(item) ".";
	counter-increment: item;
	font-size: calc(2.6rem + .6 * var(--fluid-scale));
	font-weight: 700;
	line-height: normal;
}

.market-list li h3 {
	line-height: normal;
}

@media (min-width: 1024px) {
	.market-list li {
		padding-inline-end: 4rem;
	}
}

.market-featured-project--image {
	aspect-ratio: 4/3;
}

.market-featured-project--image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

@media (min-width: 1024px) {
	.market-featured-project--image {
		order: 2;
	}
}

.market-featured-project--content {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 16px;
}

@media (min-width: 1024px) {
	.market-featured-project--content h2 {
		max-width: 20ch;
	}
}

.market-featured-project--products {
	padding-block-start: var(--s-5);
	border-top: 1px solid var(--c-gray-light);
}

.market-featured-project--products-list {
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	gap: 16px;
}

@media (min-width: 1024px) {
	.market-featured-project--products-list {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (min-width: 1255px) {
	.market-featured-project--products-list {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.market-featured-project--product {
	position: relative;
	display: grid;
	grid-template-columns: 40% 1fr;
	gap: 16px;
}

@media (min-width: 1024px) {
	.market-featured-project--product {
		display: flex;
	}
}

.market-featured-project--product>* {
	flex: 1;
}

.market-featured-project--product>div:first-child {
	aspect-ratio: 4/3;
}

.market-featured-project--product>div:first-child img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.market-featured-project--product>div:last-child {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

.market-featured-project--product>div:last-child>*:not(:first-child) {
	margin-top: 8px;
}

.market-featured-project--product>div:last-child .card-title-line {
	font-size: 16px;
}

.market-featured-project--product>div:last-child h4 {
	font-size: 16px;
}

.market-featured-project--product>div:last-child p {
	font-size: 14px;
}

.market-featured-project--product>div:last-child a:after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
}

.market-featured-project .wrapper {
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	gap: 32px;
}

@media (min-width: 1024px) {
	.market-featured-project .wrapper {
		grid-template-columns: 1fr 1fr;
		align-items: center;
	}
}

.market-projects--list {
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	gap: 16px;
}

@media (min-width: 1024px) {
	.market-projects--list {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 32px;
	}
}

@media (min-width: 1255px) {
	.market-projects--list {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

.products-line {
	display: flex;
	flex-direction: column;
	gap: var(--grid-gap);
	margin-bottom: var(--grid-gap);
}

.products-line>* {
	flex: 1 1 50%;
}

@media (min-width: 1100px) {
	.products-line {
		flex-direction: row;
		align-items: flex-start;
	}
	
	.products-line\:alt {
		flex-direction: row-reverse;
	}
}

.products-line+.grid .grid-col-full {
	grid-row: 3;
}

.projects .grid .grid-col-full:first-child {
	grid-row: 4;
}

.projects .grid .grid-col-full:last-child {
	grid-row: 8;
}

.projects .ais-RefinementList-count {
	display: none;
}

.resource {
	font-size: var(--font-size-sm);
	display: flex;
	align-items: center;
	justify-content: space-between;
	position: relative;
	padding: .75em 0;
	border-top: var(--c-gray-lighter) 1px solid;
	user-select: none;
	color: var(--c-black);
	--icon-color: var(--c-gray-dark);
}

.has-hover .resource {
	padding-left: .85em;
	padding-right: .85em;
}

.has-hover .resource:hover {
	--icon-color: currentColor;
	color: var(--c-red-light);
	background-color: var(--c-gray-lightest);
}

.resource a {
	font-weight: 700;
	margin-right: 1.5rem;
	color: currentColor;
}

.resource span {
	font-size: var(--font-size-xs);
	margin-left: 1rem;
	color: var(--c-gray-dark);
	text-transform: uppercase;
}

@media (max-width: 600px) {
	.resource .icon {
		display: none;
	}
}

.ais-CurrentRefinements-item {
	display: flex;
	gap: var(--cluster-gap, .8rem);
}

.ais-CurrentRefinements-item:first-of-type:before {
	content: "Filtering by";
	display: flex;
	align-items: center;
	font-size: var(--font-size-sm);
	font-weight: 700;
	line-height: 1;
	margin-right: var(--s-2);
}

.single-project article>.image {
	--image-ratio: 9/16;
	--image-min-height: 250px;
}

.single-project .project-header {
	--switcher-break: 100rem;
	--switcher-col-gap: var(--s-6);
	--switcher-row-gap: var(--s-5);
	--p: calc(4rem + 8 * var(--fluid-scale));
	padding-top: var(--p);
	padding-bottom: var(--p);
}

.single-project .project-header h1 {
	max-width: 32ch;
}

.single-project .project-gallery {
	--image-ratio: 9/16;
	display: flex;
	flex-direction: column;
	gap: var(--grid-gap);
}

.single-project .project-gallery-row {
	display: flex;
	flex-wrap: wrap;
	gap: var(--grid-gap);
}

.single-project .project-gallery-row>* {
	flex-grow: 1;
	flex-basis: calc(( 80rem - 100% ) * 999);
}

.single-project .next-post {
	max-width: 1080px;
	margin-left: auto;
	margin-right: auto;
}

.cluster {
	display: flex;
	flex-wrap: wrap;
	gap: var(--cluster-gap, .8rem);
	justify-content: flex-start;
	align-items: center;
}

.cluster[aria-label]:before {
	content: attr(aria-label);
	font-size: var(--font-size-sm);
	font-weight: 700;
	line-height: 1;
	margin-right: var(--s-2);
}

.c-red {
	color: var(--c-red) !important;
}

.bg-red {
	background-color: var(--c-red) !important;
}

.hover\:c-red:hover {
	color: var(--c-red) !important;
}

.hover\:bg-red:hover {
	background-color: var(--c-red) !important;
}

.c-red-dark {
	color: var(--c-red-dark) !important;
}

.bg-red-dark {
	background-color: var(--c-red-dark) !important;
}

.hover\:c-red-dark:hover {
	color: var(--c-red-dark) !important;
}

.hover\:bg-red-dark:hover {
	background-color: var(--c-red-dark) !important;
}

.c-red-light {
	color: var(--c-red-light) !important;
}

.bg-red-light {
	background-color: var(--c-red-light) !important;
}

.hover\:c-red-light:hover {
	color: var(--c-red-light) !important;
}

.hover\:bg-red-light:hover {
	background-color: var(--c-red-light) !important;
}

.c-gray-dark {
	color: var(--c-gray-dark) !important;
}

.bg-gray-dark {
	background-color: var(--c-gray-dark) !important;
}

.hover\:c-gray-dark:hover {
	color: var(--c-gray-dark) !important;
}

.hover\:bg-gray-dark:hover {
	background-color: var(--c-gray-dark) !important;
}

.c-gray-darker {
	color: var(--c-gray-darker) !important;
}

.bg-gray-darker {
	background-color: var(--c-gray-darker) !important;
}

.hover\:c-gray-darker:hover {
	color: var(--c-gray-darker) !important;
}

.hover\:bg-gray-darker:hover {
	background-color: var(--c-gray-darker) !important;
}

.c-gray-darkest {
	color: var(--c-gray-darkest) !important;
}

.bg-gray-darkest {
	background-color: var(--c-gray-darkest) !important;
}

.hover\:c-gray-darkest:hover {
	color: var(--c-gray-darkest) !important;
}

.hover\:bg-gray-darkest:hover {
	background-color: var(--c-gray-darkest) !important;
}

.c-gray-light {
	color: var(--c-gray-light) !important;
}

.bg-gray-light {
	background-color: var(--c-gray-light) !important;
}

.hover\:c-gray-light:hover {
	color: var(--c-gray-light) !important;
}

.hover\:bg-gray-light:hover {
	background-color: var(--c-gray-light) !important;
}

.c-gray-light-alt {
	color: var(--c-gray-light-alt) !important;
}

.bg-gray-light-alt {
	background-color: var(--c-gray-light-alt) !important;
}

.hover\:c-gray-light-alt:hover {
	color: var(--c-gray-light-alt) !important;
}

.hover\:bg-gray-light-alt:hover {
	background-color: var(--c-gray-light-alt) !important;
}

.c-gray-lighter {
	color: var(--c-gray-lighter) !important;
}

.bg-gray-lighter {
	background-color: var(--c-gray-lighter) !important;
}

.hover\:c-gray-lighter:hover {
	color: var(--c-gray-lighter) !important;
}

.hover\:bg-gray-lighter:hover {
	background-color: var(--c-gray-lighter) !important;
}

.c-gray-lightest {
	color: var(--c-gray-lightest) !important;
}

.bg-gray-lightest {
	background-color: var(--c-gray-lightest) !important;
}

.hover\:c-gray-lightest:hover {
	color: var(--c-gray-lightest) !important;
}

.hover\:bg-gray-lightest:hover {
	background-color: var(--c-gray-lightest) !important;
}

.c-green {
	color: var(--c-green) !important;
}

.bg-green {
	background-color: var(--c-green) !important;
}

.hover\:c-green:hover {
	color: var(--c-green) !important;
}

.hover\:bg-green:hover {
	background-color: var(--c-green) !important;
}

.c-black {
	color: var(--c-black) !important;
}

.bg-black {
	background-color: var(--c-black) !important;
}

.hover\:c-black:hover {
	color: var(--c-black) !important;
}

.hover\:bg-black:hover {
	background-color: var(--c-black) !important;
}

.c-white {
	color: var(--c-white) !important;
}

.bg-white {
	background-color: var(--c-white) !important;
}

.hover\:c-white:hover {
	color: var(--c-white) !important;
}

.hover\:bg-white:hover {
	background-color: var(--c-white) !important;
}

.c-current, .hover\:c-current:hover {
	color: currentColor !important;
}

.container {
	width: calc(100% - var(--gutters));
	max-width: var(--layout);
	margin-left: auto;
	margin-right: auto;
}

.container\:inset-1 {
	--layout: 928px;
}

.cursor-default {
	cursor: default !important;
}

.cursor-pointer {
	cursor: pointer !important;
}

.cursor-grab {
	cursor: grab !important;
}

.cursor-grabbing {
	cursor: grabbing !important;
}

.no-cursor {
	cursor: none !important;
}

.no-pointer {
	pointer-events: none !important;
}

@media (max-width: 1200px) {
	.desktop-br {
		display: none;
	}
}

.hide {
	display: none;
}

.flex {
	display: flex;
}

.block {
	display: block;
}

.inline {
	display: inline;
}

.inline-flex {
	display: inline-flex;
}

.inline-block {
	display: inline-block;
}

.visible {
	visibility: visible;
}

.invisible {
	visibility: hidden;
}

.hidden {
	position: absolute;
	width: 1px;
	height: 1px;
	margin: -1px;
	padding: 0;
	overflow: hidden;
	border-width: 0;
	white-space: nowrap;
	clip: rect(0, 0, 0, 0);
}

.fill-link:not(a) {
	position: relative;
}

.fill-link:not(a) a:before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

a.fill-link:before {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

.flex-row {
	display: flex;
	flex-direction: row;
}

.flex-row-reverse {
	display: flex;
	flex-direction: row-reverse;
}

.flex-col {
	display: flex;
	flex-direction: column;
}

.flex-col-reverse {
	display: flex;
	flex-direction: column-reverse;
}

.justify-start {
	justify-content: flex-start;
}

.justify-end {
	justify-content: flex-end;
}

.justify-center {
	justify-content: center;
}

.justify-between {
	justify-content: space-between;
}

.justify-around {
	justify-content: space-around;
}

.justify-evenly {
	justify-content: space-evenly;
}

.items-start {
	align-items: flex-start;
}

.items-end {
	align-items: flex-end;
}

.items-center {
	align-items: center;
}

.items-stretch {
	align-items: stretch;
}

.self-start {
	align-self: flex-start;
}

.self-end {
	align-self: flex-end;
}

.self-center {
	align-self: center;
}

.self-stretch {
	align-self: stretch;
}

.content-start {
	align-content: flex-start;
}

.content-end {
	align-content: flex-end;
}

.content-center {
	align-content: center;
}

.content-stretch {
	align-content: stretch;
}

.content-between {
	align-content: space-between;
}

.content-around {
	align-content: space-around;
}

.content-evenly {
	align-content: space-evenly;
}

.flex-1 {
	flex: 1;
}

.flex-initial {
	flex: initial;
}

.flex-wrap {
	flex-wrap: wrap;
}

.flex-auto {
	flex: auto;
}

.flex-none {
	flex: none;
}

.flex-grow {
	flex-grow: 1;
}

.flex-no-grow {
	flex-grow: 0;
}

.flex-shrink {
	flex-shrink: 1;
}

.flex-no-shrink {
	flex-shrink: 0;
}

.order-first {
	order: -1;
}

.order-last {
	order: 9999;
}

:root {
	--grid-gap: clamp(1.5rem, .8462rem + 1.6346vw, 3.2rem);
}

.grid {
	--grid-clamp: clamp(100% / (var(--grid-n, 3) + 1) + .1%, var(--grid-w, 315px), 100%);
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(var(--grid-clamp), 1fr));
	gap: var(--grid-row-gap, var(--grid-gap)) var(--grid-col-gap, var(--grid-gap));
}

.grid\:2 {
	--grid-n: 2;
}

.grid-col-full {
	grid-column: 1/-1;
}

.relative {
	position: relative;
}

.absolute {
	position: absolute;
}

.static {
	position: static;
}

.sticky {
	position: sticky;
}

.fixed {
	position: fixed;
}

.pin-t, .pin {
	top: 0;
}

.pin-r, .pin {
	right: 0;
}

.pin-b, .pin {
	bottom: 0;
}

.pin-l, .pin {
	left: 0;
}

.center-x, .center {
	left: 50%;
	transform: translate(-50%);
}

.center-y, .center {
	top: 50%;
	transform: translateY(-50%);
}

.fit-contain {
	object-fit: contain;
}

.fit-cover {
	object-fit: cover;
}

.z-0 {
	z-index: 0;
}

.z-1 {
	z-index: 1;
}

.z-2 {
	z-index: 2;
}

.z-3 {
	z-index: 3;
}

.z-4 {
	z-index: 4;
}

.z-5 {
	z-index: 5;
}

.z-6 {
	z-index: 6;
}

.z-7 {
	z-index: 7;
}

.z-8 {
	z-index: 8;
}

.z-9 {
	z-index: 9;
}

.z-10 {
	z-index: 10;
}

.z-20 {
	z-index: 20;
}

.z-30 {
	z-index: 30;
}

.z-40 {
	z-index: 40;
}

.z-50 {
	z-index: 50;
}

.no-overflow-x {
	overflow-x: hidden;
}

.no-overflow-y {
	overflow-y: hidden;
}

.no-overflow {
	overflow: hidden;
}

.scroll-x {
	overflow-x: auto;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	-ms-overflow-style: -ms-autohiding-scrollbar;
}

.scroll-y {
	overflow-y: auto;
	scroll-behavior: smooth;
	-webkit-overflow-scrolling: touch;
	-ms-overflow-style: -ms-autohiding-scrollbar;
}

.w-full {
	width: 100vw;
	margin-left: calc(50% - 50vw);
}

.w-100, .fill {
	width: 100%;
}

.h-100, .fill {
	height: 100%;
}

.max-w-3xl {
	max-width: 864px;
}

.m-0 {
	margin: 0 !important;
}

.mt-0 {
	margin-top: 0 !important;
}

.mr-0 {
	margin-right: 0 !important;
}

.mb-0 {
	margin-bottom: 0 !important;
}

.ml-0 {
	margin-left: 0 !important;
}

.mx-0 {
	margin-left: 0 !important;
	margin-right: 0 !important;
}

.my-0 {
	margin-top: 0 !important;
	margin-bottom: 0 !important;
}

.p-0 {
	padding: 0 !important;
}

.pt-0 {
	padding-top: 0 !important;
}

.pr-0 {
	padding-right: 0 !important;
}

.pb-0 {
	padding-bottom: 0 !important;
}

.pl-0 {
	padding-left: 0 !important;
}

.px-0 {
	padding-left: 0 !important;
	padding-right: 0 !important;
}

.py-0 {
	padding-top: 0 !important;
	padding-bottom: 0 !important;
}

.gap-0 {
	gap: 0 !important;
}

.gap-x-0 {
	column-gap: 0 !important;
}

.gap-y-0 {
	row-gap: 0 !important;
}

.m-1 {
	margin: var(--s-1) !important;
}

.mt-1 {
	margin-top: var(--s-1) !important;
}

.mr-1 {
	margin-right: var(--s-1) !important;
}

.mb-1 {
	margin-bottom: var(--s-1) !important;
}

.ml-1 {
	margin-left: var(--s-1) !important;
}

.mx-1 {
	margin-left: var(--s-1) !important;
	margin-right: var(--s-1) !important;
}

.my-1 {
	margin-top: var(--s-1) !important;
	margin-bottom: var(--s-1) !important;
}

.p-1 {
	padding: var(--s-1) !important;
}

.pt-1 {
	padding-top: var(--s-1) !important;
}

.pr-1 {
	padding-right: var(--s-1) !important;
}

.pb-1 {
	padding-bottom: var(--s-1) !important;
}

.pl-1 {
	padding-left: var(--s-1) !important;
}

.px-1 {
	padding-left: var(--s-1) !important;
	padding-right: var(--s-1) !important;
}

.py-1 {
	padding-top: var(--s-1) !important;
	padding-bottom: var(--s-1) !important;
}

.gap-1 {
	gap: var(--s-1) !important;
}

.gap-x-1 {
	column-gap: var(--s-1) !important;
}

.gap-y-1 {
	row-gap: var(--s-1) !important;
}

.m-2 {
	margin: var(--s-2) !important;
}

.mt-2 {
	margin-top: var(--s-2) !important;
}

.mr-2 {
	margin-right: var(--s-2) !important;
}

.mb-2 {
	margin-bottom: var(--s-2) !important;
}

.ml-2 {
	margin-left: var(--s-2) !important;
}

.mx-2 {
	margin-left: var(--s-2) !important;
	margin-right: var(--s-2) !important;
}

.my-2 {
	margin-top: var(--s-2) !important;
	margin-bottom: var(--s-2) !important;
}

.p-2 {
	padding: var(--s-2) !important;
}

.pt-2 {
	padding-top: var(--s-2) !important;
}

.pr-2 {
	padding-right: var(--s-2) !important;
}

.pb-2 {
	padding-bottom: var(--s-2) !important;
}

.pl-2 {
	padding-left: var(--s-2) !important;
}

.px-2 {
	padding-left: var(--s-2) !important;
	padding-right: var(--s-2) !important;
}

.py-2 {
	padding-top: var(--s-2) !important;
	padding-bottom: var(--s-2) !important;
}

.gap-2 {
	gap: var(--s-2) !important;
}

.gap-x-2 {
	column-gap: var(--s-2) !important;
}

.gap-y-2 {
	row-gap: var(--s-2) !important;
}

.m-3 {
	margin: var(--s-3) !important;
}

.mt-3 {
	margin-top: var(--s-3) !important;
}

.mr-3 {
	margin-right: var(--s-3) !important;
}

.mb-3 {
	margin-bottom: var(--s-3) !important;
}

.ml-3 {
	margin-left: var(--s-3) !important;
}

.mx-3 {
	margin-left: var(--s-3) !important;
	margin-right: var(--s-3) !important;
}

.my-3 {
	margin-top: var(--s-3) !important;
	margin-bottom: var(--s-3) !important;
}

.p-3 {
	padding: var(--s-3) !important;
}

.pt-3 {
	padding-top: var(--s-3) !important;
}

.pr-3 {
	padding-right: var(--s-3) !important;
}

.pb-3 {
	padding-bottom: var(--s-3) !important;
}

.pl-3 {
	padding-left: var(--s-3) !important;
}

.px-3 {
	padding-left: var(--s-3) !important;
	padding-right: var(--s-3) !important;
}

.py-3 {
	padding-top: var(--s-3) !important;
	padding-bottom: var(--s-3) !important;
}

.gap-3 {
	gap: var(--s-3) !important;
}

.gap-x-3 {
	column-gap: var(--s-3) !important;
}

.gap-y-3 {
	row-gap: var(--s-3) !important;
}

.m-4 {
	margin: var(--s-4) !important;
}

.mt-4 {
	margin-top: var(--s-4) !important;
}

.mr-4 {
	margin-right: var(--s-4) !important;
}

.mb-4 {
	margin-bottom: var(--s-4) !important;
}

.ml-4 {
	margin-left: var(--s-4) !important;
}

.mx-4 {
	margin-left: var(--s-4) !important;
	margin-right: var(--s-4) !important;
}

.my-4 {
	margin-top: var(--s-4) !important;
	margin-bottom: var(--s-4) !important;
}

.p-4 {
	padding: var(--s-4) !important;
}

.pt-4 {
	padding-top: var(--s-4) !important;
}

.pr-4 {
	padding-right: var(--s-4) !important;
}

.pb-4 {
	padding-bottom: var(--s-4) !important;
}

.pl-4 {
	padding-left: var(--s-4) !important;
}

.px-4 {
	padding-left: var(--s-4) !important;
	padding-right: var(--s-4) !important;
}

.py-4 {
	padding-top: var(--s-4) !important;
	padding-bottom: var(--s-4) !important;
}

.gap-4 {
	gap: var(--s-4) !important;
}

.gap-x-4 {
	column-gap: var(--s-4) !important;
}

.gap-y-4 {
	row-gap: var(--s-4) !important;
}

.m-5 {
	margin: var(--s-5) !important;
}

.mt-5 {
	margin-top: var(--s-5) !important;
}

.mr-5 {
	margin-right: var(--s-5) !important;
}

.mb-5 {
	margin-bottom: var(--s-5) !important;
}

.ml-5 {
	margin-left: var(--s-5) !important;
}

.mx-5 {
	margin-left: var(--s-5) !important;
	margin-right: var(--s-5) !important;
}

.my-5 {
	margin-top: var(--s-5) !important;
	margin-bottom: var(--s-5) !important;
}

.p-5 {
	padding: var(--s-5) !important;
}

.pt-5 {
	padding-top: var(--s-5) !important;
}

.pr-5 {
	padding-right: var(--s-5) !important;
}

.pb-5 {
	padding-bottom: var(--s-5) !important;
}

.pl-5 {
	padding-left: var(--s-5) !important;
}

.px-5 {
	padding-left: var(--s-5) !important;
	padding-right: var(--s-5) !important;
}

.py-5 {
	padding-top: var(--s-5) !important;
	padding-bottom: var(--s-5) !important;
}

.gap-5 {
	gap: var(--s-5) !important;
}

.gap-x-5 {
	column-gap: var(--s-5) !important;
}

.gap-y-5 {
	row-gap: var(--s-5) !important;
}

.m-6 {
	margin: var(--s-6) !important;
}

.mt-6 {
	margin-top: var(--s-6) !important;
}

.mr-6 {
	margin-right: var(--s-6) !important;
}

.mb-6 {
	margin-bottom: var(--s-6) !important;
}

.ml-6 {
	margin-left: var(--s-6) !important;
}

.mx-6 {
	margin-left: var(--s-6) !important;
	margin-right: var(--s-6) !important;
}

.my-6 {
	margin-top: var(--s-6) !important;
	margin-bottom: var(--s-6) !important;
}

.p-6 {
	padding: var(--s-6) !important;
}

.pt-6 {
	padding-top: var(--s-6) !important;
}

.pr-6 {
	padding-right: var(--s-6) !important;
}

.pb-6 {
	padding-bottom: var(--s-6) !important;
}

.pl-6 {
	padding-left: var(--s-6) !important;
}

.px-6 {
	padding-left: var(--s-6) !important;
	padding-right: var(--s-6) !important;
}

.py-6 {
	padding-top: var(--s-6) !important;
	padding-bottom: var(--s-6) !important;
}

.gap-6 {
	gap: var(--s-6) !important;
}

.gap-x-6 {
	column-gap: var(--s-6) !important;
}

.gap-y-6 {
	row-gap: var(--s-6) !important;
}

.m-7 {
	margin: var(--s-7) !important;
}

.mt-7 {
	margin-top: var(--s-7) !important;
}

.mr-7 {
	margin-right: var(--s-7) !important;
}

.mb-7 {
	margin-bottom: var(--s-7) !important;
}

.ml-7 {
	margin-left: var(--s-7) !important;
}

.mx-7 {
	margin-left: var(--s-7) !important;
	margin-right: var(--s-7) !important;
}

.my-7 {
	margin-top: var(--s-7) !important;
	margin-bottom: var(--s-7) !important;
}

.p-7 {
	padding: var(--s-7) !important;
}

.pt-7 {
	padding-top: var(--s-7) !important;
}

.pr-7 {
	padding-right: var(--s-7) !important;
}

.pb-7 {
	padding-bottom: var(--s-7) !important;
}

.pl-7 {
	padding-left: var(--s-7) !important;
}

.px-7 {
	padding-left: var(--s-7) !important;
	padding-right: var(--s-7) !important;
}

.py-7 {
	padding-top: var(--s-7) !important;
	padding-bottom: var(--s-7) !important;
}

.gap-7 {
	gap: var(--s-7) !important;
}

.gap-x-7 {
	column-gap: var(--s-7) !important;
}

.gap-y-7 {
	row-gap: var(--s-7) !important;
}

.m-8 {
	margin: var(--s-8) !important;
}

.mt-8 {
	margin-top: var(--s-8) !important;
}

.mr-8 {
	margin-right: var(--s-8) !important;
}

.mb-8 {
	margin-bottom: var(--s-8) !important;
}

.ml-8 {
	margin-left: var(--s-8) !important;
}

.mx-8 {
	margin-left: var(--s-8) !important;
	margin-right: var(--s-8) !important;
}

.my-8 {
	margin-top: var(--s-8) !important;
	margin-bottom: var(--s-8) !important;
}

.p-8 {
	padding: var(--s-8) !important;
}

.pt-8 {
	padding-top: var(--s-8) !important;
}

.pr-8 {
	padding-right: var(--s-8) !important;
}

.pb-8 {
	padding-bottom: var(--s-8) !important;
}

.pl-8 {
	padding-left: var(--s-8) !important;
}

.px-8 {
	padding-left: var(--s-8) !important;
	padding-right: var(--s-8) !important;
}

.py-8 {
	padding-top: var(--s-8) !important;
	padding-bottom: var(--s-8) !important;
}

.gap-8 {
	gap: var(--s-8) !important;
}

.gap-x-8 {
	column-gap: var(--s-8) !important;
}

.gap-y-8 {
	row-gap: var(--s-8) !important;
}

.mx-auto, .m-auto {
	margin-left: auto;
	margin-right: auto;
}

.my-auto, .m-auto {
	margin-top: auto;
	margin-bottom: auto;
}

.pad-t, .pad-y, .pad {
	padding-top: var(--gutter);
}

.pad-r, .pad-x, .pad {
	padding-right: var(--gutter);
}

.pad-b, .pad-y, .pad {
	padding-bottom: var(--gutter);
}

.pad-l, .pad-x, .pad {
	padding-left: var(--gutter);
}

.gap-t, .gap-y, .gap {
	margin-top: var(--gutter);
}

.gap-r, .gap-x, .gap {
	margin-right: var(--gutter);
}

.gap-b, .gap-y, .gap {
	margin-bottom: var(--gutter);
}

.gap-l, .gap-x, .gap {
	margin-left: var(--gutter);
}

:root {
	--switcher-break: 90rem;
	--switcher-gap: var(--grid-gap);
}

.switcher {
	display: flex;
	flex-wrap: wrap;
	gap: var(--switcher-row-gap, var(--switcher-gap)) var(--switcher-col-gap, var(--switcher-gap));
}

.switcher>* {
	flex-grow: 1;
	flex-basis: calc(( var(--switcher-break) - 100% ) * 999);
}

.switcher\:2>:nth-last-child(n+3), .switcher\:2>:nth-last-child(n+3)~* {
	flex-basis: 100%;
}

.switcher\:3>:nth-last-child(n+4), .switcher\:3>:nth-last-child(n+4)~* {
	flex-basis: 100%;
}

.teaser {
	display: grid;
	gap: var(--grid-gap);
	grid-template-columns: repeat(10, 1fr);
}

.teaser>* {
	grid-column: 1/-1;
}

.teaser>:first-child {
	margin-bottom: var(--s-3);
}

@media (min-width: 700px) {
	.teaser>:first-child {
		grid-column: 1/-1;
	}
	
	.teaser>* {
		grid-column: span 5;
	}
}

@media (min-width: 1100px) {
	.teaser>:first-child {
		grid-column: span 4;
		margin-top: var(--s-3);
		padding-right: var(--s-3);
	}
	
	.teaser>* {
		grid-column: span 3;
	}
}

.f-0 {
	font-size: 0;
}

.f-xs {
	font-size: var(--font-size-xs);
}

.f-sm {
	font-size: var(--font-size-sm);
}

.f-base {
	font-size: var(--font-size);
}

.f-body {
	font-family: var(--font-body) !important;
}

.f-heading {
	font-family: var(--font-heading) !important;
}

.fw-100 {
	font-weight: 100;
}

.fw-200 {
	font-weight: 200;
}

.fw-300 {
	font-weight: 300;
}

.fw-400 {
	font-weight: 400;
}

.fw-500 {
	font-weight: 500;
}

.fw-600 {
	font-weight: 600;
}

.fw-700 {
	font-weight: 700;
}

.fw-800 {
	font-weight: 800;
}

.fw-900 {
	font-weight: 900;
}

.italic {
	font-style: italic;
}

.underline {
	text-decoration: underline;
}

.lowercase {
	text-transform: lowercase;
}

.uppercase {
	text-transform: uppercase;
}

.text-left {
	text-align: left;
}

.text-right {
	text-align: right;
}

.text-center {
	text-align: center;
}

.no-underline {
	text-decoration: none;
}

.no-select {
	user-select: none;
}

.no-wrap {
	white-space: nowrap;
}

.lh-0 {
	line-height: 0;
}

.lh-1 {
	line-height: 1;
}

.lh-tight {
	line-height: var(--line-height-tight, 1.25);
}

.lh-loose {
	line-height: var(--line-height-loose, 1.75);
}

.ls-0 {
	letter-spacing: 0;
}

.ls-tight {
	letter-spacing: var(--letter-spacing-tight, -.05em);
}

.ls-loose {
	letter-spacing: var(--letter-spacing-loose, .05em);
}

.tracking-wide {
	letter-spacing: 1.6px;
}

.f-antialiased {
	-moz-osx-font-smoothing: grayscale;
	-webkit-font-smoothing: antialiased;
}

.f-subpixel {
	-moz-osx-font-smoothing: auto;
	-webkit-font-smoothing: auto;
}

.truncate {
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
}
