@charset "UTF-8";
/*
! tailwindcss v3.0.24 | MIT License | https://tailwindcss.com
*/
/*
1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116)
*/
*,
::before,
::after {
  box-sizing: border-box; /* 1 */
  border-width: 0; /* 2 */
  border-style: solid; /* 2 */
  border-color: currentColor; /* 2 */
}
::before,
::after {
  --tw-content: '';
}
/*
1. Use a consistent sensible line-height in all browsers.
2. Prevent adjustments of font size after orientation changes in iOS.
3. Use a more readable tab size.
4. Use the user's configured `sans` font-family by default.
*/
html {
  line-height: 1.5; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -moz-tab-size: 4; /* 3 */
  -o-tab-size: 4;
     tab-size: 4; /* 3 */
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"; /* 4 */
}
/*
1. Remove the margin in all browsers.
2. Inherit line-height from `html` so users can set them as a class directly on the `html` element.
*/
body {
  margin: 0; /* 1 */
  line-height: inherit; /* 2 */
}
/*
1. Add the correct height in Firefox.
2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
3. Ensure horizontal rules are visible by default.
*/
hr {
  height: 0; /* 1 */
  color: inherit; /* 2 */
  border-top-width: 1px; /* 3 */
}
/*
Add the correct text decoration in Chrome, Edge, and Safari.
*/
abbr:where([title]) {
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}
/*
Remove the default font size and weight for headings.
*/
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
}
/*
Reset links to optimize for opt-in styling instead of opt-out.
*/
a {
  color: inherit;
  text-decoration: inherit;
}
/*
Add the correct font weight in Edge and Safari.
*/
b,
strong {
  font-weight: bolder;
}
/*
1. Use the user's configured `mono` font family by default.
2. Correct the odd `em` font sizing in all browsers.
*/
code,
kbd,
samp,
pre {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; /* 1 */
  font-size: 1em; /* 2 */
}
/*
Add the correct font size in all browsers.
*/
small {
  font-size: 80%;
}
/*
Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sub {
  bottom: -0.25em;
}
sup {
  top: -0.5em;
}
/*
1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
3. Remove gaps between table borders by default.
*/
table {
  text-indent: 0; /* 1 */
  border-color: inherit; /* 2 */
  border-collapse: collapse; /* 3 */
}
/*
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
3. Remove default padding in all browsers.
*/
button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-size: 100%; /* 1 */
  line-height: inherit; /* 1 */
  color: inherit; /* 1 */
  margin: 0; /* 2 */
  padding: 0; /* 3 */
}
/*
Remove the inheritance of text transform in Edge and Firefox.
*/
button,
select {
  text-transform: none;
}
/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Remove default button styles.
*/
button,
[type='button'],
[type='reset'],
[type='submit'] {
  -webkit-appearance: button; /* 1 */
  background-color: transparent; /* 2 */
  background-image: none; /* 2 */
}
/*
Use the modern Firefox focus style for all focusable elements.
*/
:-moz-focusring {
  outline: auto;
}
/*
Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/
:-moz-ui-invalid {
  box-shadow: none;
}
/*
Add the correct vertical alignment in Chrome and Firefox.
*/
progress {
  vertical-align: baseline;
}
/*
Correct the cursor style of increment and decrement buttons in Safari.
*/
::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}
/*
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/
[type='search'] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}
/*
Remove the inner padding in Chrome and Safari on macOS.
*/
::-webkit-search-decoration {
  -webkit-appearance: none;
}
/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to `inherit` in Safari.
*/
::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}
/*
Add the correct display in Chrome and Safari.
*/
summary {
  display: list-item;
}
/*
Removes the default spacing and border for appropriate elements.
*/
blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
  margin: 0;
}
fieldset {
  margin: 0;
  padding: 0;
}
legend {
  padding: 0;
}
ol,
ul,
menu {
  list-style: none;
  margin: 0;
  padding: 0;
}
/*
Prevent resizing textareas horizontally by default.
*/
textarea {
  resize: vertical;
}
/*
1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
2. Set the default placeholder color to the user's configured gray 400 color.
*/
input::-moz-placeholder, textarea::-moz-placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}
input:-ms-input-placeholder, textarea:-ms-input-placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}
input::placeholder,
textarea::placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}
/*
Set the default cursor for buttons.
*/
button,
[role="button"] {
  cursor: pointer;
}
/*
Make sure disabled buttons don't get the pointer cursor.
*/
:disabled {
  cursor: default;
}
/*
1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
   This can trigger a poorly considered lint error in some tools but is included by design.
*/
img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
  display: block; /* 1 */
  vertical-align: middle; /* 2 */
}
/*
Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/
img,
video {
  max-width: 100%;
  height: auto;
}
/*
Ensure the default browser behavior of the `hidden` attribute.
*/
[hidden] {
  display: none;
}
*, ::before, ::after{
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
}
/* import your custom base styles here */
/*===================*/
/* WOOBLE SKEW
/*===================*/
@-webkit-keyframes wobble-skew-on-hover {
  16.65% {
    transform: skew(-12deg);
  }
  33.3% {
    transform: skew(10deg);
  }
  49.95% {
    transform: skew(-6deg);
  }
  66.6% {
    transform: skew(4deg);
  }
  83.25% {
    transform: skew(-2deg);
  }
  100% {
    transform: skew(0);
  }
}
@keyframes wobble-skew-on-hover {
  16.65% {
    transform: skew(-12deg);
  }
  33.3% {
    transform: skew(10deg);
  }
  49.95% {
    transform: skew(-6deg);
  }
  66.6% {
    transform: skew(4deg);
  }
  83.25% {
    transform: skew(-2deg);
  }
  100% {
    transform: skew(0);
  }
}
@-webkit-keyframes wobble-skew-on-hover-light {
  16.65% {
    transform: skew(-3deg);
  }
  33.3% {
    transform: skew(2.5deg);
  }
  49.95% {
    transform: skew(-1.5deg);
  }
  66.6% {
    transform: skew(1deg);
  }
  83.25% {
    transform: skew(-0.5deg);
  }
  100% {
    transform: skew(0);
  }
}
@keyframes wobble-skew-on-hover-light {
  16.65% {
    transform: skew(-3deg);
  }
  33.3% {
    transform: skew(2.5deg);
  }
  49.95% {
    transform: skew(-1.5deg);
  }
  66.6% {
    transform: skew(1deg);
  }
  83.25% {
    transform: skew(-0.5deg);
  }
  100% {
    transform: skew(0);
  }
}
.wobble-skew-on-hover {
  display: inline-block;
  vertical-align: middle;
  transform: perspective(1px) translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
}
.wobble-skew-on-hover:hover, .wobble-skew-on-hover:focus, .wobble-skew-on-hover:active {
  -webkit-animation-name: wobble-skew-on-hover;
          animation-name: wobble-skew-on-hover;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
}
html {
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  font-smoothing: antialiased;
  font-weight: 400;
}
body {
  background-color: rgb(151, 4, 191);
  font-family: "Selecta Regular", sans-serif;
  font-size: 1rem;
  color: rgb(5, 242, 175);
  font-weight: normal;
  line-height: 1.75rem;
  --footer-top: 8em;
  --page-padding: 5px;
}
header, article, .footer1_wrapper, .footer2_wrapper {
  padding-left: var(--page-padding) !important;
  padding-right: var(--page-padding) !important;
}
hr {
  border: 0;
  height: 0;
}
.sr-only {
  position: absolute;
  left: -10000px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
.container {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  max-width: 1280px !important;
  padding-left: 1rem;
  padding-right: 1rem;
}
.container.container_header, .container.footer_logo, .container.cover {
  padding-left: 0;
  padding-right: 0;
}
#burgermenu-wrapper {
  padding: 0.5rem !important;
}
.article-container {
  width: 100%;
  background-repeat: repeat-y;
  background-position-y: top;
  background-position-x: left, right;
  background-size: 12vw auto;
}
article#content {
  min-height: 380px;
  font-size: 1.4rem;
  padding-top: 1rem;
  padding-bottom: 10rem;
  overflow: hidden;
}
.type-default .default-grid,
.type-landing.page-error .default-grid, .type-landing.type-search .default-grid {
  display: flex;
  gap: 5em;
}
.type-default .default-grid .default-grid-main,
.type-landing.page-error .default-grid .default-grid-main, .type-landing.type-search .default-grid .default-grid-main {
  width: 100%;
}
.type-home .default-grid .default-grid-main {
  max-width: 748px;
  margin: 0 auto;
}
.type-home .default-grid {
  text-align: center;
}
.type-landing:not(.page-error) .default-grid, .type-events:not(.page-error) .default-grid, .type-agenda:not(.page-error) .default-grid {
  display: block;
}
.type-landing:not(.page-error) .default-grid .default-grid-main, .type-events:not(.page-error) .default-grid .default-grid-main, .type-agenda:not(.page-error) .default-grid .default-grid-main {
  width: 100%;
  margin-bottom: 6em;
}
.type-landing:not(.page-error) .default-grid .default-grid-aside, .type-events:not(.page-error) .default-grid .default-grid-aside, .type-agenda:not(.page-error) .default-grid .default-grid-aside {
  width: 100%;
}
@media screen and (max-width: 900px) {
  .default-grid, .type-landing.page-error .default-grid, .type-landing.type-search .default-grid {
    gap: 3em;
  }
}
@media screen and (max-width: 768px) {
  .default-grid {
    display: block;
  }
  .default-grid .default-grid-main {
    width: 100%;
    margin-bottom: 6em;
  }
  .default-grid .default-grid-aside {
    width: 100%;
  }
}
p {
  margin-bottom: 1em;
}
ul {
  list-style-type: disc;
  margin-bottom: 1em;
  padding-left: 2em;
}
b, strong {
  font-family: "Selecta Bold", sans-serif;
}
a {
  word-wrap: break-word;
  overflow-wrap: break-word;
}
#content ol {
  --cols: 3;
  --gap: 2em;
  grid-template-columns: repeat(var(--cols), 1fr);
  display: grid;
  grid-gap: var(--gap);
  margin: 2em 0 3em;
}
#content ol li br {
  content: "";
  display: block;
  height: 0.6em;
}
#content ol li strong {
  display: block;
  font-size: 1.7rem;
  line-height: 2.1rem;
  margin-bottom: 0;
}
#content ol li strong br {
  content: "";
  display: block;
  height: 0;
}
#content .accordion ol li strong {
  margin-bottom: 0.6em;
}
@media screen and (max-width: 620px) {
  #content ol {
    --cols: 2;
  }
}
@media screen and (max-width: 550px) {
  #content ol {
    --cols: 1;
  }
}
article .default-grid-main > *:first-child {
  margin-top: 0;
}
.justified {
  text-align: justify;
  width: 100%;
  margin-bottom: -1.5rem;
}
.justified:after {
  content: "";
  display: inline-block;
  width: 100%;
  height: 1px;
}
.type-homepage #content img.cover1, .type-homepage #content img.cover2 {
  width: 100vw;
  min-width: 100vw;
  position: relative;
  margin-left: -50vw;
  left: 50%;
}
#content .content-absatz {
  max-width: 790px;
  text-align: center;
  margin: 3rem auto 4.5rem;
}
#content .content-absatz h2 {
  margin-top: 6rem;
  margin-bottom: 2rem;
  text-transform: initial;
  text-align: center;
}
#content .content-absatz .text {
  max-width: 720px;
  margin: 2rem auto;
}
#content .content-absatz .text p {
  margin-bottom: 1em;
}
.type-home #content .content-absatz {
  margin: 6rem auto 4rem;
}
.type-home #content .content-absatz h2 {
  margin-top: 6rem;
  margin-bottom: 2rem;
}
.type-home #content .content-absatz .text {
  margin: 2rem auto;
}
.type-home #content .content-absatz .text p {
  margin-bottom: 2em;
}
#anibutton-burger .icon-button {
  transform: scaleX(0.8);
  transform-origin: center right;
}
@font-face {
  font-family: "Selecta Regular";
  src: url("/dist/fonts/Selecta-Regular.woff2") format("woff2"), url("/dist/fonts/Selecta-Regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Selecta Bold";
  src: url("/dist/fonts/Selecta-Bold.woff2") format("woff2"), url("/dist/fonts/Selecta-Bold.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
a {
  color: inherit;
  text-decoration: none;
  background-image: none;
  display: inline-block;
  transform: perspective(1px) translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
}
a:hover, a:active, a:focus {
  -webkit-animation-name: wobble-skew-on-hover;
          animation-name: wobble-skew-on-hover;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
}
.events-list .event-teaser .teacher-link {
  display: inline-block;
  transform: perspective(1px) translateZ(0);
  box-shadow: 0 0 1px rgba(0, 0, 0, 0);
}
.events-list .event-teaser .teacher-link:hover, .events-list .event-teaser .teacher-link:active, .events-list .event-teaser .teacher-link:focus {
  -webkit-animation-name: wobble-skew-on-hover-light;
          animation-name: wobble-skew-on-hover-light;
  -webkit-animation-duration: 0.9s;
          animation-duration: 0.9s;
  -webkit-animation-timing-function: ease-in-out;
          animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
}
header a,
footer a,
nav a {
  background-image: none;
}
article#content a {
  color: rgb(5, 242, 175);
}
.mainnav-box .mainnav-section .mainnav-section_title.active a {
  color: rgb(5, 242, 175);
  -webkit-text-decoration-line: underline;
          text-decoration-line: underline;
  -webkit-text-decoration-style: solid;
          text-decoration-style: solid;
  -webkit-text-decoration-skip: ink;
          text-decoration-skip-ink: auto;
  -webkit-text-decoration-skip-ink: all;
          text-decoration-skip-ink: all;
  text-underline-offset: 0.2em;
  text-decoration-thickness: 0.12em;
}
h2 {
  font-family: "Selecta Regular", sans-serif;
  font-size: 3.7rem;
  line-height: 1;
  margin-bottom: 1rem;
  margin-top: 5rem;
}
h3 {
  margin-top: 1.2em;
  margin-bottom: 0.6em;
  font-size: 1.7rem;
  font-weight: 300;
  line-height: 2.1rem;
}
h1 {
  font-family: "Selecta Regular", sans-serif;
  font-size: 2rem;
  line-height: 1;
  margin-bottom: 3rem;
}
.type-homepage h1 {
  margin-bottom: 0;
}
.type-homepage h2 {
  margin-top: 0;
  text-transform: uppercase;
  font-size: 3.1rem;
}
.type-homepage h2.bwt-img {
  font-size: 4.4rem;
  margin-top: 1.5rem;
  margin-bottom: -3.5rem;
}
.type-event-default h1 {
  font-size: 3.8rem;
  margin-top: 2rem;
}
.type-landing h1, .type-events h1, .type-default h1, .type-teachers h1, .type-homepage h1 {
  font-size: 6rem;
  text-transform: uppercase;
  text-align: center;
}
.type-landing h1, .type-events h1, .type-default h1, .type-teachers h1 {
  width: 100%;
  color: rgb(5, 242, 175);
}
.type-teachers h2 {
  margin: 0;
}
.stretch_it {
  white-space: nowrap;
  transition: 0.6s ease-out;
  text-align: center;
}
@media screen and (max-width: 650px) {
  .type-landing h1, .type-events h1, .type-default h1, .type-teachers h1, .type-homepage h1 {
    font-size: 5rem;
  }

  .type-event-default h1,
#content .accordion-section .accordion .accordion-toggle .accordion-title {
    font-size: 3rem;
  }

  .type-homepage h2 {
    font-size: 2.5rem;
  }
  .type-homepage h2.justified {
    text-align: center;
  }

  #content .content-absatz h2 {
    margin-top: 4rem;
  }

  .type-homepage h2.bwt-img {
    font-size: 3.2rem;
    margin-bottom: -2.2rem;
  }
}
@media screen and (max-width: 600px) {
  h1, h2, h3 {
    -webkit-hyphens: auto;
        -ms-hyphens: auto;
            hyphens: auto;
  }

  .no-hyphen {
    -webkit-hyphens: none;
        -ms-hyphens: none;
            hyphens: none;
  }
}
@media screen and (max-width: 500px) {
  .type-homepage h1, .type-landing h1, .type-events h1, .type-agenda h1, .type-search h1 {
    font-size: 3rem;
  }

  .type-landing h1, .type-events h1, .type-default h1, .type-teachers h1, .type-homepage h1 {
    font-size: 3.5rem;
  }
}
@media screen and (max-width: 450px) {
  .type-landing h1, .type-events h1, .type-default h1, .type-teachers h1, .type-homepage h1 {
    font-size: 3rem;
  }

  .type-event-default h1,
#content .accordion-section .accordion .accordion-toggle .accordion-title {
    font-size: 2.5rem;
  }

  .type-homepage h2 {
    font-size: 2rem;
  }

  .type-homepage h2.bwt-img {
    font-size: 2rem;
    margin-bottom: -1rem;
  }
}
.lead p {
  margin: 0;
}
.lead {
  margin-bottom: 2em;
  font-size: 1.2rem;
  line-height: 1.7rem;
}
.type-homepage .lead, .type-landing .lead, .type-events .lead, .type-agenda .lead, .type-search .lead {
  margin-bottom: 3em;
  font-size: 1.75rem;
  line-height: 1;
}
.type-landing.page-error .disclaimer {
  margin-top: 0.5em;
  font-size: 1.75rem;
  line-height: 1.35;
  margin-bottom: 3em;
  max-width: 500px;
}
.type-landing.page-error .disclaimer p {
  margin-bottom: 0.5em;
}
@media screen and (max-width: 500px) {
  .type-homepage .lead, .type-landing .lead, .type-events .lead, .type-agenda .lead, .type-search .lead {
    font-size: 1.25rem;
    line-height: 1.2;
  }
}
article figure {
  margin-bottom: 2em;
}
article figcaption {
  margin-top: 0.3em;
}
body {
  --line-width: 6px;
  --line-color: rgb(5, 242, 175);
  --line-style: solid;
}
.container.container_header {
  border-bottom-width: var(--line-width);
  border-color: var(--line-color);
  border-style: var(--line-style);
}
.page_footer .container_footer {
  border-top-width: var(--line-width);
  border-color: var(--line-color);
  border-style: var(--line-style);
}
.events-h2-container {
  border-top-width: var(--line-width);
  border-color: var(--line-color);
  border-style: var(--line-style);
}
.front-1 {
  border-bottom-width: var(--line-width);
  border-left-width: var(--line-width);
  border-color: var(--line-color);
  border-style: var(--line-style);
}
.front-2 {
  border-bottom-width: var(--line-width);
  border-right-width: var(--line-width);
  border-color: var(--line-color);
  border-style: var(--line-style);
}
.front-3 {
  border-bottom-width: var(--line-width);
  border-right-width: var(--line-width);
  border-left-width: var(--line-width);
  border-color: var(--line-color);
  border-style: var(--line-style);
}
.front-4 {
  border-right-width: var(--line-width);
  border-left-width: var(--line-width);
  border-color: var(--line-color);
  border-style: var(--line-style);
}
.accordion-section .accordion {
  border-top-width: var(--line-width);
  border-bottom-width: var(--line-width);
  border-color: var(--line-color);
  border-style: var(--line-style);
}
.accordion-section .accordion + .accordion {
  border-top-width: 0;
}
/*
@import "base/input";*/
.container{
  width: 100%;
}
@media (min-width: 640px){
  .container{
    max-width: 640px;
  }
}
@media (min-width: 768px){
  .container{
    max-width: 768px;
  }
}
@media (min-width: 1024px){
  .container{
    max-width: 1024px;
  }
}
@media (min-width: 1280px){
  .container{
    max-width: 1280px;
  }
}
@media (min-width: 1536px){
  .container{
    max-width: 1536px;
  }
}
.page_footer {
  position: relative;
  z-index: 10;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  line-height: 2.3rem;
  font-size: 1.9rem;
  background-color: rgb(151, 4, 191);
}
.page_footer .container_footer {
  margin-left: auto;
  margin-right: auto;
  flex-wrap: wrap;
  padding-top: 1rem;
  padding-bottom: 1rem;
  display: flex;
  justify-content: space-between;
}
.page_footer .container_footer section {
  width: 390px;
  max-width: 100%;
}
.page_footer .footer_navigation {
  list-style: none;
  margin: 0;
  padding: 0;
  margin-bottom: 1rem;
  line-height: 2.9rem;
}
.page_footer .footer_navigation li ol {
  margin-bottom: 1rem;
}
.page_footer .footer_navigation.footer-service-nav {
  margin-bottom: 4rem;
}
.page_footer .footer-logo-wrapper {
  padding: 6rem 0;
}
.page_footer .footer_logo {
  overflow: hidden;
}
.page_footer .footer_logo .logo-link {
  display: block;
  max-width: 100%;
  display: flex;
  align-items: center;
}
.page_footer .footer_logo .logo-link img {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .page_footer .container_footer {
    display: block;
  }
  .page_footer .footer_navigation {
    margin-top: 1rem;
    margin-bottom: 4rem;
  }
}
header {
  position: -webkit-sticky;
  position: sticky;
  top: -6vw;
  top: calc((2vw + 90px) * -1);
  z-index: 5;
  transition: top 1.2s ease-out;
}
@media screen and (min-width: 1281px) {
  header {
    top: calc((3vw + 90px) * -1);
  }
}
@media screen and (min-width: 890px) and (max-width: 1280px) {
  header {
    top: calc((2vw + 90px) * -1);
  }
}
.page_header {
  position: relative;
  line-height: 1.75rem;
  background-color: rgb(151, 4, 191);
}
.mainnav_logo {
  padding: 2.5rem 0 1rem;
}
.mainnav_logo .logo-link {
  display: block;
  max-width: 100%;
  display: flex;
  align-items: center;
  padding-bottom: 3px;
}
.mainnav_logo .logo-link img {
  width: 100%;
}
.mainnav-box {
  width: 100%;
  padding-top: 0.8rem;
  padding-bottom: 0.8rem;
}
.mainnav-box .mainnav {
  display: flex;
  justify-content: space-between;
  gap: 1em;
}
.mainnav-box .mainnav-section .mainnav-section_title {
  display: block;
}
.mainnav-box .mainnav-section .mainnav-section_title a {
  font-size: 1.7rem;
}
.mainnav-box .mainnav-section .mainnav-section_title.active {
  color: rgb(5, 242, 175);
}
@media screen and (max-width: 889px) {
  .mainnav_logo .logo-link {
    padding: 6px 0 7px;
    max-width: 300px;
  }
}
@media screen and (max-width: 768px) {
  header {
    top: 0px;
  }
}
.accordion-section {
  --icow: 30px;
  --icom: 5px;
  --icoc: rgb(5, 242, 175);
  --icos: 5px;
  margin-bottom: 3em;
  margin-top: 2em;
}
.accordion-section .accordion {
  --ast: 50px;
}
.accordion-section .accordion .accordion-toggle {
  margin: 0;
  padding: 12px 0 13px;
  display: block;
  width: 100%;
  font-family: inherit;
  font-weight: inherit;
  font-style: inherit;
  font-size: inherit;
  line-height: inherit;
  color: inherit;
  text-align: inherit;
  background-color: transparent;
  background-image: none;
  text-transform: none;
  cursor: pointer;
}
.accordion-section .accordion .accordion-toggle .accordion-title {
  order: 2;
  font-family: "Selecta Regular", sans-serif;
  font-size: 3.7rem;
  line-height: 1;
  margin: 0;
  display: inline;
}
.accordion-section .accordion .accordion-toggle .arrow-box {
  box-sizing: border-box;
  display: inline-block;
  padding-left: var(--icom);
  order: 2;
  display: inline;
  white-space: nowrap;
}
.accordion-section .accordion .accordion-toggle .arrow-box .accordion-icon {
  display: inline-block;
  position: relative;
  width: var(--icow);
  aspect-ratio: 1/1;
  background-image: linear-gradient(var(--icoc), var(--icoc));
  background-size: 100% var(--icos);
  background-repeat: no-repeat;
  background-position: 50% 50%;
  transform: translateY(-2px);
}
.accordion-section .accordion .accordion-toggle .arrow-box .accordion-icon:before {
  content: "";
  display: block;
  position: absolute;
  aspect-ratio: 1/1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background-image: linear-gradient(var(--icoc), var(--icoc));
  background-repeat: no-repeat;
  background-size: var(--icos) 100%;
  background-position: 50% 50%;
  transform: rotate(0deg);
  transition: transform 0.5s ease;
}
.accordion-section .accordion .accordion-toggle .arrow-box.right {
  order: 3;
}
.accordion-section .accordion .accordion-toggle .arrow-box.left {
  order: 1;
}
.accordion-section .accordion .accordion-toggle.accordion-active .arrow-box .accordion-icon:before {
  transform: rotate(270deg);
}
.accordion-section .accordion .accordion-toggle:hover .accordion-title {
  color: rgb(5, 242, 175);
}
.accordion-section .accordion .accordion-toggle:hover .arrow-box {
  --icoc: rgb(5, 242, 175);
}
.accordion-section .accordion .accordion-panel {
  display: none;
  padding: 0.9em 1em 1em 0;
}
.accordion-section .accordion .accordion-panel > *:first-child {
  margin-top: 0;
}
.accordion-section .section-title {
  max-width: none;
}
.accordion .accordion-toggle .arrow::before {
  border-color: var(--theme-color);
}
.accordion .accordion-toggle .arrow.right::before {
  transform: rotate(135deg);
  transform-origin: 52% 46%;
}
.accordion .accordion-toggle.accordion-active .arrow.right::before {
  transform: rotate(-45deg) translate(-4px, 4px);
}
@media screen and (max-width: 768px) {
  .accordion-section .accordion .accordion-toggle {
    -webkit-hyphens: auto;
        -ms-hyphens: auto;
            hyphens: auto;
  }
}
@media screen and (max-width: 650px) {
  .accordion-section {
    --icow: 22px;
    --icom: 5px;
    --icos: 4px;
  }
}
@media screen and (max-width: 450px) {
  .accordion-section {
    --icow: 18px;
  }
}
.video-section {
  margin: 4em auto;
  max-width: 800px;
}
.video-section figure {
  margin: 0;
}
.video-section .video-txt {
  margin-top: 0.7em;
}
.video-section .video-txt .video-title {
  margin-bottom: 0.4em;
  font-family: "FKDisplay-Regular";
  font-size: 1.2em;
  font-weight: 700;
}
.video-section .responsive-container {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  width: 100%;
  height: auto;
}
.video-section .responsive-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.events-h2-container {
  padding-top: 43px;
  position: relative;
}
.events-h2-container h2 {
  font-size: 2.7rem;
  text-align: center;
  margin-bottom: 2rem;
}
.events-list {
  --gap: 1em;
  --cols: 2;
  margin: 4em 0;
  margin-top: 1.5rem;
  display: grid;
  grid-template-columns: repeat(var(--cols), 1fr);
  -moz-column-gap: calc(100% / var(--cols) / 10);
       column-gap: calc(100% / var(--cols) / 10);
  -moz-column-gap: var(--gap);
       column-gap: var(--gap);
  row-gap: var(--gap);
}
.events-list .event-teaser {
  margin-bottom: 1em;
}
.events-list .event-teaser .teacher-link {
  display: block;
  text-decoration: none;
  position: relative;
  overflow: hidden;
  padding-bottom: 0;
  color: rgb(5, 242, 175) !important;
}
.events-list .event-teaser .teacher-link:hover, .events-list .event-teaser .teacher-link:focus {
  color: rgb(5, 242, 175) !important;
}
.events-list .event-teaser .teacher-link:hover .event-image:after, .events-list .event-teaser .teacher-link:focus .event-image:after {
  background-color: transparent;
}
.events-list .event-teaser .event-image {
  position: relative;
  transition: all 400ms ease;
  margin-bottom: 0.4em;
}
.events-list .event-teaser .event-image img {
  width: 100%;
}
.events-list .event-teaser .event-image:after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #010846;
  mix-blend-mode: color;
  opacity: 0.8;
  transition: all 400ms ease;
}
.events-list .event-teaser .event-info {
  width: 100%;
  display: flex;
  flex-direction: column;
}
.events-list .event-teaser .event-info h2 {
  order: 2;
  font-size: 1.3em;
  margin-top: 0;
  margin-bottom: 0.7rem;
}
.events-list .event-teaser .event-info p {
  order: 1;
  margin-bottom: 0.5rem;
  font-size: 1.1rem;
  line-height: 1.45rem;
}
.events-list .event-teaser .event-info .readmore {
  margin: 0;
  font-family: "Selecta Regular", sans-serif;
  font-style: italic;
}
.list1-2 {
  --gap: 1em;
  --cols: 2;
  margin: 4em 0;
  margin-top: 1.5rem;
  display: grid;
  grid-template-columns: repeat(var(--cols), 1fr);
  -moz-column-gap: calc(100% / var(--cols) / 10);
       column-gap: calc(100% / var(--cols) / 10);
  -moz-column-gap: var(--gap);
       column-gap: var(--gap);
  row-gap: var(--gap);
}
.list1-2 .events-list {
  --cols: 1;
}
@media screen and (max-width: 600px) {
  .list1-2 {
    --cols: 1;
  }
}
@media screen and (min-width: 1060px) {
  .list1-2 {
    --cols: 3;
  }
}
@media screen and (max-width: 600px) {
  .events-list {
    --cols: 1;
  }
  .events-list .event-teaser:nth-of-type(even) {
    transform: translateY(0);
  }
  .events-list .event-teaser:nth-of-type(3n+2) {
    transform: translateY(0);
  }
}
@media screen and (max-width: 900px) {
  .events-list {
    --gap: 1.5em;
  }
}
@media screen and (min-width: 1060px) {
  .events-list {
    --cols: 3;
  }
  .events-list .event-teaser:nth-of-type(even) {
    transform: translateY(0);
  }
}
.type-event-default .event-short {
  --gap: 3em;
  --hg: calc(var(--gap) / 2);
  --cols: 2;
  --col: calc(100% / var(--cols));
  display: flex;
  flex-wrap: wrap;
  -moz-column-gap: var(--gap);
       column-gap: var(--gap);
  margin: 2em 0;
}
.type-event-default .event-short .event-image, .type-event-default .event-short .teacher-contactinfo {
  width: calc(var(--col) - var(--hg));
}
.type-event-default .event-short .event-image {
  margin-bottom: 0;
}
.type-event-default .event-info {
  margin-bottom: 1rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}
.type-event-default .event-info > * {
  margin-bottom: 1.4rem;
}
.type-event-default .event-info, .type-event-default .event-type, .type-event-default .event-artist-title {
  font-size: 1.9rem;
  line-height: 1.25;
}
.type-event-default .event-artist-title {
  font-family: "GT Flexa Standard Regular", sans-serif;
  line-height: 1.2;
  margin-top: 0;
  margin-bottom: 0.5rem;
}
.type-event-default .event-sales p:first-child {
  margin-bottom: 0;
}
.type-event-default .event-sales-tickets {
  margin-bottom: 1.4rem;
}
.type-event-default .small {
  font-size: 0.73em;
}
.type-event-default .event-artist figure {
  margin-bottom: 1em;
}
.type-event-default .event-grid2 {
  display: grid;
  grid-template-columns: repeat(1, 1fr 2fr);
  gap: 2rem;
}
.type-event-default .event-grid2 > * {
  margin-bottom: 3rem;
}
.type-event-default .event-grid2 .event-artist-image {
  margin-bottom: 1.4rem;
}
.type-event-default .event-grid2 .event-artist-image figcaption {
  font-size: 13px;
}
@media screen and (max-width: 650px) {
  .type-event-default .event-info {
    display: block;
  }

  .type-event-default .event-grid2 {
    display: block;
  }

  .event-artist {
    margin-top: 2em;
  }
}
.type-homepage article#content {
  padding-top: 0;
  padding-bottom: 0;
}
.front-1, .front-2 {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
}
.front-1 h1, .front-1 h2, .front-2 h1, .front-2 h2 {
  font-size: 5rem;
  text-transform: none;
  margin-bottom: 0;
}
.front-1 h1 {
  text-align: initial;
}
.front-2 h2 {
  text-align: initial;
  display: flex;
  flex-wrap: nowrap;
}
.front-2 h2 span {
  width: 50%;
}
.front-3, .front-4 {
  display: flex;
  justify-content: center;
}
.front-3 p, .front-4 p {
  max-width: 1000px;
  padding: 1.5rem 2rem 1.5rem;
  margin-bottom: 0;
  text-align: center;
  font-size: 3.5rem;
  line-height: 3.75rem;
}
.front-3 {
  margin-top: 2rem;
}
.front-3 p {
  padding-top: 0;
}
.front-3.front-default-img {
  margin-top: 0;
  padding: 0;
}
.front-4 {
  margin-bottom: 2rem;
}
.front-4 p {
  padding-bottom: 0;
}
.front-3 {
  position: relative;
}
.front-3:before {
  content: "";
  position: absolute;
  top: 50%;
  /* Vertikal zentrieren */
  left: 50%;
  /* Horizontal zentrieren */
  transform: translate(-50%, -50%);
  /* Um das Bild in der Mitte zu zentrieren */
  background-image: url("../images/aprillen25_bg.svg");
  background-position: center;
  background-repeat: no-repeat;
  background-size: 1606px 1320px;
  width: 1606px;
  /* Breite des Bildes - kann je nach Bildgröße angepasst werden */
  height: 1320px;
  z-index: -5;
}
.front-1 p, .front-1 h1, .front-1 h2, .front-2 p, .front-2 h1, .front-2 h2, .front-3 p, .front-3 h1, .front-3 h2, .front-4 p, .front-4 h1, .front-4 h2 {
  filter: url(#outlineColored);
}
@media screen and (max-width: 990px) {
  .front-2 h2 {
    flex-wrap: wrap;
  }
  .front-2 h2 span {
    width: 100%;
  }
  .front-2 h2 span.front-venue {
    text-align: right;
  }
}
@media screen and (max-width: 500px) {
  .front-1 h1, .front-1 h2, .front-2 h1, .front-2 h2 {
    font-size: 3.5rem;
  }

  .front-3 p, .front-4 p {
    font-size: 2rem;
    line-height: 2.5rem;
  }

  .front-3 {
    padding: 0;
  }
  .front-3:before {
    display: none;
  }

  .front-1 p, .front-1 h1, .front-1 h2, .front-2 p, .front-2 h1, .front-2 h2, .front-3 p, .front-3 h1, .front-3 h2, .front-4 p, .front-4 h1, .front-4 h2 {
    filter: none;
  }
}
.off-canvas-content {
  transform: none;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  position: absolute;
  top: 0;
  width: 100%;
  min-height: 100vh;
  z-index: 0;
}
#offCanvas.off-canvas.is-transition-overlap {
  z-index: 10000;
}
#offCanvas.is-open {
  transform: translate(0, 0);
}
#offCanvas.position-right {
  max-width: 100% !important;
}
#offCanvas.is-transition-overlap {
  z-index: 13;
}
#offCanvas.is-transition-overlap.off-canvas.is-transition-overlap.is-open {
  box-shadow: none;
}
[data-whatinput=mouse] .off-canvas {
  outline: 0;
}
.off-canvas {
  position: fixed;
  z-index: 12;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  background: #fefefe;
}
.off-canvas.position-right {
  top: 0;
  right: 0;
  height: 100%;
  overflow-y: auto;
  width: 100%;
  transform: translateX(100%);
}
.off-canvas.position-right.is-transition-overlap.is-open {
  transform: translate(0, 0);
}
.off-canvas.is-closed {
  visibility: hidden;
  transition: visibility 0s linear 0.5s, 0.5s transform;
}
.off-canvas.is-open {
  visibility: visible;
  transition: visibility 0s linear 0s, 0.5s transform;
}
.js-off-canvas-overlay {
  z-index: 200;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(124, 124, 124, 0.18);
  opacity: 0;
  visibility: hidden;
  overflow: hidden;
}
.js-off-canvas-overlay.is-overlay-fixed {
  position: fixed;
}
.js-off-canvas-overlay.is-closable {
  cursor: pointer;
}
.js-off-canvas-overlay.is-visible {
  opacity: 1;
  visibility: visible;
  display: block !important;
}
.show-for-sr,
.show-on-focus {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  -webkit-clip-path: inset(50%);
  clip-path: inset(50%);
  border: 0;
}
.icon-button {
  position: relative;
  width: 42px;
  display: inline-block;
  cursor: pointer;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border: none;
  background: transparent;
  -webkit-tap-highlight-color: transparent;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}
.icon-button:after {
  content: "";
  display: block;
  padding-bottom: 100%;
}
.icon-button span {
  display: block;
}
.icon-button .icon-box {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  transition: none;
}
.icon-button.lines-button {
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}
.icon-button.lines-button:active {
  transition: 0;
  background: rgba(0, 0, 0, 0.1);
}
.lines {
  width: 100%;
  height: 3px;
  background: rgb(5, 242, 175);
  border-radius: 0;
  transition: none;
  display: inline-block;
  margin-top: calc(50% - 1.5px);
  /*create the upper and lower lines as pseudo-elements of the middle line*/
}
.lines:before, .lines:after {
  width: 100%;
  height: 3px;
  background: rgb(5, 242, 175);
  border-radius: 0;
  transition: none;
  position: absolute;
  left: 0;
  content: "";
  transform-origin: 1.5px center;
}
.lines:before {
  bottom: calc(10% - 1.5px);
}
.lines:after {
  top: calc(10% - 1.5px);
}
.lines-button.x.close .lines {
  /*hide the middle line*/
  background: transparent;
  /*overlay the lines by setting both their top values to 0*/
}
.lines-button.x.close .lines:before {
  transform: rotate3d(0, 0, 1, -45deg) scale3d(1.3, 1, 1);
}
.lines-button.x.close .lines:after {
  transform: rotate3d(0, 0, 1, 45deg) scale3d(1.3, 1, 1);
}
#anibutton-burger {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border-radius: 0;
  border: 0;
  background: 0 0;
  line-height: 1;
  margin-left: 0;
  padding: 3px 0 3px 0.5em;
  cursor: pointer;
  font-weight: 700;
  color: #777;
  display: flex;
  align-items: center;
  font-size: 20px;
}
#anibutton-burger::after {
  display: block;
  content: "";
  clear: both;
}
#anibutton-burger .lines {
  width: 100%;
  height: 3px;
  background: rgb(5, 242, 175);
  border-radius: 0;
  transition: none;
}
#anibutton-burger .lines:before {
  bottom: calc(25% - 1.5px);
}
#anibutton-burger .lines:after {
  top: calc(25% - 1.5px);
}
#anibutton-burger .button-txt {
  padding: 0 0.2em;
  vertical-align: text-top;
  transition: 0.3s;
}
#anibutton-burger:hover, #anibutton-burger:focus {
  color: rgb(5, 242, 175);
}
#anibutton-burger:hover .lines, #anibutton-burger:focus .lines {
  background: rgb(5, 242, 175);
}
#anibutton-burger:hover .lines:before, #anibutton-burger:hover .lines:after, #anibutton-burger:focus .lines:before, #anibutton-burger:focus .lines:after {
  background: rgb(5, 242, 175);
}
#anibutton-burger:hover .button-txt, #anibutton-burger:focus .button-txt {
  color: rgb(5, 242, 175);
}
#offCanvas {
  background: #fff;
}
#burgermenu-wrapper {
  padding: 1em 1rem 1rem 1.5rem;
}
#burgermenu-wrapper #mainmenu a span,
#burgermenu-wrapper #lang-menu a span {
  background-image: linear-gradient(to right, #E94C2C 0%, #E94C2C 100%);
}
#burgermenu-wrapper #mainmenu a.active span,
#burgermenu-wrapper #lang-menu a.active span {
  background-image: linear-gradient(to right, #E94C2C 0%, #E94C2C 100%), linear-gradient(to right, #E94C2C 0%, #E94C2C 100%);
}
#burgermenu-wrapper #mainmenu a:hover, #burgermenu-wrapper #mainmenu a:active, #burgermenu-wrapper #mainmenu a:focus,
#burgermenu-wrapper #lang-menu a:hover,
#burgermenu-wrapper #lang-menu a:active,
#burgermenu-wrapper #lang-menu a:focus {
  color: rgb(151, 4, 191);
  -webkit-text-decoration-color: rgb(151, 4, 191);
          text-decoration-color: rgb(151, 4, 191);
}
#burgermenu-wrapper #mainmenu a.active,
#burgermenu-wrapper #lang-menu a.active {
  color: rgb(151, 4, 191);
  -webkit-text-decoration-color: rgb(151, 4, 191);
          text-decoration-color: rgb(151, 4, 191);
}
#burgermenu-wrapper #mainmenu {
  display: block;
}
#burgermenu-wrapper #mainmenu ul li {
  display: block;
  margin-bottom: 0.9em;
  padding: 0;
}
#burgermenu-wrapper #lang-menu {
  margin-top: 2em;
  justify-content: flex-end;
}
#burgermenu-wrapper #lang-menu ul {
  justify-content: flex-end;
}
#burgermenu-wrapper #lang-menu .translation-notice-box {
  display: none !important;
}
.burger-close-button {
  padding-bottom: 2em;
}
#anibutton-burger-close {
  padding: 0.5em 0;
}
#burgermenu-wrapper .burger-close-button #anibutton-burger-close {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: 0 0;
  border: 0;
  line-height: 1;
  width: 100%;
  text-align: right;
}
#burgermenu-wrapper .burger-close-button #anibutton-burger-close .icon-button {
  display: block;
  float: right;
  width: 26px;
}
#burgermenu-wrapper .burger-close-button #anibutton-burger-close .icon-button .lines:before, #burgermenu-wrapper .burger-close-button #anibutton-burger-close .icon-button .lines:after {
  background: rgb(151, 4, 191);
  transition: none;
}
#offCanvas {
  background: rgb(5, 242, 175);
  color: rgb(151, 4, 191);
}
#mainmenu {
  list-style: none;
  margin: 0;
  padding: 0;
  margin-bottom: 1rem;
  font-size: 2rem;
  line-height: 3.5rem;
  text-align: center;
}
#mainmenu section {
  margin-bottom: 2em;
}
#mainmenu li ol {
  margin-bottom: 1rem;
}
#mainmenu.footer-service-nav {
  margin-bottom: 4rem;
}
#mainmenu .burger-service-nav {
  line-height: 2.5rem;
}
#mainmenu .burger-service-nav ol {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
#mainmenu .burger-service-nav ol li {
  display: flex;
  width: 50%;
  margin-bottom: 0.5em;
}
#mainmenu .burger-service-nav ol li img {
  margin-right: 0.5em;
}
#mainmenu .active {
  color: rgb(5, 242, 175);
}
.container.container_header {
  padding-left: 0rem;
  padding-right: 0rem;
}
@media screen and (max-width: 1280px) {
  body {
    --page-padding: 20px;
  }
}
@media screen and (min-width: 890px) and (max-width: 1280px) {
  .mainnav_logo {
    padding: 1.5rem 0 0.5rem;
  }

  .page_footer .footer_logo {
    padding-top: 3rem;
    padding-bottom: 3rem;
  }
}
@media screen and (max-width: 889px) {
  html {
    font-size: 14px;
  }

  .mainnav-box,
.service-nav ol {
    display: none;
  }

  .service-nav {
    justify-content: end;
  }

  .right_nav {
    width: 20%;
    min-width: 50px;
  }

  .mainnav_logo {
    padding: 0.8rem 0 0.8rem;
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
  }
  .mainnav_logo .logo-link {
    flex-grow: 1;
  }
}
@media screen and (min-width: 890px) {
  #anibutton-burger {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  body {
    --page-padding: 10px;
  }

  .page_footer .container_footer {
    padding-top: 5rem;
  }

  article#content {
    padding-top: 1.2rem;
    padding-bottom: 2rem;
  }

  .type-homepage article#content .cover {
    display: flex;
    flex-direction: column;
  }
  .type-homepage article#content .cover > h1 {
    order: 1;
  }
  .type-homepage article#content .cover > h2.justified:not(.bwt-img) {
    order: 2;
    margin-top: 0.5em;
  }
  .type-homepage article#content .cover > .content-2024 {
    order: 3;
  }
  .type-homepage article#content .cover > h2.justified.bwt-img {
    order: 4;
    letter-spacing: normal;
  }
  .type-homepage article#content .cover > img.cover1 {
    order: 5;
  }
  .type-homepage article#content .cover > img.cover2 {
    order: 6;
  }
  .type-homepage article#content .raster-hr {
    border: 0;
    position: relative;
    overflow: visible;
    width: 100%;
    height: 45px;
    background-repeat: repeat-x;
    transform: rotate(180deg);
  }
  .type-homepage article#content .content-absatz h2 {
    margin-top: 0;
  }
}
@media screen and (max-width: 500px) {
  h2 {
    font-size: 2.7rem;
  }
}
@media screen and (max-width: 450px) {
  html {
    font-size: 14px;
  }

  article#content {
    padding-top: 1.2rem;
    padding-bottom: 2rem;
  }

  .type-homepage article#content > h1 {
    font-size: 1.7rem;
  }
  .type-homepage article#content > h2.justified.bwt-img {
    font-size: 1.7rem;
    letter-spacing: normal;
  }
  .type-homepage article#content > h2.justified:not(.bwt-img) {
    font-size: 1.7rem;
    margin-top: 0.5em;
  }
}
.justified {
  text-align: center;
}
@media screen and (max-width: 400px) {
  body {
    --page-padding: 5px;
  }
}
@media print {
  .page_footer,
.right_nav,
.page-teaser.img-teaser {
    display: none !important;
  }

  .block-infobox {
    color: black;
    background: none;
    border: 2px solid #E94C2C;
  }
}
.sr-only{
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}
.mx-auto{
  margin-left: auto;
  margin-right: auto;
}
.block{
  display: block;
}
.contents{
  display: contents;
}
.hidden{
  display: none;
}
.resize{
  resize: both;
}
.filter{
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}
/** import your custom utilities here **/