@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes polygon {
  0% {
    clip-path: polygon(0 20%, 30px 50px, 100% 0, 95% 49%, 100% 100%, 23% 99%, 0 95%, 30px 42%);
  }
}
/******** LANDSCAPE **********/
/******** PORTRAIT **********/
.menu-skip-links ul {
  position: absolute;
  left: 0;
  top: 0;
  padding: 0;
  margin: 0;
  list-style: none;
}

.menu {
  display: flex;
  justify-content: flex-end;
  gap: 1rem;
}
.menu #accessibility-button {
  cursor: url("/assets/img/icons/clicker.png"), auto;
  align-self: center;
  height: 50px;
  gap: 10px;
}
@media screen and (min-width: 1200px) {
  .menu #accessibility-button {
    display: flex;
  }
}
.menu #accessibility-button .label {
  align-self: center;
  display: none;
}
@media screen and (min-width: 1200px) {
  .menu #accessibility-button .label {
    display: block;
  }
}
.menu #accessibility-button img {
  height: 100%;
  object-fit: contain;
}

#hamburger {
  top: 0;
  z-index: 1;
  padding-right: 1rem;
}
#hamburger.open .icon-wrapper > label span {
  text-underline-offset: 4px;
  text-decoration-thickness: 0.5px;
}
#hamburger.open .icon-wrapper .nav-icon span:nth-child(1) {
  transform: rotate(45deg);
  top: 20px;
}
#hamburger.open .icon-wrapper .nav-icon span:nth-child(2) {
  opacity: 0;
}
#hamburger.open .icon-wrapper .nav-icon span:nth-child(3) {
  transform: rotate(-45deg);
  top: 20px;
}

.icon-wrapper {
  position: relative;
  right: 0;
  align-content: center;
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .icon-wrapper {
    top: 0;
    display: flex;
    gap: 1rem;
    justify-content: center;
  }
}
@media screen and (min-width: 1200px) {
  .icon-wrapper {
    z-index: 2;
  }
}
.icon-wrapper > label {
  cursor: url("/assets/img/icons/clicker.png"), auto;
  align-self: center;
  white-space: nowrap;
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .icon-wrapper > label {
    position: relative;
    top: 0;
  }
}
.icon-wrapper > label span {
  right: 0;
  transition: all 0.5s ease-in-out;
}
.icon-wrapper .nav-icon {
  width: 55px;
  height: 50px;
  position: relative;
  cursor: url("/assets/img/icons/clicker.png"), auto;
}
.icon-wrapper .nav-icon span {
  background-color: var(--color-text);
  position: absolute;
  transition: 0.3s cubic-bezier(0.8, 0.5, 0.2, 1.4);
  width: 100%;
  height: 5px;
  transition-duration: 500ms;
}
.icon-wrapper .nav-icon span:nth-child(1) {
  top: 8px;
  left: 0px;
}
.icon-wrapper .nav-icon span:nth-child(2) {
  top: 22px;
  left: 0px;
  opacity: 1;
}
.icon-wrapper .nav-icon span:nth-child(3) {
  top: 36px;
  left: 0px;
}
.icon-wrapper .nav-icon:not(.open):hover span:nth-child(1) {
  transform: translateY(-4px);
}
.icon-wrapper .nav-icon:not(.open):hover span:nth-child(3) {
  transform: translateY(4px);
}

#blocker {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  opacity: 0.6;
}
#blocker.open {
  display: block;
}

#toggle-menu {
  position: absolute;
  right: 0;
  top: 0;
  height: 100vh;
  opacity: 0;
  overflow-y: auto;
  margin: auto;
  transform: translate(100vw);
}
#toggle-menu .icon-wrapper {
  position: absolute;
  top: 5rem;
  right: 1rem;
}
#toggle-menu .icon-wrapper > label {
  position: absolute;
  top: -2rem;
  right: 0;
}
#toggle-menu .icon-wrapper > label span {
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 0.5px;
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  #toggle-menu .icon-wrapper {
    top: 2rem;
  }
}
@media screen and (min-width: 1200px) {
  #toggle-menu .icon-wrapper {
    display: none;
  }
}
#toggle-menu > div {
  clip-path: polygon(0 23%, 7% 3%, 100% 0, 94% 49%, 100% 100%, 6% 99%, 0 85%, 6% 42%);
  transform: translate(75%, -100%) scale(0);
  transition: all 0.5s cubic-bezier(0.1, 0.1, 0.1, 1.05);
  opacity: 0;
  display: grid;
  padding: 8rem 2rem 8rem;
}
@media screen and (min-width: 1200px) {
  #toggle-menu > div {
    clip-path: polygon(0 23%, 7% 3%, 100% 0, 96% 49%, 100% 100%, 6% 99%, 0 85%, 6% 42%);
  }
}
#toggle-menu > div.open {
  clip-path: polygon(0 23%, 7% 3%, 100% 0, 96% 49%, 100% 100%, 6% 99%, 0 85%, 6% 42%);
  transform: translate(0) scale(1);
  opacity: 1;
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  #toggle-menu > div {
    padding: 8rem 5rem;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  #toggle-menu > div {
    padding: 8rem 5rem;
  }
}
#toggle-menu .title {
  padding-bottom: 1rem;
}
#toggle-menu .main-menu-item {
  padding-bottom: 1rem;
}
#toggle-menu .main-menu-item > a {
  font-size: clamp(1.6rem, 2.5vw, 2rem);
  hyphens: none;
}
#toggle-menu .sub-menu {
  padding: 2rem;
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  #toggle-menu .sub-menu {
    padding: 1rem 2rem 2rem 2rem;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  #toggle-menu .sub-menu {
    padding: 1rem 2rem 2rem 2rem;
  }
}
#toggle-menu a {
  position: relative;
  text-decoration: none;
  padding-left: 0;
}
#toggle-menu a:not(.external)::before {
  width: 1.6rem;
  height: 0.5rem;
  border-bottom: unset;
  content: "";
  display: inline-block;
  background: url("/assets/img/icons/arrow_right.svg") no-repeat center center;
  background-size: contain;
  vertical-align: middle;
}
#toggle-menu a.external::after {
  width: 1rem;
  height: 0.8rem;
  content: "";
  display: inline-block;
  background: url("/assets/img/icons/arrow_diagonal.svg") no-repeat center center;
  background-size: auto;
  background-size: contain;
  vertical-align: middle;
}
#toggle-menu a:hover {
  color: var(--color-hover);
  transition: all 0.3s ease-in-out;
}
#toggle-menu a::after {
  background-color: unset;
}
#toggle-menu a::before {
  left: -2rem;
}

#hamburger.open #toggle-menu {
  opacity: 1;
  transform: translate(0);
}
#hamburger.open #toggle-menu > div {
  opacity: 1;
  background-color: var(--color-yellow);
  transform: translate(0) scale(1);
}

/************** LANGUAGE SWITCHER **************/
.languages {
  display: none;
}
.languages .active {
  display: none;
}

.modal {
  clip-path: polygon(0 23%, 7% 3%, 100% 0, 94% 49%, 100% 100%, 6% 99%, 0 85%, 6% 42%);
  transform: translate(75%, -100%) scale(0);
  transition: all 0.5s cubic-bezier(0.1, 0.1, 0.1, 1.05);
  opacity: 0;
  position: absolute;
  z-index: 10;
  left: 0;
  top: 0;
  width: 100%;
  height: 100vh;
  overflow: auto;
  background-color: black;
}
@media screen and (min-width: 1200px) {
  .modal {
    clip-path: polygon(0 23%, 7% 3%, 100% 0, 96% 49%, 100% 100%, 6% 99%, 0 85%, 6% 42%);
  }
}
.modal.open {
  clip-path: polygon(0 23%, 7% 3%, 100% 0, 96% 49%, 100% 100%, 6% 99%, 0 85%, 6% 42%);
  transform: translate(0) scale(1);
  opacity: 1;
}
.modal.open {
  display: block;
}

.modal-content {
  margin: 4rem auto;
  padding: 1rem;
  width: 80%;
  display: grid;
  gap: 2rem;
  color: white;
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  .modal-content {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .modal-content {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (min-width: 1200px) {
  .modal-content {
    width: 70%;
    margin: 6rem auto;
  }
}
.modal-content a {
  color: white;
}
.modal-content h3 {
  font-family: var(--font-text);
  padding-bottom: 1rem;
}
.modal-content section > div {
  display: flex;
  gap: 1rem;
  padding-bottom: 1rem;
}
@media screen and (min-width: 576px) {
  .modal-content section > div {
    gap: 2rem;
  }
}
.modal-content .switch {
  position: relative;
  display: inline-block;
  width: 60px;
  height: 34px;
}
.modal-content .switch input {
  opacity: 0;
  width: 0;
  height: 0;
}
.modal-content .slider {
  position: absolute;
  cursor: url("/assets/img/icons/clicker.png"), auto;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: white;
  -webkit-transition: 0.4s;
  transition: 0.4s;
  border-radius: 34px;
}
.modal-content .slider::before {
  position: absolute;
  content: "";
  height: 26px;
  width: 26px;
  left: 4px;
  bottom: 4px;
  background-color: black;
  background-image: url("/assets/img/icons/off.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 60%;
  -webkit-transition: 0.4s;
  transition: 0.4s;
  border-radius: 50%;
}
.modal-content input:checked + .slider::before {
  background-image: url("/assets/img/icons/on.svg");
  -webkit-transform: translateX(26px);
  -ms-transform: translateX(26px);
  transform: translateX(26px);
}
.close {
  position: absolute;
  width: 60px;
  height: 60px;
  right: 1rem;
  top: 2rem;
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .close {
    right: 3rem;
  }
}
.close span {
  background-color: white;
  position: relative;
  height: 5px;
  display: block;
}
.close span:nth-child(1) {
  transform: rotate(45deg);
  top: 12px;
}
.close span:nth-child(2) {
  transform: rotate(-45deg);
  top: 6px;
}

.close:hover,
.close:focus {
  cursor: url("/assets/img/icons/clicker.png"), auto;
}

html .contrast.pink main, html .contrast.blue main, html .contrast.dark-blue main, html .contrast.green main, html .contrast.yellow main, html .contrast.mint main {
  background-color: black !important;
}
html .contrast .pill span {
  background-color: black !important;
  color: white;
  font-family: var(--font-bold);
  padding: 0 0.5rem;
}
html .contrast main .section-title span {
  background-color: black !important;
  color: white;
}
html .contrast header #page-title span {
  background-color: black !important;
  color: white;
}
html .contrast header .logo .circle {
  fill: black;
}
html .contrast footer {
  background-color: unset;
}
html .low-stimulus img:not(.functional) {
  display: none;
}

.accessibility-links img {
  height: 50px;
}

@font-face {
  font-family: "Regular";
  src: url("../fonts/Lexend-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: "Bold";
  src: url("../fonts/Lexend-Bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: "Light";
  src: url("../fonts/Lexend-Light.woff2") format("woff2");
  font-weight: 300;
  font-style: normal;
}
@font-face {
  font-family: "ExtraLight";
  src: url("../fonts/Lexend-ExtraLight.woff2") format("woff2");
  font-weight: 200;
  font-style: normal;
}
@font-face {
  font-family: "Dyslexic";
  src: url("../fonts/OpenDyslexic-Regular.woff2") format("woff2"), url("../fonts/OpenDyslexic-Regular.otf") format("otf");
  font-weight: 900;
  font-style: normal;
}
@font-face {
  font-family: "Bourrasque";
  src: url("../fonts/Bourrasque-45Ouest.woff2") format("woff2"), url("../fonts/Bourrasque-45Ouest.otf") format("otf");
  font-weight: 700;
  font-style: normal;
}
:root {
  --color-text: #000;
  --color-hover: #000;
  --color-yellow: #fff054;
  --color-pink: #f0b0ff;
  --color-pink-trans: rgb(205, 149, 209, 0.6);
  --color-green: #01a676;
  --color-green-trans: #01a677bc;
  --color-orange: #f56600;
  --color-blue: #a0c8ec;
  --color-blue-trans: #a0c8ecbd;
  --color-mint: #7fd0d7;
  --color-dark-blue: #107cec;
  --color-dark-blue-trans: #107aecb6;
  --color-hover: #cd95d1;
  --font-text: "Light", serif;
  --font-dyslexic: "Dyslexic", serif;
  --font-bold: "Regular", serif;
  --font-bolder: "Bold", serif;
  --font-deco: "Bourrasque", serif;
  --font-italic: "Italic", serif;
  --font-size: clamp(1.2rem, 2vw, 1.4rem);
  --header-height: 6rem;
  --max-screen-width: 1800px;
  --max-screen-width-small: 1300px;
  --max-text-width: 900px;
  --field-height: 40px;
}

*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/************** GENERAL STYLING **************/
html,
body {
  overflow-x: hidden;
  font-size: 16px;
}

body {
  font-family: var(--font-text);
  color: var(--color-text);
  scroll-behavior: smooth;
  font-size: var(--font-size);
  cursor: url("/assets/img/icons/cursor.png") 4 4, auto;
}
body.block {
  overflow: hidden;
}
body.dyslexic {
  font-family: var(--font-dyslexic);
}
body > * {
  hyphens: auto;
}
@media screen and (min-width: 360px) {
  body > * {
    hyphens: none;
  }
}

h1,
h2,
h3 {
  font-family: var(--font-bold);
  letter-spacing: 0.5px;
}

h1 {
  font-size: clamp(1.8rem, 3vw, 2rem);
}

h2 {
  font-size: clamp(1.5rem, 2vw, 1.8rem);
  overflow-wrap: anywhere;
  hyphens: auto;
}
@media screen and (min-width: 576px) {
  h2 {
    hyphens: none;
  }
}

h3 {
  font-size: clamp(1.3rem, 2vw, 1.5rem);
}

a {
  text-decoration: none;
  color: var(--color-text);
  transition: all 0.5s ease-in-out;
  cursor: url("/assets/img/icons/clicker.png"), auto;
}
a:hover {
  transition: all 0.3s ease-in-out;
}

.deco-font {
  font-family: var(--font-deco);
}

img {
  max-width: 100%;
}
img:empty::before {
  content: "Fehler beim Laden des Bildes.";
  color: var(--color-orange);
}

figure {
  padding: 2rem 0;
}
figure iframe {
  width: 100%;
  aspect-ratio: 3/2;
  max-width: 700px;
}
figure figcaption {
  max-width: 700px;
  font-size: clamp(1rem, 1vw, 1.2rem);
}

summary {
  list-style: none;
  cursor: url("/assets/img/icons/clicker.png"), auto;
  display: flex;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}
summary span {
  border-top: 1px solid;
  border-bottom: 1px solid;
}
summary img {
  height: 100%;
  height: 1rem;
  align-self: center;
  padding-left: 1rem;
}
summary::-webkit-details-marker {
  display: none;
}

code {
  font-family: var(--font-deco);
  padding-right: 0.5rem;
  white-space: nowrap;
}

strong,
.bold {
  font-family: var(--font-bold);
  letter-spacing: 0.5px;
}

button {
  background: none;
  border: none;
  cursor: url("/assets/img/icons/clicker.png"), auto;
  font-size: var(--font-size);
  font-family: var(--font-text);
}

.super-tiny-font {
  font-size: clamp(0.9rem, 2vw, 1rem);
}

.tiny-font {
  font-size: clamp(1rem, 1vw, 1.2rem);
}

.small-font {
  font-size: clamp(1rem, 1.3vw, 1.3rem);
}

.big-font {
  font-size: clamp(1.3rem, 2vw, 2rem);
}

.sentinel {
  height: 1px;
}

.pill span {
  background-color: var(--color-yellow);
}
.pill:not(:last-of-type)::after {
  content: " | ";
}

.categories label:not(:last-of-type) > span::after {
  content: " | ";
}

.more {
  font-family: var(--font-bold);
  letter-spacing: 0.5px;
  padding-top: 0.5rem;
}
.more.right {
  text-align: right;
}
.more a,
.more span {
  position: relative;
  text-decoration: none;
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 0.5px;
}
.more a:not(.external)::before,
.more span:not(.external)::before {
  width: 1.6rem;
  height: 0.5rem;
  border-bottom: unset;
  content: "";
  display: inline-block;
  background: url("/assets/img/icons/arrow_right.svg") no-repeat center center;
  background-size: contain;
  vertical-align: middle;
}
.more a.external::after,
.more span.external::after {
  width: 1rem;
  height: 0.8rem;
  content: "";
  display: inline-block;
  background: url("/assets/img/icons/arrow_diagonal.svg") no-repeat center center;
  background-size: auto;
  background-size: contain;
  vertical-align: middle;
}
.more a:hover,
.more span:hover {
  color: var(--color-hover);
  transition: all 0.3s ease-in-out;
}

.red {
  color: var(--color-orange);
}

/************** HEADER **************/
header {
  position: fixed;
  height: var(--header-height);
  width: 100vw;
  display: grid;
  justify-content: space-around;
  align-items: center;
  grid-template-columns: repeat(2, 1fr);
  z-index: 30;
  box-shadow: 0 0px 20px 2px var(--color-pink-trans);
  background-color: white;
}
@media screen and (min-width: 576px) {
  header {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    justify-content: space-around;
    gap: 1rem;
  }
}
header.bg {
  background-color: white;
}
header #page-title {
  display: none;
  text-align: center;
}
@media screen and (min-width: 576px) {
  header #page-title {
    display: block;
  }
}
header #page-title span {
  background-color: var(--color-pink);
  transition: opacity 0.5s ease-in-out;
}
header .logo {
  padding: 1rem 0 0 1rem;
  display: flex;
  align-items: center;
  font-weight: 600;
  transition: 0.3s ease-in-out;
}
header .logo .circle {
  width: 70px !important;
  fill: var(--color-yellow);
}
header .logo .label {
  width: 100%;
  max-width: 250px;
}

/************** CONTENT **************/
main {
  min-height: 100vh;
  margin-top: var(--header-height);
  padding: 2rem;
}
main .text-block a {
  text-decoration: underline;
  text-underline-offset: 4px;
}
main .text-block li {
  padding-left: 1.7rem;
  position: relative;
  list-style: none;
}
main .text-block li:before {
  content: "";
  background-image: url(/assets/img/kreis.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
  width: 17px;
  height: 17px;
  left: 0;
  top: 0.9rem;
}
main .text-block li p {
  padding: 0.5rem 0;
}
main .text-block p {
  padding-top: 1rem;
}
@media screen and (min-width: 1200px) {
  main .text-block p {
    padding-top: 1.5rem;
  }
}
main .content {
  margin: auto;
}
main .content a:not([href^="mailto:"], figure a) {
  position: relative;
  text-decoration: none;
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 0.5px;
}
main .content a:not([href^="mailto:"], figure a):not(.external)::before {
  width: 1.6rem;
  height: 0.5rem;
  border-bottom: unset;
  content: "";
  display: inline-block;
  background: url("/assets/img/icons/arrow_right.svg") no-repeat center center;
  background-size: contain;
  vertical-align: middle;
}
main .content a:not([href^="mailto:"], figure a).external::after {
  width: 1rem;
  height: 0.8rem;
  content: "";
  display: inline-block;
  background: url("/assets/img/icons/arrow_diagonal.svg") no-repeat center center;
  background-size: auto;
  background-size: contain;
  vertical-align: middle;
}
main .content a:not([href^="mailto:"], figure a):hover {
  color: var(--color-hover);
  transition: all 0.3s ease-in-out;
}
main .content a[href^="mailto:"] {
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 0.5px;
}
main .wide-content {
  max-width: 1600px;
  margin: auto;
}
main section {
  padding-bottom: 4rem;
  border-bottom: 1px solid;
}
main section#news-app .filter-form {
  padding-bottom: 2rem;
}
@media screen and (min-width: 576px) {
  main section#news-app .filter-form {
    gap: 3rem;
  }
}
main .section-title,
main .text-block h2 {
  text-align: center;
  padding: 4rem 2rem;
}
main .section-title span,
main .text-block h2 span {
  background-color: var(--color-pink);
}

.pink main,
.pink .nanogallery_viewertheme_light_my_nanogallery .nGY2Viewer {
  background: var(--color-pink) !important;
}
.pink .nanogallery_viewertheme_light_my_nanogallery .nGY2Viewer .toolbar .label .description {
  background-color: var(--color-pink-trans);
}
.pink #nanogallery2 .image .caption {
  background-color: var(--color-pink-trans);
}

.blue main,
.blue .nanogallery_viewertheme_light_my_nanogallery .nGY2Viewer {
  background: var(--color-blue) !important;
}
.blue .nanogallery_viewertheme_light_my_nanogallery .nGY2Viewer .toolbar .label .description {
  background-color: var(--color-blue-trans);
}
.blue #nanogallery2 .image .caption {
  background-color: var(--color-blue-trans);
}

.dark-blue main,
.dark-blue .nanogallery_viewertheme_light_my_nanogallery .nGY2Viewer {
  background: var(--color-dark-blue) !important;
}
.dark-blue .nanogallery_viewertheme_light_my_nanogallery .nGY2Viewer .toolbar .label .description {
  background-color: var(--color-dark-blue-trans);
  color: white !important;
}
.dark-blue #nanogallery2 .image .caption {
  background-color: var(--color-dark-blue-trans);
  color: white;
}

.green main,
.green .nanogallery_viewertheme_light_my_nanogallery .nGY2Viewer {
  background: var(--color-green) !important;
}
.green .nanogallery_viewertheme_light_my_nanogallery .nGY2Viewer .toolbar .label .description {
  background-color: var(--color-green-trans);
  color: white !important;
}
.green #nanogallery2 .image .caption {
  background-color: var(--color-green-trans);
  color: white;
}

.yellow main,
.yellow .nanogallery_viewertheme_light_my_nanogallery .nGY2Viewer {
  background: var(--color-yellow) !important;
}

.mint main {
  background: var(--color-mint) !important;
}

#btt-button {
  background-repeat: no-repeat;
  background-size: contain;
  opacity: 0;
  position: fixed;
  z-index: 20;
  cursor: url("/assets/img/icons/clicker.png"), auto;
  transition: all 0.2s ease-in-out;
  font-size: 2rem;
  bottom: 3rem;
  right: 2rem;
  background-image: url("/assets/img/icons/arrow_top.svg");
  height: 60px;
  width: 60px;
}
#btt-button:hover {
  transform: scale(1.05);
  transition: all 0.5s ease-in-out;
}
@media screen and (min-width: 1200px) {
  #btt-button {
    right: 6rem;
  }
}

/************** TEMPLATE SPECIFIC **************/
.page-template-home {
  animation: fadeIn 1s ease;
}
.page-template-home #home .content {
  max-width: var(--max-screen-width-small);
  margin: auto;
}
.page-template-home #home .content .illus {
  padding: 2rem 0 4rem;
  position: relative;
}
@media screen and (min-width: 1200px) {
  .page-template-home #home .content .illus {
    padding: 2rem 0;
  }
}
.page-template-home #home .content .illus img {
  height: 100%;
  max-width: 100%;
  object-fit: contain;
}
.page-template-home #home .content .illus .walker {
  position: absolute;
  bottom: -5%;
  right: -3rem;
  height: 70%;
}
@media screen and (min-width: 1200px) {
  .page-template-home #home .content .illus .walker {
    right: -4rem;
  }
}
@media screen and (min-width: 1400px) {
  .page-template-home #home .content .illus .walker {
    right: -15%;
    bottom: -10%;
  }
}
.page-template-home #home .content .text-block {
  max-width: var(--max-text-width);
  margin: auto;
}
@media screen and (min-width: 576px) {
  .page-template-home #home .content .text-block {
    padding-right: 3rem;
  }
}
.page-template-home #veranstaltungen h2 {
  text-align: left;
  padding: 2rem 0;
}
.page-template-home #veranstaltungen .event-list {
  margin: 0 auto 2rem;
}
.page-template-home #veranstaltungen .event {
  border-bottom: 1px solid;
  padding: 1rem 0;
  transition: all 0.5s ease-in-out;
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  .page-template-home #veranstaltungen .event a {
    display: flex;
    justify-content: space-between;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .page-template-home #veranstaltungen .event a {
    display: flex;
    justify-content: space-between;
  }
}
.page-template-home #veranstaltungen .event:hover {
  background-color: var(--color-yellow);
  transition: all 0.3s ease-in-out;
}
.page-template-home #veranstaltungen .event:first-of-type {
  border-top: 1px solid;
}
.page-template-home #veranstaltungen .event .more {
  align-self: flex-end;
}
.page-template-home #neuigkeiten {
  border-bottom: 1px solid;
}
.page-template-home .big-logo {
  text-align: center;
  margin: auto;
  max-width: 300px;
  display: grid;
  grid-template-columns: 30% 60%;
  font-size: clamp(1.5rem, 2.7vw, 2.7rem);
  white-space: nowrap;
}
.page-template-home .big-logo .circle svg {
  fill: var(--color-yellow);
  width: 150px;
}
.page-template-home .big-logo .label {
  position: relative;
  top: 1rem;
}
.page-template-home .big-logo .label > div:first-of-type {
  left: -3rem;
  position: relative;
}

.news-items {
  display: grid;
  max-width: 1600px;
  margin: 0 auto 2rem;
  gap: 2rem;
}
@media screen and (min-width: 576px) {
  .news-items {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .news-items {
    grid-template-columns: repeat(3, 1fr);
    gap: 3rem;
  }
}
.news-items .news-item {
  border-bottom: 1px solid;
  padding-bottom: 2rem;
  animation: fadeIn 0.5s ease-in-out;
}
.news-items .news-item a {
  display: grid;
  gap: 1rem;
}
.news-items .news-item .categories {
  line-height: 1.6;
}
.news-items .news-item .categories label {
  cursor: url("/assets/img/icons/clicker.png"), auto;
}
.news-items .news-item .categories input[type=radio] {
  opacity: 0;
  display: none;
}
.news-items .news-item .categories input[type=radio]:checked + span {
  background-color: var(--color-yellow);
}
@media screen and (min-width: 576px) {
  .news-items .news-item .info {
    min-height: 9rem;
  }
}
.news-items .news-item .image {
  padding-top: 1rem;
}
.news-items .news-item .image img {
  object-fit: cover;
  aspect-ratio: 3/2;
  width: 100%;
}

.detail-page-content {
  clip-path: polygon(0 23%, 2% 30px, 100% 0, 96% 49%, 100% 100%, 30px 99%, 0 95%, 3% 42%);
  background-color: white;
  position: relative;
  padding: 8rem 2rem 10rem;
  min-height: calc(100vh - var(--header-height));
  grid-template-columns: 100%;
  word-wrap: anywhere;
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  .detail-page-content {
    clip-path: polygon(0 23%, 15px 80px, 100% 0, 94% 49%, 100% 100%, 23% 99%, 0 95%, 2% 42%);
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .detail-page-content {
    clip-path: polygon(0 23%, 15px 80px, 100% 0, 94% 49%, 100% 100%, 23% 99%, 0 95%, 2% 42%);
  }
}
@media screen and (min-width: 1200px) {
  .detail-page-content {
    clip-path: polygon(0 23%, 40px 60px, 100% 0, 94% 49%, 100% 100%, 23% 100%, 0 calc(100% - 50px), 30px 42%);
  }
}
@media screen and (min-width: 576px) {
  .detail-page-content {
    padding: 10rem 2.5rem;
  }
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  .detail-page-content {
    gap: 1rem 2rem;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .detail-page-content {
    gap: 1rem 2rem;
  }
}
@media screen and (min-width: 1200px) {
  .detail-page-content {
    padding: 5rem 9vw 10rem;
  }
}
.detail-page-content p,
.detail-page-content .image {
  padding-top: 1rem;
}
.detail-page-content .nav-icon {
  position: absolute;
  right: 1rem;
  top: 1rem;
  display: flex;
  justify-content: center;
  align-items: end;
  cursor: url("/assets/img/icons/clicker.png"), auto;
}
.detail-page-content .nav-icon label {
  cursor: url("/assets/img/icons/clicker.png"), auto;
  padding-bottom: 5px;
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 0.5px;
  font-family: var(--font-bold);
  letter-spacing: 0.5px;
}
.detail-page-content .nav-icon div {
  width: 60px;
  height: 60px;
}
.detail-page-content .nav-icon div span {
  background-color: var(--color-text);
  transition: 0.3s cubic-bezier(0.8, 0.5, 0.2, 1.4);
  height: 5px;
  transition-duration: 500ms;
  position: relative;
  display: block;
}
.detail-page-content .nav-icon div span:nth-child(1) {
  transform: rotate(45deg);
  top: 25px;
}
.detail-page-content .nav-icon div span:nth-child(2) {
  transform: rotate(-45deg);
  top: 20px;
}
.detail-page-content a:not([href^="mailto:"], figure a, .search-results a) {
  position: relative;
  text-decoration: none;
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 0.5px;
}
.detail-page-content a:not([href^="mailto:"], figure a, .search-results a):not(.external)::before {
  width: 1.6rem;
  height: 0.5rem;
  border-bottom: unset;
  content: "";
  display: inline-block;
  background: url("/assets/img/icons/arrow_right.svg") no-repeat center center;
  background-size: contain;
  vertical-align: middle;
}
.detail-page-content a:not([href^="mailto:"], figure a, .search-results a).external::after {
  width: 1rem;
  height: 0.8rem;
  content: "";
  display: inline-block;
  background: url("/assets/img/icons/arrow_diagonal.svg") no-repeat center center;
  background-size: auto;
  background-size: contain;
  vertical-align: middle;
}
.detail-page-content a:not([href^="mailto:"], figure a, .search-results a):hover {
  color: var(--color-hover);
  transition: all 0.3s ease-in-out;
}
.detail-page-content a[href^="mailto:"] {
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 0.5px;
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .detail-page-content .image img {
    max-height: 350px;
    width: auto;
  }
}
@media screen and (min-width: 1200px) {
  .detail-page-content .image img {
    max-height: 500px;
  }
}
.detail-page-content .gallery {
  padding: 2rem 0;
}

.page-template-news-item {
  animation: fadeIn 1s ease;
}
.page-template-news-item main {
  padding: 1rem;
}
.page-template-news-item main .detail-page-content .news-content {
  display: grid;
  gap: 2rem;
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  .page-template-news-item main .detail-page-content .news-content {
    grid-template-columns: 55% 40%;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .page-template-news-item main .detail-page-content .news-content {
    grid-template-columns: 55% 40%;
  }
}

.page-template-event {
  animation: fadeIn 1s ease;
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  .page-template-event .detail-page-content {
    grid-template-columns: 65% 30%;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .page-template-event .detail-page-content {
    grid-template-columns: 65% 30%;
  }
}
@media screen and (min-width: 2000px) {
  .page-template-event .detail-page-content {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  .page-template-event .detail-page-content .infos {
    grid-area: 1/2/span 3;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .page-template-event .detail-page-content .infos {
    grid-area: 1/2/span 3;
  }
}

.page-template-project {
  animation: fadeIn 1s ease;
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  .page-template-project .detail-page-content {
    grid-template-columns: 65% 30%;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .page-template-project .detail-page-content {
    grid-template-columns: 65% 30%;
  }
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  .page-template-project .detail-page-content .title {
    grid-column: 1/3;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .page-template-project .detail-page-content .title {
    grid-column: 1/3;
  }
}
.page-template-event main,
.page-template-project main {
  padding: 1rem;
}
.page-template-event main .detail-page-content,
.page-template-project main .detail-page-content {
  display: grid;
  gap: 1rem;
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  .page-template-event main .detail-page-content,
  .page-template-project main .detail-page-content {
    gap: 2rem;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .page-template-event main .detail-page-content,
  .page-template-project main .detail-page-content {
    gap: 2rem;
  }
}
.page-template-event main .detail-page-content .infos,
.page-template-project main .detail-page-content .infos {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.page-template-event main .detail-page-content .infos p,
.page-template-project main .detail-page-content .infos p {
  padding: 0;
}
.page-template-event main .detail-page-content .infos .location a,
.page-template-event main .detail-page-content .infos .organizer a,
.page-template-project main .detail-page-content .infos .location a,
.page-template-project main .detail-page-content .infos .organizer a {
  display: block;
  margin-left: 0.5rem;
}
@media screen and (min-width: 1400px) {
  .page-template-event main .detail-page-content .infos .location a,
  .page-template-event main .detail-page-content .infos .organizer a,
  .page-template-project main .detail-page-content .infos .location a,
  .page-template-project main .detail-page-content .infos .organizer a {
    display: inline;
  }
}
.page-template-event main .detail-page-content .infos .more-dates > div,
.page-template-project main .detail-page-content .infos .more-dates > div {
  padding-bottom: 0.5rem;
}
@media screen and (min-width: 576px) {
  .page-template-event main .detail-page-content .text figure,
  .page-template-event main .detail-page-content .text img,
  .page-template-project main .detail-page-content .text figure,
  .page-template-project main .detail-page-content .text img {
    max-width: 350px;
  }
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  .page-template-event main .detail-page-content .gallery,
  .page-template-project main .detail-page-content .gallery {
    grid-column: 1/3;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .page-template-event main .detail-page-content .gallery,
  .page-template-project main .detail-page-content .gallery {
    grid-column: 1/3;
  }
}

.page-template-project main {
  padding: 1rem;
}

.main-content {
  max-width: var(--max-text-width);
  margin: auto;
  font-size: clamp(1.3rem, 2vw, 2rem);
}
.main-content a:not(a[href^="mailto:"], figure a) {
  position: relative;
  text-decoration: none;
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 0.5px;
}
.main-content a:not(a[href^="mailto:"], figure a):not(.external)::before {
  width: 1.6rem;
  height: 0.5rem;
  border-bottom: unset;
  content: "";
  display: inline-block;
  background: url("/assets/img/icons/arrow_right.svg") no-repeat center center;
  background-size: contain;
  vertical-align: middle;
}
.main-content a:not(a[href^="mailto:"], figure a).external::after {
  width: 1rem;
  height: 0.8rem;
  content: "";
  display: inline-block;
  background: url("/assets/img/icons/arrow_diagonal.svg") no-repeat center center;
  background-size: auto;
  background-size: contain;
  vertical-align: middle;
}
.main-content a:not(a[href^="mailto:"], figure a):hover {
  color: var(--color-hover);
  transition: all 0.3s ease-in-out;
}

.page-template-default .main-content {
  font-size: clamp(1.1rem, 1.5vw, 1.5rem);
}

.page-template-projects main section {
  min-height: auto;
  padding: 2rem 0;
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .page-template-projects main section {
    padding: 4rem 0 !important;
  }
}
.page-template-projects main section.list-intro h2 {
  text-align: center;
  padding: 4rem 2rem;
}
.page-template-projects main section.list-intro h2 span {
  background-color: var(--color-yellow);
}
.page-template-projects main h2 {
  max-width: 1600px;
  margin: auto;
}
.page-template-projects main .content {
  max-width: 1600px;
  display: grid;
  gap: 2rem;
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  .page-template-projects main .content {
    grid-template-columns: 60% 35%;
    gap: 5%;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .page-template-projects main .content {
    grid-template-columns: 60% 35%;
    gap: 5%;
  }
}
.page-template-projects main .content .more {
  padding-top: 2rem;
  font-family: var(--font-bold);
  letter-spacing: 0.5px;
}
.page-template-projects main .content .image img {
  object-fit: contain;
  aspect-ratio: 3/2;
  width: 100%;
}

[v-cloak] {
  display: none;
}

#events-app {
  max-width: var(--max-screen-width);
  margin: auto;
}
#events-app .calendar {
  padding-top: 2rem;
}
#events-app h3 {
  animation: fadeIn 0.5s linear;
  padding: 2rem 0;
  font-size: 2rem;
}
#events-app .day {
  animation: fadeIn 0.5s linear;
  display: grid;
}
#events-app .day:first-of-type {
  border-top: 1px solid;
}
#events-app .day .day-name {
  display: flex;
  flex-direction: column;
  font-size: 1.8rem;
  padding-top: 0.5rem;
}
@media screen and (min-width: 576px) {
  #events-app .day .day-name {
    text-align: center;
    padding: 1rem 0;
  }
}
@media screen and (min-width: 1200px) {
  #events-app .day .day-name {
    justify-content: center;
    padding: 0;
  }
}
#events-app .day .day-name .number {
  font-size: 3rem;
  font-family: var(--font-bold);
  letter-spacing: 0.5px;
}
#events-app .list .day {
  display: grid;
  border-bottom: 1px solid;
}
@media screen and (min-width: 576px) {
  #events-app .list .day {
    grid-template-columns: 15% calc(80% - 2rem);
    gap: 2rem;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  #events-app .list .day {
    grid-template-columns: 15% 85%;
    gap: 0;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  #events-app .list .day .info .title {
    grid-column: 1/3;
  }
}
#events-app .event {
  padding: 1rem 1rem 1rem 0;
  transition: all 0.6s ease-in-out;
  position: relative;
}
@media screen and (min-width: 576px) {
  #events-app .event {
    padding: 1rem;
  }
}
#events-app .event:hover {
  background-color: var(--color-yellow);
  transition: all 0.2s ease-in-out;
}
#events-app .event a {
  width: 100%;
}
#events-app .event a .time {
  margin-right: 0.5rem;
  display: block;
}
@media screen and (min-width: 576px) {
  #events-app .event a .time {
    display: inline;
  }
}
#events-app .event:not(:last-of-type) {
  border-bottom: 1px solid;
}
#events-app .weeks .day {
  border-left: 1px solid;
  border-top: 1px solid;
  border-right: 1px solid;
  hyphens: auto;
  transition: all 0.6s ease-in-out;
  display: block;
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  #events-app .weeks .day {
    border-right: 0;
    border-bottom: 1px solid;
  }
}
#events-app .weeks .day:last-of-type {
  border: 1px solid;
}
#events-app .weeks .day h2 {
  hyphens: auto !important;
}
#events-app .weeks .day-name {
  border-bottom: 1px solid;
  padding: 1rem;
  text-align: center;
}
@media screen and (min-width: 1200px) {
  #events-app .weeks .day-name {
    height: 6rem;
  }
}
#events-app .weeks .event-list {
  display: grid;
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  #events-app .weeks .event-list {
    grid-template-columns: repeat(7, 1fr);
  }
}
#events-app .weeks .event-list .events {
  aspect-ratio: 1/1;
}
#events-app .weeks .event-list .events .event {
  padding: 1rem;
  border-bottom: 1px solid;
  height: 100%;
}
#events-app .weeks .event-list .events .event a {
  display: grid;
}
#events-app .weeks .event-list .events .event:last-of-type {
  border-bottom: none;
}
#events-app .weeks .event-list .events .event .info {
  order: 1;
}
#events-app .weeks .event-list .events .event .title {
  order: 2;
}
#events-app .weeks .event-list .events .event .title h2 {
  font-family: var(--font-text);
  font-size: var(--font-size);
}
#events-app .weeks .event-list .events .event .pill,
#events-app .weeks .event-list .events .event .more,
#events-app .weeks .event-list .events .event .subtitle {
  display: none;
}

@media screen and (min-width: 1200px) {
  .event .more {
    display: none;
  }
}

.cancelled {
  color: var(--color-orange);
  font-family: var(--font-bold);
  letter-spacing: 0.5px;
}
.cancelled svg {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
}
.cancelled svg line {
  stroke: var(--color-orange);
}

.bubble {
  position: absolute;
  top: 0;
  right: 50%;
  height: 90px;
  width: 90px;
  font-size: 1.1rem;
  color: white;
  font-family: var(--font-deco);
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .bubble {
    top: 0;
    height: 100px;
    width: 100px;
    font-size: 1.3rem;
  }
}
.bubble > div {
  position: relative;
  height: 100%;
}
.bubble span {
  position: absolute;
  transform: rotate(-45deg) translate(-25%, 125%);
}
.bubble svg {
  fill: var(--color-pink);
  height: 100%;
}

.filter-form {
  display: grid;
  gap: 1rem;
  font-size: clamp(1.1rem, 1.5vw, 1.5rem);
  align-items: end;
}
@media screen and (min-width: 576px) {
  .filter-form {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .filter-form {
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem 5%;
  }
}
.filter-form .view {
  display: none;
}
.filter-form .view label {
  cursor: url("/assets/img/icons/clicker.png"), auto;
}
.filter-form .view input[type=radio] {
  opacity: 0;
  display: none;
}
.filter-form .view input[type=radio]:checked + span {
  background-color: var(--color-yellow);
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .filter-form .view {
    grid-column: 1/3;
    display: flex;
  }
}
@media screen and (min-width: 1200px) {
  .filter-form .view {
    grid-column: 1/2;
  }
}
.filter-form .view fieldset {
  padding-left: 0.5rem;
}
.filter-form .view label {
  cursor: url("/assets/img/icons/clicker.png"), auto;
  padding: 0;
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .filter-form label {
    padding: 1rem;
  }
}
.filter-form .wrapper {
  position: relative;
}
@media (hover: hover) {
  .filter-form .custom-select {
    display: block;
  }
}
@media (hover: hover) {
  .filter-form select:focus + .custom-select {
    display: none;
  }
}
.filter-form select {
  color: var(--color-text);
  outline: 0;
  border: 1px solid;
  box-shadow: none;
  padding: 0.5rem 1rem;
  cursor: url("/assets/img/icons/clicker.png"), auto;
  border-radius: 0;
  appearance: none; /* Removes the default arrow on some browsers */
  -moz-appearance: none;
  -webkit-appearance: none;
}
.filter-form select option {
  background-color: var(--color-pink);
  color: var(--color-text);
  font-family: var(--font-regular);
  font-size: var(--font-size);
  border-radius: none;
}
.filter-form select:focus {
  border: 5px solid red;
}
.filter-form summary::-webkit-details-marker {
  display: none;
}
.filter-form ::-webkit-datetime-edit {
  padding: 0 1rem;
}
.filter-form ::-webkit-datetime-edit-text,
.filter-form ::-webkit-datetime-edit-month-field,
.filter-form ::-webkit-datetime-edit-day-field,
.filter-form ::-webkit-datetime-edit-year-field {
  color: var(--form-grey);
  text-transform: uppercase;
  font-family: var(--font-regular) !important;
}

.field {
  width: 100%;
  border: 1px solid var(--color-text);
  background-color: white;
  outline: none;
  cursor: url("/assets/img/icons/clicker.png"), auto;
  padding: 10px;
}
.field.select {
  background: url("/assets/img/icons/arrow_down.svg") no-repeat right 12px center;
  background-size: 10px;
}
.field.subscribe {
  background-color: black;
  color: white;
  opacity: 1;
  margin-top: 1rem;
}
.field::placeholder {
  font-size: 1.1rem;
}

.text-search {
  justify-self: flex-end;
  align-self: end;
  text-align: right;
}
@media screen and (min-width: 576px) {
  .text-search {
    grid-column: 2/3;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .text-search {
    grid-column: 3/4;
    grid-row: 1/3;
  }
}
.text-search > div {
  display: flex;
  padding-top: 1rem;
}
.text-search svg {
  max-height: var(--field-height);
  margin: 0 0.5rem;
}

fieldset {
  border: none;
}

.custom-select {
  display: inline-block;
  max-width: 100%;
  top: 0;
  position: relative;
}
.custom-select .select-button {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.custom-select .select-button span {
  background-color: var(--color-yellow);
}
.custom-select .select-dropdown {
  position: absolute;
  width: calc(100% + 2px);
  top: calc(100% + 1px);
  left: -1px;
  list-style: none;
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.2);
  max-height: 400px;
  overflow-y: auto;
  z-index: 10;
  scrollbar-color: var(--color-pink) white;
}
.custom-select .select-dropdown::-webkit-scrollbar-track {
  background: transparent;
}
.custom-select .select-dropdown::-webkit-scrollbar-thumb {
  background: transparent;
}
.custom-select .select-dropdown .field {
  border-top: none;
}
.custom-select .select-dropdown.hidden {
  display: none;
}
.custom-select .select-dropdown li {
  list-style: none;
  /* Highlight the selected option */
}
.custom-select .select-dropdown li span {
  transition: all 0.2s ease-in-out;
}
.custom-select .select-dropdown li.selected span, .custom-select .select-dropdown li:hover span, .custom-select .select-dropdown li:focus span {
  background-color: var(--color-yellow);
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

#nanogallery2 {
  position: relative;
  padding-top: 2rem;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  #nanogallery2 {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  #nanogallery2 {
    grid-template-columns: repeat(4, 1fr);
  }
}
#nanogallery2 .image {
  position: relative;
}
#nanogallery2 .image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#nanogallery2 .image .caption {
  transition: opacity 0.3s ease-in-out;
  position: absolute;
  bottom: 1rem;
  font-family: var(--font-bold);
  letter-spacing: 0.5px;
  right: 1rem;
  left: 1rem;
  opacity: 0;
  padding: 0 0.3rem;
}
#nanogallery2 .image.no-caption .caption {
  display: none !important;
}
#nanogallery2 .image:hover .caption {
  opacity: 1;
}

.nGY2 .nGY2ViewerContent {
  clip-path: polygon(0 23%, 2% 3%, 100% 0, 98% 49%, 100% 100%, 6% 99%, 0 85%, 2% 42%);
  background: white !important;
}

.nGY2 .nGY2GThumbnailLabel {
  padding: 0 0 2rem;
}

.nGY2ViewerMedia {
  max-width: calc(100vw - 8rem) !important;
  max-height: calc(100vh - 8rem) !important;
  object-fit: contain;
}

.nGY2GThumbnailLabel {
  filter: none !important;
}

.nGY2Icon-ngy2_close2::before {
  content: "" !important;
  width: 54px;
  height: 54px;
  background-image: url("/assets/img/close.png");
  background-repeat: no-repeat;
  background-size: contain;
  display: block;
}

.nGY2Icon-ngy2_chevron_left3::before,
.nGY2Icon-ngy2_chevron_right3::before {
  content: "" !important;
  width: 40px;
  height: 54px;
  background-image: url("/assets/img/icons/arrow_left.svg");
  background-repeat: no-repeat;
  background-size: contain;
  display: block;
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .nGY2Icon-ngy2_chevron_left3::before,
  .nGY2Icon-ngy2_chevron_right3::before {
    width: 80px;
  }
}

.nGY2Icon-ngy2_chevron_left3::before {
  background-image: url("/assets/img/icons/arrow_left.svg");
}

.nGY2Icon-ngy2_chevron_right3::before {
  background-image: url("/assets/img/icons/arrow_right.svg");
  margin-right: 15px !important;
}

.nGY2 .nGY2ViewerAreaNext > i,
.nGY2 .nGY2ViewerAreaPrevious > i {
  background: unset !important;
}

.nGY2 .toolbarBackground {
  background: none !important;
}

.nGY2 .nGY2ViewerAreaNext,
.nGY2 .nGY2ViewerAreaPrevious {
  padding-left: 1rem;
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .nGY2 .nGY2ViewerAreaNext,
  .nGY2 .nGY2ViewerAreaPrevious {
    padding: 2rem;
  }
}

@media screen and (min-width: 1024px) and (orientation: landscape) {
  .nGY2 .nGY2ViewerAreaNext {
    right: 10%;
  }
}

@media screen and (min-width: 1024px) and (orientation: landscape) {
  .nGY2 .nGY2ViewerAreaPrevious {
    left: 10%;
  }
}

.nGY2 .toolbar .label {
  padding: 1rem 10px;
}
.nGY2 .toolbar .label .description {
  color: var(--color-text) !important;
}

.toolbarContainer {
  opacity: 1 !important;
  bottom: 7rem !important;
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  .toolbarContainer {
    bottom: 50px !important;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .toolbarContainer {
    bottom: 50px !important;
  }
}

.nGY2 .toolbarContainer {
  width: 80%;
  margin-right: auto;
  margin-left: auto;
}
.nGY2 .ngy2viewerToolAction {
  opacity: 1 !important;
}
.nGY2 .nGY2ViewerToolsTopRight {
  opacity: 1 !important;
}

.nGEvent.title {
  display: none;
}

.nanogallery_viewertheme_light_my_nanogallery .nGY2Viewer .toolbar .label .description {
  max-width: 500px;
  display: inline-block;
}

body > footer {
  padding: 0 1rem 1rem;
  background-color: var(--color-yellow);
}
body > footer > div {
  padding: 4rem 2rem 1rem;
  clip-path: polygon(0 23%, 2% 30px, 100% 0, 96% 49%, 100% 100%, 30px 99%, 0 95%, 3% 42%);
  background-color: white;
  position: relative;
  display: grid;
  gap: 1rem;
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  body > footer > div {
    clip-path: polygon(0 23%, 15px 80px, 100% 0, 94% 49%, 100% 100%, 23% 99%, 0 95%, 2% 42%);
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  body > footer > div {
    clip-path: polygon(0 23%, 15px 80px, 100% 0, 94% 49%, 100% 100%, 23% 99%, 0 95%, 2% 42%);
  }
}
@media screen and (min-width: 1200px) {
  body > footer > div {
    clip-path: polygon(0 23%, 40px 60px, 100% 0, 94% 49%, 100% 100%, 23% 100%, 0 calc(100% - 50px), 30px 42%);
  }
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  body > footer > div {
    padding: 5rem 4rem 1rem;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  body > footer > div {
    padding: 5rem 4rem 1rem;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
  }
}
@media screen and (min-width: 1200px) {
  body > footer > div {
    padding: 5rem 4rem;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 5%;
  }
}
body > footer > div > div {
  padding-bottom: 1rem;
}
body > footer > div h3 {
  font-size: clamp(1.5rem, 4vw, 1.8rem);
  font-family: var(--font-bold);
  letter-spacing: 0.5px;
}
body > footer > div p {
  padding-bottom: 1rem;
}
body > footer .field {
  max-width: 400px;
}
body > footer .newsletter h3 {
  padding-bottom: 1rem;
}
body > footer .newsletter form {
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  body > footer .newsletter form {
    grid-column: 1/3;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  body > footer .newsletter form {
    grid-column: 1/2;
  }
}
@media screen and (min-width: 1200px) {
  body > footer .newsletter form {
    grid-column: auto;
  }
}
body > footer .newsletter form .field {
  height: 60px;
  font-size: var(--font-size);
}
body > footer .newsletter form label {
  padding-top: 4px;
}
body > footer form > div {
  display: flex;
  padding-top: 1rem;
}
body > footer form svg {
  margin-left: 0.5rem;
}
body > footer .social a {
  height: 80px;
  width: 80px;
  background-image: url("/assets/img/kreis.svg");
  background-repeat: no-repeat;
  background-size: contain;
  display: inline-block;
}
body > footer .social a svg {
  height: 100%;
  width: 100%;
  fill: white;
}
body > footer .social a.insta svg {
  padding: 15%;
  margin-left: 3px;
}

div:where(.swal2-container) button:where(.swal2-styled):where(.swal2-confirm) {
  border-radius: 0 !important;
  background-color: black !important;
}

div:where(.swal2-container) div:where(.swal2-popup) {
  border-radius: 0 !important;
  font-family: var(--font-regular) !important;
}

@media screen and (min-width: 768px) and (orientation: portrait) {
  .legal-menu {
    grid-template-columns: repeat(2, 1fr);
    display: grid;
    justify-content: space-around;
    gap: 1rem;
    grid-column: 1/3;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .legal-menu {
    grid-template-columns: repeat(2, 1fr);
    display: grid;
    justify-content: space-around;
    gap: 1rem;
    grid-column: 1/3;
  }
}
@media screen and (min-width: 1200px) {
  .legal-menu {
    grid-column: 1/4;
  }
}
.legal-menu ul {
  display: flex;
  list-style: none;
  justify-content: flex-end;
}
.legal-menu ul li {
  padding: 1rem 0.5rem 0;
}

@media screen and (min-width: 768px) and (orientation: portrait) {
  .logos {
    grid-template-columns: repeat(2, 1fr);
    display: grid;
    justify-content: space-around;
    gap: 1rem;
    grid-column: 1/3;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .logos {
    grid-template-columns: repeat(2, 1fr);
    display: grid;
    justify-content: space-around;
    gap: 1rem;
    grid-column: 1/3;
  }
}
.logos > div {
  padding-top: 2rem;
}
.logos > div a {
  display: block;
}
.logos .kvo {
  padding-top: 2rem;
}

/****** CONTACT ********/
.page-template-contact main {
  min-height: auto;
  display: grid;
  gap: 1rem;
  max-width: var(--max-screen-width-small);
  margin: 8rem auto;
}
@media screen and (min-width: 768px) and (orientation: portrait) {
  .page-template-contact main {
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
  }
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .page-template-contact main {
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem;
  }
}
.page-template-contact main p {
  padding-bottom: 1rem;
}
.page-template-contact main .text-block {
  padding: 0;
}
.page-template-contact main .text-block p {
  padding-top: 0;
}
.page-template-contact main .intro {
  padding-bottom: 1rem;
}
.page-template-contact main .contact-form form {
  display: grid;
  gap: 1rem;
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .page-template-contact main .contact-form form {
    grid-template-columns: repeat(2, 1fr);
  }
}
.page-template-contact main .contact-form form label {
  font-size: clamp(0.9rem, 2vw, 1rem);
}
.page-template-contact main .contact-form form label a {
  position: relative;
  text-decoration: none;
  text-decoration: underline;
  text-underline-offset: 4px;
  text-decoration-thickness: 0.5px;
}
.page-template-contact main .contact-form form label a:not(.external)::before {
  width: 1.6rem;
  height: 0.5rem;
  border-bottom: unset;
  content: "";
  display: inline-block;
  background: url("/assets/img/icons/arrow_right.svg") no-repeat center center;
  background-size: contain;
  vertical-align: middle;
}
.page-template-contact main .contact-form form label a.external::after {
  width: 1rem;
  height: 0.8rem;
  content: "";
  display: inline-block;
  background: url("/assets/img/icons/arrow_diagonal.svg") no-repeat center center;
  background-size: auto;
  background-size: contain;
  vertical-align: middle;
}
.page-template-contact main .contact-form form label a:hover {
  color: var(--color-hover);
  transition: all 0.3s ease-in-out;
}
.page-template-contact main .contact-form form input,
.page-template-contact main .contact-form form textarea {
  width: 100%;
  font-family: var(--font-bold);
  font-size: 0.8rem;
  padding: 1.5rem 1rem;
}
.page-template-contact main .contact-form form input:focus,
.page-template-contact main .contact-form form textarea:focus {
  outline: none !important;
  background-color: var(--color-yellow);
}
.page-template-contact main .contact-form form input:focus::placeholder,
.page-template-contact main .contact-form form textarea:focus::placeholder {
  color: white;
}
.page-template-contact main .contact-form form input::placeholder,
.page-template-contact main .contact-form form textarea::placeholder {
  color: var(--color-text);
}
.page-template-contact main .contact-form form textarea {
  height: 130px;
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .page-template-contact main .contact-form form .textarea,
  .page-template-contact main .contact-form form #submit-btn,
  .page-template-contact main .contact-form form .legal-notice {
    grid-column: 1/3;
  }
}
.page-template-contact main .contact-form form #submit-btn {
  width: 10rem;
  margin: 0;
  background-color: black;
  color: white;
  padding: 1rem;
  cursor: pointer;
  border: none;
}
@media screen and (min-width: 1024px) and (orientation: landscape) {
  .page-template-contact main .contact-form form #submit-btn {
    font-size: 1.2rem;
  }
}
.page-template-contact #legal-notice {
  width: auto;
}
.page-template-contact .alert {
  color: var(--color-orange);
}
.page-template-contact .alert:not(.error) {
  font-size: clamp(1.5rem, 2vw, 2rem);
  color: var(--color-pink);
  font-family: var(--font-bold);
}

.honeypot {
  position: absolute;
  left: -9999px;
}

.uniform__potty {
  position: absolute;
  left: -9999px;
}

.page-template-search main .text-search {
  text-align: center;
  padding-bottom: 3rem;
}
.page-template-search main form {
  max-width: 300px;
  margin: auto;
}
.page-template-search main .search-results {
  margin: auto;
}
.page-template-search main .search-results section {
  padding-top: 2rem;
}
.page-template-search main .search-results p {
  padding: 0;
}
.page-template-search main .search-results li {
  border-bottom: 1px solid;
  list-style: none;
}
.page-template-search main .search-results li a {
  width: 100%;
  padding: 1rem 0;
  display: block;
}
.page-template-search main .search-results li a:hover {
  background-color: var(--color-yellow);
}

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