:root {
	--black: #231F20;
	--dark-gray: #41433F;
	--dark-gray2: #2F302D;
	--light-gray: #CCCCCC;
	--light-gray2: #9D9695;
	--white: #FFFFFF;
	--red: #FF0000;
	--green: #75923C;
}

/* BASE CSS */
* {
	margin: 0px;
	padding: 0px;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

html {
	background-color: var(--dark-gray);
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

body {
	font-family: "Lexend", Arial, Helvetica, sans-serif;
	font-optical-sizing: auto;
	font-size: 15.5px;
	line-height: 2em;
	font-weight: 300;
	color: var(--black);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

body.iframe {
	padding: 20px;
	background-color: var(--white);
}

body.editor, body.short_editor {
	background-image: none;
	background-color: var(--white);
	min-height: 400px;
	transition: none;
	outline: none !important;
}

body.short_editor {
	min-height: 200px;
}

.tox-edit-area__iframe {
	padding: 0px 10px !important;
	background-color: transparent !important;
}

.table_container {
	-webkit-overflow-scrolling: touch;
	overflow-x: auto;
}

table {
	border-collapse:collapse;
	border-spacing: 0px;
	border: 0px;
	margin-bottom: 1em;
}

table.data_table {
	width: 100%;
}

table th {
	text-align: left;
}

table td {
	vertical-align: top;
}

table.data_table th, table.data_table td {
	text-align: center;
}

table.data_table th:first-child, table.data_table td:first-child {
	text-align: left;
}

p, .block p {
	margin-bottom: 1.25em;
}

.block p + ul {
	margin-top: -1em;
}

.block_content.two_col p {
	text-align: justify;
	margin-bottom: 2em;
}

.block p:last-child, #content .block ul:last-child {
	margin-bottom: 0px;
}

#content ul, #content ol, .editor ul, .editor ol, .short_editor ul, .short_editor ol {
	padding-left: 15px;
	margin-bottom: 1.25em;
}

#content li, #content_blocks li, .editor li, .short_editor li {
	line-height: 1.5em;
	margin-bottom: .5em;
}

ul ul {
	list-style-type: circle;
}

ul ul {
	margin-top: .5em;
}

strong {
	font-weight: 700;
}

h1, h2.title {
	font-size: 24px;
	line-height: 1em;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .05em;
	margin-bottom: .5em;
}

.block_content.two_col h1, .block_content.two_col h2.title {
	text-align: center;
}

h2 {
	font-size: 20px;
	line-height: 1em;
	font-weight: bold;
	margin-bottom: .25em;
}

hr {
	border: 0px;
	height: 1px;
	margin: 1em auto;
	color: var(--black);
	background-color: var(--black);
}

img {
	max-width: 100%;
	height: auto;
	border: none;
}

#content img, .editor img {
}

a {
	text-decoration: none;
	cursor: pointer;
	color: var(--green);
}

a:hover {
	color: var(--black);
}

a, a:after, .overlay:after, button, .button, input[type="button"], input[type="submit"] {
	transition: all .2s ease-in-out;
	-moz-transition: all .2s ease-in-out;
	-webkit-transition: all .2s ease-in-out;
}

:focus-visible {
	outline: 2px solid var(--black);
}

blockquote {
	margin: 10px 0px 10px 15px;
}

.cl {
	clear: left;
}

.cr {
	clear: right;
}

.cb {
	clear: both;
}

.cf:before, .cf:after {
	content: "";
	display: table;
}

.cf:after {
	clear: both;
}

.cf {
	zoom: 1;
}

.sr {
	position: absolute;
	height: 1px;
	width: 1px;
	clip: rect(1px 1px 1px 1px);
	clip: rect(1px,1px,1px,1px);
	clip-path: polygon(0px 0px, 0px 0px, 0px 0px);
	-webkit-clip-path: polygon(0px 0px, 0px 0px, 0px 0px);
	overflow: hidden !important;
}

#content .embed_container, #content_blocks .embed_container {
	position: relative;
	padding-bottom: 56.25%;
	height: 0px;
	overflow: hidden;
	max-width: 100%;
	margin-bottom: 20px;
}

#content_blocks .block_content_photo .embed_container, #content_blocks .block_video .embed_container {
	height: 100%;
	margin-bottom: 0px;
}

#content .embed_container iframe, #content .embed_container object, #content .embed_container embed,
#content_blocks .embed_container iframe, #content_blocks .embed_container object, #content_blocks .embed_container embed {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	border: 0px;
}

.right_photo {
	float: right;
	margin: 5px 0px 20px 40px;
	display: block;
	max-width: 50%;
}

.left_photo {
	float: left;
	margin: 5px 40px 20px 0px;
	display: block;
	max-width: 50%;
}

.right_photo img, .left_photo img {
	display: block;
}

@media only screen and (max-width: 699px) {

	.right_photo, .left_photo {
		float: none;
		margin: 0px 0px 20px 0px !important;
		max-width: 100%;
	}

	.right_photo img, .left_photo img {
		width: 100%;
	}

}

.col2 {
	margin-bottom: 1em;
}

@media only screen and (min-width: 768px) {

	.cols {
		display: flex;
		flex-wrap: wrap;
		width: 100%;
		justify-content: space-between;
	}

	.cols .col2 {
		width: calc(50% - 15px);
	}

	.cols .col3 {
		width: calc(33.3333333333% - 20px);
	}

}

/* FORM CSS */

fieldset {
	border: 0px;
}

label, .label, fieldset legend {
	display: inline-block;
	font-weight: bold;
	line-height: 1.5em;
}

fieldset label {
	font-weight: normal;
}

input, select, textarea, .extension {
	font-family: "Lexend", Arial, Helvetica, sans-serif;
	font-size: 15px !important;
	line-height: 22px;
	font-weight: 300;
	color: var(--black);
	padding: 6px 10px;
	background-color: var(--white);
	border: 1px solid var(--light-gray);
	-webkit-border-radius: 0px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

/*
input:focus, select:focus, textarea:focus {
	outline: 1px solid var(--black);
}
*/

input[type="checkbox"], input[type="radio"] {
	display: inline-block !important;
	width: 18px !important;
	height: 18px !important;
	padding: 0px;
	margin-right: 3px;
	vertical-align: text-top;
}

input[type="checkbox"] + label, input[type="radio"] +label {
	margin-right: 10px;
}

button, .button, input[type="button"], input[type="submit"], .layout_admin .ui-dialog-buttonset .ui-button {
	border: 0px;
	background-color: var(--black);
	color: var(--white);
	font-size: 14px;
	font-weight: bold;
	padding: 4px 10px;
	-webkit-appearance: none;
	cursor: pointer;
	vertical-align: top;
}

button:hover, .button:hover, input[type="button"]:hover, input[type="submit"]:hover, .layout_admin .ui-dialog-buttonset .ui-button:hover {
	background-color: var(--dark-gray);
}

button:disabled, button[disabled], input[type="button"]:disabled {
	background-color: var(--light-gray);
	cursor: default;
}

a.button {
	display: inline-block;
	padding: 1px 10px;
	margin-bottom: 5px;
}

.fancy_button {
	background-color: var(--black);
	color: var(--white);
	font-size: 18px;
	font-weight: bold;
	padding: 8px 12px;
}

.fancy_button:hover {
	background-color: var(--dark-gray);
}

.alert, .red {
	color: var(--red);
}

#loading {
	display: none;
	position: fixed;
	top: 0px;
	left: 0px;
	right: 0px;
	bottom: 0px;
	width: 100%;
	background-color: rgba(0,0,0,0.5);
	z-index: 10000;
	color: var(--white);
	text-align: center;
	justify-content: center;
	align-items: center;
}

.contact_form .form_fields {
}

.contact_form .form_fields + h2 {
	margin-top: 1em;
}

.contact_form div {
	width: 100%;
	margin-bottom: 20px;
	line-height: 1.5em;
}

.contact_form label {
	white-space: normal;
	display: inline-block;
	margin-bottom: 3px;
}

.contact_form input:not([type='radio']):not([type='checkbox']):not([type='submit']):not([type='button']), .contact_form select, .contact_form textarea {
	width: 100%;
}

.contact_form div.other {
	display: none;
	margin-top: 5px;
	margin-bottom: 0px;
}

.contact_form select:has(> option[value="Other"]:checked) + div.other {
	display: inline-block;
}

.contact_form span.other input {
	width: 200px !important;
}

.contact_form textarea {
	width: 100%;
	height: 100px;
}

.contact_form input.button {
	width: auto;
}

.contact_form .option {
	white-space: nowrap;
}

@media only screen and (min-width: 768px) {

	.contact_form .form_fields {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
	}

	.contact_form div.half {
		width: calc(50% - 10px);
	}

}

/* CONTAINER CSS */

.container {
	width: 100%;
	max-width: 1200px;
	margin: 0px auto;
	position: relative;
}

.padding_left { padding-left: 75px; }
.padding_right { padding-right: 75px; }
.padding_top1 { padding-top: 100px; }
.padding_bottom1 { padding-bottom: 100px; }
.padding_top2 { padding-top: 50px; }
.padding_bottom2 { padding-bottom: 50px; }
.padding_top3 { padding-top: 25px; }
.padding_bottom3 { padding-bottom: 25px; }

@media only screen and (max-width: 1499px) {
	.container { max-width: 1200px; }
	.padding_left {	padding-left: 75px; }
	.padding_right { padding-right: 75px; }
	.padding_top1 { padding-top: 80px; }
	.padding_bottom1 { padding-bottom: 80px; }
	.padding_top2 { padding-top: 40px; }
	.padding_bottom2 { padding-bottom: 40px; }
	.padding_top3 { padding-top: 20px; }
	.padding_bottom3 { padding-bottom: 20px; }
}

@media only screen and (max-width: 1199px) {
	.padding_left { padding-left: 50px; }
	.padding_right { padding-right: 50px; }
	.padding_top1 { padding-top: 60px; }
	.padding_bottom1 { padding-bottom: 60px; }
	.padding_top2 { padding-top: 30px; }
	.padding_bottom2 { padding-bottom: 30px; }
	.padding_top3 { padding-top: 15px; }
	.padding_bottom3 { padding-bottom: 15px; }
}

@media only screen and (max-width: 959px) {
	.padding_left { padding-left: 30px; }
	.padding_right { padding-right: 30px; }
	.padding_top1 { padding-top: 40px; }
	.padding_bottom1 { padding-bottom: 40px; }
	.padding_top2 { padding-top: 20px; }
	.padding_bottom2 { padding-bottom: 20px; }
	.padding_top3 { padding-top: 10px; }
	.padding_bottom3 { padding-bottom: 10px; }
}

@media only screen and (max-width: 599px) {
	.padding_left { padding-left: 15px; }
	.padding_right { padding-right: 15px; }
}

/* LAYOUT CSS */

header {
	position: relative;
	background-color: var(--white);
	padding: 0px !important;
}

.layout2 header {
	padding-top: 160px !important;
}

#skip_content {
	position: absolute;
	top: 0px;
	left: 10px;
	transform: translateY(-150%);
	background-color: var(--black);
	color: var(--white);
	padding: 0px 10px;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
	outline: none;
	z-index: 500;
}

#skip_content:focus {
	transform: translateY(10px);
}

.layout2 #header_inner {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	max-width: none;
	z-index: 50;
}

#header_inner .container {
	padding: 0px;
}

#logo {
	border-top: 10px solid var(--green);
	text-align: center;
	padding: 30px 0px;
}

.layout2 #logo {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
}

#logo a {
	display: inline-block;
}

#logo img {
	width: 100%;
	max-width: 390px;
	display: inline-block;
	position: relative;
	z-index: 50;
}

@media only screen and (max-width: 549px) {

	.layout2 header {
		padding-top: 110px !important;
	}

	#logo {
		text-align: left;
		padding: 15px;
	}

	#logo img {
		max-width: 300px;
	}

}

@media only screen and (max-width: 399px) {

	.layout2 header {
		padding-top: 100px !important;
	}

	#logo img {
		max-width: 250px;
	}

}

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

@media only screen and (max-width: 799px) {

	#header_photo {
		height: 152px;
		overflow: hidden;
		padding: 0px;
	}

	#home_slideshow_wrapper {
		padding-left: 0px;
		padding-right: 0px;
	}

	#header_photo img {
		width: 800px;
	}

	#header_photo.center img {
		position: relative;
		left: 50%;
		margin-left: -400px;
	}

	#header_photo.right img {
		float: right;
	}

	#header_photo.left_center img {
		position: relative;
		left: 25%;
		margin-left: -200px;
	}

	#header_photo.right_center img {
		position: relative;
		left: 75%;
		margin-left: -600px;
	}

}

.collapsed_temp #header_inner, .collapsed #header_inner {
	position: fixed;
	top: -80px;
	width: 100%;
	height: 80px;
	background-color: var(--light-gray);
	z-index: 9999;
}

.collapsed #header_inner {
	top: 0px;
}

.scrollup .collapsed_temp #header_inner, .collapsed #header_inner {
	-webkit-transition: top 0.4s ease-in;
	transition: top 0.4s ease-in;
}

.collapsed_temp #logo img, .collapsed #logo img {
	max-width: 200px;
}

#content {
	position: relative;
	background-color: var(--white);
}

.block_ctas {
	margin-top: 1px;
	background-color: var(--white);
}

.cta {
	position: relative;
}

.cta img {
	display: block;
	width: 100%;
	height: auto;
}

.cta a {
	display: block;
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	color: var(--white);
	letter-spacing: .1em;
	background-color: rgba(35, 31, 32,.3);
	border-bottom: 10px solid var(--green);
}

.cta a:hover {
	background-color: transparent;
}

.cta a span.content {
	display: block;
	width: 100%;
	text-align: center;
	position: relative;
	top: 50%;
	transform: translateY(-50%);
	font-size: 16px;
	line-height: 1.5em;
	font-weight: 500;
}

.small .cta a span.content {
	font-size: 14px;
}

.cta strong {
	display: block;
	font-size: clamp(2em, 3.5vw, 2.5em) !important;
	font-size: 2.5em;
	font-weight: 500;
	text-transform: uppercase;
	margin-bottom: .25em;
}

.small .cta strong {
	font-size: clamp(2em, 2.5vw, 2.15em) !important;
	font-size: 2.15em;
}

@media only screen and (min-width: 850px) {

	.block_ctas .container {
		display: grid;
		grid-template-columns: 1fr 1fr;
		grid-column-gap: 2px;
	}

	.cta strong {
		font-size: clamp(2em, 3.5vw, 2.5em) !important;
	}

	.small .cta strong {
		font-size: clamp(2em, 2.5vw, 2.15em) !important;
	}

}

@media only screen and (max-width: 849px) {

	.block_ctas .container {
		max-width: 524px;
	}

	.cta {
		margin-top: 1px;
	}

	.cta:first-child {
		margin-top: 0px;
	}

}

.footer {
	padding: 40px 0px;
	background-color: var(--dark-gray2);
	color: var(--light-gray2);
	text-align: center;
}

.footer .container {
	padding: 0px 8.5%;
	line-height: 1.3em;
	position: relative;
	height: 39px;
	display: flex;
	align-items: center;
}

#social {
	padding: 0px;
	margin-bottom: 10px;
	text-align: center;
}

#social li {
	list-style: none;
	display: inline-block;
	margin: 0px 10px;
	font-size: 22px;
	line-height: 22px;
}

#social li a {
	display: block;
	color: var(--black);
}

#social li a:hover {
	color: var(--dark-gray);
}

.footer .container {
}

#copyright span, #copyright a {
	white-space: nowrap;
	color: var(--light-gray2);
}

/* NAVIGATION CSS */

#nav ul {
	padding: 0px;
}

#main_nav li {
	list-style: none;
	position: relative;
	white-space: nowrap;
	text-transform: uppercase;
	font-size: 17px;
	line-height: 1em;
	font-weight: 500;
	letter-spacing: .05em;
}

#main_nav li a, #main_nav li.active li a {
	color: var(--dark-gray);
}

#main_nav li a:hover, #main_nav li.active a {
	color: var(--green);
}

#subnav {
	text-align: center;
}

#content #subnav ul {
	padding: 0px;
	margin: 0px;
}

#subnav li {
	list-style: none;
}

#subnav li a {
	color: var(--black);
}

#subnav li a:hover, #subnav li.active a {
	color: var(--light-gray);
}

/* CONTENT BLOCK CSS */

.block {
	position: relative;
}

.block.border_top {
	border-top: 1px solid var(--light-gray);
}

@media only screen and (min-width: 700px) {

	.block_content.two_col .content {
		-webkit-column-count: 2;
		-webkit-column-gap: 40px;
		-moz-column-count: 2;
		-moz-column-gap: 40px;
		column-count: 2;
		column-gap: 40px;
	}

}

.block_photo {
	max-width: none;
	padding-left: 0px !important;
	padding-right: 0px !important;
}

.block_photo.parallax {
	min-height: 500px;
	background: transparent;
}

.block_photo img {
	width: 100%;
	display: block;
}

@media only screen and (max-width: 799px) {

	.block_photo {
		height: 400px;
		overflow: hidden;
	}

	.block_photo img {
		width: 800px;
		max-width: none;
	}

	.block_photo.center img {
		position: relative;
		left: 50%;
		margin-left: -400px;
	}

	.block_photo.right img {
		float: right;
	}

	.block_photo.left_center img {
		position: relative;
		left: 25%;
		margin-left: -200px;
	}

	.block_photo.right_center img {
		position: relative;
		left: 75%;
		margin-left: -600px;
	}

}

#content .block_content_photo .photo img {
	width: 100%;
	display: block;
}

#content .block_content_photo.stretch .photo img {
	height: 100%;
	object-fit: cover;
}

#content .block_content_photo .right_photo, #content .block_content_photo .left_photo {
	width: 50%;
}

#content .block_content_photo .right_photo {
	margin-left: 5%;
}

#content .block_content_photo .left_photo {
	margin-right: 5%;
}

@media only screen and (min-width: 1050px) {

	.block_content_photo.stretch .container {
		display: flex;
	}

	.block_content_photo.stretch.left .container, .block_content_map.stretch.right .container {
		flex-direction: row-reverse;
	}

	.block_content_map.stretch.left .container {
		flex-direction: row;
	}

	.block_content_photo.stretch .container .photo {
		flex: 1;
		margin-bottom: 0px;
	}

	.block_content_photo.stretch .content {
		display: flex;
		flex: 1;
		align-items: center;
	}

	.block_content_photo.stretch .content_inner {
		width: 100%;
	}

}

@media only screen and (max-width: 1049px) {

	.block_content_photo .content_inner {
		padding: 30px 0px 0px 0px !important;
	}

	.block_content_map .content_inner {
		padding: 0px 0px 30px 0px !important;
	}

}

.block_photo_photo .container .photo + .photo {
	margin-top: 20px;
}

.block_photo_photo img {
	display: block;
}

@media only screen and (min-width: 768px) {

	.block_photo_photo .container {
		display: flex;
		justify-content: space-between;
	}

	.block_photo_photo .photo {
		width: calc(50% - 20px);
		margin: 0px !important;
	}

}

.block_box {
	position: relative;
	margin-bottom: 40px;
}

.block_box img {
	width: 100%;
}

@media only screen and (min-width: 768px) {

	.block_boxes .container_inner {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}

	.block_box {
		width: calc(50% - 20px);
	}
}

.block_slideshow {
	clear: both;
	width: 100%;
	position: relative;
}

.block_slideshow > ul {
	padding: 0px !important;
	margin: 0px !important;
	position: relative;
	width: 100%;
	height: 100%;
}

.block_slideshow .rslides li {
	list-style: none;
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	opacity: 0;
	margin: 0px !important;
}

.block_slideshow .rslides li:first-child {
	display: block;
	float: left;
	opacity: 1;
}

.block_slideshow li img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	float: left;
}

.block_slideshow .content {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	text-align: center;
}

.block_slideshow .content_inner {
	position: relative;
	top: 50%;
	transform: translateY(-50%);
	font-size: clamp(20px, 4vw, 40px) !important;
}

.block_slideshow .rslides_tabs {
	padding: 0px;
	text-align: center;
	position: absolute;
	bottom: 1%;
	left: 0px;
	width: 100%;
	height: auto;
	z-index: 10;
}

.rslides_tabs li {
	list-style: none;
	display: inline-block;
	margin: 0px 3px;
	width: 14px;
	height: 14px;
	position: relative;
}

.rslides_tabs li a {
	display: block;
	width: 14px;
	height: 14px;
	overflow: hidden;
	text-indent: 105%;
	cursor: pointer;
}

.rslides_tabs li a:before {
	position: absolute;
	top: 0px;
	left: 0px;
	content: "\f111";
	font-family: "Font Awesome 7 Pro";
	font-size: 14px;
	line-height: 14px;
	font-weight: 400;
	color: var(--white);
	text-indent: 0px;
}

.rslides_tabs li.rslides_here a:before {
	font-weight: 900;
}

.rslides_nav {
	position: absolute;
	top: 50%;
	left: 20px;
	z-index: 10;
	font-size: 30px;
	line-height: 30px;
	color: var(--white);
}

.rslides_nav.next {
	left: auto;
	right: 20px;
}

/* HOME CSS */

#home_slideshow_wrapper {
}

#home_slideshow_wrapper::after {
	content: " ";
	display: block;
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 300px;
	background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(255,255,255,0) 33%);
	z-index: 5;
}

/* NEWS AND EVENTS CSS */

.block_news_events .container {
	max-width: none;
}

.block_news_events .item {
	text-align: center;
	position: relative;
}

@media only screen and (min-width: 600px) { 

	.block_news_events .container_inner {
		display: grid;
		grid-template-columns: 1fr 1fr;
		grid-column-gap: 20px;
		grid-row-gap: 40px;
	}

}

@media only screen and (min-width: 1000px) { 

	.block_news_events .container_inner {
		grid-template-columns: 1fr 1fr 1fr;
	}

}

@media only screen and (min-width: 1400px) { 

	.block_news_events .container_inner {
		grid-template-columns: 1fr 1fr 1fr 1fr;
	}

}

/* GALLERY CSS */

.block_gallery .container {
	max-width: 2000px;
}

.gallery div {
	width: calc(25% - 7.5px);
	margin-bottom: 8px;
}

.gallery div img {
	width: 100%;
	display: block;
}

.gallery a {
	display: block;
	width: 100%;
	height: 100%;
}

.gallery a span {
	display: block;
	width: 100%;
	height: 100%;
	position: relative;
}

.gallery a span:after {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	content: " ";
}

.gallery a:hover span:after {
	background-color: rgba(0,0,0,.3);
}

.justified-gallery {
	width: 100%;
	position: relative;
	overflow: hidden;
}

.justified-gallery > div {
	position: absolute;
	display: inline-block;
	overflow: hidden;
}

.justified-gallery > div > a > span > picture > img {
	position: absolute;
	top: 50%;
	left: 50%;
}

.justified-gallery.loaded div {
	transition: width .3s, height .3s, top .3s, left .3s;
	-moz-transition: width .3s, height .3s, top .3s, left .3s;
	-webkit-transition: width .3s, height .3s, top .3s, left .3s;
}

.justified-gallery.loaded img {
	transition: width .3s, height .3s, margin-top .3s, margin-left .3s;
	-moz-transition: width .3s, height .3s, margin-top .3s, margin-left .3s;
	-webkit-transition: width .3s, height .3s, margin-top .3s, margin-left .3s;
}

@media only screen and (max-width: 1099px) { 

	.gallery div {
		width: calc(33.333333333333333% - 6.666666666666px);
	}

}

@media only screen and (max-width: 649px) { 

	.gallery div {
		width: calc(50% - 5px);
	}

}

/* FAQ CSS */

.block_faqs .faq {
	position: relative;
}

.block_faqs div.question {
	cursor: pointer;
	padding: 5px 15px;
	margin-bottom: 10px;
	background-color: var(--light-gray);
	padding: 10px 15px 10px 15px;
}

.block_faqs div.question:before {
	float: left;
	margin-right: 10px;
	display: inline;
	content: '\f0d7';
	font-family: "Font Awesome 7 Pro";
	font-size: 20px;
	font-weight: 900;
	font-style: normal;
}

.block_faqs div.answer {
	display: none;
}

.block_faqs div.expand div.question:before {
	content: '\f0d8';
}

.block_faqs div.expand div.answer {
	display: block;
	margin-bottom: 20px;
}

/* TESTIMONIALS CSS */

.block_testimonials .testimonial {
	padding: 50px;
	background-color: var(--light-gray);
}

.block_testimonials .testimonial cite {
	display: block;
}

.block_testimonials .testimonial blockquote {
	margin: 0px;
	text-align: justify;
}

@media only screen and (min-width: 800px) {

	.block_testimonials .testimonials {
		margin-left: -50px;
	}

	.block_testimonials .testimonial {
		width: calc(50% - 50px);
		float: left;
		margin: 0px 0px 50px 50px;
	}

}

@media only screen and (min-width: 800px) and (max-width: 959px) {

	.block_testimonials .testimonials {
		margin-left: -30px;
	}

	.block_testimonials .testimonial {
		padding: 30px;
		width: calc(50% - 30px);
		margin: 0px 0px 30px 30px;
	}

}

@media only screen and (max-width: 799px) {

	.block_testimonials .testimonial {
		padding: 30px;
		position: relative !important;
		top: auto !important;
		left: auto !important;
		margin-top: 30px;
	}

}

@media only screen and (max-width: 599px) {

	.block_testimonials .testimonial {
		padding: 15px;
		margin-top: 15px;
	}

}

.block_testimonial_carousel .testimonial {
	text-align: center;
}

/* POPUP CSS */

#popup {
	display: none;
	width: 90%;
	max-width: 650px;
	background-color: var(--white);
	padding: 50px;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

#popup p {
	line-height: 1.5em;
}

#popup p:last-of-type {
	margin-bottom: 0px;
}

#popup .close {
	border: 0px;
	background-color: transparent;
	position: absolute;
	top: 8px;
	right: 10px;
	cursor: pointer;
	font-size: 22px;
	line-height: 22px;
	color: var(--black);
}

@media only screen and (max-width: 699px) {

	#popup {
		padding: 30px;
	}

}

/* RESPONSIVE CSS */

@media only screen and (min-width: 399px) {

	.footer {
		padding: 40px 7.5%;
	}


	.footer:before, .footer:after {
		content: " ";
		position: absolute;
		left: 0px;
		top: 59px;
		width: calc(7.5% - 10px);
		height: 1px;
		background-color: var(--dark-gray);
	}

	.footer:after {
		left: auto;
		right: 0px;
	}

}

@media only screen and (min-width: 768px) {

	#nav_trigger {
		display: none;
	}

	#nav {
		width: 100%;
		height: auto;
		margin-bottom: 20px;
		padding: 0px 15%;
		position: relative;
	}

	.layout2 #nav {
		position: absolute;
		top: 153.5px;
		left: 0px;
	}

	#nav:before, #nav:after {
		content: " ";
		position: absolute;
		top: 8px;
		left: 0px;
		width: calc(12.5% - 10px);
		height: 1px;
		background-color: var(--dark-gray);
	}

	#nav:after {
		left: auto;
		right: 0px;
	}

	#main_nav {
		width: 100%;
		display: flex;
		justify-content: space-between;
		max-width: 800px;
		margin: 0px auto;
	}

	#main_nav > li {
		padding-bottom: 8px;
	}

	#main_nav li > ul {
		position: absolute;
		top: 25px;
		left: 50%;
		transform: translateX(-50%);
		padding: 0px;
		z-index: 20;
		visibility: hidden;
		opacity: 0;
		transition: .2s .2s;
		background-color: var(--light-gray);
	}

	#main_nav li:hover > ul, #main_nav li.hover > ul {
		visibility: visible;
		transition-delay: 0s;
		opacity: 1;
	}

	#main_nav li li a {
		display: block;
		padding: 7px 10px;
	}

	#content #subnav ul {
		padding: 5px 0px;
	}

	#subnav li {
		display: inline;
		margin: 0px 15px;
		white-space: nowrap;
	}

	#section_title {
		display: none;
	}

}

@media only screen and (min-width: 768px) and (max-width: 999px) {

	#nav, .footer .container {
		padding: 0px 10%;
	}

	#nav:before, #nav:after, .footer:before, .footer:after {
		width: calc(7.5% - 10px);
	}

}

@media only screen and (min-width: 768px) and (max-width: 849px) {

	#nav {
		padding: 0px 7.5%;
	}

	#nav:before, #nav:after {
		width: calc(5% - 10px);
	}

}

@media only screen and (max-width: 767px) {

	.mobile_nav body {
		overflow: hidden;
	}

	.mobile_nav #header_inner {
		height: 100vh;
		overflow-y: scroll;
		position: fixed;
	}

	#nav_trigger {
		border: 0px;
		background-color: transparent;
		width: 30px;
		padding: 0px;
		position: absolute;
		top: 30px;
		right: 30px;
		z-index: 100;
		cursor: pointer;
	}

	#nav_trigger:after, #nav_trigger:before, #nav_trigger span {
		content: '';
		display: block;
		background-color: var(--dark-gray2);
		border-radius: 2px;
		height: 5px;
		margin: 5px 0px;
		transition: all .2s ease-in-out;
	}

	.mobile_nav #nav_trigger:before {
		transform: translateY(10px) rotate(45deg);
	}

	.mobile_nav #nav_trigger:after {
		transform: translateY(-10px) rotate(-45deg);
	}

	.mobile_nav #nav_trigger span {
		display: block;
		transform: scale(0);
	}

	#nav {
		width: 0px;
		height: 100vh;
		position: absolute;
		right: 0px;
		top: 0px;
		background-color: var(--dark-gray2);
		padding-top: 50px;
		padding-bottom: 80px;
		z-index: 50;
		overflow-x: hidden;
		overflow-y: scroll;
		transition: width 0.4s ease;
	}

	.mobile_nav #nav {
		width: 100%;
	}

	.mobile_nav #nav_trigger:after, .mobile_nav #nav_trigger:before, .mobile_nav #nav_trigger span {
		background-color: var(--light-gray2);
	}

	#main_nav li {
		display: block;
		font-size: 24px;
		line-height: 1em;
		text-align: center;
		white-space: normal;
	}

	#main_nav li a {
		display: block;
		padding: 10px 15px;
		color: var(--light-gray2);
	}

	#main_nav li ul {
		padding: 0px;
		max-height: 0px;
		overflow: hidden;
		transition: all 0.4s cubic-bezier(0,1,0,1);
	}

	#main_nav li.expanded > ul, #main_nav li.hover > ul {
		padding-bottom: 10px;
		max-height: 499px;
		transition: all 0.4s cubic-bezier(1,0,1,0);
	}

	#main_nav li li {
		font-size: 16px;
	}

	#main_nav li li a {
		padding: 6px 30px;
	}

	#subnav {
		height: 42px;
		position: relative;
	}

	#section_title {
		padding: 0px 15px;
		font-size: 16px;
		line-height: 38px;
		font-weight: bold;
		cursor: pointer;
		-webkit-tap-highlight-color: rgba(0,0,0,0);
	}

	#section_title:after {
		padding-left: 10px;
		content: '\f0d7';
		font-family: "Font Awesome 7 Pro";
		font-size: 20px;
		font-weight: 900;
		font-style: normal;
	}

	#subnav.expanded #section_title:after {
		content: '\f0d8';
	}

	#content #subnav ul {
		position: absolute;
		top: 40px;
		left: 0px;
		width: 100%;
		max-height: 0px;
		overflow: hidden;
		background-color: var(--light-gray);
		padding: 0px;
		z-index: 30;
		transition: all 0.4s cubic-bezier(0,1,0,1);
	}

	#content #subnav.expanded ul {
		max-height: 499px;
		overflow: auto;
		transition: all 0.4s cubic-bezier(1,0,1,0);
	}

	#subnav li {
		margin: 0px;
		display: block;
		line-height: 1.1em;
	}

	#subnav li:last-child {
		padding-bottom: 10px;
	}

	#subnav li a {
		display: block;
		padding: 10px 15px;
	}

}

@media only screen and (max-width: 599px) { 

	#logo {
		left: 15px;
	}

	#nav_trigger {
		right: 15px;
	}

}
