/************ Vogt ***********/

/* Cookie */

#cookie_warning {
  
  font-weight: 400;
  /* padding: 20px 30px; */
  /* margin: 10px; */
  /* border-radius: 3px; */
  display: block;
  position: fixed;
  bottom: 0;
  right: 0;
  /* border: 2px solid #ddd; */
  z-index: 1000;
  color: white;
  background-color: black;
  box-shadow: 0 5px 15px 4px rgb(0 0 0 / 10%);
  /* font-size: 16px; */
  width: 100%;
}


.cookie_warning_text {
  font-size: 16px;
  line-height: 1.5em;
  font-weight: 400;
  -webkit-text-stroke-width: 0px;
  margin-bottom: 1em;
}


.cookie95p {
  width: 95%;
  max-width: 1000px;
  margin: 0 auto;
}


.cookie1000 {
  display: flex;
  flex-direction: row;
  width: 100%;
  margin: 40px auto;
}


.cookieHeader {
  font-size: 36px;
}

.cookieLeft {
  width: 100%;
}

.cookieRight {
  min-width: 300px;
}

.cookieButtonHolder {
  display: flex;
}

.cookieButtonRelHolder,
.cookieButtonMarkHolder {
  display: flex;
  margin-right: 50px;
  
  cursor: pointer;
}

.cookieSelect {
  position: relative;
}

.cookieSelect input[type='checkbox'] {
  cursor: pointer;
  position: relative;
  left: -1px;
  top: -1px;
  z-index: 7;
  width: 25px;
  -webkit-appearance: none;
  height: 25px;
  margin: 0;
}

#cookie_nec_check {
  cursor: default;
}


.cookieSelect input[type='checkbox']+label {
  position: relative;
  left: -25px;
}

.cookieSelect input[type='checkbox']+label::before {
  content: '';
  display: block;
  float: left;
  z-index: 5;
  position: relative;
  width: 20px;
  height: 20px;
  border: 1px solid white;
  border-radius: 50%;
  margin-right: 20px;
}


.cookieSelect input[type='checkbox']:checked+label::before {
  background-color: #fff;
  box-shadow: inset 0px 0px 0px 2px black;
  border-color: #fff;
}

.cookieSelect input[type='checkbox']:checked+label.necText::before {
  opacity: 0.5;
}


.cookieRight {
  display: flex;
  flex-direction: column;
  align-items: end;
  font-size: 18px !important;
}

.cookieRight button {
  
  width: 265px;
  color: white;
  background-color: black;
  border-radius: 50px;
  border: 1px solid white;
  font-size: 18px;
}





.cookieHover:hover,
#cookie_warning .cookieRight button.cookieAcceptAll
{
  background-color: white;
  color: black !important;
}








.cookie_warning_text a {
  text-decoration: underline;
}

#cookie_warning #cookie_consent,
#data_cookies #cookie_consent {
  background-color: #1a1a1a;
  border: 2px solid transparent;
  font: inherit;
}

/* #cookie_warning button:first-of-type {
  margin-right: 10px;
} */

#cookie_warning button,
#data_cookies button {
  padding: 10px 20px;
  /* border-radius: 3px; */
  /* background-color: #1a1a1a; */
  color: white;
  transition: all 0.1s linear;
  cursor: pointer;
  margin-top: 15px;
}
#data_cookies {
  font-size: 18px;
}
#data_cookies .cookie_warning_text {
  font-size: 18px;
  margin: 15px 0 30px;
}
#data_cookies .cookie95p {
  width: 100%;
  margin: 100px 0;
}
#data_cookies .cookie1000 {
  margin: 40px auto 20px;
}
#data_cookies .cookieSelect input[type='checkbox']+label::before {
  border: 1px solid black;
}
#data_cookies .cookieSelect input[type='checkbox']:checked+label::before {
  background-color: black;
  box-shadow: inset 0px 0px 0px 2px white;
  border-color: black;
}

#data_cookies .cookieRight button.cookieSave {
  background-color: white;
  color: black !important;
  border: 1px solid black;
}

#data_cookies .cookieRight button.cookieSave:hover {
  background-color: black;
  color: white !important;
  border: 1px solid white;
}

#cookie_warning button {
  color: black;
  background-color: white;
}


@media screen and (max-width: 830px) {
   .cookie1000,
  .cookieButtonHolder {
    flex-direction: column;
  }

  #data_cookies {
    width: 95%;
    margin: auto;
  }



  .cookieRight button {
    width: 100%;
  }

  .cookieSelect {
    margin-bottom: 10px;
  }

  .cookieButtonHolder {
    margin: 30px 0;
  }

}

/* end Cookie */

/* lightbox */
a.lb-close {
  position: absolute;
  top: 0px;
  right: 40px;
}

.lb-outerContainer {
  background: transparent !important;
}

.lightbox .lb-image {
  border: 0px transparent !important;
}

.lb-data .lb-details {
  /*	float: right !important;
	text-align: right !important;*/
}

.lb-data .lb-caption {
  /*	font-size: 22px !important;*/
}

.lb-data .lb-number {
  /*	font-size: 20px !important;*/
}

.lb-prev,
.lb-next {
  background-size: 31px 35px !important;

}

.lb_credits {
  font-size: 14px;
  font-family: "Equitan Sans W03 Italic";
  margin: 0px auto 5px;
  text-align: left;
  line-height: 16px;

}

#lightbox.no_text_lb,
#lightbox.no_text_lb .lb-nav {
  width: calc(100% - 110px);
  left: 50px !important;
}

@media screen and (max-width: 800px) {
  #lightbox.no_text_lb {}

  #lightbox.no_text_lb .lb-dataContainer {}

  #lightbox.no_text_lb .lb-dataContainer .lb-data .lb-close {
    position: fixed;
    top: 20px;

  }
}


#lightbox.no_text_lb .lb-dataContainer {
  background: transparent;
}

#lightbox.no_text_lb .lb-data .lb-close {
  background: url(../img/X_white.svg) top right no-repeat;
}


/* end lighbox */



/* general */

img {
  border: 0px;
  /* image-rendering: crisp-edges; */
}

img,
iframe,
video {
  max-width: 100%;
  max-height: 100%;
}

a {
  text-decoration: inherit;
  color: inherit;
  border: 0;
}


.ui-tooltip {
  font-size: 12px;
}


#container {
  max-width: 1500px;
  width: 90%;
  /* margin: 150px auto 0; */
  margin: 115px auto 0;
}



.back_btn {
  cursor: pointer;
  transition: all 0.3s ease-in-out;
  padding: 0 10px;
  width: 50px;
  overflow: hidden;
  margin-bottom: 70px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

.back_btn .arrow_left {
  margin: 0;
  min-width: 10px;
  min-height: 10px;
}

.line {
  transition: all 0.3s ease-in-out;
  border: 1px solid;
  display: block;
  width: 50px;
  transform: translate(-12px, 0px);
  min-width: 50px;
}

.back_btn:hover {
  width: 60px;
}

.back_btn:hover .line {
  min-width: 15px;
}

.page_title {
  font-size: 30px;
  margin-bottom: 50px;
}




.tag {
  display: inline-block;
}

/********* WEBSITE *********/

/** all pages */
html {
  /*   overflow: hidden;
  height: 100%; */
}

body {
  /*   height: 100%;
  overflow: auto; */
  -webkit-text-size-adjust: 100%;
  font-family: "Helvetica Neue", Helvetica, "Arial";
  font-weight: 400;
  font-weight: 400;
  margin: 0px auto;
  padding: 0px;
  height: 100%;
  font-size: 18px;
  touch-action: manipulation;

  margin: 0;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/** home page */
#home_page_holder {

  max-width: 1500px;
  margin: auto;

  display: flex;
  align-items: flex-start;
  justify-content: center;
  flex-flow: column nowrap;
  margin-bottom: 0px;
  /* height: calc(100vh - 210px); */
  height: calc(100vh - 160px);
  height: calc(var(--vh, 1vh) * 100 - 160px);

  /* 95 menu + 80 footer */
}

#slider_menu {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  /* margin-bottom: 30px; */
  margin-bottom: 20px;
}

#slider_elements {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  width: 100vw;
  overflow-x: scroll;
  overflow-y: hidden;
  /* max-height: calc(100vh - 336px); */
  box-sizing: border-box;
  padding: 5px 0;
}

#slider_elements_con {
  display: flex;
}

#slider_elements_con .slider_element {
  /*  overflow: hidden;  */
  position: relative;
  min-width: 200px;
  min-height: 250px;
  max-width: 370px;
  margin-right: 30px;
  box-sizing: border-box;
  display: flex;
  flex-flow: column nowrap;
  width: calc(72vh - 342px);
  max-height: 650px;
  /* height: calc(100vh - 342px); */

}

.slider_item_img {
  overflow: hidden;
  height: 70%;
  min-height: 60%;
  max-height: calc(100vh - 450px);
  max-height: calc(var(--vh, 1vh) * 100 - 450px);
}

.slider_item_img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


.preview_vid.video_holder,
.preview_vid .embed_holder {
  height: 100%;
}

.slider_item_title {
  font-size: 22px;
  font-size: clamp(14px, 2.4vh, 22px);
  margin: 8px 0;
}

.slider_item_link {
  font-size: 16px;
  font-size: clamp(12px, 2vh, 16px);
}

#slider_item_new_more {
  margin: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
}

#slider_item_new_more:hover {
  color: rgb(253, 241, 81);
}

@media screen and (max-width: 750px) {}

@media screen and (max-height: 550px) {
  #slider_menu {
    display: none;
  }
}


/* error page */
#error_page {
  text-align: center;
  min-height: calc(100vh - 217px);
  min-height: calc(var(--vh, 1vh) * 100 - 217px);
}

/* overview page */
#overview_menu {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 50px;
  max-width: 1140px;
  margin: 0 auto 50px;
}

.search_page #overview_menu {
  padding: 20px 0 40px;
  border-bottom: 1px solid black;
  margin-bottom: 40px;
}

#overview_title {
  font-size: 34px;
}

#overview_page_holder {
  max-width: 1200px;
  margin: auto;
  min-height: calc(100vh - 217px);
  min-height: calc(var(--vh, 1vh) * 100 - 217px);
}

#overview_elements_container {}

#overview_elements {
  width: calc(100% + 30px);
  max-width: unset;
  transform: translate(-15px, 0px);
}


#overview_elements,
#related_items_container {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  flex-flow: row wrap;
}

/* #overview_elements:after {
  content: '';
  width: 250px;
} */

/* #overview_elements:after {
  content: '';
  margin: auto;
} */

.grid_element {
  position: relative;
  overflow: hidden;
  min-height: 450px;
  width: 260px;
  box-sizing: border-box;
  display: flex;
  flex-flow: column nowrap;
  margin: 0 15px 50px;
}

.grid_element:hover .grid_item_title {
  text-decoration: underline 2px rgb(253, 241, 81);
}

.grid_item_link {
  font-size: 18px;
}

.grid_item_img {
  height: 330px;
  margin-bottom: 20px;
}

.grid_item_img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.grid_item_title {
  font-size: 20px;
  margin: unset;
}

.grid_item_main_title {
  font-size: 20px;
  margin: 10px 0 5px 0;
  hyphens: auto;
  /* font-size: clamp(16px, 2.5vh, 20px); 
  min-height: 20px;*/
}

.grid_item_lable {
  font-size: 16px;
  margin: 0;
  /* font-size: clamp(14px, 2vh, 16px); 
  min-height: 15px;*/
}


/* books list */
.books_list .grid_item_img img,
.book_list_related .grid_item_img img {
  object-fit: contain;
  object-position: bottom;
}


/* case studios */
.random_placed_element_container {
  width: 25%;
  margin: 0;

  box-sizing: border-box;
  position: relative;
}

.random_placed_element_container:last-child {
  margin-right: auto;
}

@media screen and (max-width: 900px) {
  .random_placed_element_container {
    width: 33%;
  }
}

@media screen and (max-width: 600px) {
  .random_placed_element_container {
    width: 50%;
  }
}

@media screen and (max-width: 612px) {

  /* 260/330 */
  #overview_page_holder .grid_element {
    width: 60vw;
    min-width: 260px;
  }

  #overview_page_holder .grid_item_img {
    height: 78vw;
    min-height: 330px;
  }
}


.random_placed_element {
  max-width: 70%;
  max-height: 70%;
  position: absolute;
  top: 0;
  left: 0;
}

/* related items */
#related_articles #related_items_container {
  width: 100%;
  margin: 10px auto 0;
}

#related_items_container .grid_element {
  width: 200px;
  margin: 0;
  margin-bottom: 50px;
  min-height: unset;
}

#related_items_container .grid_element .grid_item_img {
  height: 280px;
}

/* list */
#overview_elements_list {}

.list_element {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.list_item_text {
  margin-right: 20px;
}

.list_item_text .grid_item_title.grid_item_main_title.bold {
  display: flex;
}

.list_item_text .grid_item_lable {
  margin: 5px 0 20px 0;
  min-height: unset;
}

.grid_item_lable .dbl_arrow_icon {
  width: 12px;
  height: 12px;
  background-size: contain;
  background-repeat: no-repeat;
  margin-left: 10px;
}

.grid_item_lable.more_arrow {
  display: flex;
  align-items: center;
}

/*  favs */
.nav_fav_icon_circle {
  /* width: 24px;
  height: 24px; */
  margin-right: 5px;
}

.heart_icon_circle.nav_fav_icon_circle.active {
  background-color: rgb(245, 255, 0);
  border-color: rgb(245, 255, 0);
}

.overview_el_fav_icon {
  position: absolute;
  top: 5px;
  right: 5px;
  width: 26px;
  height: 26px;
}

.overview_el_fav_icon.active {
  background: white;
  border-color: white;
}

.overview_el_fav_icon .heart_icon {
  width: 14px;
  height: 14px;
}

.overview_el_fav_icon.active .heart_icon {
  background-image: url(../img/heart_filled_black.svg);
}

.fav_collections_title {
  max-width: 1130px;
  width: 100%;
  font-size: 20px;
  margin: 10px auto 10px;
  hyphens: auto;
}

.delete_coll_btn.treat_btn {
  padding-top: 5px;
  margin-left: 40px;
}

/***** END WEBSITE *****/