:root{
  --header-height: 3.6em;
  --text-color: black;
  --bg-color: white;
}

/* Hide scrollbar for Chrome, Safari and Opera */
*::-webkit-scrollbar {
  display: none;
}

/* Hide scrollbar for IE, Edge and Firefox */
* {
  -ms-overflow-style: none;  /* IE and Edge */
  scrollbar-width: none;  /* Firefox */
}

html, body{
	margin: 0;
	width: 100%;
  height: 100%;
  overflow: scroll;
/*  background-image: url("screen-m-imprint.png");*/
  background-size: 100% auto;
  background-repeat: no-repeat;
}

body{
  padding: 0.5em;
  position: absolute;
}

.loader{
  width: 100%;
  height: 100%;
  background: white;
  position: fixed;
  left: 0;
  top: 0;
  display: block;
  z-index: 2;
}
* {
  color: var(--text-color);
/*  color: red;*/
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  box-sizing: border-box;

}

@font-face {
  font-family: "NEXTMono";
  src: url("fonts/ivory-mono/Fonts/IvoryMonoLLWeb-Regular.woff2") format("woff2")
}
@font-face {
  font-family: "Folio";
  src: url("fonts/folio/webFonts/FolioStdMedium/font.woff2") format("woff2")
}


.contact, .ext-button, .venue, .city, .country, .menu-button, .imprint p{
  font-family: "Folio";
}
.contact a, .contact a:visited, .ext-button a, .ext-button a:visited{
  color: var(--text-color);
}
.ext-button{
  padding-top: 0.8em;
}
.ext-button a{
   font-weight: 500;
/*  text-shadow: 0 0 3px #FFFFFF;*/
  text-decoration: none;
  font-size: 1.25em;
  letter-spacing: -0.03em;
}
.month, .day, .events-header{
  font-family: "NEXTMono";
  text-transform: uppercase;
}
/*.appear-anim{
  opacity: 0;
  transition: 1.2s opacity;
}*/

.fixed-col-left{
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  justify-content: center;
  position: sticky;
  top: 0;
  height: calc(100vh - 1em);
  
}
.socials{
  position: absolute;
  bottom: 0;
  left: 0;
  
  padding: 0em 0em 0.5em 0.5em;
  width: calc(24vw - 0.5em);
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
}
.socials p{
  page-break-inside: avoid;
    break-inside: avoid;
    -webkit-column-break-inside: avoid; 
}
.socials-links{
  grid-column-start: 1;
  grid-column-end: 3;
  column-count: 2;
  font-family: "NEXTMono";
  text-transform: uppercase;
}
.socials-links a, .socials-links a:visited{
  color: var(--text-color);
  text-decoration: none;
  font-size: 0.8em;
}
.contact{
  font-size: 0.55em;
  /* padding-left: 2.3em; */
  padding-top: 0.2em;
  line-height: 1.10em;
  row-gap: 2em;
  display: grid;
  height: fit-content;
  grid-column-start: 2;

}
.live{
/*  background: rgba(255, 0, 0, 0.5);*/
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(7vw, 1fr));
  row-gap: 3em;
  margin-top: calc(100vh - var(--header-height));
}
.date, .place{
  display: grid;
/*  background: rgba(255, 0, 0, 0.3);*/
  grid-template-columns: repeat(auto-fill, minmax(2vw, 1fr));
  width: 50%;
  row-gap: 0.1em;
}
.date .day{
  grid-row-start: 2;
  grid-column-start: 1;
  margin-left: 5.7em;
}
.place .city{
  grid-row-start: 2;
}
.place .country{
  grid-row-start: 2;
  grid-column-start: 2;
  margin-left: 8em;
}
.city, .country{
  font-size: 0.7em;
    text-transform: uppercase;
}
.month{
  font-size: 1.15em;
}
.event{
  
  display: grid;
  row-gap: 0.3em;
}

.header{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(7vw, 1fr));
  position: sticky;
  top: 0;
}
.title{
  grid-column-start: 3;
    grid-column-end: 6;
    /*display: flex;
    justify-content: center;*/
}
.title svg{
  height: var(--header-height);
 /* filter: drop-shadow(0px 0px 6px rgba(255, 255, 255, .7));
  -webkit-filter: drop-shadow(0px 0px 6px rgba(255, 255, 255, .7));*/
}
.fixed-col-left p{
  margin: 0;
/*  text-shadow: 0 0 3px #FFFFFF;*/
  font-size: 1.05em;
  line-height: 1.1em;
  font-weight: 500;
}

.events-header{
  grid-column-start: 1;
  grid-column-end: 11;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(7vw, 1fr));
  padding: 1em 0em;
  line-height: 0.9em;

}
.events-header .events-title{
  grid-column-start: 4;
  grid-row-start: 1;

}
.events-header .year{
  grid-column-start: 3;
  grid-row-start: 2;
  font-size: 0.8em;
/*  padding-left: 3vw;*/
}

.events-header p{
  margin: 0;
}
.video{
      position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    height: 100vh;
    width: 100%;
}
.video video{
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.header svg{
  fill: var(--text-color);
}
.header a{
      display: contents;
}
.imprint-item{
  margin-bottom: 3em;
  row-gap: 0.3em;
  display: flex;
  flex-direction: column;
}
.imprint-body strong{
  font-family: "NEXTMono";
  font-weight: normal !important;
  text-transform: uppercase;
  break-after: avoid;
  margin-top: 0;
  font-size: 1.2em;
/*  background: red;*/

  width: 100%;

}
.imprint-body p{
    font-family: "Folio";
    break-inside: avoid;
    break-before: avoid;
    margin: 0;
    font-size: 0.7em;
    line-height: 1.15em;
    margin-left: 17%;
}

.imprint a{
  text-decoration: none;
}

@media screen and (orientation:landscape) {
  body{
    display: grid;
    grid-template-columns: 1fr 3fr;
  }
  .desktop-hide{
    display: none;
  }
  .title{
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .music.ext-button.mobile-hide{
    grid-column-start: 7;
  }
  .event{
    margin-bottom: 4em;
  }
  .event.odd{
    grid-column-start: 1;
    grid-column-end: 5;
  }
  .events-header .events-title{
    text-align: center;
    display: flex;
    justify-content: center;
  }
  .event.even{
    grid-column-start: 5;
    grid-column-end: 10;
    padding-left: 3.2em;
  }
  .appear-anim{
    opacity: 0;
    transition: 1.2s opacity;
  }
  .year-events{
    grid-column-start: 1;
    grid-column-end: 11;
    grid-template-columns: repeat(auto-fill, minmax(7vw, 1fr));
    display: grid;
    row-gap: 3em;
  }
  .imprint.mobile-hide{
      grid-column-start: 2;
      grid-column-end: 7;
      /* margin-right: 4em; */
      display: flex;
      align-items: center;
      justify-content: center;
      text-transform: uppercase;
  }
  .imprint.mobile-hide p{
    font-size: 0.7em;
  }
  /*.title, .events-title, .year.mobile-hide, .subscribe, .imprint.mobile-hide{
    margin-right: 5vw !important;
  }*/
  .events-title{white-space: nowrap;}
  .imprint-cont{
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(7vw, 1fr));
    margin-top: 30%;
  }
  .imprint-body{
    grid-column-start: 1;
    grid-column-end: 9;
    column-count: 2;
    column-gap: 6em;
  }
}
@media screen and (orientation:landscape) and (min-width: 1000px){
  .title, .events-title, .year.mobile-hide, .subscribe, .imprint.mobile-hide, form.infomaniak-form{
    margin-right: 5vw;
  }
}

@media screen and (orientation:landscape) and (max-width: 1000px){
  .title, .events-title, .year.mobile-hide, .subscribe, .imprint.mobile-hide, form.infomaniak-form{
    margin-right: 0;
  }
  .videos.ext-button.mobile-hide{
    margin-left: 3vw;
  }
}

/*ipad, tablets*/

@media screen and (min-width: 600px) and (max-width: 820px) and (orientation:portrait), (min-width: 821px) and (orientation:portrait){

}

@media screen and (orientation:portrait){
  :root{
    --header-height: 10vh;
  }
  .appear-anim{
    opacity: 0;
    transition: 1.2s opacity;
  }
  body{
    padding: 0.5em 0.9em;
    overflow-x: hidden;
  }
  .mobile-hide{
    display: none;
  }
	.contact{
    grid-column-start: 1;
  }
  .header{
    position: fixed !important;
    bottom: 2.5em !important;
    top: auto;
    width: 100%;
    display: flex;
    justify-content: center;
    left: 0;
    z-index: 20;
  }
  .live{
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(9vw, 1fr));
    row-gap: 3em;
    margin-top: 0;
    width: 62vw;
    /* background: \red; */
    right: 0;
    position: absolute;
/*    margin-bottom: ;*/
  }
  .event{
    grid-column-start: 2;
    grid-column-end: 6;
    margin-left: 0.2em;
  }
  .events-header{
    grid-column-start: 1;
    padding: 0;
    grid-column-end: 7;
  }
  .events-header .year{
    grid-column-start: 2;
    grid-row-start: 2;
    font-size: 0.8em;
    margin-left: 30vw;
  }
  .events-header .events-title{
    grid-column-start: 1;
    grid-column-end: 5;
  }
  .date, .place{
    display: grid;
    /* background: rgba(255, 0, 0, 0.3); */
    grid-template-columns: repeat(auto-fill, minmax(7vw, 1fr));
    width: 100%;
    row-gap: 0.1em;
  }
  .fixed-col-left p{
    font-size: 1.1em;
    line-height: 1.18em;
  }
  .live{
    margin-top: 10vh;
    padding-bottom: 30vh;
  }
  .mobile-year{
    position: sticky;
    top: 3em;
    right: 1em;
    float: right;
    grid-column-start: 7;
    font-family: "NEXTMono";
    font-size: 0.8em;
    margin-bottom: 0;
  }
  .date, .country{
    text-align: right;
  }
  .mobile-menu{
/*    background: rgba(255, 0, 0, 0.5);*/
    position: fixed;
    width: 100vw;
    left: 100vw;
    top: 0;
    height: 100%;
    z-index: 11;
  }
  .menu-button{
/*    background: green;*/
    position: fixed;
    right: 1em;
    top: 1em;
    z-index: 12;
/*    text-shadow: 0 0 3px #FFFFFF;*/

  }
  .closedmenu .menu-button::before{
    content: "MENU";
  }
  .openmenu .menu-button::before{
    content: "CLOSE";
  }
  .fixed-col-left, .mobile-menu{
    transition: 0.5s transform;
  }

  .closedmenu .fixed-col-left, .closedmenu .mobile-menu{
    transform: translateX(0vw);
  }
  .openmenu .fixed-col-left, .openmenu .mobile-menu{
    transform: translateX(-100vw);
  }
  .menu-content{
    background: white;
    width: 100vw;
    position: absolute;
    right: 0;
    height: 100%;
  }
  .menu-content .menu-left{
    display: flex;
    width: 100%;
    height: 80%;
    flex-direction: column;
    text-align: center;
    position: absolute;
    justify-content: center;
  }
  .menu-content .menu-right{
    position: absolute;
    right: 0;
    /* height: 100%; */
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: flex-end;
/*    bottom: calc((var(--header-height) * 2) + 2.5em );*/
    padding: 0.5em;
    text-align: right;

  }
  .menu-content .menu-right p{
    margin: 0;
  }
  .menu-content .socials-links{
    column-count: 1;
    row-gap: 0.2em;
    display: grid;
    margin-bottom: 1.5em;
  }
  .imprint p{
    font-size: 0.7em;
    text-transform: uppercase;
  }
  .ext-button{
    padding-top: 0.2em;
  }
  .year-events{
    grid-column-start: 1;
    grid-column-end: 7;
    grid-template-columns: repeat(auto-fill, minmax(9vw, 1fr));
    display: grid;
    row-gap: 3em;
  }
  .video{
    height: 82vh;
  }
  .gradient{
/*    background: white;*/
    width: 100%;
    position: absolute;
    height: 200%;
    top: -50%;
    z-index: -1;
    background: var(--bg-color);
    background: linear-gradient(0deg, transparent 0%, var(--bg-color) 30%, var(--bg-color) 70%, transparent 100%);
  }
  .imprint-cont{
    margin-left: 45%;
    margin-top: -60%;
    padding-bottom: 50%;
  }
  .menu-bg{
    background: white;
    position: fixed;
    right: 0px;
    top: 0px;
    height: 7vh;
    width: 63%;
  }

}
