@charset "UTF-8";
/* open-sans-300 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 300;
  src: url("../fonts/open-sans-v43-latin-300.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-300italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 300;
  src: url("../fonts/open-sans-v43-latin-300italic.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-regular - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/open-sans-v43-latin-regular.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 400;
  src: url("../fonts/open-sans-v43-latin-italic.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-500 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 500;
  src: url("../fonts/open-sans-v43-latin-500.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-500italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 500;
  src: url("../fonts/open-sans-v43-latin-500italic.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-600 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 600;
  src: url("../fonts/open-sans-v43-latin-600.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-600italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 600;
  src: url("../fonts/open-sans-v43-latin-600italic.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-700 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/open-sans-v43-latin-700.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-700italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 700;
  src: url("../fonts/open-sans-v43-latin-700italic.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-800 - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Open Sans";
  font-style: normal;
  font-weight: 800;
  src: url("../fonts/open-sans-v43-latin-800.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
/* open-sans-800italic - latin */
@font-face {
  font-display: swap; /* Check https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-display for other options. */
  font-family: "Open Sans";
  font-style: italic;
  font-weight: 800;
  src: url("../fonts/open-sans-v43-latin-800italic.woff2") format("woff2"); /* Chrome 36+, Opera 23+, Firefox 39+, Safari 12+, iOS 10+ */
}
:root {
  interpolate-size: allow-keywords;
  color-scheme: light dark;
  --default: light-dark(#000, #FFF);
  --hell: light-dark(#FFF, #000);
  --dunkel: light-dark(#000, #FFF);
  --hell_kontrast: light-dark(yellow, #000);
  --dunkel_kontrast: light-dark(#000, yellow);
  --bleib_hell: light-dark(#FFF, #FFF);
  --bleib_dunkel: light-dark(#000, #000);
  --maincolor1: rgb(93,32,130);
  --maincolor2: rgb(28,56,143);
  --maincolor3: rgb(0,155,181);
  --maincolor4: rgb(199,211,0);
  --maincolor5: rgb(138,138,137);
  --maincolorval1: 93,32,130;
  --maincolorval2: 28,56,143;
  --maincolorval3: 0,155,181;
  --maincolorval4: 199,211,0;
  --maincolorval5: 138,138,137;
  --grau: #999999;
  --thiscolorval: var(--hell);
  --transp: 1;
  --textcol: var(--dunkel);
}

@keyframes dosection {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes dobtn {
  0% {
    rotate: 0deg;
    /*transform: scaleY(1);*/
    /*opacity: 0;*/
    /*background-color: var(--maincolor1);*/
  }
  20% {
    rotate: 5deg;
    box-shadow: 0.5em 0.5em 0.5em rgba(var(--maincolorval), 0.7);
    /*transform: scaleY(0);*/
  }
  35% {
    rotate: -5deg;
    /*transform: scaleY(0);*/
    box-shadow: 0.3em 0.7em 0.5em rgba(var(--maincolorval), 1);
  }
  50% {
    rotate: 0deg;
    /*transform: scaleY(0);*/
    box-shadow: 0.5em 0.5em 0.5em rgba(var(--maincolorval), 0.7);
  }
  100% {
    rotate: 0deg;
    /*transform: scaleY(1);*/
    /*opacity: 1;
      background-color: var(--dunkel);
      */
  }
}
@keyframes doflaeche {
  from {
    top: 5em;
    height: 24em;
  }
  to {
    top: 0;
    height: 12em;
  }
}
@keyframes dokachel {
  from {
    bottom: 2em;
  }
  to {
    bottom: 0.5em;
  }
}
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, img, ins, kbd, q, s, samp,
small, strike, sub, sup, tt, var,
b, u, i, center, dl, dt, dd, ol, ul, li,
fieldset, form, label, legend, textarea, input table,
caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section, main, article {
  display: block;
}

* {
  box-sizing: border-box;
}

.floatleft, .rechtsUmfliessen, .rechtsumfliessen {
  clear: left;
  float: left;
  margin: 0.4em 1em 1.6em 0;
}

.floatright, .linksUmfliessen, .linksumfliessen {
  clear: left;
  float: right;
  margin: 0.4em 0 1.6em 1em;
  text-align: right;
}

.clearfix:after, .ul2sp:after, .section:after {
  visibility: hidden;
  display: block;
  font-size: 0;
  content: " ";
  clear: both;
  height: 0;
}

.clearfix {
  display: block;
}

.hyphenate, main {
  hyphens: auto;
}

img, picture {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

svg {
  max-height: 100%;
  max-width: 100%;
}

/* - - - - - - - - general - - - - - - - - */
table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
  margin-bottom: 0.8em;
  border: none;
}
table caption {
  text-align: left;
  padding-bottom: 0.8em;
}

td, th {
  padding: 0.3em 1em 0.3em 1em;
  text-align: left;
  vertical-align: top;
}

td p, th p {
  padding: 0 0 0.3em 0;
}

ul, ol {
  padding: 0;
  margin: 0;
  list-style-type: none;
}

main ul {
  padding: 0;
  margin: 0 0 1em 1.3em;
  list-style-type: disc;
}
main ul ul {
  list-style-type: circle;
  margin-bottom: 0.2em;
}
main ul ul ul {
  list-style-type: square;
}

main ol {
  list-style-type: decimal;
  padding-left: 0.7em;
  margin-left: 0.7em;
}

strong, b {
  font-weight: 600;
}

italic, i {
  font-style: italic;
}

hr {
  background: none;
  border: none;
  border-bottom: 1px solid var(--maincolor1);
}

p {
  margin: 0;
  padding: 0 0 0.8em 0;
}

p:last-child {
  padding: 0;
}

a {
  text-decoration: none;
  color: var(--dunkel_kontrast);
  display: inline-block;
  padding: 0;
  transition: background 1s;
}

/*a:focus {box-shadow: 0 0 2em black; outline: 3px dotted yellow !important;}
a:focus:after {box-shadow: 0 0 2em black; outline: 3px dotted yellow !important;}*/
a:hover {
  text-decoration: underline;
  color: var(--dunkel_kontrast);
}

a.btn {
  text-decoration: none;
  color: var(--dunkel_kontrast);
}

a.btn:hover {
  text-decoration: underline;
}

a.btn:focus-visible, button:focus-visible { /*background: black !important; color: yellow !important;*/ }

a:focus-visible, button:focus-visible { /*box-shadow: 0 0 1em black; outline: 2px dotted yellow !important;*/ }

/* headlines */
h1, h2, h3, h4, h5, h6 {
  padding: 0;
  margin: 0 0 0.3em 0;
  line-height: 1.2em;
  font-weight: 600; /*letter-spacing: -1px;*/
}

h1 {
  font-size: 2.1em;
  font-weight: 700;
}

h2 {
  font-size: 1.5em;
  font-weight: 700;
}

h3 {
  font-size: 1.2em;
}

h4 {
  font-size: 1em;
}

h5 {
  font-size: 1em;
}

h6 {
  font-size: 1em;
}

/*h1, h2, h3, h4 {
 & + p, & + ul, & + ol {
  padding-top: 0.5em !important;
 }
}*/
* + h1, * + h2, * + h3, * + h4, * + h5 {
  margin-top: 0.8em;
}

h1 + h2, h2 + h3, h3 + h4, h4 + h5, h5 + h6 {
  padding-top: 0 !important;
}

h1 a, h2 a, h3 a, h4 a, h5 a, h6 a {
  text-decoration: none;
  display: inline-block;
  padding: 0;
}

h1 a:hover, h1 a:focus, h2 a:hover, h2 a:focus, h3 a:hover, h3 a:focus, h4 a:hover, h4 a:focus, h5 a:hover, h5 a:focus, h6 a:hover, h6 a:focus {
  text-decoration: none;
}

blockquote {
  font-style: italic;
  text-align: center;
}

.bild a {
  display: inline-block;
}

.imgtitle {
  font-size: 0.9em;
  line-height: 1.2em;
  margin-top: 0.4em;
  font-style: italic;
}

audio {
  width: 100%;
}

button, table *, form * {
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
}

html {
  height: 100%;
  scroll-behavior: smooth;
}

body {
  color-scheme: light;
  margin: 0;
  padding: 0;
  overscroll-behavior: none;
  background-color: var(--hell);
  color: var(--dunkel);
  font-family: "Open Sans", Arial, Helvetica, sans-serif;
  font-style: normal;
  font-weight: 300;
  font-size: 100%;
  font-size: clamp(0.8rem, 0.2111rem + 1.0444vw, 1.2rem);
  line-height: 1.5em;
}

/* standard */
.layout_bg, .layout_bg1, .layout_bg2, .layout_bg3, .layout_bg4, .layout_bg5 {
  --transp: 1;
}

.layout_bg1, .layout_bg2, .layout_bg3, .maincolor1 .layout_bg, .maincolor2 .layout_bg, .maincolor3 .layout_bg,
.maincolor1 figcaption, .maincolor2 figcaption, .maincolor3 figcaption, .maincolor1 .subtitle, .maincolor2 .subtitle, .maincolor3 .subtitle {
  --textcol: var(--hell);
}

.layout_bg4, .layout_bg5, .maincolor4 .layout_bg, .maincolor5 .layout_bg,
.maincolor4 figcaption, .maincolor5 figcaption, .maincolor4 .subtitle, .maincolor5 .subtitle {
  --textcol: var(--dunkel);
}

.transp0 {
  --transp: 0;
  --textcol: var(--dunkel);
}

.transp1 {
  --transp: 0.1;
  --textcol: var(--dunkel);
}

.transp2 {
  --transp: 0.2;
  --textcol: var(--dunkel);
}

.transp3 {
  --transp: 0.3;
  --textcol: var(--dunkel);
}

.transp4 {
  --transp: 0.4;
  --textcol: var(--dunkel);
}

.transp5 {
  --transp: 0.5;
  --textcol: var(--hell);
}

.transp6 {
  --transp: 0.6;
  --textcol: var(--hell);
}

.transp7 {
  --transp: 0.7;
  --textcol: var(--hell);
}

.transp8 {
  --transp: 0.8;
  --textcol: var(--hell);
}

.transp9 {
  --transp: 0.9;
  --textcol: var(--hell);
}

.transp10 {
  --transp: 1;
  --textcol: var(--hell);
}

.maincolor1 {
  --maincolorval: var(--maincolorval1);
}

.maincolor2 {
  --maincolorval: var(--maincolorval2);
}

.maincolor3 {
  --maincolorval: var(--maincolorval3);
}

.maincolor4 {
  --maincolorval: var(--maincolorval4);
}

.maincolor3 .transp5, .maincolor3.transp5, .layout_bg3 .transp5, .layout_bg3.transp5 { /*--transp: 0.5;*/
  --textcol: var(--dunkel);
}
.maincolor3 .transp6, .maincolor3.transp6, .layout_bg3 .transp6, .layout_bg3.transp6 { /*--transp: 0.6;*/
  --textcol: var(--dunkel);
}

.maincolor4, .layout_bg4 {
  --textcol: var(--dunkel);
}
.maincolor4 .transp5, .maincolor4 .transp6, .maincolor4 .transp7, .maincolor4 .transp8, .maincolor4 .transp9, .maincolor4 .transp10, .maincolor4.transp5, .maincolor4.transp6, .maincolor4.transp7, .maincolor4.transp8, .maincolor4.transp9, .maincolor4.transp10, .layout_bg4 .transp5, .layout_bg4 .transp6, .layout_bg4 .transp7, .layout_bg4 .transp8, .layout_bg4 .transp9, .layout_bg4 .transp10, .layout_bg4.transp5, .layout_bg4.transp6, .layout_bg4.transp7, .layout_bg4.transp8, .layout_bg4.transp9, .layout_bg4.transp10 {
  --textcol: var(--dunkel);
}

.maincolor5, .layout_bg5 {
  --textcol: var(--dunkel);
}
.maincolor5 .transp5, .maincolor5 .transp6, .maincolor5 .transp7, .maincolor5 .transp8, .maincolor5 .transp9, .maincolor5 .transp10, .maincolor5.transp5, .maincolor5.transp6, .maincolor5.transp7, .maincolor5.transp8, .maincolor5.transp9, .maincolor5.transp10, .layout_bg5 .transp5, .layout_bg5 .transp6, .layout_bg5 .transp7, .layout_bg5 .transp8, .layout_bg5 .transp9, .layout_bg5 .transp10, .layout_bg5.transp5, .layout_bg5.transp6, .layout_bg5.transp7, .layout_bg5.transp8, .layout_bg5.transp9, .layout_bg5.transp10 {
  --textcol: var(--dunkel);
}

body.darkmode {
  color-scheme: dark;
}
body.darkmode:not(.kontrast) {
  filter: brightness(0.7);
}
body.darkmode a:not(.btn), body.darkmode label.bars, body.darkmode .color, body.darkmode .color1, body.darkmode .color2, body.darkmode .color3, body.darkmode .color4, body.darkmode .color5, body.darkmode section:not(.chart) table caption {
  filter: brightness(2.5) !important;
}
body.darkmode .logo a {
  filter: none !important;
}
body.darkmode.maincolor2 .layout_bg, body.darkmode.maincolor1 .layout_bg, body.darkmode .layout_bg1, body.darkmode .layout_bg2, body.darkmode.maincolor2 figcaption, body.darkmode.maincolor2 .subtitle, body.darkmode.maincolor2 .tl_date, body.darkmode.maincolor1 figcaption, body.darkmode.maincolor1 .subtitle, body.darkmode.maincolor1 .tl_date {
  --textcol: var(--bleib_hell);
}
body.darkmode.maincolor4 .layout_bg, body.darkmode.maincolor4 figcaption, body.darkmode.maincolor4 .subtitle, body.darkmode.maincolor4 .tl_date, body.darkmode .layout_bg4, body.darkmode .layout_bg5 {
  --textcol: var(--bleib_dunkel);
}
body.darkmode .layout_bg4.transp1, body.darkmode .layout_bg4.transp2, body.darkmode .layout_bg4.transp3, body.darkmode .layout_bg4.transp4, body.darkmode .layout_bg4.transp5, body.darkmode .layout_bg4.transp6, body.darkmode .layout_bg4.transp7, body.darkmode .layout_bg4.transp8, body.darkmode .layout_bg5.transp1, body.darkmode .layout_bg5.transp2, body.darkmode .layout_bg5.transp3, body.darkmode .layout_bg5.transp4, body.darkmode .layout_bg5.transp5, body.darkmode .layout_bg5.transp6, body.darkmode .layout_bg5.transp7, body.darkmode .layout_bg5.transp8 {
  --textcol: var(--bleib_hell);
}
body.darkmode footer form button::before {
  background: #fff;
  border-radius: 50%;
}

body.kontrast {
  /*--transp: 1;
  --textcol: var(--dunkel);
  --maincolorval: var(--hell);
  --maincolorval1: var(--hell);
  --maincolorval2: var(--hell);
  --maincolorval3: var(--hell);
  --maincolorval4: var(--hell);
  --maincolorval5: var(--hell);*/
  --maincolor1: rgb(57, 12, 85);
  --maincolorval1: 57, 12, 85;
  --maincolor2: rgb(1, 24, 95);
  --maincolorval2: 1, 24, 95;
  --maincolor3: rgb(0, 88, 103);
  --maincolorval3: 0, 88, 103;
  --maincolor4: rgb(109, 115, 0);
  --maincolorval4: 109, 115,0;
}
body.kontrast .layout_bg4, body.kontrast .layout_bg5, body.kontrast figcaption, body.kontrast .subtitle, body.kontrast .tl_date {
  --textcol: var(--hell) !important;
}
body.kontrast .layout_bg4.transp5, body.kontrast .layout_bg4.transp6, body.kontrast .layout_bg4.transp7, body.kontrast .layout_bg4.transp8, body.kontrast .layout_bg4.transp9, body.kontrast .layout_bg4.transp10, body.kontrast .layout_bg5.transp5, body.kontrast .layout_bg5.transp6, body.kontrast .layout_bg5.transp7, body.kontrast .layout_bg5.transp8, body.kontrast .layout_bg5.transp9, body.kontrast .layout_bg5.transp10, body.kontrast figcaption.transp5, body.kontrast figcaption.transp6, body.kontrast figcaption.transp7, body.kontrast figcaption.transp8, body.kontrast figcaption.transp9, body.kontrast figcaption.transp10, body.kontrast .subtitle.transp5, body.kontrast .subtitle.transp6, body.kontrast .subtitle.transp7, body.kontrast .subtitle.transp8, body.kontrast .subtitle.transp9, body.kontrast .subtitle.transp10, body.kontrast .tl_date.transp5, body.kontrast .tl_date.transp6, body.kontrast .tl_date.transp7, body.kontrast .tl_date.transp8, body.kontrast .tl_date.transp9, body.kontrast .tl_date.transp10 {
  --textcol: var(--hell);
}
body.kontrast section.chart table td.layout_bg, body.kontrast section.chart table td.layout_bg1, body.kontrast section.chart table td.layout_bg2, body.kontrast section.chart table td.layout_bg3, body.kontrast section.chart table td.layout_bg4, body.kontrast section.chart table td.layout_bg5, body.kontrast section.chart table td.layout_bg6 {
  border-top: 2px solid #fff;
  filter: brightness(1.3);
}

body.darkmode.kontrast .layout_bg1, body.darkmode.kontrast .layout_bg2, body.darkmode.kontrast .layout_bg3, body.darkmode.kontrast .layout_bg4, body.darkmode.kontrast .layout_bg5, body.darkmode.kontrast figcaption, body.darkmode.kontrast .subtitle, body.darkmode.kontrast .tl_date {
  --textcol: var(--bleib_hell) !important;
}
body.darkmode.kontrast .transp1, body.darkmode.kontrast .transp2, body.darkmode.kontrast .transp3, body.darkmode.kontrast .transp4, body.darkmode.kontrast .transp5, body.darkmode.kontrast .transp6, body.darkmode.kontrast .transp7, body.darkmode.kontrast .transp8, body.darkmode.kontrast .transp9, body.darkmode.kontrast .transp10 {
  --textcol: var(--bleib_hell);
}
body.darkmode.kontrast .layout_bg5.transp9, body.darkmode.kontrast .layout_bg5.transp10 {
  --textcol: var(--bleib_dunkel);
}

.layout_bg, .layout_bg.layout_bg_small > .inner, figcaption, .subtitle {
  background-color: rgba(var(--maincolorval), var(--transp)) !important;
  color: var(--textcol);
}

.layout_bg1, .layout_bg1.layout_bg_small > .inner {
  background-color: rgba(var(--maincolorval1), var(--transp)) !important;
  color: var(--textcol);
}

.layout_bg2, .layout_bg2.layout_bg_small > .inner {
  background-color: rgba(var(--maincolorval2), var(--transp)) !important;
  color: var(--textcol);
}

.layout_bg3, .layout_bg3.layout_bg_small > .inner {
  background-color: rgba(var(--maincolorval3), var(--transp)) !important;
  color: var(--textcol);
}

.layout_bg4, .layout_bg4.layout_bg_small > .inner {
  background-color: rgba(var(--maincolorval4), var(--transp)) !important;
  color: var(--textcol);
}

.layout_bg5, .layout_bg5.layout_bg_small > .inner {
  background-color: rgba(var(--maincolorval5), var(--transp)) !important;
  color: var(--textcol);
}

.layout_bg1 a, .layout_bg2 a, .layout_bg3 a, .layout_bg4 a, .layout_bg5 a {
  color: var(--textcol);
}

.layout_bg_small {
  background: none !important;
}

.color {
  color: rgba(var(--maincolorval), 1);
  font-weight: 500;
}

.color1 {
  color: rgba(var(--maincolorval1), 1);
  font-weight: 500;
}

.color2 {
  color: rgba(var(--maincolorval2), 1);
  font-weight: 500;
}

.color3 {
  color: rgba(var(--maincolorval3), 1);
  font-weight: 500;
}

.color4 {
  color: rgba(var(--maincolorval4), 1);
  font-weight: 500;
}

.color5 {
  color: rgba(var(--maincolorval5), 1);
  font-weight: 500;
}

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

.inner:has(table) {
  overflow: auto;
}
.inner:has(table) .absatz {
  min-width: 42em;
}
.inner:has(table) table {
  min-width: 40em;
}

table caption {
  color: rgba(var(--maincolorval), 1);
  text-transform: uppercase;
  font-weight: 600;
  font-size: 1.2em;
}
table thead {
  font-weight: 500;
  hyphens: none;
}
table thead td {
  vertical-align: bottom;
}
table tfoot {
  font-weight: 500;
  border-bottom: 3px double rgba(var(--maincolorval5), 1);
}
table tr {
  border-bottom: 1px solid rgba(var(--maincolorval5), 1);
}
table tr:hover, table tr:focus {
  background-color: rgba(var(--maincolorval5), 0.2);
}
table td:hover, table td:focus {
  background-color: rgba(var(--maincolorval), 0.2);
}
table td:empty {
  background: none;
}

.nowrap {
  white-space: nowrap;
}

.helper {
  display: none;
}

#page {
  position: relative;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

main {
  margin-bottom: auto;
  /*display: grid;
  grid-template-rows: auto-fit, minmax(40em,1fr), auto-fit;
  */
}

header {
  position: sticky;
  top: 0;
  z-index: 20;
  /*display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: flex-start;*/
  border-bottom: 2px solid rgba(var(--maincolorval1), 0.65);
  background-color: var(--hell);
  /*display: grid;
  grid-template-columns: fit-content(15rem) 1fr auto;
  grid-template-rows: auto auto;
  align-items: center;
  gap:1em;*/
  padding: 1em;
}

.logo {
  position: relative;
  /*z-index: 2;*/
  display: inline-block;
  width: 15em;
  max-width: 100%;
  grid-row: 1/-1;
  grid-column: 1;
}
.logo a {
  display: block;
  padding: 0;
  margin: 0;
  aspect-ratio: 1695/844;
  max-height: 10vh;
}

#vtwlogo #thueringen, #vtwlogo #ww, #vtwlogo #vtw {
  fill: var(--dunkel);
}

#barrierebox {
  grid-row: 1;
  grid-column: 2/-1;
  text-align: right;
}
#barrierebox label {
  background-color: var(--hell);
  color: var(--dunkel_kontrast);
  border: none;
  padding: 0;
  cursor: pointer;
}
#barrierebox label.close {
  background-color: var(--dunkel_kontrast);
}
#barrierebox #barriereToggle:checked + label + .content {
  display: block;
  right: 0;
}
@starting-style {
  #barrierebox #barriereToggle:checked + label + .content {
    right: -50em;
  }
}
#barrierebox #barriereToggle {
  display: none;
}
#barrierebox .content {
  display: none;
  transition: all 0.5s ease;
  background-color: var(--dunkel_kontrast);
  color: var(--hell_kontrast);
  position: absolute;
  z-index: 10;
  top: 0;
  right: -50em;
  width: 32em;
  max-width: 100%;
  overflow: auto;
  padding: 1em 1.5em;
  border: 1px solid var(--grau);
  box-shadow: 5px 25px 35px 0 rgba(0, 0, 0, 0.4);
  text-align: center;
}
#barrierebox .content ul {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0.4em;
  margin: 1em 0 0 0;
}
#barrierebox .content ul li {
  padding: 0.2em 0.2em;
  margin: 0;
  font-weight: 500;
  border: 3px dotted var(--dunkel_kontrast);
}
#barrierebox .content ul li:hover, #barrierebox .content ul li.active {
  border: 3px dotted var(--hell_kontrast);
}
#barrierebox .content ul li a {
  display: block;
  background-color: var(--hell_kontrast);
  padding: 0.7em 0.2em;
  height: 100%;
  width: 100%;
}
#barrierebox .content ul li a::before {
  content: "";
  display: block;
  width: 100%;
  height: 2em;
  background-color: var(--dunkel_kontrast);
  -webkit-mask-position: center;
  mask-position: center;
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
}
#barrierebox .content ul li.text_groesser a::before {
  -webkit-mask-image: url(/layout/pics/text_groesser.svg);
  mask-image: url(/layout/pics/text_groesser.svg);
}
#barrierebox .content ul li.text_kleiner a::before {
  -webkit-mask-image: url(/layout/pics/text_kleiner.svg);
  mask-image: url(/layout/pics/text_kleiner.svg);
}
#barrierebox .content ul li.darkmode a::before {
  -webkit-mask-image: url(/layout/pics/dark_mode.svg);
  mask-image: url(/layout/pics/dark_mode.svg);
}
#barrierebox .content ul li.kontrast a::before {
  -webkit-mask-image: url(/layout/pics/kontrast.svg);
  mask-image: url(/layout/pics/kontrast.svg);
}
#barrierebox .content ul li.reset a::before {
  -webkit-mask-image: url(/layout/pics/reset.svg);
  mask-image: url(/layout/pics/reset.svg);
}

.shortmenu > ul {
  display: none;
}

/*root link zu gb*/
.shortmenu > ul:has(.bg_link) {
  font-size: clamp(0.8rem, 0.2111rem + 1.0444vw, 1.2rem);
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  flex-wrap: nowrap;
  gap: 0.5em 2%;
}
.shortmenu > ul:has(.bg_link) li.bg_link a::after {
  content: "";
  margin-left: 0.3em;
  width: 1.3rem;
  height: 1.3rem;
  display: inline-block;
  vertical-align: text-bottom;
  background-color: rgba(var(--maincolorval), 1);
  -webkit-mask-image: url(/layout/pics/arrow_forward.svg);
  mask-image: url(/layout/pics/arrow_forward.svg);
  -webkit-mask-position: center;
  mask-position: center;
}

.menu {
  justify-self: end;
  z-index: 5;
}
.menu label.bars {
  color: var(--maincolor3);
  font-weight: 500;
  display: inline-block;
  background-color: var(--hell);
  border: none;
  padding: 0;
  cursor: pointer;
  transition: all 0.5s ease;
}
.menu label.bars::after {
  display: inline-block;
  margin-left: 0.255em;
  vertical-align: 0.255em;
  content: "";
  border-top: 0.3em solid;
  border-right: 0.3em solid rgba(0, 0, 0, 0);
  border-bottom: 0;
  border-left: 0.3em solid rgba(0, 0, 0, 0);
}
.menu label.bars:hover {
  color: var(--maincolor1);
  text-decoration: none;
}
.menu svg path {
  stroke: var(--maincolor3);
}
.menu .mainmenu {
  display: none;
  transition: all 0.5s ease;
  background-color: var(--maincolor3);
  position: absolute;
  top: 0;
  right: -50em;
  bottom: 0;
  max-width: 100%;
  height: 100vh;
  overflow: auto;
  overflow-x: hidden;
  border-left: 1px solid var(--grau);
  box-shadow: 5px 25px 35px 0 rgba(0, 0, 0, 0.4);
}
.menu .mainmenu ul {
  display: flex;
  flex-direction: column;
}
.menu .mainmenu ul li {
  border-bottom: 1px solid var(--hell);
}
.menu .mainmenu ul li .cd-accordion__input {
  position: absolute;
  opacity: 0;
}
.menu .mainmenu ul li label {
  display: none;
}
.menu .mainmenu ul li a {
  padding: 0.5em 0 0.5em 0.8em;
  display: block;
  background-color: var(--maincolor3);
  color: var(--hell);
  width: calc(100% - 2em);
}
.menu .mainmenu ul li:has(> ul) {
  display: grid;
  grid-template-columns: 1fr 2em;
}
.menu .mainmenu ul li:has(> ul) a {
  width: 100%;
}
.menu .mainmenu ul li:has(> ul) label {
  display: block;
  position: relative;
  width: 2em;
  cursor: pointer;
}
.menu .mainmenu ul li:has(> ul) label::before {
  display: inline-block;
  position: absolute;
  left: 0;
  top: 0;
  content: "";
  width: 100%;
  height: 100%;
  background-color: var(--maincolor3);
}
.menu .mainmenu ul li:has(> ul) label::after {
  display: inline-block;
  position: absolute;
  content: "";
  /*padding: 0 2em 0 0;
  border: solid var(--hell);
  border-width: 0 2px 2px 0;
  right: 0.8em;
  top: 0.95em;
  padding: 0.25em;
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);*/
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  background-color: var(--hell);
  -webkit-mask-image: url(/layout/pics/arrow_forward.svg);
  mask-image: url(/layout/pics/arrow_forward.svg);
  -webkit-mask-size: 70%;
  mask-size: 70%;
  -webkit-mask-position: center;
  mask-position: center;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
}
.menu .mainmenu ul li:has(> ul) label:hover::before {
  background-color: var(--maincolor1);
}
.menu .mainmenu ul li:has(.cd-accordion__input:checked) {
  border-top: 3px solid #fff;
  border-bottom: 3px solid #fff;
}
.menu .mainmenu ul li:not(:has(ul)) label::after {
  display: none;
}
.menu .mainmenu ul li li a {
  padding-left: 1.5em;
  display: block;
  background-color: rgba(var(--maincolorval3), 0.8);
}
.menu .mainmenu ul li ul {
  display: none;
  background-color: rgba(var(--maincolorval3), 1);
  border-top: 1px solid #fff;
}
.menu .mainmenu ul li ul a {
  background-color: rgba(var(--maincolorval2), 0.4);
}
.menu .mainmenu ul li a:hover, .menu .mainmenu ul li a.rex-active, .menu .mainmenu ul li a.rex-current {
  background-color: var(--maincolor2);
  color: var(--bleib_hell);
  text-decoration: none;
}
.menu .mainmenu ul li .cd-accordion__input:checked + label::after {
  rotate: 90deg;
}
.menu .mainmenu ul li .cd-accordion__input:checked ~ ul {
  display: block;
}
.menu .mainmenu ul li li.rex-active > label::after, .menu .mainmenu ul li li.rex-current > label::after {
  rotate: 90deg;
}
.menu .mainmenu label.close::after, .menu .mainmenu label.close::before {
  background-color: var(--bleib_hell);
}
.menu #menuToggle:checked + label + .mainmenu {
  display: block;
  right: 0;
}
@starting-style {
  .menu #menuToggle:checked + label + .mainmenu {
    right: -50em;
  }
}
.menu #menuToggle {
  display: none;
}

label.close {
  width: 2.2em;
  margin-left: auto;
  height: 2em;
  display: block;
  position: relative;
  margin-bottom: 1em;
  background-color: rgba(var(--maincolorval1), 1);
  text-indent: 10em;
  overflow: hidden;
}
label.close:hover {
  cursor: pointer;
  background-color: var(--maincolor2);
}
label.close:before, label.close:after {
  content: "";
  position: absolute;
  width: 1.2em;
  height: 2px;
  background-color: var(--hell_kontrast);
  top: 0.9em;
  right: 0.4em;
}
label.close:before {
  transform: rotate(45deg);
}
label.close:after {
  transform: rotate(-45deg);
}

footer {
  position: relative;
  border-top: 2px solid rgba(var(--maincolorval3), 1);
  background-color: var(--hell);
  display: grid;
  grid-template-columns: 1fr;
  align-items: start;
  gap: 2em 4%;
  grid-auto-flow: row;
  padding: 1.5em 1em;
  font-size: 0.9em;
  line-height: 1.3em;
}
footer .flaeche {
  position: absolute;
  z-index: 0;
  right: 0;
  top: 0;
  align-self: start;
  background-color: rgba(var(--maincolorval), 0.6);
  height: 60%;
  width: 16%;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 0);
}
footer nav li {
  position: relative;
}
footer nav li a {
  display: inline-block;
  padding: 0.2em 0 0.2em 0.8em;
  border-bottom: 3px solid transparent;
}
footer nav li a::before {
  display: inline-block;
  position: absolute;
  left: 0;
  top: 0.65em;
  content: "";
  border: solid var(--dunkel);
  border-width: 0 1px 1px 0;
  display: inline-block;
  padding: 0.15em;
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
}
footer nav li a:hover {
  border-bottom: 3px solid rgba(var(--maincolorval), 1);
  text-decoration: none;
}

main article {
  max-width: 100%;
}
main article section:not(.kachelbox, .liste) a {
  color: rgba(var(--maincolorval), 1);
  font-weight: 600;
}
main article section:not(.kachelbox, .liste) a[href]::after {
  content: "";
  margin-left: 0.3em;
  width: 1.3em;
  height: 1.3em;
  display: inline-block;
  vertical-align: text-bottom;
  /*background-image: url(/layout/pics/arrow_right.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center bottom;*/
  background-color: rgba(var(--maincolorval), 1);
  -webkit-mask-image: url(/layout/pics/arrow_right.svg);
  mask-image: url(/layout/pics/arrow_right.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
}
main article section:not(.kachelbox, .liste) a[target=_blank]::after, main article section:not(.kachelbox, .liste) a[target=_blank]::after {
  -webkit-mask-image: url(/layout/pics/link_ext.svg);
  mask-image: url(/layout/pics/link_ext.svg);
}
main article section:not(.kachelbox, .liste) .layout_bg a, main article section:not(.kachelbox, .liste) .layout_bg1 a, main article section:not(.kachelbox, .liste) .layout_bg2 a, main article section:not(.kachelbox, .liste) .layout_bg3 a, main article section:not(.kachelbox, .liste) .layout_bg4 a, main article section:not(.kachelbox, .liste) .layout_bg5 a {
  color: var(--textcol);
}
main article section:not(.kachelbox, .liste) .layout_bg a[href]::after, main article section:not(.kachelbox, .liste) .layout_bg1 a[href]::after, main article section:not(.kachelbox, .liste) .layout_bg2 a[href]::after, main article section:not(.kachelbox, .liste) .layout_bg3 a[href]::after, main article section:not(.kachelbox, .liste) .layout_bg4 a[href]::after, main article section:not(.kachelbox, .liste) .layout_bg5 a[href]::after {
  background-color: var(--textcol);
}
main section {
  animation-name: dosection;
  animation-fill-mode: both;
  animation-duration: 1ms; /* Firefox requires this to apply the animation */
  animation-timing-function: linear;
  /*animation-timeline: view(block 90% 1%);*/
  animation-timeline: view(block);
  animation-range: cover 0% entry-crossing 40vh;
}
main section.bgflaeche {
  position: relative;
  /*padding-bottom: 4em;*/
}
main section.bgflaeche .flaeche {
  position: absolute;
  top: 0;
  right: 50%;
  z-index: 0;
  background-color: rgba(var(--maincolorval), 0.3);
  max-height: 100%;
  height: 12em;
  width: 12.5em;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 calc(100% - 3em));
  /*animation-name: doflaeche;
  animation-fill-mode:forwards;
  animation-timing-function: linear;
  animation-timeline: scroll(root);*/
  animation-name: doflaeche;
  animation-fill-mode: both;
  animation-duration: 1ms; /* Firefox requires this to apply the animation */
  animation-timing-function: linear;
  animation-timeline: view(block 60% 10%);
}
main section > .inner {
  width: 50em;
  max-width: 100%;
  margin: 0 auto 2em auto;
  padding: 1em 0;
  position: relative;
}
main section .absatz {
  padding: 1em;
  position: relative;
}
main section .inner .layout_bg, main section .inner .layout_bg1, main section .inner .layout_bg2, main section .inner .layout_bg3, main section .inner .layout_bg4, main section .inner .layout_bg5 {
  padding: 0.7em 4%;
  margin-bottom: 0.8em;
}
main section .mehrsp2 {
  position: relative;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 6%;
  /*.sp1 {
    margin-bottom: 5em;
  }*/
}
main section .mehrsp2 .sp1, main section .mehrsp2 .sp2 {
  width: auto;
  min-width: 17em;
  max-width: 100%;
  flex: 1;
  position: relative;
}
main section .mehrsp2 .sp1 .bgflaeche, main section .mehrsp2 .sp2 .bgflaeche {
  background-color: rgba(var(--maincolorval), 0.38);
  padding: 3em 1em 5em 1em;
  width: 60%;
  min-width: 12em;
  max-width: 100%;
  margin-top: -4em;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 calc(100% - 4em));
}
main section .mehrsp2 .sp1 .bgflaeche2, main section .mehrsp2 .sp2 .bgflaeche2 {
  background-color: rgba(var(--maincolorval), 0.38);
  padding: 5em 1em 5em 1em;
  width: 60%;
  min-width: 12em;
  max-width: 100%;
  margin-top: -4em;
  clip-path: polygon(0 0, 100% 4em, 100% 100%, 0 calc(100% - 4em));
}
main section.fullwidth {
  width: 100%;
}
main section.fullwidth .absatz {
  width: 50em;
  max-width: 100%;
  margin: 0 auto 2em auto;
}
main section.breiter > .inner {
  width: 70em;
}
main section.breiter > .inner .absatz {
  width: 100%;
}
main section.nav_prevnext .inner {
  margin-top: 2em;
  margin-bottom: 0;
}
main section.nav_prevnext ul {
  list-style-type: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
}
main section.nav_prevnext ul li.next {
  text-align: right;
}
main section.nav_prevnext ul li.next a {
  display: flex;
  flex-direction: row;
  justify-content: flex-end;
  align-items: center;
  gap: 2%;
}
main section.nav_prevnext ul li.next a::after {
  content: "";
  margin-left: 0.3em;
  width: 1.3rem;
  height: 1.3rem;
  display: inline-block;
  vertical-align: text-bottom;
  background-color: rgba(var(--maincolorval), 1);
  -webkit-mask-image: url(/layout/pics/arrow_forward.svg);
  mask-image: url(/layout/pics/arrow_forward.svg);
  -webkit-mask-position: center;
          mask-position: center;
}
main section.nav_prevnext ul li.prev a {
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: center;
  gap: 2%;
}
main section.nav_prevnext ul li.prev a::after {
  display: none;
}
main section.nav_prevnext ul li.prev a::before {
  content: "";
  margin-left: 0.3em;
  width: 1.3rem;
  height: 1.3rem;
  display: inline-block;
  vertical-align: text-bottom;
  background-color: rgba(var(--maincolorval), 1);
  -webkit-mask-image: url(/layout/pics/arrow_forward.svg);
  mask-image: url(/layout/pics/arrow_forward.svg);
  -webkit-mask-position: center;
          mask-position: center;
  rotate: 180deg;
}
main section .absatz + .absatz {
  margin-top: -3em;
}
main section .mehrsp2 .absatz + .absatz {
  margin-top: 0;
}
main section .bild {
  position: relative;
}
@supports selector(::scroll-button(*)) {
  main section .bild button.prev, main section .bild button.next {
    display: none;
  }
}
@supports not selector(::scroll-button(*)) {
  main section .bild button.prev, main section .bild button.next {
    background: none;
    border: none;
    position: absolute;
    top: 40%;
    width: 1.5em;
    overflow: hidden;
    height: 1.5em;
    cursor: pointer;
  }
  main section .bild button.prev::before, main section .bild button.next::before {
    display: inline-block;
    content: "";
    border: solid var(--hell);
    border-width: 0 2px 2px 0;
    padding: 0.4em;
    margin-top: -0.4em;
    box-shadow: 3px 3px 3px var(--dunkel);
    background: none;
    pointer-events: none;
    z-index: 2;
  }
  main section .bild button.prev {
    left: 0.6em;
  }
  main section .bild button.prev::before {
    transform: rotate(135deg);
    -webkit-transform: rotate(135deg);
  }
  main section .bild button.next {
    right: 0.6em;
  }
  main section .bild button.next::before {
    transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
  }
  main section .bild:has(.slide:first-of-type[data-active]) button.prev {
    display: none;
  }
  main section .bild:has(.slide:last-of-type[data-active]) button.next {
    display: none;
  }
}
main section .slideshow {
  position: relative;
  scroll-behavior: smooth;
  scroll-snap-type: mandatory;
  scroll-snap-points-x: repeat(100%);
  scroll-snap-type: x mandatory;
  overflow-x: scroll;
  -webkit-overflow-scrolling: touch;
  -ms-overflow-style: none;
  display: flex;
  scrollbar-width: none; /* Firefox */
}
main section .slideshow::-webkit-scrollbar {
  width: 0;
  height: 0;
  display: none;
}
main section .slideshow::-webkit-scrollbar-track {
  background: transparent;
}
main section .slideshow::-webkit-scrollbar-thumb {
  background: transparent;
  border: none;
}
@supports selector(::scroll-button(*)) {
  main section .slideshow::scroll-button(left), main section .slideshow::scroll-button(right) {
    display: inline-block;
    position: absolute;
    top: 40%;
    content: "";
    border: solid var(--hell);
    border-width: 0 2px 2px 0;
    padding: 0.4em;
    margin-top: -0.4em;
    box-shadow: 3px 3px 3px var(--dunkel);
    background: none;
    z-index: 2;
    opacity: 1;
    cursor: pointer;
  }
  main section .slideshow::scroll-button(left):disabled, main section .slideshow::scroll-button(right):disabled {
    opacity: 0;
  }
  main section .slideshow::scroll-button(left) {
    left: 0.6em;
    transform: rotate(135deg);
    -webkit-transform: rotate(135deg);
  }
  main section .slideshow::scroll-button(right) {
    right: 0.6em;
    transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
  }
}
main section .slideshow .slide {
  width: 100%;
  overflow: visible;
  flex-shrink: 0;
  scroll-snap-align: start;
  position: relative;
}
@supports selector(::scroll-button(*)) {
  main section .slideshow .slide .carousel__prev, main section .slideshow .slide .carousel__next {
    display: none;
    visibility: hidden;
  }
}
main section .subtitle {
  text-align: right;
  font-weight: 400;
  font-size: 0.9em;
  line-height: 1.3em;
  padding: 0.5em 0.5em;
}
main section picture {
  display: block;
}
main section figure figcaption {
  text-align: right;
  margin-left: auto;
  text-wrap: balance;
  font-size: 0.9em;
  line-height: 1.3em;
  padding: 0.5em 0.5em;
}
main section {
  background-color: rgba(var(--thiscolorval), var(--transp));
  color: var(--textcol);
}
main section.mittellinie {
  background: linear-gradient(90deg, transparent, transparent calc(50% - 3px), rgba(var(--maincolorval), 1) calc(50% - 3px), rgba(var(--maincolorval), 1) 50%, transparent calc(50% + 2px), transparent);
}
main section.mittellinie:nth-child(1 of .mittellinie) {
  margin-top: -3em;
}
main section.mittellinie .inner, main section.mittellinie .absatz {
  margin-top: 0;
  padding-top: 0;
}
main section.mittellinie:not(:last-child) .inner, main section.mittellinie:not(:last-child) .absatz {
  margin-bottom: 0;
  padding-bottom: 0;
}
main section.mittellinie:not(:last-child) p:last-child {
  padding-bottom: 0.8em;
}
main section.mittellinie .flaeche {
  clip-path: polygon(0 0, 100% 4em, 100% 100%, 0 calc(100% - 4em));
  height: 70% !important;
}
main section.timeline {
  background: linear-gradient(90deg, transparent, transparent calc(50% - 3px), rgba(var(--maincolorval), 1) calc(50% - 3px), rgba(var(--maincolorval), 1) 50%, transparent calc(50% + 2px), transparent);
}
main section.timeline:nth-child(1 of .timeline) {
  margin-top: -3em;
}
main section.timeline .inner {
  margin-bottom: 0;
}
main section.timeline .mehrsp2 {
  padding-top: 2.5em;
  margin-bottom: 0;
}
main section.timeline .mehrsp2 .sp1 > .inner {
  padding-right: 4cqw;
}
main section.timeline .mehrsp2 .sp2 > .inner {
  padding-left: 4cqw;
}
main section.timeline .flaeche {
  width: 35%;
  height: 8em;
}
main section.timeline .tl_date {
  position: absolute;
  z-index: 1;
  background-color: rgba(var(--maincolorval), 1);
  color: var(--textcol);
  border-radius: 100%;
  aspect-ratio: 1;
  margin-left: -5vw;
  margin-top: -3.5em;
  left: 50%;
  width: 10cqw;
  max-width: 100%;
  font-size: 1.3cqw;
  font-weight: 600;
  line-height: 1.2em;
  /*&::before {
    content: "";
    float: left;
    height: 100%;
    width: 50%;
    shape-outside: polygon(
      0 0,
      98% 0,
      50% 6%,
      23.4% 17.3%,
      6% 32.6%,
      0 50%,
      6% 65.6%,
      23.4% 82.7%,
      50% 94%,
      98% 100%,
      0 100%
    );
    shape-margin: 7%;
  }*/
}
main section.timeline .tl_date .tl_date_in {
  width: 100%;
  height: 100%;
  /*&::before {
    content: "";
    width: 50%;
    height: 100%;
    float: right;
    shape-outside: polygon(
      2% 0%,
      100% 0%,
      100% 100%,
      2% 100%,
      50% 94%,
      76.6% 82.7%,
      94% 65.6%,
      100% 50%,
      94% 32.6%,
      76.6% 17.3%,
      50% 6%
    );
    shape-margin: 7%;
  }*/
  display: flex;
  justify-content: center;
  align-items: center;
}
main section.timeline .tl_date .tl_date_val {
  /*width: 100%;
  height: 100%;*/
  text-align: center;
  padding: 0 0.5em;
}
main a.btn {
  background-color: var(--dunkel);
  color: var(--hell) !important;
  font-size: 0.9em;
  font-weight: 500;
  line-height: 1.2em;
  padding: 0.6em 1em;
  text-align: center;
  opacity: 1;
  transform: scaleY(1);
  /*transition:
    opacity 2.5s,
    transform 0.7s;
  */
  /*@starting-style {
    opacity: 0;
    transform: scaleY(0);
  }*/
  animation-name: dobtn;
  animation-fill-mode: both;
  animation-duration: 1ms; /* Firefox requires this to apply the animation */
  animation-timing-function: linear;
  /*animation-timeline: view(block 70% 1%);*/
  animation-timeline: view(block);
  animation-range: cover 8vh entry-crossing 40vh;
}
main a.btn:hover, main a.btn:focus {
  transform: scaleY(1);
  opacity: 1;
  animation: none;
  background-color: var(--dunkel);
}
main a.btn[href]::after, main a.btn::after {
  background-color: var(--hell) !important;
}

.liste .mehrsp {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(10em, 1fr));
  grid-auto-rows: minmax(8em, 1fr);
  gap: 0.8vw;
  align-items: stretch;
  margin: 0;
  padding: 0;
}
.liste .mehrsp .listeReihe {
  background-color: rgba(var(--maincolorval3), 0.7);
  color: var(--hell);
  text-align: center;
  /*display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: flex-end;*/
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 1fr;
  position: relative;
  align-items: end;
  font-size: 0.7em;
  aspect-ratio: 1;
}
.liste .mehrsp .listeReihe .listeText {
  grid-column: 1;
  grid-row: 1;
  z-index: 10;
  background-color: rgba(var(--maincolorval3), 0.8);
  padding: 5% 4%;
}
.liste .mehrsp .listeReihe .listeImg {
  grid-column: 1;
  grid-row: 1;
  overflow: hidden;
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 0;
}
.liste .mehrsp .listeReihe h3, .liste .mehrsp .listeReihe p {
  margin: 0;
  padding: 0;
}
.liste .mehrsp .listeReihe a {
  color: var(--hell);
  padding: 5% 7%;
  margin: -5% -4%;
  display: block;
  position: relative;
  font-weight: 500;
  transition: all 1s;
}
.liste .mehrsp .listeReihe a::after {
  padding: 0 2em 0 0;
  display: inline-block;
  position: absolute;
  right: 0.35em;
  bottom: 0.9em;
  content: "";
  border: solid var(--hell);
  border-width: 0 2px 2px 0;
  padding: 0.25em;
  transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
}
.liste .mehrsp .listeReihe a:hover {
  background-color: rgba(var(--maincolorval5), 1);
  /*&::after {
    background-color: rgba(var(--maincolorval5),0.4);
    transition: all 1s;
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    z-index: 3;
  }*/
}

.kachelbox .inner {
  height: calc(100vh - 10em);
  display: grid;
  grid-template-rows: 1fr min-content;
  gap: 0.8vw;
  padding-top: 0;
}
.kachelbox .inner .kacheln .bilder {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(10em, 1fr));
  grid-auto-rows: 100%;
  gap: 0.01vw;
  align-items: stretch;
  height: 100%;
  position: relative;
  /*.bild:nth-child(1 of .bild) {
      grid-column: 1 / span 2;
      grid-row: 1;
  }
  .bild:nth-child(2 of .bild) {
      grid-column: 3;
      grid-row: 1;
  }
  .bild:nth-child(3 of .bild) {
      grid-column: 4;
      grid-row: 1;
  }*/
}
.kachelbox .inner .kacheln .bilder::before {
  content: "";
  position: absolute;
  z-index: 1;
  left: 0;
  top: 0;
  background-color: rgba(var(--maincolorval2), 0.6);
  height: 97%;
  width: 30%;
  clip-path: polygon(0 0, 100% 0, 100% 84%, 0 100%);
  mix-blend-mode: multiply;
}
.kachelbox .inner .kacheln .bilder::after {
  content: "";
  position: absolute;
  z-index: 1;
  right: 0;
  top: 0;
  background-color: rgba(var(--maincolorval4), 0.6);
  height: 70%;
  width: 30%;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 80%);
}
.kachelbox .inner .kacheln .bilder .absatzbg {
  content: "";
  position: absolute;
  z-index: 0;
  left: 20%;
  bottom: 0;
  background-color: rgba(var(--maincolorval3), 0.8);
  height: 80%;
  width: 55%;
  clip-path: polygon(0 40%, 100% 0, 100% 100%, 0 100%);
  mix-blend-mode: multiply;
}
.kachelbox .inner .kacheln .bilder .absatz {
  grid-column: 1/-1;
  grid-row: 1;
  color: var(--hell);
  margin: 0;
  max-width: 54%;
  margin: 0 auto;
  display: flex;
  flex-direction: row;
  justify-content: flex-start;
  align-items: flex-end;
  position: relative;
  z-index: 10;
}
.kachelbox .inner .kacheln .bilder .bild {
  background-color: rgba(var(--maincolorval5), 0.6);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.kachelbox .inner .kacheln .bilder .bild:nth-child(1 of .bild) {
  grid-column: 1;
  grid-row: 1;
}
.kachelbox .inner .kacheln .bilder .bild:nth-child(2 of .bild) {
  grid-column: 2;
  grid-row: 1;
}
.kachelbox .inner .kacheln .bilder .bild:nth-child(3 of .bild) {
  grid-column: 3;
  grid-row: 1;
}
.kachelbox .inner .kacheln .bilder .bild:nth-child(4 of .bild) {
  grid-column: 4;
  grid-row: 1;
}
.kachelbox .inner .kacheln ul {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(10em, 1fr));
  grid-auto-rows: minmax(13vh, 1fr);
  gap: 0.8vw;
  align-items: stretch;
  margin: 0;
  padding: 0;
  list-style-type: none;
}
.kachelbox .inner .kacheln ul li {
  padding: 0;
  margin: 0;
  line-height: 1.2em;
  font-weight: 500;
}
.kachelbox .inner .kacheln ul li a {
  padding: 1vw;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  text-align: center;
  height: 100%;
  width: 100%;
  position: relative;
}
.kachelbox .inner .kacheln ul li a::after {
  display: inline-block;
  position: absolute;
  bottom: 50%;
  opacity: 0;
  left: 50%;
  right: 50%;
  content: "";
  border: solid var(--textcol);
  border-width: 0 3px 3px 0;
  padding: 0.25em;
  transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transition: all 0.5s ease-out;
}
.kachelbox .inner .kacheln ul li a:hover::after {
  bottom: 10%;
  opacity: 0.8;
  padding: 0.45em;
  /*animation-name: dokachel;
  animation-fill-mode: both;
  animation-duration: 3ms;
  animation-timing-function: linear;*/
}

main details {
  padding: 0.5em 0;
}
main details summary {
  cursor: pointer;
  display: list-item;
  list-style-type: none;
  font-weight: 400;
}
main details summary::webkit-details-marker {
  display: none;
}
main details summary::before {
  display: inline-block;
  margin-right: 0.255em;
  vertical-align: 0.255em;
  content: "";
  border-top: 0.3em solid;
  border-right: 0.3em solid rgba(0, 0, 0, 0);
  border-bottom: 0;
  border-left: 0.3em solid rgba(0, 0, 0, 0);
  rotate: -90deg;
}
main details::details-content {
  overflow: hidden;
  block-size: 0;
  transition: all 0.5s ease-in-out;
  transition-behavior: allow-discrete;
}
main details[open] summary::before {
  rotate: 0deg;
}
main details[open]::details-content {
  block-size: auto;
  transition: all 0.5s ease-in-out;
}
main .accordion .inner {
  margin: 0 auto !important;
}
main .accordion summary {
  margin: 0 auto !important;
  padding-left: 2em;
  position: relative;
}
main .accordion summary::before {
  position: absolute;
  display: inline-block;
  content: "";
  border-top: 0.3em solid;
  border-right: 0.3em solid rgba(0, 0, 0, 0);
  border-bottom: 0;
  border-left: 0.3em solid rgba(0, 0, 0, 0);
  rotate: -90deg;
  font-size: 2em;
  margin: 0.5em 0 0 -1em;
}
main .bildpos-keine .bild {
  margin-bottom: 1.5em;
}

/*css charts*/
.chart .layout_bg, .chart .layout_bg1, .chart .layout_bg2, .chart .layout_bg3, .chart .layout_bg4, .chart .layout_bg5 {
  margin: 0 !important;
  padding: 0 !important;
}
.chart .inner {
  padding: 3em 0;
}
.chart table caption {
  text-align: left;
  font-size: 1.5em;
  font-weight: 500;
  padding: 0;
  margin: 0 0 1.4em 0;
  line-height: 1.2em;
}

.charts-css {
  --primary-axis-color: var(--textcol) !important;
  --secondary-axes-color: var(--textcol) !important;
}

footer form {
  margin: 0;
  padding: 0;
}
footer form .alert-danger {
  color: #d50000;
  font-weight: 500;
}
footer form .mehrsp {
  display: flex;
  flex-direction: row;
  align-items: end;
  flex-wrap: wrap;
}
footer form .form-check-group > label {
  width: 9.5em;
  display: inline-block;
}
footer form .form-check-group .radio {
  display: inline-block;
  margin: 0 0.3em 0 0;
}
footer form .form-check-group .radio input {
  /*display: none;*/
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
}
footer form .form-check-group .radio label {
  display: inline-block;
  width: 1.4rem;
  height: 1.4rem;
  overflow: hidden;
  position: relative;
}
footer form .form-check-group .radio label::before {
  content: "";
  width: 1.4rem;
  height: 1.4rem;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  background-color: var(--hell);
  z-index: 2;
}
footer form .form-check-group .radio label:has(:focus) {
  border: 1px solid var(--dunkel);
}
footer form .form-check-group .radio:nth-child(1 of .radio) label::before {
  content: url("/layout/pics/+.svg");
}
footer form .form-check-group .radio:nth-child(1 of .radio) label:has(input[type=radio]:checked)::before, footer form .form-check-group .radio:nth-child(1 of .radio) label:hover::before {
  content: url("/layout/pics/+act.svg");
}
footer form .form-check-group .radio:nth-child(2 of .radio) label::before {
  content: url("/layout/pics/0.svg");
}
footer form .form-check-group .radio:nth-child(2 of .radio) label:has(input[type=radio]:checked)::before, footer form .form-check-group .radio:nth-child(2 of .radio) label:hover::before {
  content: url("/layout/pics/0act.svg");
}
footer form .form-check-group .radio:nth-child(3 of .radio) label::before {
  content: url("/layout/pics/-.svg");
}
footer form .form-check-group .radio:nth-child(3 of .radio) label:has(input[type=radio]:checked)::before, footer form .form-check-group .radio:nth-child(3 of .radio) label:hover::before {
  content: url("/layout/pics/-act.svg");
}
footer form button {
  background: none;
  border: none;
  display: inline-block;
  width: 1.4rem;
  height: 1.4rem;
  overflow: hidden;
  padding: 0;
  margin: 1em 0 0 1em;
}
footer form button::before {
  content: url("/layout/pics/submit.svg");
  width: 1.4rem;
  height: 1.4rem;
  display: block;
}
footer form button:hover::before {
  content: url("/layout/pics/submitact.svg");
}

@media (min-width: 23em) {
  header {
    display: grid;
    grid-template-columns: fit-content(15rem) 1fr auto;
    grid-template-rows: auto auto;
    align-items: center;
    gap: 1em;
  }
}
@media (min-width: 45em) {
  footer {
    grid-template-columns: 1fr 1fr;
    align-items: start;
    gap: 2em 4%;
  }
  footer .flaeche {
    right: 50%;
  }
}
@media (min-width: 64em) {
  .shortmenu {
    font-size: clamp(0.8rem, 0.2111rem + 1.0444vw, 1.2rem);
  }
  .shortmenu > ul {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.5em 2%;
  }
  .shortmenu > ul > li {
    position: relative;
  }
  .shortmenu > ul > li:nth-last-child(-n+2) ul {
    right: 0;
  }
  .shortmenu > ul > li > a {
    padding: 0.5em 0;
    border-bottom: 3px solid transparent;
    font-weight: 500;
  }
  .shortmenu > ul > li > a:hover, .shortmenu > ul > li > a.rex-active, .shortmenu > ul > li > a.rex-current {
    border-color: var(--maincolor2);
    text-decoration: none;
  }
  .shortmenu > ul ul {
    /*display: none;*/
    height: 0;
    overflow: hidden;
    opacity: 0;
    transition: opacity 0.5s ease;
    position: absolute;
    max-width: 96vw;
    width: 15em;
    font-size: 0.9em;
    line-height: 1.2em;
  }
  .shortmenu > ul ul a {
    display: block;
  }
  .shortmenu > ul > li:has(> ul) > a::after {
    display: inline-block;
    margin-left: 0.255em;
    vertical-align: 0.255em;
    content: "";
    border-top: 0.3em solid;
    border-right: 0.3em solid rgba(0, 0, 0, 0);
    border-bottom: 0;
    border-left: 0.3em solid rgba(0, 0, 0, 0);
  }
  .shortmenu > ul > li:hover > ul, .shortmenu > ul li:has(a:focus) > ul {
    height: auto;
    max-height: 98vh;
    overflow: auto;
    opacity: 1;
    background-color: var(--hell);
    position: absolute;
    display: flex;
    flex-direction: column;
    border: 1px solid var(--grau);
    box-shadow: 0.2em 0.3em 0.8em 0 rgba(0, 0, 0, 0.4);
  }
  .shortmenu > ul > li:hover > ul > li, .shortmenu > ul li:has(a:focus) > ul > li {
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  }
  .shortmenu > ul > li:hover > ul > li a, .shortmenu > ul li:has(a:focus) > ul > li a {
    padding: 0.35em 0.9em;
  }
  .shortmenu > ul > li:hover > ul > li a:hover, .shortmenu > ul > li:hover > ul > li a.rex-active, .shortmenu > ul > li:hover > ul > li a.rex-current, .shortmenu > ul li:has(a:focus) > ul > li a:hover, .shortmenu > ul li:has(a:focus) > ul > li a.rex-active, .shortmenu > ul li:has(a:focus) > ul > li a.rex-current {
    background-color: var(--maincolor3);
    color: var(--hell);
    text-decoration: none;
  }
  footer {
    /*grid-template-columns: repeat(auto-fit, minmax(14em, 1fr));*/
    grid-template-columns: 1fr 1fr 0.6fr 1.4fr;
    grid-template-rows: auto;
    align-items: end;
  }
}
@media (prefers-color-scheme: dark) {
  /* dunkles Farbschema für die Nacht */
  /*body, a {
    color: var(--hell);
    background: var(--dunkel);
  }*/
}
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    animation-duration: 0.01s !important;
    transition-duration: 0.01s !important;
  }
}