/* fira-sans-regular - latin */
@font-face {
  font-family: "Fira Sans";
  font-style: normal;
  font-weight: 400;
  src: url("/fonts/fira-sans-v11-latin-regular.eot"); /* IE9 Compat Modes */
  src: local(""), url("/fonts/fira-sans-v11-latin-regular.eot?#iefix") format("embedded-opentype"), url("/fonts/fira-sans-v11-latin-regular.woff2") format("woff2"), url("/fonts/fira-sans-v11-latin-regular.woff") format("woff"), url("/fonts/fira-sans-v11-latin-regular.ttf") format("truetype"), url("/fonts/fira-sans-v11-latin-regular.svg#FiraSans") format("svg"); /* Legacy iOS */
}
/* fira-sans-500 - latin */
@font-face {
  font-family: "Fira Sans";
  font-style: normal;
  font-weight: 500;
  src: url("/fonts/fira-sans-v11-latin-500.eot"); /* IE9 Compat Modes */
  src: local(""), url("/fonts/fira-sans-v11-latin-500.eot?#iefix") format("embedded-opentype"), url("/fonts/fira-sans-v11-latin-500.woff2") format("woff2"), url("/fonts/fira-sans-v11-latin-500.woff") format("woff"), url("/fonts/fira-sans-v11-latin-500.ttf") format("truetype"), url("/fonts/fira-sans-v11-latin-500.svg#FiraSans") format("svg"); /* Legacy iOS */
}
/* fira-sans-600 - latin */
@font-face {
  font-family: "Fira Sans";
  font-style: normal;
  font-weight: 600;
  src: url("/fonts/fira-sans-v11-latin-600.eot"); /* IE9 Compat Modes */
  src: local(""), url("/fonts/fira-sans-v11-latin-600.eot?#iefix") format("embedded-opentype"), url("/fonts/fira-sans-v11-latin-600.woff2") format("woff2"), url("/fonts/fira-sans-v11-latin-600.woff") format("woff"), url("/fonts/fira-sans-v11-latin-600.ttf") format("truetype"), url("/fonts/fira-sans-v11-latin-600.svg#FiraSans") format("svg"); /* Legacy iOS */
}
*, *:before, *:after {
  box-sizing: border-box;
}

button, hr, input {
  overflow: visible;
}

audio, canvas, progress, video {
  display: inline-block;
}

progress, sub, sup {
  vertical-align: baseline;
}

html {
  font-family: sans-serif;
  line-height: 1.15;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
}

menu, article, aside, details, footer, header, nav, section {
  display: block;
}

h1 {
  font-size: 2em;
  margin: 0.67em 0;
}

figcaption, figure, main {
  display: block;
}

figure {
  margin: 1em 40px;
}

hr {
  box-sizing: content-box;
  height: 0;
}

code, kbd, pre, samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

a {
  background-color: transparent;
  -webkit-text-decoration-skip: objects;
}

a:active, a:hover {
  outline-width: 0;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted;
}

b, strong {
  font-weight: bolder;
}

dfn {
  font-style: italic;
}

mark {
  background-color: #ff0;
  color: #000;
}

small {
  font-size: 80%;
}

sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

audio:not([controls]) {
  display: none;
  height: 0;
}

img {
  border-style: none;
}

svg:not(:root) {
  overflow: hidden;
}

button, input, optgroup, select, textarea {
  font-family: sans-serif;
  font-size: 100%;
  line-height: 1.15;
  margin: 0;
}

button, select {
  text-transform: none;
}

[type=submit], [type=reset], button, html [type=button] {
  -webkit-appearance: button;
}

[type=button]::-moz-focus-inner, [type=reset]::-moz-focus-inner, [type=submit]::-moz-focus-inner, button::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

[type=button]:-moz-focusring, [type=reset]:-moz-focusring, [type=submit]:-moz-focusring, button:-moz-focusring {
  outline: ButtonText dotted 1px;
}

fieldset {
  border: 1px solid silver;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}

legend {
  box-sizing: border-box;
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

textarea {
  overflow: auto;
}

[type=checkbox], [type=radio] {
  box-sizing: border-box;
  padding: 0;
}

[type=number]::-webkit-inner-spin-button, [type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type=search]::-webkit-search-cancel-button, [type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

summary {
  display: list-item;
}

[hidden], template {
  display: none;
} 
* {
  box-sizing: border-box;
  /*outline: 1px solid red;*/
}

html {
  -webkit-text-size-adjust: 100%;
}

body {
  -moz-osx-font-smoothing: grayscale;
  font-family: "Fira Sans", sans-serif;
  background: #f8f8f8;
  margin: 0;
  padding: 0;
}

h1 {
  color: #fff;
  font-size: 46px;
  font-weight: 700;
  margin-top: 150px;
  margin-bottom: 50px;
  font-family: "Fira Sans", serif;
  text-shadow: 0px 0px 4px rgba(0, 0, 0, 0.9);
  text-align: center;
  width: 1000px;
  max-width: calc(100vw - 20px);
}
h1.black {
  color: #000;
}
h1.white {
  color: #fff;
}
h1.red {
  color: #D30132;
}
h1.grey {
  color: #484848;
}
h1.none {
  color: transparent;
  text-shadow: none;
}

/*.bau h1 {
	color: #000;
}*/
h2 {
  font-weight: 500;
  line-height: 1.4;
  margin-top: 0;
}

h3 {
  margin-top: 0;
  font-weight: 500;
  line-height: 1.4;
  font-size: 1.375em;
}

h4 {
  margin-top: 0;
}

p,
ul {
  font-size: 20px;
  line-height: 1.5;
  margin: 0 0 1em 0;
}

img {
  max-width: 100%;
  height: auto;
  border-color: #D30132;
}

.img-wrap {
  display: inline;
}
.img-wrap img {
  margin-bottom: 1em;
}

img.text-right,
img.float-right {
  float: right;
  margin-left: 1em;
  margin-bottom: 1em;
}
@media screen and (max-width: 640px) {
  img.text-right,
  img.float-right {
    float: none;
    margin-left: 0;
  }
}

img.text-left,
img.float-left {
  float: left;
  margin-right: 1em;
  margin-bottom: 1em;
}
@media screen and (max-width: 640px) {
  img.text-left,
  img.float-left {
    float: none;
    margin-right: 0;
  }
}

img.full {
  width: calc(100% + 80px);
  max-width: inherit;
  margin: -40px 0 20px -40px;
}

a {
  color: #D30132;
}
a:hover {
  text-decoration: underline;
}

a.button {
  display: inline-block;
  padding: 10px 20px;
  background: #D30132;
  color: #fff;
  text-decoration: none;
  margin-bottom: 1rem;
  transition: all 0.2s ease-in-out;
}
a.button.active {
  font-weight: 900;
}
a.button:hover {
  background: #C10100;
}
a.button.white {
  background: #fff;
  color: #D30132;
}
a.button.black {
  background: #484848;
  color: #fff;
}
a.button.s28 {
  background: #00823d;
  color: #fff;
}
a.button.re47 {
  background: #d57823;
  color: #fff;
}

ul.lead {
  font-size: 1.25rem;
  line-height: 1.5;
}

a.logo {
  width: 200px;
  min-width: 200px;
  padding: 20px;
}

a.logo img {
  max-width: 100%;
  max-height: 30px;
}

.text-center {
  text-align: center;
}

.text-justify {
  text-align: justify;
}

img.text-center {
  display: block;
  margin-left: auto;
  margin-right: auto;
}

@media screen and (max-width: 58.75rem) {
  h1 {
    color: #fff;
    font-size: 1.625rem;
    font-weight: 500;
    margin-top: 50px;
    margin-bottom: 50px;
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    -moz-hyphens: auto;
    hyphens: auto;
  }
  h2 {
    -webkit-hyphens: auto;
    -ms-hyphens: auto;
    -moz-hyphens: auto;
    hyphens: auto;
  }
  p,
  ul {
    font-size: 1rem;
  }
  a.logo {
    width: 145px;
    text-align: center;
    padding: 10px 20px;
  }
}
.mobil-nav {
  display: none;
}

.topnav {
  display: flex;
  justify-content: center;
  background: #484848;
}
.topnav ul {
  list-style: none;
  display: flex;
  margin: 0;
  padding: 5px 0 0 0;
  background: none;
}
.topnav ul li {
  margin-left: 10px;
}
.topnav ul li:nth-child(2) {
  margin-right: auto;
}
.topnav ul li:last-child {
  margin-right: 10px;
}
.topnav ul li.social {
  min-width: 40px;
}
.topnav ul li.social a {
  text-align: center;
}
.topnav ul li a {
  color: #fff;
  text-decoration: none;
  padding: 10px;
  display: block;
  font-size: 0.75rem;
  transition: all 0.2s ease-in-out;
  border-top: 2px solid transparent;
}
.topnav ul li a.active, .topnav ul li a:hover {
  background: #fff;
  color: #484848;
  border-top: 2px solid #D30132;
  text-decoration: none;
}
nav,
nav ul {
  width: 100%;
  display: flex;
  background: #fff;
  position: relative;
}

nav {
  align-items: center;
}
nav.mainnav {
  min-height: 60px;
  position: sticky;
  top: 0;
  z-index: 1000;
}
nav ul ul {
  display: none;
  position: absolute;
  /*flex-direction: column;
  min-width: 100%;
  max-width: 100%;*/
  width: 100%;
  left: -20px;
  box-shadow: 0px 4px 4px #484848;
}
nav input {
  display: none;
}
nav ul {
  justify-content: flex-start;
  list-style: none;
  margin: 0;
  padding: 0 20px;
}
nav ul ul {
  flex-wrap: wrap;
}
nav ul ul li {
  width: 230px;
  max-width: 230px;
}
nav ul ul li a {
  padding-right: 20px;
  padding-left: 20px;
}
nav ul li {
  /*position: relative;*/
}
nav ul li a {
  /*transition: $transition;*/
}
nav ul li.suche {
  margin-left: auto;
}
nav ul li.suche a {
  background: url("img/icon-suche.svg") no-repeat center left;
  padding-left: 35px;
  background-size: 25px;
  padding-right: 0;
  min-height: 47px;
  font-size: 0px;
}
nav ul li:hover > ul,
nav ul li:focus > ul,
nav ul li.open > ul {
  display: flex;
  padding: 20px;
}
nav li:hover > a,
nav li.active > a,
nav ul li.open > a {
  color: #D30132;
  text-decoration: none;
}
nav label.mobil-open {
  display: none;
}

.nav-img {
  width: 100%;
  height: auto;
}

nav a,
.mobil-nav {
  padding: 10px;
  display: block;
  text-decoration: none;
  color: #000;
  font-size: 1.125rem;
  font-weight: 500;
}

.mobil-nav {
  display: none;
}

.suche-wrap {
  position: absolute;
  padding: 20px 35px;
  width: 100vw;
  right: -20px;
  background: #f8f8f8;
  display: flex;
  opacity: 0;
  pointer-events: none;
  top: 0px;
  transition: all 0.2s ease-in-out;
}
.suche-wrap input {
  display: flex;
}
.suche-wrap input[type=text] {
  flex: 1 0 300px;
}
.suche-wrap.open {
  opacity: 1;
  pointer-events: auto;
  top: 55px;
  box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.2);
}

@media screen and (max-width: 58.75rem) {
  .topnav {
    display: none;
  }
  .mobil-nav {
    display: block;
    margin-left: auto;
    margin-right: 20px;
    cursor: pointer;
  }
  nav.mainnav {
    position: relative;
  }
  nav.mainnav.mainnav {
    position: relative;
  }
  nav.mainnav ul {
    opacity: 0;
    padding: 0 10px;
    pointer-events: none;
    position: absolute;
    left: 0;
    flex-wrap: wrap;
    top: 80%;
    height: 0;
    overflow: hidden;
    /*transition: all .2s ease-in-out;*/
  }
  input[type=checkbox]:checked + label {
    color: #cf3043;
  }
  input[type=checkbox]:checked + label + ul {
    opacity: 1;
    pointer-events: all;
    top: 100%;
    padding: 0;
    height: auto;
    overflow: visible;
  }
  nav ul li {
    flex: 1 0 100%;
    display: flex;
    flex-wrap: wrap;
    border-top: 1px solid #cccccf;
  }
  nav ul li.tab-nav {
    flex: 0 1 50%;
    border-top: none;
  }
  nav ul li.tab-nav a {
    text-align: center;
    background: #484848;
    color: #fff;
    font-size: 0.75rem;
  }
  nav ul li.tab-nav a.active {
    color: #D30132;
    background: #fff;
  }
  nav ul li.social {
    flex: 0 1 50%;
    border-bottom: 1px solid #cccccf;
    border-right: 1px solid #cccccf;
  }
  nav ul li.social:last-child {
    border-right: none;
  }
  nav ul li.social a {
    text-align: center;
    background: #f8f8f8;
  }
  nav ul li a {
    /*border-bottom: 1px solid $regio-grey;*/
    flex: 1 0 80%;
    padding: 15px 20px;
  }
  nav > ul > li:first-child > a {
    /*border-top: 1px solid $regio-grey;*/
  }
  nav ul li:last-child a {
    border-bottom: none;
  }
  nav ul ul {
    border-left: 5px solid #cccccf;
    padding: 0;
    display: block;
    left: 0;
    flex: 1 0 100%;
    padding: 0;
  }
  nav ul ul li {
    max-width: inherit;
    width: 100%;
  }
  nav ul ul li a {
    background: #f8f8f8;
  }
  nav ul ul li a .nav-img {
    display: none;
  }
  nav ul li:hover > ul {
    display: block;
  }
  nav label.mobil-open {
    display: flex;
    justify-content: center;
    align-items: center;
    flex: 1 0 40px;
    /*border-left: 1px solid #000;*/
    /*font-size: 1.5em;*/
    font-weight: 500;
  }
  nav label.mobil-open .clicked {
    display: none;
  }
  ul li input:checked + label .not-clicked {
    display: none;
  }
  ul li input:checked + label .clicked {
    display: block;
  }
  ul li input:checked + label + ul {
    opacity: 1;
    position: static;
    left: 0;
    flex: 1 0 100%;
  }
  ul li input:checked + label + ul a {
    padding-left: 15px;
  }
  nav ul li.suche a {
    background: url("img/icon-suche.svg") no-repeat center left 20px;
    background-size: auto auto;
    padding-left: 55px;
    background-size: 30px;
  }
}
header {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 30px;
}
header.strecke {
  padding: 0;
  flex-wrap: wrap;
  position: relative;
}
header ul {
  list-style: none;
  width: 580px;
  padding: 0 20px;
  background: rgba(0, 0, 0, 0.2);
}
header li {
  background: #fff;
  margin: 20px 0;
}
header li.open {
  background: #EFEFEF;
  position: relative;
}

.auskunft-wrap {
  background: #EFEFEF;
  position: absolute;
  display: none;
  padding: 0px 30px 30px 30px;
  width: 100%;
  flex-wrap: wrap;
  align-self: flex-end;
  z-index: 1;
}

li.open .auskunft-wrap {
  display: block;
}

li.open .icon-link {
  transform: rotate(90deg);
}

header li.alert {
  background: #D30132;
  color: #fff;
}

header li.warning {
  background: #ffca00;
}

header li a {
  font-size: 1.275rem;
  text-decoration: none;
  color: #000;
  display: block;
  padding: 20px 20px 20px 65px;
  font-weight: 500;
  display: flex;
  width: 100%;
  align-items: center;
}

header li:hover {
  /*transform: skew(-5deg);*/
}

header li:hover a {
  /*transform: skew(5deg);
  padding: 20px 20px 20px 85px;*/
}

header li.fahrplan a {
  background: url("img/icon-fahrplan.svg") no-repeat left 20px center;
  background-size: auto 30px;
}

header li.tickets a {
  background: url("img/icon-tickets.svg") no-repeat left 20px center;
  background-size: auto 30px;
}

header li.info a {
  background: url("img/icon-info.svg") no-repeat left 20px center;
  background-size: auto 30px;
}

header li.warning a {
  background: #ffca00 url("img/icon-bau.svg") no-repeat left 20px center;
  background-size: auto 30px;
}

header li.alert a {
  background: #D30132 url("img/icon-stoerung.svg") no-repeat left 20px center;
  background-size: auto 30px;
  color: #fff;
}

header .icon-link {
  float: right;
  font-size: 2rem;
  line-height: 1.45rem;
  background: url("img/icon-arrow-right.svg") no-repeat center center;
  display: block;
  width: 25px;
  height: 25px;
  margin-left: auto;
}
header .icon-link.white {
  background: url("img/icon-arrow-right-white.svg") no-repeat center center;
}

@media screen and (max-width: 58.75rem) {
  header {
    padding: 20px;
  }
  header ul {
    width: calc(100vw - 40px);
    margin: 0;
    padding: 0;
  }
  header li {
    margin: 10px 0;
  }
  header li:first-child {
    margin-top: 0;
  }
  header li:last-child {
    margin-bottom: 0;
  }
  header li a {
    font-size: 1rem;
    padding: 15px 20px 15px 60px;
  }
  header .icon-link {
    width: 20px;
    height: 20px;
  }
}
/** Formulare **/
fieldset {
  width: 100%;
}

.form-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.form-row .form-row {
  margin: 0 -1%;
}

.form-row > div {
  flex: 1 1 auto;
}

.form-row > div.spalte-100 {
  flex: 0 0 100%;
}

.form-row > div.spalte-75 {
  flex: 0 0 74%;
}

.form-row > div.spalte-66 {
  flex: 0 0 66%;
}

.form-row > div.spalte-50 {
  flex: 0 0 49%;
}

.form-row > div.spalte-33 {
  flex: 0 0 32%;
}

.form-row > div.spalte-25 {
  flex: 0 0 24%;
}

.form-row .spalte-rechts {
  justify-content: flex-end;
}

.form-row > div > div {
  flex: 1 1 auto;
  padding: 0 5px 0 5px;
}

.form-row .radio,
.form-row .checkbox {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}

.form-row label {
  line-height: 1.4;
  font-weight: 500;
}

.form-row input[type=text],
input[type=number],
input[type=email],
.form-row select,
.form-row textarea,
.form-row label {
  width: 100%;
  margin-bottom: 10px;
  border-radius: 0;
  box-shadow: none;
}

.form-row textarea {
  padding: 5px;
  font-family: inherit;
  min-height: 200px;
  border: 1px solid #484848;
}

input[type=text],
input[type=email],
input[type=number],
input[type=submit],
select {
  height: 40px;
  border: 1px solid #484848;
  padding: 5px;
  border-radius: 0;
}

input[type=submit] {
  background: #484848 url("img/icon-arrow-right-white.svg") no-repeat center right 10px;
  background-size: 20px;
  color: #fff;
  padding: 0 40px 0 20px;
  font-weight: 500;
  float: right;
  cursor: pointer;
}

.form-row input[type=radio] {
  border: 0;
  clip: rect(0 0 0 0);
  clip-path: polygon(0px 0px, 0px 0px, 0px 0px);
  -webkit-clip-path: polygon(0px 0px, 0px 0px, 0px 0px);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  white-space: nowrap;
}
.form-row input[type=radio] + label {
  position: relative;
  padding-left: 25px;
  margin-right: 10px;
  width: auto;
}
.form-row input[type=radio] + label:before {
  content: "";
  width: 20px;
  height: 20px;
  display: block;
  background: #fff;
  border: 1px solid #484848;
  border-radius: 10px;
  position: absolute;
  top: 2px;
  left: 0;
  box-sizing: border-box;
}
.form-row input[type=radio]:checked + label:before {
  background: #484848;
}
.form-row input[type=checkbox] {
  border: 0;
  clip: rect(0 0 0 0);
  clip-path: polygon(0px 0px, 0px 0px, 0px 0px);
  -webkit-clip-path: polygon(0px 0px, 0px 0px, 0px 0px);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  white-space: nowrap;
}
.form-row input[type=checkbox] + label {
  position: relative;
  padding-left: 30px;
  margin-right: 10px;
  width: auto;
}
.form-row input[type=checkbox] + label:before {
  content: "";
  width: 20px;
  height: 20px;
  display: block;
  background: #fff;
  border: 1px solid #484848;
  border-radius: 5px;
  position: absolute;
  top: 2px;
  left: 0;
}
.form-row input[type=checkbox]:checked + label:before {
  background: #484848;
}

.input-group {
  display: flex;
}
.input-group input[type=text] {
  flex: 0 1 100%;
}

@media screen and (max-width: 58.75rem) {
  .form-row {
    display: flex;
    flex-wrap: wrap;
  }
  .form-row > div {
    flex: 1 0 100%;
    display: flex;
    padding: 0 !important;
  }
  .form-row .radio {
    padding-top: 10px;
    padding-bottom: 20px;
  }
  .form-row input[type=submit] {
    width: 100%;
    display: block;
  }
}
@media screen and (max-width: 40rem) {
  .form-row {
    display: flex;
    flex-wrap: wrap;
  }
  .form-row div {
    flex: 1 0 100% !important;
    display: flex;
    padding: 0 !important;
  }
  .form-row .radio {
    padding-top: 10px;
    padding-bottom: 20px;
  }
  .form-row input[type=submit] {
    width: 100%;
    display: block;
  }
  .form-row .form-row {
    margin: 0;
  }
}
/*** Hilfe Form ***/
.hilfe-form fieldset {
  background: #eee;
  padding: 20px;
  margin: 0.9375rem 0.9375rem 3rem 0.9375rem;
}

.eu-richtlinie input[type=checkbox],
.hilfe-form input[type=checkbox],
form input[type=checkbox] {
  border: 0;
  clip: rect(0 0 0 0);
  clip-path: polygon(0px 0px, 0px 0px, 0px 0px);
  -webkit-clip-path: polygon(0px 0px, 0px 0px, 0px 0px);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  white-space: nowrap;
}
.eu-richtlinie input[type=checkbox] + label,
.hilfe-form input[type=checkbox] + label,
form input[type=checkbox] + label {
  position: relative;
  padding-left: 34px;
  margin: 0 1rem 1rem 0;
  width: auto;
}
.eu-richtlinie input[type=checkbox] + label:before,
.hilfe-form input[type=checkbox] + label:before,
form input[type=checkbox] + label:before {
  content: "";
  width: 28px;
  height: 28px;
  display: block;
  position: absolute;
  top: -3px;
  left: 0;
  background: #fff;
  border: 2px solid #cccccf;
  border-radius: 5px;
}
.eu-richtlinie input[type=checkbox] + label:after,
.hilfe-form input[type=checkbox] + label:after,
form input[type=checkbox] + label:after {
  position: absolute;
  top: 14px;
  left: 15px;
  content: "";
  width: 0;
  height: 0;
  border: 4px solid transparent;
  border-right: none;
  border-top: none;
  transform: rotate(-45deg);
  transition: all 0.2s cubic-bezier(0.18, 0.89, 0.47, 1.62);
}
.eu-richtlinie input[type=checkbox]:checked + label:before,
.hilfe-form input[type=checkbox]:checked + label:before,
form input[type=checkbox]:checked + label:before {
  background: #fff;
}
.eu-richtlinie input[type=checkbox]:checked + label:after,
.hilfe-form input[type=checkbox]:checked + label:after,
form input[type=checkbox]:checked + label:after {
  position: absolute;
  top: 4px;
  left: 5px;
  content: "";
  width: 20px;
  height: 10px;
  border: 4px solid #D30132;
  border-right: none;
  border-top: none;
  transform: rotate(-45deg);
}
.eu-richtlinie input[type=checkbox]:focus + label,
.hilfe-form input[type=checkbox]:focus + label,
form input[type=checkbox]:focus + label {
  outline: 2px solid black;
}
.eu-richtlinie input[type=checkbox]:disabled:checked + label,
.hilfe-form input[type=checkbox]:disabled:checked + label,
form input[type=checkbox]:disabled:checked + label {
  color: #cccccf;
  cursor: not-allowed;
}
.eu-richtlinie input[type=checkbox]:disabled:checked + label:after,
.hilfe-form input[type=checkbox]:disabled:checked + label:after,
form input[type=checkbox]:disabled:checked + label:after {
  border: 4px solid #cccccf;
  border-right: none;
  border-top: none;
}
.eu-richtlinie input[type=radio],
.hilfe-form input[type=radio],
form input[type=radio] {
  border: 0;
  clip: rect(0 0 0 0);
  clip-path: polygon(0px 0px, 0px 0px, 0px 0px);
  -webkit-clip-path: polygon(0px 0px, 0px 0px, 0px 0px);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  white-space: nowrap;
}
.eu-richtlinie input[type=radio] + label,
.hilfe-form input[type=radio] + label,
form input[type=radio] + label {
  position: relative;
  padding-left: 34px;
  margin: 0 1rem 1rem 0;
  width: auto;
}
.eu-richtlinie input[type=radio] + label:before,
.hilfe-form input[type=radio] + label:before,
form input[type=radio] + label:before {
  content: "";
  width: 28px;
  height: 28px;
  border-radius: 14px;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  background: #fff;
  border: 2px solid #cccccf;
}
.eu-richtlinie input[type=radio] + label:after,
.hilfe-form input[type=radio] + label:after,
form input[type=radio] + label:after {
  position: absolute;
  background: #D30132;
  top: 15px;
  left: 15px;
  content: "";
  width: 0;
  height: 0;
  border-radius: 12px;
  transition: all 0.2s cubic-bezier(0.18, 0.89, 0.47, 1.62);
}
.eu-richtlinie input[type=radio]:checked + label:after,
.hilfe-form input[type=radio]:checked + label:after,
form input[type=radio]:checked + label:after {
  position: absolute;
  top: 8px;
  left: 8px;
  content: "";
  width: 12px;
  height: 12px;
}
.eu-richtlinie input[type=radio]:focus + label,
.hilfe-form input[type=radio]:focus + label,
form input[type=radio]:focus + label {
  outline: 2px solid black;
}
.eu-richtlinie input[type=radio]:disabled:checked + label,
.hilfe-form input[type=radio]:disabled:checked + label,
form input[type=radio]:disabled:checked + label {
  color: #cccccf;
  cursor: not-allowed;
}
.eu-richtlinie label,
.hilfe-form label,
form label {
  font-size: 1rem;
}
.eu-richtlinie input[type=submit],
.hilfe-form input[type=submit],
form input[type=submit] {
  margin-bottom: 1rem !important;
}
.eu-richtlinie .accordion,
.hilfe-form .accordion,
form .accordion {
  border: 1px solid #f8f8f8;
  margin-bottom: 1rem !important;
}
.eu-richtlinie .accordion .accordion-item > a,
.hilfe-form .accordion .accordion-item > a,
form .accordion .accordion-item > a {
  padding: 5px 10px;
  background: #f8f8f8;
  display: block;
  position: relative;
}
.eu-richtlinie .accordion .accordion-item > a:after,
.hilfe-form .accordion .accordion-item > a:after,
form .accordion .accordion-item > a:after {
  content: "";
  width: 10px;
  height: 10px;
  display: block;
  border: 2px solid #D30132;
  border-top: 0px;
  border-right: 0px;
  transform: rotate(-45deg);
  position: absolute;
  right: 9px;
  top: 9px;
}
.eu-richtlinie .accordion .accordion-item.is-active > a:after,
.hilfe-form .accordion .accordion-item.is-active > a:after,
form .accordion .accordion-item.is-active > a:after {
  transform: rotate(-225deg);
  top: 14px;
}

section.news {
  max-width: 100%;
  background: #484848;
  color: #EFEFEF;
  margin: 0 auto;
  padding: 15px 0;
}
section.news .content {
  max-width: 1000px;
  margin: 0 auto;
}
section.news .content h3,
section.news .content p {
  margin: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 18px;
}
section.news article h1 {
  font-size: 22px;
  margin: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
section.news article a {
  color: #fff;
  text-decoration: none;
}
section.news article + article {
  margin-top: 1rem;
}

section.blog {
  padding: 40px;
  margin-bottom: 20px;
  background: #fff;
}
section.blog .blog-eintrag {
  display: flex;
  justify-content: space-between;
}
section.blog .blog-eintrag.full {
  display: block;
}
section.blog .blog-eintrag .blog-image {
  width: 250px;
}
section.blog .blog-eintrag .blog-text {
  width: calc(100% - 300px);
}
@media screen and (max-width: 780px) {
  section.blog .blog-eintrag {
    display: block;
  }
  section.blog .blog-eintrag .blog-image,
  section.blog .blog-eintrag .blog-text {
    width: 100%;
  }
}

[data-content=neue_haltepunkte] {
  padding: 0 !important;
  background: none !important;
}

g#haltepunkte > g {
  cursor: pointer;
}

div.haltepunkt {
  max-width: calc(100vw - 40px);
  background: #fff;
  margin-bottom: 40px;
  display: flex;
  scroll-margin-top: 105px;
}
div.haltepunkt .haltepunkt-img {
  background: url("img/Bahnhof_Mettmann_Zentrum.jpg") no-repeat center center;
  background-size: cover;
  flex: 0 0 310px;
}
div.haltepunkt .haltepunkt-content {
  width: 100%;
}
div.haltepunkt .haltepunkt-text {
  flex: 1 0 auto;
  padding: 40px;
}
div.haltepunkt .haltepunkt-text a {
  display: block;
}
div.haltepunkt .haltepunkt-text h2 {
  margin-top: 0;
  color: #000;
}
div.haltepunkt .haltepunkt-features {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
  width: 100%;
}
div.haltepunkt .haltepunkt-features li {
  padding: 4px 12px;
  margin: 0px 10px 10px 0px;
  border: 2px solid #484848;
  color: #484848;
  border-radius: 20px;
  font-size: 14px;
  display: flex;
  align-items: center;
  font-weight: 600;
  hyphens: auto;
}
div.haltepunkt .haltepunkt-features li img {
  margin-right: 5px;
  width: 24px;
  height: auto;
}

@media screen and (max-width: 40rem) {
  div.haltepunkt {
    flex-wrap: wrap;
  }
  div.haltepunkt .haltepunkt-img {
    flex: 1 0 100%;
    height: auto;
    padding-bottom: 200px;
  }
}
.card-stack {
  width: 1000px;
  max-width: calc(100vw - 20px);
  margin: 50px auto;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.card-stack:after {
  content: "";
  flex: 0 1 31%;
}

.card-stack + .card-stack {
  margin-top: -50px;
}

.card {
  background: #fff;
  flex: 0 1 31%;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  margin-bottom: 3% !important;
  transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}
.card:hover {
  box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.2);
  transform: translateY(-4px);
}
.card .card-img {
  margin-bottom: 0;
}
.card .card-img img {
  width: 100%;
  display: block;
  height: 205px;
  object-fit: cover;
  object-position: center center;
}
.card .card-text {
  padding: 25px;
}
.card .card-text h2 {
  margin: 0 0 1rem 0;
  font-family: "Fira Sans", serif;
}
.card .card-cta {
  margin-top: auto;
  padding: 0 25px 25px 25px;
  border-top: 20px solid transparent;
}
.card .card-cta a {
  text-decoration: none;
  color: #000;
  font-size: 1rem;
}
.card.wide {
  flex: 0 1 65.5%;
}
.card.wider {
  flex: 0 1 100%;
}
.card.full {
  flex: 0 1 100%;
  flex-direction: row;
}
.card.full .card-img {
  flex: 0 0 31%;
  height: 100%;
}
.card.full .card-img img {
  height: 100%;
}
.card.full .card-text {
  padding: 25px;
}
.card.full .card-cta {
  flex: 0 0 31%;
  align-items: center;
  margin: auto;
}
.card.full.full-img {
  display: block;
}
.card.full.full-img .card-img {
  width: 100%;
  display: block;
  margin: 0;
}
.card.full.full-img .card-img img {
  object-fit: inherit;
  height: auto;
}

.card.news {
  color: #fff;
  background: #484848;
}
.card.news .card-text h2,
.card.news a {
  color: #fff;
}

.card.massnahme {
  color: #000;
  background: #FFCA00;
}
.card.massnahme .card-text h2,
.card.massnahme a {
  color: #000;
}

.card.alarm {
  color: #fff;
  background: #D30132;
}
.card.alarm .card-text h2,
.card.alarm a {
  color: #fff;
}

@media screen and (max-width: 58.75rem) {
  .card-stack {
    max-width: calc(100% - 20px);
    margin: 20px auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .card {
    margin-bottom: 20px !important;
  }
  .card,
  .card.wide {
    flex: 0 1 48.5%;
  }
}
@media screen and (max-width: 40rem) {
  .card,
  .card.wide {
    flex: 0 1 100%;
  }
  .card.full {
    flex-direction: column;
  }
  .card.full .card-cta {
    margin: auto 0 0 0;
  }
}
ul.tabs {
  display: flex;
  list-style: none;
  margin: 10px 0;
  padding: 0;
}
ul.tabs li {
  margin: 0;
  padding: 0 10px 0 0;
}
ul.tabs li a {
  border-bottom: 2px solid transparent;
  text-decoration: none;
}
ul.tabs li.is-active a {
  color: #484848;
  border-bottom: 2px solid #D30132;
}

.tabs-inhalt .tabs-text {
  display: none;
}
.tabs-inhalt .tabs-text.is-active {
  display: block;
}

ul.akkordeon {
  list-style: none;
  margin: 1rem 0;
  padding: 0;
}
ul.akkordeon li input[type=checkbox] {
  border: 0;
  clip: rect(0 0 0 0);
  clip-path: polygon(0px 0px, 0px 0px, 0px 0px);
  -webkit-clip-path: polygon(0px 0px, 0px 0px, 0px 0px);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
  white-space: nowrap;
}
ul.akkordeon li input[type=checkbox]:focus + label {
  outline: 2px solid #FFCA00;
  outline-offset: 3px;
}
ul.akkordeon li input[type=checkbox] + label {
  padding: 5px 10px;
  background: #D30132;
  color: #fff;
  display: block;
  cursor: pointer;
}
ul.akkordeon li input[type=checkbox] + label:before, ul.akkordeon li input[type=checkbox] + label:after {
  display: none;
}
ul.akkordeon li input[type=checkbox] + label + div {
  display: none;
}
ul.akkordeon li input[type=checkbox]:checked + label {
  background: #484848;
}
ul.akkordeon li input[type=checkbox]:checked + label + div {
  display: block;
}
ul.akkordeon .akkordeon-content {
  padding: 20px 10px;
  background: #f8f8f8;
}

footer {
  background: #484848;
  padding: 40px 0;
}
footer .content {
  width: 1000px;
  max-width: calc(100vw - 40px);
  margin: 0 auto;
  color: #fff;
}
footer .content a {
  color: #fff;
}
footer .content ul {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  justify-content: space-between;
}
footer .content nav {
  background: none;
  margin-bottom: 1rem;
}
footer .content nav ul {
  background: none;
  justify-content: flex-start;
}
footer .content nav ul li {
  padding-right: 20px;
  position: relative;
}
footer .content nav ul li:after {
  content: ">";
  display: block;
  width: 20px;
  height: 16px;
  text-align: center;
  position: absolute;
  font-size: 12px;
  top: 0;
  right: 0;
}
footer .content nav ul li:last-child:after {
  display: none;
}
footer .content nav ul li > span {
  display: block;
}
footer .content nav ul a,
footer .content nav ul span {
  font-size: 12px;
  font-weight: normal;
  color: #fff;
  padding: 0;
}

@media screen and (max-width: 58.75rem) {
  footer .content .breadcrumps {
    display: none;
  }
  footer .content nav ul {
    opacity: 1;
    height: auto;
    position: relative;
  }
  footer .content nav ul li:after {
    display: none;
  }
  footer .content ul {
    justify-content: center;
    flex-wrap: wrap;
  }
  footer .content ul li {
    width: 50%;
  }
  footer .content ul li:after {
    display: none;
  }
  footer .content ul li a {
    line-height: 40px;
  }
}
.job-listing {
  display: flex;
  margin: 0 -20px;
  margin-bottom: 0px;
  flex-wrap: wrap;
}

.job-eintrag {
  margin: 0 20px 40px;
  background: #fff;
  padding: 20px;
  width: calc(50% - 40px);
  transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}
.job-eintrag:hover {
  box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.2);
  transform: translateY(-4px);
}
.job-eintrag h1 {
  font-size: 1.25rem;
  margin: 0 0 1rem 0;
  padding: 0;
  color: inherit;
  text-shadow: none;
  text-align: left;
  width: 100%;
}

.popup {
  display: none;
  background: #fff;
  padding: 40px;
  pointer-events: none;
  position: fixed;
  top: 70%;
  width: 80vw;
  left: 50%;
  transform: translate(-50%, -50%);
  box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.2);
  max-height: 100vh;
  z-index: 1001;
  overflow-y: auto;
}
.popup.tiny {
  width: 25vw;
}
.popup.small {
  width: 50vw;
}
.popup.large {
  width: 75vw;
}
.popup.full {
  width: 100vw;
  height: 100vh;
}
.popup.open {
  top: 50%;
  display: block;
  pointer-events: all;
}

.close-button {
  position: absolute;
  right: 20px;
  top: 40px;
  border: none;
  background: none;
  font-size: 2rem;
  color: #D30132;
}

@media screen and (max-width: 640px) {
  .popup {
    padding: 20px;
  }
  .popup.tiny, .popup.small, .popup.large {
    width: 100vw;
    height: 100vh;
  }
}
.eu-richtlinie {
  background: #fff;
  max-width: 500px;
  padding: 20px;
  position: fixed;
  bottom: 20px;
  right: 20px;
  box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.2);
  z-index: 1002;
  max-height: 80vh;
  overflow-x: auto;
}
.eu-richtlinie fieldset {
  background: #f8f8f8;
  margin: 0;
}
.eu-richtlinie .form-row {
  margin-bottom: 1rem;
}

.spalten {
  width: 1000px;
  background: #fff;
  max-width: calc(100vw - 20px);
  margin: 50px auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.spalten.no-margin {
  margin: 0 auto;
}
.spalten > div {
  flex: 0 1 50%;
  padding: 40px;
}
.spalten.s-1-3 {
  border-top: 1px solid #D30132;
}
.spalten.s-1-3 > div {
  flex: 0 1 25%;
}
.spalten.s-1-3 > div + div {
  flex: 0 1 75%;
}
.spalten.s-3-1 > div {
  flex: 0 1 75%;
}
.spalten.s-3-1 > div + div {
  flex: 0 1 25%;
}

.spalten .spalten-3 {
  width: 1000px;
  background: #fff;
  max-width: calc(100vw - 20px);
  margin: 50px auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
}
.spalten .spalten-3.no-margin {
  margin: 0 auto;
}
.spalten .spalten-3 > div {
  flex: 0 1 33%;
  padding: 40px;
}
@media screen and (max-width: 58.75rem) {
  .spalten .spalten-3 > div {
    flex: 0 1 100%;
  }
}

main section.text.aufklapptext,
main section.text.block-galerie {
  width: 1000px;
  max-width: calc(100vw - 20px);
  background: #fff;
  padding: 40px;
  margin-bottom: 20px;
}
main section.text.aufklapptext .aufklapptext,
main section.text.block-galerie .aufklapptext {
  position: relative;
}
main section.text.aufklapptext .aufklapptext > h3,
main section.text.block-galerie .aufklapptext > h3 {
  margin: 0;
  cursor: pointer;
  position: sticky;
  top: var(--topSticky);
  z-index: 1;
}
main section.text.aufklapptext .aufklapptext .aufklapp-content,
main section.text.block-galerie .aufklapptext .aufklapp-content {
  display: none;
}
main section.text.aufklapptext .aufklapptext .aufklapp-weniger,
main section.text.block-galerie .aufklapptext .aufklapp-weniger {
  display: none;
}
main section.text.aufklapptext .aufklapptext.open,
main section.text.block-galerie .aufklapptext.open {
  border-color: #D30132;
}
main section.text.aufklapptext .aufklapptext.open .aufklapp-content,
main section.text.block-galerie .aufklapptext.open .aufklapp-content {
  display: block;
}
main section.text.aufklapptext .aufklapptext.open .aufklapp-weniger,
main section.text.block-galerie .aufklapptext.open .aufklapp-weniger {
  display: block;
}
main section.text.aufklapptext .aufklapptext.open .aufklapp-mehr,
main section.text.block-galerie .aufklapptext.open .aufklapp-mehr {
  display: none;
}
main section.text.aufklapptext .aufklapptext.open.compact h3 a:before,
main section.text.block-galerie .aufklapptext.open.compact h3 a:before {
  content: "-";
}
main section.text.aufklapptext .aufklapptext.compact > h3,
main section.text.block-galerie .aufklapptext.compact > h3 {
  background: #D30132;
  color: #fff;
  padding: 5px 5px 5px 10px;
}
main section.text.aufklapptext .aufklapptext.compact > h3 a,
main section.text.block-galerie .aufklapptext.compact > h3 a {
  color: #fff;
  text-decoration: none;
  font-weight: 400;
  display: block;
  margin-left: 25px;
}
main section.text.aufklapptext .aufklapptext.compact > h3 a:before,
main section.text.block-galerie .aufklapptext.compact > h3 a:before {
  content: "+";
  display: inline-block;
  width: 20px;
  text-align: center;
  font-weight: 300;
  font-size: 1.25em;
  margin-left: -25px;
}
main section.text.aufklapptext .aufklapptext.compact .aufklapp-content,
main section.text.block-galerie .aufklapptext.compact .aufklapp-content {
  padding: 20px 0;
}
main section.text.aufklapptext .aufklapptext ol > li::marker,
main section.text.block-galerie .aufklapptext ol > li::marker {
  font-weight: bold;
  font-size: 20px;
}

section.text.aufklapptext + section.text.aufklapptext {
  margin-top: -20px;
  padding-top: 0;
}

.gallery-wrap {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
}
.gallery-wrap > .column {
  width: 23%;
  margin-bottom: 2%;
}
.gallery-wrap > .column > .card {
  width: 100%;
  margin: 0 !important;
}
.gallery-wrap > .column > .card img {
  display: block;
  width: 100%;
  height: 250px;
  object-fit: cover;
}

@media screen and (max-width: 940px) {
  .gallery-wrap > .column {
    width: 48%;
    margin-right: 2%;
  }
  .gallery-wrap > .column > .card img {
    height: 150px;
  }
}
:root {
  --topSticky: 75px;
}

body.overlay-open {
  height: 100vh;
  width: 100vw;
  overflow: hidden;
  position: fixed;
}

header {
  background: #484848;
}

main {
  min-height: 50vh;
  position: relative;
}

.bau header {
  background: #FFCA00;
}

.streckenausbau header {
  background: url(img/regiobahn-sprechenausbau-animation.jpg) no-repeat center bottom;
}

.aktuelles header,
.aktuelles-detail header,
.aktuelles-detail2019 header {
  background: #484848;
}

main section {
  max-width: 1000px;
  margin: 20px auto;
}

main section > *:last-child {
  margin-bottom: 0;
}

body:not(.home) main section:first-child {
  margin-top: -50px !important;
}

main section.text {
  width: 1000px;
  max-width: calc(100vw - 20px);
  background: #fff;
  padding: 40px;
  margin-bottom: 20px;
}
main section.text.no-background {
  background: none;
}
main section.text.no-background-padding {
  background: none;
  padding: 0;
}
main section.text.no-format {
  background: none;
  padding: 0;
  margin: 0 auto;
}

main section.text.schmal {
  max-width: 680px;
}

main section.link {
  margin: -20px auto;
  background: #fff;
  padding: 40px;
}
main section.link.no-padding {
  padding: 0 40px;
}

main section.no-margin {
  margin: 0 auto;
}

section.galerie {
  max-width: 1080px;
  width: 100%;
  display: flex;
  justify-content: space-between;
  background: #fff;
  padding: 40px 20px;
}
section.galerie img {
  display: inline-block;
  flex: 1 1 auto;
  margin: 0 20px;
}

.marquee {
  overflow: hidden;
}

section.massnahme {
  width: 1000px;
  max-width: calc(100vw - 40px);
  background: #fff;
  margin-bottom: 20px;
  display: flex;
  flex-wrap: wrap;
}
section.massnahme h2 {
  color: #000;
  background: #FFCA00;
  margin: 0;
  padding: 20px 40px;
  width: 100%;
}
section.massnahme .massnahme-content {
  background: #fff;
  padding: 40px;
  width: 100%;
}

article.bau-article {
  width: 1000px;
  max-width: 100%;
  background: #fff;
  padding-bottom: 20px;
}
article.bau-article .bau-datum {
  margin-bottom: 1rem;
}
article.bau-article .bau-datum strong {
  display: inline-block;
  width: 50px;
  line-height: 1.5;
}

section.tabs {
  background: #fff;
  padding: 40px;
}

.row {
  display: flex;
  width: 100%;
  margin-bottom: 40px;
}
.row div {
  width: 48%;
  margin-right: 2%;
}
.row div.medium-12 {
  width: 100%;
}

table {
  width: 100%;
  margin: 0 0 1em 0;
}
table.clear {
  border: none !important;
  background: none;
}
table.clear td {
  border: none !important;
}
table.jobs {
  width: 100% !important;
  border: none !important;
  background: none !important;
}
table.jobs tr {
  height: auto !important;
  background: none;
}
table.jobs td {
  border: none !important;
  height: auto !important;
  padding: 0;
}
table.jobs td a.button {
  display: block;
  margin: 0;
  padding: 20px;
  transition: background 0.2s ease-out;
}
table.jobs td a.button:hover {
  background: #980124 !important;
}

tbody tr:nth-child(2n) {
  border-bottom: 0;
  background-color: #f8f8f8;
}

tr td:first-child {
  padding-left: 0;
}

tr td:last-child {
  padding-right: 0;
}

td {
  padding: 10px;
  font-size: 20px;
  line-height: 1.5;
}
td > *:last-child {
  margin-bottom: 0;
}
td.text-left {
  text-align: left;
}

td.menu {
  background: #D30132;
  color: #fff;
}

.icon-link {
  display: inline-block;
  padding: 0 5px 0 0;
}

.slide {
  background: #fff;
  display: flex;
  align-items: center;
  margin: 50px auto;
}

.slide-img img,
.slide img {
  display: block;
  width: 100%;
}

.slide-text {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.slide-text a {
  color: #000;
  text-decoration: none;
}

.slide-text * {
  flex: 0 1 60%;
}

figure {
  margin: 2rem auto;
}
figure.center {
  text-align: center;
}
.img-wrap figure {
  margin: 0 auto;
  text-align: center;
}

.kundencenter-hinweis {
  background: #ffca00;
  padding: 40px;
  width: 1000px;
  max-width: calc(100vw - 20px);
  margin: 20px auto;
}
.kundencenter-hinweis > *:last-child {
  margin-bottom: 0;
}

.persona {
  float: right;
  width: 250px;
  background: #efefef;
  display: block;
  padding: 20px;
  margin: 0 -100px 2rem 2rem;
  box-shadow: 0px 5px 10px rgba(0, 0, 0, 0.2);
  min-height: 300px;
}
.persona figure {
  display: flex;
  flex-direction: column;
  height: 100%;
  margin-top: 0;
}
.persona figure .persona-img {
  margin-bottom: 1rem;
}
.persona figure .persona-img img {
  width: 100%;
  height: auto;
}
.persona figure figcaption {
  margin-top: auto;
  font-size: 0.875rem;
}

.block-map {
  max-width: 1000px;
  margin: 50px auto;
}

.hide {
  display: none !important;
}

hr {
  clear: both;
  max-width: 62.5rem;
  height: 0;
  margin: 1.25rem auto;
  border-top: 0;
  border-right: 0;
  border-bottom: 1px solid #484848;
  border-left: 0;
  box-sizing: content-box;
  overflow: visible;
}

#parkplatz-stadtwald,
#parkplatz-neanderthal {
  color: #D30132;
  display: inline-block;
  float: right;
  border: 1px solid #D30132;
  font-size: 16px;
  text-align: center;
  width: 220px;
}

@media screen and (max-width: 58.75rem) {
  section.text {
    padding: 20px;
  }
  section.news .content {
    max-width: 100%;
    padding: 0 20px;
  }
  .slides {
    max-width: calc(100% - 40px);
  }
  .slide {
    flex-wrap: wrap;
  }
  .slide-text * {
    flex: 0 1 100%;
  }
  .slide-text {
    padding: 10px 25px;
  }
  .topnav ul {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    margin: 0;
    padding: 0;
  }
  .spalten {
    margin: 50px auto;
    flex-wrap: wrap;
    display: flex;
    justify-content: space-between;
  }
  .spalten > div {
    background: #fff;
    flex: 0 0 100%;
    padding: 20px;
  }
  main section.text.schmal {
    max-width: calc(100vw - 20px);
  }
  img.full {
    width: calc(100% + 40px);
    max-width: inherit;
    margin: -20px 0 20px -20px;
  }
  .row {
    display: flex;
    width: 100%;
    margin-bottom: 40px;
    flex-wrap: wrap;
  }
  .row div {
    width: 100%;
    margin-right: 0%;
  }
  td {
    font-size: 15px;
  }
}
@media screen and (max-width: 40rem) {
  main section.text {
    padding: 20px;
  }
}

/*# sourceMappingURL=page.css.map */
