@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@300;700&display=swap');

*
{
 padding: 0;
 margin: 0;
 font-family: 'Montserrat', arial, sans-serif;
 font-size: 12pt;
 color: #000;
 box-sizing: border-box;
}

html
{
 overflow-y: scroll;
 min-height: 100%;
}

body
{
 height: 100%;
 margin: 0;
}

.center
{
 text-align: center !important;
}

.r
{
 text-align: right !important;
}

.float-right
{
 float: right;
}

.clr
{
 clear: both;
}

a
{
 text-decoration: none;
 font-size: inherit;
}

a:hover
{
 color: #000;
}

p
{
 margin-bottom: 20px;
 line-height: 1.75em;
}

.mobile-only {display: none;}

ul,
ol
{
 margin: 0 0 1.5em 1.5em;
 line-height: 1.75em;
}

small,
.small
{
 font-size: .8em;
}

input, textarea, select
{
 padding: 3px;
 outline: 0;
}

.fullwidth
{
 width: 100%;
}

.twocols
{
 display: inline-block;
 vertical-align: top;
 width: 48%;
 margin-right: 4%;
}

.twocols:nth-child(2n)
{
 margin-right: 0;
}

#cookie-popup
{
 position: fixed;
 bottom: 0;
 left: 0;
 width: 100%;
 background-color: #aaa;
 border-top: 1px solid #000;
 padding: 1em;
 color: #fff;
 text-align: center;
 z-index: 1000;
}

#cookie-popup p
{
 color: #fff;
}

#cookie-popup a
{
 color: inherit;
 text-decoration: underline;
}

/* */

#popup
{
 position: fixed;
 top: 0;
 left: 0;
 bottom: 0;
 right: 0;
 z-index: 10000;
 background-color: #333;
 background-color: rgba(0, 0, 0, 0.8);
}

#popup-content
{
 position: relative;
 margin: 10% auto;
 width: 1000px;
 max-width: 90%;
 max-height: 90%;
 box-sizing: border-box;
 background-color: #ffffff;
 padding: 40px 40px 20px 40px;
 overflow-y: auto;
}

#popup-close
{
 position: absolute;
 top: 0;
 right: 15px;
 color: #ffffff;
 font-size: 48px;
 cursor: pointer;
}

/* */

header
{
 width: 100%;
 top: 0;
 margin-bottom: 1em;
}

header > div.wrapper
{
 padding: 10px 20px 20px 20px;
}

#logo
{
 width: 200px;
 display: inline-block;
 margin: 20px 0;
}

.wrapper
{
 margin: 0 auto;
 max-width: 1100px;
 padding: 0 20px;
}

footer
{
 width: 100%;
 padding: 2em 0;
 text-align: center;
}

footer p
{
 color: #333;
 line-height: 1.75em;
}


#lang
{
 float: right;
 margin: 5px 0 0 20px;
 padding: 10px 0;
}

nav#menu {float: right; display: inline-block; text-align: right; margin-top: 20px;}
nav#menu > ul {list-style-type: none; clear: both; margin: 0; line-height: 1em;}
nav#menu > ul#menu2 {margin-top: .25em;}
nav#menu > ul > li {display: inline-block; padding: 0 1em 0 0; position: relative; font-size: 12pt;}
nav#menu > ul > li:last-child {padding: 0;}
nav#menu > ul > li:not(:last-child):after {content: ""; position: absolute; height: 1em; bottom: 0; right: .4em; border-left: 1px solid #999;}
nav#menu > ul > li > a {display: block; text-decoration: none; color: #333; padding-top: 5px; border: 0;}
nav#menu > ul > li > a:hover {color: #000;}
#menu-h {display: none; cursor: pointer;}
#menu-h > svg {fill: #888;}
#menu-h:hover > svg {fill: #000;}

.index-left
{
 display: inline-block;
 vertical-align: top;
 width: 36%;
 margin-right: 4%;
}

.index-left img
{
 width: 100%;
}

.index-right
{
 display: inline-block;
 vertical-align: top;
 width: 60%;
}

.ul
{
 border-bottom: 1px solid #666;
}

.index-cta a,
.index-cta2 a,
a.u
{
 text-decoration: none;
 background-image: linear-gradient(currentColor, currentColor);
 background-position: 0% 100%;
 background-repeat: no-repeat;
 background-size: 0 1px;
 padding-bottom: 3px;
 transition: background-size .5s ease-out;
}

.index-cta a:hover,
.index-cta2 a:hover,
a.u:hover
{
 background-size: 100% 1px;
 transition: background-size .5s ease-out;
}

.index-cta span,
.index-cta2 span
{
 padding: 3px 5px;
 border: 1px solid #333;
 font-size: inherit;
 color: inherit;
}

.index-cta2
{
 display: inline-block;
 vertical-align: top;
 width: 33.333333%;
 text-align: center;
 padding: 0 .5em;
}

ul.index-bullet
{
 list-style: none;
 margin-left: 0;
}

ul.index-bullet li
{
/* font-size: 18pt;*/
 margin-bottom: .5em;
}

.index-block
{
 background-color: #aaa;
 color: #fff;
 padding: 1em;
 margin-bottom: 1em;
 text-align: center;
}

.index-block h3
{
 font-size: 1.5em;
 color: #fff;
 text-transform: none;
}

.index-block p,
.index-block strong,
.index-block a
{
 color: #fff;
}

.hand
{
 height: 30px;
 vertical-align: middle;
 margin-left: .5em;
}

.gallery-slider
{
 width: 100%;
}

.gallery-slider > div
{
 width: 100%;
}

.gallery-slider img
{
 width: 100%;
}

#msg
{
 position: fixed;
 top: 0;
 right: 0;
 z-index: 110;
 width: 40%;
 max-width: 600px;
 margin: 10px;
 padding: 1.5em 3em;
 background-color: #aaa;
 color: #fff;
 cursor: pointer;
 border-radius: 2px;
 -webkit-box-shadow: 0px 3px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 5px 0px rgba(0, 0, 0, 0.12);
 -moz-box-shadow: 0px 3px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 5px 0px rgba(0, 0, 0, 0.12);
 box-shadow: 0px 3px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 5px 0px rgba(0, 0, 0, 0.12);
 text-align: center;
}

#msg::after
{
 content: "x";
 position: absolute;
 top: 5px;
 right: 10px;
 font-size: 12px;
}

#msg.warning
{
 color: #800;
}

#msg.error
{
 background-color: #800;
 color: #fff;
 font-weight: bold;
}

/* */

h1
{
 clear: both;
 text-transform: none;
 font-size: 18pt;
 margin: 0 0 1em 0;
 font-weight: 300;
}

h2
{
 clear: both;
 font-size: 16pt;
 margin: 0 0 .5em 0;
 font-weight: normal;
}

h3
{
 clear: both;
 text-transform: uppercase;
 font-size: 14pt;
 margin: .5em 0;
 font-weight: normal;
}

.button
{
 cursor: pointer;
 box-shadow: 0px 3px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 5px 0px rgba(0, 0, 0, 0.12);
 transition: box-shadow 280ms cubic-bezier(0.4, 0, 0.2, 1);
 -moz-osx-font-smoothing: grayscale;
 -webkit-font-smoothing: antialiased;
 font-size: 0.875rem;
 line-height: 2.25rem;
 font-weight: 500;
 letter-spacing: 0.04em;
 text-decoration: none;
 text-transform: uppercase;
 -webkit-tap-highlight-color: transparent;
 will-change: transform, opacity;
 display: inline-block;
 position: relative;
 box-sizing: border-box;
 min-width: 64px;
 height: 36px;
 padding: 0 16px;
 border: none;
 outline: none;
 text-align: center;
 webkit-user-select: none;
 -moz-user-select: none;
 -ms-user-select: none;
 user-select: none;
 -webkit-appearance: none;
 overflow: hidden;
 vertical-align: middle;
 border-radius: 2px;
 background-color: #aaa;
 color: #fff;
 margin-bottom: .5em;
}

.button:disabled,
.button:disabled:hover,
.button-disabled,
.button-disabled:hover
{
 background-color: #eee;
 color: #ccc;
 cursor: default;
}

.button:hover
{
 background-color: #888;
 color: #000;
}

.button-green
{
 background-color: #0d0;
}

.text-button
{
 cursor: pointer;
 font-size: 0.875rem;
 letter-spacing: 0.04em;
 text-decoration: none;
 text-transform: uppercase;
 color: #888;
 padding: 5px;
 border: 0;
 background-color: transparent;
}

.text-button:hover
{
 color: #000;
 background-color: #aaa;
}

.text-button-small
{
 font-size: .7rem;
}

.order-form label
{
 clear: both;
 font-size: 10pt;
}

.order-form input,
.order-form select,
.order-form textarea
{
 display: block;
 width: 100%;
 margin-bottom: 1em;
 border-top: 0;
 border-left: 0;
 border-right: 0;
 border-bottom: 1px solid #999;
}

.order-form input.err,
.order-form select.err
{
 border-bottom: 1px solid #f00;
}

.order-form textarea
{
 height: 4em;
}

.order-form input:focus,
.order-form select:focus,
.order-form textarea:focus
{
 border-bottom: 1px solid #090;
}

.order-qty
{
 width: 3em;
 text-align: center;
}

table.order-sums
{
 margin-bottom: 1em;
}

table.order-sums td
{
 padding: 5px 1em 5px 0;
}

table.order-sums td.right
{
 text-align: right;
}

#order-shipping,
#order-payment
{
 list-style: none;
 margin-left: 1em;
 text-indent: -1em;
}

#order-shipping > li,
#order-payment > li
{
 line-height: 1.3em;
 margin-bottom: .5em;
}


.cols-2
{
 display: inline-block;
 vertical-align: top;
 width: 48%;
 margin-bottom: 20px;
}

.cols-2:nth-child(odd)
{
 margin-right: 4%;
}

.cols-3
{
 display: inline-block;
 vertical-align: top;
 width: 31%;
 margin-bottom: 20px;
 margin-right: 3.5%;
}

.cols-3:nth-child(3n)
{
 margin-right: 0;
}

.button2 {color: #000; font-size: 1.3em; height: auto; padding: 10px 20px 8px 20px;}
.button2:hover {background-color: #888; color: #fff;}
.index-cta2 {width: 49%; padding: .5em .5em; background-color: #aaa; margin-bottom: 1em;}
.index-cta2:nth-child(even) {margin-left: 2%;}
.index-cta2 a {color: #fff; width: 100%;}

/* MEDIA QUERIES */

@media screen and (max-width: 940px)
{
 nav#menu > ul > li {font-size: 10pt;}

 .cols-3 {width: 48%; margin-right: 4%;}
 .cols-3:nth-child(3n) {margin-right: 4%;}
 .cols-3:nth-child(even) {margin-right: 0;}
}

@media screen and (max-width: 800px)
{
 .index-left, .index-right {display: block; width: 100%; margin-bottom: 1em;}
 .twocols {display: block; width: 100%; margin-right: 0; margin-bottom: 1em;}

 .cols-2 {display: block; width: 100%; margin-bottom: 20px;}
 .cols-2:nth-child(odd) {margin-right: 0;}
 .cols-3 {display: block; width: 100%; margin-bottom: 20px; margin-right: 0;}
 .cols-3:nth-child(3n) {margin-right: 0;}
 .cols-3:nth-child(2n) {margin-right: 0;}
}

@media screen and (max-width: 700px)
{
 .desktop-only {display: none;}
 .mobile-only {display: block;}

 h1 {margin: 0 0 .5em 0;}
 #menu-h {display: block; width: 35px; height: 35px; position: absolute; top: 20px; right: 20px; z-index: 100;}
 #menu-h > img {width: 100%; height: auto; cursor: pointer;}
 nav#menu {height: 0;}
 nav#menu > ul {display: none; list-style-type: none; background-color: #333; position: absolute; top: 0; left: 0; height: auto; z-index: 99; padding: 1em 0; margin-right: 0; width: 100%;}
 nav#menu > ul > li {display: block; text-align: left; padding: 1em 2em; font-size: 12pt; line-height: 2em;}
 nav#menu > ul > li:last-child {padding: 1em 2em;}
 nav#menu > ul > li > a {display: block; text-decoration: none; color: #fff;}
 nav#menu > ul > li > a:hover {color: #ccc;}
 nav#menu > ul > li:not(:last-child):after {display: none;}
 #msg {width: calc(100% - 20px); max-width: 100%; min-height: 100px;}
}

@media screen and (max-width: 600px)
{
 nav#menu > ul#menu2 {top: 12em;}
 nav#menu > ul > li {padding: .25em 2em;}
 nav#menu > ul > li:last-child {padding: .25em 2em;}
 .index-cta2 {width: 100%;}
 .index-cta2:nth-child(even) {margin-left: 0;}
 #popup-content {padding: 20px 20px 0 20px;}
 #popup-content {margin: 20% auto 10% auto;}
}

@media screen and (max-width: 500px)
{
 .index-cta2 {width: 100%;}
}

