@charset "UTF-8";
/*----------------------
Main Menu
------------------------*/
.headermenu-scroll {
  width: fit-content;
  min-width: 600px;
  left: initial;
  right: var(--half-gutter);
  top: -150px;
  background-color: var(--orange);
  border-radius: var(--border-radius-medium);
  position: fixed;
  z-index: 100;
  height: 80px;
  padding: var(--half-gutter);
  display: flex;
  align-items: center;
  gap: var(--gap-large);
  transition: 400ms ease-out;
  backdrop-filter: invert(1);
  border: 2px var(--white) solid;
}
@media (max-width: 550px) {
  .headermenu-scroll {
    display: none;
  }
}
@media (max-width: 1500px) {
  .headermenu-scroll {
    height: 70px;
    border-radius: var(--border-radius-small);
  }
}
@media (max-width: 800px) {
  .headermenu-scroll {
    min-width: initial;
    height: 50px;
    gap: var(--gap-medium);
  }
}
.headermenu-scroll .headermenu__logo {
  width: 215px;
  height: 51px;
  color: var(--black);
}
@media (max-width: 1500px) {
  .headermenu-scroll .headermenu__logo {
    width: 180px;
    height: 43px;
  }
}
@media (max-width: 800px) {
  .headermenu-scroll .headermenu__logo {
    display: none;
  }
}
@media (hover: hover) and (pointer: fine) {
  .headermenu-scroll .headermenu__logo:hover {
    color: var(--bordeaux);
  }
}
.headermenu-scroll .headermenu__logo:active {
  transform: scale(0.95);
}
.headermenu-scroll a {
  transition: 200ms ease-out;
}
.headermenu-scroll a:active {
  transform: scale(0.95);
}
.headermenu-scroll .menu-headermenu-container {
  width: auto;
  flex: 1;
}
.headermenu-scroll .menu-headermenu-container ul {
  align-items: center;
  justify-content: flex-end;
  gap: var(--gap-large);
  width: auto;
}
.headermenu-scroll .menu-headermenu-container a {
  display: flex;
  align-items: center;
  height: 100%;
  font-size: 22px;
  line-height: 1;
}
@media (max-width: 1500px) {
  .headermenu-scroll .menu-headermenu-container a {
    font-size: 17px;
  }
}

.headermenu {
  width: 100%;
  position: relative;
  padding-top: var(--padding-menu-top);
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}
@media (max-width: 550px) {
  .headermenu {
    display: none;
  }
}
.headermenu .menu-headermenu-container a {
  font-size: 43px;
}
.headermenu .menu-headermenu-container a:active {
  transform: scale(0.95);
}
@media (min-width: 2400px) {
  .headermenu .menu-headermenu-container a {
    font-size: 75px;
  }
}
@media (max-width: 1500px) {
  .headermenu .menu-headermenu-container a {
    font-size: 32px;
  }
}
@media (max-width: 950px) {
  .headermenu .menu-headermenu-container a {
    font-size: 19px;
  }
}
@media (max-width: 550px) {
  .headermenu .menu-headermenu-container a {
    font-size: 17px;
  }
}

.menu-headermenu-container {
  width: 100%;
  z-index: 40;
}
.menu-headermenu-container a {
  text-decoration: none !important;
  color: var(--black);
  font-family: "StardosBold", serif;
  font-style: normal;
  font-weight: 700;
  display: block;
  height: var(--menu-top-height);
  line-height: 100%;
  letter-spacing: 0.5px;
}
@media (hover: hover) and (pointer: fine) {
  .menu-headermenu-container a:hover {
    color: var(--blue);
  }
}
.menu-headermenu-container ul {
  position: relative;
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  width: 100%;
  transition: 300ms ease-in-out;
}
.menu-headermenu-container ul li {
  display: inline;
  transition: 300ms ease-in-out;
}

.scroll .headermenu-scroll {
  top: var(--half-gutter);
}

.headermenu-mobile {
  display: none;
  width: 100%;
  justify-content: center;
  position: fixed;
  transition: 400ms ease-out;
  z-index: 10000;
}
@media (max-width: 550px) {
  .headermenu-mobile {
    display: flex;
  }
}
.headermenu-mobile__hamburger {
  position: absolute;
  top: calc(var(--gutter) - 10px);
  right: calc(50% - 27px);
  width: 54px;
  height: 42px;
  cursor: pointer;
  z-index: 10002;
  transition: right 400ms ease-out;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
.headermenu-mobile__hamburger:focus-visible {
  outline: 2px solid var(--white);
  outline-offset: 4px;
  border-radius: 4px;
}
.headermenu-mobile__hamburger--top, .headermenu-mobile__hamburger--bottom {
  height: 5px;
  width: 50px;
  background-color: var(--black);
  position: absolute;
  left: 0;
  border: 2px solid var(--white);
  box-sizing: content-box;
  z-index: 1000;
  transition: transform 400ms ease-out, background-color 400ms ease-out;
  transform-origin: 50% 50%;
  will-change: transform;
  pointer-events: none;
}
.headermenu-mobile__hamburger--top {
  top: 10px;
}
.headermenu-mobile__hamburger--bottom {
  top: 23px;
}
.headermenu-mobile__panel {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100vh;
  background-color: var(--orange);
  padding: 77px var(--gutter) var(--gutter) var(--gutter);
  transform: translateY(-100%);
  transition: transform 400ms ease-out;
  z-index: 10001;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  pointer-events: none;
  visibility: hidden;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--gap-large);
}
.headermenu-mobile .footernav {
  position: absolute;
  bottom: 8px;
  left: 14px;
}
.headermenu-mobile .footernav .menu-footermenu {
  display: flex;
  flex-direction: column;
  gap: 7px;
}
@media (max-height: 520px) {
  .headermenu-mobile .footernav .menu-footermenu {
    display: flex;
    flex-direction: column;
    gap: 5px;
  }
}
@media (max-height: 520px) {
  .headermenu-mobile .footernav {
    right: 22px;
    left: initial !important;
    bottom: 12px !important;
  }
  .headermenu-mobile .footernav a {
    text-align: right;
    width: 100%;
    display: block;
  }
}
.headermenu-mobile__logo {
  display: block;
  position: absolute;
  top: 174px;
  left: -149px;
  rotate: -90deg;
  width: 425px;
  max-width: initial;
  height: fit-content;
  color: var(--white);
  line-height: 0;
}
.headermenu-mobile__logo svg {
  display: block;
  width: 100%;
  height: auto;
}
@media (hover: hover) and (pointer: fine) {
  .headermenu-mobile__logo:hover {
    color: var(--bordeaux);
  }
}
.headermenu-mobile__logo:active {
  transform: scale(0.95);
}
.headermenu-mobile .menu-headermenu-container {
  width: 100%;
}
.headermenu-mobile .menu-headermenu-container ul {
  flex-direction: column;
  align-items: flex-end;
  justify-content: flex-end;
  gap: 33px;
  width: 100%;
  text-align: right;
}
.headermenu-mobile .menu-headermenu-container a {
  height: auto;
  font-size: 25px;
  line-height: 1.1;
  text-align: center;
}
.headermenu-mobile.is-open .headermenu-mobile__panel {
  transform: translateY(0);
  pointer-events: auto;
  visibility: visible;
}
.headermenu-mobile.is-open .headermenu-mobile__hamburger--top {
  transform: translateY(6.5px) rotate(45deg);
}
.headermenu-mobile.is-open .headermenu-mobile__hamburger--bottom {
  transform: translateY(-6.5px) rotate(-45deg);
}

.scroll .headermenu-mobile__hamburger {
  right: var(--gutter);
}

body.menu-open {
  overflow: hidden;
}
body.menu-open .headermenu-mobile__hamburger {
  right: 7px;
}

.pretix-widget-action button {
  padding: 0 35px 3px 35px !important;
}

button[type=submit], .wp-element-button, .frm_button_submit, .pretix-widget-action button, .pretix-widget button {
  position: relative;
  isolation: isolate;
  overflow: hidden !important;
  font-size: var(--button) !important;
  line-height: var(--button-height) !important;
  background-image: url("../img/button_white.jpg") !important;
  background-size: cover;
  border-radius: 25px 25px 25px 25px !important;
  padding: 0 35px 3px 35px;
  color: var(--blue) !important;
  cursor: pointer;
  height: 40px;
  z-index: 5;
  font-variation-settings: "wght" 270;
  border: 2px solid var(--orange) !important;
  display: flex;
  align-items: center;
  width: fit-content;
  justify-content: center;
  transition: color 200ms ease-out, border-color 200ms ease-out, transform 200ms ease-out;
}
button[type=submit]::before, .wp-element-button::before, .frm_button_submit::before, .pretix-widget-action button::before, .pretix-widget button::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url("../img/button_black.jpg");
  background-size: cover;
  opacity: 0;
  transition: opacity 200ms ease-out;
  z-index: -1;
  pointer-events: none;
}
button[type=submit]:focus, .wp-element-button:focus, .frm_button_submit:focus, .pretix-widget-action button:focus, .pretix-widget button:focus {
  outline: none !important;
}
@media (hover: hover) and (pointer: fine) {
  button[type=submit]:hover, .wp-element-button:hover, .frm_button_submit:hover, .pretix-widget-action button:hover, .pretix-widget button:hover {
    color: var(--white) !important;
    border: 2px solid var(--white) !important;
  }
  button[type=submit]:hover::before, .wp-element-button:hover::before, .frm_button_submit:hover::before, .pretix-widget-action button:hover::before, .pretix-widget button:hover::before {
    opacity: 1;
  }
  button[type=submit]:hover .icon, .wp-element-button:hover .icon, .frm_button_submit:hover .icon, .pretix-widget-action button:hover .icon, .pretix-widget button:hover .icon {
    left: 6px;
  }
}
button[type=submit]:active, .wp-element-button:active, .frm_button_submit:active, .pretix-widget-action button:active, .pretix-widget button:active {
  transform: scale(0.95);
}

body .pretix-widget-item-count-dec {
  border-radius: 25px 0 0 25px !important;
  right: -2px;
}
body .pretix-widget-item-count-inc {
  border-radius: 0 25px 25px 0 !important;
  left: -2px;
}

.pretix-widget input[type=number] {
  border: 2px solid var(--orange) !important;
}
.pretix-widget input[type=number]:focus {
  outline: none;
}

.wp-element-button .icon, button .icon {
  left: 0;
  position: relative;
  width: auto;
  height: 12px;
  margin-left: 6px;
}
@media (hover: hover) and (pointer: fine) {
  .wp-element-button:hover .icon, button:hover .icon {
    left: 6px;
  }
}

.frm_button_submit:visited {
  color: #000 !important;
}

/*--------------------------------------------------------------
Allgemeine Einstellungen
--------------------------------------------------------------*/
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

.clearfix {
  clear: both;
}

body * {
  -webkit-font-smoothing: subpixel-antialiased;
  text-rendering: optimizeLegibility;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: 160px;
}

body, html {
  overscroll-behavior: none;
}

body {
  background-image: url("../img/backdrop_light.jpg");
  background-repeat: repeat;
  background-size: 500px auto;
}

a {
  cursor: pointer;
}

.the-page {
  overflow: hidden;
}

.content {
  min-height: 100vh;
}
.content > * {
  margin-top: var(--block-spacing);
  margin-bottom: var(--block-spacing);
}
.content > *:first-child {
  margin-top: 0;
}
.content > *:last-child {
  margin-bottom: 0;
}
.content > *:only-child {
  margin: 0;
}
.content :where(.wp-block-columns.is-layout-flex) {
  gap: var(--gutter);
}

.is-layout-flex {
  flex-wrap: nowrap;
}

.is-vertical {
  flex-direction: column;
}

.is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)) {
  max-width: 100%;
}

figure {
  overflow: hidden;
}

@media (max-width: 950px) {
  .wp-block-columns {
    flex-direction: column;
  }
}

:focus {
  outline: none;
}

/*----------------------
Farbsystem
Quelle: Figma (ZwischenRaum.space)
------------------------*/
:root {
  --black: #382323;
  --bordeaux: #7f0c40;
  --blue: #0f3576;
  --orange: #ffaa16;
  --white: #ffffff;
  --darkblue: #000000;
  --beige: #e3d9c3;
  --grey: #807777;
  --dust: #edeae1;
  /* Legacy – ohne Figma-Entsprechung */
  --positive: #a9eeb7;
  --positive_text: #047874;
}

/*----------------------
Schrifteinbindung
------------------------*/
@font-face {
  font-family: "StardosRegular";
  src: url("../fonts/StardosStencil-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "StardosBold";
  src: url("../fonts/StardosStencil-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "Chikki";
  src: url("../fonts/Chikki-Variable.woff2") format("woff2-variations");
}
/*----------------------
Schriftsatz
------------------------*/
:root {
  --copy: 18px;
  --copy-height: 31px;
  --h1: 55px;
  --h1-height: 65px;
  --h2: 55px;
  --h2-height: 65px;
  --h3: 38px;
  --h3-height: 51px;
  --h4: 30px;
  --h4-height: 39px;
  --small: 14px;
  --small-height: 22px;
  --button: calc(var(--copy) + 2px);
  --button-height: 140%;
  --overline: 25px;
  --overline-height: 33px;
  --wide: 3px;
  --medium: 1.2px;
  --semi-narrow: 0.7px;
  --narrow: 0;
}
@media (max-width: 1500px) {
  :root {
    --copy: 17px;
    --copy-height: 29px;
    --h1: 47px;
    --h1-height: 54px;
    --h2: 47px;
    --h2-height: 54px;
    --h3: 30px;
    --h3-height: 38px;
    --h4: 33px;
    --h4-height: 39px;
    --small: 13px;
    --small-height: 20px;
    --overline: 20px;
    --overline-height: 28px;
  }
}
@media (max-width: 1200px) {
  :root {
    --h1: 36px;
    --h1-height: 47px;
    --h2: 36px;
    --h2-height: 47px;
    --h3: 22px;
    --h3-height: 32px;
    --overline: 19px;
    --overline-height: 26px;
  }
}
@media (max-width: 950px) {
  :root {
    --h1: 33px;
    --h1-height: 50px;
    --h2: 33px;
    --h2-height: 50px;
    --h3: 17px;
    --h3-height: 21px;
    --copy-height: 26px;
  }
}
@media (max-width: 550px) {
  :root {
    --h1: 29px;
    --h1-height: 39px;
    --h2: 29px;
    --h2-height: 39px;
  }
}

p, .wp-block-heading, .has-text-align-center {
  width: 100%;
  transition: 400ms ease-in-out;
}

.has-small-font-size {
  font-size: var(--small) !important;
  line-height: var(--small-height) !important;
}

body, p {
  color: var(--bordeaux);
  font-family: "Chikki", sans-serif;
  font-size: var(--copy);
  line-height: var(--copy-height);
  letter-spacing: var(--medium);
  margin: 0;
  padding: 0;
  font-variation-settings: "wght" 180;
}

html body b, html body strong {
  font-family: "Chikki", sans-serif;
  font-variation-settings: "wght" 270;
  letter-spacing: var(--medium);
}
html body a {
  color: inherit;
  text-decoration: none !important;
  transition: 400ms ease-in-out;
}
html body h1, html body h2, html body h3, html body h4, html body h5, html body h6 {
  font-family: "StardosBold", serif;
  text-wrap: balance;
  transition: 400ms ease-in-out;
  margin-top: 0;
}
html body .overline, html body .pretix-widget-category-name {
  font-size: var(--overline) !important;
  line-height: var(--overline-height);
  letter-spacing: var(--wide) !important;
  padding-left: 1px;
  margin-bottom: 10px;
  text-transform: uppercase;
  font-family: "StardosBold", serif;
}
@media (max-width: 950px) {
  html body .overline, html body .pretix-widget-category-name {
    margin-bottom: 6px;
  }
}
@media (max-width: 550px) {
  html body .overline, html body .pretix-widget-category-name {
    margin-bottom: 10px;
  }
}
html body .main .content h1, html body .main .content h2 {
  margin-bottom: 25px;
  margin-left: -1px;
  font-variation-settings: "wght" 700;
}
@media (max-width: 1500px) {
  html body .main .content h1, html body .main .content h2 {
    margin-bottom: 20px;
  }
}
@media (max-width: 950px) {
  html body .main .content h1, html body .main .content h2 {
    margin-bottom: 15px;
  }
}
html body .main .content h1:last-child, html body .main .content h2:last-child {
  margin-bottom: 0;
}
html body .main .content h3, html body .main .content .pretix-widget-event-list-entry, html body .main .content .pretix-widget-item-title-and-description strong {
  font-family: "StardosBold", serif;
  font-variation-settings: "wght" 700;
  font-size: var(--h3);
  line-height: var(--h3-height);
}
html body .main .content h4 {
  font-size: var(--h4);
  line-height: var(--h4-height);
}
html body p {
  text-wrap: pretty;
}
html body h1 {
  font-size: var(--h1);
  line-height: var(--h1-height);
  letter-spacing: var(--narrow);
  font-variation-settings: "wght" 700;
}
html body h2 {
  font-size: var(--h2) !important;
  line-height: var(--h2-height) !important;
  letter-spacing: var(--narrow) !important;
  font-variation-settings: "wght" 700 !important;
}
html body h3 {
  font-size: var(--h3);
  line-height: var(--h3-height);
  letter-spacing: var(--semi-narrow);
  font-variation-settings: "wght" 700;
}
html body button, html body .button, html body .button span, html body .btn, html body .wp-element-button, html body body main .frm_button_submit {
  font-family: "Chikki", sans-serif;
  font-size: var(--button);
  line-height: var(--button-height);
  letter-spacing: var(--semi-narrow);
  transition: 400ms ease-in-out;
}
html body footer a {
  font-size: var(--small);
  line-height: var(--small-height);
  font-family: "Chikki", sans-serif;
  transition: 400ms ease-in-out;
  font-variation-settings: "wght" 700;
  letter-spacing: 1px;
}
html body small, html body #menu-footermenu a {
  font-size: var(--small);
  line-height: var(--small-height);
  font-family: "Chikki", sans-serif;
  letter-spacing: 1px;
}
html body ul {
  list-style: none;
  line-height: 175%;
  margin: 0;
  padding: 0;
  transition: 400ms ease-in-out;
}
html body .content ul li {
  position: relative;
  padding-left: 20px;
  transition: 400ms ease-in-out;
  margin-bottom: var(--half-gutter);
  font-family: "Chikki", sans-serif;
}
html body .content ul li::before {
  content: "";
  position: absolute;
  left: -5px;
  width: 29px;
  height: 25px;
  background-image: url(../img/bullet_light.svg);
  background-size: contain;
  background-repeat: no-repeat;
  top: 2px;
}
@media (max-width: 1500px) {
  html body .content ul li::before {
    top: 0;
  }
}

/*----------------------------------------
Footer Layout
-----------------------------------------*/
.pagefooter {
  padding: var(--block-spacing) var(--gutter) var(--gap-large) var(--gutter);
  color: var(--bordeaux);
  position: relative;
  width: 100%;
}
@media (max-width: 550px) {
  .pagefooter {
    padding: var(--block-spacing) var(--gutter) 8px var(--gutter);
  }
}
.pagefooter__menu {
  width: fit-content;
  right: var(--gutter);
  bottom: var(--gap-large);
  position: absolute;
}
@media (max-width: 550px) {
  .pagefooter__menu {
    display: none;
  }
}
.pagefooter__menu ul {
  width: 100%;
  display: flex;
  gap: var(--gutter);
  justify-content: flex-end;
  height: 21px;
}
@media (hover: hover) and (pointer: fine) {
  .pagefooter__menu ul a:hover {
    color: var(--blue);
  }
}
.pagefooter__menu--metaball {
  position: absolute;
  right: 0;
  top: calc(-105px - var(--gap-large));
  width: 115px;
}
.pagefooter__foerderhinweis {
  height: 130px;
  margin-top: 21px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  color: var(--darkblue);
}
@media (max-width: 950px) {
  .pagefooter__foerderhinweis {
    height: 110px;
  }
}
.pagefooter__logos {
  display: flex;
  align-items: flex-start;
  gap: var(--gutter);
}
.pagefooter__logos--inimusik svg {
  width: 150px;
  height: auto;
}
@media (max-width: 950px) {
  .pagefooter__logos--inimusik svg {
    width: 99px;
  }
}
@media (max-width: 350px) {
  .pagefooter__logos--inimusik svg {
    width: 73px;
  }
}
.pagefooter__logos--bkm svg {
  width: 220px;
  height: auto;
}
@media (max-width: 950px) {
  .pagefooter__logos--bkm svg {
    width: 188px;
  }
}
@media (max-width: 350px) {
  .pagefooter__logos--bkm svg {
    width: 180px;
  }
}
.pagefooter__logos a {
  display: inline-block;
}

body main #frm_form_1_container {
  position: relative;
  margin-top: 20px;
}
body main #frm_form_1_container fieldset {
  padding: 0;
  border: none;
}
body main #frm_form_1_container .frm_form_fields .frm_fields_container {
  grid-gap: 0 10px;
}
body main #frm_form_1_container .frm_form_field {
  position: relative;
  margin: 10px 0;
}
body main #frm_form_1_container input:-webkit-autofill {
  background-color: white !important;
}
body main #frm_form_1_container label {
  top: 5px;
  right: 15px;
  z-index: 3;
  font-size: 20px;
  font-family: "Regular", sans-serif;
  position: absolute;
  color: #002aff !important;
}
body main #frm_form_1_container label:has(~ input:not(:placeholder-shown)) span, body main #frm_form_1_container label:has(~ textarea:not(:placeholder-shown)) span {
  display: none !important;
}
body main #frm_form_1_container label span {
  color: #000 !important;
}
@media (max-width: 550px) {
  body main #frm_form_1_container label {
    top: 0px;
    right: 4px;
  }
}
body main #frm_form_1_container input {
  height: 50px;
  padding: 0 var(--half-gutter) 3px var(--half-gutter);
  width: 100%;
  margin: 0;
  cursor: text;
  letter-spacing: 1px;
  font-variation-settings: "wght" 500;
  color: #000 !important;
  z-index: 3;
  font-size: var(--copy);
  line-height: var(--copy-height);
  background: #fff !important;
  border: 0 solid #fff !important;
}
body main #frm_form_1_container input::placeholder {
  color: #8f8f8f !important;
  letter-spacing: 1px;
  font-variation-settings: "wght" 500;
  font-size: 16px;
  line-height: 24px;
}
body main #frm_form_1_container input::-webkit-input-placeholder {
  color: #8f8f8f !important;
  letter-spacing: 1px;
  font-variation-settings: "wght" 500;
  font-size: 16px;
  line-height: 24px;
}
body main #frm_form_1_container input::-moz-placeholder {
  color: #8f8f8f !important;
  letter-spacing: 1px;
  font-variation-settings: "wght" 500;
  font-size: 16px;
  line-height: 24px;
}
body main #frm_form_1_container input:-ms-input-placeholder {
  color: #8f8f8f !important;
  letter-spacing: 1px;
  font-variation-settings: "wght" 500;
  font-size: 16px;
  line-height: 24px;
}
body main #frm_form_1_container input:focus, body main #frm_form_1_container input:active, body main #frm_form_1_container input :focus-visible, body main #frm_form_1_container input :focus-within {
  outline: none;
}
body main #frm_form_1_container input:focus::-webkit-input-placeholder, body main #frm_form_1_container input:active::-webkit-input-placeholder, body main #frm_form_1_container input :focus-visible::-webkit-input-placeholder, body main #frm_form_1_container input :focus-within::-webkit-input-placeholder {
  color: var(--white);
}
body main #frm_form_1_container input:focus::-moz-placeholder, body main #frm_form_1_container input:active::-moz-placeholder, body main #frm_form_1_container input :focus-visible::-moz-placeholder, body main #frm_form_1_container input :focus-within::-moz-placeholder {
  color: var(--white);
}
body main #frm_form_1_container input:focus:-ms-input-placeholder, body main #frm_form_1_container input:active:-ms-input-placeholder, body main #frm_form_1_container input :focus-visible:-ms-input-placeholder, body main #frm_form_1_container input :focus-within:-ms-input-placeholder {
  color: var(--white);
}
body main #frm_form_1_container input:focus::-ms-input-placeholder, body main #frm_form_1_container input:active::-ms-input-placeholder, body main #frm_form_1_container input :focus-visible::-ms-input-placeholder, body main #frm_form_1_container input :focus-within::-ms-input-placeholder {
  color: var(--white);
}
body main #frm_form_1_container input:focus::placeholder, body main #frm_form_1_container input:active::placeholder, body main #frm_form_1_container input :focus-visible::placeholder, body main #frm_form_1_container input :focus-within::placeholder {
  color: var(--white);
}
body main #frm_form_1_container input[aria-invalid=true] {
  border: 2px solid var(--orange);
}
body main #frm_form_1_container input:visited {
  color: var(--darkblue);
  border: 2px solid var(--darkblue);
}
body main #frm_form_1_container textarea {
  padding: 12px var(--half-gutter) var(--half-gutter) var(--half-gutter);
  font-family: "Regular", sans-serif;
  color: #000;
  letter-spacing: 1px;
  font-variation-settings: "wght" 500;
  font-size: var(--copy);
  line-height: var(--copy-height);
  background: #fff !important;
  border: 2px solid rgba(255, 255, 255, 0.36) !important;
  cursor: text;
  min-height: 300px;
}
body main #frm_form_1_container textarea::placeholder {
  color: #8f8f8f !important;
  letter-spacing: 1px;
  font-variation-settings: "wght" 500;
  font-size: 16px;
  line-height: 24px;
}
body main #frm_form_1_container textarea::-webkit-input-placeholder {
  color: #8f8f8f !important;
  letter-spacing: 1px;
  font-variation-settings: "wght" 500;
  font-size: 16px;
  line-height: 24px;
}
body main #frm_form_1_container textarea::-moz-placeholder {
  color: #8f8f8f !important;
  letter-spacing: 1px;
  font-variation-settings: "wght" 500;
  font-size: 16px;
  line-height: 24px;
}
body main #frm_form_1_container textarea:-ms-input-placeholder {
  color: #8f8f8f !important;
  letter-spacing: 1px;
  font-variation-settings: "wght" 500;
  font-size: 16px;
  line-height: 24px;
}
body main #frm_form_1_container textarea:focus, body main #frm_form_1_container textarea:active, body main #frm_form_1_container textarea :focus-visible {
  outline: none;
  color: var(--darkblue);
}
body main #frm_form_1_container textarea:focus::-webkit-input-placeholder, body main #frm_form_1_container textarea:active::-webkit-input-placeholder, body main #frm_form_1_container textarea :focus-visible::-webkit-input-placeholder {
  color: #000;
}
body main #frm_form_1_container textarea:focus::-moz-placeholder, body main #frm_form_1_container textarea:active::-moz-placeholder, body main #frm_form_1_container textarea :focus-visible::-moz-placeholder {
  color: #000;
}
body main #frm_form_1_container textarea:focus:-ms-input-placeholder, body main #frm_form_1_container textarea:active:-ms-input-placeholder, body main #frm_form_1_container textarea :focus-visible:-ms-input-placeholder {
  color: #000;
}
body main #frm_form_1_container textarea:focus::-ms-input-placeholder, body main #frm_form_1_container textarea:active::-ms-input-placeholder, body main #frm_form_1_container textarea :focus-visible::-ms-input-placeholder {
  color: #000;
}
body main #frm_form_1_container textarea:focus::placeholder, body main #frm_form_1_container textarea:active::placeholder, body main #frm_form_1_container textarea :focus-visible::placeholder {
  color: #000;
}
body main #frm_form_1_container textarea:visited {
  color: var(--darkblue);
}
body main #frm_form_1_container textarea:-webkit-autofill,
body main #frm_form_1_container textarea:-webkit-autofill:focus,
body main #frm_form_1_container textarea:-webkit-autofill:active, body main #frm_form_1_container input:-webkit-autofill:visited {
  background-color: var(--positive) !important;
  color: var(--darkblue);
  border: none;
}
body main #frm_form_1_container .frm_message h2, body main #frm_form_1_container .frm_error_style[role=status] p {
  min-height: 350px;
  display: flex;
  align-items: center;
  font-size: calc(var(--h2) - 20px);
  line-height: calc(var(--h2-height) - 10px);
  color: var(--positive_text);
  font-family: "Headline", serif;
  text-align: left;
}
@media (max-width: 1500px) {
  body main #frm_form_1_container .frm_message h2, body main #frm_form_1_container .frm_error_style[role=status] p {
    font-size: var(--h2);
    line-height: var(--h2-height);
  }
}
body main #frm_form_1_container .frm_error_style[role=alert] {
  position: absolute;
  bottom: 20px;
  left: 0;
  padding: 3.8px var(--half-gutter) 7px var(--half-gutter);
  font-size: var(--small);
  color: var(--bordeaux);
  font-family: "Italic", serif;
  font-variation-settings: "wght" 700;
  border: 0px solid var(--white);
  background-color: var(--bordeaux);
  border-radius: 10px;
}
@media (max-width: 950px) {
  body main #frm_form_1_container .frm_error_style[role=alert] {
    bottom: -50px;
    margin: var(--half-gutter);
    width: calc(100% - var(--gutter));
    text-align: center;
  }
}
body main #frm_form_1_container .frm_error {
  position: relative;
  top: 2px;
  left: var(--half-gutter);
  font-size: var(--small);
  color: var(--bordeaux);
  font-family: "Regular", sans-serif;
  font-variation-settings: "wght" 500;
  margin: 0 0 8px 0 !important;
}
body main #frm_form_1_container #frm_field_5_container {
  margin: 0;
}
body main #frm_form_1_container #spam_error {
  display: none;
}

/*--------------------------------
Headline
--------------------------------*/
.errorpage {
  min-height: 100vh;
  margin-bottom: 100px;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  padding: 0 25px;
}
.errorpage h1 {
  margin: 0 0 40px 0;
}

/*--------------------------------
Text & Button
--------------------------------*/
:root {
  --gutter: 50px;
  --double-gutter: calc(var(--gutter) * 2);
  --half-gutter: calc(var(--gutter) / 2);
  --gap-small: 16px;
  --gap-medium: 20px;
  --gap-large: 30px;
  --block-spacing: 120px;
  --half-block-spacing: calc(var(--block-spacing) / 2);
  --border-radius-large: 25px;
  --border-radius-medium: 18px;
  --border-radius-small: 10px;
  /**General Setup**/
}
@media (max-width: 1500px) {
  :root {
    --border-radius-large: 15px;
    --block-spacing: 100px;
  }
}
:root .content {
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}
:root .content > *:not(.alignwide):not(.alignfull) {
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
}
:root .alignwide {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
}
:root .content > .alignfull {
  width: calc(100% + var(--double-gutter));
  margin-left: calc(-1 * var(--gutter));
  margin-right: calc(-1 * var(--gutter));
  left: 0;
}
:root .shadow {
  -webkit-box-shadow: 0px 0px var(--gutter) 1px rgba(0, 0, 0, 0.3);
  box-shadow: 0px 0px var(--gutter) 1px rgba(0, 0, 0, 0.3);
}
@media (min-width: 1501px) and (max-width: 2299px) {
  :root {
    --gutter: 40px;
  }
}
@media (max-width: 1500px) {
  :root {
    --gutter: 30px;
    --gap-large: 25px;
  }
}
@media (max-width: 950px) {
  :root {
    --gutter: 25px;
  }
}
@media (max-width: 550px) {
  :root {
    --gutter: 20px;
  }
}

.cards {
  position: relative;
  padding-top: var(--block-spacing);
  padding-bottom: var(--block-spacing);
  padding-left: var(--gutter);
  padding-right: var(--gutter);
  margin-top: 0;
  margin-bottom: 0;
  z-index: 50;
}
@media (max-width: 950px) {
  .cards {
    padding-left: var(--double-gutter);
    padding-right: var(--double-gutter);
  }
}
@media (max-width: 550px) {
  .cards {
    padding-left: var(--gutter);
    padding-right: var(--gutter);
  }
}
.cards .cards__container {
  display: flex;
  gap: var(--gutter);
  margin-left: auto;
  margin-right: auto;
  padding: 0;
}
.cards .cards__card {
  border-radius: var(--border-radius-large);
  padding: calc(var(--gutter) - 4px) var(--gutter) var(--gutter) var(--gutter);
  overflow: hidden;
  border: 1px solid #152b28;
  transition: 600ms ease-out;
  position: relative;
  flex-basis: 100%;
  align-self: stretch;
  display: flex;
  flex-direction: column;
}
@media (hover: hover) and (pointer: fine) {
  .cards .cards__card:hover {
    border: 1px solid var(--orange);
  }
}
.cards .cards__card h2 {
  font-size: var(--h3);
  line-height: var(--h3-height);
  margin-bottom: var(--half-gutter);
}
.cards .wp-block-buttons {
  margin-top: var(--half-gutter);
}
.cards .wp-block-buttons, .cards .wp-block-button {
  width: 100%;
  text-align: center;
}

.cards:has(.wp-block-button) > div > div {
  border-radius: var(--border-radius-large) var(--border-radius-large) 50px 50px;
}
@media (min-width: 1501px) and (max-width: 2299px) {
  .cards:has(.wp-block-button) > div > div {
    border-radius: var(--border-radius-large) var(--border-radius-large) 35px 35px;
  }
}

.wp-block-accordion .wp-block-accordion-item {
  border: 2px solid var(--blue);
  border-radius: 10px;
  background-color: var(--white);
  padding: 10px var(--gap-large);
  margin-bottom: var(--gap-small);
  cursor: pointer;
  transition: 300ms ease-out;
}
.wp-block-accordion .wp-block-accordion-item .wp-block-accordion-content {
  cursor: auto;
}
.wp-block-accordion .wp-block-accordion-item.is-open {
  background-color: var(--dust);
  border: 2px solid var(--orange);
}
@media (hover: hover) and (pointer: fine) {
  .wp-block-accordion .wp-block-accordion-item:hover {
    background-color: var(--dust);
    border: 2px solid var(--orange);
  }
}
.wp-block-accordion-heading {
  font-size: var(--overline);
  line-height: var(--h4-height);
}
.wp-block-accordion-heading .wp-block-accordion-heading__toggle-title {
  font-family: "Chikki";
  font-variation-settings: "wght" 250;
  padding: 0;
  text-decoration: none !important;
}
@media (hover: hover) and (pointer: fine) {
  .wp-block-accordion-heading button:hover .wp-block-accordion-heading__toggle-title {
    text-decoration: none !important;
  }
}
.wp-block-accordion-heading .wp-block-accordion-heading__toggle-icon {
  width: 19px;
  height: 19px;
  background-image: url("../img/accordion_arrow.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  transition: transform 0.25s ease;
  color: transparent;
  text-indent: -9999em;
  overflow: hidden;
}
.wp-block-accordion-heading .wp-block-accordion-heading__toggle-icon svg {
  display: none !important;
}
.wp-block-accordion-heading .wp-block-accordion-item.is-open > .wp-block-accordion-heading .wp-block-accordion-heading__toggle-icon,
.wp-block-accordion-heading .wp-block-accordion-heading__toggle[aria-expanded=true] .wp-block-accordion-heading__toggle-icon {
  transform: rotate(180deg);
}

html body .content .wp-block-media-text {
  padding-left: 0;
  padding-right: 0;
  gap: var(--gutter);
}
html body .content .wp-block-media-text__media {
  border-radius: var(--border-radius-large);
  overflow: hidden;
}
html body .content .wp-block-media-text__content {
  padding: 0 !important;
}
@media (max-width: 950px) {
  html body .content .wp-block-media-text {
    display: flex;
    flex-direction: column;
    max-width: 710px !important;
  }
}
@media (max-width: 550px) {
  html body .content .wp-block-media-text {
    padding-left: var(--gutter);
    padding-right: var(--gutter);
  }
}
html body .content .wp-block-media-text ul li {
  margin-bottom: calc(0.5 * var(--half-gutter));
}
html body .content .wp-block-media-text ul li:last-child {
  margin-bottom: var(--half-gutter);
}

:root {
  --padding-headerlogo-top: 42px;
  --menu-top-height: 34px;
  --padding-menu-top: 34px;
}
@media (max-width: 1500px) {
  :root {
    --padding-menu-top: 25px;
    --menu-top-height: 26px;
    --padding-headerlogo-top: 28px;
  }
}
@media (max-width: 950px) {
  :root {
    --padding-menu-top: 20px;
    --menu-top-height: 17px;
    --padding-headerlogo-top: 20px;
  }
}

.headerlogo {
  padding: var(--padding-headerlogo-top) var(--gutter) var(--gutter) var(--gutter);
}
@media (max-width: 550px) {
  .headerlogo {
    padding: calc(var(--padding-headerlogo-top) + var(--menu-top-height) + var(--padding-menu-top)) var(--gutter) var(--gutter) var(--gutter);
  }
}
.headerlogo svg {
  display: block;
}

.header {
  height: calc(100vh - (var(--padding-menu-top) + var(--menu-top-height) + var(--gutter) + var(--logosize)));
  min-height: 450px;
}
.header__eyecatcher {
  position: absolute;
  width: 566px;
  height: 566px;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 7px;
  left: -131px;
  bottom: -178px;
  z-index: 7;
}
.header__eyecatcher:before {
  background-repeat: no-repeat !important;
}
@media (max-width: 1500px) {
  .header__eyecatcher {
    width: 450px;
    height: 450px;
    left: -77px;
    bottom: -128px;
  }
}
@media (max-width: 550px) {
  .header__eyecatcher {
    width: 420px;
    left: var(--gutter);
    min-width: 420px;
  }
}
@media (max-width: 550px) and (max-width: 500px) {
  .header__eyecatcher {
    left: calc(50% - 210px);
    bottom: -167px !important;
  }
}
@media (max-width: 550px) and (max-width: 500px) and (max-height: 550px) {
  .header__eyecatcher {
    bottom: -237px !important;
  }
}
@media (max-width: 550px) {
  .header__eyecatcher::before {
    background-size: 100% !important;
  }
}
.header__eyecatcher p {
  width: fit-content;
}
.header__eyecatcher h4 {
  margin-bottom: -3px;
}
.header__eyecatcher mark {
  width: 304px;
  height: 27px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  padding-bottom: 2px;
}
.header__eyecatcher .wp-element-button {
  margin-top: 18px;
  width: 304px;
}

@media (max-width: 500px) {
  .header {
    height: calc(100vh - (var(--padding-menu-top) + var(--menu-top-height) + var(--gutter) + var(--logosize) + 10px)) !important;
    min-height: initial !important;
  }
}

.interactive-header {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: var(--header-backdrop);
  --bg: var(--header-backdrop);
  --clr: var(--header-front);
  --tc: 2px;
}
@media (max-width: 1200px) {
  .interactive-header {
    --tc: var(--tc-mobile, 0.5px);
  }
}
.interactive-header *,
.interactive-header *::before,
.interactive-header *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
.interactive-header__bg {
  position: absolute;
  inset: 0;
  perspective: 1000px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.interactive-header__content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 100svh;
  text-align: center;
  color: #fff;
  pointer-events: none;
  padding: var(--gutter);
}
.interactive-header--editor .interactive-header__content {
  min-height: 400px;
}
.interactive-header .cirContainer {
  flex-shrink: 0;
  contain: layout paint;
}
.interactive-header .cirRow {
  display: flex;
  height: fit-content;
  line-height: 0;
  font-size: 0;
}
.interactive-header .cir {
  position: relative;
  width: var(--size);
  height: var(--size);
  overflow: hidden;
  flex-shrink: 0;
  transition: transform 0.6s ease-in-out;
  background: var(--bg);
  transform: rotate(var(--r, 0deg));
}
@media (prefers-reduced-motion: reduce) {
  .interactive-header .cir {
    transition: none;
  }
}
.interactive-header .cir::before, .interactive-header .cir::after {
  content: "";
  display: block;
  position: absolute;
  margin: auto;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  height: 100%;
  width: 100%;
}
.interactive-header .cir::before {
  background: radial-gradient(circle at 0.1% 0.1%, transparent 0px, transparent calc(var(--size) / 2 - var(--tc) - 0.5px), var(--clr) calc(var(--size) / 2 - var(--tc) + 0.5px), var(--clr) calc(var(--size) / 2 + var(--tc) - 0.5px), transparent calc(var(--size) / 2 + var(--tc) + 0.5px));
}
.interactive-header .cir::after {
  background: radial-gradient(circle at 99.9% 99.9%, transparent 0px, transparent calc(var(--size) / 2 - var(--tc) - 0.5px), var(--clr) calc(var(--size) / 2 - var(--tc) + 0.5px), var(--clr) calc(var(--size) / 2 + var(--tc) - 0.5px), transparent calc(var(--size) / 2 + var(--tc) + 0.5px));
}

.intro {
  position: relative;
  gap: 0;
}
@media (max-width: 950px) {
  .intro {
    margin-top: 155px;
    margin-bottom: calc(2 * var(--block-spacing));
  }
}
@media (max-width: 500px) {
  .intro {
    margin-top: 232px;
  }
}
.intro::after {
  content: "";
  background-image: url(../img/backdrop_wave1_top.svg);
  background-repeat: no-repeat;
  background-position: top right;
  position: absolute;
  width: 200px;
  height: 480px;
  top: -590px;
  right: calc(-1 * var(--gutter));
  z-index: -1;
}
.intro::before {
  content: "";
  background-image: url(../img/backdrop_wave1_bottom.svg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: bottom left;
  width: calc(50% + 370px + var(--gutter));
  height: calc(100% + var(--block-spacing) * 2 + 81px);
  position: absolute;
  left: calc(50% - 370px);
  bottom: calc(-1 * var(--block-spacing) - 70px);
  z-index: -1;
  overflow: visible;
}
@media (max-width: 950px) {
  .intro::before {
    bottom: calc(-1 * var(--block-spacing) - 20px);
  }
}
.intro .sputnik {
  overflow: visible;
  margin-top: 70px;
  margin-left: -27px;
  z-index: -1;
}
@media (max-width: 1500px) {
  .intro .sputnik {
    margin-top: 0;
    position: absolute;
    left: calc(50% - 70px);
    bottom: 0;
  }
}
@media (max-width: 950px) {
  .intro .sputnik {
    left: initial;
    right: 30px;
    width: 40px;
    bottom: initial;
    top: 37px;
  }
}
@media (max-width: 450px) {
  .intro .sputnik {
    left: var(--gutter);
    right: initial;
    bottom: -60px;
    top: initial;
  }
}
@media (max-width: 1200px) {
  .intro #intro__star {
    position: absolute;
    left: 100px;
    width: 120px;
  }
}
@media (max-width: 950px) {
  .intro #intro__star {
    position: absolute;
    left: initial;
    width: 90px;
    top: -127px;
    right: 0;
    mix-blend-mode: difference;
    opacity: 0.1;
  }
}
@media (max-width: 550px) {
  .intro #intro__star {
    right: calc(50% - 25px);
    width: 50px;
    mix-blend-mode: initial;
    opacity: 1;
    z-index: 10;
  }
}
@media (max-width: 500px) {
  .intro #intro__star {
    right: calc(50% - 19px);
    top: -88px;
  }
}

.sliders {
  rotate: -2deg;
  position: relative;
  z-index: 2;
  pointer-events: none;
}
.sliders .logoslider {
  width: calc(100% + 50px);
  left: -10px;
}
@media (max-width: 950px) {
  .sliders .logoslider {
    top: -120px;
  }
}
.sliders .logoslider__item--text {
  font-family: "StardosBold";
  text-transform: uppercase;
  letter-spacing: var(--wide);
  margin-bottom: -3px !important;
}
@media (max-width: 950px) {
  .sliders {
    margin-bottom: 0;
  }
}

.tickets {
  margin-top: calc(-1 * (var(--block-spacing) + 50px));
  margin-bottom: 0;
  z-index: 1;
  min-height: 1360px;
  position: relative;
  overflow: visible;
  padding-top: 150px;
  gap: 0;
}
@media (max-width: 1500px) {
  .tickets {
    min-height: 1250px;
  }
}
@media (max-width: 950px) {
  .tickets {
    min-height: 850px;
  }
  .tickets:has(.pretix-widget-item-title) {
    min-height: 1140px;
  }
}
@media (max-width: 550px) {
  .tickets {
    min-height: 750px;
  }
}
.tickets__backdrop {
  width: 100%;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  z-index: -1;
  overflow: hidden;
}
.tickets__backdrop img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: translate3d(0, var(--tickets-backdrop-parallax-y, 0px), 0) scale(1.06);
  transform-origin: center center;
}
@media (hover: none), (pointer: coarse) {
  .tickets__backdrop img {
    transform: none;
  }
}
@media (prefers-reduced-motion: reduce) {
  .tickets__backdrop img {
    transform: none;
  }
}
.tickets h2 {
  margin-bottom: 10px !important;
}
.tickets::after {
  content: "";
  background-image: url(../img/saturn.png);
  background-repeat: no-repeat;
  background-position: bottom center;
  position: absolute;
  bottom: -204px;
  left: calc(50% - 300px);
  width: 600px;
  height: 468px;
  background-size: contain;
  transition: 300ms ease-in-out;
}
@media (max-width: 1500px) {
  .tickets::after {
    bottom: -137px;
    left: calc(50% - 232px);
    width: 400px;
    height: 312px;
  }
}
@media (max-width: 950px) {
  .tickets::after {
    bottom: -62px;
    left: calc(50% - 105px);
    width: 180px;
    height: 141px;
  }
}
@media (max-width: 950px) {
  .tickets .pretix-widget-wrapper {
    width: 100%;
  }
}
.tickets .pretix-widget {
  border: none;
  padding: 0 var(--gap-large);
  margin: 0;
  max-width: 1152px;
}
@media (max-width: 1500px) {
  .tickets .pretix-widget {
    max-width: 800px;
  }
}
@media (max-width: 950px) {
  .tickets .pretix-widget {
    width: 100%;
    max-width: 100%;
  }
}
@media (max-width: 550px) {
  .tickets .pretix-widget {
    padding: 0 var(--gutter);
  }
}
.tickets .pretix-widget .pretix-widget-event-header, .tickets .pretix-widget .pretix-widget-back {
  display: none;
}
.tickets .pretix-widget a {
  color: var(--white);
}
.tickets .pretix-widget a:focus {
  outline: none;
}
.tickets .pretix-widget .pretix-widget-loading {
  background: none;
}
.tickets .pretix-widget .pretix-widget-loading svg {
  position: absolute;
  right: 0;
  top: -10px;
  width: 70px;
}
.tickets .pretix-widget .pretix-widget-loading .pretix-widget-primary-color {
  fill: #fff !important;
}
.tickets .pretix-widget .pretix-widget-event-details {
  width: 100%;
  display: block;
  height: fit-content;
  font-family: "StardosBold", serif;
  font-size: var(--overline);
  line-height: var(--overline-height);
  text-transform: uppercase;
  text-align: center;
  color: var(--white);
  padding: 0;
}
.tickets .pretix-widget .pretix-widget-event-list {
  padding: 0;
  display: flex;
  flex-direction: column;
  color: var(--white);
  align-items: center;
}
.tickets .pretix-widget .pretix-widget-event-list > * {
  order: 3;
}
.tickets .pretix-widget .pretix-widget-event-list::before {
  content: "1. Termin auswählen";
  width: 100%;
  display: block;
  height: fit-content;
  font-family: "StardosBold", serif;
  font-size: var(--overline);
  line-height: var(--overline-height);
  text-transform: uppercase;
  text-align: center;
  color: var(--white);
  order: 1;
}
.tickets .pretix-widget .pretix-widget-event-list::after {
  content: "Wähle dein Veranstaltungs-Wochenende. Wenn du für beide Veranstaltungen Tickets benötigst, kannst du hierher zurückkehren, nachdem du deine Tickets bestellt hast.";
  width: 800px;
  display: block;
  order: 2;
  margin: var(--gap-medium);
  text-align: center;
}
@media (max-width: 1500px) {
  .tickets .pretix-widget .pretix-widget-event-list::after {
    width: 100%;
  }
}
.tickets .pretix-widget .pretix-widget-event-list-back {
  top: -80px;
  left: var(--gap-large);
  width: 160px;
  position: absolute;
}
@media (max-width: 1500px) {
  .tickets .pretix-widget .pretix-widget-event-list-back {
    top: -76px;
  }
}
@media (max-width: 1500px) {
  .tickets .pretix-widget .pretix-widget-event-list-back {
    top: -76px;
  }
}
@media (max-width: 690px) {
  .tickets .pretix-widget .pretix-widget-event-list-back {
    top: -209px;
  }
}
.tickets .pretix-widget .pretix-widget-event-list-back a {
  font-variation-settings: "wght" 270;
  transition: color 200ms ease-out, border-color 200ms ease-out, transform 200ms ease-out;
  text-align: left;
  line-height: var(--button-height);
}
@media (hover: hover) and (pointer: fine) {
  .tickets .pretix-widget .pretix-widget-event-list-back a:hover {
    color: var(--orange) !important;
  }
}
.tickets .pretix-widget .pretix-widget-event-list-back a:active {
  transform: scale(0.95);
}
.tickets .pretix-widget .pretix-widget-event-list-entry {
  position: relative;
  padding: var(--gap-medium) var(--gap-large);
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: var(--white);
  border: none;
  cursor: pointer;
  isolation: isolate;
  height: 250px;
  width: 850px;
}
.tickets .pretix-widget .pretix-widget-event-list-entry:active {
  background: inherit;
}
@media (max-width: 950px) {
  .tickets .pretix-widget .pretix-widget-event-list-entry {
    width: 450px;
    height: 140px;
  }
}
@media (max-width: 550px) {
  .tickets .pretix-widget .pretix-widget-event-list-entry {
    width: 290px;
    height: 83px;
  }
}
@media (hover: hover) and (pointer: fine) {
  .tickets .pretix-widget .pretix-widget-event-list-entry:hover {
    background: inherit;
  }
}
.tickets .pretix-widget .pretix-widget-event-list-entry:focus {
  background: inherit;
}
.tickets .pretix-widget .pretix-widget-event-list-entry:active {
  transform: scale(0.95);
}
.tickets .pretix-widget .pretix-widget-event-list-entry > .turbulence-button {
  position: absolute;
  margin-left: auto;
  margin-right: auto;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  pointer-events: none;
  display: block;
  overflow: visible;
}
.tickets .pretix-widget .pretix-widget-event-list-entry-name, .tickets .pretix-widget .pretix-widget-event-list-entry-date {
  padding: 0 !important;
  width: 100% !important;
  text-align: center;
}
.tickets .pretix-widget .pretix-widget-event-list .pretix-widget-event-list-entry-availability {
  display: none;
}
.tickets .pretix-widget .pretix-widget-attribution {
  display: none;
}
.tickets .pretix-widget-event-details {
  color: var(--white) !important;
}
.tickets .pretix-widget-event-description {
  display: none;
}
.tickets .pretix-widget-item-row {
  padding: 35px 0 !important;
  display: flex;
}
@media (max-width: 950px) {
  .tickets .pretix-widget-item-row {
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
@media (max-width: 690px) {
  .tickets .pretix-widget-item-row {
    padding: 20px 0 !important;
  }
}
.tickets .pretix-widget-item-info-col {
  color: var(--white);
  padding-left: 0 !important;
  width: 556px !important;
}
@media (max-width: 1500px) {
  .tickets .pretix-widget-item-info-col {
    width: 445px !important;
    padding: 0 !important;
  }
}
@media (max-width: 950px) {
  .tickets .pretix-widget-item-info-col {
    width: 260px !important;
  }
}
@media (max-width: 690px) {
  .tickets .pretix-widget-item-info-col {
    width: 100% !important;
  }
}
.tickets .pretix-widget-item-price-col {
  color: var(--white);
  width: 150px !important;
}
@media (max-width: 1500px) {
  .tickets .pretix-widget-item-price-col {
    padding-right: 0 !important;
  }
}
@media (max-width: 690px) {
  .tickets .pretix-widget-item-price-col {
    min-width: 0 !important;
    width: 100px !important;
    text-align: left !important;
    padding: 0 !important;
  }
}
.tickets .pretix-widget-item-price-col .pretix-widget-pricebox {
  font-size: var(--overline);
  margin-top: -5px;
}
@media (max-width: 690px) {
  .tickets .pretix-widget-item-price-col .pretix-widget-pricebox {
    display: flex;
    flex-direction: column;
  }
}
.tickets .pretix-widget-item-price-col .pretix-widget-pricebox .pretix-widget-pricebox-currency {
  display: none;
}
.tickets .pretix-widget-item-price-col .pretix-widget-pricebox > span:first-child::after {
  content: " €";
}
.tickets .pretix-widget-item-availability-col {
  padding-right: 0 !important;
  width: 180px !important;
}
@media (max-width: 690px) {
  .tickets .pretix-widget-item-availability-col {
    width: 150px !important;
  }
}
.tickets .pretix-widget-category-name, .tickets .pretix-widget-category-description {
  padding: 0 !important;
  color: var(--white);
}
.tickets .pretix-widget-category-name p, .tickets .pretix-widget-category-description p {
  color: var(--white);
}
.tickets .pretix-widget-category-name {
  padding: var(--gap-large) 0 0 0 !important;
  width: 100%;
  text-align: center;
}
.tickets .pretix-widget-category-description {
  margin-bottom: 30px;
  margin-top: -15px;
  width: 880px;
}
@media (max-width: 1500px) {
  .tickets .pretix-widget-category-description {
    width: 100%;
  }
}
@media (max-width: 690px) {
  .tickets .pretix-widget-category-description {
    margin-bottom: 15px;
  }
}
.tickets .pretix-widget-action {
  margin-left: 563px !important;
  margin-top: var(--gap-small);
}
@media (max-width: 1500px) {
  .tickets .pretix-widget-action {
    margin-left: 432px !important;
  }
}
@media (max-width: 950px) {
  .tickets .pretix-widget-action {
    margin-left: 0 !important;
    padding: 0 !important;
  }
}
.tickets .pretix-widget-action button {
  width: 303px !important;
}
@media (max-width: 400px) {
  .tickets .pretix-widget-action button {
    width: 100% !important;
  }
}
.tickets .tickets-tabs {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin: var(--gap-large) auto;
  width: fit-content;
  max-width: 100%;
}
@media (max-width: 690px) {
  .tickets .tickets-tabs {
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
  }
}
.tickets .tickets-tabs__btn {
  background: var(--white) !important;
  background-image: none !important;
  color: var(--bordeaux) !important;
  border: none !important;
  height: 45px !important;
  padding: 7px 35px 10px !important;
  font-family: "Chikki", sans-serif;
  font-size: 23px !important;
  line-height: normal !important;
  letter-spacing: 0.8px !important;
  font-variation-settings: "wght" 270;
  white-space: nowrap;
  transition: background 200ms ease-out, color 200ms ease-out;
}
@media (max-width: 950px) {
  .tickets .tickets-tabs__btn {
    font-size: 18px !important;
  }
}
@media (max-width: 690px) {
  .tickets .tickets-tabs__btn {
    flex: 1 1 0;
    min-width: 0;
    height: 38px !important;
    padding: 4px 10px 6px !important;
    font-size: 14px !important;
    letter-spacing: 0.4px !important;
    white-space: normal;
    text-align: center;
  }
}
@media (max-width: 360px) {
  .tickets .tickets-tabs__btn {
    font-size: 13px !important;
  }
}
.tickets .tickets-tabs__btn::before {
  display: none !important;
}
@media (hover: hover) and (pointer: fine) {
  .tickets .tickets-tabs__btn:hover {
    color: var(--black) !important;
  }
}
.tickets .tickets-tabs__btn:active {
  transform: none !important;
  color: var(--blue) !important;
}
.tickets .tickets-tabs__btn--regular {
  border-radius: 30px 8px 8px 30px !important;
}
@media (max-width: 690px) {
  .tickets .tickets-tabs__btn--regular {
    border-radius: 0 8px 8px 0 !important;
    flex: 1 1 0;
  }
}
.tickets .tickets-tabs__btn--reduced {
  border-radius: 8px 30px 30px 8px !important;
}
@media (max-width: 690px) {
  .tickets .tickets-tabs__btn--reduced {
    border-radius: 8px 0 0 8px !important;
    flex: 2.3 1 0;
  }
}
.tickets .tickets-tabs__btn.is-active {
  background: var(--orange) !important;
  color: var(--blue) !important;
}
@media (hover: hover) and (pointer: fine) {
  .tickets .tickets-tabs__btn:hover {
    border: none !important;
  }
  .tickets .tickets-tabs__btn:hover::before {
    opacity: 0 !important;
  }
}
@media (hover: hover) and (pointer: fine) {
  .tickets .tickets-tabs__btn.is-active:hover {
    color: var(--blue) !important;
  }
}
.tickets .tickets-tabs__notch {
  width: 15px;
  height: 45px;
  flex: 0 0 15px;
  background: var(--white);
  transition: background 200ms ease-out;
  -webkit-mask: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 15 45' preserveAspectRatio='none'%3E%3Cpath d='M15 15C10.86 15 7.5 11.64 7.5 7.5C7.5 3.36 4.14 0 0 0V45C4.14 45 7.5 41.64 7.5 37.5C7.5 33.36 10.86 30 15 30V15Z' fill='black'/%3E%3C/svg%3E") center/100% 100% no-repeat;
  mask: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 15 45' preserveAspectRatio='none'%3E%3Cpath d='M15 15C10.86 15 7.5 11.64 7.5 7.5C7.5 3.36 4.14 0 0 0V45C4.14 45 7.5 41.64 7.5 37.5C7.5 33.36 10.86 30 15 30V15Z' fill='black'/%3E%3C/svg%3E") center/100% 100% no-repeat;
  margin-left: -7px;
}
@media (max-width: 690px) {
  .tickets .tickets-tabs__notch {
    height: 38px;
    width: 13px;
    flex-basis: 13px;
    margin-left: -6px;
  }
}
.tickets .tickets-tabs__notch--right {
  transform: scaleX(-1);
  margin-left: 0;
  margin-right: -7px;
}
@media (max-width: 690px) {
  .tickets .tickets-tabs__notch--right {
    margin-left: 0;
    margin-right: -6px;
  }
}
.tickets form[data-active-tab=regular] .tickets-tabs__notch--left {
  background: var(--orange);
}
.tickets form[data-active-tab=reduced] .tickets-tabs__notch--right {
  background: var(--orange);
}
.tickets form[data-active-tab=regular] .tickets-category--reduced,
.tickets form[data-active-tab=reduced] .tickets-category--regular {
  display: none;
}
.tickets form[data-active-tab=regular] .tickets-category--regular .pretix-widget-category-name,
.tickets form[data-active-tab=reduced] .tickets-category--reduced .pretix-widget-category-name {
  display: none;
}
.tickets form[data-active-tab=regular] .tickets-category--regular .pretix-widget-category-description,
.tickets form[data-active-tab=reduced] .tickets-category--reduced .pretix-widget-category-description {
  margin-top: 0;
}

.tickets__metaballs {
  margin: 0;
  bottom: var(--gutter);
  position: absolute;
  left: var(--gutter);
  width: calc(100% - var(--double-gutter));
}
@media (max-width: 950px) {
  .tickets__metaballs figure {
    width: 50px;
  }
}

.location {
  position: relative;
  overflow: visible;
  margin-top: 0;
  margin-bottom: 0;
  color: var(--blue);
  padding: 330px var(--double-gutter) var(--block-spacing) var(--double-gutter);
  background-color: var(--white);
}
@media (max-width: 1500px) {
  .location {
    padding: 240px var(--double-gutter) var(--block-spacing) var(--double-gutter);
  }
}
@media (max-width: 950px) {
  .location {
    padding: 170px 0 var(--block-spacing) 0;
  }
  .location .wp-block-media-text {
    margin-left: var(--gutter) !important;
    margin-right: var(--gutter) !important;
  }
  .location .wrapper {
    display: flex;
    height: 235px;
  }
  .location .wrapper .wp-block-columns {
    margin-right: var(--double-gutter) !important;
    flex-direction: column;
  }
  .location .wrapper .wp-block-accordion {
    width: 330px;
    z-index: 10;
  }
}
@media (max-width: 580px) {
  .location .wrapper {
    flex-direction: column;
    gap: var(--double-gutter);
    height: fit-content;
  }
  .location .wrapper .wp-block-accordion {
    width: calc(100vw - var(--double-gutter));
  }
  .location .wrapper .wp-block-columns {
    margin: 0 !important;
  }
  .location .wrapper .wp-block-columns .wp-block-column:nth-of-type(1) {
    flex-basis: 118px !important;
    height: 100px !important;
    min-height: initial;
  }
}
@media (max-width: 550px) {
  .location .wp-block-media-text {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
}
.location p {
  color: var(--blue);
  padding-bottom: 10px;
}
@media (max-width: 1500px) {
  .location .onwhite a {
    padding: 0 17px 3px 17px;
  }
}
.location .adress {
  margin-bottom: 25px;
}
.location .gem {
  position: absolute;
  left: 0;
  top: -92px;
}
.location .wp-block-media-text__content {
  position: relative;
}
.location .wp-block-media-text__media {
  height: 700px;
}
@media (max-width: 1500px) {
  .location .wp-block-media-text__media {
    height: 587px;
  }
}
@media (max-width: 1200px) {
  .location .wp-block-media-text__media {
    left: 0;
    border-radius: var(--border-radius-medium) 0 0 var(--border-radius-medium) !important;
    width: calc(100% + var(--double-gutter));
    position: relative;
  }
}
@media (max-width: 950px) {
  .location .wp-block-media-text__media {
    width: 100%;
    heIght: 350px;
    border-radius: var(--border-radius-medium) !important;
  }
}
.location .wp-block-media-text__media img {
  height: 100%;
  object-fit: cover;
}

.wave2 {
  margin-top: -2px !important;
  margin-bottom: 0 !important;
}

.join {
  margin-top: var(--block-spacing);
  margin-bottom: 30px !important;
  max-width: 1000px !important;
}
@media (max-width: 550px) {
  .join {
    margin-top: 70px;
  }
}
@media (max-width: 550px) {
  .join .wp-block-spacer {
    height: 30px;
  }
}

/* Scroll-gesteuerte Rotation: Winkel kommt aus --scroll-rot (gesetzt in global.js)
   Runter = im Uhrzeigersinn, hoch = gegen den Uhrzeigersinn.

   --scroll-rot als typisierten Winkel registrieren, damit Browser Updates
   direkt im Compositor verarbeiten können (kein voller Style-Recalc). */
@property --scroll-rot {
  syntax: "<angle>";
  inherits: true;
  initial-value: 0deg;
}
.sputnik img,
.gem {
  transform: rotate(var(--scroll-rot, 0deg));
  transform-origin: center center;
  will-change: transform;
}

.sun {
  transform: rotate(calc(var(--scroll-rot, 0deg) * -0.5));
  transform-origin: center center;
  will-change: transform;
}

/* Background-Image des Eyecatchers dreht sich entgegengesetzt.
   Das Bild wird per JS (global.js) auf ein ::before-Pseudoelement
   umgezogen, damit Text/Button nicht mitrotieren. */
.header__eyecatcher {
  isolation: isolate;
}
.header__eyecatcher::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: var(--eyecatcher-bg, none);
  background-repeat: var(--eyecatcher-bg-repeat, no-repeat);
  background-position: var(--eyecatcher-bg-position, center);
  background-size: var(--eyecatcher-bg-size, contain);
  /* Faktor negativ = Gegenrichtung, Betrag < 1 = langsamer */
  transform: rotate(calc(var(--scroll-rot, 0deg) * -0.12));
  transform-origin: center center;
  will-change: transform;
  z-index: -1;
  pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
  .sputnik img,
  .gem,
  .sun,
  .header__eyecatcher::before {
    transform: none;
  }
}

/*# sourceMappingURL=main.css.map */
