nav, header, footer {
	display: block;
}

body, div, input, textarea, button, td, h1, h2, h3, h4 {
	font-family:  'Roboto', cursive, 'Arial', Helvetica, Verdana;
	font-size: 20px;
	line-height: 36px;
	color: #000;
	font-weight: 300;
}

body {
	margin: 0;
	background: #ffffff;
}

p {
	margin: 24px 0;
}

/* Stuff */
h1 {
	font-family: 'Playfair Display', cursive;
	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: 'Playfair Display', cursive;
	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: 'Playfair Display', cursive;
	font-size: 22px;
	line-height: 26px;
	color: #000;
	margin: 0;
	margin-bottom: 20px;
}

h4 {
	font-family: 'Playfair Display', cursive;
	font-size: 20px;
	line-height: 26px;
	color: #000;
	margin: 0;
	margin-bottom: 20px;
}

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: 1200px;
	margin: 0 auto;
}

#content {
	min-height: 700px;
	margin-bottom: 150px;
}

/* Headers */
#header {
	position: relative;
	height: 120px;
}

	#header .site {
		display: flex;
	}

	#languages {
		width: 33%;
		line-height: 120px;
	}

		#languages a {
			color: #c8c8c8;
			font-size: 18px;
			margin-right: 10px;
		}
		#languages a.current { color: #7e7e7e; }

	#logo {
		width: 33%;
		text-align: center;
		line-height: 120px;
	}

		#logo img {
			vertical-align: middle;
		}


	#social {
		width: 33%;
		text-align: right;
		line-height: 120px;
	}

		#social a {
			font-size: 24px;
			color: #b2b2b2;
			margin-left: 15px;
		}

		#social-head p.social-icons a:hover {
			color: #000;
		}

		#social a#cart-icon {
			position: relative;
			margin-left: 75px;
		}

#main-menu {
	display: block;
	background: #fff;
	height: 54px;
	line-height: 54px;
	text-align: center;
	border-top: 1px solid #e8e8e8;
	border-bottom: 1px solid #e8e8e8;
	position: relative;
}

#main-menu nav a {
	position: relative;
	display: inline-block;
	height: 54px;
	line-height: 54px;
	font-family: 'Playfair Display', 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 {
		background: #ffae00;
	}

#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 {
	height: 560px;
}

	.section.non-fixed {
		height: auto;
		padding:  50px 0;
	}

	.section.non-fixed .columns {
		align-items: center;
	}

		.section.non-fixed .text {
			padding-top: 0;
		}

.section .text { padding-top: 130px; }
.section .col-5-2 { position: relative; }

.section-main { 
	background: #f6f6f6;
	background: url('/elements/images/bkg-section-main.jpg') no-repeat;
	background-size: cover;
}

.section img { 
	position: absolute;
	top: -40px;
	left: 0;
	right: auto;
	margin-left: -50px;
}

.section.even img { 
	position: absolute;
	top: -40px;
	left: auto;
	right: 0;
	margin-left: -50px;
}

.section img.not-special {
	position: relative;
	top: 0;
	margin: 50px 0;
}


.section-1 {
	background: url('/elements/images/bkg-section1.jpg') no-repeat;
	background-size: cover;
}

.section-2, .section.even {
	background: #f6f6f6;
}

.section-3 {
	background: url('/elements/images/bkg-section3.jpg') no-repeat;
	background-size: cover;
}

.circle-image {
	position: relative;
	width: 300px;
	height: 300px;
	margin-top: 150px;
	border-radius: 150px;
	overflow: hidden;
}

.circle-image img {
	height: 300px;
	width: auto;
}

.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: 100;
	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: 2%;
}

	.product {
		box-sizing: border-box;
		width: 23.5%;
		text-align: center;
		background: #fff;
		margin-bottom: 30px;
	}

	/*
	.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 h1 {
	margin-bottom: 10px;
}

#product .actions {
	text-align: right;
	border-top: 1px solid #eee;
	margin: 20px 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-section {
	padding: 30px;
}

.product-details {
	margin-bottom: 20px !important;
}

.product-actions {
	padding: 30px;
	text-align: right;
}

.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; }

#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: #f8f8f8;
	min-height: 150px;
	margin-top: 50px;
	padding: 20px 0;
	color: #000;
	border-top: 1px solid #e8e8e8;
}

	#footer .footer-text {
		font-size: 16px;
		line-height: 20px;
	}

	#footer nav a {
		display: block;
		margin: 0;
		color: #5f6e76;
		font-size: 16px;
	}

	#footer nav a:hover {
		color: #000;
	}

	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;
}


