:root {
	--c7-font-family: "Roboto Condensed", Arial, Helvetica, sans-serif;
	--c7-body-text-color: #2D2825;
	--c7-font-size: 18px;
	--c7-font-size-sub: 18px;
	--c7-heading-font-family: "CastellarMTRoman", Georgia, "Times New Roman", Times, sans-serif;
	--c7-heading-text-color: #E51E25;
	--c7-link-color: #E51E25;
	--c7-bg: #F5F4ED;
	--c7-bg-alt: #FFFFFF;
	--c7-border-radius: 0px;
	--c7-button-border-radius: 0px;
	--c7-primary-button-text-color: #FFFFFF;
	--c7-primary-button-bg: #2D2825;
	--c7-primary-button-bg-hover: #544D48;
	--c7-alt-button-text-color: #FFFFFF;
	--c7-alt-button-bg: #2D2825;
	--c7-alt-button-bg-hover: #52443C;
	--c7-field-border-radius: 0px;
	--c7-cart-count-bg: #E51E25;
	--c7-cart-count-text-color: #FFFFFF;
	--c7-field-option-selected-color: #2D2825;
	--c7-field-option-focus-color: #52443C;
}

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

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

body {
	background-color: #F5F4ED !important;
	font-family: "Roboto Condensed", Arial, Helvetica, sans-serif;
	font-size: 18px;
	line-height: 2em;
	color: #2D2825;
}

body.editor, body.short_editor {
	background-image: none;
	background-color: #F5F4ED;
	min-height: 400px;
	transition: none;
}

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_content p {
	text-align: justify;
}

.block p:last-child {
	margin-bottom: 0px;
}

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

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

h1 {
	font-family: "CastellarMTRoman", Georgia, "Times New Roman", Times, sans-serif;
	font-size: 34px;
	line-height: 1em;
	font-weight: normal;
	text-transform: uppercase;
	text-align: center;
	color: #E51E25;
	letter-spacing: .2em;
	margin-bottom: 1em;
}

h2 {
	font-size: 24px;
	line-height: 1em;
	font-weight: normal;
	text-transform: uppercase;
	letter-spacing: .05em;
	margin-bottom: .25em;
}

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

	h1 {
		font-size: 26px;
	}

	h2 {
		font-size: 20px;
	}
}

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

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

#content img, .editor img {
}

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

a:hover {
	color: #870F14;
}

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

button.c7-link:hover, .c7-modal__header button, .c7-link, #c7-side-cart__header__close:hover {
	background-color: transparent;
}

.c7-user-nav__cart > .c7-link:hover .c7-user-nav__cart__count {
	box-shadow: none;
}

: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%;
}

.right_photo {
	float: right;
	margin: 5px 0px 40px 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: bold;
	line-height: 1.5em;
}

fieldset label {
	font-weight: normal;
}

input, select, textarea {
	font-family: "Roboto Condensed", Arial, Helvetica, sans-serif;
	font-size: 18px !important;
	line-height: 22px;
	padding: 6px 10px;
	background-color: #FFFFFF;
	border: 1px solid #CCCCCC;
	-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: #2D2825;
	color: #F5F4ED;
	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: #333333;
}

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

.fancy_button, input.fancy_button {
	display: inline-block;
	padding: 14px 20px 14px 20px;
	background-color: #2D2825;
	font-family: "Roboto Condensed", Arial, Helvetica, sans-serif;
	font-size: 18px !important;
	line-height: 1em;
	font-weight: bold;
	color: #FFFFFF;
}

.fancy_button:hover {
	background-color: #544D48 !important;
	color: #FFFFFF;
}

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

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

.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 {
		padding-left: 75px;
		padding-right: 75px;
	}

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

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

}

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

	.container {
		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: #FFFFFF;
	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;
	height: 100%;
	max-height: 300px;
	z-index: 50;
	background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(255,255,255,0) 250px);
}

#logo {
	position: absolute;
	top: 50px;
	left: 0px;
	width: 100%;
	text-align: center;
}

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

#logo #logo2 {
	display: none;
}

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

.collapsed_temp #logo #logo1, .collapsed #logo #logo1 {
	display: none;
}

.collapsed_temp #logo #logo2, .collapsed #logo #logo2 {
	display: inline-block;
	width: 60px;
}

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

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

}

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

}

.collapsed_temp #header_inner, .collapsed #header_inner {
	position: fixed;
	top: -60px;
	width: 100%;
	height: 60px;
	background-color: #F5F4ED;
	background-image: none;
	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;
}

#content {
	position: relative;
}

.block_ctas {
	padding: 10px;
	overflow: hidden;
}

.cta {
	position: relative;
}

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

.cta a {
	display: block;
	background-color: #675C55;
	color: #E51E25;
	font-size: 25px;
	line-height: 1em;
	text-align: center;
	padding: 2%;
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,.5);
}

.cta a:hover {
	background-color: rgba(0,0,0,.8);
}

.cta a span {
	display: block;
	width: 100%;
	height: 100%;
	border: 3px solid #FFFFFF;
	padding: 5px 5px;
}

.cta a span span {
	border: 2px solid #FFFFFF;
	padding: 6.75% 5% 0px 5%;
}

.layout2 .cta a span span {
	padding: 13% 5% 0px 5%;
}

.cta a strong {
	display: block;
	font-family: "KuenstlerScriptTwoBold", Georgia, "Times New Roman", Times, sans-serif;
	font-size: 4em;
	font-weight: normal;
	line-height: .7em;
	color: #F5F4ED;
}

.layout2 .cta a strong {
	font-size: 5em;
	line-height: 1em;
}

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

	.block_ctas {
		padding: 10px;
		display: flex;
		justify-content: space-between;
	}

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

}

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

	.cta:first-child {
		margin-bottom: 10px;
	}

}

footer {
	background-color: #51493A;
	background-position: center center;
	background-repeat: no-repeat;
	height: 766px;
	padding-top: 100px;
	text-align: center;
}

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

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

#footer_logo {
	margin-bottom: 60px;
}

#footer_logo img {
	width: 150px;
}

.mailinglist {
	font-size: 21px;
	line-height: 1em;
	letter-spacing: .05em;
	color: #F5F4ED;
	width: 100%;
	max-width: 350px;
	margin: 0px auto 2em auto;
}

.mailinglist .title {
	font-family: "CastellarMTRoman", Georgia, "Times New Roman", Times, sans-serif;
	font-size: 1.6666em;
	line-height: 1em;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: #F5F4ED;
	margin-bottom: .5em;
}

.mailinglist label, #mce-responses {
	white-space: normal;
	font-style: italic;
	font-weight: normal;
	line-height: 1em;
}

.mailinglist form div {
	border: 3px solid #F5F4ED;
	margin-top: 1.5em;
	padding: 5px;
}

.mailinglist form div div {
	border: 2px solid #F5F4ED;
	margin: 0px;
	padding: 12px 10px 8px 10px;
}

.mailinglist #email_box {
	background-color: transparent;
	font-size: 16px !important;
	line-height: 18px;
	color: #F5F4ED;
	width: calc(100% - 100px);
	border: 0px;
	padding: 2px 5px;
}

.mailinglist button {
	background-color: transparent;
	font-family: "CastellarMTRoman", Georgia, "Times New Roman", Times, sans-serif;
	font-size: 20px !important;
	line-height: 24px;
	font-weight: normal;
	text-transform: uppercase;
	color: #F5F4ED;
	width: 100px;
	text-align: center;
	padding: 2px 4px;
	white-space: nowrap;
}

.mailinglist button:hover {
	color: #E51E25;
}

#mce-responses {
	padding-top: 20px;
	height: 62px;
}

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

	.mailinglist {
		font-size: 20px;
	}

}

footer a {
	color: #B0955B;
}

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

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

#social li a {
	display: block;
	color: #F5F4ED;
}

#social li a:hover {
	color: #E51E25;
}

#copyright {
	font-size: 16px;
	line-height: 1.5em;
	font-style: italic;
	color: #C1BDB3;
}

#copyright a {
	color: #C1BDB3;
}

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

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

	footer {
		background-position: center center;
		-webkit-background-size: cover;
		-moz-background-size: cover;
		-o-background-size: cover;
		background-size: cover;
	}

}

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

	#copyright br {
		display: none;
	}

}

/* NAVIGATION CSS */

#nav li {
	list-style: none;
	position: relative;
	white-space: nowrap;
	font-family: "CastellarMTRoman", Georgia, "Times New Roman", Times, sans-serif;
	font-size: 18px;
	line-height: 20px;
	letter-spacing: .2em;
	text-transform: uppercase;
}

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

#main_nav li li {
	font-family: "Roboto Condensed", Arial, Helvetica, sans-serif;
	font-size: 18px;
	font-style: italic;
	text-transform: none;
	letter-spacing: .05em;
}

#cart_nav {
	position: absolute;
	top: -75px;
	right: 20px;
}

#c7-cart, #c7-account {
	display: inline-block;
	vertical-align: middle;
}

#c7-cart {
	margin-right: 10px;
}

#nav #c7-side-cart ul li {
	white-space: normal;
}

.c7-user-nav__account {
	padding-right: 0px;
}

.c7-user-nav__account > a, .c7-user-nav__cart > button {
	font-style: italic;
	color: #2D2825;
}

.c7-user-nav__cart__title svg {
	stroke: #2D2825;
}

#cart_nav h1:after {
	display: none;
}

#subnav, #back_link {
	width: 100%;
	font-style: italic;
	text-align: center;
	border-bottom: 1px solid #B0ABA7;
	padding: 10px 0px;
}

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

#subnav li {
	list-style: none;
}

#subnav li a {
	color: #2D2825;
}

#subnav li a:hover, #subnav li.active a {
	color: #E51E25;
}

/* CONTENT BLOCK CSS */

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

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

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

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

@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 .rslides li:after, #header_photo:after {
	content: " ";
	display: block;
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(255,255,255,0) 250px);
	z-index: 5;
}
*/

.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%;
	font-size: 40px;
	line-height: 1em;
	color: #FFFFFF;
	letter-spacing: .1em;
	text-align: center;
	padding: 0px 5%;
}

.block_slideshow .content_inner {
	position: relative;
	top: 55%;
	transform: translateY(-55%);
}

.block_slideshow .title {
	font-size: 2.25em;
	line-height: 1em;
	text-transform: uppercase;
}

.block_slideshow .subtitle {
	font-style: italic;
	margin-top: .5em;
}

.block_slideshow .fancy_button {
	margin-top: 2em;
}

.block_slideshow .rslides_tabs {
	padding: 0px;
	text-align: center;
	position: absolute;
	bottom: 1%;
	left: 0px;
	width: 100%;
	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: "\f10C";
	font-family: FontAwesome;
	font-size: 14px;
	line-height: 14px;
	color: #FFFFFF;
	text-indent: 0px;
}

.rslides_tabs li.rslides_here a:before {
	content: "\f111";
}

.rslides_nav {
	position: absolute;
	top: 50%;
	left: 20px;
	z-index: 50;
	color: #FFFFFF;
}

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

/* HOME CSS */

#home_slideshow_wrapper {
	height: 100vh;
}

/* NEWS AND EVENTS CSS */

.block_news_events .item {
	border: 3px solid #DFDDCE;
	text-align: center;
	padding: 5px;
}

.block_news_events .item_inner {
	border: 2px solid #DFDDCE;
	text-align: center;
	padding: 3% 3% 2% 3%;
	margin-bottom: 14px;
	height: 100%;
}

.block_news_events.featured .item {
	margin-bottom: 0px;
}

.block_news_events .title {
	font-family: "CastellarMTRoman", Georgia, "Times New Roman", Times, sans-serif;
	font-size: 30px;
	text-transform: uppercase;
	letter-spacing: .1em;
	color: #51493A;
	margin-bottom: .15em;
}

.block_news_events .date {
	font-size: 25px;
	line-height: 1em;
	letter-spacing: .1em;
	color: #E51E25;
	margin-bottom: 1em;
}

.block_news_events p {
	font-size: 16px;
	line-height: 1.5em;
	text-align: justify;
	margin-bottom: 2em;
}

.block_news_events a {
	font-size: 25px;
	line-height: 1em;
	font-style: italic;
	letter-spacing: .1em;
	color: #51493A;
}

.block_news_events a:hover {
	color: #E51E25;
}

div.event_date {
	text-align: center;
	font-style: italic;
	font-size: 1.2em;
	margin-bottom: 1em;
}

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

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

	.block_news_events.featured .container {
		max-width: none;
		padding: 0px 10px;
	}

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

	.block_news_events.featured .item {
		width: calc(100%/3 - 7px);
		margin-bottom: 10px;
	}

}

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

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

}

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

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

}

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

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

}

/* COMMERCE7 CSS */

/*
.block_content.c7 {
	max-width: 1400px;
}
*/

.c7-product-collection__product-list {
	grid-template-columns: 1fr 1fr 1fr;
	column-gap: 50px;
	row-gap: 30px;
}

.c7-product-collection .c7-product {
	display: inline-block;
	vertical-align: top;
	border: 1px solid #B0ABA7;
	font-size: 24px;
	text-align: center;
	position: relative;
	padding: 0px 5% 30px 5%;
}

.c7-product-collection .c7-product__photo {
	padding: 15% 20% 0px 20%;
}

.c7-product-collection .c7-product img {
	width: auto;
	max-height: 400px;
}

.c7-product-collection .c7-product h2 {
	font-size: 20px;
	margin-bottom: 0px;
}

.c7-product-collection .c7-product h2 .vintage {
	display: block;
	font-size: 18px;
	font-style: italic;
	color: #AA671A;
}

.c7-product-collection .c7-product h2 a {
	color: #000000;
}

.c7-product-collection .c7-product__add-to-cart__price, .c7-product-detail .c7-product__add-to-cart__price {
	color: #80746B;
	margin: 0px;
}

.c7-product-collection .c7-product__variant__price__title, .c7-product-collection .c7-product__add-to-cart__price__variant, .c7-product-detail .c7-product__add-to-cart__price__variant {
	display: none;
}

.c7-product-collection .c7-product__add-to-cart__form__quantity, .c7-product-detail .c7-product__add-to-cart__form__quantity {
	margin: 0px;
}

.c7-product-collection .c7-product__add-to-cart__form {
	justify-content: center;
}

.c7-product-collection .c7-pagination {
	display: none;
}

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

	.c7-product-collection__product-list {
		column-gap: 30px;
	}

}

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

	.c7-product-collection__product-list {
		grid-template-columns: 1fr 1fr;
	}

}

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

	.c7-product-collection__product-list {
		grid-template-columns: 1fr;
	}

	.c7-product-collection .c7-product__photo {
		padding: 40px 40px 0px 40px;
	}

}

.c7-account__menu {
	box-shadow: none;
	background-color: transparent;
}

.c7-product__login-message {
	line-height: 1.5em;
	margin-top: 1em;
}

.c7-btn {
	padding: 9px 20px !important;
}

.c7-btn:hover {
	color: #FFFFFF;
}

/* 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);
	}

}

/* PRODUCTS CSS */

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

.block_products .product {
	display: inline-block;
	vertical-align: top;
	min-width: 210px;
	max-width: 300px;
	border: 1px solid #B0ABA7;
	font-size: 24px;
	text-align: center;
	position: relative;
	padding-top: 30px;
	padding-bottom: 55px;
	margin-bottom: 40px;
}

.block_products .photo {
	margin-bottom: 0px;
}

/*
.block_products .photo img {
	height: 100%;
	width: auto;
}
*/

.block_products .title {
	padding: 0px 10px;
	line-height: 1.3em;
	margin-bottom: .2em;
}

.block_products .price {
	font-style: italic;
	color: #52443C;
	margin-bottom: 20px;
}

.block_products .bottom {
	border-top: 1px solid #B0ABA7;
	font-size: 0.875em;
	font-style: italic;
	position: absolute;
	bottom: 0px;
	left: 0px;
	width: 100%;
}

.block_products .bottom a {
	display: block;
	height: 54px;
	line-height: 54px;
}

.block_products .details {
	width: 50%;
	float: left;
	border-right: 1px solid #B0ABA7;
}

.block_products .buy {
	width: 50%;
	float: right;
}

.block_products .product.wide .buy {
	width: 100%;
	float: none;
}

.block_products .buy a {
	background-color: #2D2825;
	color: #F5F4ED;
}

.block_products .buy a:hover {
	background-color: #52443C;
}

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

	.block_products .container {
		grid-template-columns: 1fr 1fr 1fr;
	}

}

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

	.block_products .container {
		grid-template-columns: 1fr 1fr;
	}

}

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

	.block_products .container {
		display: block;
	}

	.block_products .product {
		display: block;
		margin-left: auto;
		margin-right: auto;
	}

}

#product_photo {
	text-align: center;
}

#product_photo img, .c7-product-detail__photo img {
	width: auto;
	max-height: 700px;
}

#product_buy {
	border: 1px solid #B0ABA7;
	display: inline-block;
	font-style: italic;
	margin-bottom: 1.75em;
}

#product_price, .c7-product__add-to-cart__price {
	float: left;
	font-size: 28px;
	line-height: 1.6em;
	color: #52443C;
	padding-right: .5em;
}

#product_buy a {
	display: inline-block;
	padding: 2px .75em 0px .75em;
	background-color: #2D2825;
	color: #FFFFFF;
	font-size: 28px;
	line-height: 1.85em;
	color: #F5F4ED;
}

#product_buy a:hover {
	background-color: #52443C;
}

#wine_specs, .wine_specs {
	margin-top: 1.75em;
	border-top: 1px solid #B0ABA7;
	border-bottom: 1px solid #B0ABA7;
	font-style: italic;
	line-height: 1.5em;
	padding: 2em 0px 1.5em 0px;
}

#wine_specs dt, #wine_specs dd, .wine_specs dt, .wine_specs dd {
	width: 120px;
	float: left;
	margin-bottom: .5em;
}

#wine_specs dd, .wine_specs dd {
	width: calc(100% - 120px);
	color: #E51E25;
}

#product_techsheet {
	margin-top: 1.5em;
	font-size: 1.235294117647059em;
	font-style: italic;
}

#product_techsheet a {
	position: relative;
	padding-left: 1em;
	line-height: 1em;
}

#product_techsheet a:before {
	position: absolute;
	top: 0px;
	left: 0px;
	content: "\f15b";
	font-family: FontAwesome;
	font-size: .75em;
	line-height: 1.55em;
	font-style: normal;
	color: #B0ABA7;
}

#product_techsheet a:hover {
	color: #B0ABA7;
}

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

	#product_photo, .c7-product-detail__photo {
		float: right;
		width: 34.0909090909091%;
	}

	#product_description, .c7-product-detail__info {
		width: 58%;
	}

}

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

	#product_photo, .c7-product-detail__photo {
		margin-bottom: 2em;
	}

	#product_photo img, .c7-product-detail__photo img {
		width: auto;
		height: 400px;
		margin: 0px auto;
	}

}

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

	#product_buy {
		font-size: .75em;
	}

}

/* 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: FontAwesome;
	font-size: 20px;
	font-weight: normal;
	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: #FFFFFF;
	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: 700px) {

	#popup {
		padding: 30px;
	}

}

/* RESPONSIVE CSS */

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

	#nav_trigger {
		display: none;
	}

	#nav {
		position: absolute;
		top: 80px;
		left: 0px;
		width: 100%;
		height: auto;
	}

	.collapsed_temp #nav, .collapsed #nav {
		top: 24px;
	}

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

	.collapsed_temp #main_nav, .collapsed #main_nav {
		max-width: 1000px;
	}

	#main_nav > li {
		margin: 0px 10px;
		padding-bottom: 4px;
	}

	#main_nav > li#nav2, #main_nav > li#nav13 {
		margin: 0px 30px;
	}

	#main_nav li:hover, #main_nav li.active {
		border-bottom: 2px solid #E51E25;
	}

	#main_nav li.spacer {
		width: 400px;
		border: 0px;
	}

	.collapsed_temp #main_nav li.spacer, .collapsed #main_nav li.spacer {
		width: 100px;
	}

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

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

	#main_nav li li {
		border-bottom: 0px !important;
		text-align: center;
	}

	#main_nav li li a, #main_nav li.active li a {
		display: block;
		padding: 7px 15px;
		color: #F5F4ED;
	}

	#main_nav li li a:hover {
		color: #E51E25;
	}

	#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: 950px) and (max-width: 1299px) {

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

}

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

	#nav {
		top: 73px;
	}

	#main_nav {
		padding: 0px 3px;
		max-width: 1100px;
	}

	#main_nav > li {
		margin: 0px 10px;
		font-size: 16px;
	}

	#main_nav li.spacer {
		width: 300px;
	}

}

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

	.mobile_nav body {
		overflow: hidden;
	}

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

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

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

	.mobile_nav #nav_trigger:after, .mobile_nav #nav_trigger:before, .mobile_nav #nav_trigger span {
		background-color: #F5F4ED;
	}

	.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: #2D2825;
		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: 26px;
		line-height: 1em;
		text-align: center;
	}

	#nav li.spacer {
		display: none;
	}

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

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

	#nav li li a, #nav li.active li a {
		padding: 6px 30px;
		color: #F5F4ED;
	}

	#subnav, #back_link {
		height: 42px;
		position: relative;
		padding: 0px;
	}

	#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: FontAwesome;
		font-size: 20px;
		font-weight: normal;
		font-style: normal;
	}

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

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

	#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:first-child {
		padding-top: 10px;
	}

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

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

}
