/*!*************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./src/nwz/index.sass ***!
  \*************************************************************************************************************/
@charset "UTF-8";
*, *:before, *:after {
  box-sizing: border-box;
}

html, body, div, span, object, iframe, figure, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, code, em, img, small, strike, strong, sub, sup, tt, b, u, i, ol, ul, li, fieldset, form, label, table, caption, tbody, tfoot, thead, tr, th, td, main, canvas, embed, footer, header, nav, section, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  text-size-adjust: none;
  text-decoration: none;
}

footer, header, nav, section, main {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

input {
  -webkit-appearance: none;
  border-radius: 0;
}

/******************************************************************************
 * * Position-Attribute
 * *****************************************************************************/
.absolute, .absolute, .sm\:absolute {
  position: absolute;
  top: initial;
}

.fixed, .fixed, .sm\:fixed {
  position: fixed;
  top: initial;
}

.sticky, .sticky, .sm\:sticky {
  position: sticky;
  top: var(--header-height, 0);
}

.relative, .relative, .sm\:relative {
  position: relative;
  top: initial;
}

@media (min-width: 45em) {
  .md\:absolute {
    position: absolute;
    top: initial;
  }
  .md\:fixed {
    position: fixed;
    top: initial;
  }
  .md\:sticky {
    position: sticky;
    top: calc(2 * var(--header-height, 0) - 1px);
  }
  .md\:relative {
    position: relative;
    top: initial;
  }
}
@media (min-width: 64em) {
  .lg\:absolute {
    position: absolute;
    top: initial;
  }
  .lg\:fixed {
    position: fixed;
    top: initial;
  }
  .lg\:sticky {
    position: sticky;
    top: calc(2 * var(--header-height, 0) - 1px);
  }
  .lg\:relative {
    position: relative;
    top: initial;
  }
}
/******************************************************************************
 * * Display-Attribute
 * *****************************************************************************/
.block {
  display: block;
}

.none {
  display: none;
}

.inline-block {
  display: inline-block;
}

.flex {
  display: flex;
}

.inline-flex {
  display: inline-flex;
}

.grid {
  display: grid;
}

.dyn-width {
  width: var(--width, 100%);
}

@media (min-width: 45em) {
  .dyn-width {
    width: var(--md-width, var(--width, 100%));
  }
}
@media (min-width: 64em) {
  .dyn-width {
    width: var(--lg-width, var(--width, 100%));
  }
}
/******************************************************************************
 * * Dynamic Attributes, such as margin, padding, with
 * *****************************************************************************/
.dyn-margin {
  margin: var(--sm-margin, var(--margin));
  margin-top: var(--sm-margin-top, var(--sm-margin, var(--margin-top, var(--margin, 0))));
  margin-right: var(--sm-margin-right, var(--sm-margin, var(--margin-right, var(--margin, 0))));
  margin-bottom: var(--sm-margin-bottom, var(--sm-margin, var(--margin-bottom, var(--margin, 0))));
  margin-left: var(--sm-margin-left, var(--sm-margin, var(--margin-left, var(--margin, 0))));
  margin-left: var(--sm-margin-horizontal, var(--sm-margin-left, var(--margin-horizontal, var(--margin-left, var(--margin, 0)))));
  margin-right: var(--sm-margin-horizontal, var(--sm-margin-right, var(--margin-horizontal, var(--margin-right, var(--margin, 0)))));
  margin-top: var(--sm-margin-vertical, var(--sm-margin-top, var(--margin-vertical, var(--margin-top, var(--margin, 0)))));
  margin-bottom: var(--sm-margin-vertical, var(--sm-margin-bottom, var(--margin-vertical, var(--margin-bottom, var(--margin, 0)))));
}

@media (min-width: 45em) {
  .dyn-margin {
    margin: var(--md-margin, var(--margin));
    margin-top: var(--md-margin-top, var(--md-margin, var(--margin-top, var(--margin, 0))));
    margin-right: var(--md-margin-right, var(--md-margin, var(--margin-right, var(--margin, 0))));
    margin-bottom: var(--md-margin-bottom, var(--md-margin, var(--margin-bottom, var(--margin, 0))));
    margin-left: var(--md-margin-left, var(--md-margin, var(--margin-left, var(--margin, 0))));
    margin-left: var(--md-margin-horizontal, var(--md-margin-left, var(--margin-horizontal, var(--margin-left, var(--margin, 0)))));
    margin-right: var(--md-margin-horizontal, var(--md-margin-right, var(--margin-horizontal, var(--margin-right, var(--margin, 0)))));
    margin-top: var(--md-margin-vertical, var(--md-margin-top, var(--margin-vertical, var(--margin-top, var(--margin, 0)))));
    margin-bottom: var(--md-margin-vertical, var(--md-margin-bottom, var(--margin-vertical, var(--margin-bottom, var(--margin, 0)))));
  }
}
@media (min-width: 64em) {
  .dyn-margin {
    margin: var(--lg-margin, var(--margin));
    margin-top: var(--lg-margin-top, var(--lg-margin, var(--margin-top, var(--margin, 0))));
    margin-right: var(--lg-margin-right, var(--lg-margin, var(--margin-right, var(--margin, 0))));
    margin-bottom: var(--lg-margin-bottom, var(--lg-margin, var(--margin-bottom, var(--margin, 0))));
    margin-left: var(--lg-margin-left, var(--lg-margin, var(--margin-left, var(--margin, 0))));
    margin-left: var(--lg-margin-horizontal, var(--lg-margin-left, var(--margin-horizontal, var(--margin-left, var(--margin, 0)))));
    margin-right: var(--lg-margin-horizontal, var(--lg-margin-right, var(--margin-horizontal, var(--margin-right, var(--margin, 0)))));
    margin-top: var(--lg-margin-vertical, var(--lg-margin-top, var(--margin-vertical, var(--margin-top, var(--margin, 0)))));
    margin-bottom: var(--lg-margin-vertical, var(--lg-margin-bottom, var(--margin-vertical, var(--margin-bottom, var(--margin, 0)))));
  }
}
.dyn-padding {
  padding: var(--sm-padding, var(--padding));
  padding-top: var(--sm-padding-top, var(--sm-padding, var(--padding-top, var(--padding, 0))));
  padding-right: var(--sm-padding-right, var(--sm-padding, var(--padding-right, var(--padding, 0))));
  padding-bottom: var(--sm-padding-bottom, var(--sm-padding, var(--padding-bottom, var(--padding, 0))));
  padding-left: var(--sm-padding-left, var(--sm-padding, var(--padding-left, var(--padding, 0))));
  padding-left: var(--sm-padding-horizontal, var(--sm-padding-left, var(--padding-horizontal, var(--padding-left, var(--padding, 0)))));
  padding-right: var(--sm-padding-horizontal, var(--sm-padding-right, var(--padding-horizontal, var(--padding-right, var(--padding, 0)))));
  padding-top: var(--sm-padding-vertical, var(--sm-padding-top, var(--padding-vertical, var(--padding-top, var(--padding, 0)))));
  padding-bottom: var(--sm-padding-vertical, var(--sm-padding-bottom, var(--padding-vertical, var(--padding-bottom, var(--padding, 0)))));
}

@media (min-width: 45em) {
  .dyn-padding {
    padding: var(--md-padding, var(--padding));
    padding-top: var(--md-padding-top, var(--md-padding, var(--padding-top, var(--padding, 0))));
    padding-right: var(--md-padding-right, var(--md-padding, var(--padding-right, var(--padding, 0))));
    padding-bottom: var(--md-padding-bottom, var(--md-padding, var(--padding-bottom, var(--padding, 0))));
    padding-left: var(--md-padding-left, var(--md-padding, var(--padding-left, var(--padding, 0))));
    padding-left: var(--md-padding-horizontal, var(--md-padding-left, var(--padding-horizontal, var(--padding-left, var(--padding, 0)))));
    padding-right: var(--md-padding-horizontal, var(--md-padding-right, var(--padding-horizontal, var(--padding-right, var(--padding, 0)))));
    padding-top: var(--md-padding-vertical, var(--md-padding-top, var(--padding-vertical, var(--padding-top, var(--padding, 0)))));
    padding-bottom: var(--md-padding-vertical, var(--md-padding-bottom, var(--padding-vertical, var(--padding-bottom, var(--padding, 0)))));
  }
}
@media (min-width: 64em) {
  .dyn-padding {
    padding: var(--lg-padding, var(--padding));
    padding-top: var(--lg-padding-top, var(--lg-padding, var(--padding-top, var(--padding, 0))));
    padding-right: var(--lg-padding-right, var(--lg-padding, var(--padding-right, var(--padding, 0))));
    padding-bottom: var(--lg-padding-bottom, var(--lg-padding, var(--padding-bottom, var(--padding, 0))));
    padding-left: var(--lg-padding-left, var(--lg-padding, var(--padding-left, var(--padding, 0))));
    padding-left: var(--lg-padding-horizontal, var(--lg-padding-left, var(--padding-horizontal, var(--padding-left, var(--padding, 0)))));
    padding-right: var(--lg-padding-horizontal, var(--lg-padding-right, var(--padding-horizontal, var(--padding-right, var(--padding, 0)))));
    padding-top: var(--lg-padding-vertical, var(--lg-padding-top, var(--padding-vertical, var(--padding-top, var(--padding, 0)))));
    padding-bottom: var(--lg-padding-vertical, var(--lg-padding-bottom, var(--padding-vertical, var(--padding-bottom, var(--padding, 0)))));
  }
}
.dyn-width {
  width: var(--sm-width, var(--width));
}

@media (min-width: 45em) {
  .dyn-width {
    width: var(--md-width, var(--width));
  }
}
@media (min-width: 64em) {
  .dyn-width {
    width: var(--lg-width, var(--width));
  }
}
.dyn-min-width {
  min-width: var(--sm-min-width, var(--min-width));
}

@media (min-width: 45em) {
  .dyn-min-width {
    min-width: var(--md-min-width, var(--min-width));
  }
}
@media (min-width: 64em) {
  .dyn-min-width {
    min-width: var(--lg-min-width, var(--min-width));
  }
}
.dyn-max-width {
  max-width: var(--sm-max-width, var(--max-width));
}

@media (min-width: 45em) {
  .dyn-max-width {
    max-width: var(--md-max-width, var(--max-width));
  }
}
@media (min-width: 64em) {
  .dyn-max-width {
    max-width: var(--lg-max-width, var(--max-width));
  }
}
.dyn-height {
  height: var(--sm-height, var(--height));
}

@media (min-width: 45em) {
  .dyn-height {
    height: var(--md-height, var(--height));
  }
}
@media (min-width: 64em) {
  .dyn-height {
    height: var(--lg-height, var(--height));
  }
}
.dyn-min-height {
  min-height: var(--sm-min-height, var(--min-height));
}

@media (min-width: 45em) {
  .dyn-min-height {
    min-height: var(--md-min-height, var(--min-height));
  }
}
@media (min-width: 64em) {
  .dyn-min-height {
    min-height: var(--lg-min-height, var(--min-height));
  }
}
.dyn-max-height {
  max-height: var(--sm-max-height, var(--max-height));
}

@media (min-width: 45em) {
  .dyn-max-height {
    max-height: var(--md-max-height, var(--max-height));
  }
}
@media (min-width: 64em) {
  .dyn-max-height {
    max-height: var(--lg-max-height, var(--max-height));
  }
}
/******************************************************************************
 * * Columns
 * *****************************************************************************/
.w-1\/12 {
  width: 8.3333333333%;
}

.w-2\/12 {
  width: 16.6666666667%;
}

.w-3\/12 {
  width: 25%;
}

.w-4\/12 {
  width: 33.3333333333%;
}

.w-5\/12 {
  width: 41.6666666667%;
}

.w-6\/12 {
  width: 50%;
}

.w-7\/12 {
  width: 58.3333333333%;
}

.w-8\/12 {
  width: 66.6666666667%;
}

.w-9\/12 {
  width: 75%;
}

.w-10\/12 {
  width: 83.3333333333%;
}

.w-11\/12 {
  width: 91.6666666667%;
}

.w-12\/12 {
  width: 100%;
}

/******************************************************************************
 * *  Colors @see vars for colormap
 * *****************************************************************************/
.bg-black {
  --bg-opacity: 1;
  background-color: var(--black);
  background-color: rgba(9, 15, 23, var(--bg-opacity)) !important;
}

.text-black {
  --text-opacity: 1;
  color: var(--black);
  color: rgba(9, 15, 23, var(--text-opacity)) !important;
}

.dm-bg-black {
  --bg-opacity: 1;
  background-color: var(--black);
  background-color: rgba(9, 15, 23, var(--bg-opacity)) !important;
}

.dm-text-black {
  --text-opacity: 1;
  color: #090F17;
  color: rgba(9, 15, 23, var(--text-opacity)) !important;
}

.border-black {
  border-color: #090F17;
}

.bg-blue {
  --bg-opacity: 1;
  background-color: var(--blue);
  background-color: rgba(0, 109, 176, var(--bg-opacity)) !important;
}

.text-blue {
  --text-opacity: 1;
  color: var(--blue);
  color: rgba(0, 109, 176, var(--text-opacity)) !important;
}

.dm-bg-blue {
  --bg-opacity: 1;
  background-color: var(--blue);
  background-color: rgba(0, 109, 176, var(--bg-opacity)) !important;
}

.dm-text-blue {
  --text-opacity: 1;
  color: #006DB0;
  color: rgba(0, 109, 176, var(--text-opacity)) !important;
}

.border-blue {
  border-color: #006DB0;
}

.bg-green {
  --bg-opacity: 1;
  background-color: var(--green);
  background-color: rgba(14, 190, 8, var(--bg-opacity)) !important;
}

.text-green {
  --text-opacity: 1;
  color: var(--green);
  color: rgba(14, 190, 8, var(--text-opacity)) !important;
}

.dm-bg-green {
  --bg-opacity: 1;
  background-color: var(--green);
  background-color: rgba(14, 190, 8, var(--bg-opacity)) !important;
}

.dm-text-green {
  --text-opacity: 1;
  color: #0ebe08;
  color: rgba(14, 190, 8, var(--text-opacity)) !important;
}

.border-green {
  border-color: #0ebe08;
}

.bg-lightblue {
  --bg-opacity: 1;
  background-color: var(--lightblue);
  background-color: rgba(242, 247, 251, var(--bg-opacity)) !important;
}

.text-lightblue {
  --text-opacity: 1;
  color: var(--lightblue);
  color: rgba(242, 247, 251, var(--text-opacity)) !important;
}

.dm-bg-lightblue {
  --bg-opacity: 1;
  background-color: var(--lightblue);
  background-color: rgba(242, 247, 251, var(--bg-opacity)) !important;
}

.dm-text-lightblue {
  --text-opacity: 1;
  color: #f2f7fb;
  color: rgba(242, 247, 251, var(--text-opacity)) !important;
}

.border-lightblue {
  border-color: #f2f7fb;
}

.bg-white {
  --bg-opacity: 1;
  background-color: var(--white);
  background-color: rgba(255, 255, 255, var(--bg-opacity)) !important;
}

.text-white {
  --text-opacity: 1;
  color: var(--white);
  color: rgba(255, 255, 255, var(--text-opacity)) !important;
}

.dm-bg-white {
  --bg-opacity: 1;
  background-color: var(--white);
  background-color: rgba(255, 255, 255, var(--bg-opacity)) !important;
}

.dm-text-white {
  --text-opacity: 1;
  color: #FFFFFF;
  color: rgba(255, 255, 255, var(--text-opacity)) !important;
}

.border-white {
  border-color: #FFFFFF;
}

.bg-orange {
  --bg-opacity: 1;
  background-color: var(--orange);
  background-color: rgba(248, 60, 0, var(--bg-opacity)) !important;
}

.text-orange {
  --text-opacity: 1;
  color: var(--orange);
  color: rgba(248, 60, 0, var(--text-opacity)) !important;
}

.dm-bg-orange {
  --bg-opacity: 1;
  background-color: var(--orange);
  background-color: rgba(248, 60, 0, var(--bg-opacity)) !important;
}

.dm-text-orange {
  --text-opacity: 1;
  color: #F83C00;
  color: rgba(248, 60, 0, var(--text-opacity)) !important;
}

.border-orange {
  border-color: #F83C00;
}

.bg-yellow {
  --bg-opacity: 1;
  background-color: var(--yellow);
  background-color: rgba(236, 188, 0, var(--bg-opacity)) !important;
}

.text-yellow {
  --text-opacity: 1;
  color: var(--yellow);
  color: rgba(236, 188, 0, var(--text-opacity)) !important;
}

.dm-bg-yellow {
  --bg-opacity: 1;
  background-color: var(--yellow);
  background-color: rgba(236, 188, 0, var(--bg-opacity)) !important;
}

.dm-text-yellow {
  --text-opacity: 1;
  color: #ECBC00;
  color: rgba(236, 188, 0, var(--text-opacity)) !important;
}

.border-yellow {
  border-color: #ECBC00;
}

.bg-grey {
  --bg-opacity: 1;
  background-color: var(--grey);
  background-color: rgba(161, 169, 176, var(--bg-opacity)) !important;
}

.text-grey {
  --text-opacity: 1;
  color: var(--grey);
  color: rgba(161, 169, 176, var(--text-opacity)) !important;
}

.dm-bg-grey {
  --bg-opacity: 1;
  background-color: var(--grey);
  background-color: rgba(161, 169, 176, var(--bg-opacity)) !important;
}

.dm-text-grey {
  --text-opacity: 1;
  color: #A1A9B0;
  color: rgba(161, 169, 176, var(--text-opacity)) !important;
}

.border-grey {
  border-color: #A1A9B0;
}

.bg-lightgrey {
  --bg-opacity: 1;
  background-color: var(--lightgrey);
  background-color: rgba(235, 240, 244, var(--bg-opacity)) !important;
}

.text-lightgrey {
  --text-opacity: 1;
  color: var(--lightgrey);
  color: rgba(235, 240, 244, var(--text-opacity)) !important;
}

.dm-bg-lightgrey {
  --bg-opacity: 1;
  background-color: var(--lightgrey);
  background-color: rgba(235, 240, 244, var(--bg-opacity)) !important;
}

.dm-text-lightgrey {
  --text-opacity: 1;
  color: #EBF0F4;
  color: rgba(235, 240, 244, var(--text-opacity)) !important;
}

.border-lightgrey {
  border-color: #EBF0F4;
}

.bg-darkslategrey {
  --bg-opacity: 1;
  background-color: var(--darkslategrey);
  background-color: rgba(47, 79, 79, var(--bg-opacity)) !important;
}

.text-darkslategrey {
  --text-opacity: 1;
  color: var(--darkslategrey);
  color: rgba(47, 79, 79, var(--text-opacity)) !important;
}

.dm-bg-darkslategrey {
  --bg-opacity: 1;
  background-color: var(--darkslategrey);
  background-color: rgba(47, 79, 79, var(--bg-opacity)) !important;
}

.dm-text-darkslategrey {
  --text-opacity: 1;
  color: #2F4F4F;
  color: rgba(47, 79, 79, var(--text-opacity)) !important;
}

.border-darkslategrey {
  border-color: #2F4F4F;
}

.bg-blackblue {
  --bg-opacity: 1;
  background-color: var(--blackblue);
  background-color: rgba(0, 31, 49, var(--bg-opacity)) !important;
}

.text-blackblue {
  --text-opacity: 1;
  color: var(--blackblue);
  color: rgba(0, 31, 49, var(--text-opacity)) !important;
}

.dm-bg-blackblue {
  --bg-opacity: 1;
  background-color: var(--blackblue);
  background-color: rgba(0, 31, 49, var(--bg-opacity)) !important;
}

.dm-text-blackblue {
  --text-opacity: 1;
  color: #001F31;
  color: rgba(0, 31, 49, var(--text-opacity)) !important;
}

.border-blackblue {
  border-color: #001F31;
}

.bg-lilac {
  --bg-opacity: 1;
  background-color: var(--lilac);
  background-color: rgba(163, 166, 190, var(--bg-opacity)) !important;
}

.text-lilac {
  --text-opacity: 1;
  color: var(--lilac);
  color: rgba(163, 166, 190, var(--text-opacity)) !important;
}

.dm-bg-lilac {
  --bg-opacity: 1;
  background-color: var(--lilac);
  background-color: rgba(163, 166, 190, var(--bg-opacity)) !important;
}

.dm-text-lilac {
  --text-opacity: 1;
  color: #a3a6be;
  color: rgba(163, 166, 190, var(--text-opacity)) !important;
}

.border-lilac {
  border-color: #a3a6be;
}

body {
  --black: #090F17;
  --blue: #006DB0;
  --green: #0ebe08;
  --lightblue: #f2f7fb;
  --white: #FFFFFF;
  --orange: #F83C00;
  --yellow: #ECBC00;
  --grey: #A1A9B0;
  --lightgrey: #EBF0F4;
  --darkslategrey: #2F4F4F;
  --blackblue: #001F31;
  --lilac: #a3a6be;
  --black-darker: rgb(4.5, 7.5, 11.5);
  --green-darker: #075f04;
  --white-darker: rgb(248.625, 248.625, 248.625);
  --blue-darker: rgb(0, 92.65, 149.6);
  --grey-darker: rgb(133.5335260116, 143.8710982659, 152.9164739884);
  --orange-darker: rgb(210.8, 51, 0);
  --yellow-darker: rgb(200.6, 159.8, 0);
  --black-lighter: rgb(29.165625, 48.609375, 74.534375);
  --green-lighter: rgb(17.3090909091, 234.9090909091, 9.8909090909);
  --white-lighter: rgb(17.3090909091, 234.9090909091, 9.8909090909);
  --blue-lighter: rgb(0, 140.0278409091, 226.1);
  --grey-lighter: rgb(175.1, 181.9, 187.85);
  --orange-lighter: rgb(255, 86.1790322581, 32.3);
  --yellow-lighter: rgb(255, 207.6305084746, 22.1);
}

/******************************************************************************
 * * Opacity for texts and backgrounds 
 * *****************************************************************************/
.opacity-1 {
  opacity: 0.1;
}

.bg-opacity-1 {
  --bg-opacity: 0.1;
}

.text-opacity-1 {
  --text-opacity: 0.1;
}

.opacity-2 {
  opacity: 0.2;
}

.bg-opacity-2 {
  --bg-opacity: 0.2;
}

.text-opacity-2 {
  --text-opacity: 0.2;
}

.opacity-3 {
  opacity: 0.3;
}

.bg-opacity-3 {
  --bg-opacity: 0.3;
}

.text-opacity-3 {
  --text-opacity: 0.3;
}

.opacity-4 {
  opacity: 0.4;
}

.bg-opacity-4 {
  --bg-opacity: 0.4;
}

.text-opacity-4 {
  --text-opacity: 0.4;
}

.opacity-5 {
  opacity: 0.5;
}

.bg-opacity-5 {
  --bg-opacity: 0.5;
}

.text-opacity-5 {
  --text-opacity: 0.5;
}

.opacity-6 {
  opacity: 0.6;
}

.bg-opacity-6 {
  --bg-opacity: 0.6;
}

.text-opacity-6 {
  --text-opacity: 0.6;
}

.opacity-7 {
  opacity: 0.7;
}

.bg-opacity-7 {
  --bg-opacity: 0.7;
}

.text-opacity-7 {
  --text-opacity: 0.7;
}

.opacity-8 {
  opacity: 0.8;
}

.bg-opacity-8 {
  --bg-opacity: 0.8;
}

.text-opacity-8 {
  --text-opacity: 0.8;
}

.opacity-9 {
  opacity: 0.9;
}

.bg-opacity-9 {
  --bg-opacity: 0.9;
}

.text-opacity-9 {
  --text-opacity: 0.9;
}

.opacity-10 {
  opacity: 1;
}

.bg-opacity-10 {
  --bg-opacity: 1;
}

.text-opacity-10 {
  --text-opacity: 1;
}

/******************************************************************************
 * * Font-Families
 * *****************************************************************************/
.sm\:font-merriweather, .font-merriweather {
  font-family: merriweather;
}

.sm\:font-merriweather-light, .font-merriweather-light {
  font-family: merriweather-light;
}

.sm\:font-merriweather-bold, .font-merriweather-bold {
  font-family: merriweather-bold;
}

.sm\:font-work, .font-work {
  font-family: work;
}

.sm\:font-work-bold, .font-work-bold {
  font-family: work-bold;
}

/******************************************************************************
 * * Font-Sizes
 * *****************************************************************************/
.sm\:fs\:10, .fs\:10 {
  --fs: 0.625rem;
  font-size: 0.625rem;
}

.sm\:fs\:11, .fs\:11 {
  --fs: 0.6875rem;
  font-size: 0.6875rem;
}

.sm\:fs\:12, .fs\:12 {
  --fs: 0.75rem;
  font-size: 0.75rem;
}

.sm\:fs\:14, .fs\:14 {
  --fs: 0.875rem;
  font-size: 0.875rem;
}

.sm\:fs\:16, .fs\:16 {
  --fs: 1rem;
  font-size: 1rem;
}

.sm\:fs\:18, .fs\:18 {
  --fs: 1.125rem;
  font-size: 1.125rem;
}

.sm\:fs\:20, .fs\:20 {
  --fs: 1.25rem;
  font-size: 1.25rem;
}

.sm\:fs\:24, .fs\:24 {
  --fs: 1.5rem;
  font-size: 1.5rem;
}

.sm\:fs\:27, .fs\:27 {
  --fs: 1.6875rem;
  font-size: 1.6875rem;
}

.sm\:fs\:30, .fs\:30 {
  --fs: 1.875rem;
  font-size: 1.875rem;
}

.sm\:fs\:44, .fs\:44 {
  --fs: 2.75rem;
  font-size: 2.75rem;
}

@media (min-width: 45em) {
  .md\:fs\:10 {
    --fs: 0.625rem;
    font-size: 0.625rem;
  }
  .md\:fs\:11 {
    --fs: 0.6875rem;
    font-size: 0.6875rem;
  }
  .md\:fs\:12 {
    --fs: 0.75rem;
    font-size: 0.75rem;
  }
  .md\:fs\:14 {
    --fs: 0.875rem;
    font-size: 0.875rem;
  }
  .md\:fs\:16 {
    --fs: 1rem;
    font-size: 1rem;
  }
  .md\:fs\:18 {
    --fs: 1.125rem;
    font-size: 1.125rem;
  }
  .md\:fs\:20 {
    --fs: 1.25rem;
    font-size: 1.25rem;
  }
  .md\:fs\:24 {
    --fs: 1.5rem;
    font-size: 1.5rem;
  }
  .md\:fs\:27 {
    --fs: 1.6875rem;
    font-size: 1.6875rem;
  }
  .md\:fs\:30 {
    --fs: 1.875rem;
    font-size: 1.875rem;
  }
  .md\:fs\:44 {
    --fs: 2.75rem;
    font-size: 2.75rem;
  }
}
@media (min-width: 64em) {
  .lg\:fs\:10 {
    --fs: 0.625rem;
    font-size: 0.625rem;
  }
  .lg\:fs\:11 {
    --fs: 0.6875rem;
    font-size: 0.6875rem;
  }
  .lg\:fs\:12 {
    --fs: 0.75rem;
    font-size: 0.75rem;
  }
  .lg\:fs\:14 {
    --fs: 0.875rem;
    font-size: 0.875rem;
  }
  .lg\:fs\:16 {
    --fs: 1rem;
    font-size: 1rem;
  }
  .lg\:fs\:18 {
    --fs: 1.125rem;
    font-size: 1.125rem;
  }
  .lg\:fs\:20 {
    --fs: 1.25rem;
    font-size: 1.25rem;
  }
  .lg\:fs\:24 {
    --fs: 1.5rem;
    font-size: 1.5rem;
  }
  .lg\:fs\:27 {
    --fs: 1.6875rem;
    font-size: 1.6875rem;
  }
  .lg\:fs\:30 {
    --fs: 1.875rem;
    font-size: 1.875rem;
  }
  .lg\:fs\:44 {
    --fs: 2.75rem;
    font-size: 2.75rem;
  }
}
/******************************************************************************
 * * Line-Heights (Aspect-Ratio : ( Font : Line))
 * *****************************************************************************/
.sm\:lh\:1\/1, .lh\:1\/1 {
  --lh: calc(var(--fs, 1em) * 1);
  line-height: var(--lh);
}

.sm\:lh\:1\/4, .lh\:1\/4 {
  --lh: calc(var(--fs, 1em) * 1.25);
  line-height: var(--lh);
}

.sm\:lh\:2\/3, .lh\:2\/3 {
  --lh: calc(var(--fs, 1em) * 1.5);
  line-height: var(--lh);
}

.sm\:lh\:1\/2, .lh\:1\/2 {
  --lh: calc(var(--fs, 1em) * 2);
  line-height: var(--lh);
}

.sm\:lh\:1\/3, .lh\:1\/3 {
  --lh: calc(var(--fs, 1em) * 3);
  line-height: var(--lh);
}

@media (min-width: 45em) {
  .md\:lh\:1\/1 {
    --lh: calc(var(--fs, 1em) * 1);
    line-height: var(--lh);
  }
  .md\:lh\:1\/4 {
    --lh: calc(var(--fs, 1em) * 1.25);
    line-height: var(--lh);
  }
  .md\:lh\:2\/3 {
    --lh: calc(var(--fs, 1em) * 1.5);
    line-height: var(--lh);
  }
  .md\:lh\:1\/2 {
    --lh: calc(var(--fs, 1em) * 2);
    line-height: var(--lh);
  }
  .md\:lh\:1\/3 {
    --lh: calc(var(--fs, 1em) * 3);
    line-height: var(--lh);
  }
}
@media (min-width: 64em) {
  .lg\:lh\:1\/1 {
    --lh: calc(var(--fs, 1em) * 1);
    line-height: var(--lh);
  }
  .lg\:lh\:1\/4 {
    --lh: calc(var(--fs, 1em) * 1.25);
    line-height: var(--lh);
  }
  .lg\:lh\:2\/3 {
    --lh: calc(var(--fs, 1em) * 1.5);
    line-height: var(--lh);
  }
  .lg\:lh\:1\/2 {
    --lh: calc(var(--fs, 1em) * 2);
    line-height: var(--lh);
  }
  .lg\:lh\:1\/3 {
    --lh: calc(var(--fs, 1em) * 3);
    line-height: var(--lh);
  }
}
@media (min-width: 64em) {
  .lg\:line-30 {
    line-height: 1.875rem;
  }
}
/******************************************************************************
 * * Letter-Specing
 * *****************************************************************************/
.ls\:0 {
  letter-spacing: 0rem;
}

.ls\:03 {
  letter-spacing: 0.01875rem;
}

.ls\:04 {
  letter-spacing: 0.025rem;
}

.ls\:05 {
  letter-spacing: 0.03125rem;
}

.ls\:075 {
  letter-spacing: 0.046875rem;
}

.ls\:1 {
  letter-spacing: 0.0625rem;
}

/******************************************************************************
 * * Visibility Toggles
 * *****************************************************************************/
.show-mobile {
  display: inherit;
}

.hide-mobile {
  display: none;
}

.show-grid-mobile {
  display: grid !important;
}

.hide-grid-mobile {
  display: none !important;
}

@media (min-width: 45em) {
  .show-tablet {
    display: inherit;
  }
  .hide-tablet {
    display: none;
  }
  .show-grid-tablet {
    display: grid !important;
  }
  .hide-grid-tablet {
    display: none !important;
  }
}
@media (min-width: 64em) {
  .show-desktop {
    display: inherit;
  }
  .hide-desktop {
    display: none;
  }
  .show-grid-desktop {
    display: grid !important;
  }
  .hide-grid-desktop {
    display: none !important;
  }
}
/******************************************************************************
 * * Z-INDEX
 * *****************************************************************************/
.z-1 {
  z-index: 10000;
}

.z-2 {
  z-index: 20000;
}

.z-3 {
  z-index: 30000;
}

.z-4 {
  z-index: 40000;
}

.z-5 {
  z-index: 50000;
}

.z-6 {
  z-index: 60000;
}

.z-7 {
  z-index: 70000;
}

.z-8 {
  z-index: 80000;
}

.z-9 {
  z-index: 90000;
}

.z-10 {
  z-index: 100000;
}

.ellipse {
  background-image: radial-gradient(ellipse at 33% 33%, var(--gradient-from), var(--gradient-to) 100%);
}

/******************************************************************************
 * * WIP  Border-Stylings 
 * *****************************************************************************/
[class*=border] {
  border-width: 1px;
  border-style: solid;
}

.border-solid {
  border-style: solid;
}

.border-dotted {
  border-style: dotted;
}

.border-dashed {
  border-style: dashed;
}

.border-inset {
  border-style: inset;
}

.border-outset {
  border-style: outset;
}

.border-circle {
  border-radius: 50%;
}

.border-radius {
  border-radius: var(--lh);
}

.pointer {
  cursor: pointer;
}

.overflow-hidden {
  overflow: hidden;
}

.no-break {
  white-space: nowrap;
}

/******************************************************************************
 * * Basic Font-Attributes
 * *****************************************************************************/
.text-uc {
  text-transform: uppercase;
}

.text-lc {
  text-transform: lowercase;
}

.weight-light {
  font-weight: 200;
}

.weight-regular {
  font-weight: 400;
}

.weight-medium {
  font-weight: 600;
}

.weight-bold {
  font-weight: 800;
}

.text-italic {
  font-style: italic;
}

@font-face {
  font-family: "work";
  src: local("");
  src: url("https://www.nwzonline.de/nwzonline/assets/fonts/work-sans-regular.woff2") format("woff2");
  src: url("https://www.nwzonline.de/nwzonline/assets/fonts/work-sans-regular.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: block;
}
@font-face {
  font-family: "work-bold";
  src: local("");
  src: url("https://www.nwzonline.de/nwzonline/assets/fonts/work-sans-bold.woff2") format("woff2");
  src: url("https://www.nwzonline.de/nwzonline/assets/fonts/work-sans-bold.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: block;
}
@font-face {
  font-family: "merriweather";
  src: local("");
  src: url("https://www.nwzonline.de/nwzonline/assets/fonts/merriweather.woff2") format("woff2");
  src: url("https://www.nwzonline.de/nwzonline/assets/fonts/merriweather.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: block;
}
@font-face {
  font-family: "merriweather-light";
  src: local("");
  src: url("https://www.nwzonline.de/nwzonline/assets/fonts/merriweather-light.woff2") format("woff2");
  src: url("https://www.nwzonline.de/nwzonline/assets/fonts/merriweather-light.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: block;
}
@font-face {
  font-family: "merriweather-bold";
  src: local("");
  src: url("https://www.nwzonline.de/nwzonline/assets/fonts/merriweather-bold.woff2") format("woff2");
  src: url("https://www.nwzonline.de/nwzonline/assets/fonts/merriweather-bold.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: block;
}
@font-face {
  font-family: "icomoon";
  src: url("https://www.nwzonline.de/nwzonline/assets/fonts/icomoon.woff");
  src: url("https://www.nwzonline.de/nwzonline/assets/fonts/icomoon.woff") format("woff");
  font-weight: normal;
  font-style: normal;
  font-display: block;
  font-display: block;
}
[class^=icon-], [class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: "icomoon" !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  border: none;
  background: transparent;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-chat:before {
  content: "\e900";
}

.icon-clear:before {
  content: "\e907";
}

.icon-dehaze:before {
  content: "\e901";
}

.icon-notifications_on:before {
  content: "\e902";
}

.icon-notification:before {
  content: "\e90b";
}

.icon-person:before {
  content: "\e903";
}

.icon-bookmark:before {
  content: "\e904";
}

.icon-bookmark_outline:before {
  content: "\e905";
}

.icon-search:before {
  content: "\e906";
}

.icon-price-tag:before {
  content: "\e935";
}

.icon-next:before {
  content: "\e908";
}

.icon-settings:before {
  content: "\e909";
}

.icon-arrow_prev:before {
  content: "\e90a";
}

.icon-arrow_next:before {
  content: "\e90b";
}

.icon-zoom:before {
  content: "\e90c";
}

.icon-facebook:before {
  content: "\ea90";
}

.icon-whatsapp:before {
  content: "\ea93";
}

.icon-twitter:before {
  content: "\ea96";
}

.icon-mail:before {
  content: "\e90d";
}

.icon-play_arrow:before {
  content: "\e90e";
}

.icon-lastread:before {
  content: "\e910";
}

.icon-image {
  content: "\e90e";
}

.icon-calendar {
  content: "\e912";
}

.icon-check-square-o {
  content: "\e911";
}

.icon-menu:before {
  content: "\f0c9";
}

.icon-bulletpoint:before {
  content: "●";
  color: var(--blue);
  margin-right: 0.5rem;
}

.input-icon {
  position: absolute;
  right: 0.5rem;
  top: calc(50% - 0.75rem);
  background: none;
  border: none;
  font-size: 1.5rem;
}

/******************************************************************************
 * * Responsive Images - all have an aspect ratio .ar-w/h
 * *
 * * <div class="ar-x/y">
 * *  ...
 * *    <img />
 * *  ...
 * *  </div>
 * *
 * *****************************************************************************/
[class*=ar-] {
  width: 100%;
  position: relative;
  overflow: hidden;
  display: block;
}
[class*=ar-] img, [class*=ar-] iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  object-fit: cover;
  object-position: center center;
}

.image-caption {
  position: relative;
  font-size: 0.75rem;
  background-color: var(--lightblue);
  color: var(--blue);
  display: grid;
  column-gap: 1rem;
  font-family: work;
}
.image-caption p {
  margin-bottom: unset !important;
  padding-left: 1rem;
  padding-right: 1rem;
  grid-column: 1;
}
.image-caption p:first-of-type {
  padding-top: 0.75rem;
}
.image-caption p:last-of-type {
  padding-bottom: 0.75rem;
}
.image-caption .credit {
  grid-column: 1;
  grid-row: 2;
  white-space: nowrap;
  text-align: right;
  margin-right: 1rem;
}
.image-caption .credit:before {
  content: "Bild: ";
}

.sm\:ar-16\/9, .ar-16\/9 {
  padding-bottom: 56.25%;
}

.sm\:ar-5\/3, .ar-5\/3 {
  padding-bottom: 60%;
}

.sm\:ar-4\/3, .ar-4\/3 {
  padding-bottom: 75%;
}

.sm\:ar-3\/2, .ar-3\/2 {
  padding-bottom: 66.6666666667%;
}

.sm\:ar-2\/1, .ar-2\/1 {
  padding-bottom: 50%;
}

.sm\:ar-1\/1, .ar-1\/1 {
  padding-bottom: 100%;
}

.sm\:ar-1\/2, .ar-1\/2 {
  padding-bottom: 200%;
}

.sm\:ar-3\/4, .ar-3\/4 {
  padding-bottom: 133.3333333333%;
}

.sm\:ar-9\/16, .ar-9\/16 {
  padding-bottom: 177.7777777778%;
}

.sm\:ar-3\/5, .ar-3\/5 {
  padding-bottom: 166.6666666667%;
}

@media (min-width: 45em) {
  .md\:ar-16\/9 {
    padding-bottom: 56.25%;
  }
  .md\:ar-5\/3 {
    padding-bottom: 60%;
  }
  .md\:ar-4\/3 {
    padding-bottom: 75%;
  }
  .md\:ar-3\/2 {
    padding-bottom: 66.6666666667%;
  }
  .md\:ar-2\/1 {
    padding-bottom: 50%;
  }
  .md\:ar-1\/1 {
    padding-bottom: 100%;
  }
  .md\:ar-1\/2 {
    padding-bottom: 200%;
  }
  .md\:ar-3\/4 {
    padding-bottom: 133.3333333333%;
  }
  .md\:ar-9\/16 {
    padding-bottom: 177.7777777778%;
  }
  .md\:ar-3\/5 {
    padding-bottom: 166.6666666667%;
  }
}
@media (min-width: 64em) {
  .lg\:ar-16\/9 {
    padding-bottom: 56.25%;
  }
  .lg\:ar-5\/3 {
    padding-bottom: 60%;
  }
  .lg\:ar-4\/3 {
    padding-bottom: 75%;
  }
  .lg\:ar-3\/2 {
    padding-bottom: 66.6666666667%;
  }
  .lg\:ar-2\/1 {
    padding-bottom: 50%;
  }
  .lg\:ar-1\/1 {
    padding-bottom: 100%;
  }
  .lg\:ar-1\/2 {
    padding-bottom: 200%;
  }
  .lg\:ar-3\/4 {
    padding-bottom: 133.3333333333%;
  }
  .lg\:ar-9\/16 {
    padding-bottom: 177.7777777778%;
  }
  .lg\:ar-3\/5 {
    padding-bottom: 166.6666666667%;
  }
}
/******************************************************************************
 * * Flexbox
 * *****************************************************************************/
.row {
  flex-direction: row;
}

.column {
  flex-direction: column;
}

.flex-wrap {
  flex-wrap: wrap;
}

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

.justify-center {
  justify-content: center;
}

.justify-space-between {
  justify-content: space-between;
}

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

.justify-stretch {
  justify-content: stretch;
}

.items-center {
  align-items: center;
}

.items-flex-start {
  align-items: flex-start;
}

.items-flex-end {
  align-items: flex-end;
}

/******************************************************************************
 * * Grid
 * *****************************************************************************/
.grid {
  grid-gap: 1em;
  grid-template-columns: repeat(12, 1fr);
}

.grid-full-row {
  grid-column: 1/-1 !important;
}

._separator {
  position: relative;
  margin-bottom: 1rem !important;
}
._separator:before {
  content: "";
  width: calc(100% + 1rem);
  border-top: 1px solid #EBF0F4;
  display: block;
  position: absolute;
  top: -0.5rem;
  left: -0.5rem;
}

.input input, .input textarea, .input select, .input .button {
  border-radius: 100vh;
  border: 1px solid rgba(161, 169, 176, 0.5);
  outline: none;
  transition: 0.25s ease-out all;
  color: var(--black);
  padding: 0.25rem 1rem;
  height: unset;
}
.input input:focus, .input input:active, .input textarea:focus, .input textarea:active, .input select:focus, .input select:active, .input .button:focus, .input .button:active {
  box-shadow: inset 0 0.25rem 0.5rem -0.25rem rgba(9, 15, 23, 0.25);
  border: 1px solid rgba(9, 15, 23, 0.75);
  color: #090F17;
}
.input input:focus + .input-icon, .input input:active + .input-icon, .input textarea:focus + .input-icon, .input textarea:active + .input-icon, .input select:focus + .input-icon, .input select:active + .input-icon, .input .button:focus + .input-icon, .input .button:active + .input-icon {
  color: var(--black) !important;
}
.input *::placeholder {
  font-size: 0.75rem;
  text-transform: uppercase;
  color: var(--black);
}

[data-module] {
  border-radius: 0.25rem;
}

.intersectionTrigger {
  position: absolute;
  top: -50vh;
  top: 200px;
  left: 50%;
  display: block;
  width: 10px;
  height: 10px;
  pointer-events: none;
  visibility: hidden;
}

.preloader {
  display: flex;
  align-items: center;
  justify-content: center;
  color: #006DB0;
}
.preloader + * {
  opacity: 0;
}

.preloader.loaded {
  display: none;
}
.preloader.loaded + * {
  transition: 0.5s linear all;
  opacity: 1;
  display: flex;
  justify-content: center;
}

.cmp-vendor-info {
  width: 100%;
  height: 100%;
  padding: 1rem 2rem;
  overflow-y: scroll;
  max-height: 40vh;
}
@media (min-width: 64em) {
  .cmp-vendor-info {
    max-height: unset;
  }
}
.cmp-vendor-info.abs {
  position: absolute;
}
@media (min-width: 64em) {
  .cmp-vendor-info.abs {
    position: absolute;
  }
}
.cmp-vendor-info .toggleswitch {
  display: flex;
  background: rgba(0, 109, 176, 0.3);
  position: relative;
  border: none;
  width: 2rem;
  aspect-ratio: 3.5/2;
  border-radius: 50vh;
  margin: 0.5rem;
}
.cmp-vendor-info .toggleswitch::after {
  content: "";
  position: absolute;
  background: #FFFFFF;
  box-shadow: 0 0.25rem 0.5rem -0.25rem rgba(9, 15, 23, 0.5);
  border-radius: 50%;
  left: 0.125rem;
  top: 0.125rem;
  width: 0.9rem;
  height: 0.9rem;
}
.cmp-vendor-info .toggleswitch.active {
  background: #006DB0;
  transition: 0.175s linear all;
}
.cmp-vendor-info .toggleswitch.active::after {
  left: 1.75rem;
  transition: 0.175s linear all;
}
.cmp-vendor-info ~ [class*=twitter] {
  display: none;
}

.widget-content.activated .cmp-vendor-info {
  position: absolute;
  pointer-events: none;
  opacity: 0;
  transition: 0.5s linear opacity;
}
.widget-content.activated .cmp-vendor-info ~ iframe {
  pointer-events: unset;
}

/**
 * * pops out a message
 * */
.toast {
  position: fixed;
  background: #F83C00;
  color: #FFFFFF;
  box-shadow: 0 0.25rem 0.5rem -0.25rem rgba(9, 15, 23, 0.5);
  padding: 1rem;
  font-size: 1rem;
  font-weight: 600;
  min-width: 210px;
  max-width: 300px;
  line-height: 1.5rem;
  opacity: 1;
  display: flex;
  align-items: center;
  z-index: 500;
  pointer-events: none;
}
.toast::before {
  height: 2rem;
  font-size: 2rem;
  display: flex;
  align-items: center;
}
.toast.error {
  background: red;
}
.toast.top {
  top: 3rem;
}
.toast.right {
  right: 1rem;
}
.toast.bottom {
  bottom: 1rem;
}
.toast.left {
  left: 1rem;
}
.toast.center {
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
.toast.roasting {
  opacity: 0;
}
.toast.getEaten {
  opacity: 0;
  transition: 0.5s ease all;
}

.logo {
  height: 2.5rem;
  aspect-ratio: 1;
  display: block;
  margin: 0 1rem;
}

@media (min-width: 64em) {
  .logo {
    margin-left: 0;
  }
}
.button {
  transition: 0.25s all ease-out;
  padding: 0 1rem;
  height: 2rem;
}
.button:hover, .button.focus {
  --bg-opacity: 0.75;
}

.headerImage {
  border-bottom: 3px solid var(--blue) !important;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  margin-bottom: 0.5rem;
}

@media (min-width: 64em) {
  .headerImage {
    border-bottom: unset !important;
    padding-bottom: 0 !important;
    margin-top: 1rem !important;
  }
  .headerImage:after {
    content: "";
    height: 3px;
    display: block;
    border-bottom: 3px solid var(--blue);
  }
  .headerImage svg {
    max-height: 6rem;
  }
}
#skip-navigation {
  left: 1rem;
  top: 1rem;
  padding: 0.5rem;
  border: none;
  box-shadow: 0 0.25rem 0.5rem -0.25rem rgba(9, 15, 23, 0.5);
  transform: translateY(-100px);
  transition: 0.25s linear all;
}

#skip-navigation:focus {
  transform: translateY(0);
  transition: 0.25s linear all;
}

.modal:not([data-status=active]) > * {
  pointer-events: none !important;
}

.nav-container {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 5.25rem;
  right: 0;
  height: 100vh;
  box-shadow: 0 0 0.5rem 0 #090F17;
  transform: translateX(calc(100% + 6rem));
  pointer-events: none;
}
.nav-container .menu {
  padding: 1rem 1rem;
  overflow-y: scroll;
  height: 100vh;
}
.nav-container .menu ul {
  width: 100%;
}

[id|=toggle]:checked + nav[class|=toggle] {
  transform: translateX(0);
  pointer-events: initial;
}

.nav-container label[for|=toggle-nav],
.modal:not([data-status=active]) .close-button {
  opacity: 0;
  transform: translateX(0);
}
.nav-container label[for|=toggle-nav]:after,
.modal:not([data-status=active]) .close-button:after {
  content: "X";
  bottom: 10rem;
  opacity: 0;
}

.modal[data-status=active] .close-button {
  opacity: 1;
  transition: opacity 0.25s ease-out;
  transition-delay: 2s;
  position: absolute;
  border: none;
  left: -66vw;
  bottom: 0;
  width: 66vw;
  height: 100%;
  background: linear-gradient(0, rgba(9, 15, 23, 0.5), rgba(255, 255, 255, 0.9));
}
.modal[data-status=active] .close-button:after {
  transition: bottom 0.25s ease, opacity 0.5s linear;
  transition-delay: 2s;
  right: 1rem;
  bottom: 50%;
  content: "\e907";
  font-family: "icomoon" !important;
  position: absolute;
  opacity: 1;
  background: #006DB0;
  color: #FFFFFF;
  border-radius: 50%;
  width: 3.25rem;
  height: 3.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0.25rem 0.5rem -0.25rem rgba(9, 15, 23, 0.5);
}

[id|=toggle]:checked + nav[class|=toggle] label[for|=toggle-nav] {
  opacity: 1;
  transition: opacity 0.25s ease-out;
  transition-delay: 0.25s;
  position: absolute;
  left: -5.25rem;
  bottom: 0;
  width: 5.25rem;
  height: 100%;
  background: linear-gradient(0, rgba(9, 15, 23, 0.5), rgba(255, 255, 255, 0.9));
}
[id|=toggle]:checked + nav[class|=toggle] label[for|=toggle-nav]:after {
  transition: bottom 0.25s ease, opacity 0.5s linear;
  transition-delay: 0.25s;
  right: 1rem;
  bottom: 50%;
  content: "\e907";
  font-family: "icomoon" !important;
  position: absolute;
  opacity: 1;
  background: #006DB0;
  color: #FFFFFF;
  border-radius: 50%;
  width: 3.25rem;
  height: 3.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0.25rem 0.5rem -0.25rem rgba(9, 15, 23, 0.5);
}

.metamenu input, .mainmenu li input {
  display: none;
}

.metamenu:after {
  content: "";
  width: calc(100% + 2rem);
  border-bottom: 1px solid #EBF0F4;
  display: block;
  transform: translateX(-1rem);
  padding-bottom: 0.5rem;
  padding-top: 1rem;
}

.metamenu li, .mainmenu li {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  position: relative;
}

.metamenu li a, .metamenu li smart {
  display: block;
  font-size: 1rem;
  padding: 0.5rem 0;
  color: var(--black);
  cursor: pointer;
  white-space: nowrap;
}

.mainmenu {
  margin-bottom: 3rem;
}
.mainmenu label {
  transition: 0.25s linear all;
  transform: rotate(90deg);
  font-size: 1.5rem;
}
.mainmenu input:checked + label {
  transform: rotate(-90deg);
}
.mainmenu li:not(:last-of-type):after {
  content: "";
  width: calc(100% + 2rem);
  border-bottom: 1px solid #EBF0F4;
  position: absolute;
  bottom: 0;
  transform: translateX(-1rem);
}
.mainmenu a, .mainmenu smart {
  display: block;
  font-size: 1rem;
  padding: 1rem 0;
  color: var(--black);
  cursor: pointer;
  white-space: nowrap;
}

.submenu li a, .submenu li smart {
  padding-left: 1rem;
}

.submenu .submenu li a, .submenu .submenu li smart {
  padding-left: 2rem;
}

.main-nav-desktop {
  display: none;
}

.main-nav-mobile {
  display: flex;
  grid-area: horizontal-nav;
  height: 0;
  overflow: hidden;
  top: 0;
  border-bottom: 1px solid #EBF0F4;
  max-width: 100vw;
  width: 100vw;
  padding: 0 1rem;
}
.main-nav-mobile.active {
  height: 2.5rem;
  overflow: scroll;
  background: var(--white);
  top: var(--header-height);
  transition: 0.25s linear height;
}
.main-nav-mobile a {
  white-space: nowrap;
}

.cta-buttons {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  justify-content: flex-end;
}

.radius {
  border-radius: 100vh;
}

.logo img {
  width: 100%;
  aspect-ratio: 1;
}

@media (min-width: 45em) {
  .nav-container {
    left: 50vw;
  }
  [id|=toggle]:checked + nav[class|=toggle] label[for|=toggle-nav],
  .modal .close-button {
    left: -50vw;
    width: 50vw;
  }
}
@media (min-width: 64em) {
  .nav-container {
    left: 66vw;
  }
  [id|=toggle]:checked + nav[class|=toggle] label[for|=toggle-nav],
  .modal .close-button {
    left: -66vw;
    width: 66vw;
  }
  .logo {
    height: 6.25rem;
    height: 5.75rem;
    transition: 0.25s linear all;
    transform: translateY(1rem);
  }
  .cta-buttons {
    padding-top: 1.5rem;
    height: 3.5rem;
    transition: 0.25s linear all;
  }
  .main-nav-mobile {
    display: none;
  }
  .main-nav-desktop {
    position: relative;
    margin-left: unset !important;
    display: flex;
    height: calc(3rem - 1px);
    transition: 0.25s linear all;
    overflow: hidden;
    max-width: 55.25rem;
    overflow-x: scroll;
    /* Firefox */
    scrollbar-width: none;
    scrollbar-color: var(--grey) var(--white);
  }
  .main-nav-desktop .btn-prev,
  .main-nav-desktop .btn-next {
    background: white;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 2rem;
    height: 3rem;
    padding: 1rem;
    margin-right: 1rem;
    position: sticky;
    left: 0;
    z-index: 100;
    box-shadow: 18px 0 10px -3px white;
    user-select: none;
  }
  .main-nav-desktop .btn-prev.hidden,
  .main-nav-desktop .btn-next.hidden {
    display: none;
    box-shadow: none;
  }
  .main-nav-desktop .btn-next {
    margin: 0 0 0 1rem;
    right: 1rem;
    box-shadow: -18px 0 10px -3px white;
  }
  .main-nav-desktop a {
    position: relative;
    display: flex;
    height: 100%;
    align-items: center;
    color: var(--black);
    white-space: nowrap;
  }
  .main-nav-desktop a.active {
    color: var(--black-darker);
  }
  .main-nav-desktop a:hover:after, .main-nav-desktop a:focus:after, .main-nav-desktop a.active:after {
    content: "";
    border-bottom: 3px solid var(--blue);
    width: 100%;
    position: absolute;
    bottom: 0;
    left: 0;
  }
  .main-nav-desktop a:nth-last-child(2) {
    padding-right: 1rem;
  }
  .header {
    align-items: initial !important;
  }
  .header.stuck {
    --header-height: 3rem;
    height: 3rem;
    transition: 0.25s linear all;
  }
  .header.stuck .logo {
    width: 3.5rem;
    transform: translateY(0.25rem);
    transition: 0.25s linear all;
  }
  .header.stuck .cta-buttons {
    transform: translateY(-3.5rem);
    transition: 0.25s linear all;
    pointer-events: none;
  }
  .header.stuck .main-nav {
    transform: translateY(-3.5rem);
    transition: 0.25s linear all;
  }
  .header .veggiburger {
    position: absolute;
    right: 2rem;
    bottom: -5px;
    padding: 0 2rem 0 1rem;
    background: white;
  }
}
.breadcrumb {
  padding: 0 calc(50% - 31.875rem);
  top: 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  max-width: 100vw;
}
.breadcrumb ul {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  gap: 0.5rem;
  scroll-snap-align: center;
  overscroll-behavior-inline: contain;
  scroll-snap-type: inline mandatory;
  overflow: scroll;
}
.breadcrumb ul li {
  display: flex;
  gap: 0.5rem;
  white-space: nowrap;
}
.breadcrumb ul li:first-of-type {
  padding-left: 1rem;
}
.breadcrumb ul li:last-of-type {
  padding-right: 1rem;
}
.breadcrumb ul a, .breadcrumb ul h1 {
  padding: 1rem 0;
}
.breadcrumb ul a:hover {
  text-decoration: underline;
}
.breadcrumb ul li:not(:last-of-type):after {
  content: "\e908";
  display: block;
  font-family: icomoon;
  padding: 1rem 0;
}

@media (min-width: 64em) {
  .breadcrumb {
    max-width: 71.25rem;
    top: var(--header-height);
  }
  .breadcrumb ul {
    overflow: hidden;
  }
  .breadcrumb li {
    padding: 0 !important;
  }
}
[class*=preload] {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  opacity: 0.75;
}
[class*=preload] > * {
  background: var(--lightgrey);
  border-radius: 0.5rem;
  animation-name: preload;
  animation-iteration-count: infinite;
  animation-duration: 2s;
}
[class*=preload] div:nth-of-type(1) {
  animation: none;
}
[class*=preload] div:nth-of-type(2) {
  height: 3rem;
}
[class*=preload] span:nth-of-type(1) {
  width: 50%;
}
[class*=preload] span:nth-of-type(2) {
  width: 100%;
  animation-delay: calc(1s * var(--r));
  animation-duration: calc(6.4s * var(--r));
}
[class*=preload] span:nth-of-type(3) {
  width: 60%;
  animation-delay: calc(3s * var(--r));
  animation-duration: calc(7.2s * var(--r));
}
[class*=preload] span:nth-of-type(4) {
  width: 90%;
  animation-delay: calc(4s * var(--r));
  animation-duration: calc(9.6s * var(--r));
}
[class*=preload] span:nth-of-type(5) {
  width: 80%;
  animation-delay: calc(0s * var(--r));
  animation-duration: calc(7s * var(--r));
}

@keyframes preload {
  0% {
    opacity: 0.75;
  }
  50% {
    opacity: 0.5;
  }
  100% {
    opacity: 0.75;
  }
}
*:not(.loop-container) [class|=teaser] {
  overflow: hidden;
  border-bottom: 1px solid var(--grey);
  padding-bottom: 1rem;
}
*:not(.loop-container) [class|=teaser].teaser-widget:not(.adslot) {
  border-bottom: unset;
  margin-left: 0.75rem;
  margin-right: 0.75rem;
  margin-bottom: 1rem;
  width: calc(100% - 1.5rem);
  display: inherit;
  padding-bottom: var(--padding-bottom);
}

*:not(.loop-container) .teaser-widget {
  overflow: unset !important;
}

*:not(.article) [class|=teaser] {
  border-bottom: none;
}

.article .teaser-widget:not(.adslot) {
  margin-left: unset !important;
  margin-right: unset !important;
  width: calc(100% + 2rem) !important;
  transform: translateX(-1rem) !important;
}

@media (min-width: 64em) {
  .article .teaser-widget {
    width: 100% !important;
    transform: unset !important;
  }
}
[class|=teaser] {
  background-color: inherit;
}
[class|=teaser] a {
  background-color: inherit;
}
[class|=teaser] button + .headline {
  margin-right: 2rem;
}
[class|=teaser] .headline {
  padding-right: 2rem;
  margin-right: 0;
}
[class|=teaser]:not(.teaser-gallery) .image {
  margin: 0 0.75rem;
}
[class|=teaser]:not(.teaser-gallery) .image figure img,
[class|=teaser]:not(.teaser-gallery) .image picture img {
  border-radius: 0.5rem;
}
[class|=teaser] [data-trigger=bookmarks] {
  right: 0;
  top: 0;
}

@media (min-width: 64em) {
  [class|=teaser]:not([class*=-gallery]) .image,
  [class|=teaser]:not([class*=-dossier]) .image {
    margin: 0;
  }
}
@media (min-width: 64em) {
  [class|=teaser]:not([class*=-top]),
  [class|=teaser]:not([class*=-gallery]),
  [class|=teaser]:not([class*=-dossier]),
  [class|=teaser]:not([class*=-list-small-numbered]),
  [class|=teaser]:not([class*=-list-tiny-numbered]) {
    margin-top: 0;
    border-bottom: unset;
  }
  [class|=teaser] .image {
    margin: 0;
  }
  *:not(.loop-container) [class|=teaser].teaser-widget {
    border-bottom: unset;
    margin-left: unset;
    margin-right: unset;
    width: 100%;
  }
}
@media (max-width: 63.99em) {
  [class*=teaser][class*=-list] > a {
    display: flex;
    flex-wrap: wrap;
  }
  [class*=teaser][class*=-list] > a .image {
    order: 2;
    width: calc(33% - 1 * var(--margin));
    margin-bottom: 1rem;
    margin-right: 1rem;
    margin-left: 0;
    margin-right: 0;
  }
  [class*=teaser][class*=-list] > a .headline {
    order: 1;
    width: calc(66% - 1 * var(--margin));
    margin-top: 0;
  }
  [class*=teaser][class*=-list] > a .headline [data-trigger=bookmarks] {
    display: none;
  }
  [class*=teaser][class*=-list] > a .text {
    order: 3;
    width: calc(100% - 1 * var(--margin));
  }
}
[class*=teaser][class*=-list-small] > a {
  padding: 1rem 0;
  border-bottom: 1px solid var(--lightgrey);
  display: grid;
  grid-template-columns: 1fr 5.5rem;
  grid-template-rows: 1fr;
  column-gap: 1rem;
}
[class*=teaser][class*=-list-small] > a .image {
  width: 5.5rem;
  margin: 0;
  grid-row: 1/2;
  grid-column: 2;
}
[class*=teaser][class*=-list-small] > a .headline {
  grid-column: 1/-1;
}
[class*=teaser][class*=-list-small] > a .image ~ .headline {
  padding: 0;
  margin: 0;
  grid-column: 1;
}
[class*=teaser][class*=-list-small] > a .author > *:not(.commentWrapper) {
  display: none;
}

@media (min-width: 64em) {
  [class|=teaser] {
    border-bottom: unset;
    margin-bottom: unset;
  }
  [class|=teaser].teaser-widget {
    margin-left: unset;
    margin-right: unset;
    width: 100%;
  }
  [class*=teaser][class*=-list-small] > a {
    padding: 1rem 0;
    border-bottom: 1px solid var(--lightgrey);
    display: grid;
    grid-template-columns: 11rem 1fr;
    grid-template-rows: 1fr;
    column-gap: 1rem;
  }
  [class*=teaser][class*=-list-small] > a .image {
    width: 11rem;
    margin: 0;
    grid-row: 1/3;
    grid-column: 1;
  }
  [class*=teaser][class*=-list-small] > a .headline {
    grid-column: 1/-1;
  }
  [class*=teaser][class*=-list-small] > a .image ~ .headline {
    padding-top: 0.25rem;
    margin-top: 0.75rem;
    grid-column: 2;
  }
  [class*=teaser][class*=-list-small] > a .author {
    display: flex;
    grid-column: 1/-1;
    min-height: unset;
    line-height: unset;
  }
  [class*=teaser][class*=-list-small] > a .image ~ .author {
    grid-row: 2;
    grid-column: 2;
    margin: 0;
  }
}
[class*=teaser][class*=-newsticker] {
  display: grid;
  grid-template-columns: 3.875rem 1fr;
  grid-template-rows: 1fr;
  column-gap: 1rem;
  padding: 0 1rem 2rem 1rem;
  border: unset;
  position: relative;
}
[class*=teaser][class*=-newsticker]:not(:last-of-type):after {
  content: "";
  border-left: 1px solid var(--blue);
  position: absolute;
  top: 0;
  bottom: 0;
  left: 2.9375rem;
  width: 1px;
  z-index: 1;
  opacity: 0.3;
}
[class*=teaser][class*=-newsticker] .time-bubble {
  border-radius: 100vh;
  height: 1.625rem;
  width: 3.875rem;
  z-index: 2;
}

[class*=teaser][class*=-list-small-numbered] {
  border-bottom: 0;
}
[class*=teaser][class*=-list-small-numbered] > a {
  padding: 0.75rem 0;
  display: grid;
  grid-column-gap: 1rem;
  grid-template-columns: auto 1fr;
  border-bottom: 0;
}
[class*=teaser][class*=-list-small-numbered] > a .image {
  width: 100px;
  margin: 0;
  grid-column: 1;
  grid-row: 1/3;
}
[class*=teaser][class*=-list-small-numbered] > a .headline {
  padding: 0.5rem 0;
  grid-column: 2;
  grid-row: 1/2;
}
[class*=teaser][class*=-list-small-numbered] > a .headline .catchword {
  margin-bottom: 0.5rem;
}
[class*=teaser][class*=-list-small-numbered] > a .headline .catchword:before {
  content: attr(data-number);
  display: inline-flex;
  width: 1.25rem;
  height: 1.25rem;
  align-items: center;
  justify-content: center;
  border-radius: 100%;
  color: var(--white);
  background-color: var(--blue);
  box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
  margin-right: 0.5rem;
}
[class*=teaser][class*=-list-small-numbered] > a .author {
  grid-column: 2;
  grid-row: 2/3;
  min-height: unset;
}

[class*=teaser][class*=-list-tiny] {
  border-bottom: 0;
  padding: 0 0.7rem;
}
@media (min-width: 45em) {
  [class*=teaser][class*=-list-tiny] {
    padding: 0;
  }
}
[class*=teaser][class*=-list-tiny] > a {
  padding: 0.75rem 0;
  display: grid;
  grid-column-gap: 1rem;
  grid-template-columns: auto 1fr;
  border-bottom: 0;
  margin-bottom: 0.3rem;
}
[class*=teaser][class*=-list-tiny] > a .image {
  width: 80px;
  min-width: 80px;
  margin: 0;
  grid-column: 1;
  grid-row: 1/3;
}
[class*=teaser][class*=-list-tiny] > a .image .vignette, [class*=teaser][class*=-list-tiny] > a .image .icon-zoom {
  display: none;
}
[class*=teaser][class*=-list-tiny] > a .headline {
  padding: 0.15rem 0;
  grid-column: 2;
  grid-row: 1/2;
  min-width: 0;
  overflow-wrap: break-word;
  word-break: break-word;
}
[class*=teaser][class*=-list-tiny] > a .headline .catchword {
  padding-bottom: 0.2rem;
  margin-bottom: 0.2rem;
  min-width: inherit;
  overflow-wrap: inherit;
  word-break: inherit;
}
[class*=teaser][class*=-list-tiny] > a .author {
  grid-column: 2;
  grid-row: 2/3;
  min-height: unset;
}

[class*=teaser][class*=-list-tiny-numbered] > a .headline {
  display: flex;
}
[class*=teaser][class*=-list-tiny-numbered] > a .headline::before {
  content: attr(data-number);
  font-size: 12px;
  display: inline-flex;
  width: 1.5em;
  min-width: 1.5em;
  height: 1.5em;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  color: var(--white);
  background-color: var(--blue);
  box-shadow: 0 2px 2px rgba(0, 0, 0, 0.2);
  margin-top: -0.2em;
  margin-right: 0.5rem;
}
[class*=teaser][class*=-list-tiny-numbered] > .commentWrapper {
  display: none;
}

[class*=teaser][class*=-list-tiny-sidebar] > a {
  width: 300px;
  max-width: 300px;
  grid-template-columns: 1fr auto;
  grid-column-gap: 0.2em;
}
[class*=teaser][class*=-list-tiny-sidebar] > a .image {
  grid-column: 2;
  grid-row: 1/2;
}
[class*=teaser][class*=-list-tiny-sidebar] > a .headline {
  grid-column: 1;
  grid-row: 1/3;
}
[class*=teaser][class*=-list-tiny-sidebar] > a .headline .catchword {
  padding-right: 0;
}
[class*=teaser][class*=-list-tiny-sidebar] > a .authors-container {
  grid-row: 2/3;
  justify-content: flex-end;
}
[class*=teaser][class*=-list-tiny-sidebar] > a .authors-container .commentWrapper {
  margin-top: 0.7em;
}

.bg-blue .slot_1-col [class*=teaser][class*=-super] > a header,
.bg-blue .slot_1-col [class*=teaser][class*=-top] > a header {
  color: var(--white) !important;
}
.bg-blue .slot_1-col [class*=teaser][class*=-super] > a header .catchword,
.bg-blue .slot_1-col [class*=teaser][class*=-top] > a header .catchword {
  color: var(--white) !important;
}
.bg-blue .slot_1-col [class*=teaser][class*=-super] > a .text,
.bg-blue .slot_1-col [class*=teaser][class*=-top] > a .text {
  color: var(--white);
}
.bg-blue .slot_1-col [class*=teaser][class*=-super] .author > *,
.bg-blue .slot_1-col [class*=teaser][class*=-top] .author > * {
  color: var(--white) !important;
}
.bg-blue .slot_1-col [class*=teaser][class*=-super] .names > *,
.bg-blue .slot_1-col [class*=teaser][class*=-top] .names > * {
  color: var(--white) !important;
}
.bg-blue .slot_1-col [class*=teaser][class*=-super] [data-trigger=bookmarks],
.bg-blue .slot_1-col [class*=teaser][class*=-top] [data-trigger=bookmarks] {
  color: var(--white) !important;
}
.bg-blue .slot_1-col [class*=teaser][class*=-top] > a header .catchword {
  color: var(--white) !important;
}
.bg-blue .slot_1-col [class*=teaser][class*=-top] > a .text {
  color: var(--white);
}
.bg-blue .slot_1-col [class*=teaser][class*=-top] [data-trigger=bookmarks] {
  color: var(--white) !important;
}

@media (min-width: 64em) {
  .slot_1-col [class*=teaser][class*=-super],
  .slot_1-col [class*=teaser][class*=-top] {
    margin-top: 1rem;
    display: grid;
    grid-template-rows: auto auto 4.25rem;
    grid-template-columns: 1fr 1fr 4rem;
  }
  .slot_1-col [class*=teaser][class*=-super] > a,
  .slot_1-col [class*=teaser][class*=-top] > a {
    display: grid;
    grid-template-rows: 1fr auto 3.25rem;
    grid-template-columns: 1fr 1fr 1rem;
    grid-column: 1/-1;
    grid-row: 1/-1;
  }
  .slot_1-col [class*=teaser][class*=-super] > a .image,
  .slot_1-col [class*=teaser][class*=-top] > a .image {
    grid-column: 1/-1;
    grid-row: 1/-1;
    z-index: 1;
  }
  .slot_1-col [class*=teaser][class*=-super] > a header,
  .slot_1-col [class*=teaser][class*=-top] > a header {
    position: unset !important;
    grid-column: 2/3;
    grid-row: 1;
    z-index: 3;
    align-self: end;
    color: var(--white) !important;
  }
  .slot_1-col [class*=teaser][class*=-super] > a header .catchword,
  .slot_1-col [class*=teaser][class*=-top] > a header .catchword {
    color: var(--white) !important;
  }
  .slot_1-col [class*=teaser][class*=-super] > a .text,
  .slot_1-col [class*=teaser][class*=-top] > a .text {
    grid-column: 2/3;
    grid-row: 2;
    z-index: 3;
    color: var(--white);
    font-size: 0.875rem;
    font-family: merriweather;
  }
  .slot_1-col [class*=teaser][class*=-super] .author,
  .slot_1-col [class*=teaser][class*=-top] .author {
    grid-row: 3;
    grid-column: 2/3;
    z-index: 3;
    margin-left: 2rem;
  }
  .slot_1-col [class*=teaser][class*=-super] .author > *,
  .slot_1-col [class*=teaser][class*=-top] .author > * {
    color: var(--white) !important;
  }
  .slot_1-col [class*=teaser][class*=-super] .names > *,
  .slot_1-col [class*=teaser][class*=-top] .names > * {
    color: var(--white) !important;
  }
  .slot_1-col [class*=teaser][class*=-super]::after,
  .slot_1-col [class*=teaser][class*=-top]::after {
    content: "";
    width: 66%;
    opacity: 0.8;
    background: linear-gradient(90deg, rgba(0, 0, 0, 0), #000);
    grid-row: 1/-1;
    grid-column: 1/-1;
    border-radius: 0.5rem;
    justify-self: end;
    z-index: 2;
  }
  .slot_1-col [class*=teaser][class*=-super] [data-trigger=bookmarks],
  .slot_1-col [class*=teaser][class*=-top] [data-trigger=bookmarks] {
    color: var(--white) !important;
    right: 1rem;
    bottom: 1rem;
    font-size: 1.5rem;
    top: unset;
  }
  .slot_1-col [class*=teaser][class*=-top] > a {
    grid-template-columns: 1fr 3.75rem 1fr;
    grid-template-rows: auto 1fr 3.25rem;
    --margin: 0;
    --margin-top: 3rem;
    --margin-bottom: 1rem;
  }
  .slot_1-col [class*=teaser][class*=-top] > a .image {
    grid-column: 1/3;
    grid-row: 1/-1;
    z-index: 1;
  }
  .slot_1-col [class*=teaser][class*=-top] > a header {
    grid-column: 3;
    grid-row: 1;
    z-index: 3;
    align-self: start;
    color: var(--white);
  }
  .slot_1-col [class*=teaser][class*=-top] > a header .catchword {
    color: var(--white) !important;
  }
  .slot_1-col [class*=teaser][class*=-top] > a .text {
    grid-column: 3;
    grid-row: 2;
    z-index: 3;
    color: var(--white);
    padding-right: 1.75rem;
    font-size: 0.875rem;
  }
  .slot_1-col [class*=teaser][class*=-top] .author {
    grid-row: 3;
    grid-column: 2/3;
    z-index: 3;
    margin-left: 3rem;
    padding-left: 1rem;
    padding-bottom: 2rem;
  }
  .slot_1-col [class*=teaser][class*=-top]::after {
    background: var(--blue);
    margin: 1rem 0;
    width: 50%;
    opacity: 1;
  }
  .slot_1-col [class*=teaser][class*=-top] [data-trigger=bookmarks] {
    color: var(--white) !important;
    bottom: 3.6rem;
    top: unset;
  }
}
[class*=teaser][class*=-dossier] > a,
[class*=teaser][class*=-gallery] > a {
  display: grid;
  gap: 0.5rem;
  grid-template-rows: min-content;
  scroll-snap-align: start;
  position: relative;
  border-radius: 0.5rem;
  overflow: hidden;
  grid-column: span 1;
}
[class*=teaser][class*=-dossier] > a img,
[class*=teaser][class*=-gallery] > a img {
  inline-size: 100%;
  object-fit: cover;
}
[class*=teaser][class*=-dossier] > a header.headline,
[class*=teaser][class*=-gallery] > a header.headline {
  position: absolute !important;
  background-color: unset !important;
  left: 0;
  right: 0;
  bottom: 0;
  color: var(--white);
  background: linear-gradient(0deg, rgba(9, 15, 23, 0.5), transparent);
  padding: 3rem 0.5rem 0.5rem 0.5rem;
}
[class*=teaser][class*=-dossier] > a header.headline span,
[class*=teaser][class*=-gallery] > a header.headline span {
  color: inherit !important;
  display: block;
}

.bulletin a {
  display: flex;
  flex-direction: column;
}
.bulletin a > * {
  padding: 1rem;
  align-items: center;
}
.bulletin a::before {
  content: "EILMELDUNG";
  width: auto;
  background: var(--orange);
  align-items: center;
  text-align: center;
  color: var(--white);
  display: flex;
  padding: 1rem;
  font-family: work-bold;
  letter-spacing: 0.0625rem;
  font-size: 0.75rem;
}

@media (min-width: 64em) {
  .bulletin {
    border-radius: 0.5rem;
  }
  .bulletin a {
    flex-direction: row;
  }
  .bulletin a::before {
    text-align: center;
    border-radius: 0.5rem 0 0 0.5rem;
  }
}
.author > * {
  display: inline-flex;
  align-items: center;
}
.author .comments:not(:first-child):before,
.author .place:not(:first-child):before {
  content: " - ";
  margin: 0.25rem;
}
.author .comments > * {
  margin-left: 0.25rem;
}
.author .article-dates {
  margin-left: 0.5rem;
  display: flex;
  position: relative;
}
.author .article-dates [class*=icon] {
  transform: rotate(90deg);
  display: inline-flex;
  margin-left: 2rem;
  width: 1.25rem;
  aspect-ratio: 1;
  background: var(--lightblue);
  border-radius: 50%;
  align-items: center;
  justify-content: center;
  color: var(--blue);
  transition: 0.25s linear transform;
}
.author .article-dates .lastMod {
  top: 1.5em;
  display: none;
  white-space: nowrap;
}
.author .article-dates input:checked ~ .lastMod {
  display: block;
}
.author .article-dates input:checked ~ div > label {
  transform: rotate(-90deg);
  transition: 0.25s linear transform;
}

[class*=-mega] > .author, [class*=-top] > .author, [class*=-half] > .author {
  display: flex;
}

/*****************
 * * article-types
 * *****************/
.live, ._opinion, .leserbrief, .advertorial {
  position: relative;
}
.live .catchword:before, ._opinion .catchword:before, .leserbrief .catchword:before, .advertorial .catchword:before {
  height: 1.25rem;
  width: auto;
  display: inline-flex;
  align-items: center;
  border-radius: 0.625rem;
  color: #FFFFFF;
  background: #006DB0;
  font-weight: 200;
  font-size: 0.75rem;
  margin-right: 0.5rem;
  padding: 0 0.5rem;
  font-family: work;
  white-space: nowrap;
}

.leserbrief .headline {
  font-style: italic;
}
.leserbrief .catchword:before {
  content: "LESERBRIEF";
  font-style: normal;
}

.opinion .headline {
  font-style: italic;
}
.opinion .catchword {
  font-style: normal;
}
.opinion ._catchword:before {
  content: "MEINUNG";
  font-style: normal;
}
.opinion_avatar img {
  position: absolute;
  width: 4.5rem;
  aspect-ratio: 1;
  z-index: 1;
  border-radius: 100vh;
  border: 3px solid var(--white);
  right: 1rem;
  bottom: -1rem;
}

.teaser-top .opinion_avatar img,
.teaser-super .opinion_avatar img {
  bottom: 1.5rem;
}

@media (min-width: 64em) {
  .teaser-top .opinion_avatar img {
    bottom: -1rem;
  }
  .teaser-top .opinion_avatar img,
  .teaser-super .opinion_avatar img {
    display: none;
  }
}
[class*=teaser][class*=-list].opinion .catchword:before {
  display: flex;
  width: fit-content;
}

.live .catchword:before {
  padding: 0 0.5rem 0 1.5rem;
  content: "LIVE";
  background: var(--orange);
}
.live .catchword:after {
  content: "";
  position: absolute;
  display: block;
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 50%;
  background: var(--white);
  left: 0.5rem;
  top: calc(50% - 0.25rem + 1px);
  top: 0.75rem;
  animation-name: blink;
  animation-iteration-count: infinite;
  animation-duration: 2s;
}

.advertorial .catchword {
  color: var(--grey) !important;
}
.advertorial .catchword:before {
  content: "ANZEIGE";
  font-style: normal;
  background: var(--grey);
  color: var(--white);
}

.vignette {
  display: none;
}
.vignette.inArticle {
  display: inline-flex;
  position: absolute;
  bottom: 1rem;
  padding: 0.0375rem 1rem;
  border-top-right-radius: 100vh;
  border-bottom-right-radius: 100vh;
}

[class*=teaser-top] .vignette,
[class*=teaser-super] .vignette,
[class*=teaser-default] .vignette,
[data-res=isDesktop] [class*=teaser-list] .vignette {
  display: flex;
  position: absolute;
  left: 0;
  bottom: 0.5rem;
  padding: 0.0375rem 1rem;
  transform: translateX(-0.25rem);
  border-top-right-radius: 100vh;
  border-bottom-right-radius: 100vh;
}

@media (max-width: 63.99em) {
  [class*=teaser-top] .image,
  [class*=teaser-super] .image {
    margin: 0 !important;
    margin-bottom: -2.25rem !important;
  }
  [class*=teaser-top] .image figure img,
  [class*=teaser-top] .image picture img,
  [class*=teaser-super] .image figure img,
  [class*=teaser-super] .image picture img {
    border-radius: 0 !important;
  }
  [class*=teaser-top] .headline,
  [class*=teaser-super] .headline {
    margin-right: 0.5rem;
  }
  [class*=teaser-top] header,
  [class*=teaser-super] header {
    background-color: inherit;
    padding: 1rem;
    margin: 0 0.5rem;
    border-radius: 0.25rem;
    position: relative;
  }
  [class*=teaser-top] header [data-trigger=bookmarks],
  [class*=teaser-super] header [data-trigger=bookmarks] {
    top: 0.5rem;
  }
  [class*=teaser-top] .vignette,
  [class*=teaser-super] .vignette {
    bottom: 2.75rem;
  }
}
[class*=-gallery] .videostory:before,
[class*=-gallery] ._gallerystory:before {
  content: "\e90e";
  font-family: icomoon;
  position: absolute;
  color: var(--white);
  top: 50%;
  left: 50%;
  font-size: 1.5rem;
  z-index: 1;
  transform: translate(-50%, -50%);
}
[class*=-gallery] .videostory:after,
[class*=-gallery] ._gallerystory:after {
  content: "";
  width: 3.75rem;
  aspect-ratio: 1;
  border-radius: 100%;
  background: var(--blue);
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.2);
}
[class*=-gallery] .gallerystory:before {
  content: "\e90e";
}

@keyframes blink {
  0% {
    background: var(--white);
  }
  50% {
    background: var(--orange);
  }
  100% {
    background: var(--white);
  }
}
[class*=teaser] {
  position: relative;
  width: 100%;
}
[class*=teaser] .catchword {
  padding-right: 2rem;
  padding-bottom: 0.5rem;
}
[class*=teaser] .headlines {
  position: absolute;
  bottom: 0;
  width: 100%;
  padding: 6rem 1rem 1rem 1rem;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0), var(--imgcolor, rgba(0, 0, 0, 0)) 5rem);
  transition: ease 0.5s background;
  color: var(--txtcolor, var(--black));
}
[class*=teaser] .headlines span {
  display: block;
}
[class*=teaser] .headlines > * {
  padding: 5rem 1rem 1rem 1rem;
  padding: 0 0 0 0;
}

.no-teaser [class*=teaser] .text {
  display: none;
}

.article {
  padding: 1rem;
  display: grid;
  grid-template-columns: auto;
  grid-template-rows: auto;
  grid-auto-rows: min-content;
  grid-template-areas: "head" "source" "teaser" "author" "image" "summary" "body" "questions" "footer" "topics";
  column-gap: 1rem !important;
  row-gap: 0 !important;
  align-items: start;
}
.article .article-body .c-box {
  transform: translateX(-1rem);
  max-width: calc(100vw - 2rem);
}
.article h2 {
  grid-area: head;
}
.article h2 span {
  color: var(--blue);
  display: block;
  text-transform: uppercase;
  line-height: 1em;
  margin-bottom: 1.5em;
}
.article h3 {
  font-weight: 600;
  padding-bottom: 1.5em;
  padding-bottom: 1.5em;
}
.article .source {
  grid-area: source;
}
.article > .image {
  overflow: hidden;
  grid-area: image;
  margin: 1.5rem 0 2.5rem 0;
  width: calc(100% + 2rem);
  border-radius: unset;
  transform: translateX(-1rem);
}
.article > *:not(.carousel):not(.article-body) .image {
  transform: unset;
  width: calc(100% + 0rem);
}
.article section:not(.teaser-list-small) .image {
  transform: translateX(-1rem);
}
.article .carousel {
  grid-area: image;
}
.article .article-teaser {
  font-weight: bold;
  grid-area: teaser;
  margin-bottom: 0;
  margin-top: 1rem;
}
.article .article-summary {
  grid-area: summary;
}
.article .article-questions {
  grid-area: questions;
}
.article .article-body {
  grid-area: body;
  overflow-wrap: break-word;
  word-break: break-word;
}
.article .article-body .image {
  margin-bottom: 1rem;
  width: calc(100% + 2rem);
  transform: translateX(-1rem);
}
.article .article-body .teaser-list-small .image {
  transform: unset;
}
.article p, .article .inline-opportunity, .article .embed {
  margin-bottom: 1.5em;
}
.article .article-side {
  grid-area: side;
}
.article .article-image-side {
  grid-area: image-side;
}
.article .article-side:not(.show-tablet), .article .article-side:not(.show-mobile), .article .article-image-side:not(.show-tablet), .article .article-image-side:not(.show-mobile) {
  display: none;
}
.article .article-footer {
  grid-area: footer;
}
.article .article-topics {
  grid-area: topics;
}
.article .author {
  grid-area: author;
}
.article .question {
  font-weight: 600;
}
.article .answer .name {
  display: inline-block;
  font-weight: 600;
}
.article .answer .name::after {
  content: ":";
  display: inline-block;
  margin-right: 0.25rem;
}
.article .inline-oppertunity {
  height: 1rem;
  width: 100%;
  display: block;
  background: var(--grey);
}
.article .vertical-lines {
  padding: 1rem;
  margin: 1rem 0;
  width: calc(100% + 2rem);
  transform: translateX(-1rem);
}
.article .article-body .vertical-lines {
  border-top: 1px solid var(--lightgrey);
  border-bottom: 1px solid var(--lightgrey);
}
.article ul {
  margin-left: 1.5rem;
  margin-bottom: 1.5em;
}
.article li {
  position: relative;
}
.article li:before {
  content: "•";
  font-weight: bold;
  color: var(--blue);
  font-size: calc(var(--fs) * 2);
  display: inline-block;
  position: absolute;
  left: -1.5rem;
}

@media (min-width: 64em) {
  .article {
    --sidebar-width: 300px;
    padding: 0;
    display: grid;
    grid-template-columns: auto;
    grid-template-rows: auto;
    grid-template-areas: "head" "source" "author" "image" "summary" "teaser" "body" "questions" "footer" "topics";
    column-gap: 2rem !important;
    row-gap: 0 !important;
  }
  .article:has(.article-side) {
    grid-template-columns: calc(720px - 2rem) var(--sidebar-width);
    grid-template-areas: "head head" "source source" "author author" "image image-side" "summary side" "teaser side" "body side" "questions side" "footer footer" "topics topics";
  }
  .article .vertical-lines {
    border-top: 1px solid var(--lightgrey);
    border-bottom: 1px solid var(--lightgrey);
    padding: 1rem 0;
    margin: 1rem 0;
    width: 100%;
    transform: unset;
  }
  .article .image {
    width: 100%;
    border-radius: 0.5rem;
    transform: unset;
  }
  .article .static {
    width: 63.75rem !important;
  }
  .article .article-body .c-box {
    transform: unset;
  }
  .article .article-body .image {
    width: inherit;
    transform: unset;
  }
  .article .article-side, .article .article-image-side {
    min-width: var(--sidebar-width);
    max-width: var(--sidebar-width);
  }
  .article .article-side:not(.hide-desktop), .article .article-image-side:not(.hide-desktop) {
    display: flex;
  }
}
/* elements inside article */
.article .infobox {
  background-color: var(--lightblue);
  color: var(--blue);
  padding: 0.5rem;
  border-radius: 0.5rem;
  margin-bottom: 1.5em;
  width: calc(100% + 1rem);
  transform: translateX(-0.5rem);
}

@media (min-width: 64em) {
  .article .article-teaser {
    margin-top: 0;
    margin-bottom: 1.5rem;
  }
  .article .carousel {
    max-width: 100%;
  }
  .article .infobox {
    padding: 1rem;
    width: 100%;
    transform: unset;
  }
}
.article.advertorial .catchword:before {
  content: "ANZEIGE";
}

.article-side {
  display: grid;
  row-gap: 1rem;
}
.article-side .sticky-container {
  position: static;
}
.article-side .sticky-container > *:first-child {
  position: sticky;
  top: calc(var(--header-height) + var(--header-height) + 2rem);
}

@media (min-width: 64em) {
  .article-side {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  }
}
.article-topics .topic-list {
  overflow: hidden;
  max-height: 12rem;
}
.article-topics .topic-list.show-all {
  max-height: unset;
  overflow: unset;
}

.authors {
  display: flex;
  flex-direction: row;
  align-items: center;
  --overlap-value: 0.5rem;
  --img-size: 2.5rem;
}
.authors .avatars {
  display: inline-flex;
  margin-right: 0.5rem;
}
.authors .avatars img.profile + img.profile {
  transform: translateX(-1rem);
  margin-right: -1rem;
}
.authors .avatars img.profile + img.profile ~ * {
  transform: translateX(-1rem);
  margin-right: -1rem;
}
.authors .avatars img {
  width: var(--img-size);
  aspect-ratio: 1;
  border-radius: 100vh;
  box-shadow: 0 0.25rem 0.5rem -0.25rem rgba(9, 15, 23, 0.5);
}
.authors .names > *:not(:first-child)::before {
  content: ",";
  display: inline-block;
  margin-right: 0;
  margin-left: -0.25rem;
}
.authors .names > *:not(:nth-child(-n+2)) {
  display: none;
}
.authors .names > *:nth-child(2):not(:last-child)::after {
  content: " und weitere ";
  margin-right: 0.25rem;
}
.authors a {
  text-decoration: none;
}

.authors-container {
  display: flex;
  align-items: center;
}

.place::before {
  content: " - ";
}

.dates {
  margin-left: 0.5rem;
  display: flex;
  flex-direction: column;
  position: relative;
}
.dates [class*=icon] {
  transform: rotate(90deg);
  display: inline-flex;
  margin-left: 2rem;
  width: 1.25rem;
  aspect-ratio: 1;
  background: var(--lightblue);
  border-radius: 50%;
  align-items: center;
  justify-content: center;
  color: var(--blue);
  transition: 0.25s linear transform;
}
.dates .lastMod {
  position: absolute;
  top: 1.5em;
  left: 0;
  display: none;
  white-space: nowrap;
}
.dates input:checked ~ .lastMod {
  display: block;
}
.dates input:checked ~ div > label {
  transform: rotate(-90deg);
  transition: 0.25s linear transform;
}

.cloned-comment-icon {
  min-width: 48px !important;
  height: 48px !important;
  margin-right: 0.5rem;
  border-radius: 100% !important;
  border: none;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  filter: drop-shadow(0 2px 4px rgba(34, 36, 38, 0.35));
  position: fixed;
  left: 0.7rem;
  bottom: 60px;
  z-index: 99999;
}
.cloned-comment-icon svg {
  transform: scale(1.8) translateY(1px) !important;
}

.contentport {
  position: relative;
  border-bottom: 0.5rem solid var(--lightblue);
  column-gap: 1rem;
  row-gap: 0rem;
}
.contentport-header:first-of-type {
  border-top: none;
}
.contentport-header, .contentport-footer {
  display: flex;
  min-height: 5rem;
  max-height: 8rem;
  align-items: center;
  border-top: 1px solid var(--grey);
  border-bottom: 1px solid var(--grey);
  margin-bottom: 1rem;
  transition: 0.25s linear height;
  overflow: hidden;
}
.contentport-header.stuck, .contentport-footer.stuck {
  height: 2.5rem;
  padding: 0 1rem;
  transition: 0.25s linear height, 0.25s linear padding;
}
.contentport-header.stuck a, .contentport-header.stuck div, .contentport-footer.stuck a, .contentport-footer.stuck div {
  font-size: 1rem !important;
  transition: 0.25s linear font-size;
}
.contentport-header a, .contentport-footer a {
  display: flex;
  height: 100%;
  transition: 0.25s linear font-size;
}
.contentport-footer {
  height: 2.5rem;
  padding: 0;
  margin-top: -2rem;
}
.contentport-footer > * {
  margin: 0 1rem;
}
.contentport .sentinal {
  position: absolute;
  height: 1px;
  width: 1px;
  top: calc((var(--header-height) + 10px) * -1);
  visibility: hidden;
  pointer-events: none;
}
.contentport-footer {
  background: var(--lightblue);
  color: var(--blue);
}
@media (min-width: 64em) {
  .contentport-footer.more-btn-footer {
    background: linear-gradient(to right, transparent 0 40px, var(--lightblue) 40px 100%);
  }
}
.contentport-header {
  display: grid;
  grid-template-rows: 1fr auto;
  grid-template-columns: auto 1fr;
}
.contentport-header .navi {
  overflow-y: hidden;
  overflow-x: scroll;
  scroll-snap-align: left;
  scroll-snap-type: x mandatory;
  display: flex;
  flex-direction: row;
  gap: 1rem;
  grid-row: 2/-1;
  margin: 0 0 1rem 0;
  padding: 0 1.5rem;
}
.contentport-header .navi li {
  padding: 0.5rem;
  border-radius: 100vh;
  background: var(--lightblue);
  transition: 0.25s linear all;
}
.contentport-header .navi li a {
  color: var(--blue);
  cursor: pointer;
}
.contentport-header .navi li.active {
  background: var(--blue);
}
.contentport-header .navi li.active a {
  color: var(--white);
}
.contentport-header-title {
  grid-column: 1/2;
  grid-row: 1/1;
  margin: 1.5rem;
}
@media (min-width: 64em) {
  .contentport-header-title {
    width: unset !important;
  }
}
.contentport-header > span {
  grid-row: 1/1;
  grid-column: 2/3;
  margin: 1.5rem;
  margin-left: auto;
}

@media (min-width: 45em) {
  .contentport {
    width: 100%;
    padding: 0 1rem 1rem 1rem;
  }
}
@media (min-width: 64em) {
  .contentport {
    width: 100%;
    padding: 2rem calc(50% - 31.875rem) 2rem;
    border-bottom: unset;
  }
  .contentport-header {
    border-bottom: 3px solid currentColor;
    display: flex;
  }
  .contentport-header .navi {
    margin: 0 1rem;
    overflow-y: unset;
    overflow-x: hidden;
    scroll-snap-align: unset;
    scroll-snap-type: unset;
    width: 100%;
    padding: unset;
  }
  .contentport-header-title {
    margin: 1rem 0;
  }
  .contentport-footer {
    display: flex;
    min-height: unset;
    border-radius: 100vh;
    border: none;
    position: relative;
    margin-bottom: 1rem;
  }
  .contentport-footer-link {
    display: inline-flex !important;
    background: var(--blue);
    color: var(--white) !important;
    border-radius: 1.5rem;
    padding: 1rem;
    margin: 0;
    width: auto !important;
  }
  .contentport-footer:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    background: linear-gradient(90deg, transparent, var(--lightblue) 80%);
    height: 3rem;
    width: 5rem;
    display: block;
  }
  .contentport .navi .navi-toggler {
    display: flex !important;
    margin-left: auto;
    padding: 0;
    aspect-ratio: 1;
    height: 100%;
    align-items: center;
    justify-content: center;
  }
  .contentport .navi .navi-toggler label:before {
    transition: 0.25s linear transform;
    transform: rotate(90deg);
    display: block;
  }
  .contentport .navi .invis {
    display: none;
  }
  .contentport .navi input:checked ~ .invis {
    display: block;
  }
  .contentport .navi input:checked ~ .navi-toggler label:before {
    transition: 0.25s linear transform;
    transform: rotate(-90deg);
  }
  .contentport .navi input:checked ~ li:not(.invis) {
    display: none;
  }
}
.template {
  display: grid;
  grid-column: 1/-1;
  background: inherit;
}
.template:first-of-type {
  margin-top: 1rem;
  margin-top: 0;
}
.template:last-of-type {
  margin-bottom: 1rem;
}
.template[class*=slot_] {
  grid-gap: 0rem;
}

@media (min-width: 45em) {
  .contentport {
    column-gap: 2rem;
    row-gap: 2rem;
  }
  .template[class*=slot_] {
    grid-gap: 2rem;
  }
  .template.slot_2-col, .template.slot_3-col, .template.slot_top-basic, .template.slot_top-widget, .template.slot_top-widget-extended {
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 2rem;
  }
  .template:first-of-type {
    margin-top: 0.5rem;
  }
  .template:last-of-type {
    margin-bottom: 0.5rem;
  }
}
@media (min-width: 64em) {
  .template[class*=slot_] {
    grid-gap: 3.75rem;
  }
  .template:first-of-type {
    margin-top: 0.5rem;
  }
  .template:last-of-type {
    margin-bottom: 0.5rem;
  }
  .template.slot_2-col {
    grid-template-columns: repeat(2, 1fr);
  }
  .template.slot_3-col {
    grid-template-columns: repeat(3, 1fr);
  }
  .template.slot_top-basic {
    grid-template-columns: repeat(3, 1fr);
  }
  .template.slot_top-basic > *:first-child {
    grid-row: 1/-1;
    grid-column: 1/3;
  }
  .template.slot_top-widget {
    grid-template-columns: 1fr 1fr 1fr;
    grid-template-rows: minmax(200px, auto) auto;
  }
  .template.slot_top-widget > *:first-child {
    grid-row: 1/-1;
    grid-column: 1/3;
  }
  .template.slot_top-widget > *:nth-child(2) {
    grid-row: 1;
    grid-column: 3/4;
  }
  .template.slot_top-widget > *:nth-child(3) {
    grid-row: 2;
    grid-column: 3/4;
  }
  .template.slot_top-widget-extended {
    grid-template-columns: 1fr 1fr 1fr;
  }
  .template.slot_top-widget-extended > *:first-child {
    grid-row: 1/3;
    grid-column: 1/3;
  }
  .template.slot_top-widget-extended > *:nth-child(2) {
    grid-row: 3/4;
    grid-column: 1/2;
  }
  .template.slot_top-widget-extended > *:nth-child(3) {
    grid-row: 3/4;
    grid-column: 2/3;
  }
  .template.slot_top-widget-extended > *:nth-child(4) {
    grid-row: 1/2;
    grid-column: 3/4;
  }
  .template.slot_top-widget-extended > *:nth-child(4) {
    grid-row: 2/4;
    grid-column: 3/4;
  }
}
section.contentport[data-contentport-name^="Piano Below Article"]:has(.template):not(:has(.template div)),
section.contentport[data-contentport-name^="Piano Below Article"] + section.contentport:has(.template > div.piano-target-rec:empty) {
  margin: 0 !important;
  padding: 0;
}
section.contentport[data-contentport-name^="Piano Below Article"]:has(.template):not(:has(.template div)) > section,
section.contentport[data-contentport-name^="Piano Below Article"] + section.contentport:has(.template > div.piano-target-rec:empty) > section {
  margin: 0;
}

.modal {
  transform: translateX(100%);
  transition: 0.25s ease-out transform, 0.25s linear box-shadow;
  position: fixed;
  height: 100%;
  right: 0;
  top: 0;
  left: 0;
  z-index: 100000;
  box-shadow: none;
  grid-template-rows: 3.75rem auto;
  overflow: unset;
  border-radius: unset;
  background: var(--white);
}
.modal-wrapper {
  overflow-x: none;
  overflow-y: scroll;
  height: 100%;
}
.modal:before {
  content: "";
  opacity: 0;
  pointer-events: none;
}
.modal[data-status=active] {
  transform: translateX(5rem);
  box-shadow: 0 0 2rem var(--black);
  width: calc(100% - 5rem);
}
.modal[data-status=active]:before {
  pointer-events: unset;
  opacity: 1;
  content: "";
  position: fixed;
  width: 100vw;
  height: 100%;
  left: -100vw;
  background: linear-gradient(0deg, rgba(9, 15, 23, 0.75), rgba(255, 255, 255, 0.75));
  transition-delay: 0.5s;
  transition: 0.5s linear all;
}
.modal-header {
  overflow: unset;
  min-height: unset;
  position: relative;
  padding: 1rem;
  background: var(--white);
  justify-items: flex-end;
  border-bottom: 3px solid var(--blue);
  box-shadow: 0 0.25rem 0.5rem -0.25rem rgba(9, 15, 23, 0.5);
}
.modal-header .contentport-header-title {
  margin: unset;
}
.modal-nav {
  padding: 1rem;
  z-index: -1;
  background: linear-gradient(180deg, var(--blue-darker) 0%, var(--blue) 100%);
}
.modal-content {
  padding: 1rem;
  background: var(--white);
  opacity: 1;
  transition: 0.5s linear opacity;
}
.modal-content.hide {
  opacity: 0;
  transition: 0.5s linear opacity;
}
.modal-footer {
  padding: 1rem;
  background: var(--white);
}
.modal.fullscreen {
  z-index: 80000;
}
.modal.fullscreen .modal-content {
  padding: 0;
}
.modal.inheritHeader {
  height: calc(100% - var(--header-height));
  margin-top: var(--header-height);
  grid-template-rows: var(--header-height) auto var(--header-height);
}
.modal.inheritHeader[data-status=active] {
  box-shadow: none;
}
.modal.noFooter {
  grid-template-rows: var(--header-height) 2.5rem auto;
}
.modal.inheritHeader.noFooter {
  grid-template-rows: 2.5rem auto;
}

@media (min-width: 45em) {
  .modal {
    left: 50vw;
  }
  .modal[data-status=active] {
    transform: translateX(0);
    width: calc(100% - 50vw);
  }
}
@media (min-width: 64em) {
  .modal {
    left: 66vw;
  }
  .modal[data-status=active] {
    transform: translateX(0);
    width: calc(100% - 66vw);
  }
}
.modal-switch-list {
  padding: 1rem 0;
  display: flex;
  align-items: center;
  justify-content: stretch;
}
.modal-switch-list:not(:last-of-type) {
  border-bottom: 1px solid var(--lightgrey);
}
.modal-switch-list button {
  order: 2;
}
.modal-switch-list span {
  order: 1;
  color: var(--grey);
}
.modal-switch-list .icon-next {
  margin-left: auto;
}
.modal-switch-list button.active + span {
  color: var(--black);
}

.sharing {
  display: flex;
  align-items: center;
  visibility: hidden;
}
.sharing button, .sharing [class*=icon-] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.5rem;
  height: 2.5rem;
  border-radius: 1.25rem;
  --bg-opacity: 0.3;
  color: var(--white);
  transition: 0.25s linear all;
  margin-right: 0.5rem;
  border: none;
}
.sharing button:hover, .sharing button:focus-visible, .sharing a:hover, .sharing a:focus-visible, .sharing span:hover, .sharing span:focus-visible {
  background: var(--blue);
  opacity: var(--bg-opacity);
  --bg-opacity: 1;
  transition: 0.25s linear all;
}
.sharing button {
  background: var(--blue);
  padding: 0 0.75rem;
  margin-left: auto;
}
.sharing button span {
  margin-left: 0.25em;
}

@media (max-width: 380px) {
  .sharing {
    display: unset;
  }
  .sharing a {
    margin: 0.5rem 0;
  }
}
.msn-ads,
.adslot {
  text-align: center;
  padding-bottom: 1rem;
}

.msn-ads:has(div):before,
.adslot:has(div):before {
  content: "ANZEIGE";
  font-size: 10px;
  line-height: 1em;
  font-family: sans-serif;
  display: block;
}

.sdgAnzeigenkennung {
  display: none !important;
}

#cmpboxrecall {
  bottom: 3.75rem !important;
}

@media (min-width: 64em) {
  #cmpboxrecall {
    bottom: 1rem;
  }
}
#msn-ads-top,
#banner {
  min-height: 250px;
  text-align: center;
  margin: auto;
  width: 71.25rem;
  background: var(--lightblue);
}
#sticky-sky-right {
  position: sticky;
  top: 53px;
}

#msn-ads-out-of-page-wrapper {
  text-align: center;
}

#msn-ads-off-content-right-1,
#sky {
  position: absolute;
  text-align: left !important;
  left: calc(35.625rem + 50%);
  padding-top: 1.75rem;
  z-index: 1;
}

#msn-ads-out-of-page {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 10000000;
}

#msn-ads-out-of-page:before {
  content: "";
  display: none;
}

@media (min-width: 64em) {
  .adslot {
    height: unset;
    position: unset;
    text-align: unset;
  }
  .slot_1-col .adslot {
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--lightblue);
    width: calc(100% + 7.5rem) !important;
    transform: translateX(-3.75rem);
    margin: -2rem 0;
    padding: 1rem;
  }
  .slot_1-col .adslot:before {
    margin: unset;
    position: absolute;
    top: 2px;
    left: 2px;
  }
  .slot_3-col .adslot {
    transform: translateY(-5px);
  }
}
@media (max-width: 352px) {
  .adslot {
    margin-left: -1.2rem;
  }
}
@media (min-width: 64em) {
  #msn-ads-off-content-right-1 {
    min-width: 300px;
    min-height: 600px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
  }
}
@media (max-width: 63.99em) {
  #msn-ads-in-content-1,
  #msn-ads-in-content-3,
  #msn-ads-in-content-5,
  #msn-ads-in-content-7,
  #msn-ads-in-content-9,
  #msn-ads-in-content-11 {
    min-width: 300px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
  }
  #msn-ads-in-content-1::before,
  #msn-ads-in-content-3::before,
  #msn-ads-in-content-5::before,
  #msn-ads-in-content-7::before,
  #msn-ads-in-content-9::before,
  #msn-ads-in-content-11::before {
    position: sticky;
    top: 60px;
  }
  #msn-ads-in-content-1 > div,
  #msn-ads-in-content-3 > div,
  #msn-ads-in-content-5 > div,
  #msn-ads-in-content-7 > div,
  #msn-ads-in-content-9 > div,
  #msn-ads-in-content-11 > div {
    position: sticky;
    top: 70px;
  }
}
.loop-container {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 90%;
  overflow-x: auto;
  gap: 1rem;
  overscroll-behavior-inline: contain;
  max-width: 100vw;
  scroll-snap-type: inline mandatory;
  scroll-padding-inline: 1rem;
  padding: 0rem 1rem;
}

.loop-container .loop-item, .loop-container > * {
  display: grid;
  gap: 0.5rem;
  grid-template-rows: min-content;
  scroll-snap-align: start;
  position: relative;
  border-radius: 0.5rem;
  overflow: hidden;
  grid-column: span 1;
}
.loop-container .loop-item figure img, .loop-container > * figure img {
  inline-size: 100%;
  object-fit: cover;
}
.loop-container .loop-item _header.headline, .loop-container > * _header.headline {
  position: absolute !important;
  background-color: unset !important;
  left: 0;
  right: 0;
  bottom: 0;
  color: var(--white);
  background: linear-gradient(0deg, rgba(9, 15, 23, 0.5), transparent);
  padding: 3rem 0.5rem 0.5rem 0.5rem;
}
.loop-container .loop-item _header.headline span, .loop-container > * _header.headline span {
  color: inherit !important;
  display: block;
}

@media (min-width: 45em) {
  .caption {
    position: relative;
    background: unset;
    padding: unset;
  }
  .loop-container {
    display: grid;
    gap: 2rem;
    grid-auto-flow: unset;
    grid-auto-columns: unset;
    grid-template-columns: 1fr 1fr;
    padding: 0;
  }
}
@media (min-width: 64em) {
  .loop-container {
    grid-template-columns: 1fr 1fr 1fr;
  }
}
.toggleswitch {
  background: none;
  border: none;
  text-align: right;
  white-space: nowrap;
  margin-left: auto;
  display: flex;
  align-items: center;
  --height: 1.75rem;
  --width: calc(var(--height) * 1.75);
}
.toggleswitch .toggleswitch-label {
  display: inline !important;
  margin-right: 0.5rem;
}
.toggleswitch .toggleswitch-label:after {
  content: attr(data-label-inactive);
}
.toggleswitch.active .toggleswitch-label:after {
  content: attr(data-label-active);
}
.toggleswitch .switch {
  display: inline-flex;
  width: var(--width);
  height: var(--height);
  border-radius: 100vh;
  background: rgba(0, 109, 176, 0.3);
  position: relative;
  border: none;
}
.toggleswitch .switch:after {
  transition: 0.25s linear all;
  content: "";
  position: absolute;
  background: linear-gradient(-35deg, var(--lightgrey), var(--white));
  background: #fff;
  left: calc(var(--height) / 8);
  top: calc(var(--height) / 8);
  width: calc(var(--height) - var(--height) / 4);
  aspect-ratio: 1;
  box-shadow: 0 0.25rem 0.5rem -0.25rem rgba(9, 15, 23, 0.25);
  border-radius: 50%;
}
.toggleswitch.active .switch {
  background: var(--blue);
}
.toggleswitch.active .switch:after {
  transform: translateX(calc(var(--width) - var(--height)));
  background: linear-gradient(-35deg, var(--blue-darker), var(--blue-lighter));
  background: var(--white);
}

.text-center {
  text-align: center;
}

.contentport-header li.bg-lightblue > a {
  white-space: nowrap;
}

.contentport-header ul.navi {
  overflow-x: scroll;
}

.contentport-header ul.navi::-webkit-scrollbar {
  display: none;
}

.AR_2.ob-feed-layout .ob-widget-header {
  font-family: "work-bold" !important;
  font-weight: 400 !important;
}

ai-summary {
  border: 1px solid var(--lightgrey);
}
ai-summary .ai-summary-content {
  padding-left: 0;
  padding-right: 0;
}
ai-summary #ai-summary ~ label {
  cursor: pointer;
  padding: 0 16px;
  width: 170px;
  height: 40px;
  border-radius: 20px;
}
ai-summary #ai-summary ~ label .icon-next {
  transform: translateY(3px);
}
ai-summary #ai-summary ~ label .icon-next:before {
  transform: rotate(90deg);
}
ai-summary #ai-summary:checked ~ label {
  width: 190px;
}
ai-summary #ai-summary:checked ~ label .icon-next:before {
  transform: rotate(-90deg);
}

ai-questions {
  --padding: 1rem;
  margin: 0 0 1rem 0 !important;
}
ai-questions .ai-questions-disclaimer {
  --padding: 1rem;
  display: flex;
  font-size: 0.9rem;
  gap: 0.6rem;
}

/******************************************************************************
 * * HTML-Wrapper
 * *****************************************************************************/
body {
  overflow: initial;
  font-family: work;
  --header-height: 3.75rem;
  background: var(--lightblue);
}

.wrapper {
  position: relative;
  display: grid;
  grid-template-areas: "meta" "header" "navigation" "horizontal-nav" "content" "bottom" "footer" "modal";
  grid-template-rows: 0 var(--header-height) 0 auto auto 0 auto 0;
  grid-template-columns: 1fr;
  background: var(--white);
}

@media (min-width: 64em) {
  body {
    overflow: initial;
    --header-height: 6.5rem;
  }
  .wrapper {
    grid-template-areas: "meta" "header" "navigation" "horizontal-nav" "content" "bottom" "footer" "modal";
    grid-template-rows: auto var(--header-height) 0 0 auto 0 auto 0;
    grid-template-columns: 1fr;
    margin: auto;
    overflow-x: initial;
    height: 100%;
    width: 71.25rem;
  }
}
.meta-nav {
  grid-area: meta;
  width: 100%;
  margin: 0 auto;
  padding: 0 3.75rem;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  overflow: hidden;
}
.meta-nav *:nth-child(2) {
  margin-left: auto;
}
.meta-nav smart, .meta-nav a {
  padding: 0.5rem;
  color: var(--grey);
  display: inline-block;
}

header.header {
  grid-area: header;
  top: 0 !important;
  height: var(--header-height);
  z-index: 20;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
  background-color: var(--white);
  transition: 0.25s linear all;
  align-items: center;
}

.nav-container {
  grid-area: navigation;
  position: fixed;
}

.ticker {
  grid-area: ticker;
  overflow: hidden;
  position: relative;
  overflow-x: scroll;
  scroll-snap-type: x mandatory;
}
.ticker:after {
  content: "";
  position: absolute;
  right: 0;
  top: 0;
  width: 4rem;
  background: linear-gradient(90deg, rgba(0, 0, 0, 0) 0%, #FFF 75%);
  display: block;
  height: 100%;
  pointer-events: none;
}

.content {
  grid-area: content;
  z-index: 1;
}

.bottom {
  grid-area: bottom;
}

footer.footer {
  grid-area: footer;
  max-width: 100%;
}
footer.footer .logo-list {
  flex-direction: column;
}

header.header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
}

@media (min-width: 64em) {
  header.header {
    position: sticky;
    top: -1px !important;
    width: 100%;
    margin: 0 auto;
    padding: 0 3.75rem;
    max-width: 71.25rem;
  }
  header.header.stuck {
    height: 50px;
  }
  .content {
    overflow-x: unset;
  }
  .breadcrumb:after {
    content: "";
    position: absolute;
    bottom: calc(-1.25rem - 1px);
    left: 0;
    right: 0;
    height: 1.25rem;
    background: linear-gradient(black, white);
    opacity: 0.02;
  }
  footer.footer .logo-list {
    flex-direction: row;
  }
}
/******************************************************************************
 * *  handle toggles
 * *
 * * label for=toggle-identfier
 * * input id=toggle-identifier
 * * element class=toggle-identifier
 * * data-toggle = [display, opacity, height, var(), whatever]
 * *
 * * <label for="toggle-something">...</label>
 * * ...
 * * <input type="checkbox" id="toggle-something" data-toggle="display">
 * * <div class="toggle-something">
 * * ...
 * * </div>
 * *****************************************************************************/
[class|=toggle] {
  transition: 0.125s linear max-height;
}

[id|=toggle][data-toggle*=display] ~ [class|=toggle] {
  display: none;
}

[id|=toggle][data-toggle*=display]:checked ~ [class|=toggle] {
  display: block;
}

[id|=toggle][data-toggle*=opacity] ~ [class|=toggle] {
  opacity: 0;
}

[id|=toggle][data-toggle*=opacity]:checked ~ [class|=toggle] {
  opacity: 1;
}

[id|=toggle][data-toggle*=height] ~ [class|=toggle] {
  max-height: 0;
}

[id|=toggle][data-toggle*=height]:checked ~ [class|=toggle] {
  max-height: 100%;
}

[id|=toggle][data-toggle*=slidefromtop] ~ [class|=toggle] {
  opacity: 0;
  pointer-events: none;
  max-height: 0px;
}

[id|=toggle][data-toggle*=slidefromtop]:checked ~ [class|=toggle] {
  opacity: 1;
  max-height: unset;
  pointer-events: initial;
}

a {
  color: var(--blue);
}

.blend {
  opacity: 0;
  transition: 0.25s linear all;
}
.blend.is-blended-in {
  opacity: 1;
}

[data-text]:before {
  content: attr(data-text);
  padding-bottom: 1rem;
  display: block;
}

[data-obs-status=false] {
  display: none !important;
  opacity: 0;
  transition: 0.25s linear all;
}

[data-obs-status=true] {
  opacity: 1;
  transition: 0.25s linear all;
}
