/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}
body {
  line-height: 1;
}
ol,
ul {
  list-style: none;
}
blockquote,
q {
  quotes: none;
}
blockquote:before,
blockquote:after,
q:before,
q:after {
  content: '';
  content: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
/*................................clearfix...........................................*/
.clearfix:after {
  visibility: hidden;
  display: block;
  font-size: 0;
  content: " ";
  clear: both;
  height: 0;
}
.clearfix {
  display: inline-block;
}
/* start commented backslash hack \*/
* html .clearfix {
  height: 1%;
}
.clearfix {
  display: block;
}
/***********************************************
	 *
	 *** Selbstgehostete Schriftarten **************
	 *
	 **********************************************/
/* latin */
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url(/user/themes/wab/assets/fonts/plexsansitalic500.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin */
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/user/themes/wab/assets/fonts/plexsansnormal500.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin */
@font-face {
  font-family: 'IBM Plex Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/user/themes/wab/assets/fonts/plexsansnormal700.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Literata';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/user/themes/wab/assets/fonts/literatanormal700.woff2) format('woff2');
  unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
:root {
  /************************************************************************
*                                                                      **
* Layout Breakpoints                                                   **
*                                                                      **
* ***********************************************************************/
  --breakpoint-xs: 432px;
  --breakpoint-s: 768px;
  --breakpoint-m: 992px;
  --breakpoint-l: 1200px;
  --breakpoint-xl: 1600px;
  /************************************************************************
*                                                                      **
* Globale Wind-and-Brass-Farben                                        **
* Farbauswahl: https://coolors.co/fefefe-8a8a8a-222222-dda030-a6262a   **
*                                                                      **
* ***********************************************************************/
  --grau-1: #717171;
  --grau: #8a8a8a;
  --grau1: #a3a3a3;
  --grau2: #bdbdbd;
  --grau3: #d6d6d6;
  --grau4: #f0f0f0;
  --grau5: #ffffff;
  --grau6: #ffffff;
  --schwarz: #222222;
  --weiss: #fefefe;
  --orange-2: #8f6518;
  --orange-1: #bb841f;
  --orange: #dda030;
  --orange1: #e4b45c;
  --orange2: #ebc888;
  --orange3: #f3dcb3;
  --orange4: #faf0df;
  --orange5: #ffffff;
  --rot-2: #531315;
  --rot-1: #7d1c20;
  --rot: #a6262a;
  --rot1: #d03035;
  --rot2: #d9595d;
  /************************************************************************
	*                                                                      **
	* Container	            											   **
	*                                                                      **
	* ***********************************************************************/
  /**
	 * Maximale Breite
	 * @type: rem, px, mm
	 */
  --container-max-width: 90ch;
  --container-max-width--blog: 90ch;
  /**
	 * Spaltenbreite für Site Grid Layout
	 * . l-side l-center l-center l-side .
	 */
  --l-side: 16rem;
  --l-center: 8rem;
  /**
	 * Maximale Laufweite von Text
	 * @type: : characters (ch)
	 */
  --measure: 80ch;
  /**
	 * Default padding and margin
	**/
  --margin: 1rem;
  --padding: 1rem;
  /**
	 * Default borders
	**/
  --border-width: 0.15rem;
  --border-radius: 0.15rem;
  /************************************************************************
	*                                                                      **
	* Schriftarten            											   **
	*                                                                      **
	* ***********************************************************************/
  --sans: "IBM Plex Sans", Lato, Helvetica, Arial, sans-serif;
  --serif: "Literata", Merriweather, Lora, Georgia, serif;
  --bold: 700;
  /************************************************************************
	*                                                                      **
	* Schriftgrößen            											   **
	*                                                                      **
	* ***********************************************************************/
  /**
	 * Global font size form html
	 */
  --rem: calc(var(--s0) * var(--l0));
  /**
	 * Modular scale - Schriftgrößenverhältnisse
	 * ratio bestimmt das Verhältnis zur jeweils kleineren oder größeren Schrift
	 */
  --ratio: 1.45;
  --s-5: calc(var(--s-4) / var(--ratio));
  --s-4: calc(var(--s-3) / var(--ratio));
  --s-3: calc(var(--s-2) / var(--ratio));
  --s-2: calc(var(--s-1) / var(--ratio));
  --s-1: calc(var(--s0) / var(--ratio));
  /**
	 * Globaler Skalierungsfaktor für Schriftgrößen - 
	 * kleiner auf kleinen Bildschirmen, größer auf großen.
	 */
  --s0: calc(14px + 0.35vw);
  --s1: calc(var(--s0) * var(--ratio));
  --s2: calc(var(--s1) * var(--ratio));
  --s3: calc(var(--s2) * var(--ratio));
  --s4: calc(var(--s3) * var(--ratio));
  --s5: calc(var(--s4) * var(--ratio));
  /**
	 * Globaler Skalierungsfaktor für Zeilenhöhen - 
	 * kleiner auf kleinen Bildschirmen, größer auf großen.
	 * kleiner für große Schriftgrößen, größer für kleine Schriftgrößen
	 */
  --l-ratio: 1.06;
  --l-5: calc(var(--l-4) / var(--l-ratio));
  --l-4: calc(var(--l-3) / var(--l-ratio));
  --l-3: calc(var(--l-2) / var(--l-ratio));
  --l-2: calc(var(--l-1) / var(--l-ratio));
  --l-1: calc(var(--l0) / var(--l-ratio));
  --l0: 1.4;
  --l1: calc(var(--l0) * var(--l-ratio));
  --l2: calc(var(--l1) * var(--l-ratio));
  --l3: calc(var(--l2) * var(--l-ratio));
  --l4: calc(var(--l3) * var(--l-ratio));
  --l5: calc(var(--l4) * var(--l-ratio));
  line-height: var(--l0);
}
:root html {
  position: relative;
}
:root html.touch {
  -webkit-text-size-adjust: none;
}
@media screen and (min-width: 992px) {
  :root {
    --ratio: 1.55;
  }
}
@media screen and (min-width: 992px) {
  :root {
    --s0: calc(14px + 0.5vw);
  }
}
html {
  color: var(--grau-1);
  background: var(--weiss);
  font-size: var(--rem);
}
body {
  font-family: "IBM Plex Sans", Lato, Helvetica, Arial, sans-serif;
  font-size: var(--s0);
  font-weight: 500;
  line-height: var(--l0);
  color: var(--schwarz);
  position: relative;
  z-index: 1;
  background: var(--weiss);
  -webkit-font-smoothing: antialiased;
  -webkit-tap-highlight-color: rgba(2, 2, 2, 0.2);
}
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
p,
td,
ol,
ul,
li,
input,
select,
option,
textarea {
  font-size: var(--s0);
  line-height: var(--l0);
}
p ~ p {
  margin-top: 1rem;
  margin-bottom: 1rem;
}
p:last-child {
  margin-bottom: 1rem;
}
h1,
h2,
h3,
h4,
h5,
h6,
p,
td,
li {
  max-width: var(--measure);
}
h1,
h2,
h3,
h4,
h5 {
  font-family: "Literata", Merriweather, Lora, Georgia, serif;
  font-weight: 700;
  margin: 1em 0 0.5em;
}
h1 {
  font-size: var(--s3);
  line-height: var(--l-3);
}
h2 {
  font-size: var(--s2);
  line-height: var(--l-2);
}
h3 {
  font-size: var(--s1);
  line-height: var(--l-1);
  color: var(--rot);
}
h4 {
  font-size: var(--s0);
  line-height: var(--l0);
}
img {
  max-width: 100%;
}
ol {
  list-style: decimal inside;
  margin-bottom: 1rem;
}
ul {
  list-style: disc inside;
  margin-bottom: 1rem;
}
body {
  padding-top: 5rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 100vh;
}
body footer {
  margin-top: auto;
}
.l-wrapper {
  padding-left: var(--padding);
  padding-right: var(--padding);
}
.l-spacer {
  padding-top: 1rem;
  padding-bottom: 1rem;
}
.l-100vh {
  min-height: 98vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-bottom: 2vh;
  background-size: cover;
}
.single .l-100vh {
  align-items: end;
  justify-content: center;
}
@media (min-width: 992px) {
  .l-wrapper {
    padding-right: calc((100% - var(--container-max-width)) / 2);
    padding-left: calc((100% - var(--container-max-width)) / 2);
  }
  .l-100vh {
    flex-direction: row;
    flex-grow: all;
  }
  .l-100vh > div:first-child {
    padding-right: 2em;
  }
  .l-100vh > div:first-child {
    padding-left: 2em;
  }
  #unsere-orchester .l-100vh,
  #unsere-dirigenten .l-100vh,
  .single .l-100vh {
    flex-direction: column;
  }
}
.l-grid {
  display: grid;
  grid-gap: 0;
  /** Darf nicht größer 0 sein, wenn Grid innerhalb begrenzender Layouts eingesetzt wird. */
  grid-template-columns: 100%;
  align-content: baseline;
}
@media (min-width: 768px) {
  .l-grid {
    grid-template-columns: 48% 48%;
    justify-content: space-between;
    /** Verteilt den verbleibenden Platz in der Breite zwischen den Spalten. */
  }
}
@media (min-width: 1200px) {
  .l-grid {
    grid-template-columns: 31% 31% 31%;
  }
}
header,
.header {
  position: fixed;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  background: #fff;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9998;
  width: 100%;
  height: 5rem;
  transition: all 0.4s ease;
}
header.sticky,
.header.sticky {
  width: 100%;
  box-shadow: 3px 1px 0.99px 0.01px rgba(0, 0, 0, 0.25);
}
@media screen and (max-width: 992px) {
  header,
  .header {
    align-items: inherit;
  }
  header.l-wrapper,
  .header.l-wrapper {
    padding-left: 0.5rem;
    padding-right: 0.3rem;
  }
}
.logo {
  align-self: flex-end;
  width: 12rem;
  padding: 0 0 0.425rem 0;
  margin: 0;
}
.logo img {
  display: block;
  width: 100%;
}
.hilfslinie {
  height: 0;
  width: 100%;
  position: fixed;
  top: 96px;
  z-index: 99999;
  margin: 0;
  border-top: 1px solid lime;
  display: none;
}
nav {
  width: 70%;
  float: left;
  text-align: right;
}
nav ul li {
  display: inline-block;
  padding: 0;
}
nav ul li a {
  font-size: var(--s0);
  font-weight: 700;
  padding: 0.5rem 1em;
  display: block;
  color: #A6262A;
  transition: all 0.5s;
}
nav ul li a:hover {
  color: #DDA030;
}
@media screen and (min-width: 992px) {
  nav {
    width: 70%;
    float: left;
    text-align: right;
  }
  nav ul {
    height: 5rem;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-end;
  }
  nav ul li {
    display: inline-block;
    padding: 0;
    display: flex;
    flex-direction: column;
    align-self: flex-end;
  }
  nav ul li a {
    font-family: "Literata", Merriweather, Lora, Georgia, serif;
    font-size: var(--s0);
    line-height: 1;
    font-weight: 700;
    padding: 0.5em 1em;
    display: block;
    color: var(--rot);
  }
  nav ul li a:last-child {
    padding-right: 0;
  }
  nav ul li a:hover {
    color: #DDA030;
    transition: all 0.5s;
  }
}
.banner {
  background-repeat: no-repeat;
  background-position: 20% center;
  background-size: cover;
  text-align: center;
  position: relative;
  z-index: 100;
  min-height: calc(100vh - 5rem);
}
.banner .banner-flex {
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  min-height: calc(100vh - 5rem);
  padding: 5vh 0;
}
.banner .banner-flex div {
  margin: auto 0;
}
.banner h1 {
  font-family: "Literata", Merriweather, Lora, Georgia, serif;
  font-weight: 700;
  font-size: var(--s3);
  color: var(--weiss);
  text-shadow: 0 0 3px #000;
  text-align: right;
  margin: 0 0 0.5em 0;
}
.banner h2 {
  text-shadow: 0 0 3px #000;
  text-align: right;
  margin: 0 0 0.5em 0;
  color: var(--weiss);
}
.banner p {
  font-family: "Literata", Merriweather, Lora, Georgia, serif;
  font-weight: 700;
  font-size: var(--s1);
  color: #fff;
  text-shadow: 0 0 3px #000;
  text-align: right;
}
.banner a {
  color: #a6262a;
}
.banner .button-container {
  text-align: right;
  margin: auto 0;
}
.banner .button-container a {
  font-family: "Literata", Merriweather, Lora, Georgia, serif;
  font-size: var(--s1);
  font-weight: 700;
  color: var(--rot);
  text-align: center;
  border-radius: 0.25em;
  padding: 0.25em 1em;
  background: var(--weiss);
  display: inline-block;
  transition: all 0.4s;
}
.banner .button-container a:hover {
  background: var(--orange);
  color: var(--weiss);
}
.banner-dreieck {
  height: 2em;
  background-position: top right;
  background-repeat: no-repeat;
}
.orchester {
  background-color: var(--grau3);
}
.aktuelles {
  background-color: var(--orange);
  padding-top: 2rem;
  padding-bottom: 2rem;
}
.aktuelles h2 {
  text-align: center;
}
.mitmachen {
  background: var(--rot);
  padding-top: 2rem;
  padding-bottom: 2rem;
  text-align: center;
}
.mitmachen h2 {
  color: var(--weiss);
}
.mitmachen h2 span {
  color: var(--orange);
}
.mitmachen .button {
  text-align: center;
  width: auto;
  height: auto;
  font-family: var(--serif);
  display: inline-block;
  font-size: var(--s1);
  line-height: var(--l1);
  color: var(--schwarz);
  padding: 0.5rem 0.5em;
  background: var(--orange);
  border-radius: 3px;
  margin: 1rem 0;
  transition: background 0.4s;
}
.mitmachen .button:hover,
.mitmachen .button:active {
  background: var(--weiss);
}
@media screen and (min-width: 992px) {
  .mitmachen h2 {
    display: inline-block;
  }
}
.img {
  position: relative;
}
.img img {
  width: 100%;
  display: block;
  max-width: 100%;
}
.imgDescription2 {
  position: absolute;
  top: 0px;
  bottom: 0;
  left: 0px;
  right: 0;
  background: rgba(166, 38, 42, 0.85);
  color: #fff;
  width: 100%;
  height: auto;
  font-size: 18px;
  font-weight: 400;
  text-align: center;
  visibility: hidden;
  opacity: 0;
  padding-top: 28.5%;
  transition: all 0.5s;
  cursor: pointer;
  /*remove comment if you want a gradual transition between states
  -webkit-transition: visibility opacity 0.2s;
  */
}
.img:hover .imgDescription2 {
  visibility: visible;
  opacity: 1;
}
.imgDescription2 img {
  width: auto;
  margin: 0 auto;
}
a.showmore {
  font-weight: 400;
  color: #a6262a;
  display: block;
  margin: 30px auto 0;
  background: url(../images/down.png) no-repeat center 100%;
  min-height: 8px;
  height: 40px;
}
.cta2 {
  background-repeat: no-repeat;
  background-position: center center;
  display: block;
  padding: 135px 0 145px;
  text-align: center;
  color: #fff;
  background-size: cover;
}
.cta2 a,
.cta3 a,
.button {
  width: 200px;
  height: 50px;
  line-height: 50px;
  border-radius: 50px;
  background: #a6262a;
  display: block;
  color: #fff;
  margin: 40px auto 0px;
  font-weight: 700;
}
button.button {
  display: inline-block;
  border: none;
  margin: 0;
}
.cta2 a:hover {
  background: #fff;
  color: #a6262a;
  transition: all 0.4s;
}
.cta3 {
  background: #f4f4f4;
  padding: 135px 0 160px;
  position: relative;
}
.cta3 h2 {
  text-align: left;
}
.cta3 span.line {
  margin: 30px 0;
}
.cta3 a {
  margin: 40px 0 0;
  text-align: center;
}
.cta3 a:hover {
  background: #5a5a5a;
  transition: all 0.5s;
}
.safariimg {
  position: absolute;
  top: 7%;
  left: 3%;
  width: 43%;
}
.safariimg img {
  max-width: 100%;
  display: block;
}
@media only screen and (min-width: 1200px) {
  .safariimg img {
    float: right;
    height: 428px;
  }
}
footer {
  padding: 55px 0;
  color: #fff;
  font-weight: 400;
  background: #2b2b2b;
  font-size: 15px;
}
footer a,
footer a:visited {
  color: #fff;
}
footer a:hover {
  color: #a6262a;
}
footer div.rightside {
  text-align: right;
}
/* New */
.os-animation {
  opacity: 0;
}
.os-animation.animated {
  opacity: 1;
}
.staggered-animation {
  opacity: 0;
}
.staggered-animation.animated {
  opacity: 1;
}
/*LOADER EFFECT*/
/*Paste this css to your style sheet file or under head tag*/
/* This only works with JavaScript,
if it's not present, don't show loader */
.no-js #loader {
  display: none;
}
.js #loader {
  display: block;
  position: absolute;
  left: 100px;
  top: 0;
}
.se-pre-con {
  position: fixed;
  left: 0px;
  top: 0px;
  width: 100%;
  height: 100%;
  z-index: 9999;
  background: #a6262a;
}
.box {
  position: absolute;
  width: 78px;
  height: 78px;
  left: 50%;
  top: 50%;
  margin-left: -39px;
  margin-top: -39px;
}
.loading:before {
  content: '';
  position: absolute;
  width: 35px;
  height: 35px;
  top: 50%;
  margin-top: -18px;
  left: 50%;
  margin-left: -18px;
  border-width: 2px 1px;
  border-style: solid;
  border-color: #ffffff rgba(247, 247, 247, 0.3);
  border-radius: 50%;
  -o-border-radius: 50%;
  -ms-border-radius: 50%;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  animation: spin 3.45s infinite;
  -o-animation: spin 3.45s infinite;
  -ms-animation: spin 3.45s infinite;
  -webkit-animation: spin 3.45s infinite;
  -moz-animation: spin 3.45s infinite;
}
.loading:after {
  content: '';
  position: absolute;
  width: 6px;
  height: 6px;
  top: 50%;
  margin-top: -3px;
  left: 50%;
  margin-left: -3px;
  background-color: #ffffff;
  border-radius: 50%;
  -o-border-radius: 50%;
  -ms-border-radius: 50%;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  animation: pulse 6.9s infinite, borderPulse 6.9s infinite;
  -o-animation: pulse 6.9s infinite, borderPulse 6.9s infinite;
  -ms-animation: pulse 6.9s infinite, borderPulse 6.9s infinite;
  -webkit-animation: pulse 6.9s infinite, borderPulse 6.9s infinite;
  -moz-animation: pulse 6.9s infinite, borderPulse 6.9s infinite;
}
@keyframes spin {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  50% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
  100% {
    -webkit-transform: rotate(1080deg);
            transform: rotate(1080deg);
  }
}
@-webkit-keyframes spin {
  0% {
    -webkit-transform: rotate(0deg);
  }
  50% {
    -webkit-transform: rotate(360deg);
  }
  100% {
    -webkit-transform: rotate(1080deg);
  }
}
@keyframes pulse {
  0% {
    background-color: rgba(232, 232, 232, 0.2);
  }
  13% {
    background-color: rgba(240, 240, 240, 0.2);
  }
  15% {
    background-color: rgba(255, 255, 255, 0.9);
  }
  28% {
    background-color: rgba(222, 222, 222, 0.9);
  }
  30% {
    background-color: rgba(255, 255, 255, 0.2);
  }
  43% {
    background-color: rgba(240, 240, 240, 0.2);
  }
  45% {
    background-color: rgba(245, 245, 245, 0.9);
  }
  70% {
    background-color: rgba(250, 250, 250, 0.9);
  }
  74% {
    background-color: rgba(255, 255, 255, 0.2);
  }
  100% {
    background-color: rgba(242, 242, 242, 0.9);
  }
}
@-webkit-keyframes pulse {
  0% {
    background-color: rgba(232, 232, 232, 0.2);
  }
  13% {
    background-color: rgba(240, 240, 240, 0.2);
  }
  15% {
    background-color: rgba(255, 255, 255, 0.9);
  }
  28% {
    background-color: rgba(222, 222, 222, 0.9);
  }
  30% {
    background-color: rgba(255, 255, 255, 0.2);
  }
  43% {
    background-color: rgba(240, 240, 240, 0.2);
  }
  45% {
    background-color: rgba(245, 245, 245, 0.9);
  }
  70% {
    background-color: rgba(250, 250, 250, 0.9);
  }
  74% {
    background-color: rgba(255, 255, 255, 0.2);
  }
  100% {
    background-color: rgba(242, 242, 242, 0.9);
  }
}
@keyframes borderPulse {
  0% {
    box-shadow: 0 0 0 0 #fff5ff, 0 0 0 1px rgba(240, 240, 240, 0.8);
  }
  40% {
    box-shadow: 0 0 0 1px #faedfa, 0 0 0 2px rgba(221, 187, 0, 0.8);
  }
  80% {
    box-shadow: 0 0 0 3px #FFF, 0 0 1px 3px rgba(221, 187, 0, 0.8);
  }
}
@-webkit-keyframes borderPulse {
  0% {
    box-shadow: 0 0 0 0 #fff5ff, 0 0 0 1px rgba(240, 240, 240, 0.8);
  }
  40% {
    box-shadow: 0 0 0 1px #faedfa, 0 0 0 2px rgba(221, 187, 0, 0.8);
  }
  80% {
    box-shadow: 0 0 0 3px #FFF, 0 0 1px 3px rgba(221, 187, 0, 0.8);
  }
}
.content {
  padding: 0.5rem 1em;
  text-align: left;
  background: var(--orange3);
  margin-bottom: 1rem;
}
.related-posts .blog {
  padding: 0px;
}
.contact .form-group {
  margin-bottom: 1.5em;
}
.map-container {
  height: 400px;
  width: 100%;
}
.map-container > div {
  width: 100%;
  height: 100%;
}
.search-wrapper {
  margin-top: 3rem;
}
.search-wrapper .button {
  width: auto;
  height: auto;
  line-height: 42px;
  padding: 0 20px;
}
.search-wrapper .search-input.full-width {
  width: 100%;
}
.centered {
  text-align: center;
}
.dirigent img {
  border-radius: 50%;
  width: 12rem;
  max-width: 100%;
  margin-bottom: 1rem;
}
.orchester img {
  max-width: 100%;
}
/**********************************************

*** Forms *************************************

**********************************************/
/** 
 * Standard-Elemente
 */
form {
  width: 100%;
  max-width: 60ch;
  margin: 0 auto 1rem auto;
  border-radius: var(--border-radius);
}
legend {
  width: 100%;
  display: block;
  text-align: center;
  font-weight: 700;
  font-size: var(--s1);
  font-family: var(--serif);
}
label {
  display: block;
  margin-bottom: 0.5rem;
}
label a {
  color: var(--grau-1);
  text-decoration: underline;
  transition: 0.5s all;
}
label a:hover,
label a:active {
  text-decoration: none;
}
textarea {
  font-size: 1rem;
  line-height: 1rem;
  padding: 0.5rem;
  height: 12rem;
  margin-bottom: 1rem;
  display: block;
  width: 100%;
  box-sizing: border-box;
  vertical-align: baseline;
  overflow: auto;
  border: 0.25rem solid var(--gruen);
  border-radius: var(--border-radius);
}
input[type=text],
input[type=email],
input[type=tel],
input[type=password],
input[type=url] {
  width: 100%;
  font-size: 1rem;
  font-weight: 700;
  background: var(--weiss);
  border: 0.25rem solid var(--gruen);
  border-radius: var(--border-radius);
  padding: calc(var(--padding) / 2);
  color: var(--grau-1);
  transition: all 0.6s ease-out;
  margin-bottom: 1rem;
  caret-color: var(--orange);
}
input:not(:placeholder-shown):not(:focus):invalid {
  border-color: var(--orange);
}
input:hover {
  background: var(--weiss);
}
input:active,
input:focus {
  outline: none;
  border-color: var(--grau4);
}
input[type=submit],
button[type=submit],
button[type=reset] {
  border: 0.25rem solid var(--orange);
  border-radius: var(--border-radius);
  background: var(--orange);
  width: 100%;
  transition: all 0.6s ease-out;
  padding: calc(var(--padding) / 2);
  margin-bottom: 1rem;
  font-weight: 700;
  font-size: 1rem;
  height: auto;
}
input[type=submit]:hover,
button[type=submit]:hover,
button[type=reset]:hover,
input[type=submit]:active,
button[type=submit]:active,
button[type=reset]:active,
input[type=submit]:focus,
button[type=submit]:focus,
button[type=reset]:focus {
  background: var(--gruen1);
  border-color: var(--gruen);
}
button[type=reset] {
  background: var(--grau4);
}
input[type=checkbox],
input[type=radio] {
  width: 1em;
  height: 1em;
  margin: 0 0.5em 0 0;
  display: inline-block;
  box-sizing: border-box;
}
/** Special styling for radio buttons */
label > input[type="radio"] {
  display: none;
}
label > input[type="radio"] + *::before {
  content: "";
  display: inline-block;
  vertical-align: bottom;
  width: 1rem;
  height: 1rem;
  margin-right: 0.3rem;
  border-radius: 50%;
  border-style: solid;
  border-width: 0.2rem;
  border-color: var(--orange);
  transition: all 0.5s;
}
label > input[type="radio"]:checked + *::before {
  background: radial-gradient(var(--gruen) 0%, var(--gruen) 40%, transparent 40%, transparent);
  border-color: var(--gruen);
}
input[type=checkbox] {
  padding: 0;
  cursor: pointer;
  position: relative;
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  border: 0.2rem solid var(--orange);
  border-radius: var(--border-radius);
  color: var(--blau-2);
  background: var(--weiss);
  height: 1.5rem;
  width: 1.5rem;
  margin: 1rem 1em 1rem 0;
  display: inline-block;
  float: left;
}
input[type=checkbox]:checked {
  border-color: var(--gruen);
  color: var(--grau);
}
input[type=checkbox]:checked:before {
  content: "✔";
  font-size: 1.25rem;
  position: absolute;
  top: -0.2rem;
}
select {
  font-size: 1rem;
  font-weight: 700;
  color: var(--grau-1);
  line-height: var(--l0);
  padding: 0.5rem;
  margin-bottom: 1rem;
  box-sizing: border-box;
  vertical-align: baseline;
  background: var(--weiss);
  border: 1px solid transparent;
  border-radius: 2px;
  width: 100%;
  display: block;
}
input:hover,
input:focus,
textarea:focus,
select:focus {
  background: var(--weiss);
}
