* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;

  font-family: 'helveticaNeue';
  font-family: Helvetica, sans-serif;
}

/* .emptySlider {
  display: none;
} */

:root {
  --fontSize50: 50px;
  /* --fontSize24: 24px; */
}

html {
  /* width: 100vw; */
}

body {
  overflow-x: hidden;
}

body.noScroll, html.noScroll {
  height: 100%;
  overflow: hidden;
}




.mobileElem {
  display: none;
}

.mobileMarker {
  display: none;
}
.mobileMarker768 {
  display: none;
}

a {
  text-decoration: unset;
  color: black;
}

a:active {
  color: black;
}

.underline {
  text-decoration: underline;
}

.transparentFont {
  color: rgba(255, 255, 255, 0);
  -webkit-text-stroke: 1px white;
}

.transparentFontBlack {
  color: rgba(255, 255, 255, 0);
  -webkit-text-stroke: 1px black;
}

.slashElem.noPB {
  padding-bottom: 0;
}

header {
  position: fixed;
  width: 100%;
  top: 0;
  left: 0;
  margin-bottom: 100px;

  background-color: white;
  z-index: 100;
}

.menuOuterHolder {
  /* position: fixed; */

  width: calc(100% - 72px);
  margin: auto;
}

/* .expFader {
    position: absolute;
    width: 100%;
    height: 20px;
    bottom: -20px;
    background: linear-gradient(to top, rgba(255, 255, 255, 0), white);
} */

.menuHolder {
  display: flex;
  flex-direction: row;
  justify-content: space-between;

  height: 90px;

  border-bottom: 1px solid black;

  font-size: 14px;

  background-color: white;
}

.mobileMenuHolder {
  display: none;
}

.menuHolderLeft {
  display: flex;
  flex-direction: row;
  height: 100%;
}

.menuHolderRight {
  display: flex;
  flex-direction: row-reverse;
  height: 100%;
}

.menuBank {
  /* height: 77px;
  display: flex;
  justify-content: flex-end;
  align-items: end;
  margin-left: 20px; */

  /* height: 77px; */
display: flex;
/* justify-content: flex-end;
align-items: end; */
margin-left: 20px;
margin-top: 18px;
}

.ersteBankElem {
  height: 52px;
  width: 80px;

  display: flex;
  flex-direction: column;
  /* border-bottom: 1px solid black; */
}

.bankTop {
  height: 20px;
  width: 100%;
  font-weight: 700;
  font-size: 10px;
}

.bankBottom {
  height: 400px;
  width: 100%;
}

.ersteBankElem img {
  /* width: 104px !important; */
  /* image-rendering: pixelated; */
}

.menuHolderRightWrapper {
  display: flex;
  justify-content: space-between;

  align-items: flex-end;
  gap: 20px;

  font-size: 20px;
  font-weight: 700;

  height: 72px;
  margin-right: 10px;
}

.menuHolderRightWrapper {
}

.oneSubMenuContainer {
  /* width: 200px; */
}

.subMenuHolder * {
  text-transform: lowercase;
}

.subMenuHolder {
  position: relative;
  height: 50px;
  overflow: hidden;

  border-bottom: 1px solid black;

  font-size: 20px;

  background-color: white;
  z-index: 100;
  transition: all 200ms ease-in;
}

.subMenuHolder.active {
  height: 420px;
}

.subMenuHolderElems {
  display: flex;
  justify-content: space-between;

  cursor: pointer;
}

.subMenuElem,
.subsubMenuElem {
  font-size: 28px;
  font-weight: 700;

  height: 50px;
  line-height: 50px;
}

.subsubMenuElem {
  height: unset;
  line-height: 1.1em;
  padding: 4px 0;
  border-bottom: 1px solid black;

  -ms-hyphens: auto; /* ab IE10 */
  -moz-hyphens: auto; /* seit Firefox 6 */
  -webkit-hyphens: auto; /* seit Safari 5.1 (OS X), Safari 4.1 (iOS) */
  hyphens: auto;
}

.subsubMenuElemsMobile {
  max-height: 0;
  overflow: hidden;
  transition: all 400ms ease;
}

.cursorPointer {
  cursor: pointer;
}

.subsubMenuElemsMobile.opened {
  max-height: 500px;
  transition: all 400ms ease;
}

.subsubMenuElemMobile {
  margin-left: 50px;
  font-size: 36px;
}

.subMenuHolder.active::before {
  content: '';
  position: absolute;
  top: 46px;
  width: 100%;
  height: 1px;
  background-color: black;
}

.subsubMenuCol .subsubMenuElem:last-of-type {
  border-bottom: unset;
}

.subMenuElem {
  position: relative;
}

.subsubMenuCol {
  position: absolute;
  width: calc((100vw / 5) - 100px);
}

.subsubMenuHolderElems {
  display: flex;
  justify-content: space-between;
}

.subsubMenuHolder {
  display: none;
  width: 100%;
  background-color: white;
  border-bottom: 1px solid black;
  overflow: hidden;
}

.logo {
  width: 300px;
  font-size: 80px;
  font-weight: 700;
  line-height: normal;

  display: flex;
  align-items: center;
  height: 100%;
}

.logo img {
  /* width: 100%; */
}

.artistrun {
  display: flex;
  justify-content: center;
  align-items: flex-end;

  font-size: 20px;
  font-weight: 700;

  margin-left: 10px;
}

/* .openClosed,
.openingHours,
.langSwitch {
  margin-bottom: 10px;
} */

.langSwitch {
  cursor: pointer;
}

.artistrun span {
  margin-bottom: 16px;
}

.langSwitch {
  color: lightgrey;
}

.langSwitch .activeLang {
  color: black;
}

section {
  padding-bottom: 50px;
  border-bottom: 1px solid black;
}

.exhibSection {
  /* border-bottom: unset; */
  border-bottom: 1px solid black;
}

.invertedMarquee {
  border-bottom: none;
}

.fullWidthHolder {
  /* width: 100vw; */
  /* width: 1000vw; */
  margin-left: -36px;

  font-weight: 700;
  overflow: hidden;

  /* cursor: pointer; */
}




.bigMarqueeHolder {
  display: flex;

  /* width: 1400px; */
  height: 300px;
  /* background-color: lightsalmon; */
}

.marqueeImgHolder {
  display: inline-flex;
  align-items: center;
  height: 100%;
  /* width: 300px; */
  padding: 0 30px;
}

.innerMarqueeImgHolder {
  position: relative;
  height: 170px;
  width: 245px;
  background-color: brown;
  transform: translateY(-14px);
}

.innerMarqueeImgHolder img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.marqueeImgWrapper {
  margin: 0 20px;
  width: 300px;
  height: 200px;
}

.bmElem {
  display: flex;
  animation-name: marquee;
  animation-duration: 20s;
  animation-iteration-count: infinite;
  animation-timing-function: linear;
}

.bmElemRight {
  display: flex;
  animation-name: marqueeRight;
  animation-duration: 20s;
  animation-iteration-count: infinite;
  animation-timing-function: linear;
}

.nBmElem {
  line-height: 300px;
  height: 300px;
}

@keyframes marquee {
  0% {
    transform: translate(0, 0);
  }
  100% {
    transform: translate(-100%, 0);
  }
}

@keyframes marqueeRight {
  0% {
    transform: translate(-100%, 0);
  }
  100% {
    transform: translate(0, 0);
  }
}

.marqueeWhitespace {
  width: 50px;
}

.invertedHolder {
  display: flex;

  color: white;
  background-color: black;
  font-size: 76px;
  font-weight: 700;
  line-height: 100px;
  height: 100px;
}

.slashElem {
  font-size: 80px;
  font-weight: 700;

  padding: 20px 0;

  /* cursor: pointer; */
}


/* text marquee */

.textMarqueeContainer {
  padding-bottom: 20px;
  max-height: 1000px;

  transition: all 300ms ease;
}

.filterOuterHolder {
  max-height: 1000px;
  
  transition: all 300ms ease;

}


.textMarqueeHolder {
  display: flex;
}

.textMarqueeRight {
  overflow: hidden;
}

.sponsorElem {
  margin-right: 50px;
        /* width: 70px; */
        overflow: hidden;
        white-space: nowrap;
}

.textMarqueeHolder:hover .bmElem {
  animation-play-state: paused;
}


.collScrollBlock.scrolled .textMarqueeContainer {
  max-height: 0;
    padding-bottom: 0px;
  overflow: hidden;

}

.collScrollBlock.scrolled .filterOuterHolder {
  max-height: 0;
    padding-bottom: 0px;
  overflow: hidden;

}

.titleHolder.scrolled .marginTitle, .titleHolder.scrolled .artExHolder
{
	max-height: 0;
    padding-bottom: 0px;
  overflow: hidden;
}

/* text marquee end */













/* slider */

.announceSlider .slick-track {
  float: left;
}

.slickHolder {
  width: calc(100% + 36px);
  transform: translateX(-18px);
}

.sliderHolder {
  transform: translateY(-30px);
}

.slideCounter {
  font-size: 20px;
  margin-right: 10px;
}

.greyArrow {
  filter: invert(100%) sepia(0%) saturate(1908%) hue-rotate(162deg)
    brightness(113%) contrast(65%);
}

.sliderArrowHolder {
  height: 30px;

  display: flex;
  justify-content: flex-end;
  /* justify-content: space-between; */
}

.arrowHolderRightPart {
  display: flex;
}

.exhibSliderElem {
  position: relative;

  width: calc(100% / 4);
  margin: 0 18px;

  cursor: pointer;
}

.exhibLowerContent {
  /* height: 150px; */
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.soon {
  position: absolute;
  top: 20px;
  left: 20px;

  color: white;
  font-size: 28px;
  font-weight: 700;
}

.soonImgHolder {
  background-color: black;
}

.soonImg {
  opacity: 0.4;
}

.exhibSliderImg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.editorialSliderElem {
  position: relative;

  width: calc(100% / 3);
  margin: 0 18px;

  cursor: pointer;
}

.editorialSliderElem img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.editorialSliderImg {
  position: relative;
  width: 100%;

  background-color: grey;
}

.editorialSliderTexts {
  position: absolute;
  top: 0;

  display: flex;
  flex-direction: column;
  justify-content: space-between;

  margin: 20px;

  height: calc(100% - 40px);
  z-index: 1;
}

.topImageText,
.bottomImageTextMore {
  /* position: absolute; */

  color: white;
  font-weight: 700;
}

.bottomImageTextMore {
  text-decoration: underline;
}

.bottomImageText {
  /* position: absolute;  */
  font-weight: 700;
}

.topImageText {
  /* top: 5%;
    left: 5%; */
  font-size: 28px;
}

.bottomImageText {
  top: 75%;
  left: 5%;
  /* font-size: 76px; */
  font-size: clamp(36px, 4vw, 74px);
}

.bottomImageTextMore {
  top: 90%;
  left: 5%;
  font-size: 28px;
}

.friesMore {
  text-decoration: underline;
  font-size: 50px;
  font-weight: 700;
}

/* category event */


.subtitleText {
  font-size: 20px;
    line-height: 1.5em;
    margin-bottom: 50px;
}

.intro_text {
  font-size: 20px;
  line-height: 1.5em;
  margin-bottom: 30px;
}

.eventCatElem {
  position: relative;

  cursor: pointer;
}

.eventCatImg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.exhibCatElem {
  width: 100%;
}

/* category exhibitions */

.exhib_items_holder {
  margin-bottom: 50px;
}

.groupElemLink {
  text-decoration: underline;
}

#overview_elements_container {
  border-bottom: 1px solid black;
}

/* footer */

.mobileButton {
  font-size: 36px;
  font-weight: 700;
  line-height: 60px;

  cursor: pointer;
}

.footerContact {
  display: flex;
  justify-content: space-between;

  margin-top: 20px;
  margin-bottom: 20px;

  font-weight: 700;
}

.footerContactLeft,
.footerContactRight {
  width: 500px;
}

.footerSponsor {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 60px;
  border-bottom: 1px solid black;
  border-top: 1px solid black;
  margin-top: 100px;
}

.footerSponsor img {
  width: 100%;
  height: 40px;
}

.footerContactRight .footerContactElem {
  text-align: right;
}

.footerLinks {
  display: flex;
  justify-content: space-between;

  font-size: 28px;
  font-weight: 700;

  margin-bottom: 20px;
}

.footerLinks div {
  display: flex;
}

.footerLinks div div {
  margin-right: 20px;
}

.footerLinksRight div:last-of-type {
  margin-right: unset;
}
.footerLinksRight .withMargin {
  margin-left: 10px;
}

.invertThis img {
  filter: invert(1)
}

.footerLinksElem {
  cursor: pointer;
}

.socialMediaElem {
  height: 100%;
  width: 30px;
  /* background-color: black; */
  filter: invert(1);
}

.titleHolder {
  /* font-size: var(--fontSize50);   */
  font-size: 80px;  
  font-weight: 700;
  line-height: normal;
  text-transform: lowercase;

  margin-bottom: 50px;

  transform: translateX(4px);
}

.titleHolder:empty {
  display: none;
}

.categoryFilterTitleHolder {
  display: flex;
  justify-content: space-between;

  border-top: 1px solid black;
  border-bottom: 1px solid black;
  padding: 10px 0;
}

#category_filter_holder {
  margin: 20px 0 50px;
}

#category_filter_title {
  font-weight: 700;
  cursor: pointer;
}

#category_filter_title::after {
  content: url('../img/arrow_filter.svg');
  display: inline-block;
  width: 11px;
  /* height: 11px; */
  position: relative;
  left: 10px;
  transition: 0.5s all;
}

#category_filter_title.active::after {
  content: url('../img/arrow_filter.svg');
  display: inline-block;
  width: 11px;
  /* height: 11px; */
  position: relative;
  left: 10px;
  transform: rotate(180deg);
  transition: 0.5s all;
}

#filtering_inner_holder {
  padding: 30px 0px;
  border-bottom: 1px solid black;
  display: none;
}

.filter_row {
  margin-bottom: 10px;
}

.filter_row:last-of-type {
  border-bottom: 1px solid black;
}

.filter_title {
  width: 120px;
  font-weight: 700;
  display: inline-block;
  margin-right: 10px;
}

.filter_input_holder {
  display: inline-block;
}

.filterParentSearch {
  width: 100%;
  max-width: 500px;
}

.filter_input {

  font-size: 18px;
  
  
  border: none;
  border-bottom: 1px solid black;
  outline: none;
  -webkit-appearance: none;
  -webkit-border-radius: 0;
  
}

#search_text {
  
  width: 100%;
  max-width: 700px;
}

#filter_start_year::placeholder,
#filter_end_year::placeholder #filter_start_year:-ms-input-placeholder,
#filter_end_year:-ms-input-placeholder
  #filter_start_year::-webkit-input-placeholder,
#filter_end_year::-webkit-input-placeholder {
  color: rgb(185, 185, 185);
  
}

#filter_start_year,
#filter_end_year {
  background-color: white;
  color: black;
}

#filter_start_year,
#filter_end_year {
  width: 70px;
}

#filter_end_year {
  margin-left: 4px;
}

.clickable_filter_item {
  display: inline-block;
  cursor: pointer;
}

.clickable_filter_item.active {
  text-decoration: underline;
}

.filter_item_separator {
  display: inline-block;
  /* margin:0px 10px; */
}

#filter_buttons {
  margin-top: 30px;
  margin-left: 135px;
}

.filter_button {
  font-weight: 700;
  text-decoration: underline;
  cursor: pointer;
  display: inline-block;
  margin-right: 20px;
}

.filter_button:first-of-type {
  width: 120px;
  margin-right: 10px;
}

.ticketLinkAndSectionContainer {
  width: 100%;

  margin: 36px 0 50px 0;
  padding: 10px 0;
  border-top: 1px solid black;
  border-bottom: 1px solid black;

  font-size: 36px;
  font-weight: 700;

  overflow: hidden;
}

.firstRowTicketLink {
  display: flex;
  justify-content: space-between;
}

.ticketSectionRight {
  cursor: pointer;
}

.ticketLinkArrow {
  width: 20px;
  height: 20px;
}

.ticketLinkArrow img {
  width: 20px;
  height: 20px;
  transform: rotate(90deg);
  animation: all 300s ease;
}

.ticketLinkArrow img.collapsed {
  transform: rotate(270deg);
}

.listTicketLink {
  display: none;
}

.listTicketElem {
  text-align: right;
}

.ticketElemText {
  cursor: pointer;
}

#overview_page_holder {
  padding-top: 50px;
}


@media screen and (min-width: 2200px) {

  .module {
    float: unset !important;
    margin-left: 0 !important;
  }

}