:root {
  --headline: db-head, sans-serif;
  --copy: db-text, sans-serif;
  --copy-color: #282D37;
  --background: #F0F3F5;
  --background-rgb: 250, 248, 249;
  --grey: #D7DCE1;
  --grey-rgb: 215, 220, 225;
  --white: #fff;
  --db-red: #EC0016;
  --font-size: 16px;
  --light: 300;
  --regular: 400;
  --medium: 500;
  --semibold: 600;
  --bold: 700;
  --grid-gap: 40px;
  --space: 20px;
  --asv: 112px;
  font-size: 100% !important;
  --swiper-navigation-size: 16px;
  --swiper-navigation-color: #fff;
  --teil-1: #001E43;
  --teil-2: #14342B;
  --teil-3: #480001;
}

* {
  box-sizing: border-box;
  margin: 0;
}

/* Font */
@font-face {
  font-family: "db-head";
  font-weight: 700;
  src: url(../fonts/DBScreenHead-Black.ttf);
}
@font-face {
  font-family: "db-head";
  font-weight: 400;
  src: url(../fonts/DBScreenHead-Regular.ttf);
}
@font-face {
  font-family: "db-head";
  font-weight: 300;
  src: url(../fonts/DBScreenHead-Light.ttf);
}
@font-face {
  font-family: "db-text";
  font-weight: 400;
  src: url(../fonts/DBScreenSans-DigitalRegular.ttf);
}
@font-face {
  font-family: "db-text";
  font-weight: 500;
  src: url(../fonts/DBScreenSans-Medium.ttf);
}
@font-face {
  font-family: "db-text";
  font-weight: 600;
  src: url(../fonts/DBScreenSans-SemiBold.ttf);
}
@font-face {
  font-family: "db-text";
  font-weight: 700;
  src: url(../fonts/DBScreenSans-Bold.ttf);
}
html {
  scroll-behavior: smooth;
}

/* Reset */
body .doc-container {
  font-family: db-text, SourceSans, Arial, Helvetica, sans-serif;
}
body .doc-container .doc-content {
  padding-bottom: 0 !important;
}
body .doc-container .footer-asv-disclaimer {
  background: var(--grey);
  padding: 20px 40px;
}

@keyframes show-later {
  0%, 45% {
    opacity: 0;
  }
  60%, 100% {
    opacity: 1;
  }
}
.sz {
  --asv: 60px;
}

* {
  box-sizing: border-box;
}

.grid {
  display: grid;
  grid-template-columns: repeat(14, 1fr);
  grid-gap: var(--grid-gap);
  max-width: 1500px;
  width: 100%;
}
.grid > .content {
  max-width: 650px;
  display: flex;
  flex-flow: column;
  gap: var(--font-size);
}

main.db {
  background-color: var(--background);
  font-family: var(--headline);
  font-size: var(--font-size);
  line-height: 1.4;
  color: var(--copy-color);
  position: relative;
  display: flex;
  flex-flow: column;
  gap: calc(2 * var(--grid-gap));
  align-items: center;
  overflow-x: hidden;
  min-height: 100svh;
  padding-top: var(--asv);
}
main.db > * {
  padding: 0 var(--space);
  background: var(--background);
}
main.db h1 {
  font-size: 3.74rem;
  font-weight: var(--bold);
}
main.db h2, main.db h3, main.db h4, main.db h5, main.db h6 {
  font-weight: var(--semibold);
  font-family: var(--headline);
}
main.db h2 {
  font-size: 1.5rem;
}
main.db img {
  background: var(--lightgrey);
}
main.db figure {
  display: flex;
  position: relative;
  align-items: stretch;
  border-radius: 2px;
}
main.db figure div {
  position: relative;
}
main.db figure picture {
  width: 100%;
}
main.db picture {
  display: flex;
  position: relative;
}
main.db picture img {
  width: 100%;
  object-fit: cover;
}
main.db .no-break {
  white-space: nowrap;
  color: inherit;
}
main.db aside.fixed {
  position: fixed;
  display: block;
  z-index: 1500;
  top: 100px;
  transform: rotate(90deg);
  left: 44px;
  transform-origin: 0 0;
}
main.db aside.fixed button {
  font-family: var(--headline);
  font-size: var(--font-size);
  font-weight: var(--bold);
  background: var(--background);
  padding: 12px 24px;
  border: 1px solid var(--darkblue);
  cursor: pointer;
  width: max-content;
  animation: show-later 10s 1;
}
main.db header {
  grid-template-rows: calc(2 * var(--space)) auto var(--space) auto var(--space) 1fr;
  padding-top: var(--space);
}
main.db header .title {
  grid-row: 2;
  grid-column: 1/span 6;
  padding: calc(1.5 * var(--space));
  background: var(--background);
  font-weight: var(--bold);
  z-index: 5;
}
main.db header .title h1 {
  display: flex !important;
  flex-flow: column;
  text-align: left;
}
main.db header .title h1 .title-2 {
  font-weight: var(--medium);
  font-size: 2.74rem;
  align-self: center;
}
main.db header .title h1 .title-3 {
  font-weight: var(--light);
  font-size: 2.5rem;
  align-self: end;
}
main.db header figure {
  grid-row: 1/span 4;
  grid-column: 5/span 10;
  z-index: 1;
}
main.db header .person {
  grid-row: 3/span 4;
  grid-column: 2/span 4;
  aspect-ratio: 10/13;
  position: relative;
}
main.db header .person figcaption {
  position: absolute;
  display: flex;
  flex-flow: column;
  justify-content: end;
  align-items: center;
  width: 100%;
  aspect-ratio: 10/13;
  padding: 6%;
}
main.db header .person figcaption svg {
  width: 100%;
  align-self: end;
}
main.db header .intro {
  grid-row: 5;
  grid-column: 6/span 6;
  max-width: 650px;
  font-size: 1.25em;
}
main.db header .scroll {
  grid-row: 6;
  grid-column: 6;
}

.image-l {
  align-items: center;
}
.image-l figure {
  aspect-ratio: 9/6;
}
.image-l.right .content {
  grid-column: 3/span 5;
}
.image-l.right figure {
  grid-column: 9/span 6;
}
.image-l.left .content {
  grid-column: 8/span 5;
}
.image-l.left figure {
  grid-column: 2/span 6;
  aspect-ratio: 9/6;
}
.image-l.box.left {
  grid-template-rows: var(--grid-gap) auto var(--grid-gap);
}
.image-l.box.left .box {
  background: var(--teil-2);
  grid-row: 2/span 2;
  grid-column: 1/span 13;
  width: 100%;
  height: 100%;
  display: flex;
}
.image-l.box.left .content {
  grid-row: 2/span 2;
  grid-column: 8/span 5;
  color: var(--white);
  padding: calc(2 * var(--space)) 0;
}
.image-l.box.left figure {
  grid-row: 1/span 2;
  grid-column: 2/span 6;
}

.image-p {
  align-items: center;
}
.image-p figure {
  aspect-ratio: 10/15;
}
.image-p.right .content {
  grid-column: 3/span 5;
  grid-row: 1;
}
.image-p.right figure {
  grid-column: 9/span 4;
}
.image-p.left .content {
  grid-column: 7/span 5;
  grid-row: 1;
}
.image-p.left figure {
  grid-column: 3/span 4;
}
.image-p.box.left .box {
  background: var(--teil-2);
  grid-row: 2;
  grid-column: 1/span 13;
  width: 100%;
  height: 100%;
  display: flex;
}
.image-p.box.left .content {
  grid-row: 2;
  grid-column: 7/span 5;
  color: var(--white);
  padding: calc(2 * var(--space)) 0;
}
.image-p.box.left figure {
  grid-row: 1/span 3;
  grid-column: 2/span 4;
}
.image-p.box.right .box {
  background: var(--teil-2);
  grid-row: 2;
  grid-column: 2/span 13;
  width: 100%;
  height: 100%;
  display: flex;
}
.image-p.box.right .content {
  grid-row: 2;
  grid-column: 3/span 5;
  color: var(--white);
  padding: calc(2 * var(--space)) 0;
}
.image-p.box.right figure {
  grid-row: 1/span 3;
  grid-column: 10/span 4;
}

footer.db {
  background: var(--grey);
  width: 100%;
  display: flex;
  flex-flow: column;
  align-items: center;
  padding: calc(2 * var(--space)) var(--space);
  gap: calc(2 * var(--space));
}
footer.db > * {
  max-width: 1500px;
}
footer.db .grid {
  display: grid;
  grid-template-columns: repeat(14, 1fr);
  grid-gap: var(--grid-gap);
  max-width: 1500px;
}
footer.db .image-p figure {
  aspect-ratio: 6/7;
}
footer.db .social .social-buttons {
  display: flex;
  flex-flow: row wrap;
  gap: calc(1.5 * var(--space));
  margin-top: var(--space);
}
footer.db .social .social-buttons a {
  aspect-ratio: 1/1;
  display: flex;
  align-items: center;
  justify-content: center;
}
footer.db .social .social-buttons a svg {
  max-width: 30px;
  width: 100%;
  height: 100%;
  max-height: 30px;
  fill: var(--copy-color);
}
footer.db .teaser {
  width: 100%;
  height: fit-content;
  display: grid;
  grid-template-columns: repeat(14, 1fr);
  padding-top: var(--grid-gap);
}
footer.db .teaser .title {
  grid-column: 3/span 12;
  grid-template-columns: repeat(14, 1fr);
  display: grid;
  align-items: center;
  padding: 0;
}
footer.db .teaser .title h2 {
  margin: auto;
  width: fit-content;
  text-align: center;
  font-size: 2.5rem;
  background: var(--grey);
  padding: 0 1rem;
  position: relative;
  grid-row: 1;
  grid-column: 1/span 12;
}
footer.db .teaser .title::before {
  content: "";
  height: 2px;
  width: 100%;
  background: var(--db-red);
  display: block;
  margin: auto;
  grid-row: 1;
  grid-column: 1/span 12;
}
footer.db .teaser p {
  grid-column: 1/span 14;
  max-width: 650px;
  margin: auto;
}
footer.db .teaser a {
  text-decoration: none;
  display: grid;
  grid-template-rows: auto calc(2 * var(--space)) auto;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space);
}
footer.db .teaser a figure {
  z-index: 1;
  grid-column: 1/span 3;
  width: 75%;
}
footer.db .teaser a article {
  z-index: 5;
  padding: var(--space);
  background: var(--background);
  gap: 1rem;
  display: flex;
  flex-flow: column;
  align-items: flex-start;
  grid-column: 1/span 3;
  width: 75%;
}
footer.db .teaser a article h3 {
  font-size: 1.125rem;
}
footer.db .teaser a article h3 p {
  font-size: 0.875rem;
  font-weight: var(--regular);
}
footer.db .teaser a article p {
  margin: 0;
}
footer.db .teaser a article .btn {
  padding: 10px 20px;
  color: var(--white);
  font-family: var(--copy);
  font-weight: var(--semibold);
  font-size: 0.875rem;
}
footer.db .teaser a:first-of-type {
  grid-column: 3/span 5;
}
footer.db .teaser a:first-of-type figure {
  grid-row: 1/span 2;
  justify-self: start;
}
footer.db .teaser a:first-of-type article {
  grid-row: 2/span 2;
  justify-self: end;
  align-self: start;
}
footer.db .teaser a:nth-of-type(2) {
  grid-column: 8/span 5;
}
footer.db .teaser a:nth-of-type(2) figure {
  grid-row: 2/span 2;
  justify-self: end;
}
footer.db .teaser a:nth-of-type(2) article {
  grid-row: 1/span 2;
  justify-self: start;
  align-self: end;
}
footer.db .teaser a.teil-1 .btn {
  background: var(--teil-1);
}
footer.db .teaser a.teil-2 .btn {
  background: var(--teil-2);
}
footer.db .teaser a.teil-3 .btn {
  background: var(--teil-3);
}

.footer-copyright {
  margin: var(--grid-gap) 0;
  text-align: center;
}

@media screen and (max-height: 800px) {
  main.db header .title {
    grid-column: 1/span 7;
  }
  main.db header .title h1 {
    font-size: 3.5rem;
  }
  main.db header .title h1 .title-2 {
    font-size: 2.5rem;
  }
  main.db header .title h1 .title-3 {
    font-size: 2rem;
  }
  main.db header figure:first-of-type {
    max-height: 520px;
  }
  main.db header .person {
    grid-column: 3/span 3;
  }
}
@media screen and (max-width: 1300px) {
  main.db header .title {
    grid-column: 1/span 7;
  }
  main.db header .title h1 {
    font-size: 3rem;
  }
  main.db header .title h1 .title-2 {
    font-size: 2.3rem;
  }
  main.db header .title h1 .title-3 {
    font-size: 2.25rem;
  }
  main.db .image-l.left .content {
    grid-column: 8/span 6;
  }
  main.db .image-l.left.box .box {
    grid-column: 1/span 14;
  }
  main.db .image-l.right .content {
    grid-column: 3/span 6;
  }
  main.db .image-p.right .content {
    grid-column: 3/span 6;
  }
  main.db .image-p.left .content {
    grid-column: 7/span 6;
  }
  main.db .image-p.left.box .box {
    grid-column: 1/span 14;
  }
  main.db .image-p.left.box figure {
    grid-column: 2/span 5;
  }
  main.db .image-p.left.box .content {
    grid-column: 7/span 7;
  }
}
@media screen and (max-width: 1080px) {
  :root {
    --grid-gap: 40px;
  }
  main.db header .title {
    grid-column: 1/span 8;
    padding: calc(1.5 * var(--space));
  }
  main.db header .person {
    grid-column: 2/span 5;
  }
  main.db header .intro {
    grid-column: 7/span 7;
  }
  main.db .image-l.left .content {
    grid-row: 2;
    grid-column: 4/span 10;
  }
  main.db .image-l.left figure {
    grid-row: 1;
    grid-column: 2/span 8;
  }
  main.db .image-l.right .content {
    grid-row: 2;
    grid-column: 3/span 11;
  }
  main.db .image-l.right figure {
    grid-row: 1;
    grid-column: 7/span 8;
  }
  main.db .image-l.box.left {
    margin-left: calc(-2 * var(--space));
    grid-template-rows: auto calc(2 * var(--grid-gap)) auto;
  }
  main.db .image-l.box.left .box {
    grid-row: 2/span 2;
    grid-column: 1/span 13;
  }
  main.db .image-l.box.left .content {
    grid-row: 3;
    grid-column: 3/span 9;
    padding: 0 var(--grid-gap) var(--grid-gap);
  }
  main.db .image-l.box.left figure {
    margin-left: calc(2 * var(--space));
    wdth: calc(100% + 2 * var(--space));
    grid-row: 1/span 2;
    grid-column: 2/span 8;
  }
  main.db .image-p.left .content {
    grid-row: 2;
    grid-column: 3/span 11;
  }
  main.db .image-p.left figure {
    aspect-ratio: 4/5;
    grid-row: 1;
    grid-column: 2/span 6;
  }
  main.db .image-p.left.box .box {
    grid-row: 2/span 2;
    grid-column: 1/span 13;
  }
  main.db .image-p.left.box figure {
    grid-row: 1/span 2;
    grid-column: 2/span 5;
  }
  main.db .image-p.left.box .content {
    grid-row: 3;
    grid-column: 3/span 11;
    padding: 0 var(--grid-gap) var(--grid-gap);
  }
  main.db .image-p.right .content {
    grid-row: 2;
    grid-column: 3/span 11;
  }
  main.db .image-p.right figure {
    aspect-ratio: 4/5;
    grid-row: 1;
    grid-column: 8/span 6;
  }
  main.db .image-p.box.right {
    margin-right: calc(-2 * var(--space));
    grid-template-rows: auto calc(2 * var(--grid-gap)) auto;
  }
  main.db .image-p.box.right figure {
    aspect-ratio: 4/5;
    grid-column: 10/span 4;
    grid-row: 1/span 2;
    align-self: start;
  }
  main.db .image-p.box.right .content {
    grid-row: 2/span 2;
    grid-column: 2/span 11;
    padding: var(--grid-gap);
  }
  main.db .image-p.box.right .content h2 {
    max-width: 90%;
  }
  main.db .image-p.box.right .box {
    grid-row: 2/span 2;
    grid-column: 2/span 13;
  }
  main.db .teaser a.teaser-box {
    max-width: 650px;
    width: 100%;
    grid-template-columns: auto var(--grid-gap) auto;
    grid-template-rows: auto var(--grid-gap) auto;
  }
  main.db .teaser a.teaser-box article {
    width: 100%;
  }
  main.db .teaser a.teaser-box:first-of-type {
    grid-row: 3;
    grid-column: 1/span 14;
    justify-self: start;
  }
  main.db .teaser a.teaser-box:first-of-type article {
    grid-column: 2/span 2;
  }
  main.db .teaser a.teaser-box:last-of-type {
    grid-row: 4;
    grid-column: 1/span 14;
    justify-self: end;
  }
  main.db .teaser a.teaser-box:last-of-type article {
    grid-column: 1/span 2;
  }
}
@media screen and (max-width: 850px) {
  :root {
    --grid-gap: 25px;
  }
  .grid {
    grid-template-columns: repeat(12, 1fr);
  }
  main.db header {
    grid-template-rows: auto calc(2 * var(--space)) auto calc(1.5 * var(--space)) auto;
    padding-top: 0;
  }
  main.db header .title {
    grid-row: 1/span 2;
    grid-column: 1/span 9;
    padding: var(--space);
  }
  main.db header .title h1 {
    font-size: 2.65rem;
  }
  main.db header .title h1 .title-2 {
    font-size: 1.9rem;
  }
  main.db header .title h1 .title-3 {
    font-size: 1.75rem;
  }
  main.db header figure:first-of-type {
    grid-row: 2/span 3;
    grid-column: 3/span 10;
    aspect-ratio: 8/5;
  }
  main.db header .person {
    grid-row: 4/span 2;
    grid-column: 2/span 4;
  }
  main.db header .intro {
    grid-column: 6/span 7;
  }
  main.db .image-l.right .content, main.db .image-l.left .content, main.db .image-p.right .content, main.db .image-p.left .content {
    grid-column: 1/span 12;
    justify-self: center;
  }
  main.db .image-l.right figure {
    grid-column: 5/span 8;
  }
  main.db .image-l.left figure {
    grid-column: 1/span 8;
  }
  main.db .image-l.box.left .box {
    grid-column: 1/span 12;
  }
  main.db .image-l.box.left figure {
    margin: 0;
  }
  main.db .image-l.box.left .content {
    grid-column: 1/span 12;
  }
  main.db .image-p.right {
    grid-column: 7/span 6;
  }
  main.db .image-p.box.right .content {
    grid-row: 3;
    padding: 0 var(--grid-gap) var(--grid-gap);
    grid-column: 1/span 12;
  }
  main.db .image-p.box.right figure {
    grid-column: 6/span 6;
  }
  main.db .image-p.box.right .box {
    grid-column: 1/span 12;
  }
  main.db .image-p.box.left .box {
    grid-row: 2/span 2;
    grid-column: 1/span 13;
  }
  main.db .image-p.box.left figure {
    grid-row: 1/span 2;
    grid-column: 2/span 6;
  }
  main.db .image-p.box.left .content {
    grid-row: 3;
    padding: 0 var(--grid-gap) var(--grid-gap);
    grid-column: 1/span 12;
  }
  main.db .social {
    max-width: 650px;
    width: 100%;
  }
  main.db footer.db .grid {
    grid-template-columns: repeat(12, 1fr);
  }
  main.db footer.db .title, main.db footer.db .teaser-box, main.db footer.db .teaser p {
    grid-column: 1/span 12 !important;
  }
  main.db footer.db .title {
    grid-template-columns: repeat(12, 1fr);
  }
  main.db footer.db .teaser-box {
    max-width: 75%;
    min-width: 250px;
  }
}
@media screen and (max-width: 590px) {
  main.db header {
    grid-template-rows: auto calc(2 * var(--space)) calc(2 * var(--space)) auto calc(2 * var(--space)) auto;
  }
  main.db header .title {
    grid-column: 1/span 10;
    padding: var(--space);
  }
  main.db header figure:first-of-type {
    grid-column: 1/span 11;
  }
  main.db header .person {
    grid-column: 8/span 5;
  }
  main.db header .intro {
    grid-row: 6;
    grid-column: 1/span 12;
    max-width: 90%;
    font-size: 1.15rem;
    justify-self: center;
  }
  main.db .image-l.right figure {
    grid-column: 3/span 10;
  }
  main.db .image-l.left figure {
    grid-column: 1/span 10;
  }
  main.db .image-l.box.left {
    padding-right: 0;
  }
  main.db .image-l.box.left figure {
    grid-column: 2/span 10;
  }
  main.db .image-p.right figure {
    grid-column: 6/span 7;
  }
  main.db .image-p.box.right {
    padding-left: 0;
  }
  main.db .image-p.box.right figure {
    grid-column: 5/span 7;
  }
  main.db .image-p.box.left {
    padding-left: 0;
  }
  main.db .image-p.box.left figure {
    grid-column: 2/span 7;
  }
}
@media screen and (max-width: 480px) {
  main.db header {
    grid-template-rows: auto calc(2 * var(--space)) calc(4 * var(--space)) auto calc(2 * var(--space)) auto;
  }
  main.db header .title {
    grid-column: 1/span 11;
    padding: var(--space) var(--space) var(--space) 0;
  }
  main.db header .title h1 {
    font-size: 1.9rem;
  }
  main.db header .title h1 .title-2 {
    font-size: 1.4rem;
  }
  main.db header .title h1 .title-3 {
    font-size: 1.2rem;
  }
  main.db header figure:first-of-type {
    grid-column: 1/span 12;
  }
  footer.db .teaser .title h2 {
    font-size: 2rem;
  }
  footer.db .teaser a figure {
    width: 95%;
  }
  footer.db .image-p.left figure {
    grid-column: 3/span 8;
  }
  footer.db .social .social-buttons {
    gap: var(--space);
  }
  footer.db .social .social-buttons a svg {
    max-width: 25px;
    max-height: 25px;
  }
}
@media screen and (max-width: 420px) {
  main.db header .person {
    grid-column: 6/span 7;
    margin-right: var(--space);
  }
}
@media screen and (max-width: 380px) {
  main.db header .title {
    grid-column: 1/span 12;
  }
}