@font-face {
  font-family: Degular;
  src: url('../fonts/Degular-Bold.woff2') format("woff2"), url('../fonts/Degular-Bold.woff') format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Degular;
  src: url('../fonts/Degular-Regular.woff2') format("woff2"), url('../fonts/Degular-Regular.woff') format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: Digestive;
  src: url('../fonts/Digestive.woff2') format("woff2"), url('../fonts/Digestive.woff') format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

:root {
  --black: black;
  --highlight: #3a183f;
  --border-small: 1px;
  --primary: #ed7466;
  --border: 2px;
  --white: white;
}

body {
  color: var(--black);
  font-family: Degular, sans-serif;
  font-size: 18px;
  line-height: 29px;
}

h1 {
  text-align: left;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 20px;
  font-family: Digestive, sans-serif;
  font-size: 25vw;
  font-weight: 400;
  line-height: 100%;
}

h2 {
  text-transform: uppercase;
  margin-top: 40px;
  margin-bottom: 0;
  font-family: Digestive, sans-serif;
  font-size: 250px;
  font-weight: 400;
  line-height: 80%;
  display: inline-block;
}

h3 {
  letter-spacing: -1px;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Degular, sans-serif;
  font-size: 4vw;
  font-weight: 700;
  line-height: 75%;
  display: inline-block;
}

h4 {
  color: var(--highlight);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-top: 0;
  margin-bottom: 0;
  font-family: Degular, sans-serif;
  font-size: 1.8vw;
  font-weight: 700;
  line-height: 85%;
  display: inline-block;
}

h5 {
  letter-spacing: .25px;
  text-transform: uppercase;
  margin-top: 10px;
  margin-bottom: 10px;
  font-family: Degular, sans-serif;
  font-size: 18px;
  font-weight: 700;
  line-height: 135%;
}

h6 {
  margin-top: 10px;
  margin-bottom: 10px;
  font-size: 15px;
  font-weight: 400;
  line-height: 125%;
}

p {
  margin-bottom: 0;
  font-family: Degular, sans-serif;
  font-weight: 400;
  line-height: 135%;
}

a {
  color: var(--highlight);
  text-decoration: underline;
  transition: all .35s;
}

a:hover {
  color: var(--highlight);
}

.content {
  z-index: 2;
  max-width: none;
  margin-left: auto;
  margin-right: auto;
  padding: 0;
  display: block;
  position: relative;
}

.style-name {
  color: #d4d4d4;
  text-transform: uppercase;
  border-top: 1px solid #d4d4d4;
  border-bottom: 0 #d4d4d4;
  margin-top: 20px;
  margin-bottom: 20px;
  font-size: 14px;
}

.p-small {
  color: var(--black);
  margin-bottom: 10px;
  font-size: 15px;
  line-height: 150%;
}

.button {
  border: var(--border-small) solid var(--highlight);
  background-color: var(--primary);
  color: var(--highlight);
  letter-spacing: .5px;
  text-transform: uppercase;
  border-radius: 0;
  margin: 2px 0;
  padding: 2px 8px;
  font-family: Degular, sans-serif;
  font-size: 15px;
  font-weight: 700;
  transition: all .35s;
}

.button:hover {
  background-color: var(--highlight);
  color: var(--primary);
}

.button:visited {
  color: var(--highlight);
}

.button.w--current {
  background-color: var(--primary);
  color: var(--highlight);
}

.button.button-invert {
  border: var(--border-small) solid var(--primary);
  background-color: var(--highlight);
  color: var(--primary);
}

.button.button-invert:hover {
  border-style: solid;
  border-color: var(--highlight);
  background-color: var(--primary);
  color: var(--highlight);
}

.button.button-invert.button-ovl {
  border-width: var(--border-small);
}

.button.button-invert.button-ovl.button-big {
  border-color: var(--primary);
  letter-spacing: .1vw;
  border-radius: 0;
  margin-top: 60px;
  padding: 16px 24px;
  font-size: 36px;
}

.button.button-invert.button-ovl.button-big:hover {
  border-color: var(--highlight);
}

.button.button-invert.accept-cookies {
  border-color: var(--highlight);
  margin-top: 30px;
  margin-right: 10px;
}

.button.decline-cookies {
  margin-right: 10px;
}

.button.button-ovl.more-info {
  margin-top: 2px;
  margin-bottom: 2px;
  padding: 2px 8px;
}

.section {
  padding: 200px 35px;
}

.section.hero {
  align-items: center;
  height: 100vh;
  padding: 15vh 35px 0;
  display: flex;
}

.section.festival-top {
  background-image: url('../images/background-festival-top.svg');
  background-position: 50% 0;
  background-repeat: no-repeat;
  background-size: 100vw;
  padding-top: 230px;
  padding-bottom: 0;
}

.section.primary {
  background-color: var(--primary);
}

.section.primary.about {
  z-index: 2;
  padding-bottom: 100px;
  position: relative;
}

.section.primary.foerderer {
  padding-top: 100px;
  padding-bottom: 100px;
}

.section.footer {
  z-index: 2;
  background-color: var(--primary);
  padding-top: 50px;
  padding-bottom: 50px;
  position: relative;
}

.section.festival-lineup {
  background-color: var(--primary);
  padding-top: 0;
  padding-bottom: 0;
}

.section.festival {
  background-color: #0000;
  background-image: url('../images/background-festival-middle.svg');
  background-position: 50% 0;
  background-repeat: no-repeat;
  background-size: 100vw;
  padding-top: 45vw;
  padding-bottom: 0;
  position: static;
  top: auto;
}

.container {
  width: 100%;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: 15px;
  padding-right: 15px;
  display: block;
}

.row {
  flex-wrap: wrap;
  align-content: stretch;
  margin-left: -15px;
  margin-right: -15px;
  display: flex;
}

.row.row-faq {
  margin-top: 0;
}

.row.row-border-top {
  border-top: 1px solid var(--highlight);
  justify-content: flex-start;
  align-items: center;
  padding-top: 70px;
}

.row.row-border-bottom {
  border-bottom: 1px solid var(--highlight);
  padding-bottom: 60px;
}

.inner-div-example {
  border: 1px solid var(--primary);
  text-align: center;
  background-color: #e7855b40;
  padding-top: 15px;
  padding-bottom: 15px;
}

.col {
  flex: 1;
  align-items: flex-start;
  margin-bottom: 15px;
  padding-left: 15px;
  padding-right: 15px;
  display: block;
  position: relative;
}

.col.col-9 {
  flex-basis: 75%;
  max-width: 75%;
}

.col.col-2 {
  flex-basis: 16.67%;
  max-width: 16.6667%;
}

.col.col-2.alight-right {
  justify-content: flex-end;
  display: flex;
}

.col.col-11 {
  flex-basis: 91.67%;
  max-width: 91.6667%;
}

.col.col-7 {
  flex-basis: 58.33%;
  max-width: 58.3333%;
}

.col.col-7.col-h {
  justify-content: space-between;
  align-items: center;
  margin-bottom: 40px;
  display: flex;
}

.col.col-7.center {
  text-align: left;
}

.col.col-6 {
  flex-basis: 50%;
  max-width: 50%;
}

.col.col-6.col-h {
  flex-flow: row;
  justify-content: flex-start;
  align-items: center;
  display: flex;
  overflow: visible;
}

.col.col-5 {
  flex-basis: 41.67%;
  max-width: 41.6667%;
}

.col.col-3 {
  flex-basis: 25%;
  max-width: 25%;
}

.col.col-3.col-electronisch {
  margin-top: -6vw;
}

.col.col-3.col-hip-hop {
  margin-top: -7vw;
}

.col.col-12 {
  flex-basis: 100%;
  max-width: 100%;
}

.col.col-8 {
  flex-basis: 66.67%;
  max-width: 66.6667%;
}

.col.col-8.center {
  text-align: center;
}

.col.col-4 {
  flex-basis: 33.33%;
  max-width: 33.3333%;
}

.col.col-1 {
  flex-basis: 8.33%;
  max-width: 8.33333%;
}

.col.col-10 {
  flex-basis: 83.33%;
  max-width: 83.3333%;
}

.col.col-center {
  flex-direction: column;
  align-items: center;
  display: flex;
}

.p-large {
  font-size: 21px;
}

.body {
  background-color: var(--primary);
  color: var(--highlight);
  font-family: Degular, sans-serif;
  font-size: 15px;
  line-height: 150%;
}

.body.no-scroll {
  overflow: hidden;
}

.accordion-item {
  width: 100%;
  line-height: 150%;
  overflow: hidden;
}

.accordion-toggle {
  border-top: var(--border) none var(--highlight);
  border-bottom: var(--border-small) solid var(--highlight);
  justify-content: space-between;
  align-items: center;
  height: 35px;
  margin-top: 0;
  margin-bottom: 0;
  padding: 0 0 6px;
  transition: all .35s;
  display: flex;
}

.accordion-toggle:hover {
  color: var(--highlight);
  background-color: #0000;
  padding-left: 20px;
}

.accordion-icon {
  background-color: var(--highlight);
  color: var(--primary);
  justify-content: center;
  align-items: center;
  width: 16px;
  height: 16px;
  padding-left: 3px;
  padding-right: 3px;
  display: flex;
}

.text-block {
  white-space: normal;
  flex: none;
  width: 100%;
}

.accordion-content {
  border-bottom: var(--border-small) solid var(--highlight);
  background-color: #0000;
  padding: 20px 0;
  display: block;
  position: static;
}

.heading {
  font-family: Digestive, sans-serif;
  font-size: 250px;
  font-weight: 400;
  line-height: 80%;
}

.heading-2 {
  letter-spacing: 0;
  line-height: 80%;
}

.paragraph {
  letter-spacing: .25px;
}

.background-video {
  z-index: 1;
  width: 100vw;
  height: 100vh;
  position: fixed;
}

.navbar {
  z-index: 3;
  background-color: #0000;
  flex-direction: column;
  justify-content: space-between;
  width: auto;
  height: 100vh;
  padding-right: 20px;
  display: block;
  position: fixed;
  right: 0;
}

.nav-menu-wrapper {
  padding-top: 20px;
}

.nav-socials-wrapper {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-end;
  display: flex;
  position: absolute;
  bottom: 20px;
  right: 20px;
}

.nav-socials-wrapper.mobile {
  display: none;
}

.nav-menu {
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-end;
  display: flex;
  position: relative;
  top: 0;
}

.logo {
  text-align: left;
  width: 6vw;
}

.heading-3 {
  margin-bottom: 0;
  line-height: 100%;
}

.date {
  text-align: center;
  letter-spacing: 0;
  text-transform: uppercase;
  margin-bottom: 5px;
  font-size: 36px;
  font-weight: 400;
  line-height: 80%;
}

.date.content {
  text-align: left;
  letter-spacing: 0;
  margin-bottom: 40px;
  font-size: 2vw;
  line-height: 80%;
}

.date.hidden {
  font-size: 2vw;
  display: inline-flex;
}

.date.info {
  font-size: 36px;
  font-weight: 400;
}

.button-tickets {
  border: 1px solid var(--highlight);
  background-color: var(--highlight);
  color: var(--primary);
  text-align: center;
  letter-spacing: .75px;
  text-transform: uppercase;
  border-radius: 500px;
  justify-content: center;
  align-items: center;
  width: 20vw;
  height: 20vw;
  font-size: 3.5vw;
  font-weight: 700;
  line-height: 100%;
  text-decoration: underline;
  display: flex;
}

.button-tickets:hover {
  border: 1px solid var(--highlight);
  background-color: var(--primary);
  color: var(--highlight);
}

.button-tickets.button-ovl {
  background-color: var(--highlight);
  color: var(--primary);
  border-style: none;
  margin-top: -8vw;
  font-size: 3.5vw;
}

.button-tickets.button-ovl:hover {
  background-color: var(--primary);
  color: var(--highlight);
  border-style: solid;
  transform: rotate(360deg);
}

.section-inner {
  padding-left: 35px;
  padding-right: 35px;
}

.p-caps {
  text-transform: uppercase;
  margin-bottom: 13px;
  font-weight: 700;
  line-height: 100%;
}

.p-bold {
  font-weight: 700;
}

.accordion {
  border-top: var(--border-small) solid var(--highlight);
  margin-bottom: 90px;
  padding-top: 7px;
}

.p-accordion {
  margin-bottom: 0;
}

.trenner-festival {
  width: 100%;
  max-width: none;
  overflow: clip;
}

.trenner-festival.mobile {
  display: none;
}

.events {
  border-top: var(--border-small) solid var(--highlight);
}

.event {
  border-bottom: var(--border-small) solid var(--highlight);
  align-items: flex-start;
  min-height: 200px;
  padding-top: 10px;
  padding-bottom: 10px;
  display: flex;
}

.event-infos {
  width: 42.85%;
}

.event-links {
  flex-direction: column;
  justify-content: flex-end;
  align-items: flex-end;
  width: 14.3%;
  display: flex;
}

.event-date {
  text-transform: uppercase;
  font-weight: 700;
}

.h4-event {
  margin-top: 0;
  margin-bottom: 15px;
  font-size: 1.8vw;
  display: inline-block;
}

.event-lineup {
  width: 42.85%;
}

.slider {
  border: var(--border-small) solid var(--highlight);
  background-color: #0000;
  height: auto;
}

.slider.mobile {
  display: none;
}

.gallery-img {
  width: 100%;
  transition: all .35s;
}

.gallery-img:hover {
  transform: scale(1.1);
}

.gallery-img.mobile {
  display: none;
}

.slider-arrow {
  width: auto;
  padding: 10px;
  transition: all .35s;
  inset: auto auto 30px 30px;
}

.slider-arrow:hover {
  transform: scale(1.3);
}

.slider-arrow.right {
  transition: all .35s;
  left: 70px;
}

.slider-arrow-img {
  width: 30px;
}

.slider-nav {
  text-align: left;
  bottom: 35px;
  left: 200px;
}

.link-footer {
  letter-spacing: .5px;
  text-transform: uppercase;
  margin-right: 0;
  font-weight: 700;
  text-decoration: none;
}

.link-footer.padding {
  margin-right: 40px;
}

.anchor {
  width: 1px;
  height: 1px;
  margin-top: 0;
  position: relative;
  bottom: -75vh;
}

.anchor.festival {
  bottom: -25vh;
}

.anchor.about {
  bottom: -76vh;
}

.anchor.moments {
  bottom: -80vh;
}

.festival-middle {
  width: 100%;
}

.overlays {
  position: absolute;
}

.overlay {
  z-index: 4;
  background-color: var(--primary);
  width: 100vw;
  height: 100vh;
  padding-top: 50px;
  padding-bottom: 50px;
  position: fixed;
  inset: 0%;
  overflow: scroll;
}

.overlay.faq {
  opacity: 1;
  transform: translate(-100vw);
}

.overlay.datenschutz, .overlay.impressum, .overlay.tickets {
  transform: translate(-100vw);
}

.ovl-close {
  background-color: var(--highlight);
  cursor: pointer;
  justify-content: center;
  align-items: center;
  width: 38px;
  height: 38px;
  display: flex;
  position: fixed;
  top: 50px;
  right: 50px;
}

.close-line {
  aspect-ratio: auto;
  background-color: var(--primary);
  width: 24px;
  height: 3px;
  position: absolute;
  transform: rotate(45deg);
}

.close-line._02 {
  transform: rotate(-45deg);
}

.button-ovl {
  border: var(--border-small) solid var(--highlight);
  background-color: var(--primary);
  color: var(--highlight);
  letter-spacing: .5px;
  text-transform: uppercase;
  margin-top: 3px;
  margin-bottom: 3px;
  padding: 4px 9px;
  font-weight: 700;
}

.button-ovl:hover {
  background-color: var(--highlight);
  color: var(--primary);
}

.button-ovl-close {
  border: var(--border) solid var(--highlight);
  background-color: var(--primary);
  color: var(--highlight);
  letter-spacing: .5px;
  text-transform: uppercase;
  margin-top: 3px;
  margin-bottom: 3px;
  padding: 4px 9px;
  font-weight: 700;
}

.button-ovl-close:hover {
  background-color: var(--highlight);
  color: var(--primary);
}

.p-space {
  margin-top: 0;
  margin-bottom: 40px;
}

.link-footer-ovl {
  letter-spacing: .5px;
  text-transform: uppercase;
  font-weight: 700;
  text-decoration: none;
}

.link-footer-ovl.padding {
  margin-right: 40px;
}

.heading-4 {
  font-size: 12vw;
}

.p-bold-large {
  font-size: 42px;
  font-weight: 700;
  line-height: 90%;
}

.h4-lineup {
  letter-spacing: 0;
  margin-bottom: 12px;
  font-size: 14px;
  font-weight: 400;
  line-height: 100%;
}

.h2-festival {
  font-size: 13vw;
}

.h2-festival.slide-left {
  margin-top: 0;
  display: block;
}

.h2-festival.slide-left.hidden {
  display: none;
}

.slide {
  overflow: hidden;
}

.h3-legal {
  margin-bottom: 75px;
  display: block;
}

.p-caps-large {
  text-transform: uppercase;
  margin-bottom: 20px;
  font-size: 30px;
  font-weight: 700;
  line-height: 100%;
}

.text-regular {
  font-weight: 400;
  text-decoration: none;
}

.heading-7 {
  font-size: 1.8vw;
}

.link-ext {
  background-image: url('../images/external-link.svg');
  background-position: 100% 40%;
  background-repeat: no-repeat;
  background-size: 10px;
  padding-right: 14px;
  text-decoration: none;
}

.link-ext:hover {
  padding-left: 15px;
}

.slider-mobile-wrapper {
  display: none;
}

.slide-left {
  color: var(--highlight);
}

.img-wrapper {
  width: 29.6vw;
  height: 29.6vw;
}

.img-wrapper.about {
  background-image: url('../images/team.jpg');
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  justify-content: center;
  align-items: center;
  transition: all .35s;
  display: flex;
  overflow: hidden;
}

.img-wrapper.about:hover {
  background-size: 115% 115%;
}

.consent-wrapper {
  z-index: 10;
  border: 1px none var(--highlight);
  background-color: #0000;
  width: 33vw;
  padding: 0;
  position: fixed;
  bottom: 20px;
  left: 20px;
  right: auto;
}

.consent-popup {
  border: 1px solid var(--highlight);
  background-color: var(--primary);
  padding: 50px;
}

.hidden {
  display: none;
}

.foerderer {
  width: auto;
  max-width: none;
  height: auto;
  overflow: hidden;
}

.foerderer.stage {
  width: 23%;
}

.foerderer.vpby {
  width: 18%;
  margin-left: 0;
  margin-right: 0;
}

.foerderer.bswk {
  width: 35%;
}

.bus-stationen-wrapper {
  flex-flow: wrap;
  justify-content: space-between;
  margin-bottom: 25px;
  display: flex;
}

.bus-station {
  border: 1px solid var(--highlight);
  background-color: var(--highlight);
  color: var(--primary);
  width: 32%;
  padding: 10px 20px 20px;
}

.bus-station.center {
  width: 30%;
  margin-left: 0;
  margin-right: 0;
}

.h-bus-stops {
  margin-top: 40px;
  margin-bottom: 20px;
}

.map-link, .p-bus {
  margin-top: 20px;
  margin-bottom: 20px;
}

.h5-bus {
  margin-bottom: 20px;
}

.p-big, .h4-festival {
  margin-top: 90px;
}

.h1-onemoretime {
  margin-bottom: 40px;
  padding-left: .5vw;
  padding-right: .5vw;
  font-family: Degular, sans-serif;
  font-size: 12vw;
  font-weight: 700;
}

.button-2 {
  color: #662d86;
  letter-spacing: .5px;
  text-transform: uppercase;
  background-color: #ffffa3;
  border: 1px solid #662d86;
  border-radius: 0;
  margin: 2px 0;
  padding: 2px 8px;
  font-family: Degular, sans-serif;
  font-size: 15px;
  font-weight: 700;
  transition: all .35s;
}

.button-2:hover {
  color: #ffffa3;
  background-color: #662d86;
}

.button-2:visited {
  color: #662d86;
}

.button-2.button-invert {
  color: #ffffa3;
  background-color: #662d86;
  border: 1px solid #ffffa3;
}

.button-2.button-invert:hover {
  color: #662d86;
  background-color: #ffffa3;
  border-style: solid;
  border-color: #662d86;
}

.h1-wrapper {
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  justify-content: center;
  align-items: center;
  width: 85vw;
  display: flex;
  overflow: hidden;
}

._10-years-wrapper {
  flex-flow: column;
  justify-content: center;
  align-items: flex-start;
  display: flex;
}

.h1-10 {
  letter-spacing: -1vw;
  margin-bottom: 1vw;
  font-family: Degular, sans-serif;
  font-size: 17.9vw;
  font-weight: 700;
  line-height: 60%;
}

.h1-years {
  margin-bottom: 0;
  padding-left: .75vw;
  font-family: Degular, sans-serif;
  font-size: 5.7vw;
  font-weight: 700;
  line-height: 60%;
}

.h1-lms {
  font-size: 20vw;
}

.text-re {
  text-decoration: none;
}

.h1-wrapper-outter {
  flex-flow: column;
  justify-content: center;
  align-items: center;
  height: 21vw;
  display: flex;
  overflow: visible;
}

@media screen and (min-width: 1440px) {
  h3 {
    font-size: 60px;
  }

  h4 {
    font-size: 30px;
  }

  .button {
    border-width: var(--border-small);
    font-size: 18px;
  }

  .row.row-border-bottom {
    padding-bottom: 60px;
  }

  .body {
    font-size: 15px;
  }

  .accordion-toggle {
    border-top-width: var(--border-small);
    border-bottom-width: var(--border-small);
  }

  .accordion-content {
    border-bottom-width: var(--border-small);
  }

  .button-tickets.button-ovl {
    margin-top: 0;
  }

  .p-caps {
    font-size: 18px;
  }

  .accordion {
    border-top-width: var(--border-small);
  }

  .trenner-festival {
    overflow: visible;
  }

  .events {
    border-top-width: var(--border-small);
  }

  .event {
    border-bottom-width: var(--border-small);
    padding-top: 20px;
    padding-bottom: 20px;
  }

  .h4-event {
    font-size: 30px;
  }

  .slider {
    border-bottom-width: var(--border);
  }

  .button-ovl {
    border-width: var(--border-small);
  }

  .h4-lineup {
    font-size: 18px;
  }

  .heading-8 {
    font-size: 36px;
  }

  .foerderer.stage {
    width: 21%;
  }

  .h-bus-stops {
    margin-top: 30px;
  }

  .button-2 {
    border-width: 1px;
    font-size: 18px;
  }
}

@media screen and (max-width: 991px) {
  h1 {
    text-align: center;
    margin-top: 30px;
    margin-bottom: 40px;
    font-size: 43vw;
    line-height: 81%;
  }

  h2 {
    font-size: 25vw;
  }

  h3 {
    margin-bottom: 35px;
    font-size: 60px;
  }

  h4 {
    font-size: 30px;
  }

  h5 {
    font-size: 15px;
  }

  h6 {
    font-size: 12px;
  }

  p {
    margin-bottom: 0;
    font-size: 18px;
  }

  .p-small {
    font-size: 12px;
  }

  .button {
    font-size: 15px;
    display: inline-block;
  }

  .button.button-invert {
    border-color: var(--highlight);
  }

  .button.hidden {
    display: none;
  }

  .section {
    padding: 100px 35px;
  }

  .section.festival {
    padding-top: 55vw;
  }

  .row.row-lineup {
    position: relative;
    top: -50px;
  }

  .row.row-border-top {
    padding-top: 50px;
  }

  .row.row-border-bottom {
    padding-bottom: 40px;
  }

  .col {
    max-width: 100%;
  }

  .col.col-9, .col.col-2 {
    flex-basis: 100%;
    max-width: 100%;
  }

  .col.col-2.alight-right.footer {
    flex-basis: 50%;
    max-width: 50%;
  }

  .col.col-11, .col.col-7, .col.col-6 {
    flex-basis: 100%;
    max-width: 100%;
  }

  .col.col-6.footer {
    flex-basis: 50%;
    max-width: 50%;
  }

  .col.col-5, .col.col-3 {
    flex-basis: 100%;
    max-width: 100%;
  }

  .col.col-3.col-electronisch {
    margin-bottom: 0;
  }

  .col.col-3.col-hip-hop {
    margin-top: 30px;
  }

  .col.col-8, .col.col-4 {
    flex-basis: 100%;
    max-width: 100%;
  }

  .col.col-4.align-right {
    justify-content: flex-end;
    display: flex;
  }

  .col.col-1, .col.col-10 {
    flex-basis: 100%;
    max-width: 100%;
  }

  .p-large {
    font-size: 18px;
  }

  .body {
    font-size: 15px;
  }

  .navbar {
    width: 100vw;
    height: auto;
    padding-top: 20px;
  }

  .nav-menu-wrapper {
    padding-top: 0;
  }

  .nav-socials-wrapper {
    display: none;
  }

  .nav-socials-wrapper.mobile {
    align-items: flex-start;
    display: flex;
    bottom: 35px;
    left: 35px;
    right: auto;
  }

  .nav-menu {
    background-color: var(--primary);
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    width: 100vw;
    height: 100vh;
    padding: 35px;
    display: flex;
    position: absolute;
    inset: 0% 0% 0% auto;
  }

  .logo {
    width: 15vw;
  }

  .date {
    font-size: 4vw;
  }

  .date.content {
    letter-spacing: -.075vw;
    font-size: 4vw;
    line-height: 100%;
  }

  .button-tickets.button-ovl {
    width: 30vw;
    height: 30vw;
    margin-top: -5vw;
    position: relative;
    top: -100px;
  }

  .accordion {
    border-top-width: var(--border-small);
  }

  .trenner-festival.mobile {
    display: none;
  }

  .events {
    border-top-width: var(--border-small);
  }

  .h4-event {
    font-size: 30px;
  }

  .slider {
    border-top-width: var(--border-small);
  }

  .slider.mobile {
    display: none;
  }

  .gallery-img:hover {
    transform: none;
  }

  .gallery-img.mobile {
    display: none;
  }

  .anchor {
    bottom: 10vh;
  }

  .anchor.festival {
    bottom: 40vh;
  }

  .button-ovl {
    border-top-width: var(--border-small);
  }

  .p-space {
    margin-bottom: 35px;
  }

  .heading-4 {
    font-size: 20vw;
  }

  .heading-5 {
    font-size: 27vw;
  }

  .menu-button {
    z-index: 10;
    border: var(--border-small) solid var(--highlight);
    background-color: var(--primary);
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 40px;
    height: 40px;
    padding: 0;
    display: flex;
  }

  .menu-button.w--open {
    background-color: var(--highlight);
  }

  .burger-slice {
    height: var(--border-small);
    background-color: var(--highlight);
    width: 26px;
    margin-top: 2px;
    margin-bottom: 2px;
    padding: 0;
    position: relative;
  }

  .h4-lineup {
    margin-bottom: 15px;
    font-size: 14px;
  }

  .h2-festival {
    font-size: 20vw;
  }

  .slider-mobile-wrapper {
    display: none;
  }

  .img-wrapper.about {
    width: 88vw;
    height: 88vw;
  }

  .img-wrapper.about:hover {
    background-size: 100% 100%;
  }

  .consent-wrapper {
    width: auto;
    right: 20px;
  }

  .button-2 {
    font-size: 15px;
    display: inline-block;
  }

  .button-2.button-invert {
    border-color: #662d86;
  }

  .h1-wrapper {
    grid-column-gap: 15px;
    grid-row-gap: 15px;
  }

  .h1-10 {
    margin-top: 0;
    margin-bottom: 1vw;
  }

  .h1-years {
    margin-top: 0;
  }
}

@media screen and (max-width: 767px) {
  h3 {
    margin-bottom: 10px;
    font-size: 30px;
  }

  h4 {
    font-size: 20px;
  }

  .button {
    margin-right: 5px;
  }

  .button.button-invert.button-ovl.button-big {
    margin-top: 30px;
    font-size: 24px;
  }

  .button.button-invert.button-ovl.button-big:hover {
    margin-top: 30px;
  }

  .button.decline-cookies {
    display: inline-block;
  }

  .section {
    padding: 50px 25px;
  }

  .section.hero {
    padding-top: 0;
  }

  .section.festival-top {
    background-image: linear-gradient(to bottom, #ffffa300, var(--primary) 58%), url('../images/background-festival-top.svg');
    background-position: 0 0, 50% 0;
    background-repeat: repeat, no-repeat;
    background-size: auto, 100vw;
  }

  .section.primary.moments {
    padding-left: 0;
    padding-right: 0;
  }

  .section.primary.foerderer {
    margin-top: 0;
    margin-bottom: 0;
  }

  .section.festival {
    background-image: linear-gradient(180deg, #ffffa300, var(--primary) 89%), url('../images/background-festival-middle-mobile_1.svg');
    background-position: 0 0, 50% 0;
    background-repeat: repeat, no-repeat;
    background-size: auto, 100%;
    padding-top: 53vw;
    padding-bottom: 10vw;
  }

  .row.row-lineup {
    top: 30px;
  }

  .row.row-border-top {
    padding-top: 20px;
  }

  .row.row-border-bottom {
    padding-bottom: 20px;
  }

  .col.col-9, .col.col-2 {
    flex-basis: 100%;
    max-width: 100%;
  }

  .col.col-2.alight-right {
    flex-direction: column;
    justify-content: flex-start;
    margin-top: 15px;
  }

  .col.col-11, .col.col-7 {
    flex-basis: 100%;
    max-width: 100%;
  }

  .col.col-7.col-h {
    flex-flow: column;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 15px;
  }

  .col.col-6, .col.col-6.footer, .col.col-5, .col.col-3 {
    flex-basis: 100%;
    max-width: 100%;
  }

  .col.col-3.col-moments {
    padding-left: 40px;
  }

  .col.col-8, .col.col-4, .col.col-1, .col.col-10 {
    flex-basis: 100%;
    max-width: 100%;
  }

  .p-large {
    font-size: 15px;
    font-weight: 500;
  }

  .body {
    background-color: var(--primary);
  }

  .accordion-toggle {
    height: 35px;
  }

  .nav-menu {
    height: 100svh;
  }

  .date {
    font-size: 24px;
  }

  .date.hidden {
    font-size: 5vw;
  }

  .date.info {
    font-size: 24px;
  }

  .p-caps {
    margin-bottom: 17px;
  }

  .trenner-festival {
    display: none;
  }

  .trenner-festival.mobile {
    display: block;
  }

  .event {
    flex-direction: column;
    padding-top: 15px;
    padding-bottom: 0;
  }

  .event-infos {
    width: 100%;
    margin-bottom: 20px;
  }

  .event-links {
    flex-direction: row;
    justify-content: flex-start;
    align-items: flex-start;
    margin-bottom: 20px;
  }

  .h4-event {
    margin-top: 0;
    margin-bottom: 0;
    font-size: 20px;
  }

  .event-lineup {
    width: 100%;
    margin-bottom: 15px;
  }

  .slider {
    border-style: none;
    display: none;
  }

  .slider.mobile {
    display: block;
  }

  .gallery-img {
    display: none;
  }

  .gallery-img.mobile {
    width: 90%;
    margin-right: 15px;
    display: inline-block;
  }

  .slider-arrow, .slider-nav {
    display: none;
  }

  .anchor.moments {
    bottom: 10vh;
  }

  .h4-lineup {
    margin-bottom: 15px;
    font-size: 14px;
  }

  .mask {
    width: 100%;
    padding-left: 40px;
    left: auto;
  }

  .slide {
    border: var(--border-small) solid var(--highlight);
    width: 90%;
    margin-right: 15px;
  }

  .slide._01 {
    margin-left: 35px;
  }

  .p-caps-large {
    font-size: 24px;
  }

  .link-ext {
    background-size: 9px;
    padding-right: 12px;
  }

  .slider-mobile-wrapper {
    padding-left: 15px;
    padding-right: 15px;
    display: block;
    overflow: scroll;
  }

  .slider-mobile-wrapper-inner {
    display: flex;
  }

  .slide-left {
    margin-bottom: 20px;
  }

  .img-wrapper.about {
    width: 87vw;
    height: 87vw;
  }

  .consent-wrapper {
    padding: 0;
  }

  .consent-popup {
    padding: 20px;
  }

  .foerderer {
    margin-top: 15px;
    margin-bottom: 15px;
  }

  .foerderer.stage {
    width: 35%;
  }

  .foerderer.vpby {
    width: 28%;
  }

  .foerderer.bswk {
    width: 52%;
  }

  .bus-stationen-wrapper {
    flex-flow: column;
  }

  .bus-station {
    width: 100%;
    margin-bottom: 10px;
  }

  .h1-onemoretime {
    text-align: center;
    word-break: normal;
    width: 100%;
    height: auto;
    margin-top: 0;
    margin-bottom: 0;
    font-size: 25vw;
    line-height: 76%;
    overflow: visible;
  }

  .button-2 {
    margin-right: 5px;
  }

  .h1-wrapper {
    grid-column-gap: 0px;
    grid-row-gap: 0px;
    flex-flow: column;
    height: 90vw;
    margin-top: 0;
    overflow: hidden;
  }

  .h1-wrapper.hidden {
    display: none;
  }

  .h1-10 {
    letter-spacing: -5vw;
    margin-bottom: 2.5vw;
    font-size: 70vw;
  }

  .h1-years {
    padding-left: 3.7vw;
    font-size: 22vw;
  }

  .h1-lms {
    margin-top: 1.5vw;
    padding-left: 1vw;
    font-size: 21vw;
  }

  .h1-wrapper-outter {
    height: 90vw;
    margin-top: 35px;
  }
}

@media screen and (max-width: 479px) {
  h1 {
    font-size: 56vw;
    line-height: 81%;
  }

  h2 {
    font-size: 30px;
    line-height: 33px;
  }

  h3 {
    letter-spacing: 0;
    font-size: 30px;
    line-height: 31px;
  }

  h4 {
    letter-spacing: 0;
    font-size: 20px;
    line-height: 26px;
  }

  h5 {
    font-size: 16px;
    line-height: 22px;
  }

  p {
    margin-bottom: 0;
    font-size: 16px;
    line-height: 135%;
  }

  a {
    font-size: 15px;
  }

  .p-small {
    font-size: 13px;
    line-height: 22px;
  }

  .button {
    font-size: 15px;
  }

  .button.button-invert.button-ovl.button-big {
    font-size: 21px;
  }

  .section.primary.moments {
    position: relative;
  }

  .section.primary.foerderer {
    padding-top: 50px;
  }

  .section.festival {
    background-image: linear-gradient(180deg, #ffffa300, var(--primary) 36%), url('../images/background-festival-middle-mobile.svg');
    padding-top: 60vw;
  }

  .row {
    flex-wrap: wrap;
  }

  .row.row-slider {
    display: block;
  }

  .row.row-border-top, .row.row-border-bottom {
    margin-left: 0;
    margin-right: 0;
  }

  .col {
    flex-basis: 100%;
    max-width: 100%;
  }

  .col.col-9.col-slider {
    flex-basis: 100vw;
    width: 100%;
    max-width: 100%;
    padding-left: 0;
    padding-right: 0;
    left: -25px;
  }

  .col.col-7.col-h, .col.col-7.center {
    padding-left: 0;
    padding-right: 0;
  }

  .col.col-center.col-top {
    margin-bottom: 40px;
  }

  .accordion-toggle {
    height: 35px;
  }

  .nav-socials-wrapper.mobile {
    bottom: 35vh;
  }

  .nav-menu {
    height: 120vh;
    padding-bottom: 35px;
  }

  .logo {
    width: 25vw;
  }

  .date {
    font-size: 21px;
  }

  .date.content {
    font-size: 6vw;
  }

  .date.info {
    font-size: 21px;
  }

  .button-tickets {
    font-size: 4vw;
  }

  .button-tickets.button-ovl {
    letter-spacing: 1px;
    width: 35vw;
    height: 35vw;
    font-size: 5.5vw;
    line-height: 120%;
    top: -80px;
  }

  .p-caps {
    font-size: 16px;
    line-height: 100%;
  }

  .event {
    flex-direction: column;
  }

  .event-infos {
    width: 100%;
    margin-bottom: 20px;
  }

  .slider {
    width: 100%;
    padding-left: 40px;
    left: -40px;
    overflow: visible;
  }

  .slider.mobile {
    width: auto;
    padding-left: 0;
    left: auto;
  }

  .gallery-img.mobile {
    width: 90%;
    max-width: 100%;
    margin-right: 15px;
  }

  .anchor.about {
    bottom: 10vw;
  }

  .anchor.moments {
    bottom: 10vh;
  }

  .p-bold-large {
    font-size: 30px;
    line-height: 85%;
  }

  .h4-lineup {
    font-size: 14px;
  }

  .h2-festival {
    font-size: 25vw;
    line-height: 81%;
  }

  .paragraph-2 {
    font-size: 16px;
    line-height: 110%;
  }

  .paragraph-3 {
    margin-bottom: 35px;
  }

  .mask {
    width: auto;
    padding-left: 0;
    left: auto;
  }

  .slide {
    width: auto;
    margin-right: 0;
    padding-right: 0;
  }

  .slider-mobile-wrapper {
    width: 100vw;
    height: 100vw;
    padding-left: 15px;
    padding-right: 15px;
    overflow: scroll;
  }

  .slider-mobile-wrapper-inner {
    display: flex;
  }

  .img-wrapper.about {
    width: 76vw;
    height: 76vw;
  }

  .consent-popup {
    flex-flow: column;
    align-items: flex-start;
    display: flex;
  }

  .foerderer.stage {
    width: 60%;
  }

  .foerderer.vpby {
    width: 50%;
  }

  .foerderer.bswk {
    width: 90%;
  }

  .h1-onemoretime {
    margin-bottom: 0;
  }

  .button-2 {
    font-size: 15px;
  }

  .h1-lms {
    padding-left: 1.5vw;
  }
}


@font-face {
  font-family: 'Degular';
  src: url('../fonts/Degular-Bold.woff2') format('woff2'), url('../fonts/Degular-Bold.woff') format('woff');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Degular';
  src: url('../fonts/Degular-Regular.woff2') format('woff2'), url('../fonts/Degular-Regular.woff') format('woff');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Digestive';
  src: url('../fonts/Digestive.woff2') format('woff2'), url('../fonts/Digestive.woff') format('woff');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}