body {
	font-family: "Roboto", sans-serif
}

h1,
h2,
h3,
h4,
h5,
legend {
	font-family: "Rufina", serif;
	font-weight: normal;
	line-height: 1.3rem;
	margin: 0 0 .6em;
	word-break: break-word
}

h1 {
	color: #003a4d;
	font-size: 3.625rem;
	line-height: 1.1em;
	margin: 0 0 .375em
}

h1.small {
	font-size: 2.75rem;
	line-height: 1.1em
}

@media(max-width: 768px) {
	h1.small {
		font-size: 2.5rem !important;
		line-height: 1.025em
	}
}

@media(max-width: 576px) {
	h1.small {
		font-size: 2.25rem !important
	}
}

@media(max-width: 400px) {
	h1.small {
		font-size: 2rem !important
	}
}

@media(max-width: 768px) {
	h1 {
		font-size: 3.125rem !important
	}
}

@media(max-width: 576px) {
	h1 {
		font-size: 2.75rem !important
	}
}

h2,
.h2 {
	color: #003a4d;
	font-size: 2.125rem;
	line-height: 1.25em
}

h2.large,
.h2.large {
	font-size: 2.375rem
}

@media(max-width: 768px) {

	h2,
	.h2 {
		font-size: 1.875rem
	}

	h2.large,
	.h2.large {
		font-size: 1.75rem
	}
}

h3 {
	font-size: 1.625rem;
	line-height: 1.4em;
	font-family: "Roboto", sans-serif;
	font-weight: 500
}

@media(max-width: 768px) {
	h3 {
		font-size: 1.5rem
	}
}

h3.small {
	font-size: 1.5rem;
	line-height: 135%
}

@media(max-width: 768px) {
	h3.small {
		font-size: 1.4rem
	}
}

@media(max-width: 576px) {
	h3.small {
		font-size: 1.3rem
	}
}

h4 {
	font-size: 1.37rem;
	line-height: 1.32em;
	font-family: "Roboto", sans-serif;
	font-weight: 500
}

@media(max-width: 768px) {
	h4 {
		font-size: 1.25rem
	}
}

@media(max-width: 400px) {
	h4 {
		font-size: 1.125rem
	}
}

a h4 {
	color: #202623
}

h5 {
	font-size: 1rem;
	line-height: 1.3em
}

p,
ul,
ol {
	font-family: "Roboto", sans-serif;
	color: #363f3b;
	font-size: 17px;
	font-weight: 400;
	line-height: 1.6rem;
	padding: 0;
	margin: 0 0 1.5em
}

@media(max-width: 768px) {

	p,
	ul,
	ol {
		font-size: 15px;
		line-height: 1.4rem
	}
}

ul,
ol {
	padding: 0 0 0 1.5em;
	margin: 0 0 1.75em
}

ul li,
ol li {
	margin: 0 0 .625em
}

b,
strong {
	font-weight: 700
}

em,
i {
	font-style: italic
}

.small {
	font-size: .8375rem;
	line-height: 1.5
}

.xl {
	font-size: 1.5rem;
	line-height: 1.5
}

.xxl {
	font-size: 1.75rem;
	line-height: 1.5
}

figcaption {
	color: #7d8984;
	font-size: .9rem;
	margin-top: .75rem
}

blockquote {
	background: #f6fde4;
	padding: 32px 40px;
	text-align: center
}

.overline {
	display: block;
	color: #87b01e;
	font-size: .9375rem;
	font-weight: 500;
	line-height: 1rem;
	letter-spacing: 1px;
	margin-bottom: 1rem;
	text-transform: uppercase
}

.overline.small {
	font-size: .875rem
}

@media(max-width: 768px) {
	.overline {
		font-size: .875rem
	}
}

hr {
	display: block;
	border: 1px solid #e2ece8;
	margin: 75px 0 0
}

@media(max-width: 768px) {
	hr {
		margin: 25px 0 0
	}
}

@media(max-width: 768px) {
	hr.hide-mobile {
		display: none
	}
}

@view-transition {
	navigation: auto
}



@media(max-width: 1024px) {
	.hero-slider {
		height: 75vw
	}
}

@media(max-width: 576px) {
	.hero-slider {
		height: 500px
	}
}

.hero-slider .carousel-cell {
	width: 100%;
	height: 100%;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center
}

.hero-slider .carousel-cell .inner {
	position: relative;
	top: 50%;
	transform: translateY(-50%);
	width: 500px;
	left: calc(50vw - 600px);
	color: #fff;
	background: linear-gradient(-30deg, rgba(119, 166, 0, 0.2), rgba(0, 58, 77, 0.85) 30%);
	backdrop-filter: blur(7px);
	padding: 50px
}

@media(max-width: 1320px) {
	.hero-slider .carousel-cell .inner {
		text-align: center;
		width: auto;
		left: auto;
		padding: 0 15vw;
		background: none;
		backdrop-filter: blur(0px);
		border: none
	}
}

.hero-slider .carousel-cell .inner h1 {
	color: #fff
}

.hero-slider .carousel-cell .inner p {
	color: hsla(0, 0%, 100%, .8)
}

@media(max-width: 768px) {
	.hero-slider .carousel-cell .inner p {
		color: #fff
	}
}

.hero-slider .flickity-prev-next-button {
	width: 80px;
	height: 80px;
	background: rgba(0, 0, 0, 0)
}

.hero-slider .flickity-prev-next-button:hover {
	background: rgba(0, 0, 0, 0)
}

.hero-slider .flickity-prev-next-button .arrow {
	fill: #fff
}

.hero-slider .flickity-page-dots {
	bottom: 30px
}

.hero-slider .flickity-page-dots .dot {
	width: 30px;
	height: 4px;
	opacity: 1;
	background: hsla(0, 0%, 100%, .5);
	border: 0 solid #fff;
	border-radius: 0
}

.hero-slider .flickity-page-dots .dot.is-selected {
	background: #cfe98d;
	border: 0 solid #cfe98d
}

section.banner1 {
	background: #deeeb5;
	display: grid;
	grid-template-columns: 1fr 600px 600px 1fr;
	align-items: center;
	height: 500px;
	position: relative
}

@media(max-width: 1280px) {
	section.banner1 {
		grid-template-columns: 6vw 1fr 1fr 6vw
	}
}

@media(max-width: 1024px) {
	section.banner1 {
		grid-template-columns: 5vw 1fr 1fr 5vw
	}
}

section.banner1.marketing {
	height: 400px
}

section.banner1.marketing .banner-content {
	max-height: 400px
}

section.banner1.marketing .banner-image {
	max-height: 400px
}

section.banner1 .banner1-icon {
	position: absolute;
	background: #fff;
	width: 108px;
	height: 108px;
	left: calc(50vw - 54px);
	border-radius: 200px;
	box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, .08), 0px 2px 20px -2px rgba(0, 0, 0, .04), 0px 7px 33px -3px rgba(0, 0, 0, .07);
	display: grid;
	place-content: center;
	z-index: 1
}

section.banner1 .banner1-icon svg {
	width: auto;
	height: 54px
}

section.banner1 .banner1-icon svg path {
	fill: #086e5b;
}

@media(max-width: 1024px) {
	section.banner1 .banner1-icon {
		bottom: -36px;
		z-index: 2;
		width: 72px;
		height: 72px;
		left: calc(50vw - 36px)
	}

	section.banner1 .banner1-icon svg {
		height: 36px
	}
}

section.banner1 .banner1-content {
	grid-column: 2/span 1;
	padding-right: 75px
}

section.banner1 .banner1-content .overline {
	color: #fff
	font-family: "area-normal", Sans-serif;
}

section.banner1 .banner1-content h1 {
	color: #fff
}

section.banner1 .banner1-content p {
	margin: 0;
	color: #fff;
}

section.banner1 .banner1-image {
	grid-column: 3/span 2;
	height: 100%;
	max-height: 350px
}

section.banner1 .banner1-image picture {
	position: relative;
	width: 100%;
	height: 100%;
	overflow: hidden
}

section.banner1 .banner1-image picture img {
	width: 100%;
	min-height: 500px;
	object-fit: cover;
	margin-top: -75px;
}

@media(max-width: 1024px) {
	section.banner1 {
		grid-template-columns: 1fr
	}

	section.banner1 .banner1-content .overline,
	section.banner1 .banner1-content h1,
	section.banner1 .banner1-content p {
		color: #fff
	}

	section.banner1 .banner1-content {
		grid-column: 1/span 1;
		grid-row: 1/span 1;
		z-index: 1;
		background: rgba(0, 58, 77, .5);
		text-align: center;
		padding: 0 5vw;
		height: 500px;
		display: grid;
		place-content: center
	}

	section.banner1 .banner1-content.marketing {
		height: 400px
	}

	section.banner1 .banner1-image {
		grid-column: 1/span 1;
		grid-row: 1/span 1
	}
}

.newer-article-notification {
	position: relative;
	background: #ebf3f0;
	padding: 0 0 25px
}

@media(max-width: 1280px) {
	.newer-article-notification {
		width: 88vw;
		padding: 0 6vw 25px
	}
}

@media(max-width: 768px) {
	.newer-article-notification {
		width: 90vw;
		padding: 0 5vw 25px
	}
}

.newer-article-notification a.newer-article-content {
	position: relative;
	left: calc(50vw - 600px);
	max-width: 1200px;
	padding: 15px 0;
	border: 1px solid #0199c7;
	background-color: #ebf3f0;
	background-image: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23E2ECE8' fill-opacity='.5' fill-rule='evenodd'%3E%3Cpath d='M0 40L40 0H20L0 20M40 40V20L20 40'/%3E%3C/g%3E%3C/svg%3E");
	display: grid;
	grid-template-columns: 40px 1fr 40px;
	align-items: center;
	gap: 12px
}

@media(max-width: 1280px) {
	.newer-article-notification a.newer-article-content {
		left: auto
	}
}

@media(max-width: 576px) {
	.newer-article-notification a.newer-article-content {
		grid-template-columns: 1fr 28px;
		padding-left: 15px
	}
}

.newer-article-notification a.newer-article-content span.info {
	justify-self: end
}

.newer-article-notification a.newer-article-content span.info svg {
	width: 25px;
	height: auto
}

.newer-article-notification a.newer-article-content span.info svg path {
	fill: #00779b
}

@media(max-width: 576px) {
	.newer-article-notification a.newer-article-content span.info {
		display: none
	}
}

.newer-article-notification a.newer-article-content span.right svg {
	width: 18px;
	height: auto;
	transition: .2s ease
}

.newer-article-notification a.newer-article-content span.right svg path {
	fill: #00779b
}

.newer-article-notification a.newer-article-content p {
	margin: 0;
	color: #00779b
}

.newer-article-notification a.newer-article-content:hover {
	background-image: url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23E2ECE8' fill-opacity='.25' fill-rule='evenodd'%3E%3Cpath d='M0 40L40 0H20L0 20M40 40V20L20 40'/%3E%3C/g%3E%3C/svg%3E");
	border: 1px solid #02556e
}

.newer-article-notification a.newer-article-content:hover span.right svg {
	transform: translateX(2px)
}

.newer-article-notification a.newer-article-content:hover p {
	margin: 0;
	color: #02556e
}

section.plain-banner {
	background: #ebf3f0;
	padding: 75px 0 50px
}

@media(max-width: 768px) {
	section.plain-banner {
		padding: 50px 0 25px;
		text-align: center
	}
}

section.plain-banner .plain-title {
	position: relative;
	left: calc(50vw - 600px);
	max-width: 1000px
}

@media(max-width: 1280px) {
	section.plain-banner .plain-title {
		left: 0;
		width: 88vw;
		padding: 0 6vw
	}
}

@media(max-width: 768px) {
	section.plain-banner .plain-title {
		width: 90vw;
		padding: 0 5vw
	}
}

section.plain-banner .plain-title .overline {
	color: #003a4d
}

section.plain-banner .plain-title .overline a {
	color: #003a4d
}

section.plain-banner .plain-title .overline a:hover {
	color: #77a600
}

section.plain-banner .plain-title h1 {
	margin: 0 0 16px
}

section.plain-banner .plain-title h3 {
	color: #003a4d
}

section.plain-banner .plain-title .byline {
	display: flex;
	align-items: center;
	gap: 8px
}

@media(max-width: 768px) {
	section.plain-banner .plain-title .byline {
		justify-content: center
	}
}

section.plain-banner .plain-title .byline img {
	border-radius: 100px;
	width: 44px
}

@media(max-width: 400px) {
	section.plain-banner .plain-title .byline img {
		display: none
	}
}

section.plain-banner .plain-title .byline span {
	font-size: .9375rem;
	color: #4e5853
}

section.subnav {
	border-bottom: 1px solid #d8e3df;
	padding: 0 0
}

section.subnav .subnav-links {
	width: 1200px;
	margin: 0 auto
}

section.subnav .subnav-links a {
	padding: 24px 0;
	display: inline-block
}

section.subnav .subnav-links a.active {
	color: red
}

.alert {
	position: fixed;
	bottom: 0;
	z-index: 10;
	width: 100%;
	background: rgba(2, 85, 110, .9);
	backdrop-filter: blur(7px);
	color: #fff;
	text-align: center;
	display: grid;
	grid-gap: 12px;
	grid-template-columns: 1fr max-content;
	grid-template-rows: max-content
}

.alert p {
	align-self: center;
	padding: 12px 8px;
	margin: 0;
	color: #fff;
	font-weight: 300;
	font-size: 14px;
	line-height: 22px
}

@media(min-width: 1024px) {
	.alert p {
		padding: 28px 8px;
		font-size: 16px
	}
}

.alert p a {
	color: #fff;
	font-weight: 500;
	border-bottom: 1px solid hsla(0, 0%, 100%, .25)
}

.alert .close-button {
	background: #003a4d;
	cursor: pointer;
	transition: .3s;
	display: grid
}

.alert .close-button svg {
	padding: 15px;
	opacity: .9;
	align-self: center
}

@media(min-width: 1024px) {
	.alert .close-button svg {
		padding: 15px 25px
	}
}

.alert .close-button svg path {
	fill: #fff
}

.alert .close-button:hover {
	color: #fff;
	background: #003a4d;
	font-size: 24px
}

.alert .close-button:hover img {
	opacity: 1;
	transform: scale(1.04)
}

button,
.button {
	font-size: 15px;
	font-weight: 400;
	text-transform: uppercase;
	text-decoration: none;
	letter-spacing: 1px;
	margin: 0 0 0;
	padding: 12px 32px 14px;
	border-radius: 100px;
	display: inline-block;
	transition: .2s ease;
	background: #086e5b;
	color: #202623;
	margin-left: 250px;
}

button:hover,
.button:hover {
	background: #dbefc3;
	color: #202623
}

@media(max-width: 1024px) {

	button,
	.button {
		font-size: 14px;
		margin-left: 30px;
	}
}

button.white,
.button.white {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	background: #77a600;
	box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, .08), 0px 2px 20px -2px rgba(0, 0, 0, .04), 0px 7px 33px -3px rgba(0, 0, 0, .07)
}

button.white:hover,
.button.white:hover {
	background: #719e00;
	box-shadow: 0px 3px 4px rgba(0, 0, 0, .12), 0px 9px 33px -1px rgba(0, 0, 0, .1), 0px 12px 42px -8px rgba(0, 0, 0, .15)
}

button.white span,
.button.white span {
	color: #fff;
	margin: 0
}

button.white svg,
.button.white svg {
	height: 24px;
	width: auto
}

button.white svg path,
.button.white svg path {
	fill: #fff
}

p.button a {
	text-decoration: none
}

p.button a:hover {
	color: #202623
}

a {
	text-decoration: none;
	color: #77a600;
	transition: .2s ease
}

a:hover {
	color: #719e00
}

.richtext a,
.text a {
	font-weight: 500;
	text-decoration: underline;
	color: #202623;
	text-decoration-color: #bedd70
}

.richtext a.button,
.text a.button {
	color: #fff;
	text-decoration: none
}

.richtext a:hover,
.text a:hover {
	text-decoration-color: #77a600;
	color: #77a600
}

.text-button {
	font-weight: 500;
	border-bottom: 2px solid #cfe98d;
	color: #202623;
	padding: 0 0 2px
}

.text-button:hover {
	color: #87b01e;
	border-bottom: 2px solid #87b01e
}

.text-button.dark {
	border-bottom: 2px solid #77a600
}

.text-button.dark:hover {
	color: #719e00;
	border-bottom: 2px solid #719e00
}

.text-button.light {
	color: #fff;
	border-bottom: 2px solid #deeeb5
}

.text-button.light:hover {
	color: #bedd70;
	border-bottom: 2px solid #bedd70
}

section.footer-cta {
	background: linear-gradient(to bottom, #ebf3e1, #ebf3e1 50%, #ebf3e1 50%)
}

section.footer-cta .container {
	box-sizing: border-box;
	padding: 60px 50px;
	background: #086e5b;
	position: relative;
	overflow: hidden;
	margin-bottom: 50px;
	margin-top: 50px;
}

@media(max-width: 768px) {
	section.footer-cta .container {
		padding: 50px 40px
	}
}

section.footer-cta .overline {
	color: #fff;
	position: relative;
	margin: 0 0 1.425em;
	z-index: 1
}

section.footer-cta h3 {
	color: #fff;
	max-width: 780px;
	position: relative;
	z-index: 1;
	margin: 0 0 1em;
	font-size: 22px;
	font-family: "area-normal", Sans-serif;
}

section.footer-cta a {
	position: relative;
	z-index: 1
}

section.footer-cta .cta-watermark {
	position: absolute;
	top: 0;
	right: 0;
	z-index: 0;
	opacity: .5
}

footer {
	background: #e2ece8;
	position: relative
}

footer section.footerTop {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr 1fr;
	grid-gap: 25px;
	padding: 100px 0 0 0
}

@media(max-width: 768px) {
	footer section.footerTop {
		grid-template-columns: 1fr 1fr;
		padding: 75px 0 0 0
	}
}

footer section.footerTop div {
	display: flex;
	flex-flow: column
}

footer section.footerTop div .overline {
	margin: 0 0 20px
}

footer section.footerTop div a {
	color: #02556e;
	margin: 0 0 17px
}

footer section.footerTop div a svg {
	margin: 0 7px 0 0
}

footer section.footerTop div a svg path {
	fill: #02556e
}

footer section.footerTop div a:hover {
	color: #719e00
}

footer section.footerTop div a:hover svg path {
	fill: #719e00
}

@media(max-width: 768px) {
	footer section.footerTop .footerLogo {
		grid-column: 1/span 2
	}

	footer section.footerTop .footerLogo svg {
		margin: 0 auto 25px auto
	}
}

@media(max-width: 768px) {
	footer section.footerTop .contact {
		grid-column: 1/span 1;
		grid-row: 2/span 1
	}
}

@media(max-width: 768px) {
	footer section.footerTop .quicklinks {
		display: none
	}
}

@media(max-width: 768px) {
	footer section.footerTop .social {
		grid-column: 2/span 1;
		grid-row: 2/span 1;
		padding: 0 0 0 25px
	}
}

footer section.footerBottom {
	border-top: 1px solid #d8e3df;
	padding: 50px 0;
	margin-top: 75px;
	display: flex;
	justify-content: space-between
}

@media(max-width: 768px) {
	footer section.footerBottom {
		flex-flow: column;
		text-align: center;
		margin-top: 50px
	}
}

footer section.footerBottom p,
footer section.footerBottom a {
	font-size: 13px;
	color: #02556e
}

footer section.footerBottom a:hover {
	color: #719e00
}

footer section.footerBottom .copyright p a {
	margin-left: 5px
}

.form {
	max-width: 1000px;
	box-sizing: border-box;
	padding: 42px 36px 48px;
	margin: 0 auto 75px;
	background: #fff;
	box-shadow: 0 6px 60px rgba(0, 0, 0, .05), 0 5px 40px rgba(0, 0, 0, .1), 0 3px 15px rgba(0, 119, 155, .1), 0 2px 5px rgba(0, 0, 0, .1)
}

@media(max-width: 1024px) {
	.form {
		padding: 36px 20px 40px;
		margin: 0 auto 50px
	}
}

.form .formHeadline h2 {
	font-size: 30px;
	margin: 0 0 42px;
	text-align: center
}

.form button {
	font-size: 15px;
	font-weight: 400;
	text-transform: uppercase;
	text-decoration: none;
	letter-spacing: 1px;
	margin: 0 0 0;
	padding: 1em 32px 1em;
	border-radius: 100px;
	display: inline-block;
	transition: .2s ease;
	background: #cfe98d;
	color: #202623;
	width: 100%;
	border: none
}

.form button:hover {
	background: #a4c44b;
	color: #202623
}

.form .fui-form-container {
	font-family: "Roboto", sans-serif
}

.form .fui-form-container label,
.form .fui-form-container input,
.form .fui-form-container textarea,
.form .fui-form-container select,
.form .fui-form-container legend {
	font-weight: 400;
	color: #202623;
	font-family: "Roboto", sans-serif;
	width: 100%
}

.form .fui-form-container label.fui-legend,
.form .fui-form-container input.fui-legend,
.form .fui-form-container textarea.fui-legend,
.form .fui-form-container select.fui-legend,
.form .fui-form-container legend.fui-legend {
	font-weight: 500
}

.form .fui-form-container select {
	font-weight: 400
}

.form .fui-form-container label {
	margin: 0 0 6px;
	font-weight: 500
}

.form .fui-form-container input:focus,
.form .fui-form-container select:focus,
.form .fui-form-container textarea:focus {
	border-color: #0199c7
}

.fui-page {
	text-align: left
}

.fui-page .fui-label,
.fui-page .fui-legend {
	display: block;
	margin: 0 0 10px;
	padding: 0;
	color: #202623;
	font-size: .875em;
	font-weight: 500;
	line-height: 1.2
}

.fui-page .fui-legend {
	padding: 0
}

.fui-page input,
.fui-page textarea,
.fui-page select {
	border-radius: 0px;
	border-style: none;
	background: #f4f4f4;
	box-shadow: inset 0px 1px 2px rgba(0, 0, 0, .09);
	border: 1px solid rgba(0, 0, 0, 0);
	padding: 8px
}

.fui-page input:focus,
.fui-page textarea:focus,
.fui-page select:focus {
	outline: none;
	border: 1px solid #00779b
}

.fui-page .fui-instructions p {
	font-size: 13px;
	padding: 0;
	margin: 0;
	color: #4e5853
}

.fui-page select[multiple]:focus option:checked {
	background: #00779b
}

.fui-page select[multiple]:focus {
	background: #fff
}

.fui-i .fui-alert {
	padding: 1rem;
	margin-bottom: 1rem;
	border-radius: 0;
	font-size: 1em;
	font-family: "Roboto", sans-serif;
	font-weight: 500;
	line-height: 1.25rem;
	border-radius: 4px;
	border: 1px solid #a4c44b;
	color: #719e00;
	background: #f6fde4
}

.fui-field-rows .fui-row {
	margin: 0
}

.fui-required {
	color: red;
	margin: 0 0 0 -2px;
	font-size: 13px
}

.fui-name-last-name {
	margin: 18px 0 0 0
}

.fui-btn-container {
	margin: 25px 0 0
}

.fui-btn-container button {
	min-width: 240px
}

.fui-alert-success {
	border: 1px solid #00779b
}

#alert-success {
	display: none
}

#alert-success.show {
	display: block
}

.filters {
	padding: 28px 28px 34px;
	margin: 0 0 50px;
	background: #ebf3f0;
	display: grid;
	grid-template-columns: 1fr 250px;
	grid-gap: 25px;
	font-family: "Roboto", sans-serif
}

@media(max-width: 768px) {
	.filters {
		padding: 0;
		background: none;
		grid-template-columns: 1.5fr 1fr;
		grid-gap: 12px
	}
}

.filters.no-select {
	grid-template-columns: 1fr
}

.filters .search-filter {
	width: 100%
}

.filters label {
	display: block;
	color: #4e5853;
	font-size: .875rem;
	font-weight: 500;
	line-height: 1rem;
	letter-spacing: 1px;
	margin-bottom: .5rem;
	text-transform: uppercase
}

.filters input[type=text],
.filters input[type=search] {
	box-sizing: border-box;
	width: 100%;
	display: block;
	padding: 0 20px 0 42px;
	margin: 0;
	height: 50px;
	background: #f4f9f7 url("../svgs/icon-search.svg") no-repeat;
	background-position: 15px 15px;
	border: 1px solid rgba(0, 0, 0, 0);
	border-radius: 2px;
	font-size: 1em;
	font-family: "Roboto", sans-serif;
	transition: all .2s ease-out
}

@media(max-width: 768px) {

	.filters input[type=text],
	.filters input[type=search] {
		border: 1px solid #cbdbd4
	}
}

.filters input[type=text]::placeholder,
.filters input[type=search]::placeholder {
	color: #99a6a0
}

.filters input[type=text]:focus,
.filters input[type=text]:active,
.filters input[type=search]:focus,
.filters input[type=search]:active {
	outline: none;
	background: #f4f9f7 url("../svgs/icon-search.svg") no-repeat;
	background-position: 15px 15px;
	border: 1px solid #0199c7;
	box-shadow: 0px 1px 3px rgba(0, 0, 0, .05), 0px 3px 15px rgba(0, 0, 0, .04)
}

.filters .category-filter {
	width: 100%
}

.filters select {
	box-sizing: border-box;
	width: 100%;
	display: block;
	height: 50px;
	margin: 0;
	padding: 0 20px;
	font-size: 1em;
	font-family: "Roboto", sans-serif;
	-webkit-appearance: none;
	-moz-appearance: none;
	background: #ebf3f0 url("../svgs/icon-down.svg") no-repeat;
	background-position: calc(100% - 13px) 50%;
	border: 1px solid #cbdbd4;
	border-radius: 2px;
	box-shadow: 0px 1px 2px rgba(0, 0, 0, .03), 0px 1px 8px rgba(0, 0, 0, .02);
	color: #202623
}

.filters select:focus,
.filters select:active {
	outline: none;
	border: 1px solid #0199c7;
	background: #ebf3f0 url("../svgs/icon-down.svg") no-repeat;
	background-position: calc(100% - 13px) 50%
}

.modal-form {
	box-shadow: none;
	border: 1px solid #e2ece8;
	margin: 0
}

.modal-form a.download-icon {
	display: inline-flex;
	align-content: center;
	gap: 4px
}

.modal-form a.download-icon svg {
	height: 20px;
	width: auto
}

.modal {
	background-color: rgba(32, 38, 35, .85);
	width: 100vw;
	height: 100vh;
	position: fixed;
	top: 0;
	left: 0;
	opacity: 0;
	visibility: hidden;
	z-index: 1000;
	display: flex;
	justify-content: center;
	align-items: center
}

.modal-content {
	width: 1000px;
	height: auto;
	max-height: 95vh;
	background-color: #f4f9f7;
	box-shadow: 0px 3px 4px rgba(0, 0, 0, .12), 0px 9px 33px -1px rgba(0, 0, 0, .1), 0px 12px 42px -8px rgba(0, 0, 0, .15);
	opacity: 0;
	visibility: hidden;
	overflow-x: hidden;
	overflow-y: auto;
	position: relative;
	box-sizing: border-box;
	padding: 50px
}

@media(max-width: 768px) {
	.modal-content {
		width: 90vw;
		height: auto;
		max-height: 90vh;
		padding: 25px
	}
}

.modal-content picture {
	position: relative;
	height: 100%;
	max-height: none
}

.modal-content picture .photo-details {
	position: absolute;
	background: rgba(0, 0, 0, .67);
	bottom: 0;
	padding: 15px
}

.modal-content picture .photo-details p {
	color: #fff;
	font-size: 14px;
	line-height: 19px;
	margin: 0
}

.modal:target {
	opacity: 1;
	visibility: visible
}

.modal:target .modal-content {
	opacity: 1;
	visibility: visible;
	-webkit-overflow-scrolling: touch;
	opacity: 0;
	animation: fadein .4s linear;
	animation-fill-mode: forwards
}

.modal-close {
	position: fixed;
	z-index: 1;
	transition: all .2s ease-in;
	background: #77a600 !important;
	border-radius: 36px;
	top: 20px;
	right: 20px;
	border: 2px solid #fff
}

.modal-close svg {
	width: 26px;
	height: 22px;
	z-index: 2;
	position: relative;
	padding: 15px;
	transform: translateY(1px)
}

.modal-close svg path {
	fill: #fff;
	transition: .2s ease-in
}

.modal-close:hover {
	background: #87b01e !important
}

@keyframes fadein {
	from {
		opacity: 0
	}

	to {
		opacity: 1
	}
}

section.tabs-container {
	background: #ebf3f0;
	display: grid;
	grid-template-columns: 1fr 1200px 1fr;
	padding: 25px 0;
	border-bottom: 1px solid #e2ece8
}

@media(max-width: 1280px) {
	section.tabs-container {
		grid-template-columns: 6vw 1fr 6vw
	}
}

@media(max-width: 768px) {
	section.tabs-container {
		grid-template-columns: 5vw 1fr 5vw
	}
}

section.tabs-container .tabs {
	grid-column: 2/span 1;
	display: flex;
	align-items: center;
	gap: 12px
}

@media(max-width: 768px) {
	section.tabs-container .tabs {
		padding-top: 32px
	}
}

@media(max-width: 576px) {
	section.tabs-container .tabs {
		flex-flow: column
	}
}

section.tabs-container .tabs p {
	margin: 0
}

section.tabs-container .tabs a {
	display: inline-block;
	background: #e2ece8;
	border: 1px solid #d8e3df;
	border-radius: 100px;
	padding: 2px 12px;
	color: #4e5853
}

section.tabs-container .tabs a:hover {
	border: 1px solid #202623;
	color: #202623
}

.section-intro {
	max-width: 780px;
	margin: 0 auto;
	padding: 0 6vw;
	text-align: center
}

@media(max-width: 1024px) {
	.section-intro {
		padding: 0 5vw
	}
}

section.feature-block {
	background: #02556e;
	position: relative;
	overflow: hidden
}

section.feature-block .watermark {
	position: absolute;
	top: 20px;
	left: calc(50vw - 350px);
	pointer-events: none;
	z-index: 0
}

@media(max-width: 768px) {
	section.feature-block .watermark {
		left: -5vw
	}
}

section.feature-block .watermark svg {
	width: 300px;
	height: auto
}

section.feature-block .watermark svg path {
	fill: #0b5d75
}

section.feature-block .container {
	display: grid;
	grid-template-columns: 1fr 1fr;
	align-items: center;
	position: relative;
	padding: 100px 0
}

@media(max-width: 768px) {
	section.feature-block .container {
		grid-template-columns: 1fr
	}
}

section.feature-block .container .feature-text {
	padding: 0 80px 0 0
}

section.feature-block .container .feature-text h2 {
	color: #fff
}

section.feature-block .container .feature-text h2 span {
	color: #deeeb5
}

section.feature-block .container .feature-text .overline {
	color: #cfe98d
}

section.feature-block .container .feature-text p {
	color: #fff
}

@media(max-width: 768px) {
	section.feature-block .container .feature-text {
		padding: 0 0 50px 0
	}
}

section.feature-block .container .image-collage {
	width: 100%;
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	grid-template-rows: 1fr 1fr;
	grid-gap: 1px
}

section.feature-block .container .image-collage picture {
	width: 100%;
	height: 100%;
	display: flex;
	overflow: hidden
}

section.feature-block .container .image-collage picture img {
	width: 100%;
	object-fit: cover;
	max-height: 200px
}

section.feature-block .container .image-collage picture:nth-child(1) {
	grid-column: 1/span 1;
	grid-row: 1/span 1
}

section.feature-block .container .image-collage picture:nth-child(2) {
	grid-column: 2/span 2;
	grid-row: 1/span 1
}

section.feature-block .container .image-collage picture:nth-child(3) {
	grid-column: 1/span 2;
	grid-row: 2/span 1
}

section.feature-block .container .image-collage picture:nth-child(4) {
	grid-column: 3/span 1;
	grid-row: 2/span 1
}

section.services {
	margin: 25px 25px 25px
}

section.services .service-grid {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	grid-gap: 1px
}

@media(max-width: 1024px) {
	section.services .service-grid {
		grid-template-columns: 1fr
	}
}

section.services .service-grid a {
	position: relative;
	height: 100%
}

section.services .service-grid a * {
	transition: .2s ease-in-out
}

section.services .service-grid a .screen {
	opacity: .75;
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	background: linear-gradient(to bottom, rgba(0, 58, 77, 0.2), rgba(32, 38, 35, 0.8))
}

section.services .service-grid a picture {
	width: 100%;
	height: 100%;
	display: flex;
	overflow: hidden;
	height: 428px
}

@media(max-width: 576px) {
	section.services .service-grid a picture {
		height: 400px
	}
}

@media(max-width: 400px) {
	section.services .service-grid a picture {
		height: 360px
	}
}

section.services .service-grid a picture img {
	width: 100%;
	height: auto;
	object-fit: cover
}

section.services .service-grid a .service-content {
	position: absolute;
	bottom: 0;
	width: calc(100% - 0px);
	background: rgba(0, 58, 77, .2);
	backdrop-filter: blur(5px);
	align-items: center;
	margin: 0;
	z-index: 1
}

section.services .service-grid a .service-content .service-headline {
	display: grid;
	grid-template-columns: 1fr 50px;
	grid-gap: 15px;
	align-items: center;
	border-bottom: 1px solid hsla(0, 0%, 100%, .1);
	padding: 12px 24px
}

@media(max-width: 1280px) {
	section.services .service-grid a .service-content .service-headline {
		grid-template-columns: 1fr;
		grid-template-rows: 50px auto;
		text-align: center;
		grid-gap: 10px
	}
}

section.services .service-grid a .service-content .service-headline .icon {
	background: #ebf3f0;
	width: 50px;
	height: 50px;
	display: block;
	border-radius: 60px;
	display: grid;
	place-content: center;
	transition: .2s ease
}

@media(max-width: 1280px) {
	section.services .service-grid a .service-content .service-headline .icon {
		order: 1;
		margin: 0 auto
	}
}

section.services .service-grid a .service-content .service-headline .icon svg {
	height: 32px;
	width: auto
}

section.services .service-grid a .service-content .service-headline .icon svg path {
	fill: #202623;
	transition: .2s ease
}

section.services .service-grid a .service-content .service-headline h3 {
	color: #fff;
	margin: 0
}

@media(max-width: 1280px) {
	section.services .service-grid a .service-content .service-headline h3 {
		order: 2
	}
}

section.services .service-grid a .service-content p {
	color: #fff;
	padding: 16px 24px 25px;
	margin: 0
}

@media(max-width: 1280px) {
	section.services .service-grid a .service-content p {
		text-align: center
	}
}

section.services .service-grid a:hover .screen {
	opacity: 1
}

section.services .service-grid a:hover .service-content .service-headline {
	background: rgba(0, 138, 180, .05);
	backdrop-filter: blur(5px)
}

section.quotes {
	padding: 75px 0;
	background: #ebf3f0;
	text-align: center;
	position: relative;
	overflow: hidden
}

section.quotes .watermark {
	position: absolute;
	top: 25px;
	left: -75px
}

section.quotes .watermark svg {
	width: auto;
	height: 450px;
	opacity: .4
}

section.quotes .quote {
	margin: 0 auto;
	max-width: 780px;
	position: relative;
	z-index: 1;
	background: none;
	padding: 50px 0
}

section.quotes .quote .quotemark {
	background: #e2ece8;
	border: 1px solid #d8e3df
}

section.quotes .quote .quotemark svg {
	width: auto;
	height: 44px;
	transform: translate(1px, 2px)
}

section.quotes .quote .quotemark svg path {
	fill: #02556e
}

section.quotes .quote span {
	margin: 0 0 20px
}

section.quotes .quote p {
	color: #02556e
}

section.quotes .quote p.xl {
	margin: 0 0 1.25em
}

section.quotes .quote p.small {
	margin: 0
}

section.news {
	padding: 100px 0 125px
}

@media(max-width: 1280px) {
	section.news {
		padding: 75px 0 75px
	}
}

section.news .news-blocks {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-gap: 50px;
	padding: 25px 0 0;
	align-items: start
}

@media(max-width: 1280px) {
	section.news .news-blocks {
		grid-gap: 25px
	}
}

@media(max-width: 400px) {
	section.news .news-blocks {
		grid-gap: 12px
	}
}

section.news .news-blocks a.news-block {
	display: grid;
	grid-template-columns: 200px 1fr;
	grid-gap: 20px;
	align-items: center
}

@media(max-width: 1280px) {
	section.news .news-blocks a.news-block {
		grid-template-columns: 1fr;
		grid-template-rows: 1fr auto;
		grid-gap: 20px;
		margin: 0
	}
}

section.news .news-blocks a.news-block picture {
	width: 100%;
	height: 100%;
	display: flex;
	overflow: hidden
}

section.news .news-blocks a.news-block picture img {
	width: 100%;
	object-fit: cover;
	height: 200px
}

@media(max-width: 1280px) {
	section.news .news-blocks a.news-block picture img {
		height: 300px
	}
}

@media(max-width: 1024px) {
	section.news .news-blocks a.news-block picture img {
		height: 200px
	}
}

@media(max-width: 576px) {
	section.news .news-blocks a.news-block picture img {
		height: 150px
	}
}

section.news .news-blocks a.news-block .news-text span {
	margin: 0 0 15px
}

section.news .news-blocks a.news-block .news-text h4 {
	transition: .2s ease
}

section.news .news-blocks a.news-block .news-text .date {
	display: block;
	font-size: .8125rem;
	color: #4e5853;
	text-transform: uppercase;
	margin: 10px 0 12px;
	letter-spacing: .5px
}

section.news .news-blocks a.news-block:hover h4 {
	color: #719e00
}

article.article {
	display: grid;
	grid-template-columns: 1fr 1200px 1fr;
	position: relative;
	margin: 0 0 100px
}

@media(max-width: 1280px) {
	article.article {
		grid-template-columns: 6vw 1fr 6vw
	}
}

@media(max-width: 768px) {
	article.article {
		grid-template-columns: 5vw 1fr 5vw;
		margin: 0 0 50px
	}
}

article.article aside.share {
	position: absolute;
	width: 150px;
	left: calc(50vw - 600px);
	top: 50px
}

article.article aside.share.push-down {
	top: 39vw
}

@media(max-width: 1280px) {
	article.article aside.share {
		display: none
	}
}

article.article aside.share .overline {
	margin: 0 0 20px
}

article.article aside.subscribe {
	position: absolute;
	width: 150px;
	top: 50px;
	right: calc(50vw - 600px)
}

article.article aside.subscribe.push-down {
	top: 39vw
}

@media(max-width: 1280px) {
	article.article aside.subscribe {
		display: none
	}
}

article.article .article-banner-wide {
	grid-column: 1/span 3
}

article.article .article-banner-wide picture img {
	width: 100%
}

article.article .article-banner {
	grid-column: 2/span 1;
	margin: 0 auto;
	height: 50vw;
	width: 100%;
	max-width: 780px
}

@media(min-width: 1024px) {
	article.article .article-banner {
		height: 440px
	}
}

article.article .article-banner picture {
	position: relative;
	width: 100%;
	height: 100%;
	overflow: hidden
}

article.article .article-banner picture img {
	width: 100%;
	height: 100%;
	object-fit: cover
}

article.article .article-content {
	grid-column: 2/span 1
}

article.article .article-content .text-block {
	border: 1px solid #d8e3df;
	background: #ebf3f0;
	padding: 25px 25px 0;
	margin: 0 0 32px
}

@media(max-width: 768px) {
	article.article .article-content .text-block {
		padding: 20px 20px 0
	}
}

article.article .article-content .text-block h4 {
	font-size: 19px
}

@media(max-width: 768px) {
	article.article .article-content .text-block h4 {
		font-size: 17px
	}
}

article.article .article-content .white-paper-label {
	width: 780px;
	margin: 0 auto -40px auto;
	padding: 50px 0 0;
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-content: center;
	grid-column-gap: 18px
}

@media(max-width: 1024px) {
	article.article .article-content .white-paper-label {
		width: 100%;
		margin: 0 auto -35px auto
	}
}

article.article .article-content .white-paper-label span.line {
	height: 1px;
	align-self: center;
	display: block;
	width: 100%;
	background: #003a4d
}

article.article .article-content .white-paper-label span.overline {
	margin: 0;
	color: #003a4d;
	letter-spacing: 5px
}

article.article .article-content figure {
	margin: 0;
	text-align: center
}

article.article .article-content figure img {
	max-width: 100%;
	height: auto
}

article.article .article-content figcaption {
	font-size: 13px !important;
	line-height: 1.2;
	padding: 0 0 12px;
	border-bottom: 1px solid #e2ece8
}

article.article .article-content figure.image-style-side {
	width: 275px;
	float: right;
	margin: .375em 0 1.5em 2em
}

article.article .article-content figure.image-style-side img {
	width: 100%;
	height: auto
}

@media(max-width: 576px) {
	article.article .article-content figure.image-style-side {
		width: 100%;
		float: none;
		max-width: 100%;
		margin: 2em 0
	}

	article.article .article-content figure.image-style-side img {
		width: 100%
	}
}

article.article .article-content figure.left {
	width: 275px;
	float: left;
	margin: .375em 2em 2em 0
}

@media(max-width: 576px) {
	article.article .article-content figure.left {
		width: 100%;
		float: none;
		max-width: 100%;
		margin: 2em 0
	}

	article.article .article-content figure.left img {
		width: 100%
	}
}

article.article .article-content figure.center {
	width: 100%;
	margin: 0 auto 2em auto
}

@media(max-width: 576px) {
	article.article .article-content figure.center {
		width: 100%;
		float: none;
		max-width: 100%;
		margin: 2em 0
	}

	article.article .article-content figure.center img {
		width: 100%
	}
}

article.article .article-content .caption.full {
	margin: 0 auto !important
}

article.article .article-content ul ul {
	margin: 10px 0 0
}

button.sharer {
	background: #ebf3f0;
	border: 1px solid #d8e3df;
	border-radius: 100px;
	width: 36px;
	height: 36px;
	margin: 0 0 12px;
	transition: all .2s ease-out;
	padding: 0;
	display: block
}

button.sharer span.icon {
	width: 100%;
	height: 100%;
	display: grid;
	place-content: center
}

button.sharer span.icon svg {
	width: auto;
	height: 16px;
	max-width: 16px
}

button.sharer span.icon svg path {
	fill: #202623
}

button.sharer:hover {
	border: 1px solid #04a5d6;
	cursor: pointer
}

button.sharer:hover svg path {
	fill: #04a5d6
}

button.sharer .visuallyhidden {
	opacity: 0;
	visibility: hidden
}

section.campaign-content {
	max-width: 1200px;
	margin: 75px auto;
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-gap: 100px;
	padding: 0 6vw
}

@media(max-width: 1024px) {
	section.campaign-content {
		margin: 50px auto;
		padding: 0 5vw;
		grid-template-columns: 1fr;
		grid-gap: 50px
	}
}

section.campaign-content .form {
	margin: -200px 0 0;
	position: relative
}

@media(max-width: 1024px) {
	section.campaign-content .form {
		margin: -90px 0 0;
		order: 1;
		z-index: 2;
		text-align: center
	}
}

section.campaign-content .text {
	padding-right: 25px
}

@media(max-width: 1024px) {
	section.campaign-content .text {
		order: 2;
		padding: 0
	}
}

main.content {
	display: grid;
	grid-template-columns: 1fr 1200px 1fr;
	padding: 0 0 0px 0
}

@media(max-width: 1280px) {
	main.content {
		grid-template-columns: 6vw 1fr 6vw
	}
}

@media(max-width: 768px) {
	main.content {
		grid-template-columns: 5vw 1fr 5vw;
		padding: 0 0 100px 0
	}
}

main.content>div,
main.content hr {
	grid-column: 2/span 1
}

main.content>div.image-text-hr,
main.content hr.image-text-hr {
	margin: 25px 0 0
}

main.content section {
/*	grid-column: 1/span 1*/
}

.article-intro {
	width: 780px;
	margin: 0 auto;
	padding: 50px 0 0;
	margin-bottom: -50px
}

.article-intro p {
	font-size: 1.5rem;
	line-height: 1.5;
	color: #202623
}

@media(max-width: 1024px) {
	.article-intro {
		width: 100%
	}
}

.richtext {
	width: 780px;
	margin: 0 auto;
	padding: 50px 0 0
}

.richtext.expand {
	width: 1200px
}

@media(max-width: 1280px) {
	.richtext.expand {
		width: 100%
	}
}

@media(max-width: 1024px) {
	.richtext {
		width: 100%
	}
}

.richtext.reduce-top-margin {
	padding: 25px 0 0
}

.richtext.twoCol .columns {
	display: grid;
/*	grid-template-columns: 1fr 1fr;*/
	grid-gap: 40px
}

@media(max-width: 576px) {
	.richtext.twoCol .columns {
		grid-template-columns: 1fr;
		grid-gap: 0
	}
}

.richtext.twoCol figure {
	margin: 0 0 25px
}

.richtext figure {
	margin: 0
}

.richtext figure img {
	max-width: 100%
}

.richtext figcaption {
	font-size: 13px;
	line-height: 1.2;
	padding: 0 0 12px;
	border-bottom: 1px solid #e2ece8
}

.richtext figure.right {
	width: 275px;
	float: right;
	margin: .375em 0 1.5em 2em
}

@media(max-width: 576px) {
	.richtext figure.right {
		width: 100%;
		float: none;
		max-width: 100%;
		margin: 2em 0
	}

	.richtext figure.right img {
		width: 100%
	}
}

.richtext figure.left {
	width: 275px;
	float: left;
	margin: .375em 2em 2em 0
}

@media(max-width: 576px) {
	.richtext figure.left {
		width: 100%;
		float: none;
		max-width: 100%;
		margin: 2em 0
	}

	.richtext figure.left img {
		width: 100%
	}
}

.richtext figure.center {
	width: 100%;
	margin: 0 auto 2em auto
}

@media(max-width: 576px) {
	.richtext figure.center {
		width: 100%;
		float: none;
		max-width: 100%;
		margin: 2em 0
	}

	.richtext figure.center img {
		width: 100%
	}
}

.richtext .caption.full {
	margin: 0 auto !important
}

.image-block {
	padding: 80px 0 0;
	display: grid;
	grid-template-columns: 1fr 1fr;
	align-items: center;
	grid-column-gap: 75px
}

.image-block.top-align {
	align-items: start
}

@media(min-width: 768px) {
	.image-block.two-rows {
		align-items: start;
		grid-template-rows: auto auto
	}

	.image-block.two-rows h2 {
		grid-row: 1/span 1
	}

	.image-block.two-rows .image,
	.image-block.two-rows .text {
		grid-row: 2/span 1
	}
}

@media(max-width: 768px) {
	.image-block {
		grid-template-columns: 1fr;
		grid-gap: 0;
		padding: 50px 0 0
	}
}

.image-block hr {
	margin: 25px 0
}

.image-block .image {
	position: relative;
	overflow: visible
}

@media(max-width: 768px) {
	.image-block .image {
		margin: 0 0 25px
	}
}

.image-block .image picture.second-img img {
	transform: translate(200px, -75px);
	width: 250px;
	height: 250px
}

@media(max-width: 1280px) {
	.image-block .image picture.second-img img {
		transform: translate(200px, -75px);
		max-width: 200px;
		height: 200px
	}
}

@media(max-width: 768px) {
	.image-block .image picture.second-img {
		display: none
	}
}

.image-block .text .it-buttons {
	display: inline-flex;
	gap: 8px;
	text-align: center;
	margin-bottom: 40px
}

@media(max-width: 1024px) {
	.image-block .text .it-buttons {
		flex-direction: column
	}
}

@media(min-width: 768px) {
	.image-block.reverse .image {
		order: 2
	}

	.image-block.reverse .text {
		order: 1
	}
}

.video-block {
	padding: 80px 0 0
}

@media(max-width: 768px) {
	.video-block {
		padding: 50px 0 0
	}
}

.callout {
	margin: 80px 0 0;
	padding: 50px 50px;
	text-align: center;
	background: #ebf3e1
}

.callout * {
	max-width: 780px;
	margin-left: auto;
	margin-right: auto
}

@media(max-width: 768px) {
	.callout {
		margin: 50px 0 0
	}
}

.callout .buttons a:nth-child(2) {
	margin: 0 0 0 6px
}

@media(max-width: 576px) {
	.callout .buttons {
		display: flex;
		flex-flow: column
	}

	.callout .buttons a:nth-child(2) {
		margin: 6px 0 0 0
	}
}

section.monitor-cards {
	margin: 80px 0 0;
	padding: 100px 0;
	text-align: center;
	background: #ebf3f0
}

@media(max-width: 1280px) {
	section.monitor-cards {
		padding: 100px 6vw
	}
}

@media(max-width: 768px) {
	section.monitor-cards {
		padding: 50px 5vw
	}
}

section.monitor-cards .m-intro {
	max-width: 780px;
	margin-left: auto;
	margin-right: auto
}

@media(max-width: 768px) {
	section.monitor-cards {
		margin: 50px 0 0
	}
}

section.monitor-cards .m-cards {
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	grid-gap: 16px
}

@media(max-width: 1024px) {
	section.monitor-cards .m-cards {
		grid-template-columns: repeat(3, 1fr)
	}
}

@media(max-width: 576px) {
	section.monitor-cards .m-cards {
		grid-template-columns: repeat(2, 1fr);
		grid-gap: 8px
	}
}

section.monitor-cards .m-cards a {
	background: #f4f9f7
}

.white-paper {
	width: 780px;
	box-sizing: border-box;
	margin: 0 auto;
	padding: 50px 50px;
	background: #deeeb5;
	text-align: center
}

@media(max-width: 1024px) {
	.white-paper {
		width: 100%
	}
}

.quote {
	margin: 80px 0 0;
	padding: 50px 50px;
	text-align: center;
	background: #ecf8cd
}

.quote * {
	max-width: 780px;
	margin-left: auto;
	margin-right: auto
}

.quote .quotemark {
	background: #deeeb5;
	width: 62px;
	height: 62px;
	display: block;
	border-radius: 100px;
	display: grid;
	place-content: center;
	margin-bottom: 24px
}

.quote .quotemark svg {
	width: auto;
	height: 44px;
	transform: translate(1px, 2px)
}

.quote .quotemark.info svg {
	width: auto;
	height: 42px;
	transform: translate(0px, 0px)
}

.quote .quotemark.info svg path {
	fill: #77a600
}

.quote .overline {
	color: rgba(32, 38, 35, .8)
}

@media(max-width: 768px) {
	.quote {
		margin: 50px 0 0
	}
}

.form-block {
	margin: 80px 0 0
}

.form-block .side-content figure {
	margin: 0
}

@media(max-width: 768px) {
	.form-block {
		margin: 50px 0 0
	}
}

.form-block.split {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-gap: 75px
}

@media(max-width: 768px) {
	.form-block.split {
		grid-template-columns: 1fr;
		grid-gap: 25px
	}
}

.form-block .form {
	max-width: 872px;
	margin: 0 auto
}

main.team-listing {
	max-width: 1200px;
	margin: 50px auto 100px;
	padding: 0 6vw
}

@media(max-width: 768px) {
	main.team-listing {
		padding: 0 6vw
	}
}

main.team-listing section.team-grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	grid-gap: 10px
}

@media(max-width: 1280px) {
	main.team-listing section.team-grid {
		grid-template-columns: repeat(4, 1fr)
	}
}

@media(max-width: 1024px) {
	main.team-listing section.team-grid {
		grid-template-columns: repeat(3, 1fr)
	}
}

@media(max-width: 576px) {
	main.team-listing section.team-grid {
		grid-template-columns: repeat(2, 1fr)
	}
}

main.team-listing section.team-grid.spacing {
	margin: 0 0 40px;
	padding: 0 0 60px;
	border-bottom: 1px solid #d8e3df
}

main.team-listing section.team-grid a.team-block {
	background: #ebf3f0;
	transition: .3s ease
}

main.team-listing section.team-grid a.team-block img {
	filter: grayscale(5%)
}

main.team-listing section.team-grid a.team-block .staff-details {
	padding: 16px 18px;
	position: relative
}

@media(max-width: 576px) {
	main.team-listing section.team-grid a.team-block .staff-details {
		padding: 12px 14px
	}
}

main.team-listing section.team-grid a.team-block .staff-details h4 {
	margin: 0 0 5px
}

main.team-listing section.team-grid a.team-block .staff-details p {
	margin: 0
}

main.team-listing section.team-grid a.team-block .staff-details .departments {
	border-top: 1px solid #d8e3df;
	margin: 15px 0 0;
	padding: 15px 0 0
}

main.team-listing section.team-grid a.team-block .staff-details .departments span.chip {
	display: inline-block;
	color: #7d8984;
	font-weight: 400;
	font-size: 13px;
	background: #e2ece8;
	padding: 5px 12px;
	border-radius: 100px;
	margin: 0 0 4px;
	transition: .3s ease
}

main.team-listing section.team-grid a.team-block:hover {
	background: #fff;
	box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, .08), 0px 2px 20px -2px rgba(0, 0, 0, .04), 0px 7px 33px -3px rgba(0, 0, 0, .07);
	z-index: 2
}

main.team-listing section.team-grid a.team-block:hover img {
	filter: grayscale(90%)
}

main.team-listing section.team-grid a.team-block:hover .staff-details h4 {
	color: #003a4d
}

main.team-listing section.team-grid a.team-block:hover .staff-details p {
	color: #003a4d
}

main.team-listing section.team-grid a.team-block:hover .staff-details .departments span.chip {
	color: #003a4d;
	background: #f4f9f7
}

main.bio {
	display: grid;
	grid-template-columns: 1fr 1200px 1fr;
	padding: 0 0 100px 0
}

@media(max-width: 1280px) {
	main.bio {
		grid-template-columns: 6vw 1fr 6vw
	}
}

@media(max-width: 768px) {
	main.bio {
		grid-template-columns: 5vw 1fr 5vw;
		padding: 0 0 50px 0
	}
}

main.bio>div,
main.bio hr {
	grid-column: 2/span 1
}

main.bio .bio-masthead {
	background: #ebf3f0;
	grid-column: 1/span 3;
	padding: 75px 0 50px
}

@media(max-width: 768px) {
	main.bio .bio-masthead {
		padding: 50px 0 50px;
		text-align: center
	}
}

main.bio .bio-masthead .bio-title {
	position: relative;
	left: calc(50vw - 600px);
	max-width: 700px
}

@media(max-width: 1280px) {
	main.bio .bio-masthead .bio-title {
		left: 6vw
	}
}

@media(max-width: 768px) {
	main.bio .bio-masthead .bio-title {
		left: 0;
		padding: 0 5vw
	}
}

main.bio .bio-masthead .bio-title .overline {
	color: #003a4d
}

main.bio .bio-masthead .bio-title .overline a {
	color: #003a4d
}

main.bio .bio-masthead .bio-title .overline a:hover {
	color: #77a600
}

main.bio .bio-masthead .bio-title h1 {
	margin: 0 0 10px
}

main.bio .bio-masthead .bio-title h3 {
	color: #003a4d
}

main.bio .bio-content {
	margin: 50px 0 0;
	display: grid;
	grid-template-columns: 1fr 400px;
	grid-gap: 100px
}

@media(max-width: 1280px) {
	main.bio .bio-content {
		grid-template-columns: 1fr 300px;
		grid-gap: 50px
	}
}

@media(max-width: 1024px) {
	main.bio .bio-content {
		grid-template-columns: 1fr 220px
	}
}

@media(max-width: 768px) {
	main.bio .bio-content {
		grid-template-columns: 1fr;
		grid-gap: 25px
	}
}

@media(max-width: 768px) {
	main.bio .bio-content .bio-text {
		order: 2
	}
}

main.bio .bio-content .bio-image {
	margin-top: -140px
}

@media(max-width: 1280px) {
	main.bio .bio-content .bio-image {
		margin-top: 0
	}
}

@media(max-width: 768px) {
	main.bio .bio-content .bio-image {
		order: 1;
		margin-top: -75px
	}
}

main.bio .bio-content .bio-image img {
	width: 100%
}

.jobs {
	width: 1200px;
	margin: 75px auto -25px
}

@media(max-width: 1280px) {
	.jobs {
		width: 100%
	}
}

.jobs p.no-jobs {
	margin: 0
}

.jobs .job-grid {
	box-sizing: border-box;
	background: #ebf3f0;
	padding: 25px 0 5px
}

.jobs .job-grid .grid-header {
	display: grid;
	grid-template-columns: 3fr 2fr 1fr;
	grid-column-gap: 15px;
	padding: 0 25px
}

@media(max-width: 576px) {
	.jobs .job-grid .grid-header {
		grid-template-columns: 4fr 1fr
	}

	.jobs .job-grid .grid-header .hide-mobile {
		display: none
	}
}

.jobs .job-grid .grid-header .overline {
	color: #719e00
}

@media(max-width: 576px) {
	.jobs .job-grid .grid-header .overline {
		font-size: .75em
	}
}

.jobs .job-grid a.job {
	display: grid;
	grid-template-columns: 3fr 2fr 1fr;
	grid-column-gap: 15px;
	padding: 16px 25px;
	border-top: 1px solid #d8e3df
}

@media(max-width: 576px) {
	.jobs .job-grid a.job {
		grid-template-columns: 4fr 1fr
	}
}

.jobs .job-grid a.job h4 {
	font-size: 1.125rem;
	margin: 0
}

@media(max-width: 576px) {
	.jobs .job-grid a.job h4 {
		font-size: 1rem
	}
}

.jobs .job-grid a.job span.date {
	color: #7d8984
}

@media(max-width: 576px) {
	.jobs .job-grid a.job span.date {
		font-size: 12px
	}
}

.jobs .job-grid a.job .locations span.chip {
	display: inline-block;
	color: #7d8984;
	font-weight: 400;
	font-size: 13px;
	background: #e2ece8;
	padding: 5px 12px;
	border-radius: 100px;
	transition: .3s ease
}

@media(max-width: 576px) {
	.jobs .job-grid a.job .locations {
		display: none
	}
}

.jobs .job-grid a.job:hover {
	background: #f4f9f7;
	box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, .08), 0px 2px 20px -2px rgba(0, 0, 0, .04), 0px 7px 33px -3px rgba(0, 0, 0, .07)
}

.jobs .job-grid a.job:hover span.date,
.jobs .job-grid a.job:hover span.chip,
.jobs .job-grid a.job:hover h4 {
	color: #02556e
}

.jobs .job-grid a.job:hover span.chip {
	background: #ebf3f0
}

main.job-desc {
	padding: 50px 0
}

main.job-desc p.small {
	display: inline-block;
	margin: 0 5px 0
}

main.job-desc .locations {
	padding: 0 0 25px
}

main.job-desc .locations span.chip {
	display: inline-block;
	color: #7d8984;
	font-weight: 400;
	font-size: 13px;
	background: #e2ece8;
	padding: 5px 12px;
	border-radius: 100px;
	transition: .3s ease
}

main.insight-listing {
	max-width: 1200px;
	margin: 50px auto 100px;
	padding: 0 6vw
}

@media(max-width: 768px) {
	main.insight-listing {
		padding: 0 6vw;
		margin: 50px auto 50px
	}
}

main.insight-listing section#post-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	grid-gap: 16px
}

@media(max-width: 1024px) {
	main.insight-listing section#post-grid {
		grid-template-columns: repeat(3, 1fr)
	}
}

@media(max-width: 576px) {
	main.insight-listing section#post-grid {
		grid-template-columns: repeat(2, 1fr);
		grid-gap: 8px
	}
}

a.post-block {
	background: #ebf3f0;
	transition: .3s ease;
	position: relative;
	padding-bottom: 50px
}

a.post-block picture {
	position: relative;
	width: 100%;
	height: 100%;
	overflow: hidden
}

a.post-block img {
	filter: grayscale(5%);
	width: 100%;
	height: 240px;
	object-fit: cover;
	display: block
}

@media(max-width: 1024px) {
	a.post-block img {
		height: 200px
	}
}

@media(max-width: 1024px) {
	a.post-block img {
		height: 150px
	}
}

a.post-block .white-paper-tag {
	position: absolute;
	left: 0;
	top: -25px;
	height: 25px;
	width: 100%;
	display: flex;
	align-items: center;
	background: rgba(2, 85, 110, .5)
}

@media(max-width: 1024px) {
	a.post-block .white-paper-tag {
		top: -24px;
		height: 24px
	}
}

a.post-block .white-paper-tag span {
	width: 100%;
	text-align: center;
	color: #fff;
	font-size: .875rem;
	font-weight: 500;
	line-height: 1rem;
	letter-spacing: 1px;
	text-transform: uppercase
}

@media(max-width: 1024px) {
	a.post-block .white-paper-tag span {
		font-size: .75rem
	}
}

a.post-block .post-details {
	padding: 16px 18px;
	position: relative
}

@media(max-width: 576px) {
	a.post-block .post-details {
		padding: 12px 14px
	}
}

a.post-block .post-details .topic {
	display: block;
	font-size: .8125rem;
	color: #4e5853;
	text-transform: uppercase;
	margin: 0 0 10px;
	letter-spacing: .5px
}

a.post-block .post-details .date {
	display: block;
	font-size: .8125rem;
	color: #4e5853;
	text-transform: uppercase;
	margin: 10px 0 12px;
	letter-spacing: .5px
}

a.post-block .post-details h4 {
	margin: 0 0 10px
}

a.post-block .post-details p {
	margin: 0
}

@media(max-width: 768px) {
	a.post-block .post-details p {
		display: none
	}
}

a.post-block .more {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	gap: 6px;
	border-top: 1px solid #d8e3df;
	position: absolute;
	bottom: 0;
	height: 50px
}

a.post-block .more span.overline {
	color: #202623;
	margin: 0
}

a.post-block .more svg {
	width: auto;
	height: 8px
}

a.post-block .more svg path {
	fill: #202623
}

a.post-block:hover {
	background: #fff;
	box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, .08), 0px 2px 20px -2px rgba(0, 0, 0, .04), 0px 7px 33px -3px rgba(0, 0, 0, .07);
	z-index: 2
}

a.post-block:hover img {
	filter: grayscale(90%)
}

a.post-block:hover .whitepaper-details h4 {
	color: #003a4d
}

a.post-block:hover .whitepaper-details p {
	color: #003a4d
}

main.whitepaper-listing {
	max-width: 1200px;
	margin: 50px auto 100px;
	padding: 0 6vw
}

@media(max-width: 768px) {
	main.whitepaper-listing {
		padding: 0 6vw;
		margin: 50px auto 50px
	}
}

main.whitepaper-listing section {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	grid-gap: 16px
}

@media(max-width: 1024px) {
	main.whitepaper-listing section {
		grid-template-columns: repeat(3, 1fr)
	}
}

@media(max-width: 576px) {
	main.whitepaper-listing section {
		grid-template-columns: repeat(2, 1fr);
		grid-gap: 8px
	}
}

main.whitepaper-listing section a.whitepaper-block {
	background: #ebf3f0;
	transition: .3s ease;
	position: relative;
	padding-bottom: 50px
}

main.whitepaper-listing section a.whitepaper-block img {
	filter: grayscale(5%)
}

main.whitepaper-listing section a.whitepaper-block .whitepaper-details {
	padding: 16px 18px;
	position: relative
}

@media(max-width: 576px) {
	main.whitepaper-listing section a.whitepaper-block .whitepaper-details {
		padding: 12px 14px
	}
}

main.whitepaper-listing section a.whitepaper-block .whitepaper-details h4 {
	margin: 0 0 5px
}

main.whitepaper-listing section a.whitepaper-block .whitepaper-details p {
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden
}

@media(max-width: 768px) {
	main.whitepaper-listing section a.whitepaper-block .whitepaper-details p {
		display: none
	}
}

main.whitepaper-listing section a.whitepaper-block:hover {
	background: #fff;
	box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, .08), 0px 2px 20px -2px rgba(0, 0, 0, .04), 0px 7px 33px -3px rgba(0, 0, 0, .07);
	z-index: 2
}

main.whitepaper-listing section a.whitepaper-block:hover img {
	filter: grayscale(90%)
}

main.whitepaper-listing section a.whitepaper-block:hover .whitepaper-details h4 {
	color: #003a4d
}

main.whitepaper-listing section a.whitepaper-block:hover .whitepaper-details p {
	color: #003a4d
}

.download {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	gap: 6px;
	border-top: 1px solid #d8e3df;
	position: absolute;
	bottom: 0;
	height: 50px
}

.download span.overline {
	color: #202623;
	margin: 0
}

.download svg {
	width: auto;
	height: 24px
}

.download svg path {
	fill: #202623
}

main.monitor {
	display: grid;
	grid-template-columns: 1fr 1200px 1fr;
	padding: 0 0 100px 0
}

@media(max-width: 1280px) {
	main.monitor {
		grid-template-columns: 6vw 1fr 6vw
	}
}

@media(max-width: 768px) {
	main.monitor {
		grid-template-columns: 5vw 1fr 5vw;
		padding: 0 0 50px 0
	}
}

main.monitor>div,
main.monitor hr {
	grid-column: 2/span 1
}

main.monitor .monitor-masthead {
	background: #ecf8cd;
	grid-column: 1/span 3;
	padding: 75px 0 50px
}

@media(max-width: 768px) {
	main.monitor .monitor-masthead {
		padding: 50px 0 50px;
		text-align: center
	}
}

main.monitor .monitor-masthead .monitor-title {
	position: relative;
	left: calc(50vw - 600px);
	max-width: 600px
}

@media(max-width: 1280px) {
	main.monitor .monitor-masthead .monitor-title {
		left: 6vw
	}
}

@media(max-width: 768px) {
	main.monitor .monitor-masthead .monitor-title {
		left: 0;
		padding: 0 5vw
	}
}

main.monitor .monitor-masthead .monitor-title .overline {
	color: #003a4d
}

main.monitor .monitor-masthead .monitor-title .overline a {
	color: #003a4d
}

main.monitor .monitor-masthead .monitor-title .overline a:hover {
	color: #77a600
}

main.monitor .monitor-masthead .monitor-title h1 {
	margin: 0 0 10px
}

main.monitor .monitor-content {
	margin: 50px 0 0;
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-gap: 100px
}

@media(max-width: 1280px) {
	main.monitor .monitor-content {
		grid-template-columns: 1fr 1fr;
		grid-gap: 50px
	}
}

@media(max-width: 768px) {
	main.monitor .monitor-content {
		grid-template-columns: 1fr;
		grid-gap: 25px
	}
}

@media(max-width: 768px) {
	main.monitor .monitor-content .monitor-text {
		order: 2
	}
}

main.monitor .monitor-content .monitor-form {
	margin-top: -140px;
	width: 100%
}

@media(max-width: 1280px) {
	main.monitor .monitor-content .monitor-form {
		margin-top: 0
	}
}

@media(max-width: 768px) {
	main.monitor .monitor-content .monitor-form {
		order: 1;
		margin-top: -75px
	}
}

header#header {
	position: fixed;
	z-index: 100;
	align-items: center;
	display: grid;
	grid-gap: 25px;
	grid-template-columns: auto 1fr;
	border-bottom: 1px solid #ebf3f0;
	background: rgba(244, 249, 247, .9);
	backdrop-filter: blur(7px);
	transition: all .3s ease;
	height: 72px
}

@media(max-width: 1320px) {
	header#header {
		grid-gap: 18px
	}
}

header#header.hide-nav {
	opacity: 0;
	pointer-events: none
}

@media(max-width: 1024px) {
	header#header {
		display: none
	}
}

header#header .logo {
	position: relative
}

@media(max-width: 1320px) {
	header#header .logo {
		margin-right: 0
	}
}

header#header .logo a {
	z-index: 2;
	position: relative
}

header#header .logo a svg {
	width: auto;
	height: 44px
}

header#header .logo a svg path {
	transition: .2s ease
}

header#header .logo a:hover {
	opacity: .8
}

header#header nav {
	display: flex;
	align-items: center;
	justify-self: end;
	margin: 0
}

header#header nav ul {
	padding: 0;
	margin: 0;
	list-style: none;
	position: relative;
	display: flex;
	gap: 40px
}

@media(max-width: 1320px) {
	header#header nav ul {
		gap: 28px
	}
}

header#header nav ul li {
	display: inline-flex;
	align-items: center;
	height: 32px;
	padding: 0;
	margin: 0
}

header#header nav ul li a {
	display: block;
	padding: 0 2px;
	color: #202623
}

header#header nav ul li a svg {
	opacity: .3;
	width: 10px;
	height: auto;
	margin-left: 4px
}

header#header nav ul li a svg path {
	fill: #202623
}

header#header nav ul ul {
	display: none;
	position: absolute;
	padding: 16px 15px 15px 15px;
	margin-left: -15px;
	top: 32px;
	background: #fff;
	width: 220px;
	box-shadow: 0px 3px 4px rgba(0, 0, 0, .12), 0px 9px 33px -1px rgba(0, 0, 0, .1), 0px 12px 42px -8px rgba(0, 0, 0, .15)
}

header#header nav ul ul li {
	display: list-item;
	position: relative;
	margin: 0 0 2px;
	height: auto
}

header#header nav ul ul li a {
	padding: 8px 12px;
	display: block;
	transition: .3s ease
}

header#header nav ul ul li a:hover {
	background: #ebf3f0;
	transition: .3s ease
}

header#header nav ul li:hover>ul {
	display: inline-block;
	transform: translateY(0);
	animation: fadeup .25s linear
}

header#header nav ul ul li:hover>ul {
	display: none
}

@keyframes fadeup {
	0% {
		opacity: 0;
		visibility: hidden;
		transform: translateY(16px)
	}

	100% {
		opacity: 1;
		visibility: visible;
		transform: translateY(0)
	}
}

header#mobile {
	display: none
}

@media(max-width: 1024px) {
	header#mobile {
		display: flex;
		justify-content: space-between;
		position: absolute;
		width: 90%;
		z-index: 10;
		padding: 0 5%;
		text-align: center;
		border-bottom: 1px solid #e2ece8;
		height: 66px
	}
}

header#mobile .mobile-logo svg {
	width: auto;
	height: 40px
}

@media(max-width: 576px) {
	header#mobile .mobile-logo svg {
		height: 32px
	}
}

header#mobile .menuIcon {
	width: 42px;
	display: flex;
	justify-content: space-between
}

header#mobile .menuIcon div.menu {
	flex-basis: 42px;
	width: 42px;
	height: 28px;
	z-index: 9;
	cursor: pointer
}

header#mobile .menuIcon div.menu div.strokes {
	height: 1px;
	margin: 1px 0 11px;
	background: #00779b;
	transition: transform .3s, opacity .1s
}

.hide {
	opacity: 0;
	transform: translateX(-42px)
}

.animate0 {
	transform: rotate(45deg) translate(9px, 9px)
}

.animate2 {
	transform: rotate(-45deg) translate(7px, -9px)
}

.fullscreen-menu {
	background-color: #fff;
	top: 0;
	left: 0;
	width: 100%;
	min-height: 100%;
	position: fixed;
	opacity: 0;
	transition: all .3s ease-in-out, opacity .3s;
	z-index: -2
}

.fullscreen-menu .menu-container {
	display: none
}

.fullscreen-menu.show {
	opacity: 1;
	background-color: #f4f9f7;
	transition: all .3s ease-in-out, visibility .3s;
	z-index: 8
}

.fullscreen-menu.show .menu-container {
	display: inherit;
	position: absolute;
	width: 100%;
	height: 100%;
	overflow-y: scroll;
	-webkit-overflow-scrolling: touch
}

.fullscreen-menu.show .menu-container ul {
	list-style: none;
	padding: 0;
	margin: 108px 5vw 30px;
	width: 90vw
}

.fullscreen-menu.show .menu-container ul li {
	border-bottom: 1px solid #e2ece8
}

.fullscreen-menu.show .menu-container ul li a {
	color: #02556e;
	display: flex;
	margin: 16px 0;
	line-height: 1.125;
	padding: 0;
	font-family: "Rufina", serif
}

.fullscreen-menu.show .menu-container ul li a .bullet {
	display: none
}

.fullscreen-menu.show .menu-container ul li ul {
	margin: 15px 0;
	column-count: 1
}

.fullscreen-menu.show .menu-container ul li ul li {
	border-bottom: none
}

.fullscreen-menu.show .menu-container ul li ul li a {
	color: #4e5853;
	font-size: 16px;
	font-family: "Roboto", sans-serif;
	font-weight: 400;
	margin: 0 0 20px;
	padding: 0;
	gap: 10px
}

.fullscreen-menu.show .menu-container ul li ul li a .bullet {
	display: inherit
}

.fullscreen-menu.show .menu-container ul li ul li ul {
	display: none
}

section.offerings-bcim {
	max-width: 1200px;
	margin: 100px auto;
	padding: 0 6vw
}

@media(max-width: 1024px) {
	section.offerings-bcim {
		padding: 0 5vw;
		margin: 75px auto
	}
}

section.offerings-bcim .split-intro {
	display: grid;
	grid-template-columns: 1.5fr 1fr;
	gap: 50px;
	align-items: end;
	margin: 0 0 50px;
	padding: 0 0 50px;
	border-bottom: 1px solid #e2ece8
}

@media(max-width: 768px) {
	section.offerings-bcim .split-intro {
		grid-template-columns: 1fr;
		gap: 20px
	}
}

section.offerings-bcim .split-intro .intro-right {
	margin: 0 0 5px
}

section.offerings-bcim .split-intro a.text-button {
	margin-top: 12px;
	display: inline-block
}

section.offerings-bcim .split-intro p,
section.offerings-bcim .split-intro h2,
section.offerings-bcim .split-intro h3 {
	margin: 0
}

section.offerings-bcim .tile-grid {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr 1fr;
	grid-template-rows: auto;
	gap: 36px
}

@media(max-width: 1024px) {
	section.offerings-bcim .tile-grid {
		grid-template-columns: 1fr 1fr;
		grid-template-rows: auto auto
	}
}

@media(max-width: 400px) {
	section.offerings-bcim .tile-grid {
		grid-template-columns: 1fr;
		grid-template-rows: auto auto auto auto
	}
}

section.offerings-bcim .tile-grid .tile .tile-headline h3 {
	color: #003a4d;
	text-wrap: balance
}

section.offerings-bcim .tile-grid .tile .tile-headline .icon {
	display: grid;
	place-content: center;
	background: #baefff;
	width: 80px;
	height: 80px;
	border-radius: 100px;
	margin: 0 0 20px
}

section.offerings-bcim .tile-grid .tile .tile-headline .icon svg {
	width: 44px;
	height: 44px
}

section.offerings-bcim .tile-grid .tile .tile-headline .icon svg path {
	fill: #003a4d
}

section.offerings-bcim .tile-grid .tile .small p {
	font-size: 15px;
	line-height: 1.5;
	color: #4e5853;
	text-wrap: pretty
}

@media(max-width: 1024px) {
	section.offerings-bcim .tile-grid .tile .small p {
		font-size: 14px
	}
}

@keyframes slide {
	from {
		transform: translateX(0)
	}

	to {
		transform: translateX(-100%)
	}
}

.logo-carousel {
	margin: 0 0 100px
}

@media(max-width: 1024px) {
	.logo-carousel {
		margin: 0 0 75px
	}
}

.logo-carousel .centered-overline {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	gap: 8px;
	align-items: center;
	margin: 0 0 50px
}

.logo-carousel .centered-overline .overline-line {
	background: #d8e3df;
	height: 1px;
	width: 100%
}

.logo-carousel .overline {
	margin: 0;
	color: #4e5853
}

.logo-carousel .logos {
	width: 100%;
	overflow: hidden;
	white-space: nowrap;
	position: relative
}

.logo-carousel .logos::before,
.logo-carousel .logos::after {
	position: absolute;
	top: 0;
	width: 75px;
	height: 100%;
	content: "";
	z-index: 2
}

@media(max-width: 768px) {

	.logo-carousel .logos::before,
	.logo-carousel .logos::after {
		width: 25px
	}
}

.logo-carousel .logos::before {
	left: 0;
	background: linear-gradient(to left, rgba(244, 249, 247, 0), #f4f9f7)
}

.logo-carousel .logos::after {
	right: 0;
	background: linear-gradient(to right, rgba(244, 249, 247, 0), #f4f9f7)
}

.logo-carousel .logos .logos-slider {
	display: inline-flex;
	align-items: center;
	gap: 70px;
	animation: 50s slide infinite linear;
	margin: 0 70px 0 0
}

.logo-carousel .logos .logos-slider img {
	display: inline-block;
	width: auto;
	max-height: 60px;
	max-width: 150px
}

.logo-carousel .logos:hover .logos-slider {
	animation-play-state: paused
}

.logo-carousel .logos.grayscale img {
	filter: grayscale(100%);
	opacity: .88;
	transition: .2s ease opacity
}

.logo-carousel .logos.grayscale img:hover {
	opacity: 1
}

.services-bcim {
	margin: 0 0 100px
}

@media(max-width: 1024px) {
	.services-bcim {
		margin: 0 0 75px
	}
}

.services-bcim .service-grid {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr 1fr;
	grid-template-rows: 1fr 1fr;
	gap: 1px
}

@media(max-width: 768px) {
	.services-bcim .service-grid {
		grid-template-columns: 1fr 1fr;
		grid-template-rows: 1fr 1fr 1fr 1fr
	}
}

.services-bcim .service-grid a.photo-tile {
	display: grid;
	grid-template-columns: 1fr;
	grid-template-rows: 1fr
}

.services-bcim .service-grid a.photo-tile picture {
	height: 25vw;
	grid-column: 1/span 1;
	grid-row: 1/span 1;
	z-index: 0;
	background: #003141
}

@media(max-width: 768px) {
	.services-bcim .service-grid a.photo-tile picture {
		height: 50vw
	}
}

.services-bcim .service-grid a.photo-tile picture img {
	opacity: .5;
	transition: .2s ease opacity
}

.services-bcim .service-grid a.photo-tile .service-content {
	position: relative;
	height: 25vw;
	grid-column: 1/span 1;
	grid-row: 1/span 1;
	z-index: 1;
	box-sizing: border-box;
	padding: 30px;
	align-content: end;
	background-image: linear-gradient(rgba(0, 49, 65, 0.1), rgba(0, 49, 65, 0.25), rgba(0, 49, 65, 0.25))
}

@media(max-width: 1280px) {
	.services-bcim .service-grid a.photo-tile .service-content {
		padding: 24px
	}
}

@media(max-width: 768px) {
	.services-bcim .service-grid a.photo-tile .service-content {
		height: 50vw
	}
}

@media(max-width: 576px) {
	.services-bcim .service-grid a.photo-tile .service-content {
		padding: 18px
	}
}

.services-bcim .service-grid a.photo-tile .service-content h3 {
	position: absolute;
	bottom: 30px;
	padding-right: 30px;
	color: #fff;
	line-height: 1.2;
	text-wrap: balance;
	transform: translateY(0);
	opacity: 1;
	transition: all .3s ease
}

@media(max-width: 1280px) {
	.services-bcim .service-grid a.photo-tile .service-content h3 {
		font-size: 1.4375em;
		bottom: 12px;
		padding-right: 24px
	}
}

@media(max-width: 576px) {
	.services-bcim .service-grid a.photo-tile .service-content h3 {
		font-size: 1.25em
	}
}

.services-bcim .service-grid a.photo-tile .service-content .service-details {
	opacity: 0
}

.services-bcim .service-grid a.photo-tile .service-content .service-details p {
	color: hsla(0, 0%, 100%, .8);
	text-wrap: pretty;
	margin: 0
}

.services-bcim .service-grid a.photo-tile .service-content .service-details .view-details {
	border-top: 1px solid hsla(0, 0%, 100%, .25);
	margin-top: 12px;
	padding-top: 12px;
	display: flex;
	justify-content: space-between;
	color: #fff;
	font-weight: 500
}

.services-bcim .service-grid a.photo-tile .service-content .service-details .view-details svg {
	width: auto;
	height: 10px
}

.services-bcim .service-grid a.photo-tile .service-content .service-details .view-details svg path {
	fill: #cfe98d
}

.services-bcim .service-grid a.photo-tile:hover picture img {
	opacity: .25
}

.services-bcim .service-grid a.photo-tile:hover .service-content {
	background-image: linear-gradient(rgba(0, 0, 0, 0.12), rgba(0, 0, 0, 0.33), rgba(0, 0, 0, 0.33))
}

@media(min-width: 1024px) {
	.services-bcim .service-grid a.photo-tile:hover .service-content h3 {
		transform: translateY(-25px);
		opacity: 0
	}

	.services-bcim .service-grid a.photo-tile:hover .service-content .service-details {
		animation: fadeinup .4s ease-in-out;
		animation-delay: .1s;
		animation-fill-mode: forwards
	}
}

section.hero-bcim {
	position: relative
}

section.hero-bcim .overlay {
	z-index: 2
}

section.hero-bcim .hero-photo {
	width: 100vw
}

section.hero-bcim .hero-photo picture {
	width: 100%;
	position: relative;
	max-height: 760px
}

@media(max-width: 1024px) {
	section.hero-bcim .hero-photo picture {
		height: 500px
	}
}

section.hero-bcim .hero-photo picture img {
	max-height: 760px
}

section.hero-bcim .hero-video {
	width: 100vw;
	background-image: url("https://nmd.nyc3.cdn.digitaloceanspaces.com/bci/images/bcim/videos/agriculture.webp");
	background-color: #fff;
	opacity: 0;
	animation-delay: .25s;
	animation: fadein .5s ease-in-out;
	animation-fill-mode: forwards
}

section.hero-bcim .hero-video img,
section.hero-bcim .hero-video video {
	display: block;
	width: 100vw;
	height: 56vw
}

@media(min-width: 1320px) {

	section.hero-bcim .hero-video img,
	section.hero-bcim .hero-video video {
		height: 800px;
		object-fit: cover
	}
}

@media(max-width: 768px) {

	section.hero-bcim .hero-video img,
	section.hero-bcim .hero-video video {
		height: 70vw;
		min-height: 500px;
		object-fit: cover
	}
}

section.hero-bcim .hero-bcim-intro {
	position: absolute;
	z-index: 2;
	top: 50%;
	transform: translateY(-50%);
	left: calc(50vw - 600px);
	backdrop-filter: blur(7px);
	width: 640px;
	padding: 50px 50px;
	box-sizing: border-box;
	background: linear-gradient(-30deg, rgba(4, 165, 214, 0.25), rgba(255, 255, 255, 0.75) 30%)
}

section.hero-bcim .hero-bcim-intro .overline {
	color: #719e00
}

section.hero-bcim .hero-bcim-intro .hero-text {
	text-wrap: pretty
}

@media(max-width: 1280px) {
	section.hero-bcim .hero-bcim-intro {
		text-align: center;
		width: auto;
		left: auto;
		padding: 0 15vw;
		background: none;
		backdrop-filter: blur(0px);
		border: none
	}

	section.hero-bcim .hero-bcim-intro * {
		color: #fff
	}
}

@media(max-width: 576px) {
	section.hero-bcim .hero-bcim-intro {
		padding: 0 7.5vw;
		margin-top: -20px
	}
}

section.hero-bcim .video-control {
	position: absolute;
	bottom: 25px;
	right: calc(50vw - 600px);
	z-index: 2;
	text-align: right
}

section.hero-bcim .video-control button.button {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	cursor: pointer;
	color: #fff;
	font-size: 12px;
	font-family: "Roboto", sans-serif;
	padding: 10px 0 11px;
	border: 1px solid #fff;
	width: 160px;
	background: rgba(0, 0, 0, 0)
}

section.hero-bcim .video-control button.button:after {
	display: inline-block;
	margin: 0 0 0 6px;
	content: url("/svgs/icon-video-pause.svg");
	width: 20px;
	height: auto;
	transform: translateY(1px)
}

section.hero-bcim .video-control button.button:active,
section.hero-bcim .video-control button.button:focus,
section.hero-bcim .video-control button.button:hover {
	background: #719e00
}

section.hero-bcim .video-control button.button.paused:after {
	content: url("/svgs/icon-video-play.svg")
}

@media(max-width: 1280px) {
	section.hero-bcim .video-control {
		right: 7vw
	}
}

@media(max-width: 768px) {
	section.hero-bcim .video-control {
		right: 5vw
	}
}

@media(max-width: 576px) {
	section.hero-bcim .video-control {
		right: auto;
		left: 50%;
		transform: translatex(-50%);
		bottom: 0
	}

	section.hero-bcim .video-control button.button {
		font-size: 11px;
		padding: 3px 0 4px;
		border-radius: 0;
		width: 138px;
		border: 1px solid hsla(0, 0%, 100%, .5)
	}
}

section.banner-bcim {
	background: #baefff;
	display: grid;
	grid-template-columns: 1fr 600px 600px 1fr;
	align-items: center;
	height: 500px;
	position: relative
}

@media(max-width: 1280px) {
	section.banner-bcim {
		grid-template-columns: 6vw 1fr 1fr 6vw
	}
}

@media(max-width: 1024px) {
	section.banner-bcim {
		grid-template-columns: 5vw 1fr 1fr 5vw;
		height: 400px
	}
}

section.banner-bcim .banner-content {
	grid-column: 2/span 1;
	padding-right: 75px
}

section.banner-bcim .banner-content .overline {
	color: #003a4d
}

section.banner-bcim .banner-content h1 {
	color: #003a4d
}

section.banner-bcim .banner-content p {
	margin: 0
}

section.banner-bcim .banner-image {
	grid-column: 3/span 1;
	height: 500px
}

section.banner-bcim .banner-image picture.flex {
	position: relative;
	width: 100%;
	height: 100%;
	overflow: hidden
}

section.banner-bcim .banner-image picture.flex img {
	width: 100%;
	height: 100%;
	object-fit: cover
}

@media(max-width: 1024px) {
	section.banner-bcim {
		grid-template-columns: 1fr
	}

	section.banner-bcim .banner-content .overline,
	section.banner-bcim .banner-content h1,
	section.banner-bcim .banner-content p {
		color: #fff
	}

	section.banner-bcim .banner-content {
		grid-column: 1/span 1;
		grid-row: 1/span 1;
		z-index: 1;
		background: rgba(0, 58, 77, .5);
		text-align: center;
		padding: 0 5vw;
		height: 100%;
		display: grid;
		place-content: center
	}

	section.banner-bcim .banner-image {
		grid-column: 1/span 1;
		grid-row: 1/span 1;
		z-index: 0;
		height: 400px
	}

	section.banner-bcim .banner-image picture.flex {
		z-index: 0
	}
}

@media(max-width: 1024px){
	.richtext figure img{
		max-width: 89%;
	}
}



