

/* Don't delete this */

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  font-family: 'inter-regular', sans-serif;
  /* font-family: sans-serif; */
  /* border: 1px solid red; */
}

html {
  width: 100%;
}

body {
  background-color: white;
  font-size: var(--genFontSize);
  width: 100%;
}

html,
body {
  margin: 0;
  padding: 0;
  /* height: 100%; */
}

.h1 {
  font-family: 'HK-bold', sans-serif;
  font-size: 64px;
  /* margin-bottom: 1rem; */

  hyphenate-limit-chars: 20;
  hyphens: auto;
}

.h2 {
  font-family: 'HK-bold', sans-serif;;
  font-size: 32px;
  /* margin-bottom: 1rem; */
}

.h3 {
  font-family: 'HK-bold', sans-serif;;
  font-size: 18px;
  /* margin-bottom: 1rem; */
}

.normalA {
  display: inline;
  border-bottom: unset;
  padding-right: unset;
}

.normalA:after,
.lb-cancel:after 

 {
  display: none;
}



a {
  display: inline;
  position: relative;
  color: black;
  /* padding-right: 20px; */
  /* text-decoration: underline; */
  border-bottom: 1px solid black;
}


a:after {
  content: '→';
  position: relative;
  right: 0;
  margin-left: 10px;
}

a.lb-close::after {
  content: 'x';
  text-decoration: none;
  border-bottom: none !important;
}

a.lb-close {
  border-bottom: none !important;
}

/* a:hover {
  text-decoration: underline;
} */

.button a {
  display: inline;
  text-decoration: none;
  border-bottom: unset
}

.button a:after {
  display: none;
}

.button a:hover {
  text-decoration: none;

}

.button {
  border: unset;
  margin-bottom: 5px;
  padding: 10px 15px;
  /* width: 300px; */
  font-size: 18px;

  display: flex;
  align-items: center;

  background-color: transparent;

  cursor: pointer;
}

.df-8 {
  display: flex;
  gap: 5px;
}

.df-aic {
  display: flex;
  align-items: center;
  height: 100%;
}

.df-jcfe {
  display: flex;
  justify-content: flex-end;
}




.interBold {
  font-family: 'inter-bold', sans-serif;
}

.druk500 {
  font-family: 'druk500';
  line-height: 1.1em;
}
.druk700 {
  font-family: 'druk700';
  line-height: 1.1em;
}

.desktopElem {
  display: block;
}

.mobileElem {
  display: none;
}







#container {
  min-height: calc(100vh - var(--headerHeight) - var(--footerHeight));
}

.limit1000 {
  width: 100%;
  max-width: 1000px;
  padding: 20px;
  margin: auto;

}

.genPadding {
  padding: var(--genPadding);
}

.smallContainerWidth {
  border: 1px solid black;
  background: white;
  width: 100%;
  max-width: var(--detWidth);
  margin: auto;
  min-height: var(--minBodyHeight);
}

.drArrow {
  width: 20px;
  height: 20px;
}

.mShift {
  margin-top: -60px;
}

.detFullWidthBlock.noHeader .mShift {
  margin-top: 0;
}

.pb50 {
  padding-bottom: 50px;
}


/* MECHATRONIKER */



.greyBG {
  background-color: var(--greyColor);
}

.greenBG {
  background-color: var(--greenColor);
}

.blueBG {
  background-color: var(--blueColor);
}

.purpleBG {
  background-color: var(--purpleColor);
}

.lblueBG {
  background-color: rgba(54, 168, 255, 0.4)
}

.whiteBG {
  background-color: white;
}



.dblueColor {
  color: var(--darkblueColor);
}

.whiteColor {
  color: white;
}

.dgreenColor {
  color: var(--darkgreenColor);
}

.dpurpleColor {
  color: var(--darkpurpleColor);
}

.blueColor {
  color: var(--dblueColor);
}




.tinyFont {
  font-size: var(--tinyFont);
  line-height: 1.2em;
}





.fullWidthBlock {
  position: relative;
  /* width: 100vw; */
  height: calc(80vh - var(--headerHeight));
  /* background-color: var(--blueColor); */

  /* margin-bottom: 250px; */
}

.fullWidthBlock .lpTitle {
  margin-bottom: 10px;
}


.lpTextHolder {
  position: relative;
  /* height: 225px; */
  width: 100%;
  bottom: 0;

  /* padding: 20px; */

  /* background-color: var(--blueColor); */
}

.lpImageHolder {
  height: 100%;
}

.lpImage {
  height: 100%;
  width: 100%;
  object-fit: cover;
  object-position: center;
}

.lpVideoHolder {
  height: 100%;
}

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

.s1Header1 {
  color: var(--darkblueColor);
}

.s1Header2 {
  color: white;
}


.lpDivider {
  display: flex;
  gap: 40px;

}

.lpTitleBanner {
  padding: 8px 10px;
  margin-bottom: 20px;
  width: 100%;
  min-width: 450px;
  text-transform: uppercase;
  font-size: 36px;
}

.lpTitleLeft {
  flex: 1 0 450px;
}
.lpTitleRight {
  flex: 1 0 450px;
}

.lpButton1, .lpButton2, .memberButton {
  width: 100%;
}





.lpTeaser {
  /* margin-left: 60%; */
  margin-bottom: 24px;
}

.lpButton1 {
    /* margin-left: 60%; */
    margin-bottom: 7px;
    /* width: 400px; */
    white-space: nowrap;
    overflow: hidden;

    display: flex;
    align-items: center;
    gap: 8px;
    
  }
  
  .lpButton2 {
    /* margin-left: 60%; */
    /* width: 400px;   */
    white-space: nowrap;
    overflow: hidden;
  }
  
  .buttonFlex {
  
    display: flex;
    align-items: center;
    gap: 8px;
}


.uppercase {

  text-transform: uppercase;
}

.lpTitle,
.module_headline,
.collTitle
 {
  text-transform: uppercase;
}

.lpMemberBlock .lpTitle{
  margin-bottom: 40px;
}




.memberButton {
  margin-bottom: 10px;
  /* width: 400px; */
}

.lpNewsBlock .lpTitle {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 50px;

}


.lpNewsGrid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-gap: 50px;
    margin-bottom: 100px;
}

.lpNewsElem {
  width: 100%;
}

.lpNewsElem > img {
  width: 100%;
  aspect-ratio: 1/1;
  margin-bottom: 10px;
  object-fit: cover;
}

.lpNewsTitle {
  color: var(--darkpurpleColor);
  font-size: 16px;
}

.lpNewsTeaser {
  color: var(--darkpurpleColor);
  font-size: 16px;

}

.lpNewsArrow {
  display: inline-flex;
  align-items: center;
}

.newsButton {
  height: fit-content;
  width: 410px;
}



.aboutSection {
  margin: 20px auto 50px;
}

.staticHLStripe {
  position: relative;
}

.staticHLStripe:after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  height: 40px;
  width: 100%;
  background-color: white;
}



.moduleHeadline {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 1000px;
  padding: 0 20px;
  margin: auto;
}









/* INFO LIST */


.topBlock {
  padding: 20px 40px;
}

.topBlock2Col {
  margin: 50px auto;
  display: flex;
}

.topBlockLeftCol {
  flex: 1;
  font-size: var(--textFont);
}

.topBlockRightCol {
  flex: 1;
  font-size: var(--textFont);
}

.filterAndButton {
  display: flex;
  justify-content: space-between;
  padding-bottom: 50px;
}

.deleteFilterButton {
  width: fit-content;
}

.filterListElem {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 0;
  gap: 20px;
  border-bottom: 1px solid var(--purpleColor);
}

.filterListText1 {
  margin-bottom: 10px;
}

.filterTitle {
  margin-bottom: 20px;
}

.filterListLeft {
  max-width: calc(100% - 50px);
}

.filterListRight {
  width: 30px;
  height: 30px;
}

.branchesList, .themesList {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 30px;
}

.filterElemContainer {
  margin-bottom: 100px;
}

.filterElem {
  border: 1px solid var(--purpleColor);
  padding: 6px 8px;
  font-size: var(--tinyFont);

  cursor: pointer;
}

.filterElem:hover,
.filterElem.active
 {
  background-color: var(--purpleColor);
  color: var(--darkpurpleColor);
}


/* customs and modules */

.personElem {
  display: flex;
  align-items: center;
  gap: 10px;
  /* width: calc(100%/3) !important; */

}

.personHolder,
.galleryHolder
 {
  position: relative;
  padding: 20px 0;
  margin-top: 20px;
}

.galleryGrid {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
  gap: 50px;
}

.galleryGrid .galleryElem {
  margin-right: 0;
  background-color: unset;
}

.galleryGrid .galleryElem img {
  object-fit: contain;
}

.onlyGalleryAndArrows {
  position: relative;
}


.personFlex {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}

.personCircle {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  background-color: grey;
}

.personSlickSlider,
.gallerySlickSlider
 {
  visibility: hidden;
}


.persSliderArrowLeft .leftArrow,
.gallSliderArrowLeft .leftArrow
 {
  rotate: 180deg;
}

.persSliderArrowLeft,
.gallSliderArrowLeft
 {
  position: absolute;
  height: 100%;
  width: 50px;
  top: 0;
  left: -50px;
  padding: 0;
  margin: 0;

  display: flex;
  align-items: center;

  cursor: pointer;
}

.personRight {
  flex: 1 0 160px;
  font-size: 16px;
  
}

.personJob {
  
  font-size: 16px;
}

.personName {
  hyphens: auto;

}


.persSliderArrowRight,
.gallSliderArrowRight
 {
  position: absolute;
  height: 100%;
  width: 50px;
  top: 0;
  right: -50px;
  padding: 0;
  margin: 0;

  display: flex;
  align-items: center;

  cursor: pointer;
}

.slick-slider {
  display: none !important;
}

.slick-slider.slick-initialized {
  display: block !important;
}

.slick-disabled {
  display: none !important;
}

.personName {
  margin-bottom: 5px;
}

.gallerySlickSlider {
  margin-bottom: 20px;
}

.galleryElem {
  width: 200px;
  height: 200px;
  background-color: grey;
  margin-right: 10px;
}

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


.basicTitle {
  margin-bottom: 5px;
}



.collBlock {
  cursor: pointer;
  margin-bottom: 0px;
  margin-left: 30px;
}

.collColumns {
  display: flex;
  gap: 20px;
}

.collColLeft {
  flex: 1;
}

.collColLeft * {
  font-size: var(--textFont) !important;
    line-height: var(--textLineHeight) !important;
}

.collColRight {
  flex: 1;
  height: 200px;
}

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

.module.module_collapsable.purpleType {
  background-color: var(--purpleColor);
}

.module.module_collapsable.blueType {
  background-color: var(--greenColor);
}

.module.module_collapsable .collTitle {
  color: white;
}


.collContent * {
  font-size: var(--textFont);
  line-height: var(--textLineHeight);
}

.collContent, .collColumns {
  height: 100%;
  max-height: 0;
  overflow: hidden;
}

.collBlock.collapsed .collContent,
.collBlock.collapsed .collColumns
 {
  max-height: 2000px;
  transition: all 500ms linear;
}

.collBlock.collapsed .collArrow {
  rotate: 180deg;
}


.collGrid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-gap: 20px;
    margin-bottom: 100px;
    width: calc(100%);
    /* transform: translateX(-25px); */
}

.collTitle {
  position: relative;
  margin-bottom: 10px;
}

.collElem {
  display: flex;
  gap: 5px;
}

.collArrow {
  position: absolute;
  left: -30px;
  top: 0;
  width: 20px;
  height: 20px;
}

.collNr {
  flex: 0 0 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: white;
  border-radius: 50%;
  width: 20px;
  height: 20px;
}

.collInnerElem {
  flex: 1 0 50px;
}

.collInnerElem .interBold {
  margin-bottom: 5px;
}


/* fake Marquee */


.fakeMarquee {
  position: relative;
  height: 200px;
  width: 100vw;

  display: flex;
  align-items: center;
  justify-content: center;

}

.gradient {
  position: absolute;
  width: 100%;
  height: 100%;

  background: rgb(255, 255, 255);
    background: linear-gradient(90deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0) 25%, rgba(255, 255, 255, 0) 75%, rgba(255, 255, 255, 1) 100%);

    pointer-events: none;
}

.fakeInnerMarquee {
  width: 4000px;
  display: flex;
  justify-content: center;
}

.fakeInnerMarquee {
  display: inline-flex;
  align-items: center;
  gap: 30px;
}


.fakeMarquee .button {
  white-space: nowrap;
  overflow: hidden;
  margin: 0 20px;
  width: unset;
}

.fakeMarquee.purpleType .button {
  color: var(--darkpurpleColor);
}
.fakeMarquee.purpleType .centralMarqueeElem {
  background-color: var(--purpleColor);
}
.fakeMarquee.purpleType .greenArrow {
  display: none;
}
.fakeMarquee.purpleType .purpleArrow {
  display: block;
}

.fakeMarquee.greenType .button {
  color: var(--darkgreenColor);
}
.fakeMarquee.greenType .centralMarqueeElem {
  background-color: var(--greenColor);
}
.fakeMarquee.greenType .greenArrow {
  display: block;
}

.fakeMarquee.greenType .purpleArrow {
  display: none;
}





/* lightbox */


#lightbox a:before, 
#lightbox a:after {
  display: none;
    content: '';
  
} 



/* .lb-dataContainer {
  visibility: hidden !important;
  pointer-events: none;
} */

/* .lb-nav {
  width: 100%;
}

.lb-cancel {
  border-bottom: none;
} */

  
  /* .lightbox {
    transform: translateX(12.5%);
  } */










