/* #####################################################################################################
   HOMEPAGE
   ##################################################################################################### */

/*--- standard variables ---*/
/*--- product item ratio (thumb + content) ---*/
/* set ProductImageRatio in productOverview! */
/*--- media queries. When using responsive ---*/
/* Range breakpoints */
/*--- media queries. When using responsive: only mobile & desktop ---
@responsive:	false;
@largePhone:	~"only screen and (min-width: 480px)";
@tablet:		~"only screen and (min-width: 999999999px)";
@tabletLand:	~"only screen and (min-width: 768px)";
@desktop:		~"only screen and (min-width: 768px)";

@upToTablet:	~"only screen and (max-width: 767px)";
@upToDesktop:	~"only screen and (max-width: 767px)";*/
/*--- media queries. When not using responsive ---
@responsive:	false;
@largePhone:	~"only screen and (min-width: 1px)";
@tablet:		~"only screen and (min-width: 1px)";
@tabletLand:	~"only screen and (min-width: 1px)";
@desktop:		~"only screen and (min-width: 1px)";

@upToTablet:	~"only screen and (max-width: 1px)";
@upToDesktop:	~"only screen and (max-width: 1px)";*/
/*----- Default functions -----*/
/*----- Default Crossbrowser functions -----*/
/*----- CSS3 functions -----*/
/*----- CSS3 Animation functions -----*/
/*----- Buttons -----*/
/*----- Responsive functions -----*/
.homepage .mainBanner {
  margin-bottom: 15px;
}
.homepage .productList {
  padding: 0 20px;
}
.homepage #content {
  text-align: center;
}
@media only screen and (max-width: 767px) {
  .homepage #content {
    padding-bottom: 0;
  }
}
.homepage .footerTop {
  background: none;
  height: 0;
  padding: 0;
}
.homepage #cols {
  padding: 0;
}
@media only screen and (max-width: 767px) {
  .homepage #cols .banner img {
    width: 100%;
  }
  .homepage #cols .mobileBanners,
  .homepage #cols .subBannersLeft,
  .homepage #cols .subBannersRightHigh,
  .homepage #cols .subBannersRightService > .banner:first-child {
    margin-left: 20px;
    margin-right: 20px;
  }
}
.homepage .highlights .productList .hoverImg {
  display: block !important;
}
.homepage .highlights .productList .hoverImg + img {
  display: none !important;
}
.homepage .highlights .productList .item:hover .hoverImg {
  display: none !important;
}
.homepage .highlights .productList .item:hover .hoverImg + img {
  display: block !important;
}
.homepage #homepageHighlightedBlock {
  background: #3f3d3e;
  width: 100%;
  padding: 30px 30px 24px;
  color: white;
}
.homepage #homepageHighlightedBlock .kop3 {
  font-size: 18px;
  line-height: 24px;
  white-space: normal;
  overflow: visible;
  text-overflow: unset;
  margin: 0;
}
.homepage #homepageHighlightedBlock p {
  font-family: 'Merriweather', serif;
  font-style: italic;
}
.homepage #homepageHighlightedBlock h2,
.homepage #homepageHighlightedBlock h3,
.homepage #homepageHighlightedBlock label {
  display: none;
}
@media only screen and (min-width: 1024px) {
  .homepage #homepageHighlightedBlock {
    max-width: 305px;
    max-height: 305px;
  }
  .homepage #homepageHighlightedBlock .kop3 {
    overflow: hidden;
  }
  .homepage #homepageHighlightedBlock p {
    max-height: 44px;
    overflow: hidden;
  }
}
.homepage #homepageHighlightedBlock .newsletterWrapper {
  margin: 0;
}
.homepage #homepageHighlightedBlock .newsletterWrapper .row {
  float: left;
  width: 60%;
  margin: 0;
  min-height: 40px;
  background: none;
}
.homepage #homepageHighlightedBlock .newsletterWrapper .row label {
  display: none;
}
.homepage #homepageHighlightedBlock .newsletterWrapper input[type="email"] {
  background: none;
  border: 0;
  margin: 0 0 5px;
  color: white;
  height: 30px;
  font-size: 12px;
  min-height: 30px;
  vertical-align: top;
  border-bottom: 2px solid white;
  outline: none;
  -webkit-transition: all 0.2s ease-out;
  -moz-transition: all 0.2s ease-out;
  -o-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
  /*-moz-backface-visibility: hidden;*/

}
.homepage #homepageHighlightedBlock .newsletterWrapper input[type="email"]::-webkit-input-placeholder {
  color: #d1d2d4;
}
.homepage #homepageHighlightedBlock .newsletterWrapper input[type="email"]:-moz-placeholder {
  color: #d1d2d4;
}
.homepage #homepageHighlightedBlock .newsletterWrapper input[type="email"]:-ms-input-placeholder {
  color: #d1d2d4;
}
.homepage #homepageHighlightedBlock .newsletterWrapper input[type="email"]::-moz-placeholder {
  color: #d1d2d4;
}
.homepage #homepageHighlightedBlock .newsletterWrapper input[type="email"]:focus {
  border-color: #c2ab9a;
}
.homepage #homepageHighlightedBlock .newsletterWrapper input[type="submit"] {
  float: right;
  width: 40%;
  text-transform: uppercase;
  border: 0;
  padding-left: 0;
  height: 30px;
  line-height: 30px;
  padding-right: 0;
  -webkit-border-radius: 0;
  -moz-border-radius: 0;
  border-radius: 0;
  -moz-background-clip: padding-box;
  -webkit-background-clip: padding-box;
  background-clip: padding-box;
  text-transform: none;
  margin: 0 0 5px;
}
.homepage #homepageHighlightedBlock .newsletterWrapper .emailErrorMessage {
  color: #c2ab9a;
}
.homepage #homepageHighlightedBlock .newsletterWrapper .privacyStatement {
  float: left;
  color: white;
}
.homepage #homepageHighlightedBlock .newsletterWrapper .required:before {
  content: none;
}
@media only screen and (min-width: 768px) {
  .homepage .slider {
    position: relative;
  }
  .homepage .slider [data-slider-role="slide"] a {
    color: black;
    display: block;
    position: relative;
  }
  .homepage .slider [data-slider-role="slide"] a:hover {
    color: black;
  }
  .homepage .slider [data-slider-role="slide"] span {
    height: auto;
    text-align: center;
    padding: 20px 10%;
    bottom: 0;
    display: block;
  }
  .homepage .slider [data-slider-role="slide"] span p {
    font-family: 'Merriweather', serif;
    font-style: italic;
    line-height: 21px;
  }
  .homepage .slider [data-slider-role="slide"] span h3 {
    text-decoration: underline;
    display: inline-block;
    line-height: 34px;
  }
  .homepage .slider [data-slider-role="slide"] span h3:hover {
    color: #90284a;
  }
  .homepage .subBannersLeft,
  .homepage .subBannersRight {
    display: inline-block;
    vertical-align: top;
  }
  .homepage .subBannersLeft {
    margin: 0 0 20px;
    width: 630px;
    max-width: 100%;
  }
  .homepage .subBannersLeft a {
    display: block;
  }
  .homepage .subBannersLeft.subBannersLeftSmall {
    overflow: hidden;
  }
  .homepage .subBannersLeft.subBannersLeftSmall > * {
    float: left;
    margin-right: 3.053435115%;
    margin-bottom: 3.053435115%;
    width: 48.473282443%;
  }
  .lt-ie9 .homepage .subBannersLeft.subBannersLeftSmall > * {
    /*IE 8*/
    width: 46.946564885%;
  }
  .homepage .subBannersLeft.subBannersLeftSmall > *:nth-of-type(n) {
    /*reset if function is called more then once*/
    margin-right: 3.053435115%;
  }
  .homepage .subBannersLeft.subBannersLeftSmall > *:nth-of-type(2n) {
    margin-right: 0;
  }
  .homepage .subBannersLeft.subBannersLeftSmall > * {
    margin-bottom: 20px;
  }
  .homepage .subBannersLeft img {
    line-height: 0;
  }
  .homepage .subBannersLeft :last-child {
    margin-right: 0;
  }
  .homepage .subBannersRight {
    margin-left: 18px;
  }
  .homepage .subBannersRight > * {
    margin-bottom: 20px;
  }
  .homepage .productList {
    overflow: hidden;
  }
  .homepage .productList > .item {
    float: left;
    margin-right: 1.557632399%;
    margin-bottom: 1.557632399%;
    width: 23.831775701%;
  }
  .lt-ie9 .homepage .productList > .item {
    /*IE 8*/
    width: 23.442367601%;
  }
  .homepage .productList > .item:nth-of-type(n) {
    /*reset if function is called more then once*/
    margin-right: 1.557632399%;
  }
  .homepage .productList > .item:nth-of-type(4n) {
    margin-right: 0;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1023px) {
  .homepage .subBannersRight {
    margin: 0;
  }
  .homepage .subBannersRight .banner,
  .homepage .subBannersRight #homepageHighlightedBlock {
    float: left;
  }
  .homepage .subBannersRight #homepageHighlightedBlock {
    margin-left: 20px;
    padding: 34.5px 30px;
    max-height: 305px;
  }
}
@media only screen and (min-width: 1024px) {
  .homepage .slider [data-slider-role="slide"] span {
    position: absolute;
    top: auto;
    right: auto;
    left: 50%;
    bottom: 0;
    width: 986px;
    background: rgba(255, 255, 255, 0.9);
    padding: 25px 10% 25px 10%;
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    -o-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
  }
}
.homepage .bannerBlock {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media only screen and (min-width: 1024px) {
  .homepage .bannerBlock {
    flex-direction: row;
  }
}
.homepage .bannerBlock .banners {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media only screen and (min-width: 768px) {
  .homepage .bannerBlock .banners {
    flex-direction: row;
  }
}
.homepage .bannerBlock .banner {
  margin: 0 18px 18px 0;
}
@media only screen and (max-width: 1023px) {
  .homepage .bannerBlock .banner {
    margin: 0 18px 18px 18px;
  }
}
.homepage .socialBlock ul {
  width: 100%;
  margin-top: 15px;
}
.homepage .socialBlock ul li {
  float: left;
  width: 50%;
  margin-left: 0;
  margin-right: 0;
}
