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

html {
	background-color: #000000;
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

body {
	background-position: bottom left;
	background-repeat: no-repeat;
	background-size: 100% auto;
	font-family: ivypresto-display, Georgia, serif;
	font-size: 17px;
	line-height: 1.75em;
	font-weight: 300;
	letter-spacing: .05em;
	color: #C7C4C2;
}

.webp body {
	background-image: url('../images/footer-bg.webp');
}

.no-webp body {
	background-image: url('../images/footer-bg.jpg');
}

body.layout2 {
	background-image: none;
}

body.editor, body.short_editor {
	background-image: none;
	background-color: #000000;
	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: 1em;
}

.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: 1em;
}

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

h1 {
	font-size: 34px;
	line-height: 1.2em;
	font-weight: normal;
	text-transform: uppercase;
	letter-spacing: .15em;
	text-align: center;
	color: #FEFEFE;
	color: #C7C4C2;
	margin-bottom: 1em;
}

h2 {
	font-size: 26px;
	line-height: 1.2em;
	font-weight: normal;
	text-transform: uppercase;
	letter-spacing: .15em;
	text-align: center;
	color: #FEFEFE;
	color: #C7C4C2;
	margin-bottom: .5em;
}

h2 em {
	font-size: .9em;
	text-transform: none;
}

hr {
	border: 0px;
	height: 1px;
	margin: 1em auto;
	color: #000000;
	background-color: #000000;
}

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

#content img, .editor img {
}

a {
	text-decoration: none;
	cursor: pointer;
	color: #FFFFFF;
}

a:hover {
	color: #E32B28;
}

a, a: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 #000000;
}

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 40px 0px;
	display: block;
	max-width: 50%;
}

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

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

}

.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: normal;
	line-height: 1.5em;
}

fieldset label {
	font-weight: normal;
}

input, select, textarea, .extension {
	font-family: ivypresto-display, Georgia, serif;
	font-size: 17px !important;
	line-height: 22px;
	letter-spacing: .05em;
	color: #FFFFFF;
	color: #C7C4C2;
	padding: 6px 10px;
	background-color: #373737;
	border: 0px;;
	-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 #000000;
}
*/

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: #FEFEFE;
	background-color: #C7C4C2;
	color: #000000;
	font-size: 17px;
	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 {
	color: #E32B28;
}

button:disabled, button[disabled], input[type="button"]:disabled {
	background-color: #CCCCCC;
	cursor: default;
}

.fancy_button {
	text-transform: uppercase;
}

.alert, .red {
	color: #EB0000;
}

#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: #FEFEFE;
	color: #C7C4C2;
	text-align: center;
	justify-content: center;
	align-items: center;
}

.contact_form .form_fields {
	background-color: #EEEEEE;
	padding: 20px 20px 0px 20px;
}

.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%;
	padding: 10px 15px;
}

.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;
	padding-left: 100px;
	padding-right: 100px;
	position: relative;
}

.block.padding_top {
	padding-top: 100px;
}

.block.padding_bottom {
	padding-bottom: 100px;
}

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

	.container {
		max-width: 1150px;
		padding-left: 75px;
		padding-right: 75px;
	}

	.block.padding_top {
		padding-top: 80px;
	}

	.block.padding_bottom {
		padding-bottom: 80px;
	}

}

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

	.container {
		max-width: 1100px;
		padding-left: 50px;
		padding-right: 50px;
	}

	.block.padding_top {
		padding-top: 60px;
	}

	.block.padding_bottom {
		padding-bottom: 60px;
	}

}

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

	.container {
		padding-left: 30px;
		padding-right: 30px;
	}

	.block.padding_top {
		padding-top: 30px;
	}

/*
	.subnav .block.padding_top:first-child {
		padding-top: 70px;
	}
*/

	.block.padding_bottom {
		padding-bottom: 30px;
	}

}

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

	.container {
		padding-left: 15px;
		padding-right: 15px;
	}

}

/* LAYOUT CSS */

header {
	position: relative;
}

#skip_content {
	position: absolute;
	top: 0px;
	left: 10px;
	transform: translateY(-150%);
	background-color: #000000;
	color: #FEFEFE;
	color: #C7C4C2;
	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);
}

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

#header_inner .container {
	max-width: none;
}

#logo {
	position: absolute;
	top: 40px;
	left: 100px;
}

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

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

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

}

#header_photo:after {
	content: " ";
	display: block;
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	background-repeat: no-repeat;
	background-position: center top;
	background-size: 100% auto;
	z-index: 5;
}

.webp #header_photo:after {
	background-image: url('../images/header-overlay.webp');
}

.no-webp #header_photo:after {
	background-image: url('../images/header-overlay.png');
}

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

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

	#header_photo {
		height: 240px;
		overflow: hidden;
	}

	#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;
	}

	#header_photo:after {
		background-size: 800px 240px;
	}

}

.collapsed_temp #header_inner, .collapsed #header_inner {
	position: fixed;
	top: -80px;
	width: 100%;
	height: 80px;
	background-color: #000000;
	z-index: 50;
}

.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 #nav, .collapsed #nav {
	padding-top: 30px;
}

.collapsed_temp #logo, .collapsed #logo {
	top: 20px;
}

#content {
	position: relative;
	min-height: 350px;
}

#content.subnav {
	margin-top: 0px !important
}

@media only screen and (min-width: 960px) and (max-width: 1299px) {

	#content {
		margin-top: -35px;
		margin-bottom: -35px;
	}

}

@media only screen and (min-width: 1300px) and (max-width: 1499px) {

	#content {
		margin-top: -60px;
		margin-bottom: -60px;
	}

}

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

	#content {
		margin-top: -75px;
		margin-bottom: -75px;
	}

}

.block_ctas {
	max-width: 2000px;
	padding-left: 10px;
	padding-right: 10px;
}

.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%;
	background-color: rgba(0,0,0,.5);
	font-size: 80px;
	line-height: 1em;
	text-transform: uppercase;
	letter-spacing: .2em;
	color: #FFFFFF !important;
}

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

.cta a span.content {
	display: block;
	width: 100%;
	text-align: center;
	position: relative;
	top: 50%;
	transform: translateY(-50%);
}

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

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

}

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

	.cta {
		margin-top: 10px;
	}

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

}

.layout2 footer {
	position: fixed;
	bottom: 0px;
	left: 0px;
	width: 100%;
	z-index: 10;
}

footer .container {
	max-width: none;
	padding-top: 125px;
	padding-bottom: 20px;
}

#footer_left {
	float: left;
	height: 47px;
	font-size: 14px;
	line-height: 40px;
	letter-spacing: .15em;
}

#footer_left img {
	vertical-align: bottom;
	margin-right: 25px;
}

#footer_left a {
	color: #FEFEFE;
	color: #C7C4C2;
}

#social {
	float: right;
	padding: 0px;
	display: inline-block;
	margin-left: 15px;
}

#social li {
	list-style: none;
	display: inline-block;
	margin-left: 15px;
	font-size: 22px;
}

#social li a {
	display: block;
	color: #FEFEFE;
	color: #C7C4C2;
}

#social li a:hover {
}

#footer_right {
	float: right;
	font-size: 13px;
	line-height: 53px;
	color: #B7B7B7;
}

#footer_right a {
	color: #B7B7B7;
}

#footer_right span, #footer_right a {
	white-space: nowrap;
}

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

	footer .container {
		display: block;
		text-align: center;
	}

	#footer_left {
		float: none;
		display: inline-block;
	}

	#social {
		float: none;
	}

	#footer_right {
		float: none;
		display: block;
		line-height: 25px;
		margin-top: 10px;
	}

}

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

	#social {
		display: block;
	}

	#social li {
		margin: 0px 7.5px;
	}

	#footer_right {
		margin-top: 5px;
	}

}

/* NAVIGATION CSS */

#nav li {
	list-style: none;
	position: relative;
	white-space: nowrap;
	font-size: 16px;
	line-height: 18px;
	text-transform: uppercase;
	letter-spacing: .1em;
}

#nav li a, #nav li.active li a {
	color: #FEFEFE;
}

#top_nav li {
	font-size: 13px;
	line-height: 15px;
	font-style: italic;
	text-transform: none;
}

#subnav {
/*
	position: absolute;
	top: 0px;
	left: 0px;
	z-index: 10;
*/
	width: 100%;
	text-align: center;
}

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

#subnav li {
	list-style: none;
	text-transform: uppercase;
	letter-spacing: .1em;
}

#subnav li a {
	color: #C7C4C2;
}

#subnav li a:hover, #subnav li.active a {
}

/* VINOSHIPPER CSS */

#vs-cart .vs-cart-button, #vs-cart button {
	background-color: #373737 !important;
}

.vs-cart-header-icon .vs-cart-icon {
	fill: #FFFFFF !important;
}

.vs-products-parent .vs-products-item-stage {
	background-color: transparent !important;
	border: 0px !important;
}

.vs-products-item-productMaker, .vs-products-item-badges, .vs-products-item-meta {
	display: none !important;
}

.vs-products-parent .vs-products-item-stage .vs-products-item-desc-stage .vs-products-item-desc-actions a, .vs-products-parent .vs-products-item-stage {
	color: #C7C4C2 !important;
}

.vs-products-item-info, .vs-products-item-desc-actions {
	text-align: center;
}

.vs-products-parent .vs-products-item-stage .vs-atc-button {
	background-color: #C7C4C2 !important;
	color: #000000 !important;
	text-transform: uppercase;
}

.vs-products-parent .vs-products-item-stage .vs-atc-select select {
	background-color: #373737 !important;
	border-radius: 0px !important;
	color: #C7C4C2 !important;
	appearance: auto !important;
	border: 0px !important;
}

.vs-products-parent .vs-products-item-stage .vs-atc-button {
	border-radius: 0px !important;
}

.vs-available-states-state, .vs-available-pickups-item {
	background-color: #373737 !important;
	color: #C7C4C2 !important;
}

/* CONTENT BLOCK CSS */

.block.border_top {
	border-top: 1px solid #DDDDDD;
}

.block_content p, .block_content_photo p {
	text-align: justify;
}

.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: -150px;
	}

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

}

.block_content_photo .container {
}

#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.wine .right_photo, #content .block_content_photo.wine .left_photo {
	width: 30%;
}

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

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

.block_content_photo .content_inner {
	padding-top: 20px;
}

.block_content_map .content_inner {
	padding-top: 0px;
	padding-bottom: 20px;
}

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

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

}

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

	#content .block_content_photo.wine .right_photo, #content .block_content_photo.wine .left_photo {
		max-width: 350px !important;
	}

}

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

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

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

	.block_content_map.stretch.right .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%;
		padding: 0px 0px 0px 10%;
	}

	.block_content_photo.stretch.right .content_inner {
		padding: 0px 10% 0px 0px;
	}

}

.block_box {
	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;
	padding-left: 0px !important;
	padding-right: 0px !important;
}

.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.bg {
	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;
	z-index: 20;
}

.block_slideshow .content_inner {
	position: relative;
	top: 50%;
	transform: translateY(-50%);
	padding: 0px 5%;
}

.block_slideshow .content_inner .title {
	font-size: 30px;
	line-height: 1em;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .15em;
	color: #FEFEFE;
	color: #C7C4C2;
	margin-top: .5em;
}

.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 6 Pro";
	font-size: 14px;
	line-height: 14px;
	font-weight: 400;
	color: #FEFEFE;
	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: #FEFEFE;
}

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

/* HOME CSS */

#home_slideshow_wrapper {
	height: 100vh;
}

#home_slideshow li:after {
	content: " ";
	display: block;
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	background-repeat: no-repeat;
	background-size: cover;
	z-index: 5;
}

.webp #home_slideshow li:after {
	background-image: url('../images/home-overlay.webp');
}

.no-webp #home_slideshow li:after {
	background-image: url('../images/home-overlay.png');
}

#home_slideshow .content img {
	width: 100%;
	max-width: 1250px;
}

/* PRODUCTS CSS */

.block_products .container {
	max-width: 1400px;
}

/* MAILING LIST CSS */

#mc-embedded-subscribe {
	margin: 0px !important;
}

#mc_embed_signup .mc-field-group select {
	width: 100% !important;
}

/* NEWS AND EVENTS CSS */

.block_news_events .item {
	border: 1px solid #DDDDDD;
	text-align: center;
	padding: 3% 3% 2% 3%;
	margin-bottom: 14px;
}

.block_news_events .title {
}

.block_news_events .date {
}

.block_news_events p {
	text-align: left;
}

.block_news_events a {
}

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

	.block_news_events .container_inner {
		padding: 10px;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}

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

	.block_news_events .item {
		width: calc(50% - 7px);
	}

}

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

	.block_news_events .item {
		padding: 3% 3% 2% 3%;
	}

}

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

	.block_news_events .item {
		padding: 4% 4% 2.8% 4%;
	}

}

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

	.block_news_events .item {
		padding: 20px 20px 10px 20px;
	}

}

/* 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:after {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	content: " ";
}

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

@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 div.question {
	cursor: pointer;
	padding: 5px 15px;
	margin-bottom: 10px;
	background-color: #DDDDDD;
	padding: 10px 15px 10px 15px;
}

.block_faqs div.question:before {
	float: left;
	margin-right: 10px;
	display: inline;
	content: '\f0d7';
	font-family: "Font Awesome 6 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: #EEEEEE;
}

.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;
	}

}

/* POPUP CSS */

#popup {
	display: none;
	width: 90%;
	max-width: 650px;
	background-color: #FEFEFE;
	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: #000000;
}

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

	#popup {
		padding: 30px;
	}

}

/* RESPONSIVE CSS */

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

	#nav_trigger {
		display: none;
	}

	#nav {
		position: absolute;
		top: 10px;
		right: 100px;
		height: auto;
		padding-top: 47px;
	}

	#main_nav {
	}

	#main_nav > li {
		float: left;
		margin-left: 20px;
		display: inline;
	}

	#main_nav > li a {
		display: inline-block;
		padding-bottom: 10px;
	}

	#main_nav > li a:after, #subnav li a:after {
		content: " ";
		transition: all .2s;
		width: 10px;
		height: 2px;
		position: absolute;
		bottom: 0px;
		left: calc(50% - 5px);
	}

	#main_nav > li a:hover:after, #main_nav > li.active a:after, #subnav li a:hover:after, #subnav li.active a:after {
		background-color: #E32B28;
	}

	#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: #DDDDDD;
	}

	#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;
	}

	#top_nav {
		position: absolute;
		top: 0px;
		right: 0px;
	}

	#top_nav li {
		float: left;
		margin-left: 20px;
		display: inline;
	}

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

	#subnav li {
		display: inline;
		margin: 0px 15px;
		white-space: nowrap;
		position: relative;
		padding-bottom: 8px;
	}

	#section_title {
		display: none;
	}

}

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

	#logo {
		left: 75px;
	}

	#nav {
		right: 75px;
	}

}

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

	#logo {
		left: 50px;
	}

	#nav {
		right: 50px;
	}

}

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

	#logo {
		left: 30px;
	}

	#nav {
		right: 30px;
	}

}

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

	.mobile_nav body {
		overflow: hidden;
	}

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

	#logo {
		top: 25px;
	}

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

	#nav_trigger:after, #nav_trigger:before, #nav_trigger span {
		content: '';
		display: block;
		background-color: #FEFEFE;
		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: #000000;
		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%;
	}

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

	#nav li a {
		display: block;
		padding: 10px 15px;
		color: #FFFFFF;
	}

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

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

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

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

	#top_nav {
		margin-top: 1em;
	}

	#top_nav li {
		font-size: 22px;
	}

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

	#section_title {
		padding: 0px 15px;
		font-size: 16px;
		line-height: 38px;
		text-transform: uppercase;
		letter-spacing: .1em;
		color: #FFFFFF;
		cursor: pointer;
		-webkit-tap-highlight-color: rgba(0,0,0,0);
	}

	#section_title:after {
		padding-left: 10px;
		content: '\f0d7';
		font-family: "Font Awesome 6 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: #000000;
		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;
	}

}
