@font-face {
	font-family: 'Helvetica Neue Light';
	src: url("../fonts/HelveticaNeue-Light.woff2") format("woff2"), url("../fonts/HelveticaNeue-Light.woff") format("woff"), url("../fonts/HelveticaNeue-Light.ttf") format("truetype"), url("../fonts/HelveticaNeue-Light.eot") format("embedded-opentype")
}

@font-face {
	font-family: 'Helvetica Neue Medium';
	src: url("../fonts/HelveticaNeue-Medium.woff2") format("woff2"), url("../fonts/HelveticaNeue-Medium.woff") format("woff"), url("../fonts/HelveticaNeue-Medium.ttf") format("truetype"), url("../fonts/HelveticaNeue-Medium.eot") format("embedded-opentype")
}

@font-face {
	font-family: 'Klavika';
	src: url("../fonts/Klavika-Light.woff2") format("woff2"), url("../fonts/Klavika-Light.woff") format("woff"), url("../fonts/Klavika-Light.ttf") format("truetype"), url("../fonts/Klavika-Light.eot") format("embedded-opentype")
}

@font-face {
	font-family: 'Klavika Light';
	src: url("../fonts/Klavika-Light.woff2") format("woff2"), url("../fonts/Klavika-Light.woff") format("woff"), url("../fonts/Klavika-Light.ttf") format("truetype"), url("../fonts/Klavika-Light.eot") format("embedded-opentype")
}

@font-face {
	font-family: 'Klavika Medium';
	src: url("../fonts/Klavika-Medium.woff2") format("woff2"), url("../fonts/Klavika-Medium.woff") format("woff"), url("../fonts/Klavika-Medium.ttf") format("truetype"), url("../fonts/Klavika-Medium.eot") format("embedded-opentype")
}

h2,
h2 p,
.slide-text,
.text--strong-headings strong {
	text-transform: uppercase;
	font-size: 1.071rem;
	line-height: 1.67rem;
	letter-spacing: .2rem
}

h3 {
	text-transform: uppercase;
	font-size: 1.071rem;
	line-height: 1.67rem;
	letter-spacing: .2rem
}

header nav a {
	text-transform: uppercase;
	font-size: .857rem;
	letter-spacing: .2rem;
	line-height: 1.142rem
}

footer nav a {
	text-transform: uppercase;
	font-size: 1rem;
	line-height: 1.142rem;
	letter-spacing: .2rem
}

h1,
.panel-switcher a,
footer p,
.modal-navigation h3,
.awards h2 {
	text-transform: uppercase;
	font-size: .7857rem;
	line-height: 1.07rem;
	letter-spacing: .2rem
}

img {
	display: block;
	max-width: 100%
}

.imgSrc50Hero {
	width: 100%
}

img.imgSrcLoad {
	/*opacity: 0*/
}

img.imgSrc50 {
	/*opacity: 0;*/
	width: 100%;
	position: relative;
	z-index: 1
}

img.imgSrcLoadOn {
	opacity: 1;
	height: auto;
	-moz-transition: opacity 1s ease-out;
	-o-transition: opacity 1s ease-out;
	-webkit-transition: opacity 1s ease-out;
	transition: opacity 1s ease-out
}

div.imgSrc50 {
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;
	width: 100%;
	position: absolute;
	opacity: 0;
	transition: opacity .3s
}

div.imgSrc50.loaded {
	opacity: 1
}

.bgFadeImage {
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;
	width: 100%;
	opacity: 0;
	-webkit-transition: all .3s;
	transition: all .3s
}

.bgFadeImage.loaded {
	opacity: 1
}

.bg-img--full-height {
	height: calc(100vh - 174px);
	max-height: 752px;
	min-height: 550px;
	background-position: center top
}

* {
	box-sizing: border-box
}

body {
	animation: fadeInOnLoad .3s ease-in-out
}

img {
	max-width: 100%
}

.circle {
	border-radius: 50%
}

@keyframes fadeInOnLoad {
	0% {
		opacity: 0
	}
	100% {
		opacity: 1
	}
}

html {
	font-size: 14px
}

body {
	background-color: #fff;
	font-family: "Helvetica Neue Light", sans-serif;
	color: #393838;
	-webkit-font-smoothing: antialiased;
	letter-spacing: .075rem;
	line-height: 1.64rem;
	margin-top: 0
}

p,
li,
input,
textarea,
button {
	letter-spacing: .075rem;
	line-height: 1.64rem;
	margin-top: 0
}

.strong-text,
p strong,
.inline-header {
	font-family: "Helvetica Neue Medium", sans-serif;
	font-weight: normal;
	letter-spacing: .075rem;
	line-height: 1.64rem;
	text-transform: none;
	font-size: 1rem;
	margin: 0 .3rem 0 0
}

p strong,
.inline-header {
	display: inline
}

.inline-header+p {
	display: inline
}

a,
a:visited {
	color: #393838;
	text-decoration: none;
	transition: all .3s ease-in-out
}

a:hover,
a:active {
	color: #1f1f1f
}

h1,
h2,
h3,
h4,
h5,
.slide-text,
.slide-text strong,
.slide-text em,
.text--strong-headings strong {
	font-family: "Klavika Light", sans-serif;
	font-weight: 300;
	text-transform: uppercase;
	margin-top: 0
}

h2,
h2 p {
	margin-bottom: 1.4rem
}

ul {
	padding: 0;
	list-style: none
}

.list--bulleted li {
	padding-left: 0.6em;
	position: relative
}

.list--bulleted li::before {
	content: ".";
	position: absolute;
	top: -0.32em;
	left: -.2em
}

.callout {
	background-color: #F7F9FA;
	font-family: "Klavika Light", sans-serif;
	text-transform: uppercase;
	color: #85898D
}

.callout p,
.callout a,
.callout a:visited {
	color: #85898D
}

.callout a:hover,
.callout a:active {
	color: #6c7073
}

.callout hr {
	border: none;
	border-bottom: 1px solid #d7e0e7
}

hr {
	border: 0;
	border-bottom: 1px solid #393838
}

.small-rule {
	width: 3.14rem;
	margin: 1.65rem 0
}

address {
	font-style: normal
}

.top-label-wrapper {
	position: relative
}

.top-label-wrapper .label {
	top: 2rem;
	right: 2.85rem;
	position: absolute
}

.label-wrapper {
	position: relative
}

.label-wrapper .info-toggle {
	position: absolute;
	bottom: .34rem;
	right: .8rem;
	display: inline-block;
	width: 1.227rem;
	height: 1.227rem
}

.label-wrapper .info-toggle span {
	position: absolute;
	top: 0;
	left: 0;
	display: inline-block;
	border-bottom: 1px solid #393838;
	transition: all .2s ease-in-out
}

.label-wrapper .info-toggle span:first-of-type {
	width: 1.14rem
}

.label-wrapper .info-toggle span:last-of-type {
	width: 1.227rem;
	transform: rotate(90deg)
}

.label-wrapper img,
.label-wrapper a {
	display: block
}

.label-wrapper .inline-label,
.label-wrapper .expandable-label {
	position: absolute;
	bottom: 1.785rem;
	right: 1.785rem;
	background-color: rgba(255, 255, 255, 0.9);
	padding: .6rem 2rem .9rem 1rem;
	min-width: 10.43rem;
	line-height: 1.143rem;
	margin-bottom: 0;
	z-index: 2
}

.label-wrapper .expandable-label {
	max-width: 65%;
	min-width: 15.64rem;
	transition: all .3s ease-in-out;
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-height: 41px;
	padding-bottom: 0
}

.label-wrapper .expandable-label::after {
	content: '';
	width: 1.14
}

.label-wrapper .expandable-label .placeholder {
	opacity: 0
}

.label-wrapper .expandable-label .text-wrapper {
	position: absolute;
	top: .6rem;
	left: 1rem;
	transition: all .3s ease-in-out
}

.label-wrapper .expandable-label h3 {
	margin-bottom: .9rem;
	padding-right: 1.5rem
}

.label-wrapper .expandable-label p {
	margin: 0;
	opacity: 0;
	visibility: hidden
}

.label-wrapper--open .expandable-label {
	min-width: 65%;
	min-height: calc(100% - 3.57rem);
	padding: 2.28rem;
	transition: all .3s ease-in-out
}

.label-wrapper--open .expandable-label .text-wrapper {
	left: 2.28rem;
	top: 50%;
	transform: translateY(-50%);
	max-height: calc(100% - 4.6rem);
	width: 80%
}

.label-wrapper--open .expandable-label p {
	opacity: 1;
	margin-top: 1rem;
	visibility: visible;
	transition: all .3s ease-in-out .3s
}

.label-wrapper--open .info-toggle span:first-of-type {
	transform: rotate(-45deg);
	width: 1.227rem
}

.label-wrapper--open .info-toggle span:last-of-type {
	transform: rotate(45deg)
}

.panel-switcher li {
	margin-bottom: 1rem
}

.panel-switcher li:first-of-type {
	border-bottom: 1px solid #393838
}

.panel-switcher a {
	padding: .6rem 0;
	display: inline-block
}

.rotated-text-wrapper {
	position: relative;
	display: block
}

.rotated-text-wrapper .rotated-text-left,
.rotated-text-wrapper .rotated-text-right {
	position: absolute;
	top: 50%
}

.rotated-text-wrapper .rotated-text-left {
	left: 30px;
	transform: translateY(-50%) rotate(-90deg)
}

.rotated-text-wrapper .rotated-text-right {
	right: 30px;
	transform: translateY(-50%) rotate(90deg)
}

.gallery .rotated-text-left {
	opacity: 0;
	animation: slideUpOnLoad 1s ease-in-out .2s;
	animation-fill-mode: forwards;
	transform: translateX(-50%) translateY(20px) rotate(-90deg)
}

.gallery .rotated-text-right {
	opacity: 0;
	animation: slideDownOnLoad 1s ease-in-out .2s;
	animation-fill-mode: forwards;
	transform: translateX(50%) translateY(-20px) rotate(90deg)
}

@keyframes slideUpOnLoad {
	0% {
		opacity: 0;
		transform: translateX(-50%) translateY(20px) rotate(-90deg)
	}
	100% {
		opacity: 1;
		transform: translateX(-50%) translateY(0) rotate(-90deg)
	}
}

@keyframes slideDownOnLoad {
	0% {
		opacity: 0;
		transform: translateX(50%) translateY(-20px) rotate(90deg)
	}
	100% {
		opacity: 1;
		transform: translateX(50%) translateY(0) rotate(90deg)
	}
}

@media only screen and (max-width: 760px) {
	html {
		font-size: 12px
	}
}

.clearfix:before,
header .page-center:before,
.clearfix:after,
header .page-center:after {
	display: table;
	content: " "
}

.clearfix:after,
header .page-center:after {
	clear: both
}

.grid {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 0 -1.4rem -1.4rem
}

.grid [class^="grid__cell"] {
	padding: 0 0 1.4rem 1.4rem
}

.grid--staggered:nth-of-type(even) [class^="grid__cell"]:first-of-type,
.grid-wrapper--border-top .grid:nth-of-type(even) [class^="grid__cell"]:first-of-type {
	order: 2
}

.grid--staggered:nth-of-type(even) [class^="grid__cell"]:last-of-type,
.grid-wrapper--border-top .grid:nth-of-type(even) [class^="grid__cell"]:last-of-type {
	order: 1
}

.grid--split {
	align-items: center
}

.yes_ie_only header nav a {
	display: inline
}

.grid--split [class^="grid__cell"]:last-of-type {
	margin-left: auto
}

@media only screen and (min-width: 769px) {
	.grid--large-column-gutters {
		margin: 0 0 -1.4rem -4.29rem
	}
	.grid--large-column-gutters [class^="grid__cell"] {
		padding: 0 0 1.4rem 4.29rem
	}
	.grid--large-column-gutters .grid {
		margin: 0 0 -1.4rem -4.29rem
	}
	.grid--large-gutters {
		margin: 0 0 -3.4rem -3.4rem
	}
	.grid--large-gutters [class^="grid__cell"] {
		padding: 0 0 3.4rem 3.4rem
	}
	.grid--small-gutters {
		margin: 0 0 0 -.64rem
	}
	.grid--small-gutters [class^="grid__cell"] {
		padding: 0 0 1.4rem .64rem
	}
}

@media only screen and (max-width: 768px) {
	.grid--staggered:nth-of-type(even) [class^="grid__cell"]:first-of-type,
	.grid-wrapper--border-top .grid:nth-of-type(even) [class^="grid__cell"]:first-of-type {
		order: 1
	}
}

.grid__cell--fit {
	flex: 1
}

.grid__cell--100 {
	width: 100%
}

.grid__cell--60 {
	width: 60%
}

.grid__cell--55 {
	width: 55%
}

.grid__cell--50 {
	width: 50%
}

.grid__cell--40 {
	width: 40%
}

.grid__cell--36 {
	width: 36%
}

.grid__cell--33 {
	width: 33.333%
}

.grid__cell--25 {
	width: 25%
}

.grid__cell--17 {
	width: 17%
}

@media (max-width: 1100px) {
	.grid__cell--lg-50 {
		width: 50%
	}
}

@media (max-width: 992px) {
	.grid__cell--md-fit {
		flex: 1
	}
	.grid__cell--md-100 {
		width: 100%
	}
	.grid__cell--md-50 {
		width: 50%
	}
	.grid__cell--md-33 {
		width: 33.333%
	}
	.grid__cell--md-25 {
		width: 25%
	}
}

@media (max-width: 768px) {
	.grid>[class^="grid__cell"] {
		flex: none;
		width: 100%;
		padding-left: 0
	}
	.grid {
		margin: 0
	}
}

.aligner {
	display: flex;
	align-items: center;
	justify-content: center
}

.aligner-item--top {
	align-self: flex-start
}

.aligner-item--bottom {
	align-self: flex-end
}

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

.no_ie .site-content {
	flex: 1
}

.full-height {
	display: flex;
	flex: 1
}

.page-center {
	max-width: 1100px;
	margin: 0 auto
}

@media only screen and (max-width: 1100px) {
	.page-center {
		padding: 0 1.5rem
	}
}

.vertical-heading-wrapper,
.vertical-heading-wrapper--full-page {
	padding-left: 14.28rem;
	margin-top: 14.28rem;
	padding-bottom: 10rem;
	border-left: 1px solid #393838;
	position: relative
}

.vertical-heading-wrapper h1,
.vertical-heading-wrapper--full-page h1 {
	position: absolute;
	top: 0;
	left: 0;
	display: inline-block;
	padding-left: 1.2rem;
	padding-right: 1rem;
	background-color: #fff;
	transform-origin: 0 65%;
	transform: rotate(-90deg) translateX(-83%)
}

.vertical-heading-wrapper--full-page {
	padding-left: 11.5rem;
	margin-top: 1.5rem
}

.horizontal-heading-wrapper h1,
.horizontal-heading-wrapper--margin h1,
.horizontal-heading-wrapper--padding-left h1 {
	position: relative;
	margin-bottom: 1.6rem
}

.horizontal-heading-wrapper h1::before,
.horizontal-heading-wrapper--margin h1::before,
.horizontal-heading-wrapper--padding-left h1::before {
	content: '';
	border-bottom: 1px solid #393838;
	width: 1000px;
	position: absolute;
	top: 50%;
	transform: translateX(-102%)
}

.horizontal-heading-wrapper h2,
.horizontal-heading-wrapper--margin h2,
.horizontal-heading-wrapper--padding-left h2 {
	margin-bottom: 2.9rem
}

.horizontal-heading-wrapper--margin {
	margin-top: 9.28rem;
	margin-bottom: 9.28rem
}

.horizontal-heading-wrapper--padding-left {
	padding-left: 11.5rem;
	margin-top: 2rem;
	position: relative
}

.horizontal-heading-wrapper--padding-left h1 {
	position: absolute;
	left: 0;
	top: 5px
}

@media only screen and (max-width: 1000px) {
	.vertical-heading-wrapper,
	.vertical-heading-wrapper--full-page {
		padding-left: 10rem;
		margin-top: 10rem
	}
}

@media only screen and (max-width: 860px) {
	.vertical-heading-wrapper,
	.vertical-heading-wrapper--full-page {
		padding-left: 6rem;
		margin-top: 6rem
	}
}

@media only screen and (max-width: 768px) {
	.vertical-heading-wrapper,
	.vertical-heading-wrapper--full-page {
		padding-left: 3rem
	}
	.vertical-heading-wrapper--full-page {
		margin-top: 0
	}
	.horizontal-heading-wrapper--margin {
		margin-top: 5rem;
		margin-bottom: 3rem
	}
	.horizontal-heading-wrapper--padding-left {
		padding-left: 0;
		margin-top: 2rem
	}
	.horizontal-heading-wrapper--padding-left h1 {
		position: static
	}
}

.paragraphs-with-rule p:last-of-type:not(:first-of-type)::before,
.paragraphs-with-small-rule p:last-of-type:not(:first-of-type)::before {
	content: '';
	display: block;
	position: relative;
	border-bottom: 1px solid #393838
}

.paragraphs-with-rule p:last-of-type:not(:first-of-type) {
	margin-top: 4.2rem
}

.paragraphs-with-rule p:last-of-type:not(:first-of-type)::before {
	top: -2.2rem;
	width: 3.14rem
}

.paragraphs-with-small-rule p:last-of-type:not(:first-of-type) {
	margin-top: 2rem
}

.paragraphs-with-small-rule p:last-of-type:not(:first-of-type)::before {
	top: -1rem;
	width: 1.29rem
}

.grid>.grid__cell--border-top {
	padding-top: 7.14rem
}

.grid>.grid__cell--border-top h2 {
	max-width: 530px
}

.grid-wrapper--border-top .grid {
	position: relative;
	padding-bottom: 4.29rem
}

.grid-wrapper--border-top .grid:last-of-type {
	padding-bottom: 0
}

.grid-wrapper--border-top .grid::before {
	content: '';
	border-bottom: 1px solid #393838;
	position: absolute;
	top: 3.57rem;
	width: calc(100% - 4.29rem);
	left: 4.29rem;
	z-index: -1
}

@media only screen and (max-width: 920px) {
	.grid>.grid__cell--border-top {
		padding-top: 3.4rem
	}
	.grid-wrapper--border-top .grid::before {
		top: 2rem
	}
}

@media only screen and (max-width: 768px) {
	.grid-wrapper--border-top .grid::before {
		display: none
	}
	.grid>.grid__cell--border-top {
		padding-top: 0
	}
	.grid-wrapper--border-top .grid {
		padding-bottom: 2rem
	}
}

.hamburger {
	display: none;
	width: 2rem;
	height: 1.4rem;
	transition: all .3s ease-in-out;
	position: absolute;
	top: 1.2rem;
	right: 0;
	z-index: 250
}

.hamburger span {
	border-bottom: 1px solid #393838;
	position: absolute;
	display: block;
	width: 100%
}

.hamburger span:first-of-type {
	top: 0
}

.hamburger span:nth-of-type(2) {
	top: 50%
}

.hamburger span:last-of-type {
	bottom: -2px
}

header {
	padding: 3.14rem 0
}

header .page-center {
	position: relative
}

header nav {
	margin-left: auto;
	overflow: hidden
}

@media only screen and (min-width: 921px) {
	header nav {
		padding-top: 17px;
		float: right
	}
	header .logo {
		float: left
	}
}

header nav a {
	font-family: "Klavika Light", sans-serif;
	padding: 0px 1.57rem 2px;
	display: inline-block;
	line-height: 1;
	border-right: 1px solid #393838
}

header nav a:nth-last-child(-n+2) {
	border-right: 0
}

header nav a:last-of-type {
	font-family: "Klavika Medium", sans-serif;
	padding-right: 0
}

.logo {
	width: 183px
}

.open-nav .hamburger {
	transform: rotate(90deg)
}

.open-nav .animation-wrapper {
	visibility: visible;
	transform: translateX(0);
	opacity: 1
}

.open-on-load nav .hamburger {
	transition: none
}

.open-on-load nav .animation-wrapper {
	transition: none
}

@media only screen and (max-width: 1100px) {
	.hamburger {
		right: 1.5rem
	}
	header nav a:last-of-type {
		padding-left: .5rem;
		padding-right: .5rem
	}
}

@media only screen and (max-width: 1000px) {
	header nav a {
		padding: 0 1rem 3px
	}
}

@media only screen and (max-width: 920px) {
	body.open-nav {
		overflow: hidden
	}
	header nav .animation-wrapper {
		background-color: rgba(255, 255, 255, 0.96);
		position: fixed;
		overflow-y: scroll;
		width: 100%;
		height: 100%;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		z-index: 300;
		opacity: 0;
		visibility: hidden;
		text-align: center;
		z-index: 200;
		display: flex;
		flex-direction: column;
		justify-content: center
	}
	header nav .animation-wrapper a {
		padding: 0;
		display: block;
		font-size: 1.357rem;
		padding: 1rem .5rem;
		margin: 1rem 0;
		border: 0
	}
	.animation-wrapper {
		transform: translateX(5%);
		opacity: 0;
		transition: all .3s ease-in-out;
		visibility: hidden
	}
	.hamburger {
		display: block
	}
}

@media only screen and (max-height: 360px) {
	header nav .animation-wrapper {
		padding-top: 3rem
	}
}

footer {
	padding: 5.7rem 0;
	text-align: center
}

footer nav {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 1rem 0;
	flex-wrap: wrap
}

footer nav span:last-of-type {
	display: none
}

footer nav a {
	font-family: "Klavika Light", sans-serif
}

footer hr {
	margin: 0
}

footer p {
	margin-top: 2.4rem;
	margin-bottom: 0;
	display: inline-block
}

footer .fab {
	font-size: 1.2rem
}

footer .copyright-info-wrap a,
footer .copyright-info-wrap span {
	margin: 0 1rem
}

footer .copyright-info-wrap span {
	position: relative;
	bottom: 2px
}

.lk-credit {
	margin-top: 40px;
	display: block;
	font-size: .9rem;
	text-align: right
}

@media screen and (max-width: 768px) {
	footer nav a {
		width: 50%;
		margin-bottom: 1rem
	}
	footer nav span {
		display: none
	}
	footer .copyright-info-wrap span {
		display: block;
		margin-top: 2rem
	}
	footer .copyright-info-wrap span:first-of-type {
		display: none
	}
}

input,
textarea {
	border: 0;
	border-bottom: 1px solid #393838;
	display: block;
	padding: 1rem 0;
	margin-bottom: .5rem;
	width: 100%
}

textarea {
	resize: none;
	height: 3.8rem
}

input:focus,
input:active,
textarea:focus,
textarea:active,
button {
	outline: 0
}

button {
	background-color: transparent;
	border: 0;
	display: block;
	margin-top: 2rem;
	font-family: "Helvetica Neue Medium", sans-serif;
	padding: 1rem 0
}

.thanks {
	display: none
}

.validation-wrapper {
	position: relative;
	transition: all .3s ease-in-out
}

.validation-wrapper .error {
	color: red;
	position: absolute;
	font-size: 12px;
	bottom: 5px;
	transform: translateY(100%);
	left: 0;
	z-index: 10;
	transition: all .3s ease-in-out;
	opacity: 0
}

.validation-wrapper.has-error {
	padding-bottom: 10px
}

.validation-wrapper.has-error .error {
	opacity: 1
}

.validation-wrapper.has-error input,
.validation-wrapper.has-error textarea {
	border-bottom-color: red
}

::-webkit-input-placeholder {
	color: #393838
}

::-moz-placeholder {
	color: #393838
}

:-ms-input-placeholder {
	color: #393838
}

:-moz-placeholder {
	color: #393838
}

.modal-wrapper {
	background-color: rgba(255, 255, 255, 0.96);
	position: fixed;
	overflow-y: scroll;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 300;
	opacity: 0;
	visibility: hidden;
	transition: all .3s ease-in-out
}

.open-modal {
	overflow: hidden
}

.open-modal .modal-wrapper {
	visibility: visible;
	opacity: 1
}

.modal-navigation {
	margin-top: 4.28rem;
	margin-bottom: 4.28rem;
	display: flex;
	align-items: center
}

.modal-navigation .modal-info {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline
}

.modal-navigation h2,
.modal-navigation h3,
.modal-navigation p {
	display: inline-block;
	margin-bottom: 0
}

.modal-navigation h2 {
	margin-right: 1.42rem
}

.modal-navigation h3 {
	margin-left: 2rem;
	margin-right: .714rem
}

.modal-navigation .column-wrap:first-of-type h3 {
	margin-left: 0
}

.modal-navigation .bar {
	margin-right: 1.42rem
}

.modal-navigation .close-modal {
	width: 28px;
	height: 28px;
	position: relative;
	margin-left: 3rem
}

.modal-navigation .close-modal span {
	border-bottom: 1px solid #393838;
	width: 28px;
	position: absolute;
	top: 50%;
	transform: rotate(45deg)
}

.modal-navigation .close-modal span:last-of-type {
	transform: rotate(-45deg)
}

.modal-wrapper .swiper-pagination {
	display: inline-block;
	position: static;
	margin-left: auto
}

.modal-wrapper .swiper-pagination-bullet {
	margin: 0 .5rem;
	width: 12px;
	height: 12px;
	background: #98999A
}

.modal-wrapper .swiper-pagination-bullet-active {
	background: #393838
}

.modal-wrapper .swiper-slide img {
	display: block;
	margin: 0 auto;
	max-height: 1000px
}

@media only screen and (max-width: 889px) {
	.modal-navigation .bar {
		display: none
	}
	.modal-navigation .column-wrap:first-of-type h3 {
		margin-left: 0
	}
	.modal-navigation h2 {
		width: 100%;
		margin-bottom: 3.2rem;
		position: relative
	}
	.modal-navigation h2::before {
		content: '';
		position: absolute;
		bottom: -1.8rem;
		width: 40px;
		border-bottom: 1px solid #393838
	}
	.modal-navigation .swiper-pagination {
		position: absolute;
		top: 7.2rem;
		right: 2rem
	}
	.modal-navigation .close-modal {
		position: absolute;
		top: 3rem;
		right: 2rem
	}
}

@media only screen and (max-width: 600px) {
	.modal-navigation {
		margin-top: 3.28rem;
		margin-bottom: 3.28rem
	}
	.modal-navigation h3 {
		margin-left: 0
	}
	.modal-navigation .modal-info {
		flex-direction: column
	}
}

.home .vertical-heading-wrapper--full-page {
	padding-bottom: 3rem
}

.home .banner-image {
	/*margin-bottom: 7rem*/
	margin-bottom: 11.3rem;
}

.home .swiper-slide {
	height: auto;
	max-height: 620.88px;
	overflow: hidden
}

@media only screen and (max-width: 765px) {
	.home .swiper-slide {
		height: auto;
		max-height: 620.88px
	}
}

.has-video .video-wrapper {
	position: relative;
	padding-bottom: 51%;
	height: 0;
	overflow: hidden
}

.has-video .video-wrapper iframe,
.has-video .video-wrapper video {
	position: absolute;
	top: 0;
	left: 0;
	border: 0;
	width: 100%;
	height: 100%;
    object-fit: cover;
	z-index: 2
}

.has-video .thumb {
	top: 0;
	left: 0;
	z-index: 1
}

.slide-text {
	font-size: 1rem
}

.slide-text strong,
.slide-text em {
	margin-bottom: 18px;
	font-size: 1.3rem;
	line-height: 1.5rem;
	letter-spacing: .2rem;
	margin-right: 0
}

.slide-text em {
	color: black !important;
	font-style: normal !important
}

@media only screen and (max-width: 765px) {
	.slide-text h1 {
		font-size: 1.25rem;
		margin-bottom: 10px
	}
	.slide-text h1+h1 {
		margin-top: 12px
	}
}

.text-only-slide-container {
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: 100%;
	text-align: center
}

.text-only-slide-container .slide-text {
	font-size: 1.3rem
}

.text-only-slide-container .slide-text strong {
	font-size: 1.6rem
}

@media (max-width: 768px) {
	.text-only-slide-container .slide-text strong {
		font-size: 1.3rem
	}
}

.text-only-slide-container .large-text {
	font-size: 1.6rem
}

.text-only-slide-container .large-text strong {
	font-size: 1.6rem
}

@media (max-width: 768px) {
	.text-only-slide-container .large-text {
		font-size: 1.4rem
	}
	.text-only-slide-container .large-text strong {
		font-size: 1.4rem
	}
}

.swiper-slide-active .text-only-slide-container .slide-text,
.swiper-slide-prev .text-only-slide-container .slide-text {
	-webkit-transition: all 1.5s ease-in-out;
	transition: all 1.5s ease-in-out
}

.text-overlay-slide {
	position: relative
}

.text-overlay-slide .slide-text {
	position: absolute;
	z-index: 10;
	color: white
}

.text-overlay-slide .black {
	color: black
}

.text-overlay-slide .white {
	color: white
}

.text-overlay-slide .right-center {
	left: 68%;
	max-width: 248px;
	top: 29%
}

@media (max-width: 768px) {
	.text-overlay-slide .right-center {
		right: 0px;
		max-width: 33%;
		top: 25%;
		font-size: 10px;
		line-height: 1.5;
		color: white
	}
}

.text-overlay-slide .top-center {
	top: 11%;
	left: 25%
}

@media (max-width: 768px) {
	.text-overlay-slide .top-center {
		color: black;
		top: 6%;
		left: 23%;
		max-width: 172px
	}
	.text-overlay-slide .top-center strong {
		font-size: 10px;
		line-height: 1.2
	}
	.text-overlay-slide .top-center p {
		line-height: 1.2
	}
}

.text-overlay-slide .top-right {
	top: 50px;
	right: 70px;
	width: 230px;
	text-align: right
}

@media (max-width: 768px) {
	.text-overlay-slide .top-right {
		top: 13px;
		right: 10px;
		width: 150px;
		text-align: right;
		font-size: 10px;
		line-height: 1.2
	}
	.text-overlay-slide .top-right strong,
	.text-overlay-slide .top-right p {
		line-height: 1.2
	}
}

.text-overlay-slide .top-left {
	left: 60px;
	top: 50px
}

@media (max-width: 768px) {
	.text-overlay-slide .top-left {
		left: 20px;
		top: 14px;
		font-size: 10px
	}
	.text-overlay-slide .top-left strong {
		font-size: 10px;
		line-height: 1.2
	}
	.text-overlay-slide .top-left p {
		line-height: 1.2
	}
}

.text-overlay-slide .bottom-right {
	right: 60px;
	bottom: 40px
}

@media (max-width: 768px) {
	.text-overlay-slide .bottom-right {
		left: 10px;
		bottom: 0px;
		max-width: 240px
	}
	.text-overlay-slide .bottom-right p {
		line-height: 1.2
	}
	.text-overlay-slide .bottom-right em {
		color: white !important;
		font-size: 10px
	}
	.text-overlay-slide .bottom-right strong {
		font-size: 10px;
		line-height: 1.2
	}
}

@media only screen and (min-width: 750px) {
	.slide-from-right {
		-webkit-transform: translateX(40px);
		transform: translateX(40px);
		opacity: 0
	}
	.slide-from-left {
		-webkit-transform: translateX(-40px);
		transform: translateX(-40px);
		opacity: 0
	}
	.slide-up {
		-webkit-transform: translateY(40px);
		transform: translateY(40px);
		opacity: 0
	}
	.split-slide-in p:first-of-type {
		-webkit-transform: translateX(10px);
		transform: translateX(10px)
	}
	.split-slide-in p:last-of-type {
		-webkit-transform: translateX(-10px);
		transform: translateX(-10px)
	}
	.animate-text .slide-from-right,
	.animate-text .slide-from-left {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1;
		-webkit-transition: 1.5s ease-in-out;
		transition: 1.5s ease-in-out
	}
	.animate-text .split-slide-in p:first-of-type,
	.animate-text .split-slide-in p:last-of-type {
		-webkit-transform: translateX(0);
		transform: translateX(0)
	}
	.animate-text .slide-up {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}
	.scale-in-text {
		-webkit-transform: scale(0.85);
		transform: scale(0.85);
		opacity: 0
	}
	.animate-text .text-only-slide-container .scale-in-text {
		-webkit-transition: opacity .8s ease-in-out, -webkit-transform 2.3s ease-in-out;
		transition: opacity .8s ease-in-out, -webkit-transform 2.3s ease-in-out;
		transition: opacity .8s ease-in-out, transform 2.3s ease-in-out;
		transition: opacity .8s ease-in-out, transform 2.3s ease-in-out, -webkit-transform 2.3s ease-in-out
	}
	.animate-text .scale-in-text {
		-webkit-transform: scale(1.05);
		transform: scale(1.05);
		opacity: 1
	}
	.fade-in {
		opacity: 0
	}
	.split-fade-in p:first-of-type,
	.split-fade-in p+p,
	.split-fade-in p strong,
	.split-fade-in p em {
		opacity: 0
	}
	.animate-text .fade-in {
		opacity: 1
	}
	.animate-text .split-fade-in p:first-of-type,
	.animate-text .split-fade-in p+p,
	.animate-text .split-fade-in p strong,
	.animate-text .split-fade-in p em {
		opacity: 1
	}
}

.text-overlay-slide .slide-text {
	-webkit-transition: all 1.75s ease-in-out;
	transition: all 1.75s ease-in-out
}

.three-part-fade {
	font-size: 1.2rem
}

.three-part-fade span {
	opacity: 0
}

.animate-text .three-part-fade {
	-webkit-transition: none;
	transition: none
}

.animate-text .three-part-fade span {
	-webkit-transition: all 1.25s ease-in-out;
	transition: all 1.25s ease-in-out;
	opacity: 1
}

.animate-text .three-part-fade span:nth-of-type(2) {
	-webkit-transition-delay: 1s;
	transition-delay: 1s
}

.animate-text .three-part-fade span:nth-of-type(3) {
	-webkit-transition-delay: 2s;
	transition-delay: 2s
}

.animate-text .split-fade-in {
	-webkit-transition: none;
	transition: none
}

.animate-text .split-fade-in p:first-of-type,
.animate-text .split-fade-in p:last-of-type,
.animate-text .split-fade-in p strong,
.animate-text .split-fade-in p em {
	-webkit-transition: all 1.25s ease-in-out;
	transition: all 1.25s ease-in-out
}

.animate-text .split-fade-in p+p,
.animate-text .split-fade-in p em {
	-webkit-transition-delay: 1.8s !important;
	transition-delay: 1.8s !important
}

@media only screen and (min-width: 750px) {
	img.scale-in {
		-webkit-transform: scale(1);
		transform: scale(1);
		opacity: 0
	}
	img.scale-out {
		-webkit-transform: scale(1.3);
		transform: scale(1.3);
		opacity: 0
	}
	.swiper-slide-active img.scale-in,
	.swiper-slide-prev img.scale-in {
		-webkit-transform: scale(1.3);
		transform: scale(1.3);
		opacity: 1
	}
	.swiper-slide-active img.scale-out,
	.swiper-slide-prev img.scale-out {
		-webkit-transform: scale(1);
		transform: scale(1);
		opacity: 1
	}
}

.home .swiper-slide-active img,
.home .swiper-slide-prev img {
	-webkit-transition-duration: 6000ms;
	transition-duration: 6000ms;
	-webkit-transition-property: all;
	transition-property: all;
	-webkit-transition-timing-function: ease-in-out;
	transition-timing-function: ease-in-out
}

.swiper-slide-active .slide-in-right,
.swiper-slide-active .slide-in-left,
.swiper-slide-prev .slide-in-right,
.swiper-slide-prev .slide-in-left {
	-webkit-transform: translateX(0);
	transform: translateX(0);
	opacity: 1
}

.home .slide-in-right,
.home .slide-in-left {
	-webkit-transition: all 2.2s ease-in-out !important;
	transition: all 2.2s ease-in-out !important
}

.slide-in-left {
	-webkit-transform: translateX(-100%);
	transform: translateX(-100%);
	opacity: 0
}

.slide-in-right {
	-webkit-transform: translateX(100%);
	transform: translateX(100%);
	opacity: 0
}

img.fade-in {
	opacity: 0;
	-webkit-transition: all 1.4s ease-in-out;
	transition: all 1.4s ease-in-out
}

.swiper-slide-active img.fade-in,
.swiper-slide-prev img.fade-in {
	opacity: 1
}

.text-overlay-slide img.fade-in {
	opacity: 1
}

.logo-slide-container {
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: 100%
}

.logo-slide-container img {
	max-width: 300px;
	margin: 0 auto
}

@media (max-width: 768px) {
	.logo-slide-container img {
		width: 60%
	}
}

.logo-slide-container strong {
	display: block;
	text-align: center;
	margin-bottom: 0;
	margin-top: 30px
}

@media (max-width: 768px) {
	.logo-slide-container strong {
		margin-top: 16px;
		font-size: 1.1rem
	}
}

.audio-controls {
	position: absolute;
	top: 15px;
	right: 20px;
	z-index: 100
}

.audio-controls a {
	font-size: 1.1rem;
	opacity: .7
}

.audio-controls a:hover {
	opacity: 1
}

.audio-controls .turn-off-volume,
.audio-controls .turn-on-volume {
	display: none
}

.awards hr {
	margin: 60px 0
}

.award-logos {
/* 	display: -webkit-box;
	display: -ms-flexbox;
	display: flex; */
	margin-bottom: 65px
}

.award-logos img {
	display: inline-block;
	margin: 1.2rem 4rem 0 0;
	height: 85px
}

@media only screen and (max-width: 600px) {
	.award-logos img {
		margin: 1.2rem 1.5rem 0 0;
		height: 70px
	}
}

.grid--large-column-gutters .grid--honors {
	padding-top: 1.3rem
}

.grid--large-column-gutters .grid--honors h3 {
	margin-bottom: .5rem
}

.grid--large-column-gutters .grid--honors p {
	margin-bottom: 25px
}

.grid--large-column-gutters .grid--honors [class^="grid__cell"] {
	padding-bottom: 0
}

.grid--large-column-gutters .grid--honors [class^="grid__cell"]:nth-child(n+7) hr {
	display: none
}

.about section:last-of-type {
	padding-bottom: 10rem
}

.products .intro-title {
	margin-bottom: 2rem
}

.products .landing {
	padding-bottom: 5rem
}

.products .padder {
	padding-bottom: 8rem
}

.has-video {
	position: relative
}

.has-video img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	-webkit-transition: all .3s ease-in-out;
	transition: all .3s ease-in-out
}

.has-video .embed-container {
	padding-top: 90px
}

.has-video .embed-container-inner {
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
	max-width: 100%
}

.has-video .embed-container-inner iframe,
.has-video .embed-container-inner object,
.has-video .embed-container-inner embed {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%
}

.animation-playing img {
	opacity: 0;
	visibility: hidden
}

@media only screen and (min-width: 600px) {
	.has-video {
		min-height: 444px
	}
}

@media only screen and (max-width: 600px) {
	.home .banner-image {
		margin-bottom: 2rem
	}
}

.gallery .landing {
	margin-bottom: 5rem
}

.gallery .landing .highlight-wrapper {
	background: #F7F9FA
}

.gallery .landing .rotated-text-wrapper img {
	max-width: 85%;
	margin: 0 auto;
	display: block
}

.gallery .landing h2,
.gallery .landing h3 {
	font-size: .857rem
}

.map-wrapper h3 {
	display: none
}

.map-wrapper h2 {
	margin-bottom: 0;
	margin-top: 1rem;
	text-align: center
}

.map-wrapper .map-link-wrapper {
	position: relative
}

.map-wrapper [class*="full-map-link"] {
	width: 50%;
	background: url("../images/spacer.png") 0 0 repeat;
	height: 100%;
	position: absolute;
	display: block;
	z-index: 100
}

.map-wrapper .full-map-link--left {
	top: 0;
	left: 0
}

.map-wrapper .full-map-link--right {
	top: 0;
	right: 0
}

@media only screen and (min-width: 920px) {
	.map-wrapper {
		position: relative
	}
	.map-wrapper h2,
	.map-wrapper h3 {
		position: absolute;
		z-index: 2;
		display: block
	}
	.map-wrapper h2:first-of-type {
		top: 30px;
		left: 60px
	}
	.map-wrapper h2:last-of-type {
		top: 30px;
		right: 60px
	}
	.map-wrapper h3:first-of-type {
		bottom: 50px;
		left: 60px
	}
	.map-wrapper h3:first-of-type::before {
		content: '';
		border-bottom: 1px solid #393838;
		width: 50px;
		position: absolute;
		top: 50%;
		-webkit-transform: translateX(-60px);
		transform: translateX(-60px)
	}
	.map-wrapper h3:last-of-type {
		bottom: 50px;
		right: 60px
	}
	.map-wrapper h3:last-of-type::before {
		content: '';
		border-bottom: 1px solid #393838;
		width: 50px;
		position: absolute;
		top: 50%;
		right: 0;
		-webkit-transform: translateX(60px);
		transform: translateX(60px)
	}
}

.map-pin {
	display: none
}

.arrow-wrapper {
	position: relative
}

.arrow-wrapper .swiper-button-next,
.arrow-wrapper .swiper-button-prev {
	height: 34px;
	background-size: 100%
}

.arrow-wrapper .swiper-button-prev {
	left: -60px;
	width: 20px;
	background-image: url("../images/left-arrow.svg")
}

.arrow-wrapper .swiper-button-next {
	right: -60px;
	width: 20px;
	background-image: url("../images/right-arrow.svg")
}

@media only screen and (max-width: 1260px) {
	.arrow-wrapper .swiper-container {
		width: calc(100% - 60px);
		margin-left: auto;
		margin-right: auto
	}
	.arrow-wrapper .swiper-button-prev {
		left: 0;
		height: 26px
	}
	.arrow-wrapper .swiper-button-next {
		right: 0;
		height: 26px
	}
}

.faq ul {
	margin-bottom: 8rem
}

.faq li {
	cursor: pointer;
	border-bottom: 1px solid #393838;
	padding: 1.9rem 0 2rem
}

.faq li:first-of-type {
	padding-top: 0
}

.faq li h3 {
	margin-bottom: 0
}

.faq li p {
	opacity: 0;
	margin-top: 1.1rem;
	margin-bottom: 0;
	-webkit-transform: scale(0.99);
	transform: scale(0.99);
	-webkit-transition: all .2s ease-in-out .3s;
	transition: all .2s ease-in-out .3s
}

.faq li .answer {
	display: none;
	overflow: hidden
}

.faq li .answer--open p {
	opacity: 1;
	-webkit-transform: scale(1);
	transform: scale(1)
}

.logo-grid {
	margin-bottom: 5rem
}

.logo-wrapper {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	height: 20.4rem;
	position: relative;
	padding: 3rem
}

.logo-wrapper h3 {
	position: absolute;
	color: #85898D
}

.logo-wrapper img {
	opacity: .7;
	max-width: 15.64rem;
	max-height: 8.78rem;
	-webkit-transition: all .3s ease-in-out;
	transition: all .3s ease-in-out
}

.careers .landing li {
	padding: 1.5rem 0;
	border-bottom: 1px solid #393838
}

.careers .landing li h2 {
	font-family: "Helvetica Neue Medium", sans-serif;
	text-transform: none;
	font-size: 1rem;
	letter-spacing: .075rem;
	margin: 0
}

.careers .landing p {
	margin-bottom: 1.5rem
}

@media only screen and (min-width: 1100px) {
	.careers .landing {
		padding-left: 10rem
	}
}

.careers .detail ul {
	margin-top: .2rem
}

.careers .detail article:first-of-type {
	margin-top: 3.5rem
}

.careers .detail p a {
	font-family: "Helvetica Neue Medium", sans-serif
}

.text--strong-headings strong {
	margin-top: 2rem;
	display: inline-block
}

.text--strong-headings p:first-of-type strong {
	margin-top: 0
}

.downloads .rotated-text-wrapper {
	padding: 40px;
	height: 200px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	text-align: center
}

.downloads .rotated-text-wrapper h2 {
	margin: 0
}

.downloads .rotated-text-left {
	left: 10px
}

.downloads .rotated-text-right {
	right: 10px
}

.downloads .detail .grid {
	margin-top: 60px
}

.downloads .detail .grid h3 {
	margin-bottom: 30px
}

.downloads .password-protect-section {
	margin-top: 60px
}

.downloads .password-protect-section form {
	max-width: 500px;
	margin-top: 60px;
	margin-bottom: 45px
}

.downloads .password-protect-section form button {
	margin-top: 0;
	padding-top: 0
}

.downloads .password-protect-section form font {
	font-size: 11px
}

.downloads .password-protect-section form input:first-of-type {
	padding-top: 10px
}

.downloads .password-protect-section .terms {
	margin-bottom: 120px
}

.download-list {
	margin-top: 80px;
	margin-bottom: 80px
}

.download-list h2 {
	margin: 0;
	text-align: center
}

.download-list h2 a {
	background-color: #F7F9FA;
	padding: 4rem 1rem;
	display: block
}

@media only screen and (min-width: 1000px) {
	.contact .vertical-heading-wrapper,
	.contact .vertical-heading-wrapper--full-page {
		margin-top: 11rem;
		padding-left: 11rem
	}
}

.innovation {
	overflow-x: hidden
}

.innovation .intro-text {
	margin: 3.4rem 0 4rem
}

.innovation .timeline {
	position: relative;
	margin-top: 9rem;
	margin-bottom: 5.89rem
}

.innovation .timeline h2 {
	font-size: 1.35rem;
	text-align: center;
	padding: 1rem 0 1.5rem;
	margin-bottom: 0
}

.innovation .timeline p {
	color: #85898D
}

.innovation .timeline .strong-text,
.innovation .timeline p {
	font-size: .87rem;
	letter-spacing: .075rem
}

.innovation .timeline .strong-text {
	margin-bottom: 7px
}

.innovation .timeline .text-wrapper {
	padding-bottom: 0
}

.innovation .timeline .paragraphs-with-small-rule {
	padding: 0 1rem
}

.innovation .timeline article {
	padding: 0 5.89rem 1.4rem
}

.innovation .timeline .grid--large-column-gutters [class^="grid__cell"] {
	padding-bottom: 0
}

.innovation .image-wrapper img {
	width: 66%
}

.innovation article:nth-of-type(3) .event {
	padding-bottom: 1rem;
	padding-top: 1rem
}

.innovation article:first-of-type::before,
.innovation article:nth-of-type(6)::before,
.innovation article:nth-of-type(10)::before {
	content: '';
	width: 400%;
	height: 154%;
	position: absolute;
	top: -60px;
	background-color: #F7F9FA;
	z-index: -2
}

.innovation article:first-of-type {
	position: relative
}

.innovation article:first-of-type::before {
	left: 0;
	background-color: #F7F9FA
}

.innovation article:nth-of-type(6) {
	position: relative
}

.innovation article:nth-of-type(6)::before {
	right: 0;
	height: 273%;
	top: -20px
}

.innovation article:nth-of-type(10) {
	position: relative
}

.innovation article:nth-of-type(10)::before {
	height: 86%;
	top: 100px;
	left: 0;
	background-color: #F7F9FA
}

.innovation article:nth-of-type(10) .event:last-of-type {
	padding-bottom: 3rem
}

.innovation article:nth-of-type(10) .event:last-of-type .text-wrapper {
	padding-top: 3rem
}

.patents {
	margin-bottom: 0;
	padding-top: 3.21rem;
	padding-bottom: 5.3rem
}

.patents .patent-card {
	position: relative;
	overflow: hidden;
	margin-top: 1.5rem;
	height: 296px
}

.patents .patent-card .patent-info {
	background-color: #F7F9FA;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	opacity: 1;
	-webkit-transition: all .5s ease-in-out;
	transition: all .5s ease-in-out;
	text-align: center;
	padding: 0 10px
}

.patents .patent-card .patent-info h3 {
	font-size: .9rem;
	line-height: 1.4
}

.patents .patent-card .patent-info h4 {
	margin-bottom: 0;
	font-size: .8rem;
	margin-top: 10px
}

.patents .patent-card .patent-info-has-image:hover {
	opacity: 0
}

.patents .patent-card img {
	max-height: 100%;
	margin: 0 auto;
	display: block
}

.patents .patent-card h3 {
	margin-bottom: 0
}

@media only screen and (min-width: 769px) {
	.innovation .timeline .event {
		position: relative
	}
	.innovation .timeline .event::before,
	.innovation .timeline .event::after {
		left: calc(50% + 2.145rem)
	}
	.innovation .timeline .event::before {
		content: '';
		position: absolute;
		top: 50%;
		-webkit-transform: translate(-50%, -50%);
		transform: translate(-50%, -50%);
		height: 13px;
		width: 13px;
		border-radius: 50%;
		background-color: white;
		border: 1px solid #393838
	}
	.innovation .timeline .event::after {
		content: '';
		position: absolute;
		top: 0;
		bottom: 0;
		border-left: 1px solid #393838;
		z-index: -1;
		width: 1px
	}
	.innovation .timeline .image-wrapper {
		position: relative
	}
	.innovation .timeline .image-wrapper img {
		position: relative;
		z-index: 1;
		margin-left: 9.64rem
	}
	.innovation .timeline .has-image::before {
		content: '';
		border-bottom: 1px solid #393838;
		width: 200px;
		position: absolute;
		top: 50%;
		left: 5rem;
		height: 1px;
		-webkit-transform: translateY(-50%);
		transform: translateY(-50%)
	}
	.innovation .timeline article:nth-of-type(10) [class^="grid__cell"]:nth-of-type(3) {
		-webkit-box-ordinal-group: 2;
		-ms-flex-order: 1;
		order: 1
	}
	.innovation .timeline article:nth-of-type(n+2):nth-of-type(-n+3) .image-wrapper,
	.innovation .timeline article:nth-of-type(2n+5):nth-of-type(-n+7) .event:first-of-type .image-wrapper,
	.innovation .timeline article:nth-of-type(8) .image-wrapper,
	.innovation .timeline article:nth-of-type(10) .image-wrapper {
		-webkit-box-ordinal-group: 0;
		-ms-flex-order: -1;
		order: -1;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-pack: end;
		-ms-flex-pack: end;
		justify-content: flex-end
	}
	.innovation .timeline article:nth-of-type(n+2):nth-of-type(-n+3) .image-wrapper img,
	.innovation .timeline article:nth-of-type(2n+5):nth-of-type(-n+7) .event:first-of-type .image-wrapper img,
	.innovation .timeline article:nth-of-type(8) .image-wrapper img,
	.innovation .timeline article:nth-of-type(10) .image-wrapper img {
		right: 9.4rem;
		-ms-flex-item-align: center;
		align-self: center;
		position: relative
	}
	.innovation .timeline article:nth-of-type(n+2):nth-of-type(-n+3) .has-image::before,
	.innovation .timeline article:nth-of-type(2n+5):nth-of-type(-n+7) .event:first-of-type .has-image::before,
	.innovation .timeline article:nth-of-type(8) .has-image::before,
	.innovation .timeline article:nth-of-type(10) .has-image::before {
		left: auto;
		right: .6rem
	}
	.innovation .timeline article:nth-of-type(2) .text-wrapper {
		/*-ms-flex-item-align: end;
		align-self: flex-end*/
	}
	.innovation .timeline article:first-of-type .text-wrapper {
		padding-bottom: 9rem
	}
}

@media only screen and (max-width: 1000px) {
	.innovation .timeline article {
		padding: 0
	}
}

@media only screen and (max-width: 768px) {
	.innovation .timeline article {
		padding: 0 0 0 1.5rem;
		margin-bottom: 2rem
	}
	.innovation .timeline {
		border-left: 1px solid #393838;
		margin-left: 1.5rem
	}
	.innovation .timeline .paragraphs-with-small-rule {
		padding: 0
	}
	.innovation .timeline h2 {
		padding-top: 0;
		text-align: left;
		position: relative
	}
	.innovation .timeline h2::before {
		content: '';
		position: absolute;
		top: 33%;
		left: -3rem;
		-webkit-transform: translate(-50%, -50%);
		transform: translate(-50%, -50%);
		height: 13px;
		width: 13px;
		border-radius: 50%;
		background-color: white;
		border: 1px solid #393838
	}
	.innovation .timeline h2::after {
		content: '';
		position: absolute;
		top: 33%;
		left: -1.5rem;
		width: 2rem;
		-webkit-transform: translate(-50%, -50%);
		transform: translate(-50%, -50%);
		height: 1px;
		border-bottom: 1px solid #393838;
		z-index: -1
	}
	.innovation .event::before {
		left: 0
	}
	.innovation img {
		margin: 1rem 0;
		display: block
	}
}


/*5.5*/
.line-clamp-4 {
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-all;
  white-space: normal;
}