nav,
header,
footer {
	display: block;
}

body,
div,
input,
textarea,
button,
td,
h1,
h2,
h3,
h4 {
	font-family: 'Roboto', serif, 'Arial', Helvetica, Verdana;
	font-size: 18px;
	line-height: 24px;
	color: #000;
	font-weight: 300;
}

body {
	margin: 0;
	background: #ffffff;
}

p {
	margin: 24px 0;
}

/* Stuff */
h1 {
	font-family: 'Old Standard TT', serif;
	font-size: 32px;
	line-height: 32px;
	font-weight: 400;
	margin: 0;
	margin-top: 0;
	margin-bottom: 24px;
	padding-bottom: 0;
	color: #000;
}

h1 span {
	font-size: 18px;
	color: #6f6f6f;
}


h2 {
	font-family: 'Old Standard TT', serif;
	font-size: 24px;
	line-height: 32px;
	font-weight: 400;
	margin: 0;
	margin-top: 0;
	margin-bottom: 24px;
	padding-bottom: 0;
	color: #000;
}

h3 {
	font-family: 'Old Standard TT', serif;
	font-size: 22px;
	line-height: 26px;
	color: #000;
	margin: 0;
	margin-bottom: 20px;
}

h4 {}

h5 {}

img {
	max-width: 100%;
	height: auto;
}

/*
.clearfix:after, .columns:after {
	content: "";
	display: table;
	clear: both;
}

.clear {
	clear: both;
}


.last {
	margin-right: 0 !important;
}

.last-row {
	margin-bottom: 0 !important;
}
*/

a:link,
a:visited {
	color: #a60000;
	text-decoration: none;
}

a:link:hover,
a:visited:hover {
	color: #000;
}

a img {
	border: 0;
}

a.button {
	background: #ffae00;
	display: inline-block;
	padding: 5px 15px;
	min-width: 150px;
	text-align: center;
	color: #000;
	border-radius: 6px;
}

a.button:hover {
	background: #ffbb28;
}

/*
a.button-link {
	display: inline-block;
	color: #e9faff;
	font-weight: 300;
	font-size: 16px;
	font-style: italic;
	background-image: linear-gradient(#64b6cc, #54a8c3);
	padding: 5px 10px;
	border-radius: 3px;
	box-shadow: 1px 1px 0 rgba(0, 0, 0, 0.4);
}
*/

hr {
	clear: both;
	font-size: 1px;
	border: 0;
	border-top: 1px solid #e8e8e8;
	margin: 20px 0;
}

hr.less {
	margin: 10px 0;
}

hr.more {
	margin: 50px 0;
}

hr.clean {
	border: none;
}


img.left {
	float: left;
	margin-right: 20px;
	margin-bottom: 10px;
}

.left {
	text-align: left !important;
}

.right {
	text-align: right !important;
}

.center {
	text-align: center !important;
}

.bold {
	font-weight: bold;
}

/* Containers */
.site {
	position: relative;
	max-width: 1400px;
	margin: 0 auto;
}

#content {
	padding-top: 101px;
	min-height: 700px;
	margin-bottom: 150px;
}

/* Headers */
#header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	height: 100px;
	display: flex;
	border-bottom: 1px solid #e8e8e8;
	background: #fff;
	z-index: 1000;
}

#logo {
	width: 20%;
	text-align: left;
	padding-left: 20px;
	line-height: 100px;
}

#logo img {
	vertical-align: middle;
}


#social {
	width: 20%;
	text-align: right;
	line-height: 100px;
	padding-right: 20px;
}

#social a {
	font-size: 24px;
	color: #b2b2b2;
	margin-left: 15px;
}

#social a:hover {
	color: #000;
}

#social a#cart-icon {
	position: relative;
	margin-left: 75px;
}

#main-menu {
	width: 80%;
	display: block;
	height: 100px;
	line-height: 100px;
	text-align: center;
	position: relative;
}

#main-menu nav a {
	position: relative;
	display: inline-block;
	height: 60px;
	line-height: 60px;
	margin: 20px 0;
	font-family: 'Old Standard TT', serif;
	font-size: 18px;
	font-weight: 400;
	padding: 0 15px;
	color: #000;
}

#main-menu nav a.shop {
	background: #f8f8f8;
}

/*
	#main-menu nav a.shop::before {
		/*position: absolute;
		top: -12px;
		right: -12px;

		font-family: 'Font Awesome 5 Free';
		font-style: normal;
		font-weight: 900;
		font-size: 16px;
		content: "\f07a";
		color: #505050;
		margin-right: 5px;

		/*
		background: #fff;
		box-shadow: 1px 1px 3px rgba(0, 0, 0, 0.2);
		height: 24px;
		width: 24px;
		line-height: 24px;
		border-radius: 12px;
	}*/

#main-menu .submenu {
	z-index: 2000;
	display: none;
	position: absolute;
	top: 54px;
	left: 0;
	width: 350px;
	padding: 0;
	background: #fff;
	text-align: left;
	border: 1px solid #e8e8e8;
}

#main-menu .submenu a {
	display: block;
}

#main-menu nav a:hover {
	border-bottom: 2px solid #ffc600;
}

#main-menu-mobile {
	display: none;
}


/* Columns */
.columns {
	display: flex;
	gap: 20px;
}

.columns.gappy {
	gap: 50px;
}

.columns.spread {
	gap: 75px;
}

.col {
	flex-grow: 1;
}

.columns .mid {}

.col-10-1 {
	width: 10%;
}

.col-10-9 {
	width: 90%;
}

.col-5-1 {
	width: 20%;
}

.col-5-2 {
	width: 40%;
}

.col-5-3 {
	width: 60%;
}

.col-5-4 {
	width: 80%;
}

.col-4-1 {
	width: 25%;
}

.col-3-1 {
	width: 33%;
}

.col-3-2 {
	width: 66%;
}

.col-2 {
	width: 50%;
}

/* Boxes */


/* Home Sections */
section {
	text-align: center;
	margin-top: 100px;
}

.slider {
	margin-top: -50px;
	/* height: 700px; */
	background-color: #000;
	/* overflow: hidden; */
	position: relative;
}

.slider .slide {
	/* position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0; */
	/* display: none; */
	height: 0;
	opacity: 0;
	overflow: hidden;
	/* opacity: 0; */
	background-color: #000;
	transition: height 0ms, opacity 500ms;
}

.slider .slide.active {
	/* display: block; */
	height: auto;
	opacity: 1;
	/* opacity: 1; */
	/* transition: ; */
}

	.slider .slide img {
		display: block;
		width: 100%;
		opacity: 0.5;
		/* transition: opacity 0.5s ease-out; */
	}

	/* .slider .slide:hover img {
		opacity: 1;
	} */

	.slider .slide .text {
		position: absolute;
		/* display: flex; */
		align-content: center;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		color: #fff;
		width: 100%;
		text-transform: uppercase;
		display: none;
		flex-wrap: wrap;
		/* align-items: center; */
		align-content: center;
	}

	.slider .slide.active .text {
		display: flex;
	}

	.slider .slide .text div {
		flex-grow: 1;
	}

	.slide .text .toptext {
		color: #fff;
	}

	.slide .text .main {
		font-size: 80px;
		line-height: 80px;
		color: #fff;
	}

	.slide .text a {
		color: #ffc600;
		font-size: 18px;
		font-weight: 400;
	}

.slider-nav {
	position: absolute;
	bottom: 20px;
	width: 100%;
	padding: 0;
	text-align: center;
	z-index: 100;
}

.slider-nav span {
	display: inline-block;
	width: 30px;
	height: 6px;
	margin: 0 2px;
	background: #fff;
	cursor: pointer;
}

.slider-nav span.active {
	background-color: #ffc600;
}

.home-categories {
	display: flex;
	flex-wrap: wrap;
	padding-top: 20px;
	justify-content: center;
}

.home-category {
	background: #000;
}

.home-category a {
	display: block;
	position: relative;
	color: #fff;
	text-transform: uppercase;
	font-size: 80px;
}

.home-category a img {
	opacity: 0.5;
	transition: opacity 0.5s ease-out;
}

.home-category a:hover {
	color: #fff;
}

.home-category a:hover img {
	opacity: 1;
}

.home-categories a span {
	display: block;
	position: absolute;
	width: 100%;
	top: 0;
	bottom: 0;
	line-height: 800px;
}

.page-head {
	background: #f6f6f6;
	padding: 50px 0;
	margin-bottom: 50px;
}

.page-head h1 {
	margin-bottom: 0;
}

.page-head p:last-child {
	margin-bottom: 0;
}

.page-head.breadcrumbs {
	padding: 10px 0;
}

.breadcrumbs>* {
	font-size: 14px;
	color: #aaa;
}

.breadcrumbs a {
	display: inline-block;
	color: #606060;
	margin: 0 5px;
}


.gallery {
	columns: 4;
	column-gap: 20px;
}

.gallery img {
	cursor: zoom-in;
	box-sizing: border-box;
	display: block;
	margin-bottom: 20px;
	box-shadow: 0 5px 8px rgba(0, 0, 0, 0.2);
}

#gallery-zoomed {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: #fff;
	z-index: 2000;
	text-align: center;
	box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.2);
}

#gallery-zoomed-thumbnails {
	background: transparent;
	box-sizing: border-box;
	position: absolute;
	left: 0;
	width: 10%;
	top: 0;
	bottom: 0;
	overflow-y: auto;
	z-index: 120;
}

#gallery-zoomed-thumbnails img {
	display: block;
	cursor: pointer;
	box-sizing: border-box;
	border: 2px solid #fff;
	border-bottom: 0;
}

#gallery-zoomed-thumbnails img:last-child {
	border-bottom: 2px solid #fff;
}

#gallery-zoomed-photo {
	z-index: 105;
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
}

#gallery-zoomed-photo img {
	position: relative;
	width: 100%;
	height: 100%;
	object-fit: contain;
	object-position: 50% 50%;
}

#gallery-zoomed-close {
	position: absolute;
	display: block;
	right: 10px;
	top: 10px;
	font-size: 28px;
	line-height: 32px;
	height: 32px;
	width: 32px;
	z-index: 150;
	cursor: pointer;
	background: #fff;
	box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.2);
	border-radius: 16px;
}

#gallery-store-availability {
	display: none;
	position: absolute;
	z-index: 120;
	right: 5px;
	bottom: 5px;
	background: rgba(0, 0, 0, 0.75);
	color: #fff;
	padding: 5px 10px;
	border-radius: 6px;
}

#map {
	margin-top: 50px;
}

#gmap {
	height: 600px;
}

/* Products List */
.products {
	display: flex;
	flex-wrap: wrap;
	column-gap: 20px;
}

.product {
	box-sizing: border-box;
	width: 420px;
	text-align: center;
	background: #fff;
	margin-bottom: 30px;
	flex-grow: 1;
	max-width: 500px;
}

/*
	.products-5 .product:nth-child(5n) { margin-right: 0; }
	.products-4 .product:nth-child(4n) { margin-right: 0; }
	.products-3 .product:nth-child(3n) { margin-right: 0; }
	*/
.product a.name {
	color: #000;
}

.product img {
	width: 100%;
	border-radius: 12px;
}


.shop h2 {
	margin-bottom: 0px;
}

.shop h2:not(:first-child) {
	margin-top: 30px;
}

.shop hr {
	margin: 10px 0;
	margin-bottom: 20px;
}

/* Product */
#product {
	margin-top: 50px;
}

#product h1 {
	margin-bottom: 10px;
}

#product .info {
	border-top: 1px solid #eee;
	margin: 30px 0;
	padding: 20px 0;
}

#product .actions {
	text-align: right;
	border-top: 1px solid #eee;
	border-bottom: 1px solid #eee;
	margin: 30px 0;
	padding: 20px 0;
}

#product .add-to-cart {
	display: block;
}

.add-to-cart .price {
	display: inline-block;
	padding: 0 20px;
	font-weight: 400;
	height: 40px;
	line-height: 40px;
}

.add-to-cart a {
	display: inline-block;
	height: 40px;
	padding: 0 20px;
	background: #ffae00;
	color: #000;
	font-weight: 700;
	text-transform: uppercase;
	font-size: 15px;
	line-height: 40px;
}

.add-to-cart a:hover {
	background: #ffae00;
}

#stock-notify {
	display: none;
	margin-top: 20px;
	border: 1px solid #eee;
	border-radius: 12px;
	padding: 20px;
}

#stock-notify p {
	margin: 0;
}

.fa-check {
	color: #4dc600;
}

.fa-times {
	color: #dd4d00;
}

.fa-exclamation-circle {
	color: #dd4d00;
}

.fa-info-circle {
	color: #ffae00;
}

#product img {
	display: block;
	width: 100%;
	height: auto;
}

#product .image img {
	border-radius: 12px;
	cursor: zoom-in;
}

#product .thumbnails {
	display: grid;
	grid-gap: 10px;
	grid-template-columns: repeat(6, 1fr);
	margin-top: 10px;
}

#product .thumbnails img {
	display: block;
	border-radius: 6px;
	cursor: pointer;
}

#product .images-thumbs img {
	width: 154px;
	height: auto;
	cursor: pointer;
	margin: 0;
	float: left;
	margin-right: 1px;
	margin-bottom: 1px;
	border-radius: 6px;
}

#product .product-action {
	background: #f8f8f8;
	padding: 20px;
	border-radius: 12px;
}

.buy-notice {
	font-size: 14px;
	line-height: 16px;
	margin-bottom: 10px;
	padding: 5px 10px;
	background: #f8f0f0;
	border-radius: 6px;
}

.buy-included {
	font-size: 14px;
	line-height: 16px;
	margin-bottom: 20px;
	padding: 5px 10px;
}

.buy-included ul {
	padding-top: 5px;
}

#product ul {
	margin: 0;
}

#product h2 {
	margin-bottom: 10px;
}

#product h3 {
	/* margin-bottom: 0; */
	margin-top: 10px;
}

#product p {
	margin-bottom: 0;
}

#product .description {
	text-align: center;
}

#product .specs {
	margin-top: 50px;
}

table.specs td {
	text-align: left;
	padding: 10px 20px;
	border-left: none;
	border-right: none;
}

.product-section {
	padding: 30px;
}

.product-details {
	margin-bottom: 20px !important;
}

.product-actions {
	padding: 30px;
	text-align: right;
}

.product-company {
	width: 80%;
	margin: 50px auto;
	border-top: 1px solid #e8e8e8;
	padding: 50px 0;
}

#product .product-company h1 {
	text-align: center;
	margin-top: 50px;
	margin-bottom: 50px;
}

.product-price {
	height: 54px;
	line-height: 54px;
	font-weight: 700;
	text-align: right;
}

.price-current {
	display: inline-block;
	margin-right: 10px;
}

.price-old {
	font-size: 16px;
	text-decoration: line-through;
	color: #bbb;
}

a.download {
	display: block;
	background-color: #77b600;
	border: 1px solid #76be70;
	height: 32px;
	line-height: 32px;
	border-radius: 6px;
	text-align: center;
	padding: 0 10px;
	color: #fff;
	font-size: 16px;
	font-weight: 400;
}

a.download:hover {
	color: #fff;
	background-color: #517c00;
}

a.download i {
	margin-right: 10px;
}

.var-colors {
	height: 50px;
	line-height: 50px;
}

.var-colors p {
	display: inline-block;
	font-size: 16px;
	border-right: 1px solid #eaeaea;
	padding: 0 20px;
	margin: 0;
	margin-right: 20px;
}

.var-color {
	vertical-align: middle;
	display: inline-block;
	width: 46px;
	height: 46px;
	border-radius: 6px;
	border: 2px solid #fff;
	cursor: pointer;
	text-align: center;
	line-height: 50px;
}

.var-color.selected {
	border-color: #000;
}

.var-color.disabled {}

.var-color i {
	color: #000;
}

.var-color i.fa-times {
	color: red;
}

.var-materials {
	display: flex;
	flex-wrap: 1;
	gap: 10px;
}

.var-material {
	display: block;
	width: 70px;
	height: 70px;
	border-radius: 36px;
	border: 1px solid #c2c2c2;
}

.share {
	display: flex;
	flex-wrap: wrap;
	text-align: center;
	gap: 20px;
}

.share h3 {
	flex: 0 0 100%;
}

.share a {
	display: inline-block;
	flex-grow: 1;
	color: #000;
}

.share a i {
	margin-right: 5px;
}

#cart-info-popup {
	display: none;
	box-sizing: border-box;
	position: fixed;
	width: 400px;
	height: max-content;
	text-align: center;
	left: 50%;
	top: 50%;
	margin-left: -200px;
	margin-top: - 50px;
	padding: 15px;
	background: #fff;
	border-radius: 12px;
	box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.2);
}

#cart-info-popup p {
	margin: 0;
}

#cart-info-popup a {
	display: inline-block;
	padding: 0 15px;
	border-right: 1px solid #ccc;
	line-height: 20px;
}

#cart-info-popup p a:last-child {
	border-right: none;
}


/* Shopping Cart and Ordering */
#cart-count {
	position: absolute;
	right: -8px;
	top: -8px;
	width: 16px;
	height: 16px;
	border-radius: 8px;
	background: #ffae00;
	font-size: 12px;
	line-height: 16px;
	text-align: center;
}

#order-progress {
	display: flex;
	height: 70px;
	margin: 10px 0;
}

.order-step {
	width: 10%;
}

.order-step .circle {
	display: inline-block;
	width: 40px;
	height: 40px;
	border-radius: 20px;
	background: #dedede;
	text-align: center;
	line-height: 40px;
	font-weight: 700;
	font-size: 14px;
}

.order-step .step-text {
	font-size: 16px;
}

.order-step .circle i {
	font-size: 20px;
	line-height: 40px;
}

.order-step.active .circle {
	background: #ffae00;
}

.order-step.active .step-text {
	font-weight: 700;
}

.order-connect {
	width: 35%;
}

.order-connect hr {
	border-top: 2px dashed #ccc;
	margin: 0;
	margin-top: 18px;
}

.order-id {
	font-family: 'Roboto';
	font-weight: 700;
}

td.price {
	text-align: right;
}

td.total {
	font-weight: 400;
}

td.grand-total {
	font-weight: 700;
}

td.image {
	line-height: 50px;
}

td.image img {
	width: 50px;
	height: auto;
	vertical-align: middle;
}

td.name {
	text-align: center;
}

td.status {
	text-align: center;
}

td.status div {
	display: inline-block;
	background: #ccc;
	font-size: 16px;
	padding: 5px;
	padding-right: 10px;
	border-radius: 6px;
	line-height: 16px;
	margin: 0 5px;
	white-space: nowrap;
}

td.status div span {
	display: inline-block;
	background: rgba(255, 255, 255, 0.5);
	/*width: 20px;*/
	height: 20px;
	border-radius: 6px;
	line-height: 20px;
	margin-right: 5px;
	padding: 0 5px;
}

td.status div.instock {
	background-color: #a8d983;
}

td.status div.preorder {
	background-color: #ffdc9b;
}

.cart-color {
	display: inline-block;
	width: 46px;
	height: 46px;
	border-radius: 6px;
	border: 2px solid #fff;
	vertical-align: middle;
}

.cart-options {
	text-align: center;
	margin-top: 50px;
}

#cart-customer {
	width: 800px;
	margin: 0 auto;
}

.notice {
	display: block;
	font-size: 18px;
	color: red;
}

button.cart-amount-adjust {
	display: inline-block;
	min-width: 24px;
	height: 24px;
	line-height: 24px;
	background: #f2f2f2;
	font-size: 16px;
	text-align: center;
	margin: 0 5px;
	border-radius: 3px;
	cursor: pointer;
	padding: 0 5px;
}

.fa-minus {
	color: #dd4d00;
}

.fa-plus {
	color: #4dc600;
}

/*.fa-calendar-plus { color: #4dc600; }*/

.hint {
	font-style: italic;
	font-size: 14px;
}

/* Categories */
.categories {
	min-height: 1px;
}

.categories a {
	display: block;
	color: #000;
	font-size: 16px;
}

.categories a i {
	font-size: 14px;
	color: #ccc;
	margin-right: 10px;
}

.categories a.current {
	font-weight: 700;
}

.categories h3 {
	margin-top: 30px;
}

.categories h3:first-child {
	margin-top: 0
}



.tooltip {
	position: relative;
	cursor: pointer;
}

.tooltip div {
	position: absolute;
	display: inline-block;
	visibility: hidden;
	width: 200px;
	font-size: 16px;
	line-height: 18px;
	text-align: center;
	background: #ffe1ae;
	padding: 5px 10px;
	border-radius: 6px;
	top: 100%;
	left: 50%;
	margin-top: 15px;
	margin-left: -110px;
	z-index: 500;
}

.tooltip:hover div {
	visibility: visible;
}



/* Article */
.date {
	text-align: right;
	font-style: italic;
	font-size: 14px;
}

/* Tables */
table {
	width: 100%;
	border-collapse: collapse;
}

thead td {
	background: #fafafa;
}

td {
	padding: 5px 10px;
	border: 1px solid #f2f2f2;
}

td.cart-adjust {
	width: 35px;
	text-align: center;
}

td.cart-amount {
	border-left: none;
	border-right: none;
}

td.cart-adjust-left {
	border-right: none;
}

td.cart-adjust-right {
	border-left: none;
}

/* Pagination */


/* Tags */


/* Footer */
#footer {
	background: #101010;
	min-height: 150px;
	margin-top: 50px;
	padding: 20px 50px;
	color: #fff1bf;
}

#footer div {
	color: #fff1bf;
}

#footer .footer-text {
	font-size: 16px;
	line-height: 20px;
}

#footer nav a {
	display: block;
	margin: 0;
	color: #fff1bf;
	font-size: 16px;
}

#footer nav a:hover {
	color: #fff;
}

nav#foot-social {
	margin-top: 10px;
	margin-bottom: 30px;
}

nav#foot-social a {
	display: inline-block;
	font-size: 32px;
	margin-left: 5px;
}

.copyright {
	margin-top: 20px;
	text-align: center;
	font-size: 14px;
}

.copyright i {
	color: #ffacb6;
	text-shadow: 0 1px 0 rgba(0, 0, 0, 0.5);
}

.foot-logo {
	height: 100px;
	width: auto;
}

/* Forms */
form {}

.set {
	display: flex;
	column-gap: 30px;
	margin-bottom: 20px;
}

.set label {
	width: 200px;
	text-align: right;
}

.set .options-set {
	flex-basis: 0;
	flex-grow: 1;
}

input,
textarea {
	box-sizing: border-box;
	width: 100%;
	border: 1px solid #cecece;
	border-radius: 6px;
	padding: 5px 10px;
	margin-bottom: 10px;
	background: rgba(0, 0, 0, 0.03);
	font-size: 16px;
}

textarea {
	height: 200px;
}

select {
	box-sizing: border-box;
	border: 1px solid #cecece;
	border-radius: 6px;
	padding: 5px 10px;
	margin-bottom: 20px;
	background: rgba(0, 0, 0, 0.03);
	font-size: 16px;
}

input[type="search"] {
	background: #fff url('/elements/images/search-icon.png') right 10px center no-repeat;
	border: 2px solid #b50000;
	width: 300px;
	border-radius: 6px;
	padding: 5px 10px;
	box-shadow: inset 1px 1px 5px rgba(0, 0, 0, 0.25);
	font-size: 18px;
}

input[type="submit"],
button {
	border: 0;
	background: #ffae00;
	display: inline-block;
	padding: 5px 15px;
	min-width: 150px;
	text-align: center;
	color: #000;
	border-radius: 6px;
	width: auto;
	font-size: 20px;
	font-weight: 300;
	margin: 0;
}

input[type="submit"]:hover,
button:hover {
	background: #ffbb28;
}


.note {
	text-align: center;
	text-transform: uppercase;
	font-weight: 700;
}