@charset "UTF-8";

/* SEM clean layout */
:root {
	--black-1: #030303;
	--black-2: #111111;
	--black-3: #222222;
	--grey-1: #303030;
	--grey-2: #5d6570;
	--grey-3: #8d949c;
	--grey-4: #f8f8f8;
	--white-1: #ffffff;
	--white-2: #e6e6e6;
	--white-3: #d9dde3;
	--yellow-1: #fdd000;
	--yellow-2: #ffdc2e;
	--yellow-3: #ffa202;
	--blue-1: #003b83;
	--blue-2: #002b62;
	--blue-3: #001f45;
	--blue-4: #0a4590;
	--blue-1-0: rgba(0,59,131,0);
	--white-1-0: rgba(255,255,255,0);
	--title-font: Calibri, Aptos, Arial, Helvetica, "Microsoft YaHei", STHeiTi, sans-serif;
	--main-font: Calibri, Aptos, Arial, Helvetica, "Microsoft YaHei", STHeiTi, sans-serif;
	--title-font-size: 74px;
	--hero-title-size: 74px;
	--page-title-size: 64px;
	--section-title-size: 48px;
	--machine-title-size: 52px;
	--huge-font-size: 48px;
	--large-font-size: 30px;
	--lead-font-size: 19px;
	--medium-font-size: 16px;
	--regular-font-size: 16px;
	--small-font-size: 13px;
	--button-font-size: 13px;
	--title-line-height: 1.05;
	--text-line-height: 1.58;
	--title-rule-width: 56px;
	--title-rule-height: 5px;
	--title-rule-gap: 18px;
	--small-title-rule-width: 42px;
	--small-title-rule-height: 3px;
	--small-title-rule-gap: 13px;
	--max: 1180px;
	--shadow: 0 18px 45px rgba(0,31,69,0.16);
	--soft-shadow: 0 12px 30px rgba(0,31,69,0.08);
}

* {
	box-sizing: border-box;
	outline-color: var(--yellow-1);
}
html {
	scroll-behavior: smooth;
}
body {
	margin: 0;
	color: var(--black-3);
	background: var(--white-1);
	font-family: var(--main-font);
	font-size: var(--regular-font-size);
	line-height: var(--text-line-height);
	text-rendering: optimizeLegibility;
	-webkit-font-smoothing: antialiased;
}
img, svg {
	display: block;
	max-width: 100%;
}
a {
	color: inherit;
	text-decoration: none;
	transition: color 0.25s ease, background 0.25s ease, border-color 0.25s ease, opacity 0.25s ease, transform 0.25s ease;
}
p, ul, ol, figure {
	margin-top: 0;
	margin-bottom: 1.05em;
}
h1, h2, h3, h4, h5, h6 {
	margin-top: 0;
	color: inherit;
	font-family: var(--title-font);
	font-weight: 700;
	line-height: var(--title-line-height);
	letter-spacing: 0;
	text-transform: uppercase;
	text-wrap: balance;
}
.section-head h1:after,
.section-head h2:after,
.machines-listing h1:after,
.machines-listing h2:after,
.content-title h2:after,
.content-container h2:after,
#index-industries h2:after,
.machine-1 h1:after,
.machine-1 h2:after,
.machine-2 h2:after,
.machine-4 h2:after,
.quote-aside h2:after,
.page-title h1:after {
	content: "";
	display: block;
	width: var(--title-rule-width);
	height: var(--title-rule-height);
	margin-top: var(--title-rule-gap);
	background: var(--yellow-1);
}
.machine-category h4:after,
.side-content h3:after,
footer h3:after {
	content: "";
	display: block;
	width: var(--small-title-rule-width);
	height: var(--small-title-rule-height);
	margin-top: var(--small-title-rule-gap);
	background: var(--yellow-1);
}
h1.center:after,
h2.center:after,
h3.center:after,
h1.aligncenter:after,
h2.aligncenter:after,
h3.aligncenter:after,
.section-head h1:only-child:after,
.section-head h2:only-child:after {
	margin-right: auto;
	margin-left: auto;
}
button, input, select, textarea {
	font: inherit;
}
.hidden {
	display: none !important;
}
.center, .aligncenter {
	text-align: center;
}
.alignleft {
	text-align: left;
}
.alignright {
	text-align: right;
}
.mobile-only {
	display: none;
}
.desktop-only {
	display: block;
}
.text-white {
	color: var(--white-1);
}
.color-white {
	background: var(--white-1);
}
.color-black {
	background: var(--blue-3);
	color: var(--white-1);
}
.color-yellow {
	background: var(--yellow-1);
}
.content-box {
	position: relative;
	width: min(var(--max), calc(100% - 36px));
	max-width: var(--max);
	margin: 0 auto;
	padding: 0;
}
.content-box.flex-container {
	width: min(var(--max), calc(100% - 36px));
}
.content-box-small {
	width: min(960px, calc(100% - 36px));
	margin: 0 auto;
}
.content-spacer-large {
	padding: 78px 0;
}
.content-spacer {
	padding: 42px 0;
}
.content-spacer-small {
	padding: 24px 0;
}
.flex-container {
	display: flex;
	align-items: stretch;
	justify-content: space-between;
	flex-wrap: wrap;
}
.grid_1 { width: 8.333333%; }
.grid_2 { width: 16.666666%; }
.grid_3 { width: 25%; }
.grid_4 { width: 33.333333%; }
.grid_5 { width: 41.666666%; }
.grid_6 { width: 50%; }
.grid_7 { width: 58.333333%; }
.grid_8 { width: 66.666666%; }
.grid_9 { width: 75%; }
.grid_10 { width: 83.333333%; }
.grid_11 { width: 91.666666%; }
.grid_12 { width: 100%; }

/* Buttons */
a.button,
button.button,
input[type=submit],
.sem-btn {
	min-height: 46px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	padding: 0 20px;
	border: 2px solid var(--yellow-1);
	border-radius: 4px;
	background: var(--yellow-1);
	color: var(--blue-2);
	font-family: var(--title-font);
	font-size: var(--button-font-size);
	font-weight: 800;
	line-height: 1.1;
	text-align: center;
	text-transform: uppercase;
	cursor: pointer;
}
a.button:after,
.sem-btn:after {
	content: ">";
	font-weight: 900;
}
a.button:hover,
button.button:hover,
input[type=submit]:hover,
.sem-btn:hover {
	background: var(--yellow-2);
	border-color: var(--yellow-2);
	color: var(--blue-2);
}
a.button.secondary,
.sem-btn-quiet {
	background: var(--white-1);
	border-color: var(--white-3);
	color: var(--blue-1);
}
a.button.secondary:hover,
.sem-btn-quiet:hover {
	border-color: var(--blue-1);
	color: var(--blue-1);
}
.sem-btn-primary {
	background: var(--yellow-1);
	border-color: var(--yellow-1);
	color: var(--blue-2);
}

/* Header */
#main {
	position: relative;
	width: 100%;
	min-height: 100vh;
	padding-top: 131px;
	overflow: hidden;
	background: var(--white-1);
}
header {
	position: fixed;
	z-index: 99;
	top: 0;
	left: 0;
	width: 100%;
	background: rgba(255,255,255,0.96);
	box-shadow: 0 8px 22px rgba(0,31,69,0.08);
	transition: height 0.25s ease, background 0.25s ease;
}
.top-header {
	height: 131px;
}
.top-sticky {
	height: 70px;
}
.sem-topline {
	height: 38px;
	overflow: hidden;
	background: var(--blue-1);
	color: var(--white-1);
	font-size: 13px;
	line-height: 1.25;
	transition: height 0.25s ease, opacity 0.25s ease;
}
.top-sticky .sem-topline {
	height: 0;
	opacity: 0;
}
.sem-topline-inner {
	min-height: 38px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 18px;
	overflow: hidden;
}
.sem-topline strong {
	color: var(--yellow-1);
}
.sem-topline-inner > div:first-child {
	min-width: 0;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
#top-menu,
#top-menu ul {
	display: flex;
	align-items: center;
}
#top-menu {
	flex: 0 0 auto;
	max-width: 56%;
}
#top-menu ul {
	justify-content: flex-end;
	gap: 22px;
	margin: 0;
	padding: 0;
	list-style: none;
}
#top-menu a,
#top-menu span {
	display: block;
	white-space: nowrap;
	color: var(--white-1);
	font-size: 13px;
	font-weight: 700;
	line-height: 1.1;
}
#main-header {
	position: relative;
	border-bottom: 1px solid rgba(0,59,131,0.12);
}
.overcolors {
	min-height: 7px;
	background: linear-gradient(90deg, var(--blue-1) 0 58%, var(--yellow-1) 58% 76%, var(--blue-1) 76% 100%);
}
.sem-nav-inner {
	min-height: 86px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: nowrap;
	gap: 18px;
}
.top-sticky .sem-nav-inner {
	min-height: 63px;
}
#header-logo .logo,
footer .logo {
	display: block;
	background: url(../images/logo.svg) top left / contain no-repeat;
}
#header-logo .logo {
	width: 116px;
	height: 60px;
}
.top-sticky #header-logo .logo {
	width: 78px;
	height: 40px;
}
#main-menu {
	flex: 1 1 auto;
	min-width: 0;
}
#main-menu > ul {
	display: flex;
	align-items: center;
	justify-content: flex-end;
	flex-wrap: nowrap;
	gap: 7px;
	min-height: 86px;
	margin: 0;
	padding: 0;
	list-style: none;
}
#main-menu li {
	position: relative;
}
#main-menu > ul > li {
	position: static;
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	min-height: 86px;
	white-space: nowrap;
}
#main-menu .bg-menu {
	display: none !important;
	width: 0 !important;
	height: 0 !important;
	margin: 0 !important;
	padding: 0 !important;
	border: 0 !important;
	pointer-events: none;
}
#main-menu > ul > li > a,
#main-menu > ul > li > span:not(.bg-menu) {
	min-height: 86px;
	display: flex;
	align-items: center;
	padding: 0 7px;
	border-top: 4px solid transparent;
	border-bottom: 4px solid transparent;
	color: #2e3338;
	font-family: var(--title-font);
	font-size: 13px;
	font-weight: 700;
	line-height: 1.1;
	text-transform: uppercase;
	white-space: nowrap;
	cursor: pointer;
}
.top-sticky #main-menu > ul > li > a,
.top-sticky #main-menu > ul > li > span:not(.bg-menu),
.top-sticky #main-menu > ul,
.top-sticky #main-menu > ul > li {
	min-height: 63px;
}
#main-menu > ul > li:hover > a,
#main-menu > ul > li:hover > span:not(.bg-menu),
#main-menu > ul > li.is-open > a,
#main-menu > ul > li.is-open > span:not(.bg-menu),
#main-menu > ul > li:focus-within > a,
#main-menu > ul > li:focus-within > span:not(.bg-menu) {
	color: var(--blue-1);
	border-color: var(--blue-1);
}
#main-menu > ul > li.has-submenu > a:after,
#main-menu > ul > li.has-submenu > span:not(.bg-menu):after {
	content: "";
	display: inline-block;
	width: 7px;
	height: 7px;
	margin: 0 0 2px 8px;
	border-right: 2px solid currentColor;
	border-bottom: 2px solid currentColor;
	transform: rotate(45deg);
	transition: transform 0.25s ease;
}
#main-menu > ul > li.has-submenu:hover > a:after,
#main-menu > ul > li.has-submenu:hover > span:not(.bg-menu):after,
#main-menu > ul > li.has-submenu.is-open > a:after,
#main-menu > ul > li.has-submenu.is-open > span:not(.bg-menu):after {
	transform: rotate(-135deg);
}
#main-menu > ul > li:nth-last-child(-n+2) > a,
#main-menu > ul > li:nth-last-child(-n+2) > span:not(.bg-menu) {
	min-height: 42px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-left: 4px;
	padding: 0 13px;
	border: 2px solid var(--yellow-1);
	border-radius: 4px;
	background: var(--white-1);
	color: var(--blue-1);
	line-height: 1;
}
#main-menu > ul > li:last-child > a,
#main-menu > ul > li:last-child > span:not(.bg-menu) {
	background: var(--yellow-1);
	color: var(--blue-2);
}
#main-menu > ul > li:nth-last-child(-n+2):hover > a,
#main-menu > ul > li:nth-last-child(-n+2):hover > span:not(.bg-menu),
#main-menu > ul > li:nth-last-child(-n+2).is-open > a,
#main-menu > ul > li:nth-last-child(-n+2).is-open > span:not(.bg-menu),
#main-menu > ul > li:nth-last-child(-n+2):focus-within > a,
#main-menu > ul > li:nth-last-child(-n+2):focus-within > span:not(.bg-menu) {
	border-color: var(--yellow-2);
	background: var(--yellow-2);
	color: var(--blue-2);
}
#main-menu > ul ul {
	position: absolute;
	top: calc(100% + 1px);
	left: 50%;
	z-index: 200;
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	align-items: flex-start;
	align-content: flex-start;
	gap: 0 25px;
	width: 100vw;
	margin: 0;
	padding: 32px max(25px, calc((100vw - var(--max)) / 2 + 25px));
	list-style: none;
	border-top: 1px solid var(--white-3);
	border-bottom: 3px solid var(--blue-1);
	background: var(--white-1);
	box-shadow: 0 22px 38px rgba(0,31,69,0.12);
	opacity: 0;
	transform: translateX(-50%);
	visibility: hidden;
	pointer-events: none;
	transition: opacity 0.25s ease, visibility 0.25s ease;
}
#main-menu > ul > li:hover > ul,
#main-menu > ul > li:focus-within > ul,
#main-menu > ul > li.is-open > ul {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}
#main-menu > ul ul li {
	min-width: 240px;
}
#main-menu > ul ul a,
#main-menu > ul ul span {
	display: block;
	padding: 13px 18px;
	color: var(--blue-1);
	font-size: 13px;
	font-weight: 700;
	line-height: 1.25;
	text-transform: uppercase;
}
#main-menu > ul ul a:hover,
#main-menu > ul ul span:hover {
	color: var(--black-1);
	background: var(--grey-4);
}
#menu-trigger {
	display: none;
	width: 44px;
	height: 44px;
	cursor: pointer;
}
#menu-trigger .inner {
	position: relative;
	width: 28px;
	height: 20px;
	margin: 12px auto;
}
#menu-trigger .inner div {
	position: absolute;
	left: 0;
	width: 28px;
	height: 3px;
	background: var(--blue-1);
	transition: all 0.25s ease;
}
#menu-trigger .inner div:first-child { top: 0; }
#menu-trigger .inner div:nth-child(2) { top: 8px; }
#menu-trigger .inner div:last-child { top: 16px; }
#menu-trigger:not(.closed) .inner div:first-child {
	top: 8px;
	transform: rotate(45deg);
}
#menu-trigger:not(.closed) .inner div:nth-child(2) {
	opacity: 0;
}
#menu-trigger:not(.closed) .inner div:last-child {
	top: 8px;
	transform: rotate(-45deg);
}

/* Mobile menu */
#mobile-menu {
	position: fixed;
	z-index: 90;
	top: 70px;
	left: 0;
	width: 100%;
	max-height: calc(100vh - 70px);
	overflow: auto;
	background: var(--blue-3);
	color: var(--white-1);
	transform: translateY(0);
	transition: transform 0.25s ease;
}
#mobile-menu.closed {
	transform: translateY(-110%);
}
#mobile-menu ul {
	margin: 0;
	padding: 0;
	list-style: none;
}
#mobile-menu > ul > li > a,
#mobile-menu > ul > li > span {
	display: block;
	padding: 16px 24px;
	border-bottom: 1px solid rgba(255,255,255,0.12);
	font-weight: 800;
	text-transform: uppercase;
}
#mobile-menu > ul ul {
	display: none;
	background: rgba(255,255,255,0.06);
}
#mobile-menu > ul > li.open ul {
	display: block;
}
#mobile-menu > ul ul a,
#mobile-menu > ul ul span {
	display: block;
	padding: 12px 34px;
	color: rgba(255,255,255,0.86);
}

/* Side contact */
#side {
	--side-header-height: 131px;
	--side-panel-offset: 25px;
	--side-tab-size: 54px;
	--side-tab-gap: 25px;
}
header.top-sticky ~ #side {
	--side-header-height: 70px;
}
#side-shade {
	position: fixed;
	z-index: 100;
	inset: 0;
	background: rgba(0,31,69,0.58);
	opacity: 0;
	visibility: hidden;
	cursor: pointer;
	transition: opacity 0.25s ease, visibility 0.25s ease;
}
#side-shade.open {
	opacity: 1;
	visibility: visible;
}
#side-contact,
#side-phone {
	position: fixed;
	z-index: 101;
	right: 0;
	display: flex;
	align-items: flex-start;
	color: var(--white-1);
	transition: top 0.25s ease, transform 0.25s ease;
}
#side-contact {
	top: calc(var(--side-header-height) + var(--side-panel-offset));
	transform: translateX(calc(100% - var(--side-tab-size)));
}
#side-phone {
	top: calc(var(--side-header-height) + var(--side-panel-offset) + var(--side-tab-size) + var(--side-tab-gap));
	transform: translateX(calc(100% - var(--side-tab-size)));
}
#side-contact.open,
#side-phone.open {
	transform: translateX(0);
}
#side-contact.out,
#side-phone.out {
	transform: translateX(100%);
}
.side-icon {
	width: var(--side-tab-size);
	height: var(--side-tab-size);
	display: grid;
	place-items: center;
	flex: 0 0 auto;
	border-radius: 10px 0 0 10px;
	background: var(--yellow-1);
	cursor: pointer;
}
.side-icon svg {
	width: 28px;
	height: 28px;
	fill: var(--blue-2);
}
.side-content {
	width: min(420px, calc(100vw - var(--side-tab-size)));
	max-height: calc(100vh - var(--side-header-height) - var(--side-panel-offset) - 25px);
	overflow: auto;
	padding: 28px;
	background: var(--blue-1);
	box-shadow: var(--shadow);
}
.side-content h3 {
	margin-bottom: 18px;
	color: var(--white-1);
	font-size: 26px;
	line-height: var(--title-line-height);
}
.side-content p,
.side-content a {
	color: var(--white-1);
}
#side-phone .side-content {
	width: min(390px, calc(100vw - var(--side-tab-size)));
	max-height: calc(100vh - var(--side-header-height) - var(--side-panel-offset) - var(--side-tab-size) - var(--side-tab-gap) - 25px);
	padding: 30px;
	background: linear-gradient(145deg, var(--blue-1), var(--blue-3));
}
.side-phone-kicker {
	margin: 0 0 18px;
	color: var(--yellow-1);
	font-family: var(--title-font);
	font-size: 24px;
	font-weight: 800;
	line-height: var(--title-line-height);
	text-transform: uppercase;
}
.side-phone-list {
	display: grid;
	gap: 0;
	margin: 0;
	border-top: 1px solid rgba(255,255,255,0.18);
}
.side-phone-item {
	padding: 18px 0;
	border-bottom: 1px solid rgba(255,255,255,0.18);
}
.side-phone-label {
	display: block;
	margin-bottom: 7px;
	color: rgba(255,255,255,0.74);
	font-family: var(--title-font);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.1;
	text-transform: uppercase;
}
.side-phone-number {
	display: inline-block;
	color: var(--white-1);
	font-family: var(--title-font);
	font-size: 28px;
	font-weight: 900;
	line-height: 1.05;
	white-space: nowrap;
}
.side-phone-number:hover {
	color: var(--yellow-1);
}
.side-phone-hours {
	margin: 20px 0 0;
	padding: 14px 16px;
	border-left: 4px solid var(--yellow-1);
	background: rgba(255,255,255,0.08);
	color: rgba(255,255,255,0.86);
	font-size: 14px;
	font-weight: 700;
	line-height: 1.35;
}

/* Forms */
.contact-form,
.input_form {
	width: 100%;
}
.input_form {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 16px;
}
.input_form > div {
	width: 100%;
	min-width: 0;
}
.input_form > div.form-half {
	width: calc(50% - 8px);
}
input[type=text],
input[type=tel],
input[type=email],
select,
textarea {
	width: 100%;
	min-height: 46px;
	margin: 0;
	padding: 10px 12px;
	border: 1px solid #bfc6ce;
	border-radius: 3px;
	background: var(--white-1);
	color: var(--black-1);
	font-size: var(--medium-font-size);
}
select {
	height: 46px;
	overflow: hidden;
	line-height: 1.15;
	text-overflow: ellipsis;
	white-space: nowrap;
}
textarea {
	min-height: 112px;
	resize: vertical;
}
input.error,
select.error,
textarea.error {
	border-color: #d00000;
}
p.small,
.small {
	color: var(--grey-2);
	font-size: var(--small-font-size);
}
.form-consent {
	margin: 12px 0 0;
	line-height: 1.45;
}
.form-consent label {
	position: relative;
	display: block;
	padding-left: 28px;
}
.form-consent input[type=checkbox] {
	position: absolute;
	top: 0.2em;
	left: 0;
	margin: 0;
}
.form-consent a {
	display: inline;
	color: var(--blue-1);
	font-weight: 800;
	text-decoration: underline;
	text-underline-offset: 2px;
}
.form-confirmation {
	padding: 24px;
	background: var(--yellow-1);
	color: var(--blue-2);
	font-weight: 800;
}
#side .contact-form {
	display: grid;
	gap: 10px;
}
#side input,
#side select,
#side textarea {
	font-size: var(--medium-font-size);
	line-height: 1.35;
}
#side input[type=submit] {
	width: 100%;
	margin-top: 6px;
}

/* Slideshow */
.slideshow {
	position: relative;
	height: calc(100vh - 131px);
	min-height: 680px;
	margin: 0;
	padding: 0;
	overflow: hidden;
	background:
		radial-gradient(circle at 78% 34%, rgba(253,208,0,0.18) 0%, rgba(253,208,0,0) 24%),
		linear-gradient(135deg, var(--blue-3) 0%, var(--blue-1) 100%);
	isolation: isolate;
}
.slideshow:before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 3;
	pointer-events: none;
	background:
		linear-gradient(180deg, rgba(0,0,0,0.34) 0%, rgba(0,0,0,0) 30%, rgba(0,0,0,0.48) 100%),
		repeating-linear-gradient(90deg, rgba(255,255,255,0.055) 0 1px, transparent 1px 160px);
	opacity: 0.72;
}
.slideshow:after {
	content: "";
	position: absolute;
	z-index: 5;
	left: 0;
	right: 0;
	bottom: 0;
	height: 8px;
	background: linear-gradient(90deg, var(--yellow-1), var(--yellow-3) 42%, var(--yellow-1));
	box-shadow: 0 -18px 42px rgba(0,31,69,0.34);
	pointer-events: none;
}
.slideshow .container.sem-slider,
.slideshow .sem-slider-track {
	position: relative;
	width: 100%;
	height: 100%;
}
.slideshow .sem-slide {
	position: absolute;
	inset: 0;
	overflow: hidden;
	background: var(--blue-1);
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.55s ease, visibility 0.55s ease;
}
.slideshow .sem-slide.is-active {
	z-index: 2;
	opacity: 1;
	visibility: visible;
}
.slideshow .sem-slide:before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	background:
		linear-gradient(100deg, rgba(0,31,69,0.98) 0%, rgba(0,43,98,0.9) 27%, rgba(0,59,131,0.58) 54%, rgba(0,31,69,0.14) 82%),
		radial-gradient(circle at 78% 44%, rgba(253,208,0,0.2) 0%, rgba(253,208,0,0) 28%),
		linear-gradient(180deg, rgba(0,0,0,0.1) 0%, rgba(0,0,0,0.48) 100%);
}
.slideshow .sem-slide:after {
	content: "";
	position: absolute;
	z-index: 2;
	left: max(18px, calc((100vw - var(--max)) / 2));
	top: 104px;
	bottom: 72px;
	width: 1px;
	background: linear-gradient(180deg, rgba(253,208,0,0), rgba(253,208,0,0.9) 18%, rgba(255,255,255,0.42) 74%, rgba(253,208,0,0));
	box-shadow: 18px 0 0 rgba(253,208,0,0.18);
}
.slideshow .sem-slide-media {
	position: absolute;
	inset: 0;
	margin: 0;
	overflow: hidden;
}
.slideshow .sem-slide-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0.94;
	transform: scale(1.06);
	filter: saturate(1.05) contrast(1.04);
	transition: transform 7.2s ease, filter 0.55s ease;
}
.slideshow .sem-slide.is-active .sem-slide-media img {
	transform: scale(1);
}
.slideshow .sem-slide-caption {
	position: relative;
	z-index: 4;
	width: min(var(--max), calc(100% - 36px));
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 72px 0 82px 38px;
	color: var(--white-1);
}
.slideshow .sem-slide-caption:before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	z-index: 1;
	width: 14px;
	height: 116px;
	background: linear-gradient(180deg, var(--yellow-1) 0 52px, rgba(255,255,255,0.28) 52px 100%);
	transform: translateY(-50%);
}
.slideshow .sem-slide-caption:after {
	content: "";
	position: absolute;
	left: 38px;
	top: 50%;
	z-index: 1;
	width: min(740px, 60vw);
	height: min(420px, 48vh);
	border: 1px solid rgba(255,255,255,0.08);
	border-left: 0;
	background:
		linear-gradient(90deg, rgba(255,255,255,0.05) 0 1px, transparent 1px 100%),
		linear-gradient(0deg, rgba(255,255,255,0.04) 0 1px, transparent 1px 100%);
	background-size: 92px 92px;
	opacity: 0.54;
	transform: translateY(-50%);
	pointer-events: none;
}
.slideshow .slide-eyebrow {
	position: relative;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	width: fit-content;
	min-height: 34px;
	margin-bottom: 22px;
	padding: 0 13px;
	border: 1px solid rgba(253,208,0,0.48);
	background: rgba(0,31,69,0.62);
	color: var(--yellow-1);
	font-family: var(--title-font);
	font-size: 12px;
	font-weight: 900;
	line-height: 1.1;
	text-transform: uppercase;
	box-shadow: 0 14px 35px rgba(0,0,0,0.18);
}
.slideshow .slide-eyebrow:before {
	content: "";
	width: 28px;
	height: 4px;
	margin-right: 10px;
	background: var(--yellow-1);
}
.slideshow .sem-slide-caption h2 {
	position: relative;
	z-index: 2;
	max-width: 820px;
	margin-bottom: 24px;
	color: var(--white-1);
	font-size: var(--hero-title-size);
	line-height: 0.96;
	text-shadow: 0 22px 54px rgba(0,0,0,0.46);
	text-wrap: balance;
}
.slideshow .sem-slide-caption p {
	position: relative;
	z-index: 2;
	max-width: 650px;
	margin-bottom: 34px;
	color: rgba(255,255,255,0.88);
	font-size: var(--lead-font-size);
	font-weight: 500;
	line-height: 1.5;
	text-shadow: 0 12px 34px rgba(0,0,0,0.36);
}
.slideshow .slide-actions {
	position: relative;
	z-index: 2;
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
}
.slideshow .slide-actions a {
	position: relative;
	min-height: 52px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	padding: 0 24px;
	border: 2px solid var(--yellow-1);
	border-radius: 4px;
	background: var(--yellow-1);
	color: var(--blue-2);
	font-size: var(--button-font-size);
	font-weight: 800;
	line-height: 1.1;
	text-transform: uppercase;
	box-shadow: 0 18px 34px rgba(0,0,0,0.28);
}
.slideshow .slide-actions a:after {
	content: ">";
	margin-left: 12px;
	color: currentColor;
	font-size: 16px;
	line-height: 1;
	transition: transform 0.25s ease;
}
.slideshow .slide-actions a.secondary {
	border-color: rgba(255,255,255,0.42);
	background: rgba(0,31,69,0.46);
	color: var(--white-1);
	box-shadow: none;
}
.slideshow .slide-actions a:hover,
.slideshow .slide-actions a.secondary:hover {
	background: var(--yellow-2);
	border-color: var(--yellow-2);
	color: var(--blue-2);
	transform: translateY(-2px);
}
.slideshow .slide-actions a:hover:after {
	transform: translateX(4px);
}
.slideshow .slide-foreground {
	position: absolute;
	right: -2%;
	bottom: 48px;
	z-index: 1;
	width: min(600px, 42vw);
	height: auto;
	pointer-events: none;
	filter: drop-shadow(0 32px 38px rgba(0,0,0,0.36));
}
.sem-slider-controls {
	position: absolute;
	z-index: 7;
	right: max(18px, calc((100vw - var(--max)) / 2));
	bottom: 36px;
	display: flex;
	align-items: center;
	gap: 14px;
	min-height: 58px;
	padding: 8px;
	border: 1px solid rgba(255,255,255,0.16);
	border-radius: 8px;
	background: rgba(0,31,69,0.56);
	box-shadow: 0 24px 48px rgba(0,0,0,0.28);
	backdrop-filter: blur(12px);
}
.sem-slider-arrow,
.sem-slider-dot {
	border: 0;
	cursor: pointer;
	transition: all 0.25s ease;
}
.sem-slider-arrow {
	position: relative;
	width: 42px;
	height: 42px;
	border: 1px solid rgba(255,255,255,0.22);
	border-radius: 4px;
	background: rgba(255,255,255,0.1);
}
.sem-slider-arrow span {
	position: absolute;
	top: 15px;
	left: 16px;
	width: 10px;
	height: 10px;
	border-left: 2px solid var(--white-1);
	border-bottom: 2px solid var(--white-1);
	transform: rotate(45deg);
}
.sem-slider-next span {
	left: 13px;
	transform: rotate(-135deg);
}
.sem-slider-arrow:hover {
	background: var(--yellow-1);
	border-color: var(--yellow-1);
	transform: translateY(-1px);
}
.sem-slider-arrow:hover span {
	border-color: var(--blue-2);
}
.sem-slider-dots {
	display: flex;
	align-items: center;
	gap: 9px;
}
.sem-slider-dot {
	width: 34px;
	height: 4px;
	padding: 0;
	border-radius: 999px;
	background: rgba(255,255,255,0.42);
	opacity: 1;
}
.sem-slider-dot.is-active,
.sem-slider-dot:hover {
	width: 62px;
	background: var(--yellow-1);
	box-shadow: 0 0 0 4px rgba(253,208,0,0.14);
}
.testimonials .sem-slider-track {
	min-height: 280px;
}
.testimonials .sem-slide-media,
.testimonials .slide-foreground,
.testimonials .sem-slider-arrow {
	display: none;
}
.testimonials .sem-slide {
	position: absolute;
	inset: 0;
	opacity: 0;
	visibility: hidden;
}
.testimonials .sem-slide.is-active {
	position: relative;
	opacity: 1;
	visibility: visible;
}
.testimonials .sem-slider-controls {
	position: static;
	justify-content: center;
	margin-top: 24px;
	min-height: 0;
	padding: 0;
	border: 0;
	background: transparent;
	box-shadow: none;
	backdrop-filter: none;
}
.testimonials .sem-slider-dot {
	background: var(--white-3);
}
.testimonials .sem-slider-dot.is-active,
.testimonials .sem-slider-dot:hover {
	background: var(--yellow-1);
}

/* Sections and content modules */
.content-container,
.machines-listing,
#categories-listing,
#index-industries,
.contact-short,
.contact-full,
.machine-content {
	padding: 78px 0;
	background: var(--white-1);
}
.content-title {
	position: relative;
	padding: 58px 0 42px;
	overflow: hidden;
	background: linear-gradient(135deg, var(--blue-3) 0%, var(--blue-1) 100%);
	color: var(--white-1);
}
.content-title:before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(90deg, rgba(253,208,0,0.18) 0 5px, transparent 5px 100%);
	pointer-events: none;
}
.content-title .content-spacer-large {
	padding: 0;
}
.section-head {
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: end;
	gap: 24px;
	margin-bottom: 34px;
}
.section-kicker {
	margin-bottom: 10px;
	color: var(--blue-1);
	font-family: var(--title-font);
	font-size: 13px;
	font-weight: 900;
	line-height: 1.1;
	text-transform: uppercase;
}
.section-head h1,
.section-head h2,
.machines-listing h1,
.machines-listing h2,
.content-title h2,
.content-container h2 {
	margin: 0;
	color: var(--black-1);
	font-size: var(--section-title-size);
	line-height: var(--title-line-height);
}
.content-title h2 {
	max-width: 760px;
	color: var(--white-1);
}
.section-head p,
.machines-listing p.epigraph {
	max-width: 670px;
	margin: 14px 0 0;
	color: var(--grey-2);
	font-size: var(--lead-font-size);
	line-height: 1.48;
}
.listing-actions {
	display: grid;
	justify-items: end;
	gap: 14px;
}
.listing-count {
	width: fit-content;
	margin: 0;
	padding: 0 0 10px;
	border-bottom: 4px solid var(--yellow-1);
	color: var(--blue-1);
	font-family: var(--title-font);
	font-size: 14px;
	font-weight: 800;
	line-height: 1.1;
	text-transform: uppercase;
}
.item-2,
.item-3,
.item-4 {
	position: relative;
}
.listing {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
}
.listing .grid_12 {
	grid-column: 1 / -1;
	width: 100%;
}

/* Machine cards */
.machine-grid,
.machines-full-listing {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 18px;
	padding: 0 0 78px;
}
.grid-item.machine-card {
	min-height: 438px;
	display: grid;
	grid-template-rows: 210px 1fr auto;
	border: 1px solid var(--white-3);
	border-radius: 6px;
	background: var(--white-1);
	overflow: hidden;
	box-shadow: var(--soft-shadow);
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
.grid-item.machine-card:hover {
	border-color: var(--yellow-1);
	transform: translateY(-3px);
	box-shadow: var(--shadow);
}
.machine-image {
	display: grid;
	place-items: center;
	margin: 14px 14px 0;
	padding: 18px;
	border: 1px solid var(--white-3);
	border-radius: 5px;
	background: var(--white-1);
	box-shadow: inset 0 -1px 0 rgba(0,0,0,0.04);
}
.machine-image img,
.machine-card img {
	width: 100%;
	height: 166px;
	object-fit: contain;
}
.machine-content,
.machine-card .desc {
	width: auto;
	display: grid;
	gap: 14px;
	padding: 22px;
	background: transparent;
}
.badge-row {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.badge {
	min-height: 24px;
	display: inline-flex;
	align-items: center;
	padding: 2px 9px;
	border-radius: 3px;
	background: var(--yellow-1);
	color: var(--blue-2);
	font-size: 12px;
	font-weight: 900;
	line-height: 1.1;
	text-transform: uppercase;
}
.badge.is-outline {
	border: 1px solid var(--white-3);
	background: var(--white-1);
	color: var(--grey-2);
}
.machine-card h4 {
	margin: 0;
	color: var(--blue-1);
	font-size: 22px;
	line-height: 1.12;
}
.machine-meta {
	display: grid;
	grid-template-columns: 1fr;
	gap: 8px;
	font-size: 14px;
	line-height: 1.35;
}
.machine-meta span {
	padding-top: 8px;
	border-top: 1px solid var(--white-3);
}
.machine-meta strong {
	display: block;
	color: var(--grey-2);
	font-size: 11px;
	line-height: 1.15;
	text-transform: uppercase;
}
.machine-link,
.grid-item.machine-card a.button {
	width: auto;
	min-height: 44px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	margin: 0 22px 22px;
	padding: 0 14px;
	border: 2px solid var(--yellow-1);
	border-radius: 4px;
	background: var(--yellow-1);
	color: var(--blue-2);
	font-size: 13px;
	font-weight: 900;
	line-height: 1.15;
	text-align: left;
	text-transform: uppercase;
	box-shadow: 0 10px 20px rgba(0,31,69,0.08);
}
.machine-link:hover,
.grid-item.machine-card a.button:hover {
	border-color: var(--blue-1);
	background: var(--blue-1);
	color: var(--white-1);
	transform: translateY(-1px);
}
.machine-link:after,
.grid-item.machine-card a.button:after {
	content: ">";
	color: currentColor;
	font-size: 16px;
}

/* Homepage machine categories */
#machine-categories {
	padding: 86px 0 96px;
	background: linear-gradient(180deg, var(--white-1) 0%, #f2f5f8 100%);
}
#machine-categories .content-box {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
	grid-auto-rows: minmax(210px, auto);
	gap: 22px;
	width: min(var(--max), calc(100% - 36px));
	max-width: var(--max);
	margin: 0 auto;
}
.machine-category {
	position: relative;
	min-height: 220px;
	display: grid;
	align-content: stretch;
	overflow: hidden;
	border-radius: 8px;
	background: var(--blue-3);
	color: var(--white-1);
	box-shadow: var(--shadow);
	transform: translateZ(0);
}
.machine-category:first-child {
	grid-row: span 3;
	min-height: 720px;
}
.machine-category .bg-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0.78;
	transform: scale(1.02);
	transition: opacity 0.25s ease, transform 0.45s ease;
}
.machine-category:before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	background:
		linear-gradient(90deg, rgba(0,31,69,0.94) 0%, rgba(0,43,98,0.76) 42%, rgba(0,31,69,0.16) 100%),
		linear-gradient(0deg, rgba(0,31,69,0.72) 0%, rgba(0,31,69,0) 46%);
}
.machine-category:after {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 2;
	border: 1px solid rgba(255,255,255,0.14);
	border-bottom: 5px solid var(--yellow-1);
	border-radius: inherit;
	pointer-events: none;
}
.machine-category .bg-hover {
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(135deg, rgba(0,59,131,0.3) 0%, rgba(253,208,0,0.14) 100%);
	opacity: 0;
	transition: opacity 0.28s ease;
}
.machine-category:hover .bg-img {
	opacity: 0.9;
	transform: scale(1.075);
}
.machine-category:hover .bg-hover {
	opacity: 1;
}
.machine-category > div:not(.bg-hover) {
	position: relative;
	z-index: 3;
	max-width: 62%;
	padding: 30px 30px 88px;
}
.machine-category:first-child > div:not(.bg-hover) {
	max-width: 470px;
	padding: 44px 34px 128px 44px;
}
.machine-category h4 {
	max-width: none;
	margin: 0 0 16px;
	color: var(--white-1);
	font-size: 26px;
	line-height: 1.12;
	text-wrap: balance;
	white-space: normal;
}
.machine-category h4:before {
	content: "SEM";
	display: flex;
	align-items: center;
	width: fit-content;
	min-height: 24px;
	margin-bottom: 14px;
	padding: 0 9px;
	border: 1px solid rgba(253,208,0,0.54);
	border-radius: 3px;
	background: rgba(0,31,69,0.42);
	color: var(--yellow-1);
	font-size: 11px;
	font-weight: 900;
	line-height: 1;
	letter-spacing: 0.08em;
}
.machine-category:first-child h4 {
	max-width: 390px;
	font-size: 42px;
	line-height: 1.05;
}
.machine-category p {
	max-width: 360px;
	margin: 0;
	color: rgba(255,255,255,0.84);
	font-size: 15px;
	line-height: 1.48;
}
.machine-category:first-child p {
	max-width: 440px;
	font-size: 17px;
	line-height: 1.55;
}
.machine-category:not(:first-child) p {
	display: -webkit-box;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
}
.machine-category > a:first-of-type {
	position: absolute;
	right: 18px;
	bottom: 18px;
	z-index: 3;
	width: min(44%, 220px);
	margin: 0;
	filter: drop-shadow(0 22px 28px rgba(0,0,0,0.28));
	transition: transform 0.35s ease, filter 0.35s ease;
}
.machine-category:first-child > a:first-of-type {
	right: -7%;
	bottom: 72px;
	width: min(74%, 590px);
}
.machine-category > a:first-of-type img {
	width: 100%;
	height: auto;
	object-fit: contain;
}
.machine-category:hover > a:first-of-type {
	transform: translateY(-6px) scale(1.02);
	filter: drop-shadow(0 28px 34px rgba(0,0,0,0.34));
}
.machine-category > a:last-child {
	position: absolute;
	left: 30px;
	bottom: 30px;
	z-index: 4;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: fit-content;
	min-height: 44px;
	margin: 0;
	padding: 0 18px;
	border: 2px solid var(--yellow-1);
	border-radius: 4px;
	background: var(--yellow-1);
	color: var(--blue-2);
	font-family: var(--title-font);
	font-size: var(--button-font-size);
	font-weight: 800;
	line-height: 1.1;
	text-transform: uppercase;
}
.machine-category:first-child > a:last-child {
	left: 44px;
	bottom: 44px;
}
.machine-category > a:last-child:after {
	content: ">";
	margin-left: 10px;
}
.machine-category > a:last-child:hover {
	border-color: var(--white-1);
	background: var(--white-1);
	color: var(--blue-2);
}

/* Category, news and gallery listings */
#categories-listing .listing {
	grid-template-columns: repeat(4, 1fr);
}
#categories-listing .item-3,
#news-listing .item-3,
#news_main .item-3 {
	border: 1px solid var(--white-3);
	border-radius: 6px;
	overflow: hidden;
	background: var(--white-1);
	box-shadow: var(--soft-shadow);
}
#categories-listing .item-3 a,
#news-listing .item-3 a {
	display: block;
}
#categories-listing .item-3 img {
	width: 100%;
	height: 170px;
	object-fit: contain;
	padding: 22px;
	background: var(--white-1);
}
#categories-listing .item-3 h4,
#news-listing .item-3 h4,
#news_main .item-3 h4 {
	margin: 0;
	padding: 22px;
	color: var(--blue-1);
	font-size: 22px;
	line-height: 1.12;
}
#news-listing img,
#news_main img {
	width: 100%;
	height: 220px;
	object-fit: cover;
}
.flex-gallery {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 18px;
	margin: 0;
	padding: 0;
	list-style: none;
}
.flex-gallery img {
	width: 100%;
	aspect-ratio: 4 / 3;
	object-fit: cover;
}

/* Distributor page */
#addresses-listing {
	position: relative;
	padding: 0 0 88px;
	background: linear-gradient(180deg, var(--white-1) 0%, var(--grey-4) 100%);
}
#addresses-listing .addresses-intro {
	display: grid;
	grid-template-columns: minmax(0, 0.95fr) minmax(280px, 0.45fr);
	gap: 38px;
	align-items: end;
	padding: 76px 0 34px;
}
#addresses-listing .addresses-intro h1 {
	max-width: 840px;
	margin: 0;
	color: var(--blue-1);
	font-size: var(--section-title-size);
	line-height: var(--title-line-height);
}
#addresses-listing .addresses-intro h1:after,
#addresses-listing .grid_12 h2:after {
	content: "";
	display: block;
	width: var(--title-rule-width);
	height: var(--title-rule-height);
	margin-top: var(--title-rule-gap);
	background: var(--yellow-1);
}
#addresses-listing .addresses-intro p {
	max-width: 660px;
	margin: 18px 0 0;
	color: var(--grey-2);
	font-size: var(--lead-font-size);
	line-height: 1.48;
}
.addresses-intro-points {
	display: grid;
	gap: 10px;
}
.addresses-intro-points span {
	display: flex;
	align-items: center;
	min-height: 54px;
	padding: 0 18px;
	border: 1px solid var(--white-3);
	border-left: 6px solid var(--yellow-1);
	border-radius: 6px;
	background: var(--white-1);
	color: var(--blue-1);
	font-family: var(--title-font);
	font-size: 14px;
	font-weight: 900;
	line-height: 1.15;
	text-transform: uppercase;
	box-shadow: var(--soft-shadow);
}
#addresses-listing > .content-box.flex-container {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 22px;
	align-items: stretch;
}
#addresses-listing.has-region-layout > .content-box.flex-container {
	grid-template-columns: 1fr;
	gap: 28px;
}
.dealer-nav {
	position: sticky;
	top: 96px;
	z-index: 8;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	padding: 10px;
	border: 1px solid rgba(217,221,227,0.92);
	border-radius: 8px;
	background: rgba(255,255,255,0.94);
	box-shadow: var(--soft-shadow);
	backdrop-filter: blur(10px);
}
.dealer-nav a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 38px;
	padding: 0 14px;
	border: 1px solid var(--white-3);
	border-radius: 4px;
	background: var(--grey-4);
	color: var(--blue-1);
	font-family: var(--title-font);
	font-size: 13px;
	font-weight: 900;
	line-height: 1.1;
	text-transform: uppercase;
}
.dealer-nav a:hover {
	border-color: var(--yellow-1);
	background: var(--yellow-1);
	color: var(--blue-2);
}
.dealer-region {
	display: grid;
	gap: 18px;
	scroll-margin-top: 160px;
}
.dealer-cards {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
	align-items: stretch;
}
#addresses-listing .grid_12 {
	grid-column: 1 / -1;
	width: 100%;
	margin-top: 34px;
	padding: 26px 30px;
	border-left: 8px solid var(--yellow-1);
	border-radius: 8px;
	background: var(--blue-3);
	color: var(--white-1);
	box-shadow: var(--soft-shadow);
}
#addresses-listing .grid_12:first-child {
	margin-top: 0;
}
#addresses-listing.has-region-layout .grid_12 {
	margin-top: 0;
}
#addresses-listing .grid_12 h2 {
	margin: 0;
	color: var(--white-1);
	font-size: 34px;
	line-height: var(--title-line-height);
}
#addresses-listing .item-3 {
	min-height: 100%;
	border: 1px solid var(--white-3);
	border-radius: 8px;
	background: var(--white-1);
	box-shadow: var(--soft-shadow);
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
#addresses-listing .item-3:hover {
	border-color: var(--yellow-1);
	transform: translateY(-3px);
	box-shadow: var(--shadow);
}
#addresses-listing .content-spacer-small {
	height: 100%;
	display: flex;
	flex-direction: column;
	padding: 26px;
}
#addresses-listing h4 {
	margin: 0 0 18px;
	color: var(--blue-1);
	font-size: 21px;
	line-height: 1.12;
}
#addresses-listing h4:after {
	content: "";
	display: block;
	width: 36px;
	height: 3px;
	margin-top: 12px;
	background: var(--yellow-1);
}
#addresses-listing .contact-address {
	margin: 0 0 20px;
	color: var(--grey-2);
	font-size: 15px;
	line-height: 1.45;
}
#addresses-listing .contact-phone {
	margin: auto 0 0;
}
#addresses-listing .contact-phone + .contact-phone {
	margin-top: 8px;
}
#addresses-listing .contact-phone a {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	color: var(--blue-1);
	font-family: var(--title-font);
	font-size: 16px;
	font-weight: 900;
	line-height: 1.2;
}
#addresses-listing .contact-phone a:before {
	content: "";
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: var(--yellow-1);
	box-shadow: 0 0 0 4px rgba(253,208,0,0.2);
}
#addresses-listing .contact-phone a:hover {
	color: var(--blue-4);
}

/* Legal pages */
body.legal-page {
	background: var(--grey-4);
}
body.legal-page .page-title {
	min-height: 380px;
	background-color: var(--blue-3);
	background-position: center;
	background-size: cover;
}
body.legal-page .page-title:before {
	background: linear-gradient(90deg, rgba(0,31,69,0.94) 0%, rgba(0,43,98,0.76) 42%, rgba(0,59,131,0.28) 100%);
}
body.legal-page .page-title > div {
	position: relative;
	z-index: 2;
	min-height: 380px;
	display: grid;
	align-items: end;
	padding: 92px 0 62px;
}
body.legal-page .page-title .content-box {
	width: min(980px, calc(100% - 50px));
	max-width: 980px;
	margin-right: auto;
	margin-left: auto;
}
body.legal-page .page-title .content-box > div {
	max-width: 760px;
}
body.legal-page .page-title h1 {
	width: auto;
	margin: 0;
	color: var(--white-1);
	font-size: var(--page-title-size);
	line-height: var(--title-line-height);
	text-shadow: 0 18px 44px rgba(0,0,0,0.34);
}
body.legal-page .page-title h1:before {
	width: 64px;
	height: 6px;
	margin-bottom: 20px;
}
body.legal-page .page-title h4 {
	max-width: 680px;
	margin: 20px 0 0;
	color: rgba(255,255,255,0.84);
	font-family: var(--main-font);
	font-size: var(--lead-font-size);
	font-weight: 500;
	line-height: 1.35;
	text-transform: none;
}
body.legal-page .ariane {
	background: var(--white-1);
}
.legal-toc {
	position: sticky;
	top: 96px;
	z-index: 8;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	align-items: center;
	margin-top: 22px;
	margin-bottom: 18px;
	padding: 10px;
	border: 1px solid rgba(217,221,227,0.92);
	border-radius: 8px;
	background: rgba(255,255,255,0.95);
	box-shadow: var(--soft-shadow);
	backdrop-filter: blur(10px);
}
.legal-toc strong {
	margin-right: 6px;
	color: var(--blue-1);
	font-family: var(--title-font);
	font-size: 13px;
	font-weight: 900;
	text-transform: uppercase;
}
.legal-toc a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 36px;
	padding: 0 12px;
	border: 1px solid var(--white-3);
	border-radius: 4px;
	background: var(--grey-4);
	color: var(--blue-1);
	font-family: var(--title-font);
	font-size: 12px;
	font-weight: 900;
	line-height: 1.1;
	text-transform: uppercase;
}
.legal-toc a:hover {
	border-color: var(--yellow-1);
	background: var(--yellow-1);
	color: var(--blue-2);
}
body.legal-page #main > div[class*="content-"] {
	padding: 0;
	background: var(--white-1);
	color: var(--black-3);
}
body.legal-page #main > .content-7 {
	padding: 58px 0 70px;
	background: var(--grey-4);
}
body.legal-page .ariane + div[class*="content-"],
body.legal-page #main > div[class*="content-"]:first-of-type {
	padding-top: 46px;
}
body.legal-page .ariane + .content-7 {
	padding-top: 58px;
}
body.legal-page .legal-toc + div[class*="content-"] {
	padding-top: 28px;
}
body.legal-page #main > div[class*="content-"] > .content-box,
body.legal-page #main > div[class*="content-"] > .flex-container.content-box {
	width: min(980px, calc(100% - 36px));
	max-width: 980px;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 0 18px;
}
body.legal-page #main > .content-7 > .content-box,
body.legal-page #main > .content-7 > .flex-container.content-box {
	gap: 30px 22px;
	padding-bottom: 0;
}
body.legal-page #main > div[class*="content-"] .grid_12 {
	grid-column: 1 / -1;
	width: 100%;
}
body.legal-page #main > div[class*="content-"] .grid_6 {
	width: 100%;
}
body.legal-page #main > div[class*="content-"] .content-spacer-large {
	margin: 0;
	padding: 36px 40px;
	border: 1px solid var(--white-3);
	border-bottom: 0;
	border-left: 7px solid var(--yellow-1);
	border-radius: 0;
	background: var(--white-1);
	box-shadow: none;
}
body.legal-page .ariane + div[class*="content-"] .content-spacer-large,
body.legal-page .legal-toc + div[class*="content-"] .content-spacer-large,
body.legal-page #main > div[class*="content-"]:first-of-type .content-spacer-large {
	border-radius: 8px 8px 0 0;
}
body.legal-page #main > div[class*="content-"]:last-of-type .content-spacer-large {
	margin-bottom: 58px;
	border-bottom: 1px solid var(--white-3);
	border-radius: 0 0 8px 8px;
	box-shadow: var(--soft-shadow);
}
body.legal-page #main > div[class*="content-"].color-black .content-spacer-large {
	border-left-color: var(--blue-1);
}
body.legal-page #main > div[class*="content-"] h4.center {
	display: inline-flex;
	align-items: center;
	min-height: 30px;
	margin: 0 0 16px;
	padding: 0 12px;
	border-radius: 4px;
	background: var(--yellow-1);
	color: var(--blue-2);
	font-family: var(--title-font);
	font-size: 12px;
	font-weight: 900;
	line-height: 1.1;
	text-align: left;
	text-transform: uppercase;
}
body.legal-page #main > div[class*="content-"] h2 {
	max-width: 760px;
	margin: 0 0 24px;
	color: var(--blue-1);
	font-size: 32px;
	line-height: 1.12;
	text-align: left;
}
body.legal-page #main > div[class*="content-"] h2:after {
	content: "";
	display: block;
	width: var(--title-rule-width);
	height: var(--title-rule-height);
	margin-top: var(--title-rule-gap);
	background: var(--yellow-1);
}
body.legal-page #main > div[class*="content-"] h3 {
	margin: 28px 0 12px;
	color: var(--blue-2);
	font-size: 20px;
	line-height: 1.18;
	text-align: left;
}
body.legal-page #main > div[class*="content-"] p,
body.legal-page #main > div[class*="content-"] li {
	color: var(--grey-2);
	font-size: 17px;
	line-height: 1.72;
}
body.legal-page #main > div[class*="content-"] p {
	margin-bottom: 16px;
}
body.legal-page #main > div[class*="content-"] p.aligncenter {
	max-width: 760px;
	margin-right: auto;
	margin-left: auto;
	text-align: center;
}
body.legal-page #main > div[class*="content-"] .text-2columns {
	column-count: 1;
	column-gap: 0;
}
body.legal-page #main > div[class*="content-"] a:not(.button) {
	color: var(--blue-1);
	font-weight: 800;
	text-decoration: underline;
	text-decoration-color: rgba(253,208,0,0.9);
	text-decoration-thickness: 2px;
	text-underline-offset: 3px;
}
body.legal-page #main > div[class*="content-"] ul.in-text,
body.legal-page #main > div[class*="content-"] ol.in-text {
	display: grid;
	gap: 10px;
	margin: 18px 0 24px;
	padding: 0;
	list-style: none;
}
body.legal-page #main > div[class*="content-"] ul.in-text li,
body.legal-page #main > div[class*="content-"] ol.in-text li {
	position: relative;
	padding-left: 26px;
}
body.legal-page #main > div[class*="content-"] ul.in-text li:before,
body.legal-page #main > div[class*="content-"] ol.in-text li:before {
	content: "";
	position: absolute;
	top: 0.72em;
	left: 0;
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background: var(--yellow-1);
	box-shadow: 0 0 0 4px rgba(253,208,0,0.18);
}
body.legal-page #main > div[class*="content-"] strong {
	color: var(--blue-2);
}
body.legal-page #main > div[class*="content-"] .button {
	margin-top: 6px;
	box-shadow: var(--soft-shadow);
}
body.legal-page #main > .content-7 .content-spacer-small {
	height: 100%;
	margin: 0;
	padding: 30px;
	border: 1px solid var(--white-3);
	background: var(--white-1);
}
body.legal-page #main > .content-7 .grid_12 .content-spacer-small {
	padding: 38px 42px;
	border-left: 7px solid var(--yellow-1);
	border-radius: 8px;
	box-shadow: var(--soft-shadow);
}
body.legal-page #main > .content-7 .grid_6 .content-spacer-small {
	display: grid;
	align-content: space-between;
	gap: 22px;
	min-height: 230px;
	border-top: 1px solid var(--white-3);
	border-radius: 8px;
	box-shadow: var(--soft-shadow);
	transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}
body.legal-page #main > .content-7 .grid_6:first-of-type .content-spacer-small {
	border-radius: 8px;
}
body.legal-page #main > .content-7 .grid_6:last-of-type .content-spacer-small {
	border-radius: 8px;
}
body.legal-page #main > .content-7 .grid_6 .content-spacer-small:hover {
	border-color: var(--yellow-1);
	transform: translateY(-3px);
	box-shadow: var(--shadow);
}
body.legal-page #main > .content-7 .grid_6 h3 {
	position: relative;
	margin: 0;
	color: var(--blue-1);
	font-size: 24px;
	text-align: left;
}
body.legal-page #main > .content-7 .grid_6 h3:before {
	content: "";
	display: block;
	width: 42px;
	height: 4px;
	margin-bottom: 16px;
	background: var(--yellow-1);
}
body.legal-page #main > .content-7 .grid_6 p.aligncenter {
	margin: 0;
	text-align: left;
}
body.legal-page #main > .content-7 .grid_6 .button {
	width: 100%;
	justify-content: space-between;
	min-height: 52px;
}
.zoom-icon {
	display: none;
}

/* Application / industries */
#index-industries {
	background: var(--grey-4);
}
#index-industries h2 {
	width: min(var(--max), calc(100% - 36px));
	margin: 0 auto 34px;
	padding: 0;
	color: var(--black-1);
	font-size: var(--section-title-size);
	line-height: var(--title-line-height);
}
#index-industries .flex-container {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 12px;
	width: min(var(--max), calc(100% - 36px));
	margin: 0 auto;
}
#index-industries a {
	min-height: 138px;
	display: grid;
	align-content: space-between;
	padding: 18px;
	border: 1px solid var(--white-3);
	border-radius: 6px;
	background: var(--white-1);
	color: var(--blue-1);
}
#index-industries a span:first-child {
	color: var(--yellow-3);
	font-size: 22px;
	line-height: 1.05;
}
#index-industries a span:nth-child(2) {
	font-size: 17px;
	font-weight: 800;
	line-height: 1.18;
	text-transform: uppercase;
}
#index-industries a:hover {
	background: var(--yellow-1);
	border-color: var(--yellow-1);
	color: var(--blue-2);
}
#industries {
	padding: 78px 0;
	background: var(--grey-4);
}
#industries .flex-container {
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: 24px;
}
#industries ul {
	margin: 0;
	padding: 0;
	list-style: none;
	background: var(--blue-1);
}
#industries li {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 18px;
	border-bottom: 1px solid rgba(255,255,255,0.14);
	color: var(--white-1);
	cursor: pointer;
}
#industries li:hover,
#industries li.active {
	background: var(--yellow-1);
	color: var(--blue-2);
}
#industries .flex-container > div {
	display: none;
	position: relative;
	min-height: 380px;
	overflow: hidden;
	border-radius: 6px;
	background: var(--blue-3);
}
#industries .flex-container > div.open {
	display: block;
}
#industries img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0.68;
}
#industries h3,
#industries a {
	position: absolute;
	left: 38px;
	z-index: 2;
}
#industries h3 {
	top: 40px;
	max-width: 560px;
	color: var(--white-1);
	font-size: 34px;
	line-height: var(--title-line-height);
}
#industries a {
	top: 150px;
}

/* Breadcrumb and vehicle nav */
.ariane {
	padding: 12px 0;
	background: var(--white-1);
	border-bottom: 1px solid var(--white-3);
}
.ariane ul {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
}
.ariane a {
	color: var(--grey-2);
	font-size: 13px;
	line-height: 1.2;
}
.ariane li:not(:last-child):after {
	content: ">";
	margin-left: 8px;
	color: var(--grey-3);
}
#vehicle-nav-holder {
	min-height: 64px;
}
#vehicle-nav {
	z-index: 60;
	background: var(--blue-3);
	color: var(--white-1);
	box-shadow: 0 14px 28px rgba(0,31,69,0.14);
}
#vehicle-nav.sticky {
	position: fixed;
	top: 70px;
	left: 0;
	width: 100%;
}
#vehicle-nav ul {
	display: flex;
	flex-wrap: nowrap;
	gap: 2px;
	overflow-x: auto;
	margin: 0;
	padding: 0;
	list-style: none;
	scrollbar-width: none;
}
#vehicle-nav ul::-webkit-scrollbar {
	display: none;
}
#vehicle-nav li {
	flex: 0 0 auto;
	border-bottom: 4px solid transparent;
	font-size: 13px;
	font-weight: 800;
	line-height: 1.1;
	text-transform: uppercase;
	cursor: pointer;
}
#vehicle-nav li > a,
#vehicle-nav li > span {
	display: block;
	padding: 20px 18px;
	color: inherit;
	white-space: nowrap;
}
#vehicle-nav li.active,
#vehicle-nav li:hover {
	border-color: var(--yellow-1);
	color: var(--yellow-1);
}
.js-content {
	display: none;
}
.js-content.open {
	display: block;
}

/* Machine pages */
.machine-1,
.machine-2,
.machine-4 {
	padding: 86px 0;
	background: var(--white-1);
}
.machine-anchor-section {
	scroll-margin-top: 150px;
}
.machine-1 {
	background: linear-gradient(180deg, #f3f5f8 0%, #ffffff 100%);
}
.machine-hero-grid {
	display: grid;
	grid-template-columns: minmax(0, 1.04fr) minmax(360px, 0.96fr);
	gap: 34px;
	align-items: stretch;
}
.machine-hero-visual {
	display: grid;
	place-items: center;
	min-height: 520px;
	padding: 34px;
	border: 1px solid var(--white-3);
	border-radius: 8px;
	background: var(--white-1);
	box-shadow: var(--soft-shadow);
}
.machine-hero-visual img {
	width: 100%;
	max-height: 460px;
	height: auto;
	object-fit: contain;
}
.machine-hero-panel {
	display: grid;
	align-content: center;
	gap: 22px;
	padding: 42px;
	border-radius: 8px;
	background: linear-gradient(145deg, var(--blue-3) 0%, var(--blue-1) 100%);
	color: var(--white-1);
	box-shadow: var(--shadow);
}
.machine-1 h1,
.machine-1 h2,
.machine-2 h2,
.machine-4 h2 {
	color: var(--blue-1);
	font-size: var(--machine-title-size);
	line-height: var(--title-line-height);
}
.machine-hero-panel h1 {
	margin: 0;
	color: var(--white-1);
}
.machine-hero-panel h1:after {
	background: var(--yellow-1);
}
.machine-hero-panel h3 {
	margin: 8px 0 0;
	color: var(--yellow-1);
	font-size: 17px;
	line-height: 1.12;
	text-transform: uppercase;
}
.machine-hero-panel .badge.is-outline {
	background: rgba(255,255,255,0.1);
	border-color: rgba(255,255,255,0.22);
	color: rgba(255,255,255,0.88);
}
.machine-hero-panel .sem-btn {
	width: fit-content;
}
.machine-main-specs {
	display: grid;
	grid-template-columns: 1fr;
	gap: 10px;
	margin: 0;
}
.machine-main-specs div {
	display: grid;
	grid-template-columns: minmax(130px, 0.8fr) minmax(0, 1.2fr);
	gap: 16px;
	align-items: baseline;
	padding: 14px 0;
	border-top: 1px solid rgba(255,255,255,0.16);
}
.machine-main-specs span {
	color: rgba(255,255,255,0.62);
	font-size: 12px;
	font-weight: 800;
	line-height: 1.2;
	text-transform: uppercase;
}
.machine-main-specs strong {
	color: var(--white-1);
	font-size: 17px;
	line-height: 1.25;
}
.encart {
	padding: 16px 18px;
	border: 1px solid var(--white-3);
	border-radius: 6px;
	background: var(--grey-4);
}
.machine-story-layout {
	display: grid;
	grid-template-columns: 280px minmax(0, 1fr);
	gap: 26px;
	align-items: stretch;
}
.machine-story-nav {
	position: sticky;
	top: 154px;
	align-self: start;
	display: grid;
	gap: 8px;
	padding: 10px;
	border: 1px solid var(--white-3);
	border-radius: 8px;
	background: var(--white-1);
	box-shadow: var(--soft-shadow);
}
.machine-story-nav button {
	width: 100%;
	padding: 14px 16px;
	border: 0;
	border-radius: 5px;
	background: transparent;
	color: var(--blue-1);
	font-size: 13px;
	font-weight: 900;
	line-height: 1.18;
	text-align: left;
	text-transform: uppercase;
	cursor: pointer;
}
.machine-story-nav button:hover,
.machine-story-nav button.is-active {
	background: var(--yellow-1);
	color: var(--blue-2);
}
.machine-story-panels {
	min-width: 0;
}
.machine-story-panel {
	display: none;
	grid-template-columns: minmax(0, 0.96fr) minmax(320px, 1.04fr);
	gap: 28px;
	align-items: center;
	min-height: 430px;
}
.machine-story-panel.is-active {
	display: grid;
}
.machine-story-copy {
	padding: 34px;
	border-left: 6px solid var(--yellow-1);
	border-radius: 8px;
	background: var(--white-1);
	box-shadow: var(--soft-shadow);
}
.machine-story-copy h3 {
	margin-bottom: 16px;
	color: var(--blue-1);
	font-size: 30px;
	line-height: 1.1;
}
.machine-story-copy p:last-child {
	margin-bottom: 0;
}
.machine-story-media {
	display: grid;
	place-items: center;
	min-height: 390px;
	padding: 26px;
	border: 1px solid var(--white-3);
	border-radius: 8px;
	background: var(--white-1);
	box-shadow: var(--soft-shadow);
}
.machine-story-media img {
	max-height: 360px;
	width: 100%;
	object-fit: contain;
}
.machine-data {
	margin: 0;
	padding: 0;
	list-style: none;
	border-top: 1px solid var(--white-3);
}
.machine-data li {
	border-bottom: 1px solid var(--white-3);
}
.machine-data > li > div {
	display: block;
	padding: 22px 0 10px;
	color: var(--blue-1);
	font-size: 20px;
	font-weight: 800;
	line-height: 1.25;
}
.machine-data > li > ul {
	display: block;
	margin: 0;
	padding: 0 0 12px;
	list-style: none;
}
.machine-data > li > ul > li {
	display: grid;
	grid-template-columns: minmax(260px, 0.58fr) minmax(0, 1fr);
	gap: 24px;
	align-items: baseline;
	padding: 12px 0;
	border-bottom: 1px solid rgba(217,221,227,0.72);
}
.machine-data > li > ul > li:last-child {
	border-bottom: 0;
}
.machine-data li span {
	display: block;
	padding: 0;
	line-height: 1.35;
}
.machine-data li span:first-child {
	color: var(--grey-2);
	font-size: 13px;
	font-weight: 900;
	text-transform: uppercase;
}
.machine-data li span:last-child {
	color: var(--black-2);
	font-size: 16px;
	font-weight: 700;
	text-align: right;
}
.machine-data.single-list {
	display: grid;
	gap: 14px;
	border-top: 0;
}
.machine-data.single-list > li {
	border: 1px solid var(--white-3);
	border-left: 6px solid var(--blue-1);
	border-radius: 8px;
	background: var(--white-1);
	box-shadow: var(--soft-shadow);
	overflow: hidden;
}
.machine-data.machine-options-list > li {
	border-left-color: var(--yellow-1);
}
.machine-data.single-list > li > div {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 22px 24px;
	border-bottom: 1px solid var(--white-3);
	background: linear-gradient(180deg, var(--white-1) 0%, var(--grey-4) 100%);
	color: var(--blue-1);
	font-size: 18px;
	font-weight: 900;
	line-height: 1.15;
	text-transform: uppercase;
}
.machine-data.single-list > li > div:before {
	content: "";
	flex: 0 0 auto;
	width: 42px;
	height: 4px;
	background: var(--yellow-1);
}
.machine-data.single-list ul {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 12px;
	margin: 0;
	padding: 24px;
	list-style: none;
}
.machine-data.single-list > li > ul > li {
	position: relative;
	display: flex;
	align-items: center;
	min-height: 54px;
	padding: 14px 16px 14px 46px;
	border: 1px solid rgba(217,221,227,0.82);
	border-radius: 6px;
	background: linear-gradient(180deg, var(--white-1) 0%, #fbfcfd 100%);
	color: var(--black-2);
	font-size: 15px;
	font-weight: 800;
	line-height: 1.32;
}
.machine-data.single-list > li > ul > li:before {
	content: "";
	position: absolute;
	top: 50%;
	left: 17px;
	width: 9px;
	height: 9px;
	background: var(--yellow-1);
	box-shadow: 0 0 0 5px rgba(253,208,0,0.16);
	transform: translateY(-50%);
}
.machine-data.single-list li span,
.machine-data.single-list li span:first-child,
.machine-data.single-list li span:last-child {
	color: inherit;
	font-size: inherit;
	font-weight: inherit;
	line-height: inherit;
	text-align: left;
	text-transform: none;
}
.brochure-block {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 24px;
	align-items: center;
	padding: 34px;
	border: 1px solid var(--white-3);
	border-radius: 8px;
	background: linear-gradient(135deg, #ffffff 0%, #f3f5f8 100%);
	box-shadow: var(--soft-shadow);
}
.brochure-block h2 {
	margin: 0;
	font-size: 36px;
}
.content-14.machine-anchor-section {
	padding: 86px 0;
	background: var(--white-1);
}
.content-14.machine-anchor-section h2 {
	width: min(var(--max), calc(100% - 36px));
	margin: 0 auto 34px;
	color: var(--blue-1);
	font-size: var(--section-title-size);
}
.flex-gallery .touch-item {
	display: block;
	overflow: hidden;
	border: 1px solid var(--white-3);
	border-radius: 8px;
	background: var(--white-1);
	box-shadow: var(--soft-shadow);
}
.flex-gallery .touch-item img {
	transition: transform 0.3s ease;
}
.flex-gallery .touch-item:hover img {
	transform: scale(1.04);
}
.phone-contact a {
	color: var(--blue-1);
	font-size: var(--machine-title-size);
	font-weight: 800;
	line-height: var(--title-line-height);
}

/* Quote/contact section */
.contact-short {
	background: linear-gradient(180deg, #ffffff 0%, #f3f5f8 100%);
}
.quote-layout {
	display: grid;
	grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr);
	gap: 34px;
	align-items: start;
}
.quote-aside {
	padding: 32px;
	border-left: 8px solid var(--yellow-1);
	border-radius: 6px;
	background: var(--blue-1);
	color: var(--white-1);
}
.quote-aside .section-kicker {
	color: var(--yellow-1);
}
.quote-aside h2 {
	color: var(--white-1);
	font-size: 38px;
	line-height: var(--title-line-height);
}
.quote-aside p {
	margin: 18px 0 0;
	color: rgba(255,255,255,0.82);
	font-size: 18px;
	line-height: 1.5;
}
.contact-methods {
	display: grid;
	gap: 12px;
	margin-top: 28px;
}
.contact-methods a {
	min-height: 48px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	border-top: 1px solid rgba(255,255,255,0.22);
	color: var(--white-1);
	font-size: 15px;
	font-weight: 800;
	line-height: 1.2;
}
.contact-methods a:after {
	content: ">";
	color: var(--yellow-1);
}
.quote-form-shell > h2 {
	display: none;
}
.quote-form {
	display: block;
	padding: 30px;
	border: 1px solid var(--white-3);
	border-radius: 6px;
	background: var(--white-1);
	box-shadow: var(--soft-shadow);
}
.quote-form .input_form {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 16px;
}
.quote-form .input_form > div,
.quote-form .input_form > div.form-half {
	width: auto;
}
.quote-form .input_form > div:last-child,
.quote-form p.small,
.quote-form .recaptcha-holder {
	grid-column: 1 / -1;
}
.quote-form input[type=submit] {
	margin-top: 16px;
}
.contact-full.color-black {
	background: linear-gradient(145deg, var(--blue-3) 0%, var(--blue-1) 100%);
	color: var(--white-1);
}
.contact-full.color-black > .content-box {
	display: grid;
	grid-template-columns: minmax(280px, 0.78fr) minmax(0, 1.22fr);
	gap: 34px;
	align-items: start;
}
.contact-full.color-black > .content-box > h2 {
	margin: 0;
	color: var(--white-1);
	font-size: 46px;
	line-height: var(--title-line-height);
}
.contact-full.color-black > .content-box > h2:after {
	background: var(--yellow-1);
}
.contact-full.color-black .content-spacer-small {
	padding: 0;
}
.contact-full.color-black .contact-form {
	padding: 30px;
	border-radius: 8px;
	background: var(--white-1);
	color: var(--black-2);
	box-shadow: var(--shadow);
}
.contact-full.color-black .input_form {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 16px;
}
.contact-full.color-black .input_form > div,
.contact-full.color-black .input_form > div.form-half {
	width: auto;
}
.contact-full.color-black .form-consent,
.contact-full.color-black input[type=submit] {
	grid-column: 1 / -1;
}
.contact-full.color-black .contact-form > p {
	color: var(--grey-2);
	font-size: 16px;
	line-height: 1.45;
}
.contact-full.color-black .contact-form > p:first-child {
	margin-bottom: 8px;
	color: var(--blue-1);
	font-size: 20px;
	font-weight: 800;
}
.contact-full.color-black .form-consent {
	color: var(--grey-2);
}
.contact-full.color-black input[type=submit] {
	width: 100%;
	margin-top: 18px;
}
.recaptcha-holder {
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	opacity: 0;
	pointer-events: none;
}
.grecaptcha-badge {
	visibility: hidden;
}
.expert-section {
	padding: 78px 0;
	background: linear-gradient(180deg, var(--white-1) 0%, var(--grey-4) 100%);
}
.expert-callout {
	display: grid;
	grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
	gap: 28px;
	align-items: center;
	padding: 34px;
	border: 1px solid var(--white-3);
	border-left: 8px solid var(--yellow-1);
	border-radius: 8px;
	background: var(--white-1);
	color: var(--blue-1);
	box-shadow: var(--soft-shadow);
}
.expert-callout-copy h2 {
	margin: 0;
	color: var(--blue-1);
	font-size: 40px;
	line-height: var(--title-line-height);
}
.expert-callout-copy h2:after {
	background: var(--yellow-1);
}
.expert-callout-copy p {
	margin: 20px 0 0;
	color: var(--grey-2);
	font-size: 16px;
	line-height: 1.45;
}
.expert-callout-grid {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 14px;
}
.expert-callout-grid a {
	display: grid;
	gap: 10px;
	padding: 22px;
	border: 1px solid var(--white-3);
	border-radius: 6px;
	background: linear-gradient(180deg, var(--white-1) 0%, var(--grey-4) 100%);
	color: var(--blue-1);
}
.expert-callout-grid a:hover {
	border-color: var(--yellow-1);
	background: var(--yellow-1);
	color: var(--blue-2);
}
.expert-callout-grid span {
	color: var(--grey-2);
	font-size: 12px;
	font-weight: 900;
	line-height: 1.1;
	text-transform: uppercase;
}
.expert-callout-grid strong {
	color: var(--blue-1);
	font-size: 24px;
	line-height: 1.1;
	white-space: nowrap;
}
.expert-callout-grid a:hover span,
.expert-callout-grid a:hover strong {
	color: var(--blue-2);
}

/* Footer */
.sem-footer {
	position: relative;
	padding: 0;
	background: linear-gradient(135deg, var(--blue-3) 0%, var(--blue-2) 54%, #001832 100%);
	color: rgba(255,255,255,0.76);
}
.sem-footer-inner {
	display: grid;
	grid-template-columns: minmax(300px, 0.95fr) minmax(0, 0.72fr) minmax(0, 0.78fr) minmax(310px, 1fr);
	gap: 30px;
	padding: 62px 0 56px;
}
.sem-footer-inner > .grid_3 {
	width: auto;
	min-width: 0;
}
.sem-footer-col {
	min-width: 0;
}
.sem-footer-brand {
	order: -1;
}
.sem-footer .content-spacer {
	height: 100%;
	padding: 0 0 0 28px;
	border-left: 1px solid rgba(255,255,255,0.14);
}
.sem-footer-brand .content-spacer {
	padding: 28px;
	border: 1px solid rgba(255,255,255,0.16);
	border-left: 6px solid var(--yellow-1);
	border-radius: 8px;
	background: rgba(255,255,255,0.06);
	box-shadow: 0 18px 46px rgba(0,0,0,0.16);
}
.sem-footer h3 {
	margin-bottom: 18px;
	color: var(--white-1);
	font-size: 17px;
	line-height: 1.15;
}
.sem-footer h3:after {
	width: 44px;
	height: 4px;
	margin-top: 14px;
}
.sem-footer ul {
	margin: 0;
	padding: 0;
	list-style: none;
}
.sem-footer nav li + li {
	margin-top: 11px;
}
.sem-footer a {
	color: rgba(255,255,255,0.82);
	line-height: 1.45;
}
.sem-footer nav a {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	font-size: 15px;
	font-weight: 700;
}
.sem-footer nav a:before {
	content: "";
	flex: 0 0 auto;
	width: 10px;
	height: 2px;
	background: rgba(253,208,0,0.62);
	transition: width 0.2s ease, background 0.2s ease;
}
.sem-footer a:hover,
.sem-footer nav a:hover {
	color: var(--yellow-1);
}
.sem-footer nav a:hover:before {
	width: 18px;
	background: var(--yellow-1);
}
.sem-footer-logo.logo {
	width: 156px;
	height: 76px;
	margin: 0 0 24px;
	border-radius: 4px;
	background-color: var(--white-1);
	background-position: center;
	background-size: calc(100% - 28px) auto;
	filter: none;
}
.sem-footer-kicker {
	margin: 0;
	color: var(--white-1);
	font-family: var(--title-font);
	font-size: 28px;
	font-weight: 800;
	line-height: 1.08;
	text-transform: uppercase;
}
.sem-footer-text {
	max-width: 270px;
	margin: 14px 0 0;
	color: rgba(255,255,255,0.74);
	font-size: 16px;
	font-weight: 700;
	line-height: 1.45;
}
.footer-address {
	margin: 0 0 14px;
	color: rgba(255,255,255,0.7);
	font-size: 14px;
	line-height: 1.5;
}
.footer-address strong {
	color: inherit;
	font-weight: 700;
}
.footer-call {
	margin: 22px 0 0;
	padding: 18px 20px;
	border-left: 5px solid var(--yellow-1);
	border-radius: 6px;
	background: rgba(255,255,255,0.07);
	color: rgba(255,255,255,0.72);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.65;
	text-transform: uppercase;
}
.footer-call a {
	color: var(--white-1);
	font-size: 20px;
	font-weight: 900;
	line-height: 1.25;
	text-transform: none;
	white-space: nowrap;
}
.footer-call a:hover {
	color: var(--yellow-1);
}
.social {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 24px;
}
.social li a {
	width: 44px;
	height: 44px;
	display: grid;
	place-items: center;
	border: 1px solid rgba(255,255,255,0.18);
	border-radius: 50%;
	background: rgba(255,255,255,0.05);
}
.social li a:hover {
	border-color: var(--yellow-1);
	background: var(--yellow-1);
	transform: translateY(-2px);
}
.social svg {
	width: 18px;
	height: 18px;
	fill: var(--white-1);
}
.social li a:hover svg {
	fill: var(--blue-2);
}
#copyright.sem-copyright {
	padding: 0;
	background: #001832;
	border-top: 1px solid rgba(255,255,255,0.12);
	color: rgba(255,255,255,0.62);
}
.sem-copyright-inner {
	min-height: 66px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}
#copyright nav ul,
#lang-menu ul {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 10px 16px;
	margin: 0;
	padding: 0;
	list-style: none;
}
#copyright li,
#copyright a,
#copyright span {
	color: rgba(255,255,255,0.62);
	font-size: 13px;
	font-weight: 700;
	line-height: 1.25;
}
#copyright a:hover {
	color: var(--yellow-1);
}
#lang-menu a {
	display: inline-flex;
	align-items: center;
	min-height: 34px;
	padding: 0 12px;
	border: 1px solid rgba(255,255,255,0.16);
	border-radius: 4px;
	color: rgba(255,255,255,0.78);
}
#lang-menu a:hover {
	border-color: var(--yellow-1);
	background: var(--yellow-1);
	color: var(--blue-2);
}

/* Utility content */
.share-box {
	margin-top: 24px;
}
.page-title {
	position: relative;
	isolation: isolate;
	overflow: hidden;
	background-color: var(--blue-3);
	background-position: center;
	background-size: cover;
	color: var(--white-1);
}
.page-title > .desktop-only,
.page-title > .mobile-only {
	position: relative;
	min-height: 430px;
	align-items: end;
	overflow: hidden;
	padding: 92px 0 72px;
}
.page-title > .desktop-only {
	display: grid;
}
.page-title > .mobile-only {
	display: none;
}
.page-title > .desktop-only:before,
.page-title > .mobile-only:before,
.page-title:before {
	content: "";
	position: absolute;
	inset: 0;
	z-index: 1;
	background: linear-gradient(90deg, rgba(0,31,69,0.86) 0%, rgba(0,31,69,0.64) 34%, rgba(0,43,98,0.2) 66%, rgba(0,31,69,0.1) 100%);
}
.page-title:before {
	z-index: 0;
	background: linear-gradient(90deg, rgba(0,31,69,0.9) 0%, rgba(0,43,98,0.55) 100%);
}
.page-title .content-box,
.page-title .flex-container {
	position: relative;
	z-index: 2;
	align-items: center;
}
.page-title > * {
	position: relative;
	z-index: 2;
}
.page-title img {
	position: absolute;
	inset: 0;
	z-index: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
.page-title h1 {
	position: relative;
	z-index: 2;
	width: min(820px, calc(100% - 50px));
	margin: 0 25px 0 max(25px, calc((100vw - var(--max)) / 2));
	color: var(--white-1);
	font-size: var(--page-title-size);
	line-height: var(--title-line-height);
	text-shadow: 0 18px 44px rgba(0,0,0,0.34);
}
.page-title > h1 {
	width: min(var(--max), calc(100% - 36px));
	max-width: min(var(--max), calc(100% - 36px));
	margin-right: auto;
	margin-left: auto;
}
.page-title h1:before {
	content: "";
	display: block;
	width: 54px;
	height: 5px;
	margin-bottom: 18px;
	background: var(--yellow-1);
}
.page-title h1:after {
	display: none;
}
.parallax-content {
	min-height: 420px;
	display: grid;
	align-items: center;
	background-position: center;
	background-size: cover;
	color: var(--white-1);
}
.has-lightbox {
	overflow: hidden;
}
.sem-lightbox {
	position: fixed;
	inset: 0;
	z-index: 10000;
	display: grid;
	grid-template-columns: 72px minmax(0, 1fr) 72px;
	align-items: center;
	gap: 18px;
	padding: 34px;
	background: rgba(0,31,69,0.92);
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 0.2s ease, visibility 0.2s ease;
}
.sem-lightbox.is-open {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}
.sem-lightbox figure {
	min-width: 0;
	margin: 0;
}
.sem-lightbox img {
	width: 100%;
	max-height: calc(100vh - 130px);
	object-fit: contain;
	border-radius: 6px;
	background: var(--white-1);
	box-shadow: var(--shadow);
}
.sem-lightbox figcaption {
	margin-top: 14px;
	color: var(--white-1);
	font-size: 15px;
	font-weight: 800;
	line-height: 1.25;
	text-align: center;
}
.sem-lightbox button {
	border: 0;
	background: var(--yellow-1);
	color: var(--blue-2);
	font-family: var(--title-font);
	font-weight: 900;
	cursor: pointer;
}
.sem-lightbox-close {
	position: absolute;
	top: 20px;
	right: 20px;
	width: 46px;
	height: 46px;
	border-radius: 50%;
	font-size: 28px;
	line-height: 1;
}
.sem-lightbox-nav {
	width: 58px;
	height: 58px;
	border-radius: 50%;
	font-size: 42px;
	line-height: 1;
}
.sem-lightbox-prev {
	grid-column: 1;
}
.sem-lightbox figure {
	grid-column: 2;
}
.sem-lightbox-next {
	grid-column: 3;
}

/* Responsive */
@media only screen and (max-width: 1280px) {
	:root {
		--hero-title-size: 66px;
		--page-title-size: 58px;
		--section-title-size: 44px;
		--machine-title-size: 48px;
	}
	.content-box,
	.content-box.flex-container,
	.sem-topline-inner,
	.sem-nav-inner,
	.sem-slide-caption,
	#stock,
	#index-industries h2,
	#index-industries .flex-container {
		width: calc(100% - 50px);
		margin-left: 25px;
		margin-right: 25px;
	}
	.sem-nav-inner {
		gap: 12px;
	}
	#main-menu > ul {
		gap: 4px;
	}
	#main-menu > ul > li > a,
	#main-menu > ul > li > span:not(.bg-menu) {
		padding-left: 5px;
		padding-right: 5px;
		font-size: 13px;
	}
	#main-menu > ul > li:nth-last-child(-n+2) > a,
	#main-menu > ul > li:nth-last-child(-n+2) > span:not(.bg-menu) {
		min-height: 38px;
		padding-left: 10px;
		padding-right: 10px;
	}
	.page-title h1 {
		margin-left: 25px;
		width: min(820px, calc(100% - 50px));
	}
}
@media only screen and (max-width: 1080px) {
	:root {
		--hero-title-size: 56px;
		--page-title-size: 50px;
		--section-title-size: 40px;
		--machine-title-size: 42px;
		--lead-font-size: 18px;
	}
	#main {
		padding-top: 70px;
	}
	#side {
		--side-header-height: 70px;
	}
	.sem-topline,
	#main-menu {
		display: none;
	}
	.top-header,
	.top-sticky {
		height: 70px;
	}
	.sem-nav-inner,
	.top-sticky .sem-nav-inner {
		min-height: 63px;
	}
	#header-logo .logo,
	.top-sticky #header-logo .logo {
		width: 78px;
		height: 40px;
	}
	#menu-trigger {
		display: block;
	}
	.slideshow {
		height: calc(100vh - 70px);
		min-height: 640px;
	}
	.slideshow .sem-slide-caption {
		padding-bottom: 98px;
	}
	.slideshow .sem-slide:after {
		bottom: 94px;
	}
	.sem-slider-controls {
		bottom: 34px;
	}
	.machine-grid,
	.machines-full-listing,
	#machine-categories .content-box,
	#categories-listing .listing,
	#index-industries .flex-container,
	.flex-gallery,
	.dealer-cards,
	.listing {
		grid-template-columns: repeat(2, 1fr);
	}
	#addresses-listing .addresses-intro {
		grid-template-columns: 1fr;
		align-items: start;
		padding-top: 62px;
	}
	#addresses-listing > .content-box.flex-container {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
	.dealer-nav {
		top: 82px;
	}
	body.legal-page .page-title,
	body.legal-page .page-title > div {
		min-height: 340px;
	}
	body.legal-page .page-title > div {
		padding: 70px 0 52px;
	}
	body.legal-page .page-title .content-box {
		width: calc(100% - 50px);
		margin-right: 25px;
		margin-left: 25px;
	}
	#machine-categories {
		padding: 72px 0;
	}
	#machine-categories .content-box {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		grid-auto-rows: auto;
		gap: 18px;
	}
	.machine-category:first-child {
		grid-column: 1 / -1;
		grid-row: auto;
		min-height: 540px;
	}
	.machine-category:not(:first-child) {
		min-height: 370px;
	}
	.machine-category:nth-child(4) {
		grid-column: 1 / -1;
		min-height: 360px;
	}
	.machine-category > div:not(.bg-hover) {
		max-width: 68%;
		padding: 28px 28px 86px;
	}
	.machine-category:first-child > div:not(.bg-hover) {
		padding: 38px 38px 116px;
	}
	.machine-category:first-child h4 {
		font-size: 36px;
	}
	.quote-layout,
	#industries .flex-container,
	.machine-hero-grid,
	.machine-story-layout,
	.machine-story-panel,
	.contact-full.color-black > .content-box,
	.expert-callout,
	.brochure-block {
		grid-template-columns: 1fr;
	}
	.machine-story-nav {
		position: static;
		display: flex;
		overflow-x: auto;
	}
	.machine-story-nav button {
		flex: 0 0 auto;
		width: auto;
		white-space: nowrap;
	}
	.machine-hero-visual {
		min-height: 420px;
	}
	.machine-hero-panel,
	.machine-story-copy,
	.contact-full.color-black .contact-form {
		padding: 28px;
	}
	.sem-footer-inner {
		grid-template-columns: repeat(2, minmax(0, 1fr));
		gap: 24px;
	}
	.sem-footer-brand,
	.sem-footer-contact {
		grid-column: 1 / -1;
	}
	.sem-footer-brand .content-spacer {
		display: grid;
		grid-template-columns: auto minmax(0, 1fr);
		gap: 0 28px;
		align-items: center;
	}
	.sem-footer-brand .sem-footer-logo {
		grid-row: 1 / 3;
	}
	.sem-footer-brand .sem-footer-kicker,
	.sem-footer-brand .sem-footer-text {
		grid-column: 2;
	}
	.sem-footer-brand .sem-footer-text {
		margin-top: 8px;
	}
	.sem-footer-brand .social {
		grid-column: 1 / -1;
	}
	footer .grid_3 {
		width: 50%;
		margin-bottom: 28px;
	}
}
@media only screen and (max-width: 680px) {
	:root {
		--hero-title-size: 40px;
		--page-title-size: 38px;
		--section-title-size: 32px;
		--machine-title-size: 34px;
		--lead-font-size: 17px;
		--regular-font-size: 15px;
		--button-font-size: 13px;
	}
	body {
		font-size: var(--regular-font-size);
	}
	.mobile-only {
		display: block;
	}
	.desktop-only {
		display: none;
	}
	.content-box,
	.content-box.flex-container,
	.sem-topline-inner,
	.sem-nav-inner,
	.sem-slide-caption,
	#stock,
	#index-industries h2,
	#index-industries .flex-container {
		width: calc(100% - 36px);
		margin-left: 18px;
		margin-right: 18px;
	}
	.slideshow {
		min-height: 680px;
	}
	.page-title {
		min-height: 0;
	}
	.page-title > .desktop-only {
		display: none;
	}
	.page-title > .mobile-only {
		display: grid;
		min-height: 320px;
		padding: 58px 0 50px;
	}
	.page-title > .desktop-only:before,
	.page-title > .mobile-only:before,
	.page-title:before {
		background: linear-gradient(90deg, rgba(0,31,69,0.92) 0%, rgba(0,31,69,0.72) 58%, rgba(0,43,98,0.28) 100%);
	}
	.page-title h1 {
		width: calc(100% - 36px);
		margin-left: 18px;
		margin-right: 18px;
	}
	.slideshow .sem-slide:before {
		background:
			linear-gradient(180deg, rgba(0,31,69,0.96) 0%, rgba(0,43,98,0.84) 48%, rgba(0,31,69,0.54) 100%),
			linear-gradient(90deg, rgba(0,31,69,0.84) 0%, rgba(0,31,69,0.2) 100%);
	}
	.slideshow .sem-slide:after {
		display: none;
	}
	.slideshow .sem-slide-caption {
		align-items: flex-start;
		height: 100%;
		padding: 48px 0 132px 22px;
	}
	.slideshow .sem-slide-caption:before {
		width: 10px;
		height: 86px;
	}
	.slideshow .sem-slide-caption:after {
		display: none;
	}
	.slideshow .slide-eyebrow {
		min-height: 30px;
		margin-bottom: 16px;
	}
	.slideshow .sem-slide-caption h2 {
		font-size: var(--hero-title-size);
		line-height: 1;
	}
	.slideshow .sem-slide-caption p {
		font-size: var(--lead-font-size);
	}
	.slideshow .slide-actions,
	.sem-btn {
		width: 100%;
	}
	.slideshow .slide-actions a {
		width: 100%;
		justify-content: center;
	}
	.sem-slider-controls {
		right: 18px;
		bottom: 34px;
		left: 18px;
		justify-content: space-between;
	}
	.sem-slider-dots {
		flex: 1 1 auto;
		justify-content: center;
	}
	.section-head,
	.listing-actions {
		justify-items: start;
	}
	.machine-grid,
	.machines-full-listing,
	#machine-categories .content-box,
	#categories-listing .listing,
	#index-industries .flex-container,
	.flex-gallery,
	.dealer-cards,
	.listing,
	.quote-form .input_form {
		grid-template-columns: 1fr;
	}
	#addresses-listing {
		padding-bottom: 58px;
	}
	#addresses-listing .addresses-intro {
		gap: 24px;
		padding: 48px 0 26px;
	}
	.addresses-intro-points {
		gap: 8px;
	}
	.addresses-intro-points span {
		min-height: 48px;
	}
	#addresses-listing > .content-box.flex-container {
		grid-template-columns: 1fr;
		gap: 16px;
	}
	.dealer-nav {
		position: relative;
		top: auto;
		margin-bottom: 6px;
		overflow-x: auto;
		flex-wrap: nowrap;
		padding: 8px;
	}
	.dealer-nav a {
		flex: 0 0 auto;
	}
	body.legal-page .page-title,
	body.legal-page .page-title > div {
		min-height: 300px;
	}
	body.legal-page .page-title > div {
		padding: 54px 0 42px;
	}
	body.legal-page .page-title .content-box {
		width: calc(100% - 36px);
		margin-right: 18px;
		margin-left: 18px;
	}
	body.legal-page .page-title h4 {
		font-size: 16px;
	}
	body.legal-page #main > .content-7,
	body.legal-page .ariane + .content-7 {
		padding-top: 42px;
		padding-bottom: 52px;
	}
	body.legal-page #main > div[class*="content-"] > .content-box,
	body.legal-page #main > div[class*="content-"] > .flex-container.content-box {
		grid-template-columns: 1fr;
	}
	body.legal-page #main > .content-7 > .content-box,
	body.legal-page #main > .content-7 > .flex-container.content-box {
		gap: 20px;
		padding-bottom: 0;
	}
	body.legal-page #main > .content-7 .content-spacer-small,
	body.legal-page #main > div[class*="content-"] .content-spacer-large {
		padding: 24px;
	}
	body.legal-page #main > .content-7 .grid_12 .content-spacer-small,
	body.legal-page #main > .content-7 .grid_6:first-of-type .content-spacer-small,
	body.legal-page #main > .content-7 .grid_6:last-of-type .content-spacer-small {
		border-radius: 8px;
	}
	body.legal-page #main > .content-7 .grid_12 .content-spacer-small {
		border-radius: 8px;
	}
	body.legal-page #main > .content-7 .grid_6:last-of-type .content-spacer-small {
		border-radius: 8px;
	}
	body.legal-page #main > .content-7 .grid_6 h3 {
		font-size: 21px;
	}
	.dealer-region {
		scroll-margin-top: 92px;
	}
	#addresses-listing .grid_12 {
		padding: 22px;
	}
	#addresses-listing .grid_12 h2 {
		font-size: 28px;
	}
	#addresses-listing .content-spacer-small {
		padding: 22px;
	}
	#machine-categories {
		padding: 46px 0 58px;
	}
	#machine-categories .content-box {
		gap: 16px;
	}
	.machine-category,
	.machine-category:first-child,
	.machine-category:not(:first-child),
	.machine-category:nth-child(4) {
		grid-column: auto;
		min-height: 460px;
	}
	.machine-category > div:not(.bg-hover),
	.machine-category:first-child > div:not(.bg-hover) {
		max-width: none;
		padding: 24px 24px 146px;
	}
	.machine-category h4,
	.machine-category:first-child h4 {
		max-width: none;
		font-size: 25px;
	}
	.machine-category p,
	.machine-category:first-child p {
		max-width: 340px;
		font-size: 15px;
	}
	.machine-category:not(:first-child) p {
		-webkit-line-clamp: 4;
	}
	.machine-category > a:first-of-type,
	.machine-category:first-child > a:first-of-type {
		right: -8%;
		bottom: 76px;
		width: min(76%, 330px);
		opacity: 0.86;
	}
	.machine-category > a:last-child,
	.machine-category:first-child > a:last-child {
		left: 24px;
		bottom: 24px;
	}
	.section-head {
		grid-template-columns: 1fr;
	}
	.machine-1,
	.machine-2,
	.machine-4,
	.expert-section {
		padding: 54px 0;
	}
	.machine-hero-visual {
		min-height: 300px;
		padding: 20px;
	}
	.machine-hero-panel,
	.machine-story-copy,
	.contact-full.color-black .contact-form,
	.expert-callout {
		padding: 22px;
	}
	.machine-main-specs div,
	.machine-data > li > ul > li,
	.expert-callout-grid,
	.contact-full.color-black .input_form {
		grid-template-columns: 1fr;
		gap: 8px;
	}
	.machine-data.single-list > li > div {
		padding: 18px;
		font-size: 16px;
	}
	.machine-data.single-list ul {
		grid-template-columns: 1fr;
		padding: 18px;
	}
	.machine-data li span:last-child {
		text-align: left;
	}
	.machine-story-media {
		min-height: 260px;
		padding: 18px;
	}
	.machine-story-media img {
		max-height: 260px;
	}
	.contact-full.color-black > .content-box > h2,
	.expert-callout-copy h2 {
		font-size: var(--section-title-size);
	}
	.grid_3,
	.grid_4,
	.grid_6,
	.grid_8 {
		width: 100%;
	}
	.grid-item.machine-card {
		min-height: auto;
	}
	.machine-meta,
	.machine-main-specs {
		grid-template-columns: 1fr;
	}
	.input_form > div.form-half {
		width: 100%;
	}
	.quote-form,
	.quote-aside,
	.side-content {
		padding: 22px;
	}
	.sem-lightbox {
		grid-template-columns: 44px minmax(0, 1fr) 44px;
		gap: 8px;
		padding: 18px;
	}
	.sem-lightbox-nav {
		width: 42px;
		height: 42px;
		font-size: 30px;
	}
	.sem-lightbox-close {
		top: 12px;
		right: 12px;
		width: 40px;
		height: 40px;
	}
	#side-phone .side-content {
		padding: 22px;
	}
	.side-phone-kicker {
		font-size: 22px;
	}
	.side-phone-number {
		font-size: 24px;
	}
	.sem-footer-inner {
		grid-template-columns: 1fr;
		gap: 0;
		padding: 42px 0 34px;
	}
	.sem-footer-brand,
	.sem-footer-contact {
		grid-column: auto;
	}
	.sem-footer .content-spacer {
		padding: 24px 0;
		border-top: 1px solid rgba(255,255,255,0.12);
		border-left: 0;
	}
	.sem-footer-brand .content-spacer {
		display: block;
		padding: 24px;
		border-top: 1px solid rgba(255,255,255,0.16);
		border-left: 5px solid var(--yellow-1);
	}
	.sem-footer-brand .sem-footer-logo,
	.sem-footer-brand .sem-footer-kicker,
	.sem-footer-brand .sem-footer-text {
		grid-row: auto;
		grid-column: auto;
	}
	.sem-footer-brand .sem-footer-text {
		margin-top: 14px;
	}
	.sem-footer-kicker {
		font-size: 24px;
	}
	.footer-call a {
		font-size: 18px;
	}
	footer .grid_3,
	footer .flex-container > .grid_3 {
		width: 100%;
	}
	#copyright .content-box,
	.sem-copyright-inner {
		align-items: flex-start;
		flex-direction: column;
		justify-content: center;
		padding: 18px 0;
	}
}

/* Retained plugin compatibility */
#galleryOverlay {
	display: none;
	position: fixed;
	z-index: 100000;
	inset: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
	background: rgba(3,3,3,0.88);
	opacity: 0;
	transition: opacity 0.35s ease;
}
#galleryOverlay.visible {
	opacity: 1;
}
#gallerySlider {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	white-space: nowrap;
	transition: left 0.35s ease;
}
#gallerySlider .placeholder {
	display: inline-block;
	width: 100%;
	height: 100%;
	line-height: 1px;
	text-align: center;
}
#gallerySlider .placeholder:before {
	content: "";
	display: inline-block;
	width: 1px;
	height: 50%;
	margin-right: -1px;
}
#gallerySlider .placeholder img {
	display: inline-block;
	max-width: 90%;
	max-height: 90%;
	vertical-align: middle;
	box-shadow: 0 24px 70px rgba(0,0,0,0.35);
}
#gallerySlider.rightSpring {
	animation: rightSpring 0.3s;
}
#gallerySlider.leftSpring {
	animation: leftSpring 0.3s;
}
@keyframes rightSpring {
	0% { margin-left: 0; }
	50% { margin-left: -30px; }
	100% { margin-left: 0; }
}
@keyframes leftSpring {
	0% { margin-left: 0; }
	50% { margin-left: 30px; }
	100% { margin-left: 0; }
}
#prevArrow,
#nextArrow {
	position: absolute;
	top: 50%;
	width: 43px;
	height: 58px;
	margin-top: -29px;
	border: 0;
	background: url(../images/arrows.svg) no-repeat;
	opacity: 0.72;
	cursor: pointer;
	transition: opacity 0.2s ease, transform 0.2s ease;
}
#prevArrow:hover,
#nextArrow:hover {
	opacity: 1;
}
#prevArrow {
	left: 40px;
	background-position: left top;
}
#nextArrow {
	right: 40px;
	background-position: right top;
}
.cookie-popup {
	display: none;
	position: fixed;
	left: 0;
	bottom: 0;
	z-index: 1000;
	width: 100vw;
	background: var(--blue-3);
	color: var(--white-1);
	font-family: var(--main-font);
	box-shadow: 0 -18px 55px rgba(0,31,69,0.24);
}
.cookie-popup a {
	color: var(--yellow-1);
	text-decoration: underline;
}
.cookie-popup a:hover {
	color: var(--yellow-2);
}
.cookie-popup-inner {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 28px;
	align-items: center;
	width: min(var(--max), calc(100% - 36px));
	margin: 0 auto;
	padding: 26px 0;
}
.cookie-popup-left,
.cookie-popup-right {
	display: block;
	padding: 0;
}
.cookie-popup-headline {
	margin: 0 0 8px;
	color: var(--white-1);
	font-size: 22px;
	line-height: 1.15;
	font-weight: 800;
	text-transform: uppercase;
}
.cookie-popup-sub-headline {
	color: rgba(255,255,255,0.82);
	font-size: 14px;
	line-height: 1.45;
}
.cookie-popup-sub-headline ul {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 4px 18px;
	margin: 12px 0 0;
	padding: 0 0 0 18px;
}
.cookie-popup-sub-headline li {
	margin: 0;
}
.cookie-popup-right {
	min-width: 250px;
	text-align: right;
}
.cookie-popup-accept-cookies,
.cookie-popup-refuse-cookies {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 42px;
	margin: 0 0 10px;
	padding: 0 16px;
	border: 2px solid var(--yellow-1);
	border-radius: 4px;
	background: var(--yellow-1);
	color: var(--blue-2);
	font-size: 14px;
	font-weight: 800;
	text-align: center;
	text-decoration: none;
	text-transform: uppercase;
	cursor: pointer;
}
.cookie-popup-refuse-cookies {
	margin-bottom: 0;
	background: transparent;
	color: var(--white-1);
	border-color: rgba(255,255,255,0.28);
}
.cookie-popup-accept-cookies:hover,
.cookie-popup-refuse-cookies:hover {
	text-decoration: none;
}
.cookie-popup-learn-more,
.cookie-popup-lower {
	display: none;
}
.cookie-popup.position-top {
	top: 0;
	bottom: auto;
	box-shadow: 0 18px 55px rgba(0,31,69,0.24);
}
.cookie-popup.position-bottomright,
.cookie-popup.position-bottomleft,
.cookie-popup.position-topright,
.cookie-popup.position-topleft {
	right: 18px;
	left: auto;
	bottom: 18px;
	width: min(420px, calc(100vw - 36px));
	border-radius: 6px;
}
.cookie-popup.position-bottomleft,
.cookie-popup.position-topleft {
	right: auto;
	left: 18px;
}
.cookie-popup.position-topright,
.cookie-popup.position-topleft {
	top: 18px;
	bottom: auto;
}
.cookie-popup.position-bottomright .cookie-popup-inner,
.cookie-popup.position-bottomleft .cookie-popup-inner,
.cookie-popup.position-topright .cookie-popup-inner,
.cookie-popup.position-topleft .cookie-popup-inner {
	display: block;
	width: auto;
	padding: 22px;
}
.cookie-popup.position-bottomright .cookie-popup-right,
.cookie-popup.position-bottomleft .cookie-popup-right,
.cookie-popup.position-topright .cookie-popup-right,
.cookie-popup.position-topleft .cookie-popup-right {
	min-width: 0;
	margin-top: 18px;
	text-align: left;
}
.theme-amber .cookie-popup {
	background: var(--blue-3);
	color: var(--white-1);
}
.theme-amber .cookie-popup-accept-cookies {
	background: var(--yellow-1);
	color: var(--blue-2);
}

@media only screen and (max-width: 767px) {
	#prevArrow {
		left: 18px;
	}
	#nextArrow {
		right: 18px;
	}
	.cookie-popup-inner {
		display: block;
		padding: 22px 0;
	}
	.cookie-popup-right {
		min-width: 0;
		margin-top: 18px;
		text-align: left;
	}
	.cookie-popup-sub-headline ul {
		grid-template-columns: 1fr;
	}
}