@font-face {
  font-family: 'SourceHanSansCN';
  src: url('/css/font/SourceHanSansCN/SourceHanSansCN-Bold.otf');
  font-weight: bold;
  font-style: normal;
}
@font-face {
  font-family: 'SourceHanSansCN';
  src: url('/css/font/SourceHanSansCN/SourceHanSansCN-Regular.otf');
  font-weight: normal;
  font-style: normal;
}
@font-face {
  font-family: 'SourceHanSansCN';
  src: url('/css/font/SourceHanSansCN/SourceHanSansCN-Normal.otf');
  font-weight: 300;
  font-style: normal;
}
/*
|--------------------------------------------------------------------------
| Behavior
|--------------------------------------------------------------------------
*/
html {
  scroll-behavior: smooth;
  position: relative;
  min-height: 100%;
}
#nprogress .bar {
  background-color: #B21107;
}
/*
|--------------------------------------------------------------------------
| Ckeditor
|--------------------------------------------------------------------------
*/
#content.cke_editable {
  padding: 10px;
}
/*
|--------------------------------------------------------------------------
| body & formate & helper
|--------------------------------------------------------------------------
*/
body {
  font-family: 'Open Sans', sans-serif;
  font-family: 'SourceHanSansCN', sans-serif;
  color: #000;
  /* margin-bottom: 300px; /* Margin bottom by footer height */
}
body a {
  color: #B21107;
}
body a:hover,
body a:focus {
  color: #980C03;
  text-decoration: none;
}
.drop-shadow {
  box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.1);
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: 'SourceHanSansCN', sans-serif;
}
.min-width-100 {
  min-width: 100px;
}
/*
|--------------------------------------------------------------------------
| buttons
|--------------------------------------------------------------------------
*/
.btn-primary {
  color: #fff;
  background-color: #B21107;
  border-color: #B21107;
}
.btn-primary:hover {
  color: #fff;
  background-color: #980C03;
  border-color: #980C03;
}
.btn-primary:not(:disabled):not(.disabled):active,
.btn-primary:not(:disabled):not(.disabled).active {
  color: #fff;
  background-color: #980C03;
  border-color: #980C03;
}
.btn-link {
  color: #B21107;
}
.btn-link:hover,
.btn-link:focus {
  color: #980C03;
  text-decoration: none;
}
/*
|--------------------------------------------------------------------------
| Sections
|--------------------------------------------------------------------------
*/
/* White section */
.parents-id-65 {
  background-color: #fff !important;
}
/* gray section */
/*
|--------------------------------------------------------------------------
| layout & etc
|--------------------------------------------------------------------------
*/
.shortcuts {
  padding: 15px;
}
.shortcuts ul {
  margin: 0 auto;
  padding: 0;
  list-style: none;
}
.shortcuts ul li {
  display: inline-block;
  margin: 0 5px;
}
.shortcuts ul li a {
  padding: 5px 10px;
  color: #B21107;
  transition: all 0.15s ease-in;
}
.shortcuts ul li a:hover,
.shortcuts ul li a:focus {
  color: #B21107;
}
.shortcuts ul li.active a {
  color: #B21107;
}
main section {
  position: relative;
}
main section:nth-child(odd) {
  background-color: #f7f7f9;
}
main section:nth-child(even) {
  background-color: #fff;
}
main section.no-bg {
  background-color: transparent;
}
footer {
  color: #000;
  /* 	position: absolute;
	bottom: 0;
	width: 100%;
	height: 300px; */
  background-color: #f7f7f9;
}
footer a {
  color: #000;
}
footer a:hover,
footer a:focus {
  color: #000;
  text-decoration: underline;
}
footer li {
  font-size: 80%;
  font-weight: 400;
  list-style-type: none;
}
footer ul {
  padding-left: 0;
}
footer .lang .active {
  font-weight: bold;
}
footer .footer-linkedin-logo {
  float: left;
  width: 7%;
  height: 7%;
}
@media (max-width: 1199.98px) {
  footer .footer-linkedin-logo {
    float: left;
    width: 17%;
    height: 17%;
  }
}
.footer-top {
  border-bottom: 1px solid #000;
  padding-bottom: 10px;
  margin-bottom: 20px;
}
.footer-bar {
  background-color: #B21107;
  color: #fff;
  font-size: 80%;
  font-weight: 400;
}
.footer-bar ul {
  padding-left: 0px;
}
.footer-bar li {
  display: inline;
  list-style: none;
}
.footer-bar a {
  color: #fff;
}
.footer-bar p {
  font-size: 80%;
  font-weight: 400;
}
/*
|--------------------------------------------------------------------------
| Sticky Footer
|--------------------------------------------------------------------------
*/
html,
body {
  height: 100%;
}
.page-content {
  flex: 1 0 auto;
}
footer {
  flex-shrink: none;
}
/*
|--------------------------------------------------------------------------
| Main Nav
|--------------------------------------------------------------------------
*/
ul.main-nav.sf-menu {
  margin-bottom: 0;
  background-color: transparent;
}
ul.main-nav.sf-menu li {
  background-color: #fff;
  transition: none;
}
ul.main-nav.sf-menu li a {
  font-family: 'SourceHanSansCN', sans-serif;
  border: none;
  color: #56596b;
  font-size: 1.4rem;
  padding: 0.75em;
}
ul.main-nav.sf-menu li:hover,
ul.main-nav.sf-menu li.sfHover {
  background-color: #B21107;
}
ul.main-nav.sf-menu li:hover a,
ul.main-nav.sf-menu li.sfHover a {
  color: #fff !important;
}
ul.main-nav.sf-menu li.parent-active > a {
  color: #B21107;
}
ul.main-nav.sf-menu ul {
  min-width: auto;
  background-color: #B21107;
  box-shadow: 0px 8px 20px -10px rgba(0, 0, 0, 0.75);
}
ul.main-nav.sf-menu ul li {
  background-color: #B21107;
  width: 100%;
}
ul.main-nav.sf-menu ul li:hover {
  background-color: #980C03;
}
ul.main-nav.sf-menu ul li.active {
  background-color: #000;
}
/*
|--------------------------------------------------------------------------
| flex navi
|--------------------------------------------------------------------------
*/
.menu-button {
  background-color: transparent;
  color: #56596b;
  border: none;
}
.menu-button.active {
  color: #B21107;
}
.menu-button .touch-button {
  display: none;
}
ul.flexnav {
  padding: 0;
  position: absolute;
  background-color: white;
  padding: 0 20px;
  z-index: 999;
  width: 100%;
}
ul.flexnav li {
  margin: 0;
  padding: 0;
}
ul.flexnav li.parent-active a {
  color: #B21107;
}
ul.flexnav li.parent-active ul li.active a {
  color: #000;
  background-color: #980C03;
}
ul.flexnav li.parent-active ul li a {
  color: #fff;
}
ul.flexnav li a {
  background-color: transparent;
  color: #56596b;
  border: none;
  padding: 1rem 1rem 1rem 0;
}
ul.flexnav li a:hover,
ul.flexnav li a:focus {
  color: #B21107;
  text-decoration: none;
}
ul.flexnav li ul {
  padding: 0;
}
ul.flexnav li ul li a {
  padding: 1rem;
  color: #fff;
  background-color: #B21107;
}
ul.flexnav li ul li a:hover {
  color: #fff;
}
ul.flexnav .touch-button {
  width: 56px;
  height: 56px;
  line-height: 56px;
  background-color: #B21107;
}
ul.flexnav .touch-button:after {
  font-family: FontAwesome;
  font-size: 32px;
  content: "\f107";
  transition: all 0.15s ease-in;
  color: #fff;
  position: absolute;
  left: 18px;
}
ul.flexnav .touch-button.active:after {
  transform: rotate(-180deg);
}
ul.flexnav .touch-button .navicon {
  display: none;
}
/*
|--------------------------------------------------------------------------
| cards
|--------------------------------------------------------------------------
*/
.card {
  background-color: #fff;
  border-radius: 0;
  display: inline-block;
  width: 100%;
  position: relative;
  transition: all 0.15s ease-in;
  border: none;
}
.card .image {
  position: relative;
  overflow: hidden;
}
.card .image img {
  transition: all 0.15s ease-in;
}
.card .content {
  padding: 2rem;
}
.card .card-body.p-5 {
  padding: 0.5rem !important;
}
.card-with-link {
  overflow: hidden;
  color: #000;
}
.card-with-link:hover,
.card-with-link:focus,
.card-with-link:active {
  text-decoration: none;
  background-color: #B21107;
  color: #fff;
}
.card-with-link:hover h3,
.card-with-link:focus h3,
.card-with-link:active h3,
.card-with-link:hover p,
.card-with-link:focus p,
.card-with-link:active p {
  color: #fff;
}
.card-with-link:hover span[style*="color:#b22222;"],
.card-with-link:focus span[style*="color:#b22222;"],
.card-with-link:active span[style*="color:#b22222;"] {
  color: white !important;
}
.card-with-link:hover .image,
.card-with-link:focus .image,
.card-with-link:active .image {
  filter: brightness(110%);
}
.card-with-link:hover .image img,
.card-with-link:focus .image img,
.card-with-link:active .image img {
  transform: scale(1.04);
}
/*
|--------------------------------------------------------------------------
| beardcrumb navi
|--------------------------------------------------------------------------
*/
.breadcrumbs-navi {
  list-style: none;
  margin: 0;
  margin-bottom: 10px;
  padding: 0;
  margin-left: -6px;
  margin-right: -6px;
  color: #56596b;
  font-weight: 300;
}
.breadcrumbs-navi .list-item {
  display: inline-block;
  position: relative;
}
.breadcrumbs-navi .list-item:after {
  content: "/";
}
.breadcrumbs-navi .list-item:last-child::after {
  content: "";
}
.breadcrumbs-navi .list-item .link {
  display: inline-block;
  color: #56596b;
  padding: 0 6px;
  transition: all 0.15s ease-in;
}
.breadcrumbs-navi .list-item .link .active,
.breadcrumbs-navi .list-item .link:hover,
.breadcrumbs-navi .list-item .link:focus {
  color: #000;
  text-decoration: none;
}
.breadcrumbs-navi .list-item .link .active .icon path,
.breadcrumbs-navi .list-item .link:hover .icon path {
  transition: all 0.15s ease-in;
  stroke: #000;
}
.breadcrumbs-navi .list-item .icon-container {
  display: flex;
  align-items: center;
  height: 24px;
}
.breadcrumbs-navi .list-item .icon-container .icon {
  margin-left: 5px;
  transition: all 0.15s ease-in;
}
.breadcrumbs-navi .list-item .icon-container .icon path {
  stroke: #56596b;
}
.breadcrumbs-navi .list-item .icon-container .icon-home {
  margin-left: 0;
}
.breadcrumbs-navi .list-item .active .icon {
  transform: rotate(-180deg);
}
.breadcrumbs-navi .list-item .siblings-list {
  list-style: none;
  margin: 0;
  padding: 0;
  position: absolute;
  padding: 6px 0;
  border: 1px solid #FFF;
  left: -6px;
  top: 120%;
  background-color: #fff;
  width: auto;
  min-width: 100%;
  max-width: 220px;
  display: none;
  z-index: 1000;
}
.breadcrumbs-navi .list-item .siblings-list .link {
  display: block;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: #56596b;
  padding: 3px 12px;
  transition: all 0.15s ease-in;
}
.breadcrumbs-navi .list-item .siblings-list .link:hover,
.breadcrumbs-navi .list-item .siblings-list .link:focus {
  color: #000;
  text-decoration: none;
}
.breadcrumbs-navi .list-item .siblings-list .link.active {
  color: #000;
}
.breadcrumbs-navi .list-item .active + .siblings-list {
  display: block;
}
/*
|--------------------------------------------------------------------------
| news slider
|--------------------------------------------------------------------------
*/
.news .carousel-title {
  margin-bottom: 10px;
}
.news .slider-controls a {
  margin-left: 5px;
  cursor: pointer;
}
.news .slick-disabled {
  opacity: 0.5;
}
/*
|--------------------------------------------------------------------------
| galerie slick slider
|--------------------------------------------------------------------------
*/
.slick-slide {
  margin-bottom: 0;
}
.slick-slide .slide {
  position: relative;
}
.slick-slide .slide img {
  width: 100%;
}
.slick-slide .slide .slide-caption {
  position: absolute;
  bottom: 2rem;
  width: 50%;
  right: 2rem;
  padding: 2rem;
  color: #000;
  background-color: rgba(255, 255, 255, 0.8);
}
.slick-slide .slide .slide-caption h3 {
  font-size: 2rem;
}
.slick-slide .slide .slide-caption p {
  font-size: 1.25rem;
}
.slick-dots {
  display: block;
  text-align: center;
  list-style: none;
  padding: 0;
}
.slick-dots li {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  cursor: pointer;
  margin: 0px 5px;
  padding: 0px;
}
.slick-dots li button {
  font-size: 0;
  line-height: 0;
  display: block;
  width: 20px;
  height: 20px;
  padding: 5px;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: none;
  background: transparent;
}
.slick-dots li button:hover,
.slick-dots li button:focus {
  outline: none;
}
.slick-dots li button:hover:before,
.slick-dots li button:focus:before {
  color: #B21107;
}
.slick-dots li button:before {
  font-size: 10px;
  line-height: 20px;
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  font-family: FontAwesome;
  content: '\f111';
  text-align: center;
  color: #56596b;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.slick-dots li.slick-active button:before {
  color: #B21107;
}
/*
|--------------------------------------------------------------------------
| accordion
|--------------------------------------------------------------------------
*/
.accordion h5 {
  position: relative;
}
.accordion .btn-link:after {
  font-family: FontAwesome;
  font-size: 21px;
  content: "\f106";
  color: #B21107;
  position: absolute;
  right: 0;
  top: 0.4rem;
  transition: all 0.15s ease-in;
}
.accordion .btn-link.collapsed:after {
  transform: rotate(-180deg);
}
/*
|--------------------------------------------------------------------------
| pagination
|--------------------------------------------------------------------------
*/
.page-item.active .page-link {
  background-color: #B21107;
  border-color: #B21107;
}
.page-link {
  color: #B21107;
}
.page-link:hover {
  color: #ECECEC;
}
/*
|--------------------------------------------------------------------------
| print
|--------------------------------------------------------------------------
*/
/*
|--------------------------------------------------------------------------
| google recaptcha
|--------------------------------------------------------------------------
*/
.grecaptcha-badge {
  z-index: 2;
}
/*
|--------------------------------------------------------------------------
| language selection dropdown
|--------------------------------------------------------------------------
*/
#dropdownMenuButton {
  background-color: transparent;
  color: #B21107;
  border: none;
}
/*
|--------------------------------------------------------------------------
| side icon & info-panel
|--------------------------------------------------------------------------
*/
.side-icon {
  position: fixed;
  right: 0;
  font-size: 1.5rem;
  background-color: rgba(152, 12, 3, 0.1);
  padding: 1rem 0.5rem;
}
.side-icon.icon-tel {
  top: 350px;
  transition: all 0.15s ease-in;
}
.side-icon.icon-tel.moved {
  top: 475px;
}
.side-icon.icon-email {
  padding: 1rem 0.4rem;
  top: 425px;
  opacity: 1;
  transition: all 0.15s ease-in;
}
.side-icon.icon-email.moved {
  top: 565px;
}
.info-panel .ui-slideouttab-right {
  border: unset;
  background-color: transparent;
}
.info-panel .ui-slideouttab-right .handle {
  background-color: rgba(152, 12, 3, 0.1);
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
  color: #980C03 !important;
  font-weight: bold;
  top: 0 !important;
}
.info-panel .ui-slideouttab-right .slide-out-div {
  font-weight: bold;
  -webkit-backdrop-filter: blur(8px);
  backdrop-filter: blur(8px);
}
@supports not (backdrop-filter: blur(8px)) {
  .slide-out-div {
    background-color: rgba(255, 255, 255, 0.6);
  }
}
a[id]::before {
  content: '';
  display: block;
  height: 75px;
  margin-top: -75px;
  visibility: hidden;
}
.seitenanfanglink_unten {
  position: fixed;
  right: 20px;
  bottom: 40px;
  margin-bottom: 0;
}
@media (max-width: 991.98px) {
  .cookie-bar .btn-primary {
    width: 100%;
    margin-left: 0;
    margin-top: 20px;
  }
}
