a, abbr, acronym, address, applet, article, aside, audio, b, big, blockquote, body, canvas, caption, center, cite, code, dd, del, details, dfn, div, dl, dt, em, embed, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, output, p, pre, q, ruby, s, samp, section, small, span, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, time, tr, tt, u, ul, var, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  vertical-align: baseline;
}

article, aside, details, figcaption, figure, footer, header, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:after, blockquote:before, q:after, q:before {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

.clearfix:after {
  content: "";
  display: block;
  clear: both;
}

img {
  width: 100%;
  max-width: 100%;
}

@font-face {
  font-family: "Suisse";
  font-weight: normal;
  font-style: normal;
  font-display: swap;
  src: url("webfonts/SuisseScreen-Regular-WebS.woff2");
}
@font-face {
  font-family: "Suisse";
  font-weight: 700;
  font-style: normal;
  font-display: swap;
  src: url("webfonts/SuisseScreen-Bold-WebS.woff2");
}
@font-face {
  font-family: "Noto Sans";
  font-style: normal;
  font-weight: 400;
  src: url("webfonts/noto-sans-v14-latin-regular.woff2") format("woff2");
}
@font-face {
  font-family: "Noto Sans";
  font-style: normal;
  font-weight: 700;
  src: url("webfonts/noto-sans-v14-latin-700.woff2") format("woff2");
}
.font-size-18 {
  font-size: 14px;
}
@media screen and (min-width: 1500px) {
  .font-size-18 {
    font-size: 18px;
  }
}

.font-size-24, .pill {
  font-size: 18px;
}
@media screen and (max-width: 1024px) {
  .font-size-24, .pill {
    font-size: 16px;
  }
}
@media screen and (max-width: 599px) {
  .font-size-24, .pill {
    font-size: 14px;
  }
}
@media screen and (min-width: 1500px) {
  .font-size-24, .pill {
    font-size: 24px;
  }
}

.font-size-34, .textpage #main .wrapper h3 {
  font-size: 24px;
}
@media screen and (max-width: 1024px) {
  .font-size-34, .textpage #main .wrapper h3 {
    font-size: 22px;
  }
}
@media screen and (max-width: 599px) {
  .font-size-34, .textpage #main .wrapper h3 {
    font-size: 18px;
  }
}
@media screen and (min-width: 1500px) {
  .font-size-34, .textpage #main .wrapper h3 {
    font-size: 34px;
  }
}

.font-size-43 {
  font-size: 30px;
}
@media screen and (max-width: 1024px) {
  .font-size-43 {
    font-size: 28px;
  }
}
@media screen and (max-width: 599px) {
  .font-size-43 {
    font-size: 23px;
  }
}
@media screen and (min-width: 1500px) {
  .font-size-43 {
    font-size: 43px;
  }
}

.font-size-50, #geschaeftsleiter-text h2, #geschaeftsleiter-text h3,
#karrieretext h2,
#karrieretext h3 {
  font-size: 35px;
}
@media screen and (max-width: 1024px) {
  .font-size-50, #geschaeftsleiter-text h2, #geschaeftsleiter-text h3,
  #karrieretext h2,
  #karrieretext h3 {
    font-size: 32px;
  }
}
@media screen and (max-width: 599px) {
  .font-size-50, #geschaeftsleiter-text h2, #geschaeftsleiter-text h3,
  #karrieretext h2,
  #karrieretext h3 {
    font-size: 26px;
  }
}
@media screen and (min-width: 1500px) {
  .font-size-50, #geschaeftsleiter-text h2, #geschaeftsleiter-text h3,
  #karrieretext h2,
  #karrieretext h3 {
    font-size: 50px;
  }
}

.font-size-60 {
  font-size: 42px;
}
@media screen and (max-width: 1024px) {
  .font-size-60 {
    font-size: 39px;
  }
}
@media screen and (max-width: 599px) {
  .font-size-60 {
    font-size: 32px;
  }
}
@media screen and (min-width: 1500px) {
  .font-size-60 {
    font-size: 60px;
  }
}

.font-size-65 {
  font-size: 44px;
}
@media screen and (max-width: 1024px) {
  .font-size-65 {
    font-size: 32px;
  }
}
@media screen and (max-width: 599px) {
  .font-size-65 {
    font-size: 27px;
  }
}
@media screen and (min-width: 1500px) {
  .font-size-65 {
    font-size: 65px;
  }
}

.font-size-160 {
  font-size: 9vw;
}
@media screen and (max-width: 599px) {
  .font-size-160 {
    font-size: 9.5vw;
  }
}

.font-size-185 {
  font-size: 10vw;
}
@media screen and (max-width: 599px) {
  .font-size-185 {
    font-size: 10.5vw;
  }
}

.line-height-08 {
  line-height: 0.8;
}

.line-height-1 {
  line-height: 1;
}

.line-height-106 {
  line-height: 1.06;
}

.line-height-118, #geschaeftsleiter-text h2, #geschaeftsleiter-text h3,
#karrieretext h2,
#karrieretext h3 {
  line-height: 1.18;
}

.line-height-125 {
  line-height: 1.25;
}

* {
  box-sizing: border-box;
}

html {
  font-size: 16px;
  --color-primary: #ff4c3e;
  --color-sustainablity: #9fcfb5;
  --color-public-affairs: #32648c;
  --color-komm: #7fa9b1;
  --color-category: var( --color-primary );
  --header-height: 6.5rem;
  --distance-xs: 18px;
  --distance-s: 36px;
  --distance-m: 60px;
  --distance-l: 100px;
  --distance-xl: 140px;
}
@media screen and (max-width: 1200px) {
  html {
    --header-height: 5rem;
  }
}
@media screen and (max-width: 1024px) {
  html {
    --distance-xs: 13px;
    --distance-s: 25px;
    --distance-m: 43px;
    --distance-l: 70px;
    --distance-xl: 100px;
  }
}
@media screen and (max-width: 599px) {
  html {
    --header-height: 4.1rem;
    --distance-xs: 11px;
    --distance-s: 21px;
    --distance-m: 36px;
    --distance-l: 60px;
    --distance-xl: 84px;
  }
}

body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.5;
  font-family: "Noto Sans", Arial, sans-serif;
}
body.open-nav, body.no-overflow {
  overflow: hidden;
}

.scroll-margin,
.scroll-to-anchor {
  scroll-margin-top: var(--header-height);
}

h1, h2, h3, h4 {
  font-family: "Suisse", Arial, sans-serif;
}

.noto {
  font-family: "Noto Sans", Arial, sans-serif;
}

.suisse, #geschaeftsleiter-text h2, #geschaeftsleiter-text h3,
#karrieretext h2,
#karrieretext h3 {
  font-family: "Suisse", Arial, sans-serif;
}

.color-sustainability {
  color: var(--color-sustainablity);
}

.color-public-affairs {
  color: var(--color-public-affairs);
}

.color-kommunikation, .color-communication {
  color: var(--color-komm);
}

img {
  height: auto;
}

strong, .bold, #geschaeftsleiter-text h2, #geschaeftsleiter-text h3,
#karrieretext h2,
#karrieretext h3, .pill {
  font-weight: bold;
}

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

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

@media screen and (max-width: 599px) {
  .smartphone-text-left {
    text-align: left;
  }
}

p:not(:last-child) {
  margin-bottom: 1.3em;
}

a:link, a:visited {
  color: inherit;
  text-decoration: none;
}
a:hover, a:active, a.active {
  color: inherit;
  font-weight: bold;
}
a.underlined:link, a.underlined:visited, .underlined-links a:link, .underlined-links a:visited {
  text-decoration: underline;
  text-underline-offset: 0.17em;
  text-decoration-skip: none;
  text-decoration-skip-ink: none;
}
a.underlined:hover, a.underlined:active, a.underlined.active, .underlined-links a:hover, .underlined-links a:active, .underlined-links a.active {
  text-decoration: none;
  font-weight: inherit;
}

button {
  font: inherit;
  color: inherit;
  border: none;
  border-radius: 0;
  text-transform: inherit;
  background-color: transparent;
  cursor: pointer;
  padding: 0;
}

#skip-to-content-link {
  position: fixed;
  top: 0;
  height: 30px;
  left: 50%;
  padding: 8px;
  transform: translate(-50%, -150%);
  transition: transform 0.3s;
  z-index: 100;
}
#skip-to-content-link:focus {
  transform: translate(0%, 0%);
}

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

#main-header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 5;
  display: flex;
  width: 100%;
  max-width: 100vw;
  height: var(--header-height);
  padding-top: 2rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid black;
  overflow: hidden;
}
@media screen and (max-width: 1200px) {
  #main-header {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
  }
}
@media screen and (max-width: 599px) {
  #main-header {
    padding-top: 1.2rem;
    padding-bottom: 1.2rem;
  }
}
#main-header .wrapper {
  width: 100%;
  max-width: 1800px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  max-height: 100%;
}
#main-header .nav-wrapper {
  display: flex;
  flex: 1;
  justify-content: space-between;
  align-items: center;
}
@media screen and (max-width: 1200px) {
  #main-header .nav-wrapper {
    position: absolute;
    top: var(--header-height);
    height: calc(100vh - var(--header-height) * 2);
    left: 0;
    right: 0;
    flex-direction: column;
    justify-content: center;
    pointer-events: none;
    z-index: 2;
    grid-column-start: 1;
    grid-column-end: -1;
  }
}
@media screen and (max-width: 1200px) {
  #main-header .wrapper {
    display: grid;
    grid-template-columns: 3fr 1fr;
    align-items: start;
  }
  #main-header .start-nav {
    margin-bottom: 2em;
  }
  #main-header::after {
    content: " ";
    background-color: white;
    overflow: hidden;
    height: 100vh;
    max-height: 0;
    transition: max-height 0.4s ease-in-out 0.2s;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
  }
}
@media screen and (max-width: 599px) {
  #main-header .start-nav {
    margin-bottom: 2em;
  }
}
@media screen and (max-width: 599px) and (max-height: 600px) {
  #main-header .start-nav {
    margin-bottom: 1em;
  }
}
#main-header .logo {
  position: relative;
  z-index: 2;
  flex: 0 1 29%;
}
#main-header .logo img {
  height: 30px;
  width: auto;
  display: block;
}
@media screen and (max-width: 599px) {
  #main-header .logo img {
    height: 25px;
  }
}
#main-header nav ul {
  display: flex;
}
#main-header nav a {
  padding-left: 1ch;
  padding-right: 1ch;
  white-space: nowrap;
}
#main-header nav a[aria-current=page] {
  font-weight: bold;
}
#main-header nav a[aria-current=page] .link-title {
  text-decoration: underline;
  text-underline-offset: 0.3em;
}
@media screen and (max-width: 1200px) {
  #main-header nav {
    font-size: 1.2em;
  }
  #main-header nav ul {
    display: block;
    text-align: center;
  }
  #main-header nav ul li {
    padding: 12px 0;
    margin-left: 0;
    opacity: 0;
    transition: opacity 0.3s ease-in-out;
    transition-delay: 0.25s;
  }
}
@media screen and (max-width: 599px) {
  #main-header nav ul {
    font-size: 1.5rem;
  }
  #main-header nav ul li {
    padding: 4px 0;
  }
}
@media screen and (max-height: 550px) {
  #main-header nav ul li {
    padding: 2px 0;
  }
}
.open-nav #main-header {
  z-index: 11;
}
@media screen and (max-width: 1200px) {
  .open-nav #main-header {
    overflow: initial;
  }
  .open-nav #main-header::after {
    max-height: 100vh;
    transition-delay: 0s;
  }
  .open-nav #main-header nav {
    pointer-events: initial;
  }
  .open-nav #main-header nav li {
    opacity: 1;
  }
  .open-nav #main-header #top-bar {
    transform: translateY(4px) rotate(45deg);
  }
  .open-nav #main-header #bottom-bar {
    transform: translateY(-5px) rotate(-45deg);
  }
}
#main-header .language-switcher {
  display: flex;
  margin-left: 2em;
}
#main-header .language-switcher a {
  padding-left: 0;
  padding-right: 0;
}
@media screen and (max-width: 1200px) {
  #main-header .language-switcher {
    margin-left: 0;
    margin-top: 2em;
    justify-content: center;
  }
}
@media screen and (max-width: 599px) and (max-height: 600px) {
  #main-header .language-switcher {
    margin-top: 1em;
  }
}

#main {
  margin-top: var(--header-height);
  padding-bottom: var(--distance-xl);
}

.wrapper {
  padding-left: 3rem;
  padding-right: 3rem;
  max-width: 1500px;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (max-width: 1024px) {
  .wrapper {
    padding-left: 2rem;
    padding-right: 2rem;
  }
}
@media screen and (max-width: 599px) {
  .wrapper {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
  }
}
@media screen and (max-width: 339px) {
  .wrapper {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

.accordion button {
  padding: 0.5em 0;
  display: flex;
  justify-content: center;
  width: 100%;
}
.accordion button .arrow {
  margin-right: 0.5em;
  transition: transform 0.4s ease-out;
}
.accordion .details {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease-out;
}
.accordion .details .inner {
  max-width: 80ch;
  margin-left: auto;
  margin-right: auto;
}
.accordion .details .padding {
  padding: 0.1em 1em 2em;
}
.accordion.open .details {
  max-height: 300vh;
}
.accordion.open .arrow {
  transform: rotate(90deg);
}

#introslider {
  height: calc(100vh - var(--header-height));
  position: relative;
}
@media screen and (max-width: 599px) {
  #introslider {
    height: calc(90vh - var(--header-height));
  }
}
#introslider .font-size-160 {
  font-size: 6vw;
}
@media screen and (max-width: 599px) and (orientation: portrait) {
  #introslider .font-size-160 {
    font-size: 11vw;
  }
}
#introslider .swiper-pagination {
  bottom: var(--distance-m);
  opacity: 0;
}
@media screen and (max-width: 599px) {
  #introslider .swiper-pagination {
    opacity: 1;
  }
}

.das-machen-wir .leistung-title,
.what-we-do .leistung-title {
  color: var(--color-category);
  position: relative;
  z-index: 2;
}
.das-machen-wir .leistungen-text,
.what-we-do .leistungen-text {
  margin-top: 1.5em;
  margin-bottom: var(--distance-m);
}
.das-machen-wir .leistungen-text .headline,
.what-we-do .leistungen-text .headline {
  position: relative;
  z-index: 6;
  pointer-events: none;
}
@media screen and (min-width: 600px) {
  .das-machen-wir .leistungen-text .headline,
  .what-we-do .leistungen-text .headline {
    font-size: 7vw;
  }
}
.das-machen-wir .leistung-kategorie,
.what-we-do .leistung-kategorie {
  transition: max-height 0.4s ease-in-out;
}
.das-machen-wir .leistung-kategorie .inner,
.what-we-do .leistung-kategorie .inner {
  padding-bottom: 1px;
}
.das-machen-wir #sustainability,
.what-we-do #sustainability {
  --color-category: var( --color-sustainablity );
}
.das-machen-wir #public-affairs,
.what-we-do #public-affairs {
  --color-category: var( --color-public-affairs );
}
.das-machen-wir #kommunikation, .das-machen-wir #communication,
.what-we-do #kommunikation,
.what-we-do #communication {
  --color-category: var( --color-komm );
}
.das-machen-wir .subleistungen,
.what-we-do .subleistungen {
  transition: max-height 0.4s ease-in-out;
  max-height: 0;
  overflow: hidden;
}
.das-machen-wir .subleistungen .subleistung,
.what-we-do .subleistungen .subleistung {
  margin-bottom: 3em;
}
.das-machen-wir .subleistungen .accordion,
.what-we-do .subleistungen .accordion {
  border-bottom: 1px solid black;
}
.das-machen-wir .subleistungen.show,
.what-we-do .subleistungen.show {
  max-height: 1000vh;
}

#fokusthemen-swiper {
  color: white;
}
#fokusthemen-swiper .thema-wrapper {
  position: relative;
  display: grid;
  justify-content: center;
  align-items: center;
  height: 25vw;
  padding: 1em;
}
@media screen and (max-width: 599px) {
  #fokusthemen-swiper .thema-wrapper {
    height: 55vw;
  }
}
#fokusthemen-swiper .thema-wrapper.white-text {
  color: white;
}
#fokusthemen-swiper .thema-wrapper.black-text {
  color: black;
}
#fokusthemen-swiper .thema-wrapper .thema-ueberschrift {
  max-width: 40vw;
}
@media screen and (max-width: 599px) {
  #fokusthemen-swiper .thema-wrapper .thema-ueberschrift {
    max-width: 100%;
  }
}
#fokusthemen-swiper img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
  object-fit: cover;
}

.image-slider {
  color: white;
}
.image-slider .swiper-slide {
  height: 100%;
}
.image-slider .image-wrapper img {
  height: 100%;
  width: 100%;
  object-fit: cover;
  object-position: center;
}
.image-slider .image-wrapper .slide-text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -20%);
  width: max-content;
  max-width: 90%;
}

#fragen, #kunden {
  position: relative;
}
#fragen .swiper-slide .wrapper, #kunden .swiper-slide .wrapper {
  max-width: 80%;
}
@media screen and (max-width: 599px) {
  #fragen .swiper-slide .wrapper, #kunden .swiper-slide .wrapper {
    max-width: 100%;
  }
}
#fragen .swiper-slide .wrapper .text, #kunden .swiper-slide .wrapper .text {
  margin-top: 0.25em;
}

#kunden .swiper-pagination {
  margin-top: var(--distance-m);
}
#kunden .swiper-slide .wrapper.logoSlide {
  max-width: 1500px;
}
#kunden figcaption {
  margin-top: 1em;
}

.image-text-slider, .background-slider {
  background-color: var(--color-primary);
  color: white;
}
@media (pointer: fine) {
  .image-text-slider a.pill:hover, .image-text-slider a.pill:active, .background-slider a.pill:hover, .background-slider a.pill:active {
    background-color: white;
    color: var(--color-primary);
  }
}

.image-text-slider .swiper-pagination {
  margin-top: 0;
  max-width: 875px;
  text-align: left;
  position: absolute;
  bottom: var(--distance-m);
  left: 50%;
}
@media screen and (max-width: 599px) {
  .image-text-slider .swiper-pagination {
    transform: translateX(-50%);
    text-align: center;
  }
}

.background-slider .swiper {
  padding-top: var(--distance-m);
  padding-bottom: calc(var(--distance-m) * 2);
}

.swiper-pagination {
  --swiper-pagination-color: currentColor;
  line-height: 1;
  z-index: 1;
}
.swiper-pagination.swiper-pagination-bullets {
  bottom: var(--distance-m);
}
.swiper-pagination .swiper-pagination-bullet {
  background-color: transparent;
  border: 1px solid currentColor;
  width: 0.7em;
  height: 0.7em;
  margin-left: 0.2em !important;
  margin-right: 0.2em !important;
  opacity: 1;
  transition: background-color 0.4s ease-in-out, opacity 0.4s ease-in-out;
}
.swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background-color: currentColor;
}

.pill {
  border-radius: 1em;
  border: 1px solid currentColor;
  padding: 0.4em 1.5em;
  line-height: 1;
  margin: 0 auto;
  display: block;
  width: max-content;
  color: var(--color-category);
  transition: color 0.2s ease-in-out, background-color 0.2s ease-in-out;
}

a.pill, button.pill {
  color: var(--color-category);
}
a.pill:hover, button.pill:hover {
  background-color: var(--color-category);
  color: white;
}

button.pill:hover {
  border-color: var(--color-category);
}

.with-bold-placeholder {
  position: relative;
}
.with-bold-placeholder .bold-placeholder {
  visibility: hidden;
  font-weight: bold;
}
.with-bold-placeholder .link-title {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  text-align: center;
}

.limited-text-width {
  max-width: 80ch;
  margin-left: auto;
  margin-right: auto;
}

.relative {
  position: relative;
}

#header-bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: var(--header-height);
  z-index: 2;
  background-color: rgb(255, 255, 255);
}

.leistung-slider .grid,
.geschaeftsleitung-slider .grid {
  display: grid;
  grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
  grid-gap: 12px;
}
@media screen and (max-width: 599px) {
  .leistung-slider .grid,
  .geschaeftsleitung-slider .grid {
    display: block;
    position: relative;
  }
}
.leistung-slider .grid .narrow img,
.geschaeftsleitung-slider .grid .narrow img {
  height: 100%;
  object-fit: cover;
  display: block;
}
@media screen and (max-width: 599px) {
  .leistung-slider .grid .narrow img,
  .geschaeftsleitung-slider .grid .narrow img {
    height: auto;
  }
}
.leistung-slider .grid .wide,
.geschaeftsleitung-slider .grid .wide {
  display: flex;
}
@media screen and (max-width: 599px) {
  .leistung-slider .grid .wide,
  .geschaeftsleitung-slider .grid .wide {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    text-align: center;
  }
}
.leistung-slider .grid .wide .inner,
.geschaeftsleitung-slider .grid .wide .inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: 875px;
  padding: var(--distance-m) 3em var(--distance-m) 8.3333333333vw;
}
@media screen and (max-width: 599px) {
  .leistung-slider .grid .wide .inner,
  .geschaeftsleitung-slider .grid .wide .inner {
    width: 100%;
    padding: var(--distance-m) 1rem;
  }
}
.leistung-slider .swiper .grid .wide .inner,
.geschaeftsleitung-slider .swiper .grid .wide .inner {
  padding-bottom: calc(var(--distance-m) * 2 + 0.5em);
}

.leistung-slider,
.geschaeftsleitung-slider {
  padding-top: 0;
  padding-bottom: 0;
  background-color: var(--color-category);
}
.leistung-slider .subline,
.geschaeftsleitung-slider .subline {
  margin-top: 0.5em;
}
.leistung-slider .subline p,
.geschaeftsleitung-slider .subline p {
  margin-bottom: 0;
}

#das-macht-uns-aus-slider {
  padding-bottom: 0;
}
#das-macht-uns-aus-slider .grid .narrow img {
  width: 80%;
  margin-left: 20%;
  object-fit: contain;
  padding-top: 1.3em;
  padding-bottom: 3em;
}

#leistungen-overview {
  padding: 9em 0;
}
#leistungen-overview a {
  transition: color 0.2s ease-in-out;
}
#leistungen-overview a[href*=sustainability]:hover {
  color: var(--color-sustainablity);
}
#leistungen-overview a[href*=public-affairs]:hover {
  color: var(--color-public-affairs);
}
#leistungen-overview a[href*=kommunikation]:hover {
  color: var(--color-komm);
}
#leistungen-overview a[href*=communication]:hover {
  color: var(--color-komm);
}

#toggle-menu-button {
  display: none;
  position: relative;
  z-index: 2;
  justify-self: end;
  align-self: center;
  width: 30px;
  height: 100%;
  grid-template-rows: 1fr 1fr;
  grid-row-gap: 6px;
  box-sizing: content-box;
}
@media screen and (max-width: 1200px) {
  #toggle-menu-button {
    display: grid;
  }
}
#toggle-menu-button .bar {
  height: 3px;
  background: black;
  transition: transform 0.3s ease-in-out;
  transform-origin: center;
}
#toggle-menu-button #top-bar {
  align-self: end;
}
#toggle-menu-button #bottom-bar {
  align-self: start;
}

#sticky-illustration {
  position: relative;
  z-index: 4;
  pointer-events: none;
  margin-top: calc(var(--header-height) + 1rem);
}
@media screen and (max-width: 599px) {
  #sticky-illustration {
    margin-top: 7rem;
  }
}
#sticky-illustration img {
  top: var(--header-height);
  width: 40%;
  max-width: 600px;
  display: block;
  margin-left: auto;
  margin-right: auto;
  object-fit: contain;
  z-index: -1;
}
@media screen and (max-width: 599px) {
  #sticky-illustration img {
    width: 75%;
  }
}
.das-machen-wir #sticky-illustration, .what-we-do #sticky-illustration {
  margin-bottom: -12vw;
  padding-top: 3vw;
}
@media screen and (max-width: 599px) {
  .das-machen-wir #sticky-illustration, .what-we-do #sticky-illustration {
    margin-bottom: -25vw;
  }
}
.das-macht-uns-aus #sticky-illustration, .what-sets-us-apart #sticky-illustration {
  margin-bottom: -16vw;
}
@media screen and (max-width: 599px) {
  .das-macht-uns-aus #sticky-illustration, .what-sets-us-apart #sticky-illustration {
    margin-bottom: -22vw;
  }
}
@media screen and (max-width: 599px) {
  .das-macht-uns-aus #sticky-illustration, .what-sets-us-apart #sticky-illustration {
    margin-bottom: -35vw;
  }
}
.das-macht-uns-aus #sticky-illustration img, .what-sets-us-apart #sticky-illustration img {
  width: 34%;
  max-width: 510px;
}
@media screen and (max-width: 1024px) and (orientation: portrait) {
  .das-macht-uns-aus #sticky-illustration img, .what-sets-us-apart #sticky-illustration img {
    width: 50%;
  }
}
@media screen and (max-width: 599px) {
  .das-macht-uns-aus #sticky-illustration img, .what-sets-us-apart #sticky-illustration img {
    width: 75%;
  }
}

.das-macht-uns-aus .profil-text .headline,
.what-sets-us-apart .profil-text .headline {
  position: relative;
  z-index: 6;
  font-size: 7vw;
}
@media screen and (max-width: 599px) {
  .das-macht-uns-aus .profil-text .headline,
  .what-sets-us-apart .profil-text .headline {
    font-size: 13vw;
  }
}
.das-macht-uns-aus .profil-text .subline,
.what-sets-us-apart .profil-text .subline {
  margin-top: 1em;
}
.das-macht-uns-aus #partner,
.what-sets-us-apart #partner {
  color: white;
  background-color: var(--color-public-affairs);
  padding-top: var(--distance-m);
  padding-bottom: var(--distance-m);
}
.das-macht-uns-aus #partner img,
.what-sets-us-apart #partner img {
  height: 1em;
  width: auto;
  display: block;
  margin: 0.5rem auto 1.5rem;
}

.social-media-icons-wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
}
#main-header .social-media-icons-wrapper {
  margin-left: 0.5ch;
}
#main-header .social-media-icons-wrapper a {
  padding-left: 0.5ch;
  padding-right: 0.5ch;
}
.social-media-icons-wrapper img {
  height: 1.1em;
  width: auto;
  display: block;
}

#main-footer {
  background-color: black;
  color: white;
  padding-top: var(--distance-m);
  padding-bottom: var(--distance-m);
}
#main-footer .wrapper {
  max-width: 1800px;
}
#main-footer .footer-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem;
  justify-content: space-between;
}
@media screen and (max-width: 599px) {
  #main-footer .footer-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
#main-footer a {
  text-underline-offset: 0.1em;
}
#main-footer .spalte5 {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
#main-footer .spalte5 .copyright img {
  width: 6rem;
  margin-bottom: 2px;
}
@media screen and (max-width: 1024px) {
  #main-footer .spalte5 .copyright img {
    width: 5rem;
  }
}
@media screen and (max-width: 599px) {
  #main-footer .spalte5 {
    grid-column-end: -1;
    grid-column-start: 1;
  }
  #main-footer .spalte5 .copyright {
    margin-top: 1.5rem;
  }
  #main-footer .spalte5 .copyright .font-size-18 {
    display: block;
  }
}
@media screen and (max-width: 599px) {
  #main-footer .font-size-18 {
    display: none;
  }
}

.text-after-headline {
  margin-top: calc(var(--distance-m) * 0.9);
}

.related {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
  margin-top: var(--distance-l);
}
.related .pill {
  margin: 0 1em;
}

#geschaeftsleiter-text h2, #geschaeftsleiter-text h3,
#karrieretext h2,
#karrieretext h3 {
  margin-bottom: var(--distance-m);
}
#geschaeftsleiter-text h2 + p, #geschaeftsleiter-text h3 + p,
#karrieretext h2 + p,
#karrieretext h3 + p {
  margin-top: -0.2em;
}

#team,
#buch-grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  grid-gap: 1rem;
}
@media screen and (max-width: 1200px) {
  #team,
  #buch-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
}
@media screen and (max-width: 1024px) {
  #team,
  #buch-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
@media screen and (max-width: 599px) {
  #team,
  #buch-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
#team .show-details,
#team .show-dialog,
#buch-grid .show-details,
#buch-grid .show-dialog {
  background-color: var(--color-primary);
  position: relative;
  width: 100%;
  display: block;
}
#team .show-details img,
#team .show-dialog img,
#buch-grid .show-details img,
#buch-grid .show-dialog img {
  display: block;
}
#team .show-details .overlay,
#team .show-dialog .overlay,
#buch-grid .show-details .overlay,
#buch-grid .show-dialog .overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  justify-content: flex-end;
  flex-direction: column;
  padding: 1.2rem 1rem;
  pointer-events: none;
  background-color: rgba(255, 76, 62, 0.85);
  opacity: 0;
  transition: opacity 0.2s ease-in-out;
}
#team .show-details .overlay .name,
#team .show-details .overlay .position,
#team .show-details .overlay .icons,
#team .show-dialog .overlay .name,
#team .show-dialog .overlay .position,
#team .show-dialog .overlay .icons,
#buch-grid .show-details .overlay .name,
#buch-grid .show-details .overlay .position,
#buch-grid .show-details .overlay .icons,
#buch-grid .show-dialog .overlay .name,
#buch-grid .show-dialog .overlay .position,
#buch-grid .show-dialog .overlay .icons {
  display: block;
}
#team .show-details .overlay .name,
#team .show-dialog .overlay .name,
#buch-grid .show-details .overlay .name,
#buch-grid .show-dialog .overlay .name {
  margin-bottom: 0.5rem;
}
#team .show-details .overlay .icons,
#team .show-dialog .overlay .icons,
#buch-grid .show-details .overlay .icons,
#buch-grid .show-dialog .overlay .icons {
  display: flex;
  justify-content: center;
}
#team .show-details .overlay .icons:not(:empty),
#team .show-dialog .overlay .icons:not(:empty),
#buch-grid .show-details .overlay .icons:not(:empty),
#buch-grid .show-dialog .overlay .icons:not(:empty) {
  margin-top: 0.75rem;
}
#team .show-details .overlay .icons a,
#team .show-dialog .overlay .icons a,
#buch-grid .show-details .overlay .icons a,
#buch-grid .show-dialog .overlay .icons a {
  margin-right: 0.5em;
}
#team .show-details .overlay .icons img,
#team .show-dialog .overlay .icons img,
#buch-grid .show-details .overlay .icons img,
#buch-grid .show-dialog .overlay .icons img {
  height: 1em;
  width: auto;
}
@media (pointer: fine) {
  #team .show-details:hover .overlay,
  #team .show-dialog:hover .overlay,
  #buch-grid .show-details:hover .overlay,
  #buch-grid .show-dialog:hover .overlay {
    opacity: 1;
  }
}
#team .no-image .show-details,
#team .no-image .show-dialog,
#buch-grid .no-image .show-details,
#buch-grid .no-image .show-dialog {
  height: 100%;
}
#team .no-image .show-details .overlay,
#team .no-image .show-dialog .overlay,
#buch-grid .no-image .show-details .overlay,
#buch-grid .no-image .show-dialog .overlay {
  opacity: 1;
}
#team .buch .show-details,
#team .buch .show-dialog,
#buch-grid .buch .show-details,
#buch-grid .buch .show-dialog {
  aspect-ratio: 2/3;
}
#team .buch .show-details img,
#team .buch .show-dialog img,
#buch-grid .buch .show-details img,
#buch-grid .buch .show-dialog img {
  height: 100%;
  object-fit: cover;
}
#team .buch .overlay,
#buch-grid .buch .overlay {
  justify-content: center;
}
#team .details,
#buch-grid .details {
  padding: 2em 2.5em;
  top: 50%;
  left: 50%;
  width: 750px;
  max-width: 90vw;
  height: auto;
  max-height: 90vh;
  overflow: auto;
  transform: translate(-50%, -50%);
  background-color: white;
  border: none;
}
@media screen and (max-width: 599px) {
  #team .details,
  #buch-grid .details {
    height: auto;
  }
}
#team .details .name,
#buch-grid .details .name {
  padding-right: 1em;
}
#team .details .name span,
#buch-grid .details .name span {
  display: block;
}
#team .details .position,
#buch-grid .details .position {
  margin-top: 5px;
}
#team .details .beschreibung,
#buch-grid .details .beschreibung {
  margin-top: 1em;
}
#team .details .kontakt,
#buch-grid .details .kontakt {
  margin-top: 1em;
}
#team .details .kontakt a + .channels,
#buch-grid .details .kontakt a + .channels {
  margin-top: 1em;
}
#team .details .kontakt .channels,
#buch-grid .details .kontakt .channels {
  display: flex;
}
#team .details .kontakt .channels a,
#buch-grid .details .kontakt .channels a {
  margin-right: 0.75em;
}
#team .details .kontakt .channels img,
#buch-grid .details .kontakt .channels img {
  height: 1.75em;
  width: auto;
}
#team .details .close-overlay,
#buch-grid .details .close-overlay {
  position: absolute;
  top: 1rem;
  right: 1rem;
  font-size: 2rem;
  line-height: 1;
  width: 2rem;
  height: 2rem;
}
#team .details .close-overlay svg,
#buch-grid .details .close-overlay svg {
  height: 100%;
  width: 100%;
}
#team .person,
#buch-grid .person {
  aspect-ratio: 24/33;
}

sub {
  transform: translateY(15%);
  display: inline-block;
  font-size: 0.8em;
}

.top-headline {
  margin-top: calc(var(--header-height) + var(--distance-l));
  position: relative;
  z-index: 2;
}

.veranstaltungen #veranstaltungen-grid,
.events #veranstaltungen-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 1rem;
}
@media screen and (max-width: 699px) {
  .veranstaltungen #veranstaltungen-grid,
  .events #veranstaltungen-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media screen and (max-width: 599px) {
  .veranstaltungen #veranstaltungen-grid,
  .events #veranstaltungen-grid {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
}
.veranstaltungen #veranstaltungen-grid .veranstaltung,
.events #veranstaltungen-grid .veranstaltung {
  aspect-ratio: 3/2;
  position: relative;
  height: 100%;
  display: grid;
  justify-content: center;
  align-items: center;
}
.veranstaltungen #veranstaltungen-grid .veranstaltung a,
.events #veranstaltungen-grid .veranstaltung a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.veranstaltungen #veranstaltungen-grid .veranstaltung img,
.events #veranstaltungen-grid .veranstaltung img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: -1;
}
.veranstaltungen #veranstaltungen-grid .veranstaltung .pill,
.events #veranstaltungen-grid .veranstaltung .pill {
  color: white;
}
.veranstaltungen #veranstaltungen-grid .veranstaltung:hover .pill,
.events #veranstaltungen-grid .veranstaltung:hover .pill {
  background-color: white;
  color: black;
  border-color: white;
}

.single-veranstaltung h2 {
  margin-bottom: 8px;
}
.single-veranstaltung .headerbild {
  padding-top: var(--distance-m);
  margin-bottom: var(--distance-m);
}
.single-veranstaltung .headerbild img {
  display: block;
}

#kontaktdaten {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 1rem;
  padding-top: var(--distance-l);
  margin-bottom: 0;
  border-top: 1px solid black;
}
@media screen and (max-width: 599px) {
  #kontaktdaten {
    grid-template-columns: repeat(1, minmax(0, 1fr));
    border: none;
    padding-top: 0;
  }
}
#kontaktdaten #karte {
  width: 83%;
  height: 100%;
  position: relative;
}
#kontaktdaten #karte img {
  display: block;
  height: 100%;
  object-fit: cover;
  position: absolute;
}
@media screen and (max-width: 599px) {
  #kontaktdaten #karte img {
    position: static;
    height: auto;
  }
}
@media screen and (max-width: 599px) {
  #kontaktdaten #karte {
    width: 100%;
    height: auto;
  }
}
#kontaktdaten .adresse {
  margin: 1em 0;
}
#kontaktdaten .anmerkung {
  margin-top: 2.6em;
}

.textpage #main .wrapper ol, .textpage #main .wrapper ul {
  list-style: initial;
  margin-bottom: 1.2em;
  padding-left: 1.1em;
}
.textpage #main .wrapper h3, .textpage #main .wrapper h4 {
  font-weight: bold;
  margin-top: 1.5em;
  margin-bottom: 1em;
}
.swiper-btn-prev,
.swiper-btn-next {
  position: absolute;
  width: 50%;
  height: 100%;
  top: 0;
  z-index: 1;
}
.swiper-btn-prev::after,
.swiper-btn-next::after {
  display: none;
}
@media (pointer: coarse) {
  .swiper-btn-prev,
  .swiper-btn-next {
    display: none !important;
  }
}
.swiper-btn-prev:focus,
.swiper-btn-next:focus {
  outline: none;
}

.swiper-btn-prev {
  left: 0;
  cursor: url("images/arrow-left-small.svg"), pointer;
  cursor: url("images/arrow-left-small.svg") 0 21, pointer;
}

.swiper-btn-next {
  right: 0;
  cursor: url("images/arrow-small.svg"), pointer;
  cursor: url("images/arrow-small.svg") 100 21, pointer;
}

.news section:last-child, #ehemalige section:last-child {
  margin-bottom: 0;
}
.news article .vorschaubild, #ehemalige article .vorschaubild {
  width: 100%;
  margin-bottom: 1rem;
}
.news article .vorschaubild img, #ehemalige article .vorschaubild img {
  width: 100%;
  display: block;
}
.news article .metainfos, #ehemalige article .metainfos {
  margin-bottom: 0.5em;
}
.news article .anleser, #ehemalige article .anleser {
  margin: 0.8em 0 0;
}
.news article .anleser p:last-of-type, #ehemalige article .anleser p:last-of-type {
  display: inline;
}
.news .weiterlesen-link, #ehemalige .weiterlesen-link {
  color: var(--color-primary);
}

.news .news-grid[data-show="1"] article:nth-child(n+4) {
  display: none;
}
.news .news-grid[data-show="2"] article:nth-child(n+7) {
  display: none;
}
.news .news-grid[data-show="3"] article:nth-child(n+10) {
  display: none;
}
.news .news-grid[data-show="4"] article:nth-child(n+13) {
  display: none;
}
.news .news-grid[data-show="5"] article:nth-child(n+16) {
  display: none;
}
.news .load-more-wrapper {
  grid-column-start: 1;
  grid-column-end: -1;
}
.news .load-more-wrapper button {
  margin-top: 0;
}
.news .load-more-wrapper button.hide {
  display: none;
}

.news-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 1rem;
  grid-row-gap: var(--distance-m);
  /*
  @media screen and (max-width: 1024px){
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-gap: 2.5rem;
  }
   */
}
@media screen and (max-width: 599px) {
  .news-grid {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
}

.single-news #main .wrapper, .job #main .wrapper {
  margin-top: calc(var(--header-height) + 2rem);
}
.single-news #main .wrapper .headerbild, .job #main .wrapper .headerbild {
  margin-bottom: var(--distance-m);
}
.single-news #main .wrapper .headerbild img, .job #main .wrapper .headerbild img {
  display: block;
}
.single-news #main .wrapper section, .job #main .wrapper section {
  margin-bottom: var(--distance-m);
}
.single-news #main .wrapper section.bilder img, .job #main .wrapper section.bilder img {
  display: block;
}
.single-news #main .wrapper .metainfos, .job #main .wrapper .metainfos {
  margin-bottom: 0.5em;
}
.single-news #main .wrapper .anleser, .job #main .wrapper .anleser {
  margin-top: 1em;
  margin-bottom: 1.2em;
}
.single-news #main .wrapper .share-buttons, .job #main .wrapper .share-buttons {
  display: flex;
  justify-content: center;
  margin-top: 3em;
}
.single-news #main .wrapper .share-buttons a, .job #main .wrapper .share-buttons a {
  display: block;
  margin: 0 0.25em;
}
.single-news #main .wrapper .share-buttons img, .job #main .wrapper .share-buttons img {
  height: 1.3em;
  width: auto;
  display: block;
}

.bilder-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 1rem;
  grid-row-gap: var(--distance-m);
}
@media screen and (max-width: 599px) {
  .bilder-grid {
    grid-template-columns: repeat(1, minmax(0, 1fr));
  }
}
.bilder-grid img {
  display: block;
}

img.portrait {
  width: 70%;
  margin: 0 auto;
  display: block;
}

hr {
  width: 5em;
  margin-left: 0;
  margin-bottom: 2em;
  margin-top: 2em;
  background: black;
  height: 1px;
  border: none;
}

.job #main .wrapper {
  margin-top: calc(var(--header-height) + 4rem);
}

blockquote {
  font-size: 2em;
  text-align: center;
  padding: 0 1em;
  margin: 1em 0;
}

.karriere #jobs .title,
.careers #jobs .title {
  margin-bottom: 0.2em;
}
.karriere #jobs .kurzbeschreibung,
.careers #jobs .kurzbeschreibung {
  margin-bottom: 1em;
}
.karriere #jobs a.pill,
.careers #jobs a.pill {
  color: currentColor;
}
.karriere #jobs a.pill:hover,
.careers #jobs a.pill:hover {
  color: var(--color-primary);
}

@media (pointer: fine) {
  .with-arrows .swiper-slide {
    pointer-events: none;
  }
  .with-arrows .swiper-slide a, .with-arrows .swiper-slide button {
    pointer-events: auto;
  }
  .with-arrows .pagination-wrapper {
    z-index: 1;
  }
  .with-arrows .swiper-btn-next, .with-arrows .swiper-btn-prev {
    z-index: 0;
  }
}

.back-to-news .pill {
  margin-bottom: 0;
}

.mt-xs {
  margin-top: var(--distance-xs);
}

.mt-s {
  margin-top: var(--distance-s);
}

.mt-m {
  margin-top: var(--distance-m);
}

.mt-l {
  margin-top: var(--distance-l);
}

.mt-xl {
  margin-top: var(--distance-xl);
}

.pt-xl {
  padding-top: var(--distance-xl);
}

.mb-xs {
  margin-bottom: var(--distance-xs);
}

.mb-s {
  margin-bottom: var(--distance-s);
}

.mb-m {
  margin-bottom: var(--distance-m);
}

.mb-l {
  margin-bottom: var(--distance-l);
}

.mb-xl {
  margin-bottom: var(--distance-xl);
}

blockquote {
  text-align: inherit;
  margin: 0;
  padding: 0;
  font-size: inherit;
}

.bildunterschrift {
  font-size: 0.9em;
}

.hidden {
  display: none;
}

@media screen and (max-width: 599px) {
  .smartphone-hidden {
    display: none;
  }
}

@media screen and (max-width: 599px) {
  .smartphone-initial {
    display: initial;
  }
}

dialog::backdrop {
  background: rgba(0, 0, 0, 0.8);
}

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