/*  -------------- Fonts -------------- */
/* Font License see 'OFL.txt' in folder */

@font-face {
  font-family: 'Aboreto';
  font-style: normal;
  font-weight: 400;
  src: url('../design/aboreto.eot'); /* IE9 */
  src: url('../design/aboreto?#iefix') format('embedded-opentype'), /* IE6-IE8 */
       url('../design/aboreto.woff2') format('woff2'), /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
       url('../design/aboreto.woff') format('woff'), /* Chrome 5+, Firefox 3.6+, IE 9+, Safari 5.1+, iOS 5+ */
       url('../design/aboreto.ttf') format('truetype'), /* Chrome 4+, Firefox 3.5+, IE 9+, Safari 3.1+, iOS 4.2+, Android 2.2+ */
       url('../design/aboreto.svg#Aboreto') format('svg'); /* Legacy iOS*/
}


/*  --------- General Settings --------- */

* {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  font-family: Roboto, Oxygen, Ubuntu, Helvetica, Arial, sans-serif;
  font-size: 16px;
}

html {
  height: 100%;
}

body {
  position: relative;
  min-height: 100%;
  color: #222222;
  background-color: rgb(238, 238, 238);
  margin: 0;
  padding-bottom: 100px;
  /* Same height as footer */
}

h1, h2, h3, h4, h5, .wheremax, .wheremed, .wheremin {
  font-family: 'Aboreto', Aboreto, Arial, Helvetica, sans-serif;
  color: rgb(147, 14, 14);
}

a {
  color: rgb(49, 14, 14); 
  text-decoration: none;
}

.content-wrapper {
  width: 1070px;
  margin: 0 auto;
  padding: 2px;
}

.content-wrapper.error {
  padding: 40px 0;
}

.headline {
  font-family: 'Aboreto', Aboreto, Arial, Helvetica, sans-serif;
  font-size: 16px;
  color: rgb(49, 14, 14);
}


/*  -------------- Header ------------- */

header {
  position: fixed;
  background-color: rgba(210, 210, 238, 0.7);
  border-bottom: 1px solid rgb(210, 210, 210);
  -webkit-box-shadow: 1px 1px 4px 0 rgba(0,0,0,0.2);
          box-shadow: 1px 1px 4px 0 rgba(0,0,0,0.2);
  color: rgb(49, 14, 14);
  width: 100%;
  z-index: 130;
}

header .content-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

header .logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  float: left;
  padding: 12px 2px 10px 0px;
  text-decoration: none;
}

header .brand {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  float: left;
  padding: 3px 48px 0px 8px;
  font-size: 24px;
  line-height: 1.15em;
  text-decoration: none;
  margin-right: 38px;
}


/* Menu at page top */

header .topmenu {
  clear: both;
  max-height: 0;
  -webkit-transition: max-height .2s ease-out;
  -o-transition: max-height .2s ease-out;
  transition: max-height .2s ease-out;
  font-family: 'Aboreto', Aboreto, Arial, Helvetica, sans-serif;
  padding: 0;
}

header ul { 
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
     -ms-flex-pack: center;
   justify-content: center;
  -webkit-box-align: center;
     -ms-flex-align: center;
        align-items: center;
  list-style: none;
  overflow: hidden;
  margin: 0;
}

header li a {
  display: block;
  text-decoration: none;
  list-style: none;
  border: 2px solid transparent;
  border-radius: 7px;
  margin-right: 12px;
  padding: 14px 11px 14px 11px;
  font-family: 'Aboreto', Aboreto, Arial, Helvetica, sans-serif;
  font-size: 17px;
  color: rgb(49, 14, 14);
}

header li a:hover {
  background-color: rgba(252, 252, 252, 0.5);
  border: 2px solid rgba(147,14,14,0.1);
     -moz-transition: all 0.7s ease;
  -webkit-transition: all 0.7s ease;
       -o-transition: all 0.7s ease;
          transition: all 0.7s ease;
  border-radius: 7px;
}

header .link-icons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
   -webkit-box-flex: 1;
  -ms-flex-positive: 1;
          flex-grow: 1;
  -ms-flex-preferred-size: 0;
               flex-basis: 0;
  -webkit-box-pack: end;
     -ms-flex-pack: end;
   justify-content: flex-end;
  -webkit-box-align: center;
     -ms-flex-align: center;
        align-items: center;
  position: relative;
}

header .link-icons .search i {
  font-size: 20px;
  padding: 16px 13px 12px 14px;
  cursor: pointer;
  color: rgb(49, 14, 14);
  border: 2px solid transparent;
  border-radius: 7px;
}

header .link-icons .search i:hover {
  background-color: rgba(252, 252, 252, 0.5);
  border: 2px solid rgba(147,14,14,0.1);
     -moz-transition: all 0.7s ease;
  -webkit-transition: all 0.7s ease;
       -o-transition: all 0.7s ease;
          transition: all 0.7s ease;
  border-radius: 7px;
}

header .link-icons .search input {
  font-family: 'Aboreto', Aboreto, Arial, Helvetica, sans-serif;
  font-size: 16px;
  display: none;
  background-color: rgba(252, 252, 252, 0.5);
  border: 2px solid rgba(147,14,14,0.1);
  border-radius: 7px;
  padding: 15px 4px 14px 6px;
  margin-right: 0px;
  max-width: 190px;
  outline: none;
  color: #222222;
}

header .link-icons .responsive-toggle {
  display: none;
}

header .link-icons a {
  position: relative;
  text-decoration: none;
  color: rgb(49, 14, 14);
  padding: 15px 13px 12px 10px;
  margin-left: 4px;
  border: 2px solid transparent;
  border-radius: 7px;
}

header .link-icons a:hover {
  background-color: rgba(252, 252, 252, 0.5);
  border: 2px solid rgba(147,14,14,0.1);
     -moz-transition: all 0.7s ease;
  -webkit-transition: all 0.7s ease;
       -o-transition: all 0.7s ease;
          transition: all 0.7s ease;
  border-radius: 7px;
}

header .link-icons a i {
  font-size: 20px;
}

header .link-icons a span {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
     -ms-flex-pack: center;
   justify-content: center;
  -webkit-box-align: center;
     -ms-flex-align: center;
        align-items: center;
  text-align: center;
  background-color: #63748e;
  background-color: #eea965;
  border-radius: 50%;
  color: #222222;
  font-size: 14px;
  width: 18px;
  height: 18px;
  font-weight: 500;
  position: absolute;
  top: 4px;
  right: 5px;
}

/* Navicon (Hamburger menu icon) is hidden,          */
/* if screen width is more than 1070px               */
/* Do NOT put 'display: none' instead of max-height! */

.menu-icon {
  display: none;
}
.menu-button {
  display: none;
}
.menu-button:checked ~ .topmenu {
  max-height: 260px;
}

/* Navicon position */

.menu-icon {
  cursor: pointer;
  display: block;
  padding: 44px 22px 6px 22px;
  position: relative;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}  

/* Navicon creation with CSS */

.menu-icon .navicon {
  background-color: rgb(49, 14, 14);
  display: block;
  height: 3px;
  position: relative;
  -webkit-transition: background-color .2s ease-out;
       -o-transition: background-color .2s ease-out;
          transition: background-color .2s ease-out;
  width: 20px;
}
.menu-icon .navicon::before,
.menu-icon .navicon::after {
  background-color: rgb(49, 14, 14);
  content: '';
  display: block;
  height: 100%;
  position: absolute;
  -webkit-transition: all .2s ease-out;
       -o-transition: all .2s ease-out;
          transition: all .2s ease-out;
  width: 100%;
}
.menu-icon .navicon::before {
  top: 6px;
}
.menu-icon .navicon::after {
  top: -6px;
} 
  
/* Navicon animation */

.menu-button:checked ~ .menu-icon .navicon {
  background-color: transparent;
}
.menu-button:checked ~ .menu-icon .navicon::before {
  -webkit-transform: rotate(-45deg);
      -ms-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
.menu-button:checked ~ .menu-icon .navicon::after {
  -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
          transform: rotate(45deg);
}
.menu-button:checked ~ .menu-icon:not(.steps) .navicon::before,
.menu-button:checked ~ .menu-icon:not(.steps) .navicon::after {
  top: 0;
}  


/*  ----------- Content-Body ------------ */

main {
  padding-top: 99px;
}

.products-form {
-webkit-box-pack: end;
   -ms-flex-pack: end;
 justify-content: flex-end;
}

.allproducts, .sortby, .category {
  font-family: Arial, Helvetica, sans-serif;
  font-size: 17px;
  color:#777777;
  padding-left: 12px;
}

main .featured {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
     -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  background-repeat: no-repeat;
  background-size: cover;
  height: 500px;
  -webkit-box-align: center;
     -ms-flex-align: center;
        align-items: center;
  -webkit-box-pack: center;
     -ms-flex-pack: center;
   justify-content: center;
  text-align: center;
}

main .featured h2 {
  display: inline-block;
  margin: 0;
  width: 1070px;
  font-family: Rockwell, "Courier Bold", Courier, Georgia, Times, "Times New Roman", sans-serif;
  font-size: 60px;
  color: #FFFFFF;
  padding-bottom: 10px;
}

main .featured p {
  display: inline-block;
  margin: 0;
  width: 1070px;
  font-size: 28px;
  color: #FFFFFF;
}

main .recentlyadded h2 {
  display: block;
  font-weight: normal;
  margin: 0;
  padding: 40px 0 10px 0;
  font-size: 24px;
  text-align: center;
  width: 100%;
}

main .recentlyadded .products, main .products .products-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
          -webkit-box-pack: center;
          -ms-flex-pack: center;
        justify-content: center;
border-radius: 12px;
padding-bottom: 12px;
margin-bottom: 20px;
}

/* Items displayed */
main .recentlyadded .products .product, main .products .products-wrapper .product  {
  width: auto;
  padding: 6px;
  margin: 24px 12px 10px 12px;
}

main .recentlyadded .products .product img, main .products .products-wrapper .product img {
  -webkit-transform: scale(1);
      -ms-transform: scale(1);
          transform: scale(1);
  -webkit-transition: -webkit-transform 1s;
  transition: -webkit-transform 1s;
  -o-transition: transform 1s;
  transition: transform 1s;
  transition: transform 1s, -webkit-transform 1s;
  border-radius: 7px;
}

/* Product name and padding to title */
main .recentlyadded .products .product .name, main .products .products-wrapper .product .name {
  display: block;
  max-width: 200px;
  height: 50px;
  font-size: 15px;
  color: #111111;
  padding: 8px 2px 2px 2px;
  overflow: hidden;
}

/* Price and padding to title */
main .recentlyadded .products .product .price, main .products .products-wrapper .product .price {
  display: block;
  padding: 10px 2px 4px 2px;
  color: #777777;
}

main .recentlyadded .products .product .rrp, main .products .products-wrapper .product .rrp {
  color: #999999;
  text-decoration: line-through;
}

main .recentlyadded .products .product:hover img, main .products .products-wrapper .product:hover img {
  -webkit-transform: scale(1.07);
      -ms-transform: scale(1.07);
          transform: scale(1.07);
  -webkit-transition: -webkit-transform 1s;
  transition: -webkit-transform 1s;
  -o-transition: transform 1s;
  transition: transform 1s;
  transition: transform 1s, -webkit-transform 1s;
  border-radius: 7px;
}

main .recentlyadded .products .product:hover .name, main .products .products-wrapper .product:hover .name {
  text-decoration: underline;
}
main > .product {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding-top: 20px;
}

main > .product h1 {
  font-size: 24px;
  font-weight: normal;
  margin: 0;
  padding-top: 20px;
}

main > .product .product-img-large, .back-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 500px;
}

main > .product .product-small-imgs {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: wrap;
      flex-flow: wrap;
}

main > .product .product-small-imgs .product-img-small {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-preferred-size: 31%;
      flex-basis: 31%;
      border: 2px solid transparent;
  cursor: pointer;
  margin: 12px 8px;
  border-radius: 7px;
}

.imgsize {
  width: 200px;
  height: auto;
}

main > .product .product-small-imgs .product-img-small:nth-child(1n) {
  margin-left: 0;
}

main > .product .product-small-imgs .product-img-small:nth-child(3n) {
  margin-right: 0;
}

main > .product .product-small-imgs .product-img-small.selected {
  border: 2px solid rgba(147,14,14,0.4);
  border-radius: 4px;
}

main > .product .product-img-small img {
  width: 100%;
  height: auto;
  -o-object-fit: contain;
     object-fit: contain;
     border-radius: 9px;
}

main > .product .product-imgs {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  padding: 16px 16px 0 0;
}

main > .product .product-wrapper {
  width: 460px;
  margin-left: 26px;
}

main > .product .prices {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

main > .product .price {
  display: block;
  font-size: 18px;
  color: #999999;
}

main > .product .rrp {
  color: #BBBBBB;
  text-decoration: line-through;
  font-size: 18px;
  padding-left: 10px;
}

main > .product form {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-flow: column;
          flex-flow: column;
  margin: 25px 0 40px 0;
}

main > .product form label {
  padding-bottom: 10px;
}

main > .product form select, main > .product form input[type="number"], main > .product form input[type="text"], main > .product form input[type="datetime-local"] {
  width: 100%;
  padding: 8px 10px;
  margin-bottom: 15px;
  border: 2px solid rgba(49, 14, 14, 0.4);
  background-color: rgba(252, 252, 252, 0.9);
  color: #777777;
  border-radius: 5px;
}

main > .product form .radio-checkbox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: wrap;
      flex-flow: wrap;
  max-width: 400px;
}

main > .product form .radio-checkbox input {
  margin: 0 10px 10px 0;
}

main > .product form .radio-checkbox label {
  padding-right: 15px;
}

main > .product form .btn {
  margin-top: 10px;
  width: 100%;
  text-transform: uppercase;
}

main > .products h1 {
  display: block;
  font-weight: normal;
  margin: 0;
  padding: 40px 0;
  font-size: 24px;
  text-align: center;
  width: 100%;
}

main > .products .products-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;

  -webkit-box-pack: end;
  -ms-flex-pack: end;
justify-content: flex-end;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-bottom: 40px;
}

main > .products .products-header p {
  margin: 0;
}

main > .products .products-header label {
  padding-left: 20px;
}

main > .products .products-header select {
  padding: 6px;
  margin-left: 15px;
  border: 2px solid rgba(49, 14, 14, 0.4);
  background-color: rgba(252, 252, 252, 0.9);
  color: #777777;
  border-radius: 7px;
}

main > .products .buttonline {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
     -ms-flex-pack: center;
   justify-content: center;
  -webkit-box-align: center;
     -ms-flex-align: center;
        align-items: center;
  padding: 6px 4px 32px 4px;
}

.where {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.wheremin {
  padding: 0 8px;
}
.wheremed {
  padding: 0 0 0 8px;
}
.wheremax {
  padding: 0 8px 0 0;
}

main .cart h1, main .myaccount h1 {
  display: block;
  font-weight: normal;
  margin: 0;
  padding: 40px 0;
  font-size: 24px;
  text-align: center;
  width: 100%;
}

main .cart table, main .myaccount table {
  width: 100%;
}

main .cart table thead td, main .myaccount table thead td {
  padding: 30px 0;
  border-bottom: 1px solid rgb(210, 210, 210);
}

main .cart table thead td:last-child, main .myaccount table thead td:last-child {
  text-align: right;
}

main .cart table tbody td, main .myaccount table tbody td {
  padding: 20px 0;
  border-bottom: 1px solid rgb(210, 210, 210);
}

main .cart table tbody td:last-child, main .myaccount table tbody td:last-child {
  text-align: right;
}

main .cart table .img, main .myaccount table .img {
  width: 80px;
}

main .cart table .remove, main .myaccount table .remove {
  color: #777777;
  font-size: 12px;
  padding-top: 3px;
}

main .cart table .remove:hover, main .myaccount table .remove:hover {
  text-decoration: underline;
}

main .cart table .price, main .cart table .options, main .myaccount table .price, main .myaccount table .options {
  color: #999999;
}

main .cart table .options, main .myaccount table .options {
  font-size: 14px;
  max-width: 200px;
}

main .cart table a, main .myaccount table a {
  text-decoration: none;
  color: #555555;
}

main .cart table input[type="number"], main .myaccount table input[type="number"] {
  width: 68px;
  padding: 10px;
  border-bottom: 1px solid rgb(210, 210, 210);
  color: #555555;
  border-radius: 4px;
}

main .cart .total, main .myaccount .total {
  text-align: right;
  padding: 30px 0 40px 0;
}

main .cart .total .text, main .myaccount .total .text {
  padding-right: 100px;
  font-size: 18px;
  color: rgb(147, 14, 14); 
}

main .cart .total .price, main .myaccount .total .price {
  font-size: 18px;
  color: rgb(147, 14, 14); 
}

main .cart .total .note, main .myaccount .total .note {
  display: block;
  padding-top: 15px;
  color: #999999;
}

main .cart .buttons, main .myaccount .buttons {
  text-align: right;
  padding-bottom: 40px;
}

main .cart .buttons .btn, main .myaccount .buttons .btn {
  margin: 0 0 10px 5px;
}

main .placeorder h1 {
  display: block;
  font-weight: normal;
  margin: 0;
  padding: 40px 0;
  font-size: 24px;
  text-align: center;
  width: 100%;
}

main .placeorder p {
  text-align: center;
}

main .checkout h1, main .myaccount h1 {
  display: block;
  font-weight: normal;
  margin: 0;
  padding: 40px 0;
  font-size: 24px;
  text-align: center;
  width: 100%;
}

.loginlink {
  color:rgb(147, 14, 14);
}

.loginlink:hover {
  text-decoration: underline;
}

main .checkout .shipping-details, main .myaccount .shipping-details {
  width: 600px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: wrap;
      flex-flow: wrap;
  padding-bottom: 40px;
}

main .checkout .shipping-details h2, main .myaccount .shipping-details h2 {
  width: 100%;
  font-weight: normal;
  font-size: 20px;
  padding: 30px 0 20px 0;
  margin: 0 0 10px 0;
  border-bottom: 1px solid rgb(210, 210, 210);
}

main .checkout .shipping-details h2:first-child, main .myaccount .shipping-details h2:first-child {
  padding: 20px 0 20px 0;
}

main .checkout .shipping-details label, main .myaccount .shipping-details label {
  display: block;
  padding: 15px 0 10px 0;
}

main .checkout .shipping-details .row1, main .checkout .shipping-details .row2, main .myaccount .shipping-details .row1, main .myaccount .shipping-details .row2 {
  width: 50%;
  display: inline-block;
}

main .checkout .shipping-details .row1, main .myaccount .shipping-details .row1 {
  padding-right: 10px;
}

main .checkout .shipping-details .row1b, main .myaccount .shipping-details .row1b{
  width: 20%;
  display: inline-block;
  padding-right: 10px;
}  

main .checkout .shipping-details .row2, main .myaccount .shipping-details .row2 {
  padding-left: 10px;
}

main .checkout .shipping-details .rowextra, main .myaccount .shipping-details .rowextra {
  width: 50%;
  display: inline-block;
  padding: 57px 10px 10px 10px;
}

main .checkout .container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}

main .checkout .shipping-details {
  margin-right: 25px;
  width: 100%;
}

main .checkout .payment-methods {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: wrap;
      flex-flow: wrap;
  width: 100%;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

main .checkout .payment-methods label {
  text-decoration: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-bottom: 1px solid rgb(210, 210, 210);
  border-radius: 5px;
  height: 60px;
  width: 159px;
  margin: 10px;
  font-weight: 500;
  color: #434f61;
  padding: 0;
  cursor: pointer;
}

main .checkout .payment-methods label .fa-stripe {
  color: #6671E4;
}

main .checkout .payment-methods label:nth-child(2), main .checkout .payment-methods label:nth-child(8) {
  margin-left: 0;
}

main .checkout .payment-methods label:nth-child(3n) {
  margin-right: 0;
}

main .checkout .payment-methods label:hover {
  border-bottom: 1px solid rgb(210, 210, 210);
}

main .checkout .payment-methods input {
  position: absolute;
  top: -9999px;
  left: -9999px;
  visibility: hidden;
}

main .checkout .payment-methods input:checked + label {
  border: 2px solid #7ed1a1;
}

main .checkout .cart-details {
  width: 90%;
  -webkit-box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.15);
          box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.15);
  border-radius: 4px;
  margin-left: 25px;
  margin-bottom: 50px;
}

main .checkout .cart-details h2 {
  margin: 0;
  padding: 23px 15px;
  font-weight: 500;
  border-bottom: 1px solid rgb(210, 210, 210);
}

main .checkout .cart-details table {
  width: 100%;
  padding: 20px;
}

main .checkout .cart-details table .price {
  text-align: right;
  font-weight: 500;
}

main .checkout .cart-details table td {
  padding: 5px;
}

main .checkout .cart-details .discount-code {
  padding: 0 23px 23px 23px;
}

main .checkout .cart-details .discount-code .result {
  display: block;
  padding-top: 10px;
}

main .checkout .cart-details .shipping-methods {
  border-bottom: 1px solid rgb(210, 210, 210);
  padding: 23px;
}

main .checkout .cart-details .shipping-methods h3 {
  margin: 0;
  padding: 0 0 10px;
  font-weight: 500;
}

main .checkout .cart-details .shipping-methods .shipping-method {
  padding-top: 10px;
  margin: 0;
}

main .checkout .cart-details .total {
  border-bottom: 1px solid rgb(210, 210, 210);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
     -ms-flex-pack: justify;
   justify-content: space-between;
  padding: 23px;
  font-size: 18px;
  font-weight: 500;
  color: rgb(147, 14, 14);
}

main .checkout .cart-details .alt {
  font-size: 14px;
  color: #a6aab1;
  padding-left: 5px;
}

main .checkout .cart-details .summary {
  border-bottom: 1px solid rgb(210, 210, 210);
  padding: 23px 0;
}

main .checkout .cart-details .summary div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 10px 23px;
}

main .checkout .cart-details .summary div span {
  font-size: 14px;
  font-weight: 500;
}

main .checkout .cart-details .summary .discount span {
  color: #de0000;
}

main .checkout .cart-details .buttons {
  margin: 0 23px 23px 23px;
}

main .checkout .cart-details .buttons .btn {
  width: 100%;
}

main .myaccount {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: wrap;
      flex-flow: wrap;
}

main .myaccount .menu {
  padding-right: 35px;
  width: 300px;
}

main .myaccount .menu a {
  display: block;
  text-decoration: none;
  color: #888888;
  padding: 8px 0 18px 0;
  border-bottom: 1px solid rgb(210, 210, 210);
}

main .myaccount .menu .menu-item {
  padding: 18px 0;
}

main .myaccount .menu a:hover {
  color: #3c3c3c;
}

main .myaccount .myorders, main .myaccount .mydownloads, main .myaccount .settings {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  padding-bottom: 50px;
}

main .myaccount .myorders .order {
  -webkit-box-shadow: 0px 0px 4px 0px rgba(0, 0, 0, 0.15);
          box-shadow: 0px 0px 4px 0px rgba(0, 0, 0, 0.15);
  margin: 30px 0 30px 0;
}

main .myaccount .myorders .order .order-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  border-bottom: 1px solid rgb(210, 210, 210);
}

main .myaccount .myorders .order .order-header > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 15px;
}

main .myaccount .myorders .order .order-header > div div {
  padding-right: 35px;
}

main .myaccount .myorders .order .order-header > div div:last-child {
  padding-right: 0;
}

main .myaccount .myorders .order .order-header > div div span {
  display: block;
  font-size: 14px;
}

main .myaccount .myorders .order .order-items {
  padding: 15px;
}

main .myaccount .myorders .order .order-items table {
  margin: 0;
  padding: 0;
}

main .myaccount .settings form {
  max-width: 400px;
}

main .myaccount .settings form .btn {
  margin-top: 25px;
}

main .myaccount form {
  width: 100%;
}

main .myaccount h2 {
  width: 100%;
  font-weight: normal;
  font-size: 20px;
  padding: 30px 0 20px 0;
  margin: 0 0 10px 0;
  border-bottom: 1px solid rgb(210, 210, 210);
}

main .myaccount table {
  padding-bottom: 40px;
}

main .myaccount table tr:last-child td {
  border-bottom: 0;
}

main .myaccount table a {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 40px;
  border-bottom: 1px solid rgb(210, 210, 210);
  border-radius: 4px;
  padding: 0 10px;
  font-size: 14px;
  color: #de0000;
  margin: 0 5px 5px 0;
}

main .myaccount table a:hover {
  color: #ab0000;
}

main .myaccount table a i {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-item-align: center;
      -ms-grid-row-align: center;
      align-self: center;
  padding-right: 10px;
  margin-right: 10px;
  height: 100%;
  border-bottom: 1px solid rgb(210, 210, 210);
}

main .myaccount table .name {
  word-break: break-all;
}

main .myaccount .login-register {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  margin-top: 36px;
}

main .myaccount .login-register h1 {
  text-align: left;
  padding-top: 2px;
}

main .myaccount .login-register .login, main .myaccount .login-register .register {
  width: 100%;
  padding-left: 45px;
  padding-right: 45px;
}

main .myaccount .login-register .btn {
  margin-top: 25px;
}

main p.error {
  color: red;
}


/*  -------------- Images ------------- */

.img-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7);
}

/* padding 0px 60px and background white for a white picture frame */

.img-modal div {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
     -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-flow: column;
          flex-flow: column;
  width: 640px;
  height: 640px;
  max-width: 90%;
  max-height: 90%;
  top: 60%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  background-color: rgba(255, 255, 255, 0);
  padding: 0;
  border-radius: 24px;
}

.img-modal div a {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-item-align: end;
           align-self: flex-end;
  text-decoration: none;
  font-size: 24px;
  line-height: 60px;
  color: rgb(147, 147, 154, 1);
}

.img-modal div a:hover {
  color: rgb(42, 42, 49, 0.9);
}

.img-modal div img {
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}


/*  ------------- Buttons ------------ */

.btn {
  text-decoration: none;
  background-color: rgb(77, 77, 84, 0.9);
  border: 0;
  color: #ffffff;
  padding: 11px 16px;
  font-size: 14px;
  font-weight: 500;
  border-radius: 4px;
  cursor: pointer;
}

.btn:hover {
  background-color: rgb(42, 42, 49, 0.9);
     -moz-transition: all 0.5s ease;
  -webkit-transition: all 0.5s ease;
       -o-transition: all 0.5s ease;
          transition: all 0.5s ease;
}

.btn:disabled {
  background: #dddddd;
}

.btngoto {
  padding: 7px 45px;
  user-select: none;
  -webkit-box-shadow: 4px 4px 4px 0 rgba(0,0,0,0.4);
  box-shadow: 4px 4px 4px 0 rgba(0,0,0,0.4); 
  border: 2px solid transparent;
  border-radius: 9px;
  font-family: 'Aboreto', Aboreto, Arial, Helvetica, sans-serif;
  font-size: 17px;
  color: rgb(49, 14, 14, 0.9);
  background-color: rgba(210, 210, 238, 0.7);
}

.btngoto:hover {
  border: 2px solid rgba(147,14,14,0.2);
     -moz-transition: all 0.7s ease;
  -webkit-transition: all 0.7s ease;
       -o-transition: all 0.7s ease;
          transition: all 0.7s ease;
  border-radius: 9px;
  color: rgb(49, 14, 14, 1);
  background-color: rgba(252, 252, 252, 0.3);
}


/*  -------------- Form -------------- */

.form-label {
  display: block;
  padding: 20px 0 10px 0;
}

.form-field {
  width: 100%;
  padding: 10px;
  border: 2px solid rgba(49, 14, 14, 0.4);
  background-color: rgba(252, 252, 252, 0.9);
  color: #777777;
  border-radius: 5px;
}




/*  -------------- Slider -------------- */
/* max. 12 Slides - for more modify CSS */

#img-1, #img-2, #img-3, #img-4, #img-5, #img-6, #img-7, #img-8, #img-9, 
#img-10, #img-11, #img-12 { display: none; }

.back-container {
  position: relative;
  margin: 0;
  padding: 0;
  width: 48px;
  height: 500px;
  user-select: none;
  -webkit-box-shadow: 4px 4px 4px 0 rgba(0,0,0,0.4);
  box-shadow: 4px 4px 4px 0 rgba(0,0,0,0.4); 
  border: 2px solid transparent;
  border-radius: 9px;
  font-family: 'Aboreto', Aboreto, Arial, Helvetica, sans-serif;
  font-size: 17px;
  color: rgb(49, 14, 14, 0.7);
  background-color: rgba(210, 210, 238, 0.7);
}

.back-container:hover {
  border: 2px solid rgba(147,14,14,0.1);
     -moz-transition: all 0.7s ease;
  -webkit-transition: all 0.7s ease;
       -o-transition: all 0.7s ease;
          transition: all 0.7s ease;
  border-radius: 9px;
  color: rgb(147, 14, 14, 1);
  background-color: rgba(252, 252, 252, 0.3);
}

.textrotate {
  font-family: 'Aboreto', Aboreto, Arial, Helvetica, sans-serif;
  font-size: 18px;
  text-decoration: none;
  background-color: transparent;
  color: rgb(49, 14, 14, 0.7);
  transform: rotate(-90deg);
}

.textrotate:hover {
  text-decoration: none;
  background-color: transparent;
  color: rgb(49, 14, 14, 1);
}

.presentation-container {
    position: relative; /* without this line, resizing smoothly */
		align-items: stretch;
    margin: 0 auto;
    width: 500px;
    height: 500px;
	  user-select: none;
	}
  .presentation-container .slide_img {
    position: absolute;
	}

  .presentation-container .slide_img img {     
    width: 100%;
    height: 100%;
    -webkit-box-shadow: 4px 4px 4px 0 rgba(0,0,0,0.2);
            box-shadow: 4px 4px 4px 0 rgba(0,0,0,0.2); 
		border-radius: 9px;
  }

  .prev, .next {
    position: absolute;
		width: 100%;
		height: 100%;
		transition: 0.4s;
		cursor: pointer;
		text-align: center;
		color:rgba(244, 244, 244, 0.9);
    border-radius: 9px;
		z-index: 99;
	}

	.next { right: 0; }
	.prev { left:  0; }

  .presentation-container .slide_img label span {
		position: absolute;
    top: 5px;
    right: 9px;
		font-size: 77px;
	}

	.prev:hover, .next:hover {
		transition: 0.3s;
    color:#ffffff;
		background-color: rgba(47, 47, 47, 0.3);
	}

.slide_img { z-index: -1; }

	 #img-1:checked ~ #slide_1,
	 #img-2:checked ~ #slide_2,
	 #img-3:checked ~ #slide_3,
	 #img-4:checked ~ #slide_4,
	 #img-5:checked ~ #slide_5,
	 #img-6:checked ~ #slide_6,
	 #img-7:checked ~ #slide_7,
	 #img-8:checked ~ #slide_8,
	 #img-9:checked ~ #slide_9,
	#img-10:checked ~ #slide_10,
	#img-11:checked ~ #slide_11,
	#img-12:checked ~ #slide_12
	{ z-index: 9; animation: scroll 0.3s ease-in-out; }

@keyframes scroll { 
	  0% { opacity: 0.4; }
	100% { opacity: 1; }
}		


/* Thanks for ordering - Slider with random photo choice */

#thankscontainer {
  width: 100%; 
  overflow: hidden;
  margin: 40px auto;
  background: transparent;
 }

/* photo size 350px to 233px */
.showphoto {
  width: 350px;
  height: 233px;
 }

/* photobanner */
.photobanner {
height: 240px;
width: 6550px;
}


/* keyframe animations */
.first {
-webkit-animation: bannermove 80s linear infinite;
   -moz-animation: bannermove 80s linear infinite;
    -ms-animation: bannermove 80s linear infinite;
     -o-animation: bannermove 80s linear infinite;
        animation: bannermove 80s linear infinite;
}

@keyframes bannermove {
  0% { margin-left: 0px; }
  100% { margin-left: -2125px; }
}

@-moz-keyframes bannermove {
  0% { margin-left: 0px; }
  100% { margin-left: -2125px; }
}

@-webkit-keyframes bannermove {
  0% { margin-left: 0px; }
  100% { margin-left: -2125px; }
}

@-ms-keyframes bannermove {
  0% { margin-left: 0px; }
  100% { margin-left: -2125px; }
}

@-o-keyframes bannermove {
  0% { margin-left: 0px; }
  100% { margin-left: -2125px; }
}


/*  -------------- Footer ------------- */

footer {
  position: absolute;
  bottom: 0;
  border-top: 1px solid rgb(210, 210, 210);
  -webkit-box-shadow: 1px 1px 6px 0 rgba(0,0,0,0.4);
          box-shadow: 1px 1px 6px 0 rgba(0,0,0,0.4);
  padding: 9px 14px;
  width: 100%;
  background-color: rgba(210, 210, 238, 0.7);
  z-index: 130;
}

footer a {
  text-decoration: none;
  padding: 16px 16px;
  color: rgb(49, 14, 14);
  border: 2px solid transparent;
  border-radius: 7px;
  font-size: 18px;
}

footer a:hover {
  background-color: rgba(252, 252, 252, 0.5);
  border: 2px solid rgba(147,14,14,0.1);
     -moz-transition: all 0.7s ease;
  -webkit-transition: all 0.7s ease;
       -o-transition: all 0.7s ease;
          transition: all 0.7s ease;
  border-radius: 7px;
}


/*  -------- Responsive Change -------- */
/* if screen's width is smaller 1070px  */

@media only screen and (max-width: 1070px) {
  .rhide {
    display: none;
  }
  .content-wrapper {
    width: 100%;
    padding: 2px 10px;
  }
  header {
    -webkit-box-pack: justify;
       -ms-flex-pack: justify;
     justify-content: space-between;
  }
  header h1 {
    font-size: 16px;
    -ms-flex-preferred-size: auto;
                 flex-basis: auto;
  }

  header .topmenu {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
       -ms-flex-pack: center;
     justify-content: center;
    -webkit-box-align: center;
       -ms-flex-align: center;
          align-items: center;
    list-style: none;
    margin: 0;
    position: absolute;
    left: 0px;
    top: 100%;
    width: 100%;
    background-color: rgba(210, 210, 238, 0.7);
    border-bottom: 1px solid rgb(210, 210, 210);
    -webkit-box-shadow: 1px 1px 4px 0 rgba(0,0,0,0.2);
            box-shadow: 1px 1px 4px 0 rgba(0,0,0,0.2);
  }
  header li a {
    display: block;
    white-space: nowrap;
    text-decoration: none;
    color: rgb(49, 14, 14);
    list-style: none;
    border: 2px solid transparent;
    border-radius: 7px;
    margin: 16px 16px 13px 16px;
    padding: 14px 11px;
  }
  header li a:hover {
    background-color: rgba(252, 252, 252, 0.5);
    border: 2px solid rgba(147,14,14,0.1);
       -moz-transition: all 0.7s ease;
    -webkit-transition: all 0.7s ease;
         -o-transition: all 0.7s ease;
            transition: all 0.7s ease;
    border-radius: 7px;
  }

  header .link-icons {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    width: 100px;
  }
  header .link-icons .responsive-toggle {
    display: block;
  }

  /*  ---------- main content ----------- */

  main {
    padding-top: 99px;
    z-index: 110;
  }  

  main .recentlyadded .products, main .products .products-wrapper {
    -webkit-box-pack: center;
       -ms-flex-pack: center;
     justify-content: center;
  }

  .sortby {
    padding-right: 29px;
  }

  /* Padding around product pictures */
  main .recentlyadded .products .product, main .products .products-wrapper .product {
    width: auto;
    padding: 6px;
    margin: 24px 12px 10px 12px;
  }
  main .featured {
    height: 320px;
  }
  main .featured .slideshow {
    height: 320px;
  }
  main .featured .slidetext {
    height: 320px;
  }
  main .featured h2 {
    font-size: 48px;
    width: 100%;
    padding: 0 10px;
  }
  main .featured p {
    font-size: 22px;
    width: 100%;
    padding: 0 10px;
  }
  main > .products .products-header {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-flow: column;
            flex-flow: column;
  }
  main > .products .products-header p {
    padding-bottom: 10px;
  }
  main > .products .products-header form {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-flow: column;
            flex-flow: column;
  }
  main > .products .products-header form label {
    padding-top: 15px;
  }

  main > .product {
    padding: 0 8px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-flow: column;
            flex-flow: column;
  }
  main > .product .product-imgs {
    display: block;
    padding: 48px 16px 0 0;
  }
  main > .product .product-imgs .product-img-large {
  -webkit-box-align: start;
     -ms-flex-align: start;
        align-items: flex-start;
    width: 470px;
    height: 450px;
    margin: 0 auto;
  }
  .back-container {
    width: 40px;
    height: 424px;
    margin-right: 6px;
    font-size: 15px;
    color: rgb(49, 14, 14, 1);
  }
  .presentation-container .slide_img label span {
		position: absolute;
    top: 4px;
    right: 8px;
		font-size: 68px;
	}
  main > .product .product-imgs .product-small-imgs .product-img-small {
    height: 16%;
    -ms-flex-preferred-size: 16%;
        flex-basis: 16%;
    margin: 0 auto;
    border-radius: 7px;
  }
  main > .product form input[type="number"], main > .product form input[type="text"], main > .product form input[type="datetime-local"], main > .product form input[type="submit"], main > .product form select {
    width: 100%;
  }
  main > .product .product-wrapper { 
    margin: 0 auto;
    width: 460px;
    padding: 0;
  }
  main .cart table input[type="number"] {
    width: 40px;
  }
  main .checkout .container, main .myaccount .container {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-flow: column;
            flex-flow: column;
  }
  main .checkout .shipping-details .payment-methods, main .myaccount .shipping-details .payment-methods {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-flow: column;
            flex-flow: column;
  }
  main .checkout .shipping-details .payment-methods label, main .myaccount .shipping-details .payment-methods label {
    margin: 0 0 10px 0;
  }
  main .checkout .cart-details, main .myaccount .cart-details {
    margin: 0 0 40px 0;
    width: 100%;
  }
  main .checkout form, main .myaccount form {
    width: 100%;
  }
  main .myaccount .login-register {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-flow: column;
            flex-flow: column;
  }
  main .myaccount .login-register .login {
    border-right: 0;
    padding: 2px 10px 20px 10px;
  }
  main .myaccount .login-register .register {
    padding: 60px 10px 20px 10px;
  }
  main .myaccount .menu {
    width: 100%;
    padding-right: 0;
  }
}


/*  Navicon disappears, when screen width is bigger than 1070px */

@media only screen and (min-width: 1071px) {
  header .topmenu {
    clear: none;
    float: right;
    max-height: none;
  }
  .menu-icon {
    display: none;
  }
}


/*  Border has picturs when screen is bigger 1366px */

@media only screen and (min-width: 1367px) {
  html {
    width: 1080px;
    margin: 0 auto;
    background-image: url(background.jpg);
    background-position: center;
    background-size: cover;
    background-size: 100vmax;
  }
  header {
    width: 1080px;
    margin: 0 auto;
    -webkit-box-shadow: 2px 2px 7px 0 rgba(0,0,0,0.2);
            box-shadow: 2px 2px 7px 0 rgba(0,0,0,0.2);
    border-bottom-left-radius: 14px;
    border-bottom-right-radius: 14px;
  }
  footer {
    width: 1080px;
    margin: 0 auto;
    -webkit-box-shadow: 2px -2px 7px 0 rgba(0,0,0,0.2);
            box-shadow: 2px -2px 7px 0 rgba(0,0,0,0.2);
    border-top-left-radius: 14px;
    border-top-right-radius: 14px;
  }
}


/* Hiding total page number on the products if width is smaller than 730px */

@media only screen and (max-width: 730px) {
  .wheremax {
    display: none;
  }
}


/* No brand name (only logo is shown) if width is smaller than 630px  */
/* Menu and footer gets smaller  */

@media only screen and (max-width: 630px) {
  header .brand  {
    display: none;
    position: absolute;
    left: 0;
    top: 100%;
  }
  header li a {
    display: block;
    white-space: nowrap;
    text-decoration: none;
    list-style: none;
    border: 2px solid transparent;
    border-radius: 7px;
    margin: 8px 3px 7px 3px;
    padding: 14px 11px;
  }
  footer {
    padding: 9px 11px 9px 14px;
    width: 100%;
  }
}


/* Hiding total page number on the products page when width is smaller than 730px */

@media only screen and (max-width: 730px) {
  .wheremax {
    display: none;
  }
}


/* Optional menu gets smaller, when screen smaller 520px (because of admin link) 
@media only screen and (max-width: 520px) { 
  header li a {
    margin: 6px 1px 4px 0px;
    padding: 14px 6px;
    font-size: 14px;
  }
}
*/


/* Hiding the word 'page' on the products page when width is smaller than 500px */
/* Bigger image (because there will be only one in a row) */

@media only screen and (max-width: 500px) {
  .wheremax, .wheremed {
    display: none;
  }
  .imgsize {
    width: 260px;
    height: auto;
  }
}


/* Presentation picture gets smaller, when screen smaller 480px */

@media only screen and (max-width: 480px) { 
  main .product .product-imgs .product-img-large {
   width: 360px;
   height: 360px;
   margin: 0 auto;
   padding: 0;
  }
  .presentation-container .slide_img label span {
		position: absolute;
    top: 3px;
    right: 7px;
		font-size: 56px;
	}
  .back-container {
  width: 40px;
  height: 314px;
  margin-right: 6px;
  font-size: 15px;
  color: rgb(49, 14, 14, 1);
  padding: 0;
  }
  main > .product .product-wrapper { 
    margin: 0 auto;
    width: 360px;
    padding: 0;
  }
}


/* Search-field and menu get smaller, when screen smaller than 450px */
/* Also showing product page numbers changes */

@media only screen and (max-width: 450px) {  
  header .link-icons .search input {
    max-width: 160px;
  }
  header li a {
    margin: 6px 2px 4px 2px;
    padding: 14px 6px;
  }
  .buttonline {
    flex-direction: column;
  }
  .wheremax, .wheremed, .wheremin {
    padding: 24px 6px;
  }
  .wheremax, .wheremed {
    display: block;
  }
}


/* Search-field gets smaller again, when screen smaller 420px */

@media only screen and (max-width: 420px) {  
  header .link-icons .search input {
    max-width: 120px;
    font-size: 13px;
  }
}

