/* COLORS */
/* -- FONT - SIZE -- */
/* pt-sans-regular - latin */
@font-face {
  font-family: 'PT Sans';
  font-style: normal;
  font-weight: 400;
  font-display: optional;
  src: url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-regular.eot');
  src: local(''), url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */ url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-regular.woff') format('woff'), /* Modern Browsers */ url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */ url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-regular.svg#PTSans') format('svg');
  
  /* IE9 Compat Modes */
  /* Legacy iOS */
}
/* pt-sans-italic - latin */
@font-face {
  font-family: 'PT Sans';
  font-style: italic;
  font-weight: 400;
  font-display: optional;
  src: url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-italic.eot');
  src: local(''), url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-italic.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-italic.woff2') format('woff2'), /* Super Modern Browsers */ url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-italic.woff') format('woff'), /* Modern Browsers */ url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-italic.ttf') format('truetype'), /* Safari, Android, iOS */ url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-italic.svg#PTSans') format('svg');
  
  /* IE9 Compat Modes */
  /* Legacy iOS */
}
/* pt-sans-700 - latin */
@font-face {
  font-family: 'PT Sans';
  font-style: normal;
  font-weight: 700;
  font-display: optional;
  src: url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-700.eot');
  src: local(''), url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-700.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-700.woff2') format('woff2'), /* Super Modern Browsers */ url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-700.woff') format('woff'), /* Modern Browsers */ url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-700.ttf') format('truetype'), /* Safari, Android, iOS */ url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-700.svg#PTSans') format('svg');
  
  /* IE9 Compat Modes */
  /* Legacy iOS */
}
/* pt-sans-700italic - latin */
@font-face {
  font-family: 'PT Sans';
  font-style: italic;
  font-weight: 700;
  font-display: optional;
  src: url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-700italic.eot');
  src: local(''), url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-700italic.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */ url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-700italic.woff2') format('woff2'), /* Super Modern Browsers */ url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-700italic.woff') format('woff'), /* Modern Browsers */ url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-700italic.ttf') format('truetype'), /* Safari, Android, iOS */ url('/typo3conf/ext/ig_project/Resources/Public/Fonts/PtSans/pt-sans-v12-latin-700italic.svg#PTSans') format('svg');
  
  /* IE9 Compat Modes */
  /* Legacy iOS */
}
@font-face {
  font-family: 'johanneswerk-iconfont';
  src: url('/typo3conf/ext/ig_project/Resources/Public/Fonts/Iconfont/fonts/johanneswerk-iconfont.eot?lfo316');
  src: url('/typo3conf/ext/ig_project/Resources/Public/Fonts/Iconfont/fonts/johanneswerk-iconfont.eot?lfo316#iefix') format('embedded-opentype'), url('/typo3conf/ext/ig_project/Resources/Public/Fonts/Iconfont/fonts/johanneswerk-iconfont.woff2?lfo316') format('woff2'), url('/typo3conf/ext/ig_project/Resources/Public/Fonts/Iconfont/fonts/johanneswerk-iconfont.ttf?lfo316') format('truetype'), url('/typo3conf/ext/ig_project/Resources/Public/Fonts/Iconfont/fonts/johanneswerk-iconfont.woff?lfo316') format('woff'), url('/typo3conf/ext/ig_project/Resources/Public/Fonts/Iconfont/fonts/johanneswerk-iconfont.svg?lfo316#johanneswerk-iconfont') format('svg');
  font-weight: normal;
  font-style: normal;
  font-display: block;
}
[class^="icon-"],
[class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'johanneswerk-iconfont' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.icon-icon_kalender:before {
  content: "\e927";
}
.icon-icon_mobile:before {
  content: "\e926";
}
.icon-twitter:before {
  content: "\e922";
}
.icon-facebook-f:before {
  content: "\e923";
}
.icon-icon_linkedin_black:before {
  content: "\e924";
}
.icon-insta:before {
  content: "\e90d";
  color: #999;
}
.icon-facebook-logo-button:before {
  content: "\e921";
  color: #999;
}
.icon-icon_linkedin:before {
  content: "\e925";
  color: #999;
}
.icon-icon_angebote-alter:before {
  content: "\e900";
  color: #b51d28;
}
.icon-icon_angebote-behinderung:before {
  content: "\e901";
  color: #b51d28;
}
.icon-icon_angebote-industrie:before {
  content: "\e902";
  color: #b51d28;
}
.icon-icon_angebote-psychisch:before {
  content: "\e903";
  color: #b51d28;
}
.icon-icon_arrow_1_down:before {
  content: "\e904";
}
.icon-icon_arrow_1_left:before {
  content: "\e905";
}
.icon-icon_arrow_1_right:before {
  content: "\e906";
}
.icon-icon_arrow_1_up:before {
  content: "\e907";
}
.icon-icon_check:before {
  content: "\e908";
  color: #b51d28;
}
.icon-icon_dokument:before {
  content: "\e909";
  color: #b51d28;
}
.icon-icon_fax:before {
  content: "\e90a";
  color: #999;
}
.icon-icon_leichte-sprache:before {
  content: "\e90b";
  color: #999;
}
.icon-icon_liste:before {
  content: "\e90c";
  color: #b51d28;
}
.icon-icon_login:before {
  content: "\e90e";
  color: #999;
}
.icon-icon_mail:before {
  content: "\e90f";
  color: #999;
}
.icon-icon_map:before {
  content: "\e910";
  color: #b51d28;
}
.icon-icon_pin:before {
  content: "\e911";
  color: #999;
}
.icon-icon_schriftvergroesserung:before {
  content: "\e912";
  color: #999;
}
.icon-icon_telefon:before {
  content: "\e913";
  color: #999;
}
.icon-icon_user:before {
  content: "\e914";
  color: #999;
}
.icon-icon_vorlesen:before {
  content: "\e915";
  color: #999;
}
.icon-icon_hotline:before {
  content: "\e91e";
}
.icon-icon_feedback:before {
  content: "\e91c";
  color: #b51d28;
}
.icon-icon-suche:before {
  content: "\e916";
}
.icon-icon-menu:before {
  content: "\e917";
}
.icon-radio:before {
  content: "\e918";
  color: #999;
}
.icon-radio-checked-font:before {
  content: "\e919";
  color: #b51d28;
}
.icon-checkbox:before {
  content: "\e91a";
  color: #999;
}
.icon-checkbox-checked-font:before {
  content: "\e91b";
  color: #b51d28;
}
.icon-icon-bullet-square:before {
  content: "\e91d";
  color: #999;
}
.icon-icon_add:before {
  content: "\e91f";
}
.icon-icon_close:before {
  content: "\e920";
}
/* Import Bootstrap Mixings*/
/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */
/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS and IE text size adjust after device orientation change,
 *    without disabling user zoom.
 */
html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}
/**
 * Remove default margin.
 */
body {
  margin: 0;
}
/* HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11
 * and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
  display: block;
}
/**
 * 1. Correct `inline-block` display not defined in IE 8/9.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */
audio,
canvas,
progress,
video {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}
/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}
/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22.
 */
[hidden],
template {
  display: none;
}
/* Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {
  background-color: transparent;
}
/**
 * Improve readability of focused elements when they are also in an
 * active/hover state.
 */
a:active,
a:hover {
  outline: 0;
}
/* Text-level semantics
   ========================================================================== */
/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */
abbr[title] {
  border-bottom: 1px dotted;
}
/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */
b,
strong {
  font-weight: bold;
}
/**
 * Address styling not present in Safari and Chrome.
 */
dfn {
  font-style: italic;
}
/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari, and Chrome.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}
/**
 * Address styling not present in IE 8/9.
 */
mark {
  background: #ff0;
  color: #000;
}
/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
  font-size: 80%;
}
/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sup {
  top: -0.5em;
}
sub {
  bottom: -0.25em;
}
/* Embedded content
   ========================================================================== */
/**
 * Remove border when inside `a` element in IE 8/9/10.
 */
img {
  border: 0;
}
/**
 * Correct overflow not hidden in IE 9/10/11.
 */
svg:not(:root) {
  overflow: hidden;
}
/* Grouping content
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari.
 */
figure {
  margin: 1em 40px;
}
/**
 * Address differences between Firefox and other browsers.
 */
hr {
  box-sizing: content-box;
  height: 0;
}
/**
 * Contain overflow in all browsers.
 */
pre {
  overflow: auto;
}
/**
 * Address odd `em`-unit font size rendering in all browsers.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}
/* Forms
   ========================================================================== */
/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */
/**
 * 1. Correct color not being inherited.
 *    Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 */
button,
input,
optgroup,
select,
textarea {
  color: inherit;
  /* 1 */
  font: inherit;
  /* 2 */
  margin: 0;
  /* 3 */
}
/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */
button {
  overflow: visible;
}
/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */
button,
select {
  text-transform: none;
}
/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 */
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */
}
/**
 * Re-set default cursor for disabled elements.
 */
button[disabled],
html input[disabled] {
  cursor: default;
}
/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}
/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
input {
  line-height: normal;
}
/**
 * It's recommended that you don't attempt to style these elements.
 * Firefox's implementation doesn't respect box-sizing, padding, or width.
 *
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 */
input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}
/**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}
/**
 * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari and Chrome.
 */
input[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  box-sizing: content-box;
  /* 2 */
}
/**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}
/**
 * Define consistent border, margin, and padding.
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}
/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */
legend {
  border: 0;
  /* 1 */
  padding: 0;
  /* 2 */
}
/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */
textarea {
  overflow: auto;
}
/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */
optgroup {
  font-weight: bold;
}
/* Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0;
}
td,
th {
  padding: 0;
}
.meta-nav a {
  font-size: 18px;
  color: #999999;
  margin-right: 32px;
  display: inline-block;
  line-height: 48px;
  position: relative;
  padding-top: 2px;
}
.meta-nav a span {
  margin-right: 5px;
  display: inline-block;
}
.meta-nav a:hover span:before {
  color: #b51d28 !important;
}
.meta-nav .right a {
  float: right;
}
.meta-nav .social-links {
  display: inline-block;
}
.meta-nav .social-links a {
  margin-right: 10px;
  font-size: 23px;
}
.meta-nav .social-links-wrapper {
  display: flex;
}
.meta-nav .social-link {
  margin-top: 15px;
  width: 23px;
  height: 23px;
  background-color: transparent;
  color: white;
  display: inline-block;
  border-radius: var(--image-borders);
}
.meta-nav .social-link:hover {
  background-color: #b51d28 !important;
}
.meta-nav .social-link-facebook {
  background: url('/typo3conf/ext/ig_project/Resources/Public/Icons/JHW-Facebook_weiss.svg') no-repeat;
  background-position: center bottom;
  background-color: #9d9d9c;
  border-radius: 8px;
  background-size: 75%;
}
.meta-nav .social-link-instagram {
  background: url('/typo3conf/ext/ig_project/Resources/Public/Icons/JHW-Instagram_weiss.svg') no-repeat;
  background-color: #9d9d9c;
  border-radius: 8px;
  background-size: 87%;
  background-position: center;
}
.meta-nav .social-link-linkedin {
  background: url('/typo3conf/ext/ig_project/Resources/Public/Icons/JHW-Linkedin_weiss.svg') no-repeat;
  background-position: center;
  background-size: 50%;
  background-color: #9d9d9c;
  border-radius: 8px;
}
.meta-nav .social-link span {
  display: none;
}
.meta-nav .donation {
  display: inline-block;
  width: 170px;
  text-align: center;
  color: #b51d28;
  margin-right: 0px;
  font-weight: bold;
  text-transform: uppercase;
  border: 1px solid #B51D28;
  border-radius: 20px;
  background-color: #ffffff;
  margin-top: 7px;
  line-height: 22px;
  padding: 7px 0 5px 0;
}
.meta-nav .donation span {
  line-height: 22px;
}
.meta-nav .donation span:after {
  content: "\e906";
  font-family: 'johanneswerk-iconfont' !important;
  font-size: 13px;
  margin-left: 5px;
}
.meta-nav .donation:hover {
  background-color: #cb6168;
  color: #ffffff !important;
}
.meta-nav .donation:hover span:before {
  color: #ffffff !important;
}
.meta-nav .tooltip.bottom > .tooltip-arrow {
  border-bottom-color: #b51d28;
}
.meta-nav .tooltip > .tooltip-inner {
  background-color: #b51d28;
  color: #ffffff;
  max-width: 180px;
  font-size: 14px;
  padding: 8px;
}
.homepage-header {
  height: 176px;
  max-height: 176px;
}
.homepage-header .search-icon {
  line-height: 132px;
  font-size: 30px;
  color: #333333;
  padding: 25px 20px 10px 20px;
  float: left;
}
.homepage-header .search-icon::before {
  content: "\e916";
  font-family: 'johanneswerk-iconfont' !important;
  display: inline-block;
}
.homepage-header .search-icon:hover {
  text-decoration: none;
  color: #b51d28;
  border-bottom: 4px solid #b51d28;
}
.homepage-header .nav-wrapper {
  position: relative;
  height: 176px;
  display: inline-block;
  margin-left: -15px;
  clear: both;
  float: left;
}
.homepage-header .main-nav {
  margin-bottom: 0px;
  float: left;
}
.homepage-header .main-nav .navigation {
  padding: 0;
  list-style-type: none;
  display: inline;
}
.homepage-header .main-nav .navigation li {
  margin: 20px;
  float: left;
  position: relative;
}
.homepage-header .main-nav .navigation li.sub:after {
  content: "\e904";
  font-family: 'johanneswerk-iconfont' !important;
  font-size: 13px;
  line-height: 18px;
  height: 16px;
  margin-left: 5px;
  position: relative;
  top: -2px;
  display: inline-block;
  transition: transform 550ms ease, color 550ms ease;
  -moz-transition: -moz-transform 550ms ease, color 550ms ease;
  -ms-transition: -ms-transform 550ms ease, color 550ms ease;
  -o-transition: -o-transform 550ms ease, color 550ms ease;
  -webkit-transition: -webkit-transform 550ms ease, color 550ms ease;
}
.homepage-header .main-nav .navigation li.sub:hover:after {
  color: #b51d28;
  top: -2px;
  transform: rotate(-180deg);
  -moz-transform: rotate(-180deg);
  -ms-transform: rotate(-180deg);
  -o-transform: rotate(-180deg);
  -webkit-transform: rotate(-180deg);
}
.homepage-header .main-nav .navigation li a {
  line-height: 136px;
  font-size: 30px;
  color: #333333;
  display: inline-block;
  padding-bottom: 16px;
  transition: transform 550ms ease, color 450ms ease;
  -moz-transition: -moz-transform 550ms ease, color 450ms ease;
  -ms-transition: -ms-transform 550ms ease, color 450ms ease;
  -o-transition: -o-transform 550ms ease, color 450ms ease;
  -webkit-transition: -webkit-transform 550ms ease, color 450ms ease;
}
.homepage-header .main-nav .navigation li ul.lvl-1 {
  list-style-type: none;
  width: 250px;
  box-shadow: 0 5px 15px 0 rgba(0, 0, 0, 0.3);
  visibility: hidden;
  opacity: 0;
  transition: opacity 450ms ease;
  -moz-transition: opacity 450ms ease;
  -ms-transition: opacity 450ms ease;
  -o-transition: opacity 450ms ease;
  -webkit-transition: opacity 450ms ease;
  position: absolute;
  display: block;
  z-index: 1;
  background-color: #ffffff;
  margin: 0px 0px 0px 0px;
  padding: 5px 0px 0px 0px;
}
.homepage-header .main-nav .navigation li ul.lvl-1 li {
  float: none;
  margin: 0;
  margin-right: 250px;
  padding: 0;
  position: initial;
}
.homepage-header .main-nav .navigation li ul.lvl-1 li.sub:after {
  display: none;
}
.homepage-header .main-nav .navigation li ul.lvl-1 li a {
  transition: none;
  width: 250px;
  color: #333333;
  line-height: 30px;
  font-size: 22px;
  padding: 10px 40px 10px 20px;
  border-bottom: 0px solid transparent;
  display: inline-block;
}
.homepage-header .main-nav .navigation li ul.lvl-1 li ul.lvl-2 {
  position: absolute;
  visibility: hidden;
  opacity: 0;
  transition: opacity 450ms ease;
  -moz-transition: opacity 450ms ease;
  -ms-transition: opacity 450ms ease;
  -o-transition: opacity 450ms ease;
  -webkit-transition: opacity 450ms ease;
  display: block;
  top: 0px;
  right: -250px;
  background-color: #b51d28;
  width: 250px;
  padding-top: 5px;
}
.homepage-header .main-nav .navigation li ul.lvl-1 li ul.lvl-2 li a {
  color: #ffffff;
  font-size: 18px;
  line-height: 24px;
}
.homepage-header .main-nav .navigation > li:hover a {
  color: #b51d28;
  text-decoration: none;
  border-bottom: 4px solid #b51d28;
  transition: transform 550ms ease, color 450ms ease;
  -moz-transition: -moz-transform 550ms ease, color 450ms ease;
  -ms-transition: -ms-transform 550ms ease, color 450ms ease;
  -o-transition: -o-transform 550ms ease, color 450ms ease;
  -webkit-transition: -webkit-transform 550ms ease, color 450ms ease;
}
.homepage-header .main-nav .navigation > li:hover ul.lvl-1 {
  box-shadow: 0 5px 15px 0 rgba(0, 0, 0, 0.3);
  visibility: visible;
  opacity: 1;
  transition: opacity 450ms ease;
  -moz-transition: opacity 450ms ease;
  -ms-transition: opacity 450ms ease;
  -o-transition: opacity 450ms ease;
  -webkit-transition: opacity 450ms ease;
  z-index: 10;
  background-color: #ffffff;
}
.homepage-header .main-nav .navigation > li:hover ul.lvl-1 li {
  float: none;
  margin-left: 0px;
  padding: 0;
  margin: 0;
}
.homepage-header .main-nav .navigation > li:hover ul.lvl-1 li a {
  font-size: 22px;
  border-bottom: 0px solid transparent;
}
.homepage-header .main-nav .navigation > li > ul.lvl-1 > li:hover {
  background-color: #b51d28;
}
.homepage-header .main-nav .navigation > li > ul.lvl-1 > li:hover a {
  color: #ffffff;
}
.homepage-header .main-nav .navigation > li > ul.lvl-1 > li:hover ul.lvl-2 {
  visibility: visible;
  opacity: 1;
  transition: opacity 450ms ease;
  -moz-transition: opacity 450ms ease;
  -ms-transition: opacity 450ms ease;
  -o-transition: opacity 450ms ease;
  -webkit-transition: opacity 450ms ease;
}
.homepage-header .main-nav .navigation > li > ul.lvl-1 > li > ul.lvl-2 li:hover {
  background-color: #cb6168;
}
.logo {
  margin-top: 45px;
  float: right;
}
.homepage .homepage-header {
  border-top: solid 1px #d2d2d2;
}
@media (max-width: 1199px) {
  .logo {
    margin-top: 0px;
  }
}
/* cookie link */
.container .copyright {
  line-height: 10px;
  margin-bottom: 25px;
}
.uc-embedding-container {
  z-index: 2;
}
.unstarted-mode:not(.playing-mode) .ytp-cued-thumbnail-overlay:not([aria-hidden=true]),
.ended-mode .ytp-cued-thumbnail-overlay:not([aria-hidden=true]) {
  cursor: pointer;
}
.ytp-thumbnail-overlay {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 1;
  background-position: center;
  background-repeat: no-repeat;
  -moz-transition: opacity 0.5s cubic-bezier(0, 0, 0.2, 1);
  -webkit-transition: opacity 0.5s cubic-bezier(0, 0, 0.2, 1);
  transition: opacity 0.5s cubic-bezier(0, 0, 0.2, 1);
  background-size: cover;
  -moz-background-size: cover;
  -webkit-background-size: cover;
}
.ytp-thumbnail-overlay span {
  color: #fff;
  width: 100%;
  background: #000;
  display: block;
  position: absolute;
  height: 46px;
  padding: 10px 30px;
  padding: 18px 0px 0px 63px;
  line-height: 30px;
  font-size: 18px;
  font-family: "YouTube Noto", Roboto, Arial, Helvetica, sans-serif;
  -webkit-font-smoothing: antialiased;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
.ytp-thumbnail-overlay span.top::before {
  content: "";
  position: absolute;
  top: 12px;
  left: 12px;
  width: 40px;
  height: 40px;
  background: #ffffff url(/typo3conf/ext/ig_project/Resources/Public/Img/logo-johanneswerk.svg) no-repeat center center;
  border-radius: 50%;
  background-size: 86px;
  background-position: -59px 5px;
}
.ytp-thumbnail-overlay span.bottom {
  bottom: 0;
  padding: 5px 12px;
  font: 500 16px/28px "YouTube Noto", Roboto, Arial, Helvetica, sans-serif;
}
.ytp-button:not([aria-disabled=true]):not([disabled]):not([aria-hidden=true]) {
  cursor: pointer;
}
.ytp-small-mode .ytp-large-play-button {
  width: 42px;
  height: 30px;
  margin-left: -21px;
  margin-top: -15px;
}
.ytp-large-play-button {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 68px;
  height: 48px;
  margin-left: -34px;
  margin-top: -24px;
  -moz-transition: opacity 0.25s cubic-bezier(0, 0, 0.2, 1);
  -webkit-transition: opacity 0.25s cubic-bezier(0, 0, 0.2, 1);
  transition: opacity 0.25s cubic-bezier(0, 0, 0.2, 1);
}
.ytp-button {
  border: none;
  background-color: transparent;
  padding: 0;
  color: inherit;
  text-align: inherit;
  font-size: 100%;
  font-family: inherit;
  cursor: default;
  line-height: inherit;
}
.html5-video-player svg {
  pointer-events: none;
}
.ytp-large-play-button-bg {
  -moz-transition: fill 0.1s cubic-bezier(0.4, 0, 1, 1), fill-opacity 0.1s cubic-bezier(0.4, 0, 1, 1);
  -webkit-transition: fill 0.1s cubic-bezier(0.4, 0, 1, 1), fill-opacity 0.1s cubic-bezier(0.4, 0, 1, 1);
  transition: fill 0.1s cubic-bezier(0.4, 0, 1, 1), fill-opacity 0.1s cubic-bezier(0.4, 0, 1, 1);
  fill: #1f1f1f;
  fill-opacity: .81;
}
.ytp-large-play-button.ytp-touch-device .ytp-large-play-button-bg,
.ytp-cued-thumbnail-overlay:hover .ytp-large-play-button-bg {
  -moz-transition: fill 0.1s cubic-bezier(0, 0, 0.2, 1), fill-opacity 0.1s cubic-bezier(0, 0, 0.2, 1);
  -webkit-transition: fill 0.1s cubic-bezier(0, 0, 0.2, 1), fill-opacity 0.1s cubic-bezier(0, 0, 0.2, 1);
  transition: fill 0.1s cubic-bezier(0, 0, 0.2, 1), fill-opacity 0.1s cubic-bezier(0, 0, 0.2, 1);
  fill: #cc181e;
  fill: #FF0000;
  fill-opacity: 1;
}
.uc-embedding-container > img[alt="Youtube video preview image"] {
  display: none;
}
.igcontent-accordion {
  margin-bottom: 50px;
  border-bottom: 1px solid #d2d2d2;
}
.igcontent-accordion .card .card-header a {
  position: relative;
  display: inline-block;
  width: 100%;
  background: transparent;
  border: 0;
  border-top: 1px solid #d2d2d2;
  border-radius: 0;
  padding-left: 0;
  font-weight: 500;
  padding-top: 18px;
  padding-bottom: 18px;
  padding-right: 28px;
  line-height: 36px;
  font-size: 36px;
  font-family: Calibri, 'PT Sans';
  color: #333;
}
.igcontent-accordion .card .card-header a:after {
  position: absolute;
  left: inherit;
  right: 10px;
  text-indent: 0;
  background: none;
  height: 30px;
  margin-top: -14px;
  font-family: 'johanneswerk-iconfont' !important;
  content: '\e904';
  color: #b51d28;
  font-size: 22px;
  font-weight: normal;
  display: inline-block;
  text-align: center;
  width: 30px;
  line-height: 36px;
  padding: 18px 0;
}
.igcontent-accordion .card .card-header a[aria-expanded="true"]:after {
  content: '\e907';
}
.igcontent-accordion .card-body {
  border: 0;
  padding: 0 38px 0 0;
  font-family: Calibri, 'PT Sans';
}
.igcontent-accordion .card-body p:last-child {
  padding-bottom: 0;
}
.igcontent-accordion .card-body > h1,
.igcontent-accordion .card-body > h2,
.igcontent-accordion .card-body > h3,
.igcontent-accordion .card-body > h4 {
  padding-top: 0;
}
.igcontent-accordion .card-body li > a {
  font-weight: normal;
}
.tx_nsnewscomments #comment-form p.text-muted {
  font-size: 14px;
}
.tx_nsnewscomments #comment-form .ns-form-group {
  max-width: 600px;
}
.tx_nsnewscomments #comment-form .ns-form-group label {
  width: 110px;
  float: left;
  font-size: 16px;
}
.tx_nsnewscomments #comment-form .ns-form-group label + input,
.tx_nsnewscomments #comment-form .ns-form-group label + textarea {
  width: calc(100% - 114px);
  border-radius: 18px;
  background-color: #eeeeee;
  border: 1px solid #d2d2d2;
  font-size: 16px;
}
.tx_nsnewscomments #comment-form .checkbox-group label {
  width: 110px;
  float: none;
}
.tx_nsnewscomments #comment-form .checkbox-group label.ns-form-checkbox {
  clear: both;
  width: auto;
}
.tx_nsnewscomments #comment-form .ns-btn {
  border-radius: 25px;
  padding: 0 30px;
  height: 47px;
  background-color: #b51d28;
  border: none;
  margin: 0 auto;
  font-weight: bold;
  color: #fff;
  font-size: 22px;
  display: block;
}
.tx_nsnewscomments .comments-list .comment-avatar {
  border: 0;
  border-radius: 50%;
  -webkit-box-shadow: none;
  -moz-box-shadow: none;
  box-shadow: none;
}
.tx_nsnewscomments .comments-list .comment-box .comment-content p {
  font-size: 18px;
  line-height: 26px;
}
.tx_nsnewscomments .comments-list .comment-box .comment-btn.reply {
  color: #b51d28;
  font-weight: bold;
}
.tx_nsnewscomments .comments-list .comment-box .comment-footer {
  padding-top: 0;
}
.tx_nsnewscomments .error-msg {
  position: relative;
  background: none;
  border: 0;
  box-shadow: none;
  color: #333333 !important;
  font-style: italic;
  font-size: 16px;
  text-align: left;
  margin-left: 140px;
  text-transform: none;
}
.tx_nsnewscomments .error-msg:before {
  font-family: 'johanneswerk-iconfont' !important;
  display: inline-block;
  margin-left: -1.3em;
  width: 1.3em;
  position: relative;
  color: #b51d28;
  content: "\e920";
  top: 2px;
}
.tx_nsnewscomments .error-msg:after {
  display: none;
}
.tx_nsnewscomments .checkbox-group .error-msg {
  clear: both;
  margin-left: 18px;
}
.tx_nsnewscomments .red-title h2 {
  color: #b51d28;
  font-weight: bold;
  text-transform: uppercase;
  font-size: 18px;
  line-height: 22px;
  padding: 20px 0 0px 0;
}
@media (max-width: 767px) {
  .tx_nsnewscomments #comment-form .ns-form-group label + input,
  .tx_nsnewscomments #comment-form .ns-form-group label + textarea {
    width: 100%;
  }
  .tx_nsnewscomments .error-msg {
    margin-left: 18px;
  }
  .tx_nsnewscomments .ns-news-comment-wrapper .comment-author,
  .tx_nsnewscomments .ns-news-comment-wrapper .comment-box .comment-btn {
    font-size: 16px;
  }
  .tx_nsnewscomments .ns-news-comment-wrapper .comment-box .comment-content,
  .tx_nsnewscomments .ns-news-comment-wrapper .reply-form .comment-form .text-muted {
    font-size: 16px;
  }
  .tx_nsnewscomments .ns-news-comment-wrapper .reply-form .ns-form-group label {
    font-size: 16px;
  }
  .tx_nsnewscomments .ns-news-comment-wrapper .reply-form .comment-form input,
  .tx_nsnewscomments .ns-news-comment-wrapper .reply-form .comment-form textarea,
  .tx_nsnewscomments .ns-news-comment-wrapper .reply-form .comment-form select {
    font-size: 16px;
    height: 32px !important;
  }
}
@-webkit-keyframes spin {
  from {
    -webkit-transform: rotateZ(0deg);
  }
  to {
    -webkit-transform: rotateZ(360deg);
  }
}
@keyframes spin {
  from {
    transform: rotateZ(0deg);
  }
  to {
    transform: rotateZ(360deg);
  }
}
fieldset .powermail_fieldwrap .btn-primary.btn-loading {
  width: auto;
  padding-right: 20px;
  cursor: wait;
  background-color: #cb6168;
  font-size: 20px;
  line-height: 34px;
}
fieldset .powermail_fieldwrap .btn-primary.btn-loading .icon-spin {
  margin-right: 10px;
}
fieldset .powermail_fieldwrap .btn-primary.btn-loading .icon-markup {
  float: left;
  width: 30px;
  height: 30px;
  -webkit-animation: spin 2s linear infinite;
  -moz-animation: spin 2s linear infinite;
  animation: spin 2s linear infinite;
}
form fieldset .powermail_fieldwrap input.error,
form fieldset .powermail_fieldwrap textarea.error {
  border-color: #b51d28;
}
.sweet-field2 {
  height: 0px;
  overflow: hidden;
}
.homepage-content .shariff_title {
  color: #b51d28;
  font-weight: bold;
  text-transform: uppercase;
  font-size: 18px;
  line-height: 22px;
  padding: 40px 0 20px 0;
}
.homepage-content .shariff ul li {
  border: 1px solid #e7e7e7;
}
.homepage-content .shariff ul li:hover.facebook {
  border-color: #3b5998;
}
.homepage-content .shariff ul li:hover.twitter {
  border-color: #55acee;
}
.homepage-content .shariff ul li:hover.mail {
  border-color: #999999;
}
.homepage-content .shariff ul li:before {
  margin-left: 0;
  top: 0;
  display: none;
}
.homepage-content .shariff ul li a {
  line-height: 30px;
}
.homepage-content .shariff ul li a .share_text {
  font-weight: bold;
}
.homepage-content .shariff ul li.facebook a {
  color: #3b5998;
  background-color: transparent;
}
.homepage-content .shariff ul li.facebook a .fab {
  padding-left: 10px;
  margin-right: 10px;
  display: inline-block;
  margin-top: -2px;
  font-family: 'johanneswerk-iconfont';
}
.homepage-content .shariff ul li.facebook a .fab:before {
  content: "\e923";
}
.homepage-content .shariff ul li.twitter a {
  color: #55acee;
  background-color: transparent;
}
.homepage-content .shariff ul li.twitter a .fab {
  padding-left: 10px;
  margin-right: 10px;
  display: inline-block;
  margin-top: -2px;
  font-family: 'johanneswerk-iconfont';
}
.homepage-content .shariff ul li.twitter a .fab:before {
  content: "\e922";
}
.homepage-content .shariff ul li.mail a {
  color: #999999;
  background-color: transparent;
}
.homepage-content .shariff ul li.mail a .fas {
  padding-left: 10px;
  margin-right: 10px;
  display: inline-block;
  margin-top: -4px;
  font-family: 'johanneswerk-iconfont';
}
.homepage-content .shariff ul li.mail a .fas:before {
  content: "\e90f";
}
.spendenteaser,
.offerpage .spendenteaser,
.subpage .spendenteaser {
  border: 1px solid #b51d28;
  padding: 32px 30px 30px 30px;
  position: relative;
}
.spendenteaser .h1,
.offerpage .spendenteaser .h1,
.subpage .spendenteaser .h1 {
  text-transform: uppercase;
  color: #b51d28;
  font-weight: bold;
  margin-top: 0;
  margin-bottom: 0;
  font-size: 40px;
}
.spendenteaser a.don-button,
.offerpage .spendenteaser a.don-button,
.subpage .spendenteaser a.don-button {
  font-weight: bold;
  height: 47px;
  width: 202px;
  border-radius: 25px;
  background-color: #b51d28;
  display: inline-block;
  text-align: center;
  color: #ffffff;
  line-height: 45px;
  padding-top: 2px;
  font-size: 22px;
  text-transform: uppercase;
}
.spendenteaser a.don-button:hover,
.offerpage .spendenteaser a.don-button:hover,
.subpage .spendenteaser a.don-button:hover {
  background-color: #cb6168;
}
.spendenteaser a.don-button.displayDonationAmount,
.offerpage .spendenteaser a.don-button.displayDonationAmount,
.subpage .spendenteaser a.don-button.displayDonationAmount {
  position: absolute;
}
.spendenteaser a.text-button,
.offerpage .spendenteaser a.text-button,
.subpage .spendenteaser a.text-button {
  font-weight: bold;
  height: 42px;
  width: auto;
  border-radius: 21px;
  background-color: #B51D28;
  display: inline-block;
  text-align: center;
  margin: 0 auto;
  color: #ffffff;
  line-height: 42px;
  font-size: 22px;
  padding: 0 20px;
}
.spendenteaser a.text-button:hover,
.offerpage .spendenteaser a.text-button:hover,
.subpage .spendenteaser a.text-button:hover {
  background-color: #cb6168;
  color: #fff;
}
@media (max-width: 767px) {
  .spendenteaser a.don-button,
  .offerpage .spendenteaser a.don-button,
  .subpage .spendenteaser a.don-button {
    float: left;
  }
  .spendenteaser .h1,
  .offerpage .spendenteaser .h1,
  .subpage .spendenteaser .h1 {
    font-size: 28px;
  }
}
.spendenteaser .form-donation-amount,
.offerpage .spendenteaser .form-donation-amount,
.subpage .spendenteaser .form-donation-amount {
  margin-top: 30px;
}
.spendenteaser .form-donation-amount .iradio_square-blue,
.offerpage .spendenteaser .form-donation-amount .iradio_square-blue,
.subpage .spendenteaser .form-donation-amount .iradio_square-blue {
  margin-top: -6px;
}
.spendenteaser .form-donation-amount .checkbox-donation-amount,
.offerpage .spendenteaser .form-donation-amount .checkbox-donation-amount,
.subpage .spendenteaser .form-donation-amount .checkbox-donation-amount {
  margin: 0 20px 0 8px;
  font-size: 22px;
  font-weight: normal;
}
.spendenteaser .amount-verification,
.offerpage .spendenteaser .amount-verification,
.subpage .spendenteaser .amount-verification {
  position: relative;
  height: 100%;
  margin-top: 20px;
}
.spendenteaser .amount-verification > div,
.offerpage .spendenteaser .amount-verification > div,
.subpage .spendenteaser .amount-verification > div {
  background: black;
  position: relative;
  z-index: 1;
  border-radius: 25px;
  background: #EEEEEE;
  height: 47px;
  border: 2px solid #D2D2D2;
}
@media (max-width: 480px) {
  .spendenteaser .amount-verification > div,
  .offerpage .spendenteaser .amount-verification > div,
  .subpage .spendenteaser .amount-verification > div {
    margin-left: 45px;
  }
}
.spendenteaser .amount-verification > div span,
.offerpage .spendenteaser .amount-verification > div span,
.subpage .spendenteaser .amount-verification > div span {
  line-height: 47px;
  font-size: 22px;
  margin-left: 20px;
}
.spendenteaser .amount-verification > a,
.offerpage .spendenteaser .amount-verification > a,
.subpage .spendenteaser .amount-verification > a {
  z-index: 2;
  right: 0;
  bottom: 0;
}
.spendenteaserBild img {
  max-width: 100%;
  height: auto;
}
@media (min-width: 480px) {
  .spendenteaserBild .spendenteaser {
    margin: -80px 30px 0 30px;
    z-index: 100;
    position: relative;
    background-color: #fff;
    display: inline-block;
    width: calc(100% - 60px);
  }
}
.allocatorpage .spendenteaser .h1 {
  text-align: left;
  padding-left: 0;
}
.allocatorpage .spendenteaser .h1:after {
  display: none;
}
.exitStoerer {
  position: fixed;
  right: 0;
  top: 256px;
  width: 228px;
  height: 292px;
  background: url('../Img/stoerer-kirchentag-2019@2x.png') no-repeat right center;
  background-size: contain;
  transition: right 1s ease-out;
  z-index: 101;
}
.exitStoerer a.mainlink {
  width: 195px;
  height: 100%;
  display: block;
  margin-left: 33px;
}
.exitStoerer a.openclose.open,
.exitStoerer a.openclose.close {
  width: 40px;
  height: 40px;
  display: block;
  background: url('../Img/x@2x.png') no-repeat right center;
  background-size: 12px 12px;
  padding: 16px;
  top: 26px;
  left: -14px;
  position: absolute;
}
.exitStoerer a.openclose.close {
  background: url('../Img/logo@2x.png') no-repeat right center;
  width: 40px;
  height: 40px;
  top: 26px;
  left: -12px;
  background-size: 16px 16px;
  opacity: 1;
  padding: 12px;
}
.exitStoerer.closeme {
  right: -195px;
}
@media (max-width: 767px) {
  .exitStoerer {
    top: 200px;
  }
}
.homepage-content .teaser-slider {
  margin-bottom: 30px;
  position: relative;
  max-width: 350px;
  margin-left: auto;
  margin-right: auto;
}
.homepage-content .teaser-slider ul.slick-dots {
  list-style-type: none;
  width: calc(100% - 60px);
  margin-left: 30px;
}
.homepage-content .teaser-slider ul.slick-dots li,
.homepage-content .teaser-slider ul.slick-dots li.slick-active {
  width: 20px;
  height: 20px;
  padding: 4px;
}
.homepage-content .teaser-slider ul.slick-dots li:before,
.homepage-content .teaser-slider ul.slick-dots li.slick-active:before {
  display: none;
}
.homepage-content .teaser-slider ul.slick-dots li button:before,
.homepage-content .teaser-slider ul.slick-dots li.slick-active button:before {
  content: "\e918";
  font-size: 12px;
  font-family: 'johanneswerk-iconfont' !important;
  font-weight: bold;
  color: #999;
  display: inline-block;
  margin-left: auto;
  width: 12px;
  height: 12px;
  position: relative;
  top: 8px;
}
.homepage-content .teaser-slider ul.slick-dots li.slick-active button:before {
  color: #b51d28;
  background-color: #b51d28;
  border-radius: 50%;
  line-height: 12px;
  opacity: 1;
}
.homepage-content .teaser-slider .slick-arrow {
  left: 0;
  bottom: -25px;
  top: unset;
  position: absolute;
  font-size: 18px;
  cursor: pointer;
}
.homepage-content .teaser-slider .slick-arrow:before {
  color: #b51d28;
}
.homepage-content .teaser-slider .slick-arrow.icon-icon_arrow_1_right {
  left: unset;
  right: 0;
}
@media (max-width: 991px) {
  .homepage-content .teaser-slider {
    margin-bottom: 60px;
  }
  .homepage-content .teaser-slider .teaser {
    margin-bottom: 0;
  }
}
.teaser img {
  border-radius: var(--image-borders);
}
.powermail_form.nolabel > h3 {
  display: none;
}
.homepage-content .powermail_form ul .parsley-required {
  font-style: italic;
}
.homepage-content .powermail_form ul .parsley-required:before {
  color: #b51d28;
  content: "\e920";
  top: 2px;
}
fieldset {
  border: 0px solid transparent;
  margin: 0;
  padding: 0;
}
fieldset legend {
  display: none;
}
fieldset .powermail_fieldwrap {
  font-size: 22px;
  line-height: 28px;
  width: 100%;
  display: inline-block;
  /*
        select{
          background: url(http://cdn1.iconfinder.com/data/icons/cc_mono_icon_set/blacks/16x16/br_down.png) no-repeat @color-background;
          -webkit-appearance: none;
          background-size:
                  20px 20px,
                  20px 20px,
                  2.5em 2.5em;
          background-position:  96% 15px;
          option {
            content: attr(title);
            background: @color-light;
            color: @color-font-normal;
            position: absolute;
            width: 100%;
            left: 0;
            border: none;
            &:focus{
              border: 1px solid @color-separator;
              box-shadow: 0 0 3pt 2pt #719ECE;
              -webkit-appearance: none;
            }
          }
        }*/
}
fieldset .powermail_fieldwrap .control-label {
  text-align: left;
  float: left;
}
fieldset .powermail_fieldwrap input[type=text],
fieldset .powermail_fieldwrap input[type=email],
fieldset .powermail_fieldwrap textarea,
fieldset .powermail_fieldwrap select,
fieldset .powermail_fieldwrap input[type=date] {
  background-color: #eeeeee;
  border: 2px solid #d2d2d2;
  border-radius: 25px;
  height: 50px;
  width: 100%;
  margin-right: 30px;
  color: #333333;
  padding-left: 20px;
  font-size: 22px;
  outline: none;
}
fieldset .powermail_fieldwrap input[type=text]:focus,
fieldset .powermail_fieldwrap input[type=email]:focus,
fieldset .powermail_fieldwrap textarea:focus,
fieldset .powermail_fieldwrap select:focus,
fieldset .powermail_fieldwrap input[type=date]:focus {
  border: 2px solid #333333;
  outline: none;
  outline-style: none;
  outline-color: transparent;
  -webkit-appearance: none;
  box-shadow: none;
}
fieldset .powermail_fieldwrap textarea {
  height: auto;
}
fieldset .powermail_fieldwrap .btn-primary {
  border-radius: 25px;
  width: 136px;
  height: 47px;
  background-color: #b51d28;
  border: none;
  margin: 2px 55px 0px 0px;
  font-weight: bold;
  color: #fff;
  font-size: 22px;
}
fieldset .powermail_fieldwrap .btn-primary:hover {
  background-color: #cb6168;
}
fieldset .powermail_fieldwrap .radio label,
fieldset .powermail_fieldwrap .checkbox label {
  padding: 0px;
}
fieldset .powermail_fieldwrap.nolabel > label {
  display: none;
}
@media (max-width: 767px) {
  fieldset .powermail_fieldwrap {
    font-size: 18px;
    line-height: 26px;
  }
  fieldset .powermail_fieldwrap input[type=text],
  fieldset .powermail_fieldwrap input[type=email],
  fieldset .powermail_fieldwrap select,
  fieldset .powermail_fieldwrap input[type=date] {
    height: 40px;
    font-size: 18px;
  }
  fieldset .powermail_fieldwrap textarea {
    font-size: 18px;
  }
  fieldset .powermail_fieldwrap .chosen-container.chosen-container-single .chosen-single {
    height: 40px;
    font-size: 18px;
  }
  fieldset .powermail_fieldwrap .chosen-container.chosen-container-single .chosen-single span {
    line-height: 37px;
  }
  fieldset .powermail_fieldwrap .chosen-container.chosen-container-single .chosen-single div b {
    padding: 3.5px 15px;
  }
  fieldset .powermail_fieldwrap .chosen-container.chosen-container-single .chosen-single div b:before {
    font-size: 16px;
  }
}
fieldset .powermail_fieldwrap.sweet-field {
  display: none;
}
fieldset .powermail_fieldwrap.fixed-field label {
  color: #fff;
}
fieldset .powermail_fieldwrap.fixed-field input[type=text] {
  background: #fff;
  border: 0;
  color: #fff;
}
.powermail_confirmation .btn-primary,
.powermail_confirmation .btn-danger {
  border-radius: 25px;
  width: auto;
  height: 47px;
  background-color: #b51d28;
  border: none;
  margin: 2px 55px 0px 0px;
  font-weight: bold;
  color: #fff;
  font-size: 22px;
  padding: 6px 20px;
}
.powermail_confirmation .btn-primary:hover,
.powermail_confirmation .btn-danger:hover {
  background-color: #cb6168;
}
.powermail_confirmation .btn-danger {
  background-color: #999999;
}
.powermail_confirmation .btn-danger:hover {
  background-color: #d2d2d2;
}
.powermail_confirmation table {
  border-top: transparent;
}
.powermail_confirmation table.table-striped > tbody > tr:nth-of-type(odd) {
  background-color: transparent;
}
.powermail_confirmation table tr {
  border-bottom: none;
}
.powermail_confirmation table.table-striped > tbody > tr > td {
  border-top: none;
}
.pflichtfeld {
  font-size: 16px;
  color: #999999;
}
#modal_loading .modal-bar {
  height: 50px;
  width: 100%;
  display: block;
  background: #B51D28;
}
#modal_loading .modal-bar .close {
  color: #fff;
  opacity: 1;
  margin-right: 14px;
  margin-top: 3px;
}
#modal_loading .modal-bar .close span {
  font-size: 40px;
}
#modal_loading .modal-body {
  padding: 30px 5%;
}
#modal_loading .modal-body h1 {
  font-size: 30px;
  text-align: left;
  margin-bottom: 20px;
  padding: 0;
  text-transform: none;
}
#modal_loading .modal-body h1:after {
  display: none;
}
#modal_loading .modal-body p {
  font-size: 18px;
}
@media (min-width: 1200px) {
  #modal_loading .modal-dialog {
    width: 900px;
    margin: 30px auto;
  }
}
.chosen-container.chosen-container-single .chosen-single {
  background: none;
  background-color: #eeeeee;
  border: 2px solid #d2d2d2;
  border-radius: 25px;
  height: 50px;
  width: 100%;
  margin-right: 30px;
  color: #333333;
  padding-left: 20px;
  font-size: 22px;
  outline: none;
  line-height: 28px;
  box-shadow: none;
}
.chosen-container.chosen-container-single .chosen-single span {
  line-height: 45px;
}
.chosen-container.chosen-container-single .chosen-single div {
  height: auto;
  width: auto;
}
.chosen-container.chosen-container-single .chosen-single div b {
  background: none;
  padding: 6.5px 15px;
  background-image: none !important;
}
.chosen-container.chosen-container-single .chosen-single div b:before {
  font-family: 'johanneswerk-iconfont' !important;
  content: "\e904";
  font-size: 20px;
  font-weight: 100;
  vertical-align: middle;
}
.chosen-container-active.chosen-with-drop.chosen-container.chosen-container-single .chosen-single div b:before {
  content: "\e907";
}
.chosen-container.chosen-container-single .chosen-drop {
  border: 2px solid #d2d2d2;
  background: none;
  box-shadow: none;
  background-color: #ffffff;
  border-radius: 0;
  font-size: 22px;
  color: #333333;
  padding: 0;
  height: auto;
  margin: 3px 0px 0px 0px;
}
.chosen-container.chosen-container-single .chosen-drop .chosen-results {
  margin: 0;
  padding: 0;
}
.chosen-container.chosen-container-single .chosen-drop .chosen-results li {
  padding: 0px 0px 0px 20px;
  height: auto;
  line-height: 36px;
  margin: 0;
}
.chosen-container.chosen-container-single .chosen-drop .chosen-results li:before {
  display: none;
}
.chosen-container.chosen-container-single .chosen-drop .chosen-results li.highlighted {
  background-color: #eeeeee;
  color: #333333;
  background-image: none;
}
.chosen-container.chosen-container-active.chosen-with-drop .chosen-single {
  border: 2px solid #d2d2d2;
  box-shadow: none;
}
.chosen-container.chosen-container-active.chosen-with-drop .chosen-drop {
  border: 2px solid #d2d2d2;
}
.grid img {
  margin-bottom: 20px;
}
.grid h4 {
  color: #b51d28;
}
.grid h3 {
  color: #333333;
  margin: 0px 0px 20px 0px;
}
.grid-4 h3 {
  font-size: 24px;
  color: #333333;
  margin: 0px;
}
.latest-news .col-md-6 {
  padding-left: 30px;
}
.latest-news .col-md-6 a {
  display: inline-block;
  margin-bottom: 50px;
}
.latest-news .col-md-6 a h3 {
  color: #333333;
  margin: 0px;
}
.latest-news .col-md-6 a .h4 {
  color: #b51d28;
  margin: 5px 0;
  font-size: 18px;
  font-weight: bold;
  text-transform: uppercase;
  display: block;
}
.latest-news .col-md-6 a:hover h3 {
  color: #b51d28;
}
.latest-news .col-md-6:first-child {
  padding-left: 15px;
  padding-right: 30px;
  border-right: solid 1px #d2d2d2;
}
.latest-news .col-md-6:first-child a {
  margin-bottom: 0;
}
.latest-news .col-md-6:first-child a .h4 {
  margin-top: 20px;
}
@media (min-width: 991px) {
  .latest-news .col-md-6:first-child a .imagewrap {
    max-height: 370px;
    overflow: hidden;
  }
}
.latest-news .col-md-6:first-child a img {
  margin: 0 auto;
  width: 100%;
  height: auto;
}
.news-img-wrap {
  width: 50%;
}
.news-img-wrap .outer {
  display: block;
}
.main-wrap {
  display: table;
}
.list-news .news-article {
  margin-bottom: 50px;
}
.list-news .news-article h3 {
  margin: 0px 0px 0px 0px;
  color: #333333;
}
.list-news .news-article .h4 {
  margin: 5px 0;
  text-transform: uppercase;
  font-size: 18px;
  font-weight: bold;
}
.list-news .news-article .more img {
  width: 100%;
}
.subpage .news-single .news-img-wrap {
  float: left;
  margin: 0px 30px 10px 0px;
  display: inline-block;
}
.subpage .news-single .news-img-wrap img {
  width: 100%;
}
.subpage .news-single .news-img-wrap .news-img-caption {
  line-height: 1.42857143;
  margin-top: 10px;
  color: #999999;
  font-size: 18px;
  margin-bottom: 0;
}
.subpage .news-single .teaser-text {
  color: #b51d28;
  font-weight: bold;
  text-transform: uppercase;
  font-size: 22px;
  margin: 0px;
  padding: 0px;
  text-align: left;
}
.subpage .news-single .teaser-text:after {
  content: "";
  background: transparent;
  position: inherit;
  bottom: 0;
  height: 0px;
  margin-left: 0px;
  width: 0px;
  left: 0;
}
.subpage .news-single h1 {
  margin: 0px 0px 10px 0px;
  text-align: left;
  padding: 0;
  text-transform: none;
}
.subpage .news-single h1:after {
  content: "";
  background: transparent;
  position: inherit;
  bottom: 0;
  height: 0px;
  margin-left: 0px;
  width: 0px;
  left: 0;
}
.subpage .news-single .news-list-date,
.subpage .news-single .news-list-author {
  font-size: 18px;
}
@media (max-width: 991px) {
  .latest-news .col-md-6,
  .latest-news .col-md-6:first-child {
    padding-left: 15px;
    border-right: solid 0px transparent;
  }
  .latest-news .col-md-6 a:first-child,
  .latest-news .col-md-6:first-child a:first-child {
    margin-bottom: 50px;
  }
  .latest-news .col-md-6 a .h4,
  .latest-news .col-md-6:first-child a .h4 {
    margin-bottom: 0px;
  }
}
@media (max-width: 767px) {
  .latest-news .col-md-6,
  .latest-news .col-md-6:first-child {
    padding-left: 15px;
    padding-right: 15px;
    border-right: solid 0px transparent;
  }
  .latest-news .col-md-6 a,
  .latest-news .col-md-6:first-child a,
  .latest-news .col-md-6 a:first-child,
  .latest-news .col-md-6:first-child a:first-child {
    margin-bottom: 20px;
  }
  .news-img-wrap {
    width: 100%;
  }
  .news-img-wrap img {
    width: 100%;
  }
}
.breadcrumb {
  color: #999999;
  background: transparent;
  padding: 0;
  margin: 30px 0px 30px 0px;
  font-size: 18px;
}
.breadcrumb a {
  color: #999999;
}
.breadcrumb span {
  display: inline-block;
  margin: 0px 10px;
  color: #999999;
}
@media (max-width: 767px) {
  .breadcrumb {
    font-size: 14px;
    line-height: 17px;
  }
}
.homepage-content .ce-intext {
  display: table;
  width: 100%;
}
.homepage-content .ce-intext .ce-gallery {
  float: left;
  margin-right: 30px;
}
.homepage-content .ce-intext .ce-gallery figure {
  /*https://typo10.johanneswerk.de/angebote/menschen-im-alter/pflege-in-bochum*/
  /*width: 370px;*/
  margin: 0;
}
.homepage-content .ce-intext .ce-gallery figure img {
  /*width: 370px;*/
  height: auto;
}
.homepage-content .ce-intext .ce-gallery figure figcaption {
  margin-top: 10px;
  color: #999999;
  font-size: 18px;
}
.homepage-content .ce-intext.ce-left ol,
.homepage-content .ce-intext.ce-left ul {
  overflow: visible;
  display: inline-block;
}
.homepage-content ul {
  font-size: 22px;
}
.homepage-content ul li {
  line-height: 40px;
  font-size: 22px;
  list-style: none;
}
.homepage-content ul li:before {
  content: "\e91d";
  /* FontAwesome Unicode */
  font-family: 'johanneswerk-iconfont' !important;
  color: #999;
  display: inline-block;
  margin-left: -1.3em;
  /* same as padding-left set on li */
  width: 1.3em;
  /* same as padding-left set on li */
  position: relative;
  top: 4px;
}
.homepage-content ol {
  font-size: 22px;
  line-height: 40px;
}
.homepage-content ol li {
  padding-left: 10px;
  margin-left: -0.3em;
  /* same as padding-left set on li */
}
.ce-uploads {
  max-width: 770px;
  margin: auto;
  padding-bottom: 50px;
}
.ce-uploads li {
  border-top: 1px solid #d2d2d2;
  padding-top: 19px;
  margin-bottom: 0;
  margin-top: 0;
  padding-bottom: 21px;
}
.ce-uploads li:hover {
  background-color: #eeeeee;
}
.ce-uploads li:hover a.download:before {
  background-color: #fff;
}
.ce-uploads li:before {
  display: none;
}
.ce-uploads a.download {
  float: left;
  padding-left: 15px;
}
.ce-uploads a.download:before {
  float: left;
  background-color: #eeeeee;
  width: 90px;
  height: 90px;
  display: inline-block;
  border-radius: 50%;
  text-align: center;
  padding-right: 0;
  padding-top: 27px;
  font-size: 36px;
  margin-right: 15px;
}
.ce-uploads a.download span {
  /*float: left;*/
  display: inline;
}
.ce-uploads a.download span.downloadlink {
  font-size: 16px;
  line-height: 20px;
  text-transform: uppercase;
  font-weight: bold;
  min-width: 50%;
  color: #b51d28;
}
.ce-uploads a.download span.ce-uploads-fileName {
  padding-top: 18px;
  color: #333333;
  font-size: 24px;
  line-height: 29px;
}
.offerpage #gmap {
  height: 320px;
  width: 100%;
}
.offerpage .downloads {
  font-size: 22px;
  line-height: 27px;
  height: 27px;
  display: table;
}
.offerpage .downloads a {
  display: block;
  color: #b51d28;
  margin-bottom: 20px;
}
.offerpage .downloads a:hover {
  color: #b51d28;
}
.offerpage .downloads a:active,
.offerpage .downloads a:visited,
.offerpage .downloads a:focus {
  text-decoration: none;
}
.offerpage .downloads a span {
  padding-right: 15px;
  font-size: 24px;
}
.subpage .ce-bodytext h2,
.allocatorpage .ce-bodytext h2,
.offerpage .ce-bodytext h2,
.navigatorpage .ce-bodytext h2,
.subpage .ce-bodytext h3,
.allocatorpage .ce-bodytext h3,
.offerpage .ce-bodytext h3,
.navigatorpage .ce-bodytext h3,
.subpage .ce-bodytext h4,
.allocatorpage .ce-bodytext h4,
.offerpage .ce-bodytext h4,
.navigatorpage .ce-bodytext h4,
.subpage .ce-bodytext h5,
.allocatorpage .ce-bodytext h5,
.offerpage .ce-bodytext h5,
.navigatorpage .ce-bodytext h5,
.subpage .ce-bodytext h6,
.allocatorpage .ce-bodytext h6,
.offerpage .ce-bodytext h6,
.navigatorpage .ce-bodytext h6 {
  margin-top: 30px;
}
a.download {
  color: #b51d28;
}
a.download:hover {
  color: #b51d28;
}
a.download:before {
  padding-right: 15px;
  font-size: 24px;
  font-family: 'johanneswerk-iconfont' !important;
  speak: none;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
  content: "\e909";
  color: #b51d28;
}
@media (max-width: 767px) {
  .homepage-content .ce-intext .ce-gallery {
    margin-bottom: 20px;
  }
  .homepage-content ul {
    font-size: 18px !important;
  }
  .homepage-content ul li {
    font-size: 18px !important;
    line-height: 30px !important;
  }
  .homepage-content ol {
    font-size: 18px !important;
    line-height: 30px !important;
  }
  .homepage-content ol li {
    padding-left: 10px;
    margin-left: -0.3em;
    /* same as padding-left set on li */
  }
  fieldset .powermail_fieldwrap .btn-primary {
    height: 37px;
    line-height: 37px;
    font-size: 18px;
    padding: 0;
  }
}
@media (max-width: 359px) {
  .homepage-content .ce-intext .ce-gallery {
    margin-right: 0px;
    margin-bottom: 20px;
  }
}
.frame-layout-0 {
  margin-bottom: 50px;
}
.frame-layout-1 {
  margin-bottom: 100px;
}
.frame-layout-2 {
  margin-bottom: 30px;
}
.frame-layout-3 {
  margin-bottom: 0;
}
@media (max-width: 991px) {
  .frame-layout-1 {
    margin-bottom: 60px;
  }
}
@media (max-width: 767px) {
  .frame-layout-0 {
    margin-bottom: 30px;
  }
  .frame-layout-1 {
    margin-bottom: 50px;
  }
  .frame-layout-2 {
    margin-bottom: 20px;
  }
}
.side ul.navi {
  margin: 30px 0px 0px 0px;
  padding: 0px 0px 0px 10px;
}
.side ul.navi:first-child {
  border-top: 4px solid #d2d2d2;
}
.side ul.navi li {
  font-size: 22px;
  list-style: none;
  line-height: 50px;
}
.side ul.navi li.sub:before {
  font-family: 'johanneswerk-iconfont' !important;
  content: "\e904";
  display: inline-block;
  float: right;
  margin: 0px;
  width: 70px;
  padding: 0px 10px 0px 10px;
  text-align: center;
  height: 50px;
  font-size: 18px;
}
.side ul.navi li.sub.active:before {
  content: "\e907";
}
.side ul.navi li.sub.active.toggle:before {
  content: "\e904";
}
.side ul.navi li.sub.active.toggle ul {
  display: none !important;
}
.side ul.navi li.sub.toggle:before {
  content: "\e907";
}
.side ul.navi li.sub.toggle ul {
  display: block !important;
}
.side ul.navi li a {
  color: #333333;
  display: block;
  padding: 0px 10px;
  margin-left: -10px;
}
.side ul.navi li .active {
  margin-left: -10px;
  padding: 0px 10px;
  line-height: 50px;
  background-color: #eeeeee;
  color: #b51d28;
}
.side ul.navi li ul {
  padding: 0;
  margin: 0px 0px 0px 15px;
  display: none;
}
.side ul.navi li ul li {
  font-size: 18px;
}
.side ul.navi li.active ul.lvl-1 {
  display: block;
}
.side ul.navi li.active ul.lvl-1 ul {
  display: none;
}
.side ul.navi li.active ul.lvl-1 li.active,
.side ul.navi li.active ul.lvl-1 .active {
  background-color: transparent;
}
.side ul.navi li.active ul.lvl-1 li.active ul,
.side ul.navi li.active ul.lvl-1 .active ul {
  display: block;
}
.side .logos img {
  max-height: 85px;
  width: auto;
  text-align: center;
  margin: 0px auto;
}
@media (max-width: 1199px) {
  .side .navi {
    display: none;
  }
}
.contact,
.fix-contact {
  border: 1px solid #d2d2d2;
  border-top-width: 4px;
  line-height: 22px;
  font-size: 18px;
  margin-bottom: 20px;
}
.contact .wrapper,
.fix-contact .wrapper {
  padding: 10px 20px;
  display: table;
  width: 100%;
}
.contact .person,
.fix-contact .person {
  width: 34%;
  float: left;
  margin: 20px 0px;
}
.contact .person img,
.fix-contact .person img {
  float: left;
  -webkit-border-radius: 45px;
  -moz-border-radius: 45px;
  border-radius: 45px;
  border: 2px solid #d2d2d2;
  margin-right: 20px;
}
.contact .person .info,
.fix-contact .person .info {
  float: left;
  max-width: 200px;
}
.contact .person .info h3,
.fix-contact .person .info h3 {
  color: #b51d28;
  font-weight: bold;
  text-transform: uppercase;
  margin: 0;
  margin-bottom: 10px;
  font-size: 18px;
  line-height: 22px;
}
.contact .person .info .name,
.fix-contact .person .info .name {
  font-weight: bold;
}
.contact .person .job p,
.fix-contact .person .job p {
  margin: 0;
  font-size: 18px;
  line-height: 22px;
}
.contact .data,
.fix-contact .data {
  width: 33%;
  float: left;
  margin: 20px 0px;
}
.contact .data a,
.fix-contact .data a {
  line-height: 22px;
  color: #333333;
}
.contact .data a:before,
.fix-contact .data a:before {
  font-family: 'johanneswerk-iconfont' !important;
  color: #999;
  display: inline-block;
  margin-left: 3px;
  /* same as padding-left set on li */
  width: 1.3em;
  /* same as padding-left set on li */
  vertical-align: top;
  position: relative;
  top: 7px;
}
.contact .data .phone a,
.fix-contact .data .phone a,
.contact .data .fax a,
.fix-contact .data .fax a,
.contact .data .mail a,
.fix-contact .data .mail a {
  padding-left: 41px;
  position: relative;
  display: inline-block;
}
.contact .data .phone a:before,
.fix-contact .data .phone a:before,
.contact .data .fax a:before,
.fix-contact .data .fax a:before,
.contact .data .mail a:before,
.fix-contact .data .mail a:before {
  position: absolute;
  left: 0;
  top: 0;
}
.contact .data .phone a:before,
.fix-contact .data .phone a:before {
  content: "\e913";
  /* FontAwesome Unicode */
}
.contact .data .mobile a:before,
.fix-contact .data .mobile a:before {
  content: "\e926";
  color: #999;
}
.contact .data .fax a:before,
.fix-contact .data .fax a:before {
  content: "\e90a";
  /* FontAwesome Unicode */
}
.contact .data .mail a,
.fix-contact .data .mail a {
  color: #b51d28;
}
.contact .data .mail a:before,
.fix-contact .data .mail a:before {
  content: "\e90f";
  /* FontAwesome Unicode */
}
.contact .data .btn-anfrage,
.fix-contact .data .btn-anfrage {
  font-size: 16px;
  font-weight: bold;
  border-radius: 25px;
  background-color: #ffffff;
  color: #333333 !important;
  padding: 8px 20px;
  display: inline-block;
  margin: 15px 0;
}
.contact .data .btn-anfrage:before,
.fix-contact .data .btn-anfrage:before {
  content: "\e90f";
  /* FontAwesome Unicode */
  top: 0;
  color: #b51d28 !important;
  font-size: 18px;
}
.contact .data .btn-anfrage:hover,
.fix-contact .data .btn-anfrage:hover {
  background-color: #cb6168;
  color: #ffffff !important;
}
.contact .data .btn-anfrage:hover:before,
.fix-contact .data .btn-anfrage:hover:before {
  color: #ffffff !important;
}
.contact .adress,
.fix-contact .adress {
  width: 33%;
  float: left;
  margin: 20px 0px;
}
.offerpage .contact {
  border: none;
  border-top: 4px solid #d2d2d2;
  background-color: #b51d28;
  color: #ffffff;
}
.offerpage .contact .person .info h3 {
  color: #ffffff;
}
.offerpage .contact .person .job p {
  margin: 0;
  font-size: 18px;
  line-height: 22px;
}
.offerpage .contact .data {
  line-height: 34px;
}
.offerpage .contact .data a {
  color: #ffffff;
}
.offerpage .contact .data a:before {
  color: #ffffff;
}
.offerpage .contact .data .phone {
  font-size: 22px;
}
.offerpage .contact .data .phone a:before {
  font-size: 18px;
}
.offerpage .contact .adress {
  background-color: #eeeeee;
  margin: 0px;
  padding: 10px 20px 20px 20px;
  color: #333333;
}
.offerpage .contact .adress .header {
  text-transform: uppercase;
  margin: 10px 0px;
  font-weight: bold;
}
.offerpage .contact .coffee {
  margin-top: 30px;
  margin-bottom: 30px;
  display: block;
}
.offerpage .contact .coffee .textblock {
  background: #fff;
}
.offerpage .contact .coffee .textblock a {
  padding: 15px;
  display: block;
}
.homepage-content .sidecontact {
  display: none;
}
.side .contact,
.offerpage .side .contact,
.side .fix-contact,
.offerpage .side .fix-contact {
  width: 100%;
  margin-bottom: 20px;
  display: table;
}
.side .contact .wrapper,
.offerpage .side .contact .wrapper,
.side .fix-contact .wrapper,
.offerpage .side .fix-contact .wrapper {
  padding: 0px 20px;
}
.side .contact .person,
.offerpage .side .contact .person,
.side .fix-contact .person,
.offerpage .side .fix-contact .person,
.side .contact .data,
.offerpage .side .contact .data,
.side .fix-contact .data,
.offerpage .side .fix-contact .data,
.side .contact .adress,
.offerpage .side .contact .adress,
.side .fix-contact .adress,
.offerpage .side .fix-contact .adress {
  width: 100%;
}
.offerpage .side .contact,
.offerpage .side .contact.container .offerpage .side .fix-contact,
.offerpage .side .fix-contact.container {
  padding: 0;
}
.offerpage .side .contact .data,
.offerpage .side .contact.container .offerpage .side .fix-contact .data,
.offerpage .side .fix-contact.container .data {
  margin: 0px 0px 20px 0px;
}
.offerpage .side .contact .person,
.offerpage .side .contact.container .offerpage .side .fix-contact .person,
.offerpage .side .fix-contact.container .person {
  padding-top: 10px;
}
.offerpage .side .contact .adress,
.offerpage .side .contact.container .offerpage .side .fix-contact .adress,
.offerpage .side .fix-contact.container .adress {
  padding-top: 10px;
  padding-bottom: 20px;
}
@media (max-width: 1199px) and (min-width: 992px) {
  .main .sidecontact {
    display: block;
  }
  .main .sidecontact .contact .person {
    width: 100%;
  }
  .main .sidecontact .contact .adress {
    width: 100%;
    margin-bottom: 30px;
  }
  .side .karriere {
    display: none !important;
  }
  .side .contact {
    display: none !important;
  }
  .side .contact .person {
    padding-top: 5px !important;
  }
  .side .contact .person img {
    text-align: center;
    float: none;
    margin: auto;
    display: block;
  }
  .side .contact .person .info {
    float: none;
    width: 100%;
    margin: 5px auto 0px;
    display: block;
    text-align: center;
  }
  .side .contact .data .mail a span {
    max-width: 180px;
  }
}
@media (max-width: 991px) {
  .contact {
    width: 100%;
  }
  .contact .person,
  .contact .data,
  .contact .adress {
    width: 100%;
  }
  .contact .data,
  .contact .adress {
    margin-top: 0px;
  }
  .homepage-content .contact {
    display: table;
  }
  .homepage-content .sidecontact {
    display: block;
  }
  .homepage-content .sidecontact .person,
  .homepage-content .sidecontact .data,
  .homepage-content .sidecontact .adress {
    width: 100%;
  }
  .fix-contact {
    width: 100% !important;
  }
  .fix-contact .person,
  .fix-contact .adress,
  .fix-contact .data {
    float: left !important;
    width: 33% !important;
  }
  .side .contact,
  .side .karriere {
    display: none !important;
  }
}
@media (max-width: 767px) {
  .contact {
    width: 100%;
    max-width: 370px;
  }
  .contact .person,
  .contact .data,
  .contact .adress {
    width: 100%;
  }
  .contact .data,
  .contact .adress {
    margin-top: 0px;
  }
  .fix-contact {
    width: 100% !important;
  }
  .fix-contact .person,
  .fix-contact .adress,
  .fix-contact .data {
    float: none !important;
    width: 100% !important;
  }
}
@media (max-width: 379px) {
  .sidecontact .contact .person {
    padding-top: 5px !important;
  }
  .sidecontact .contact .person img {
    text-align: center;
    float: none;
    margin: auto;
    display: block;
  }
  .sidecontact .contact .person .info {
    float: none;
    width: 100%;
    margin: 5px auto 0px;
    display: block;
    text-align: center;
  }
  .sidecontact .contact .data .mail a span {
    max-width: 180px;
  }
}
.allocatorpage .row.allocate .col-md-4 > div > .fix-contact.container,
.allocatorpage .row.allocate .col-md-6 > div > .fix-contact.container,
.allocatorpage .row.allocate .col-md-3 > div > .fix-contact.container {
  width: 100%;
  margin-bottom: 20px;
  display: table;
}
.allocatorpage .row.allocate .col-md-4 > div > .fix-contact.container .wrapper,
.allocatorpage .row.allocate .col-md-6 > div > .fix-contact.container .wrapper,
.allocatorpage .row.allocate .col-md-3 > div > .fix-contact.container .wrapper {
  padding: 0 20px;
}
.allocatorpage .row.allocate .col-md-4 > div > .fix-contact.container .person,
.allocatorpage .row.allocate .col-md-6 > div > .fix-contact.container .person,
.allocatorpage .row.allocate .col-md-3 > div > .fix-contact.container .person,
.allocatorpage .row.allocate .col-md-4 > div > .fix-contact.container .data,
.allocatorpage .row.allocate .col-md-6 > div > .fix-contact.container .data,
.allocatorpage .row.allocate .col-md-3 > div > .fix-contact.container .data,
.allocatorpage .row.allocate .col-md-4 > div > .fix-contact.container .adress,
.allocatorpage .row.allocate .col-md-6 > div > .fix-contact.container .adress,
.allocatorpage .row.allocate .col-md-3 > div > .fix-contact.container .adress {
  width: 100%;
}
.allocatorpage .row.allocate .col-md-4 > div > .fix-contact.container .data a span,
.allocatorpage .row.allocate .col-md-6 > div > .fix-contact.container .data a span,
.allocatorpage .row.allocate .col-md-3 > div > .fix-contact.container .data a span {
  width: 100%;
  display: inline;
}
.allocatorpage .row.allocate .col-md-4 > div > .fix-contact.container .data a:before,
.allocatorpage .row.allocate .col-md-6 > div > .fix-contact.container .data a:before,
.allocatorpage .row.allocate .col-md-3 > div > .fix-contact.container .data a:before {
  top: 0;
}
.offerpage .offer-header {
  height: 174px;
  border-bottom: 1px solid #d2d2d2;
  margin-bottom: 70px;
}
.offerpage .offer-header .header h1 {
  text-align: left;
  padding: 0;
  text-transform: none;
  font-size: 48px;
  margin: 37px 0px 0px 0px;
  margin: 49px 0px 0px 0px;
}
.offerpage .offer-header .header h1:after {
  content: "";
  background: none;
  position: inherit;
  bottom: 0;
  height: auto;
  margin-left: 0px;
  width: auto;
  left: 0;
}
.offerpage .offer-header .header .logo {
  float: right;
}
.offerpage .offer-header .header .subheader {
  color: #b51d28;
  font-weight: bold;
  font-size: 22px;
}
@media (max-width: 1199px) {
  .offerpage .offer-header .header h1 {
    margin: 20px 0px 0px 0px;
  }
  .offerpage .offer-header a {
    line-height: 36px;
    font-size: 16px;
    color: #999999;
  }
}
@media (max-width: 767px) {
  .offerpage .offer-header {
    height: auto;
    border-bottom: 1px solid #d2d2d2;
    margin-bottom: 35px;
  }
  .offerpage .offer-header .header h1 {
    font-size: 36px;
    line-height: 44px;
    padding: 0px 0px 5px;
    margin: 10px 0px 0px 0px;
  }
  .offerpage .offer-header .header .subheader {
    margin: 0 0 20px;
  }
}
.checklist ul li {
  line-height: 40px;
  font-size: 22px;
  list-style: none;
}
.checklist ul li:before {
  content: "\e908";
  /* FontAwesome Unicode */
  font-family: 'johanneswerk-iconfont' !important;
  color: #b51d28;
  display: inline-block;
  margin-left: -1.3em;
  /* same as padding-left set on li */
  width: 1.5em;
  /* same as padding-left set on li */
  position: relative;
  top: 0px;
}
.offerpage .checklist ul {
  padding-left: 30px;
}
@media (max-width: 767px) {
  .offerpage .checklist {
    padding: 0px;
  }
}
table,
.ce-bodytext table {
  overflow-x: auto;
  line-height: 49px;
  font-size: 18px;
  border-top: solid 1px #d2d2d2;
  min-width: 100%;
  margin-bottom: 40px;
  border-spacing: 0;
  display: block;
}
table tr,
.ce-bodytext table tr {
  border-bottom: solid 1px #d2d2d2;
}
table thead,
.ce-bodytext table thead {
  background-color: #eeeeee;
  font-weight: bold;
}
table thead th,
.ce-bodytext table thead th {
  padding: 0px 10px;
}
table thead th p,
.ce-bodytext table thead th p {
  font-size: 18px;
}
table tbody,
.ce-bodytext table tbody {
  background-color: #ffffff;
}
table tbody td,
.ce-bodytext table tbody td {
  padding: 0px 10px;
}
table tbody td p,
.ce-bodytext table tbody td p {
  font-size: 18px;
}
.tx-ig-navigator .ce-bodytext table {
  border-top: none;
}
.tx-ig-navigator .ce-bodytext table thead tr th {
  border-top: solid 1px #d2d2d2;
}
.tx-ig-navigator .ce-bodytext table tr td {
  white-space: nowrap;
  text-align: right;
}
.tx-ig-navigator .ce-bodytext table tr td:first-child {
  white-space: normal;
  text-align: left;
}
.add-offer .header {
  color: #b51d28;
  text-transform: uppercase;
  font-weight: bold;
  font-size: 18px;
  line-height: 22px;
  padding-bottom: 20px;
  border-bottom: solid 4px #d2d2d2;
}
.add-offer ul {
  margin: 10px 0px 0px;
  list-style: none;
  padding: 0;
}
.add-offer ul li {
  font-size: 22px;
}
.add-offer ul li a {
  display: inline-block;
  padding: 10px 0px 10px 10px;
  width: 100%;
}
.add-offer ul li a:hover {
  background-color: #eeeeee;
}
.add-offer ul li a:hover span {
  color: #b51d28;
}
.add-offer ul li a:hover span:after {
  color: #b51d28;
}
.add-offer ul li a span {
  color: #333333;
  line-height: 30px;
}
.add-offer ul li a span:after {
  content: "\e906";
  /* FontAwesome Unicode */
  font-family: 'johanneswerk-iconfont' !important;
  color: #333333;
  display: inline-block;
  margin-left: -1.3em;
  /* same as padding-left set on li */
  width: 1.5em;
  /* same as padding-left set on li */
  float: right;
}
.add-offer ul li a span.icon-icon_leichte-sprache:after {
  display: none;
}
.add-offer ul li a span.icon-icon_leichte-sprache:before {
  color: #b51d28;
}
@media (max-width: 767px) {
  .add-offer .header {
    font-size: 16px;
    font-weight: bold;
    line-height: 19px;
  }
}
.mail-to {
  background-color: #eeeeee;
  font-size: 22px;
  padding: 17px;
}
.mail-to a {
  color: #333333;
}
.mail-to a:after {
  content: "\e906";
  /* FontAwesome Unicode */
  font-family: 'johanneswerk-iconfont' !important;
  color: #333333;
  display: inline-block;
  margin-left: -1.3em;
  /* same as padding-left set on li */
  width: 1.5em;
  /* same as padding-left set on li */
  position: absolute;
  right: 0px;
  top: auto;
}
.mail-to a span {
  color: #b51d28;
  margin-right: 10px;
}
@media (max-width: 1199px) and (min-width: 992px) {
  .mail-to a:after {
    content: "";
    /* FontAwesome Unicode */
  }
}
.certification {
  text-align: center;
}
.certification img {
  margin: 15px;
}
.certification img:first-child {
  margin: 0px 15px 15px 15px;
}
.offer-list .explanation {
  border-bottom: solid 1px #d2d2d2;
  padding-bottom: 55px;
  margin-top: -60px;
}
.offer-list .explanation .offer-num {
  margin-top: 10px;
  font-size: 18px;
  color: #999999;
  float: left;
}
.offer-list .explanation .btn-map {
  float: right;
  border: solid 2px #d2d2d2;
  height: 44px;
  border-radius: 25px;
  padding: 0px 35px;
  font-size: 18px;
  line-height: 40px;
}
.offer-list .offer-count {
  padding: 30px 0px 20px 0px;
  font-size: 18px;
  color: #999999;
  line-height: 22px;
  border-bottom: solid 1px #d2d2d2;
}
.offer-list .single-offer {
  border-bottom: solid 1px #d2d2d2;
  margin: 30px 0px 0px 0px;
  padding-bottom: 30px;
}
.offer-list .single-offer img {
  width: 100%;
  padding-right: 15px;
}
.offer-list .single-offer h3 {
  font-size: 24px;
  margin: 0;
  line-height: 28px;
}
.offer-list .single-offer .add-offer {
  color: #b51d28;
  font-size: 16px;
  font-weight: bold;
  line-height: 19px;
}
.offer-list .single-offer .adress {
  margin: 8px 0px;
  font-size: 18px;
}
.offer-list .single-offer .phone {
  font-size: 18px;
  margin-bottom: 12px;
}
.offer-list .single-offer .phone a {
  color: #333333;
}
.offer-list .single-offer .phone a:before {
  font-family: 'johanneswerk-iconfont' !important;
  color: #b51d28;
  display: inline-block;
  margin-left: 3px;
  /* same as padding-left set on li */
  width: 1.3em;
  /* same as padding-left set on li */
  content: "\e913";
  /* FontAwesome Unicode */
  position: relative;
  top: 3px;
}
.offer-list .single-offer .phone a span {
  margin-left: 5px;
}
.offer-list .single-offer .mobile a:before {
  content: "\e926";
  /* FontAwesome Unicode */
}
.offer-list .single-offer .btn-more {
  font-size: 16px;
  border-radius: 25px;
  background-color: #b51d28;
  color: #ffffff;
  padding: 5px 20px;
  display: inline-block;
}
.offer-list .single-offer .btn-more:hover {
  background-color: #cb6168;
}
.offer-list .single-offer .btn-anfrage {
  font-size: 16px;
  border-radius: 25px;
  background-color: #ffffff;
  color: #b51d28;
  padding: 5px 20px;
  display: inline-block;
}
.offer-list .single-offer .btn-anfrage:hover {
  background-color: #cb6168;
}
.offer-list .single-offer .checklist ul li {
  line-height: 30px;
  font-size: 18px;
}
@media (max-width: 991px) {
  .offer-list .single-offer .checklist {
    margin-top: 20px;
    margin-left: -30px;
  }
}
@media (max-width: 767px) {
  .checklist {
    padding: 10px 0px 0px;
  }
  .offer-list .single-offer .offer-data {
    margin-left: 0px;
  }
  .offer-list .single-offer img {
    width: 100%;
    margin-bottom: 20px;
    padding-right: 15px;
  }
  .offer-list .single-offer .checklist {
    margin-top: 0px;
    margin-left: -15px !important;
  }
  .explanation {
    font-size: 16px;
  }
}
@media (max-width: 479px) {
  .offer-list .single-offer .col-xs-6 {
    width: 100%;
  }
  .offer-list .single-offer .offer-data {
    margin-left: -15px;
  }
  .offer-list .single-offer img {
    width: 100%;
    margin-bottom: 20px;
    padding-right: 0;
  }
  .offer-list .single-offer .checklist {
    margin-top: 20px;
  }
}
.hinweis {
  border: 3px solid #D2D2D2;
  background-color: #FFFFFF;
  padding: 20px 20px 30px 20px;
}
.hinweis p {
  color: #B51D28;
  font-family: Calibri, 'PT Sans';
  font-size: 18px;
  line-height: 24px;
  margin-bottom: 0;
}
.hinweis p a {
  text-decoration: underline;
}
.hinweis p a.text-button {
  margin-top: 15px;
  font-size: 16px;
  line-height: 22px;
  padding: 8px 20px;
  height: auto;
  text-decoration: none;
}
.coffee .teaser p a {
  font-size: 18px;
}
.coffee.contact.teaser {
  background: #fff;
  margin: 0px;
  padding: 30px 0px 0px 0px;
}
.coffee.teaser.textbox {
  width: 100%;
  margin-top: 20px;
}
.coffee.teaser.textbox a {
  padding-bottom: 15px;
  display: block;
}
.coffee.teaser.textbox a:focus {
  outline: none;
  text-decoration: none;
}
.coffee.teaser.textbox p .text-button {
  display: inline-block;
  font-size: 18px;
}
.coffee.teaser.textbox .text {
  line-height: 22px;
  font-size: 18px;
  margin-bottom: 0;
  color: #333;
  padding-top: 10px;
  display: block;
}
#coffeeForm .close {
  position: absolute;
  right: -16px;
  top: -16px;
  background: #999999;
  border-radius: 50%;
  width: 32px;
  height: 32px;
  opacity: 1;
  text-shadow: none;
  color: #fff;
  font-size: 28px;
  font-weight: 400;
}
#coffeeForm .close:focus {
  outline: none;
}
#coffeeForm .h4 {
  margin-bottom: 5px;
  font-size: 18px;
  font-weight: bold;
  text-transform: uppercase;
  margin-top: 20px;
  display: block;
  color: #b51d28;
}
#coffeeForm .modal-body {
  padding: 30px;
}
#coffeeForm .modal-body .h4 {
  margin-top: 10px;
}
#coffeeForm .h3 {
  margin: 0px;
  font-weight: 500;
}
#coffeeForm p {
  padding-top: 20px;
}
#coffeeForm .btn.btn-primary {
  font-weight: bold;
  height: 42px;
  width: auto;
  border-radius: 21px;
  background-color: #B51D28;
  display: inline-block;
  text-align: center;
  margin: 15px auto 0px;
  color: #ffffff;
  line-height: 42px;
  font-size: 18px;
  padding: 0 20px;
  outline: none;
  border: 0px none;
}
.hotline,
.appointment {
  position: fixed;
  top: 256px;
  right: -200px;
  z-index: 2;
  transition: right 1s;
}
.hotline .triangle,
.appointment .triangle {
  height: 0px;
  width: 0px;
  border-top: 30px solid transparent;
  border-bottom: 30px solid transparent;
  border-right: 20px solid #b51d28;
  float: left;
}
.hotline .rectangle,
.appointment .rectangle {
  box-shadow: 0 4px 4px -2px rgba(0, 0, 0, 0.3);
  background-color: #b51d28;
  width: 145px;
  float: left;
  height: 60px;
}
.hotline .rectangle span,
.appointment .rectangle span {
  color: #ffffff;
  font-size: 17px;
  float: left;
  display: block;
  display: inline-block;
  width: 40px;
  line-height: 20px;
  text-transform: uppercase;
  padding-top: 11px;
}
.hotline .rectangle span.icon-icon_hotline,
.appointment .rectangle span.icon-icon_hotline,
.hotline .rectangle span.icon-icon_kalender,
.appointment .rectangle span.icon-icon_kalender {
  font-size: 36px;
  line-height: 56px;
  padding-top: 0px;
}
.hotline .rectangle span.icon-icon_kalender,
.appointment .rectangle span.icon-icon_kalender {
  margin-right: 10px;
}
.hotline .outline,
.appointment .outline {
  float: right;
  line-height: 60px;
  background-color: #333333;
  color: #ffffff;
  font-size: 22px;
  width: 200px;
  text-align: center;
  box-shadow: 0 4px 4px -2px rgba(0, 0, 0, 0.3);
}
.hotline .outline .text,
.appointment .outline .text {
  display: none;
}
.hotline .outline span.number a,
.appointment .outline span.number a {
  color: #fff;
  text-decoration: underline;
}
.hotline.small,
.appointment.small {
  right: 0px;
}
@media (max-width: 1199px) {
  .hotline,
  .appointment {
    top: 256px;
    right: -130px;
  }
  .hotline .triangle,
  .appointment .triangle {
    height: 0px;
    width: 0px;
    border-top: 20px solid transparent;
    border-bottom: 20px solid transparent;
    border-right: 15px solid #b51d28;
    float: left;
  }
  .hotline .rectangle,
  .appointment .rectangle {
    box-shadow: 0 4px 4px -2px rgba(0, 0, 0, 0.3);
    background-color: #b51d28;
    width: 31px;
    float: left;
    height: 40px;
  }
  .hotline .rectangle span,
  .appointment .rectangle span {
    display: none;
  }
  .hotline .rectangle span.icon-icon_hotline,
  .appointment .rectangle span.icon-icon_hotline,
  .hotline .rectangle span.icon-icon_kalender,
  .appointment .rectangle span.icon-icon_kalender {
    display: block;
    font-size: 24px;
    line-height: 37px;
    padding-top: 0px;
  }
  .hotline .outline,
  .appointment .outline {
    float: right;
    line-height: 10px;
    background-color: #333333;
    box-shadow: 0 4px 4px -2px rgba(0, 0, 0, 0.3);
    color: #ffffff;
    font-size: 24px;
    width: 130px;
    text-align: left;
    padding: 0px 0px 0px 10px;
    height: 40px;
  }
  .hotline .outline .text,
  .appointment .outline .text {
    white-space: nowrap;
    display: inline;
    line-height: 14px;
    font-size: 12px;
    font-weight: bold;
    text-transform: uppercase;
  }
  .hotline .outline .number,
  .appointment .outline .number,
  .hotline .outline a,
  .appointment .outline a,
  .hotline .outline .number a,
  .appointment .outline .number a {
    white-space: nowrap;
    font-size: 14px;
    line-height: 22px;
    font-weight: bold;
    color: #ffffff;
  }
  .appointment .outline {
    padding-left: 5px;
  }
}
@media (max-width: 991px) {
  .hotline,
  .appointment {
    top: 75px;
  }
}
.metasearch {
  display: inline-block;
  position: relative;
  top: 8px;
  padding-left: 10px;
}
.metasearch input#ke_search_sword {
  background-color: #fff;
  border: 1px solid #d2d2d2;
  border-radius: 25px;
  height: 34px;
  width: 200px;
  float: right;
  margin-right: 0;
  color: #333333;
  padding: 0 30px 0 10px;
  font-size: 16px;
  /* do not group these rules */
}
.metasearch input#ke_search_sword::-webkit-input-placeholder {
  color: #999999;
}
.metasearch input#ke_search_sword:-moz-placeholder {
  /* FF 4-18 */
  color: #999999;
}
.metasearch input#ke_search_sword::-moz-placeholder {
  /* FF 19+ */
  color: #999999;
}
.metasearch input#ke_search_sword:-ms-input-placeholder {
  /* IE 10+ */
  color: #999999;
}
.metasearch input#ke_search_searchfield_submit {
  font-family: 'johanneswerk-iconfont' !important;
  border: 0;
  color: #999999;
  position: absolute;
  right: 4px;
  background: transparent;
  top: 5px;
  font-size: 19px;
}
.search {
  position: absolute;
  right: 19px;
  bottom: 62px;
  background-color: #fff;
  font-size: 24px;
  height: 50px;
  width: 40px;
  overflow: hidden;
}
.search form {
  position: absolute;
  width: 100%;
  right: 0;
}
.search form input#ke_search_sword {
  background-color: #eeeeee;
  border: 2px solid #d2d2d2;
  border-radius: 25px;
  height: 47px;
  width: 62.5%;
  float: right;
  margin: 2px 30px 0 0;
  color: #333333;
  padding-left: 20px;
  font-size: 22px;
  top: 0;
}
.search form input#ke_search_searchfield_submit {
  border-radius: 25px;
  width: 136px;
  height: 47px;
  background-color: #b51d28;
  float: right;
  border: none;
  margin: 2px 55px 0px 0px;
  font-weight: bold;
  color: #fff;
  font-size: 22px;
  text-transform: uppercase;
}
.search form .close_search {
  float: right;
  width: 24px;
  height: 24px;
}
.search form .close_search span {
  line-height: 50px;
}
#kesearch_num_results {
  font-size: 18px;
  color: #999999 !important;
  font-weight: normal;
  float: none !important;
  width: 100% !important;
  max-width: 100% !important;
  line-height: 50px;
  border-bottom: solid 1px #d2d2d2;
}
#kesearch_results {
  margin-top: 0px !important;
}
#kesearch_results .result-list-item {
  margin: 0px !important;
}
#kesearch_results .result-list-item a {
  font-size: 22px;
}
#kesearch_results .result-list-item .result-title {
  font-size: 36px !important;
  margin: 40px 0px 10px 0px;
  display: inline-block;
}
#kesearch_results .result-list-item .result-title a {
  line-height: 44px !important;
  font-size: 36px !important;
  color: #333333 !important;
}
#kesearch_results .result-list-item .result-teaser {
  color: #333333 !important;
  font-size: 22px !important;
  margin-bottom: 10px;
  display: inline-block;
  width: 100%;
}
mark {
  color: #333333 !important;
  font-weight: bold;
  background-color: transparent;
}
#kesearch_pagebrowser_bottom .pages_total {
  margin-top: 40px;
  border-top: 1px solid #d2d2d2 !important;
  padding-top: 30px;
}
.search.fix {
  position: initial;
  height: auto;
  width: auto;
}
.search.fix form {
  position: initial;
  width: auto;
}
.search.fix form .kesearch_searchbox {
  border: none 0px transparent;
  margin: 0px 0px 20px 0px;
  padding: 0px;
}
.search.fix form .kesearch_searchbox input#ke_search_sword {
  float: left;
  position: relative;
}
.search.fix form .kesearch_searchbox input#ke_search_searchfield_submit {
  float: left;
}
.result-title .icon-icon_leichte-sprache:before {
  color: #b51d28;
}
.mobile-header {
  border-bottom: solid 1px #d2d2d2;
}
.mobile-header .mobile {
  position: relative;
}
.mobile-header .mobile .top {
  height: 50px;
}
.mobile-header .mobile .top .icon-icon-menu {
  background-color: #ffffff;
  color: #333333;
  font-size: 32px;
  line-height: 47px;
  padding: 0px 15px;
  display: inline-block;
}
.mobile-header .mobile .top .icon-icon-menu.open {
  background-color: #b51d28;
  color: #ffffff;
  font-size: 32px;
  line-height: 50px;
  padding: 0px 15px;
  display: inline-block;
}
.mobile-header .mobile .top .logo-link {
  float: right;
  display: inline-block;
  height: 50px;
  padding: 3px;
}
.mobile-header .mobile .top .logo-link img {
  height: 40px;
  margin: 2px 8px 0px 0px;
}
.mobile-header .mobile .nav-wrapper {
  display: none;
  position: absolute;
  top: 50px;
  left: 0px;
  right: 0px;
  z-index: 3;
}
.mobile-header .mobile .nav-wrapper .mobile-nav {
  list-style-type: none;
  padding: 0px;
  margin: 0;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li {
  line-height: 50px;
  background-color: #b51d28;
  position: relative;
  border-bottom: solid 1px #cb6168;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li a {
  color: #ffffff;
  font-size: 22px;
  line-height: 50px;
  display: block;
  padding: 0px 0px 0px 15px;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li span {
  color: #ffffff;
  display: inline-block;
  float: right;
  margin: 0px;
  /* same as padding-left set on li */
  width: 70px;
  /* same as padding-left set on li */
  padding: 15px 10px 0px 10px;
  text-align: center;
  position: absolute;
  top: 0px;
  right: 0px;
  height: 50px;
  font-size: 18px;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.lvl-1 {
  display: none;
  position: initial;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.lvl-1 li {
  background-color: #cb6168;
  border-bottom: solid 1px #d2d2d2;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.lvl-1 ul.lvl-2 {
  display: none;
  position: initial;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.lvl-1 ul.lvl-2 li {
  background-color: #eeeeee;
  border-bottom: solid 1px #d2d2d2;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.lvl-1 ul.lvl-2 li a {
  color: #333333;
  padding: 0px 0px 0px 30px;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.lvl-1 ul.lvl-2 li span {
  color: #333333;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.lvl-1 ul.lvl-2 li ul.lvl-3 {
  display: none;
  position: initial;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.lvl-1 ul.lvl-2 li ul.lvl-3 li {
  background-color: #eeeeee;
  border-top: solid 1px #d2d2d2;
  border-bottom: solid 0px transparent;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.lvl-1 ul.lvl-2 li ul.lvl-3 li a {
  color: #333333;
  padding: 0px 0px 0px 45px;
  font-size: 18px;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.lvl-1 ul.lvl-2 li ul.lvl-3 li ul.lvl-4 {
  display: none;
  position: initial;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.lvl-1 ul.lvl-2 li ul.lvl-3 li ul.lvl-4 li {
  background-color: #eeeeee;
  border-top: solid 1px #d2d2d2;
  border-bottom: solid 0px transparent;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.lvl-1 ul.lvl-2 li ul.lvl-3 li ul.lvl-4 li a {
  color: #333333;
  padding: 0px 0px 0px 60px;
  font-size: 18px;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.spenden-lvl-1 {
  display: none;
  position: initial;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.spenden-lvl-1 li {
  background-color: #cb6168;
  border-bottom: solid 1px #d2d2d2;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.spenden-lvl-1 ul.lvl-1 {
  display: none;
  position: initial;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.spenden-lvl-1 ul.lvl-1 li {
  background-color: #eeeeee;
  border-bottom: solid 1px #d2d2d2;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.spenden-lvl-1 ul.lvl-1 li a {
  color: #333333;
  padding: 0px 0px 0px 30px;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.spenden-lvl-1 ul.lvl-1 li span {
  color: #333333;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.spenden-lvl-1 ul.lvl-1 li ul.lvl-2 {
  display: none;
  position: initial;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.spenden-lvl-1 ul.lvl-1 li ul.lvl-2 li {
  background-color: #eeeeee;
  border-top: solid 1px #d2d2d2;
  border-bottom: solid 0px transparent;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.spenden-lvl-1 ul.lvl-1 li ul.lvl-2 li a {
  color: #333333;
  padding: 0px 0px 0px 45px;
  font-size: 18px;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.spenden-lvl-1 ul.lvl-1 li ul.lvl-2 li ul.lvl-3 {
  display: none;
  position: initial;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.spenden-lvl-1 ul.lvl-1 li ul.lvl-2 li ul.lvl-3 li {
  background-color: #eeeeee;
  border-top: solid 1px #d2d2d2;
  border-bottom: solid 0px transparent;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li ul.spenden-lvl-1 ul.lvl-1 li ul.lvl-2 li ul.lvl-3 li a {
  color: #333333;
  padding: 0px 0px 0px 60px;
  font-size: 18px;
}
.mobile-header .mobile .nav-wrapper .mobile-nav li.active > ul {
  display: block;
}
.mobile-header .mobile .nav-wrapper .meta {
  background-color: #333333;
  padding: 30px 15px 0px 15px;
}
.mobile-header .mobile .nav-wrapper .meta .search {
  background-color: transparent;
  font-size: 24px;
  height: 40px;
  width: 100%;
  overflow: inherit;
  position: relative;
  margin-bottom: 15px;
  right: auto;
  bottom: auto;
}
.mobile-header .mobile .nav-wrapper .meta .search form {
  position: inherit;
  width: auto;
  font-size: 18px;
}
.mobile-header .mobile .nav-wrapper .meta .search form .close_search {
  display: none;
}
.mobile-header .mobile .nav-wrapper .meta .search form input#ke_search_searchfield_submit {
  width: 122px;
  margin: 0;
  height: 40px;
}
.mobile-header .mobile .nav-wrapper .meta .search form input#ke_search_sword {
  background-color: #ffffff;
  width: 100%;
  float: left;
  height: 40px;
  margin-right: 10px;
}
.mobile-header .mobile .nav-wrapper .meta .assistance {
  display: block;
  float: left;
  line-height: 50px;
}
.mobile-header .mobile .nav-wrapper .meta .assistance a {
  font-size: 18px;
  color: #999999;
  margin-left: 20px;
}
.mobile-header .mobile .nav-wrapper .meta .assistance a:first-of-type {
  margin-left: 0px;
}
.mobile-header .mobile .nav-wrapper .meta .assistance .social-link {
  margin-top: 15px;
  width: 23px;
  height: 23px;
  background-color: transparent;
  color: white;
  display: inline-block;
  border-radius: var(--image-borders);
}
.mobile-header .mobile .nav-wrapper .meta .assistance .social-link-facebook {
  background: url('/typo3conf/ext/ig_project/Resources/Public/Icons/JHW-Facebook_weiss.svg') no-repeat;
  background-position: center bottom;
  background-color: #9d9d9c;
  border-radius: 8px;
  background-size: 75%;
}
.mobile-header .mobile .nav-wrapper .meta .assistance .social-link-instagram {
  background: url('/typo3conf/ext/ig_project/Resources/Public/Icons/JHW-Instagram_weiss.svg') no-repeat;
  background-color: #9d9d9c;
  border-radius: 8px;
}
.mobile-header .mobile .nav-wrapper .meta .assistance .social-link-linkedin {
  background: url('/typo3conf/ext/ig_project/Resources/Public/Icons/JHW-Linkedin_weiss.svg') no-repeat;
  background-position: center;
  background-size: 50%;
  background-color: #9d9d9c;
  border-radius: 8px;
}
.mobile-header .mobile .nav-wrapper .meta .assistance .social-link span {
  display: none;
}
.mobile-header .mobile .nav-wrapper .meta .metaeasy {
  line-height: 50px;
  float: right;
  font-size: 18px;
}
.mobile-header .mobile .nav-wrapper .meta .metaeasy .switch {
  display: inline-block;
}
.mobile-header .mobile .nav-wrapper .meta .accessible {
  line-height: 50px;
  float: right;
  font-size: 18px;
}
.mobile-header .mobile .nav-wrapper .meta .accessible a {
  margin-left: 40px;
}
.mobile-header .mobile .nav-wrapper .meta .donation {
  display: block;
  height: 50px;
  line-height: 50px;
  background-color: #ffffff;
  margin-left: -15px;
  margin-right: -15px;
  padding: 0px 15px;
  text-align: center;
}
.mobile-header .mobile .nav-wrapper .meta .donation span {
  color: #b51d28;
  text-transform: uppercase;
  font-weight: bold;
  font-size: 18px;
}
.homepage .mobile,
.navigatorpage .mobile {
  margin-bottom: 0px;
}
@media (max-width: 1200px) {
  .overlay {
    width: 100%;
    height: 100%;
    position: absolute;
    background-color: #000;
    opacity: 0.5;
    z-index: 2;
  }
}
@media (max-width: 767px) {
  .mobile .nav-wrapper .meta .metaeasy {
    display: block;
    float: none;
  }
  .mobile .nav-wrapper .meta .accessible {
    float: none;
    clear: both;
    display: inline-block;
  }
  .mobile .nav-wrapper .meta .accessible a {
    margin-left: 0px;
    margin-right: 30px;
    float: none;
  }
  .mobile .nav-wrapper .meta .assistance {
    display: block;
    float: none;
    margin-right: 30px;
  }
}
@media (max-width: 550px) {
  .mobile .nav-wrapper .meta .search form input#ke_search_sword {
    width: 90%;
  }
  .mobile .nav-wrapper .meta .search form input#ke_search_searchfield_submit {
    width: 122px;
  }
  .mobile .nav-wrapper .meta .metaeasy {
    float: none;
    clear: both;
    display: inline-block;
  }
  .mobile .nav-wrapper .meta .metaeasy a {
    margin-left: 0px;
    margin-right: 30px;
    float: right;
  }
  .mobile .nav-wrapper .meta .accessible {
    float: none;
    clear: both;
    display: inline-block;
  }
  .mobile .nav-wrapper .meta .accessible a {
    margin-left: 0px;
    margin-right: 30px;
    float: right;
  }
  .mobile .nav-wrapper .meta .assistance {
    display: block;
    float: none;
    margin-right: 30px;
  }
}
@media (max-width: 350px) {
  .mobile {
    min-width: 310px;
  }
  .mobile .nav-wrapper .meta .search form input#ke_search_sword {
    width: 100%;
    padding-left: 10px;
    font-size: 16px;
  }
  .mobile .nav-wrapper .meta .search form input#ke_search_searchfield_submit {
    padding: 0px 22px;
    width: auto !important;
    font-size: 16px;
  }
  .mobile .nav-wrapper .meta .assistance a {
    font-size: 16px;
  }
}
#kesearch_pagebrowser_bottom {
  word-wrap: initial !important;
}
#offer-pagination,
.list-news .page-navigation {
  margin-top: 30px;
}
.pagination,
.paginationjs-pages,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser,
.list-news .page-navigation {
  text-align: center;
  width: 100%;
  font-size: 18px;
  line-height: 39px;
}
.pagination p,
.paginationjs-pages p,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser p,
.list-news .page-navigation p {
  display: none;
}
.pagination ul,
.paginationjs-pages ul,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul,
.list-news .page-navigation ul {
  display: inline;
  margin: 0;
  padding: 0;
  -webkit-margin-before: 0;
  -webkit-margin-after: 0;
  -webkit-margin-start: 0;
  -webkit-margin-end: 0;
  -webkit-padding-start: 0;
}
.pagination ul li,
.paginationjs-pages ul li,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li,
.list-news .page-navigation ul li {
  list-style-type: none;
  display: inline;
  margin: 0;
}
.pagination ul li::before,
.paginationjs-pages ul li::before,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li::before,
.list-news .page-navigation ul li::before {
  content: '';
}
.pagination ul li a,
.paginationjs-pages ul li a,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li a,
.list-news .page-navigation ul li a {
  font-size: 18px;
  height: 42px;
  width: 42px;
  border-radius: 100px;
  display: inline-block;
  border: solid 2px #d2d2d2;
  margin-right: 8px;
  font-weight: bold;
  color: #333333;
  padding: 0px;
  line-height: 39px;
}
.pagination ul li a:hover,
.paginationjs-pages ul li a:hover,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li a:hover,
.list-news .page-navigation ul li a:hover {
  height: 40px;
  width: 40px;
  border-radius: 100px;
  background-color: #b51d28;
  display: inline-block;
  color: #ffffff;
  margin-right: 10px;
  font-weight: bold;
  border: none 0px transparent;
  text-decoration: none;
}
.pagination ul li.active a,
.paginationjs-pages ul li.active a,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li.active a,
.list-news .page-navigation ul li.active a,
.pagination ul li a.current,
.paginationjs-pages ul li a.current,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li a.current,
.list-news .page-navigation ul li a.current {
  height: 40px;
  width: 40px;
  border-radius: 100px;
  background-color: #b51d28;
  display: inline-block;
  color: #ffffff;
  margin-right: 10px;
  font-weight: bold;
  border: none 0px transparent;
}
.pagination ul li.J-paginationjs-previous a,
.paginationjs-pages ul li.J-paginationjs-previous a,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li.J-paginationjs-previous a,
.list-news .page-navigation ul li.J-paginationjs-previous a,
.pagination ul li a.prev,
.paginationjs-pages ul li a.prev,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li a.prev,
.list-news .page-navigation ul li a.prev {
  margin-right: 15px;
  overflow: initial;
  border: none 0px transparent;
  color: transparent;
  background: none;
  width: 25px;
  display: inline-flex;
}
.pagination ul li.J-paginationjs-previous a:hover,
.paginationjs-pages ul li.J-paginationjs-previous a:hover,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li.J-paginationjs-previous a:hover,
.list-news .page-navigation ul li.J-paginationjs-previous a:hover,
.pagination ul li a.prev:hover,
.paginationjs-pages ul li a.prev:hover,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li a.prev:hover,
.list-news .page-navigation ul li a.prev:hover {
  height: 42px;
  width: 25px;
  background-color: transparent;
  border: none 0px transparent;
  margin-right: 15px;
  color: transparent;
}
.pagination ul li.J-paginationjs-previous a:before,
.paginationjs-pages ul li.J-paginationjs-previous a:before,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li.J-paginationjs-previous a:before,
.list-news .page-navigation ul li.J-paginationjs-previous a:before,
.pagination ul li a.prev:before,
.paginationjs-pages ul li a.prev:before,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li a.prev:before,
.list-news .page-navigation ul li a.prev:before {
  color: #333333;
  font-family: 'johanneswerk-iconfont' !important;
  content: "\e905";
}
.pagination ul li.J-paginationjs-next a,
.paginationjs-pages ul li.J-paginationjs-next a,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li.J-paginationjs-next a,
.list-news .page-navigation ul li.J-paginationjs-next a,
.pagination ul li a.next,
.paginationjs-pages ul li a.next,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li a.next,
.list-news .page-navigation ul li a.next {
  margin-left: 5px;
  border: none 0px transparent;
  color: transparent;
  background: none;
  overflow: initial;
  display: inline-flex;
}
.pagination ul li.J-paginationjs-next a:hover,
.paginationjs-pages ul li.J-paginationjs-next a:hover,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li.J-paginationjs-next a:hover,
.list-news .page-navigation ul li.J-paginationjs-next a:hover,
.pagination ul li a.next:hover,
.paginationjs-pages ul li a.next:hover,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li a.next:hover,
.list-news .page-navigation ul li a.next:hover {
  height: 42px;
  width: 42px;
  background-color: transparent;
  border: none 0px transparent;
  color: transparent;
  margin-left: 5px;
  margin-right: 8px;
}
.pagination ul li.J-paginationjs-next a:before,
.paginationjs-pages ul li.J-paginationjs-next a:before,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li.J-paginationjs-next a:before,
.list-news .page-navigation ul li.J-paginationjs-next a:before,
.pagination ul li a.next:before,
.paginationjs-pages ul li a.next:before,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li a.next:before,
.list-news .page-navigation ul li a.next:before {
  content: "\e906";
  font-family: 'johanneswerk-iconfont' !important;
  color: #333333;
}
.pagination ul li.current,
.paginationjs-pages ul li.current,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li.current,
.list-news .page-navigation ul li.current {
  font-size: 18px;
  height: 40px;
  width: 40px;
  border-radius: 100px;
  background-color: #b51d28;
  display: inline-block;
  color: #ffffff;
  margin-right: 10px;
  font-weight: bold;
  border: none 0px transparent;
}
.pagination ul li.next,
.paginationjs-pages ul li.next,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li.next,
.list-news .page-navigation ul li.next {
  margin-left: 5px;
  margin-right: 8px;
  border: none 0px transparent;
  color: transparent;
  background: none;
  overflow: initial;
}
.pagination ul li.next:hover,
.paginationjs-pages ul li.next:hover,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li.next:hover,
.list-news .page-navigation ul li.next:hover {
  height: 42px;
  width: 42px;
  background-color: transparent;
  border: none 0px transparent;
  color: transparent;
  margin-left: 5px;
  margin-right: 8px;
  cursor: pointer;
}
.pagination ul li.next:before,
.paginationjs-pages ul li.next:before,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li.next:before,
.list-news .page-navigation ul li.next:before {
  content: "\e906";
  font-family: 'johanneswerk-iconfont' !important;
  color: #333333;
  left: 39px;
  z-index: -1;
}
.pagination ul li.next a,
.paginationjs-pages ul li.next a,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li.next a,
.list-news .page-navigation ul li.next a {
  height: 42px;
  width: 40px;
  color: transparent;
  background: none;
  border: none 0px transparent;
  margin-right: 8px;
}
.pagination ul li.previous,
.paginationjs-pages ul li.previous,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li.previous,
.list-news .page-navigation ul li.previous {
  margin-right: 15px;
  overflow: initial;
  border: none 0px transparent;
  color: transparent;
  background: none;
  width: 25px;
}
.pagination ul li.previous:hover,
.paginationjs-pages ul li.previous:hover,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li.previous:hover,
.list-news .page-navigation ul li.previous:hover {
  height: 42px;
  width: 25px;
  background-color: transparent;
  border: none 0px transparent;
  margin-right: 15px;
  color: transparent;
  cursor: pointer;
}
.pagination ul li.previous:before,
.paginationjs-pages ul li.previous:before,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li.previous:before,
.list-news .page-navigation ul li.previous:before {
  color: #333333;
  font-family: 'johanneswerk-iconfont' !important;
  content: "\e905";
  left: 39px;
  z-index: -1;
}
.pagination ul li.previous a,
.paginationjs-pages ul li.previous a,
#kesearch_pagebrowser_bottom .pages_total .kesearch_pagebrowser ul li.previous a,
.list-news .page-navigation ul li.previous a {
  height: 42px;
  width: 40px;
  color: transparent;
  background: none;
  border: none 0px transparent;
  margin-right: 8px;
}
.teaser a h3,
.teaser a .h3 {
  margin: 0px;
  font-weight: 500;
}
.teaser a h4,
.teaser a .h4 {
  margin-bottom: 5px;
  font-size: 18px;
  font-weight: bold;
  text-transform: uppercase;
  margin-top: 20px;
}
.teaser a:hover h3 {
  color: #b51d28;
}
.teaser.teasertext h3,
.teaser.teasertext .h3 {
  font-size: 24px;
}
.teaser.teasertext p {
  font-size: 18px;
}
.teaser .btn-teaser {
  border-radius: 17px;
  background-color: #b51d28;
  border: none;
  font-weight: bold;
  color: #fff;
  font-size: 18px;
  line-height: 22px;
  padding: 6px 30px;
  margin-top: 20px;
}
.teaser .btn-teaser:hover {
  background-color: #cb6168;
}
.teaser .teaser-image {
  max-width: 100%;
  height: auto;
}
@media (max-width: 991px) {
  .homepage-content .teaser {
    max-width: 370px;
    text-align: left;
    margin-bottom: 30px;
    margin-left: auto;
    margin-right: auto;
  }
  .homepage-content .teaser img {
    margin: 0px auto;
  }
  .homepage-content .teaser h4,
  .homepage-content .teaser .h4 {
    margin: 15px 0px 0px 0px;
    font-size: 16px;
    font-weight: bold;
    line-height: 19px;
  }
  .homepage-content .teaser h3,
  .homepage-content .teaser .h3 {
    font-size: 24px;
    line-height: 29px;
    font-weight: 500;
  }
  .homepage-content .karriere.teaser {
    max-width: inherit;
  }
}
.dachzeile,
.h4.dachzeile {
  margin-bottom: 5px;
  font-size: 18px;
  font-weight: bold;
  text-transform: uppercase;
  color: #b51d28;
  letter-spacing: 0;
  line-height: 22px;
  display: inline-block;
  margin-top: 0;
}
.dachzeile + h3,
.h4.dachzeile + h3 {
  margin: 0;
  text-align: left;
  padding-left: 0;
}
.dachzeile + h3:after,
.h4.dachzeile + h3:after {
  content: '';
  margin: 0;
  display: none;
}
@media (max-width: 991px) {
  .dachzeile,
  .h4.dachzeile,
  .homepage-content .teaser .dachzeile,
  .homepage-content .teaser .h4.dachzeile {
    margin: 0;
    font-size: 16px;
    font-weight: bold;
    line-height: 19px;
  }
}
@media (max-width: 767px) {
  .dachzeile,
  .h4.dachzeile,
  .homepage-content .teaser .dachzeile,
  .homepage-content .teaser .h4.dachzeile {
    margin-top: 15px;
  }
  .homepage-content .igcontent-textimageteaser.teaser {
    margin-bottom: 50px;
  }
}
.homepage-content .igcontent-textimageteaser.teaser {
  max-width: inherit;
}
.homepage-content .igcontent-textimageteaser.teaser .h2 {
  text-transform: none;
}
.homepage-content .igcontent-textimageteaser.teaser p {
  font-size: 20px;
}
.ig-gallery {
  padding: 0px 30px;
}
.ig-gallery .icon-icon_arrow_1_left,
.ig-gallery .icon-icon_arrow_1_right {
  position: absolute;
  top: 58px;
  font-size: 18px;
}
.ig-gallery .icon-icon_arrow_1_left {
  left: -30px;
}
.ig-gallery .icon-icon_arrow_1_right {
  right: -30px;
}
.ig-gallery .slick-slide {
  margin-right: 10px;
}
/* Slider */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}
.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0;
}
.slick-list:focus {
  outline: none;
}
.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}
.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}
.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
}
.slick-track:before,
.slick-track:after {
  content: "";
  display: table;
}
.slick-track:after {
  clear: both;
}
.slick-loading .slick-track {
  visibility: hidden;
}
.ig-gallery .ig-gallery.slick-slide {
  margin: 10px;
  float: left;
  height: auto;
  min-height: 1px;
  position: relative;
  display: none;
}
.ig-gallery .ig-gallery.slick-slide:hover::before {
  position: absolute;
  content: "\e916";
  font-family: 'johanneswerk-iconfont' !important;
  left: 0px;
  top: 0px;
  z-index: 99;
  font-size: 25px;
  color: #ffffff;
  padding: 40px 0px 0px 0px;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.3);
  text-align: center;
}
.ig-gallery .ig-gallery.slick-slide.slick-lightbox-slick-item:hover::before {
  position: relative;
  content: " ";
  font-family: 'johanneswerk-iconfont' !important;
  left: 0px;
  top: 0px;
  z-index: auto;
  font-size: inherit;
  color: inherit;
  padding: 0;
  width: auto;
  height: 100%;
  background-color: transparent;
}
[dir="rtl"] .ig-gallery .ig-gallery.slick-slide {
  float: right;
}
.ig-gallery .ig-gallery.slick-slide img {
  display: block;
}
.ig-gallery .ig-gallery.slick-slide.slick-loading img {
  display: none;
}
.ig-gallery .ig-gallery.slick-slide.dragging img {
  pointer-events: none;
}
.slick-initialized .ig-gallery .ig-gallery.slick-slide {
  display: block;
}
.slick-loading .ig-gallery .ig-gallery.slick-slide {
  visibility: hidden;
}
.slick-vertical .ig-gallery .ig-gallery.slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}
.slick-arrow.slick-hidden {
  display: none;
}
.slick-lightbox-slick-item-inner {
  position: relative;
  border: solid 40px #fff;
  background-color: #fff;
}
.slick-lightbox-slick-caption {
  display: inline-block !important;
  margin: 20px 0px 0px 0px !important;
  color: #333333 !important;
  font-size: 22px !important;
  line-height: 28px !important;
}
.slick-lightbox .slick-arrow {
  width: 40px;
  height: 50px;
  background-color: #333333;
  font-size: 36px;
  z-index: 1;
}
.slick-lightbox .slick-arrow.slick-next:before,
.slick-lightbox .slick-arrow.slick-prev:before {
  font-family: 'johanneswerk-iconfont' !important;
  content: "\e906" !important;
  margin-left: 10px;
  color: #fff;
  opacity: 1;
}
.slick-lightbox .slick-arrow.slick-next:hover,
.slick-lightbox .slick-arrow.slick-prev:hover {
  background-color: #333333;
}
.slick-lightbox .slick-arrow.slick-next:hover:before,
.slick-lightbox .slick-arrow.slick-prev:hover:before {
  color: #fff;
}
.slick-lightbox .slick-arrow.slick-next:focus,
.slick-lightbox .slick-arrow.slick-prev:focus {
  background-color: #333333;
}
.slick-lightbox .slick-arrow.slick-next:focus:before,
.slick-lightbox .slick-arrow.slick-prev:focus:before {
  color: #fff;
}
.slick-lightbox .slick-arrow.slick-prev:before {
  content: "\e905" !important;
}
.slick-lightbox .slick-lightbox-close:before {
  font-family: 'johanneswerk-iconfont' !important;
  content: "\e920" !important;
  font-size: 36px;
  color: #fff;
  opacity: 1;
}
@charset "UTF-8";
/* Slider */
.slick-loading .slick-list {
  background: #ffffff url('ajax-loader.gif') center center no-repeat;
}
/* Icons */
@font-face {
  font-family: 'slick';
  font-weight: normal;
  font-style: normal;
  src: url('fonts/slick.eot');
  src: url('fonts/slick.eot?#iefix') format('embedded-opentype'), url('fonts/slick.woff') format('woff'), url('fonts/slick.ttf') format('truetype'), url('fonts/slick.svg#slick') format('svg');
}
/* Arrows */
.slick-prev,
.slick-next {
  position: absolute;
  display: block;
  height: 20px;
  width: 20px;
  line-height: 0px;
  font-size: 0px;
  cursor: pointer;
  background: transparent;
  color: transparent;
  top: 50%;
  -webkit-transform: translate(0, -50%);
  -ms-transform: translate(0, -50%);
  transform: translate(0, -50%);
  padding: 0;
  border: none;
  outline: none;
}
.slick-prev:hover,
.slick-next:hover,
.slick-prev:focus,
.slick-next:focus {
  outline: none;
  background: transparent;
  color: transparent;
}
.slick-prev:hover:before,
.slick-next:hover:before,
.slick-prev:focus:before,
.slick-next:focus:before {
  opacity: 1;
}
.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before {
  opacity: 0.25;
}
.slick-prev:before,
.slick-next:before {
  font-family: "slick";
  font-size: 20px;
  line-height: 1;
  color: #ffffff;
  opacity: 0.75;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.slick-prev {
  left: -25px;
}
.slick-prev[dir="rtl"] {
  left: auto;
  right: -25px;
}
.slick-prev:before {
  content: "<";
}
.slick-prev:before[dir="rtl"] {
  content: ">";
}
.slick-next {
  right: -25px;
}
.slick-next[dir="rtl"] {
  left: -25px;
  right: auto;
}
.slick-next:before {
  content: ">";
}
.slick-next:before[dir="rtl"] {
  content: "<";
}
/* Dots */
.slick-dotted .slick-slider {
  margin-bottom: 30px;
}
.slick-dots {
  position: absolute;
  bottom: -25px;
  list-style: none;
  display: block;
  text-align: center;
  padding: 0;
  margin: 0;
  width: 100%;
}
.slick-dots li {
  position: relative;
  display: inline-block;
  height: 20px;
  width: 20px;
  margin: 0 5px;
  padding: 0;
  cursor: pointer;
}
.slick-dots li button {
  border: 0;
  background: transparent;
  display: block;
  height: 20px;
  width: 20px;
  outline: none;
  line-height: 0px;
  font-size: 0px;
  color: transparent;
  padding: 5px;
  cursor: pointer;
}
.slick-dots li button:hover,
.slick-dots li button:focus {
  outline: none;
}
.slick-dots li button:hover:before,
.slick-dots li button:focus:before {
  opacity: 1;
}
.slick-dots li button:before {
  position: absolute;
  top: 0;
  left: 0;
  content: "•";
  width: 20px;
  height: 20px;
  font-family: "slick";
  font-size: 6px;
  line-height: 20px;
  text-align: center;
  color: #000000;
  opacity: 0.25;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.slick-dots li.slick-active button:before {
  color: #000000;
  opacity: 0.75;
}
.img-wrap {
  margin: 0 auto;
  max-width: 1400px;
  position: relative;
  /* Firefox */
  /* Safari and Chrome */
  /* Internet Explorer */
  /* Opera */
}
.img-wrap .gradient {
  display: inline-block;
  background: -moz-linear-gradient(top, rgba(255, 255, 255, 0) 50%, rgba(0, 0, 0, 0.5) 100%);
  background: -webkit-linear-gradient(top, rgba(255, 255, 255, 0) 50%, rgba(0, 0, 0, 0.5) 100%);
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 50%, rgba(0, 0, 0, 0.5) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#00ffffff', endColorstr='#80000000', GradientType=0);
  height: 50%;
  position: absolute;
  bottom: 0px;
  left: 0px;
  right: 0px;
  max-width: 100%;
  -webkit-animation: fadein 8s;
  /* Safari and Chrome */
  -moz-animation: fadein 8s;
  /* Firefox */
  -ms-animation: fadein 8s;
  /* Internet Explorer */
  -o-animation: fadein 8s;
  /* Opera */
  animation: fadein 8s;
}
.img-wrap .header-img {
  margin: 0 auto;
  max-width: 1400px;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center top;
  height: 600px;
  -webkit-animation: fadein 4s;
  /* Safari and Chrome */
  -moz-animation: fadein 4s;
  /* Firefox */
  -ms-animation: fadein 4s;
  /* Internet Explorer */
  -o-animation: fadein 4s;
  /* Opera */
  animation: fadein 4s;
}
@keyframes fadein {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@-moz-keyframes fadein {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@-webkit-keyframes fadein {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@-ms-keyframes fadein {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@-o-keyframes fadein {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.calculator {
  margin-top: -140px;
  position: relative;
  z-index: 1;
}
.calculator.c3po {
  margin-top: 0px;
  margin-bottom: 0px;
}
.calculator.c3po .tile-col {
  margin-bottom: 100px;
}
.calculator .custom-pin {
  background-color: blue;
}
.calculator .offer {
  line-height: 1.5em;
  text-align: center;
  color: #ffffff;
  font-size: 48px;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
  text-transform: uppercase;
  font-weight: bold;
}
.calculator .tile-col {
  margin-left: 15px;
  margin-right: 15px;
}
.calculator .tile-col .background {
  display: table;
  height: 230px;
  background-color: #ffffff;
}
.calculator .tile-col .tile-wrapper {
  padding: 0px 0px 0px 2px;
  cursor: pointer;
}
.calculator .tile-col .tile-wrapper:hover .tile {
  text-decoration: none;
  background-color: #ffffff;
  border-left: 1px solid #d2d2d2;
  border-right: 1px solid #d2d2d2;
  border-bottom: 1px solid #d2d2d2;
  border-top: 4px solid #b51d28;
  padding-top: 21px;
  height: 230px;
}
.calculator .tile-col .tile-wrapper:hover .tile .text {
  text-decoration: none;
  color: #b51d28;
}
.calculator .tile-col .tile-wrapper .tile {
  background-color: #eeeeee;
  height: 230px;
  text-align: center;
  display: block;
  padding: 25px 24px;
  position: relative;
}
.calculator .tile-col .tile-wrapper .tile.active {
  text-decoration: none;
  background-color: #ffffff;
  border-left: 1px solid #d2d2d2;
  border-right: 1px solid #d2d2d2;
  border-bottom: 0px solid transparent;
  border-top: 4px solid #b51d28;
  padding-top: 21px;
  height: 231px;
  position: relative;
  z-index: 2;
}
.calculator .tile-col .tile-wrapper .tile.active .text {
  text-decoration: none;
  color: #b51d28;
}
.calculator .tile-col .tile-wrapper .tile.inactive .text {
  text-decoration: none;
  color: #666666;
}
.calculator .tile-col .tile-wrapper .tile.inactive .icon {
  color: #666666;
}
.calculator .tile-col .tile-wrapper .tile.inactive .icon:before {
  color: #666666;
}
.calculator .tile-col .tile-wrapper .tile.inactive:hover .text {
  text-decoration: none;
  color: #b51d28;
}
.calculator .tile-col .tile-wrapper .tile.inactive:hover .icon {
  color: #b51d28;
}
.calculator .tile-col .tile-wrapper .tile.inactive:hover .icon:before {
  color: #b51d28;
}
.calculator .tile-col .tile-wrapper .tile .icon {
  font-size: 65px;
  display: block;
  color: #b51d28;
  line-height: 115px;
  pointer-events: none;
}
.calculator .tile-col .tile-wrapper .tile .text {
  font-size: 22px;
  color: #333333;
  pointer-events: none;
}
.calculator .tile-col .first {
  padding: 0px 0px 0px 0px;
}
.calculator .tile-col .filterWrap {
  display: none;
  text-align: left;
  background-color: #ffffff;
  z-index: 0;
}
.calculator .tile-col .filterWrap.active {
  display: block;
}
.calculator .tile-col .filterWrap .filterList {
  padding: 40px 0px 0px 0px;
  border: 1px solid #d2d2d2;
  top: -1px;
  position: relative;
}
.calculator .tile-col .filterWrap .filterList form {
  display: none;
  margin: 0px;
}
.calculator .tile-col .filterWrap .filterList form.active {
  display: block;
  margin-bottom: 30px;
}
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap {
  margin-bottom: 30px;
}
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap label {
  font-weight: normal;
}
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap .wrapper {
  padding-left: 35px;
  padding-right: 35px;
}
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap .wrapper .iradio_square-blue {
  margin: -2px 10px 0px 0px;
}
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap .wrapper .cat-wrapper {
  line-height: 40px;
  margin-left: -15px;
  padding-left: 15px;
  margin-right: -50px;
}
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap .wrapper .cat-wrapper.active {
  background-color: #eeeeee;
}
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap .wrapper .location,
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap .wrapper .navigator_text_search {
  background-color: transparent;
  margin-bottom: 20px;
  /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#eeeeee+0,eeeeee+50,cccccc+55,eeeeee+60,eeeeee+100 */
  background: #eeeeee;
  /* Old browsers */
  background: -moz-linear-gradient(to left, #eeeeee 0%, #eeeeee 50%, #cccccc 55%, #eeeeee 60%, #eeeeee 100%);
  /* FF3.6-15 */
  background: -webkit-linear-gradient(to left, #eeeeee 0%, #eeeeee 50%, #cccccc 55%, #eeeeee 60%, #eeeeee 100%);
  /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to left, #eeeeee 0%, #eeeeee 50%, #cccccc 55%, #eeeeee 60%, #eeeeee 100%);
  /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  background-size: 240% 100%;
  background-position: right bottom;
}
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap .wrapper .location.loading,
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap .wrapper .navigator_text_search.loading {
  background-position: left bottom;
  transition: all 1s ease;
}
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap .wrapper .reset-filter {
  margin-top: 20px;
  text-align: right;
  text-decoration: underline;
  cursor: pointer;
  font-size: 18px;
}
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap .sub-cat {
  background-color: #eeeeee;
}
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap .sub-cat.hidden {
  display: none;
}
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap .sub-cat .wrapper {
  padding-left: 15px;
  padding-right: 15px;
}
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap .sub-cat .wrapper .icheckbox_square-blue {
  background-position: -120px 0;
}
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap .sub-cat .wrapper .icheckbox_square-blue-blue.hover {
  background-position: -144px 0;
}
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap .sub-cat .wrapper .icheckbox_square-blue.checked {
  background-position: -168px 0;
}
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap .sub-cat .wrapper .icheckbox_square-blue.disabled {
  background-position: -192px 0;
  cursor: default;
}
.calculator .tile-col .filterWrap .filterList form .powermail_fieldwrap .sub-cat .wrapper .icheckbox_square-blue.checked.disabled {
  background-position: -216px 0;
}
#gmap {
  height: 570px;
  width: 100%;
  position: relative !important;
}
.hits {
  position: relative;
  /* The Overlay (background) */
  /* Position the content inside the overlay */
}
.hits .no-results {
  padding: 40px 0px;
  font-size: 18px;
  color: #999999;
  line-height: 22px;
  border-bottom: solid 1px #d2d2d2;
}
.hits .no-result-map {
  width: 100%;
  height: 100%;
  background-color: rgba(1, 1, 1, 0.5);
  position: absolute;
}
.hits .no-result-map .no-result-msg {
  width: 50%;
  height: auto;
  background: #ffffff;
  margin: 100px auto;
  padding: 20px;
  font-size: 18px;
  color: #333333;
  line-height: 22px;
  border-bottom: solid 1px #d2d2d2;
  text-align: center;
}
.hits .switch-view {
  position: absolute;
  right: 15px;
  top: 15px;
  border-radius: 25px;
  background-color: #FFFFFF;
  font-weight: bold;
  line-height: 22px;
  text-align: center;
  font-size: 18px;
  box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.3);
  height: 42px;
  padding: 8px 20px;
  z-index: 1;
  cursor: pointer;
}
.hits.list-view .switch-view {
  box-shadow: none;
  border: 2px solid #D2D2D2;
}
.hits.list-view .switch-view:before {
  font-family: 'johanneswerk-iconfont' !important;
  content: "\e910";
  color: #b51d28;
}
.hits.list-view .switch-view:after {
  margin-left: 10px;
  color: #333333;
  content: "Karte";
  position: relative;
  top: -2px;
}
.hits.list-view .switch-view:hover {
  border: 2px solid #b51d28;
  background-color: #b51d28;
  color: #ffffff;
}
.hits.list-view .switch-view:hover:before {
  color: #ffffff;
}
.hits.list-view .switch-view:hover:after {
  color: #ffffff;
}
.hits.list-view #gmap {
  display: none;
}
.hits .overlay {
  /* Height & width depends on how you want to reveal the overlay (see JS below) */
  height: 100%;
  width: 100%;
  display: none;
  position: fixed;
  /* Stay in place */
  z-index: 2;
  /* Sit on top */
  left: 0;
  top: 0;
  opacity: 1;
  background-color: #eeeeee;
  /* Black fallback color */
  background-color: rgba(238, 238, 238, 0.6);
  /* Black w/opacity */
  overflow-x: hidden;
  /* Disable horizontal scroll */
  transition: 0.5s;
  /* 0.5 second transition effect to slide in or slide down the overlay (height or width, depending on reveal) */
}
.hits .overlay-content {
  position: relative;
  top: 25%;
  /* 25% from the top */
  width: 100%;
  /* 100% width */
  text-align: center;
  /* Centered text/links */
  margin-top: 30px;
  /* 30px top margin to avoid conflict with the close button on smaller screens */
}
.hits.map-view .switch-view:before {
  font-family: 'johanneswerk-iconfont' !important;
  content: "\e90c";
  color: #b51d28;
}
.hits.map-view .switch-view:after {
  margin-left: 10px;
  color: #333333;
  content: "Listenansicht";
  position: relative;
  top: -2px;
}
.hits.map-view .switch-view:hover {
  background-color: #b51d28;
  color: #ffffff;
}
.hits.map-view .switch-view:hover:before {
  color: #ffffff;
}
.hits.map-view .switch-view:hover:after {
  color: #ffffff;
}
.hits.map-view .list {
  display: none;
}
.navigatorpage .offer {
  display: none;
}
.navigatorpage .calculator .container {
  margin-top: 0px;
}
@media (max-width: 1400px) {
  .img-wrap .header-img {
    height: 540px;
  }
}
@media (max-width: 1199px) {
  .img-wrap .header-img {
    height: 500px;
  }
  .calculator .container {
    margin-top: -140px;
  }
  .calculator .container .row .tile-col .tile-wrapper .tile {
    height: 200px;
  }
  .calculator .container .row .tile-col .tile-wrapper .tile .icon {
    font-size: 54px;
    line-height: 90px;
  }
  .calculator .container .row .tile-col .tile-wrapper .tile .text {
    font-size: 19px;
  }
}
@media (max-width: 991px) {
  .homepage .container {
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
  .img-wrap .header-img {
    height: 420px;
  }
  .calculator {
    margin-top: -100px;
  }
  .calculator.c3po .tile-col {
    margin-bottom: 30px;
  }
  .calculator .offer {
    font-size: 36px;
  }
  .calculator .tile-col .background {
    height: 185px;
  }
  .calculator .tile-col .background .tile-wrapper .tile {
    height: 185px;
    padding: 15px;
  }
  .calculator .tile-col .background .tile-wrapper .tile:hover {
    padding-top: 11px;
  }
  .calculator .tile-col .background .tile-wrapper .tile .icon {
    font-size: 54px;
    line-height: 75px;
  }
  .calculator .tile-col .background .tile-wrapper .tile .text {
    font-size: 19px;
  }
  .cat {
    padding: 0px;
  }
  .cat .wrapper {
    margin: 0px 20px 20px 0px;
    padding-left: 0px !important;
    padding-right: 30px !important;
  }
  .cat .wrapper .cat-wrapper {
    padding: 0px 0px 0px 30px !important;
    margin-left: 0px !important;
  }
  .sub-cat {
    margin-bottom: 30px;
  }
  .sub-cat .wrapper {
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
  .filter-search .wrapper {
    padding: 0px 20px 0px 20px !important;
  }
}
@media (max-width: 767px) {
  .img-wrap .header-img {
    height: 350px;
  }
  .calculator {
    margin-top: -80px;
    margin-bottom: 100px !important;
  }
  .calculator.c3po .tile-col {
    margin-bottom: 30px;
  }
  .calculator .offer {
    font-size: 30px;
  }
  .calculator .tile-col .background {
    background-color: transparent;
  }
  .calculator .tile-col .background .tile-wrapper {
    padding: 0px;
  }
  .calculator .tile-col .background .tile-wrapper .tile {
    display: table;
    height: 75px;
    padding: 11px;
    margin: 0px 0px 1px 0px;
    width: auto;
  }
  .calculator .tile-col .background .tile-wrapper .tile .icon {
    font-size: 54px;
    line-height: 75px;
    display: inline;
    padding-left: 15px;
    padding-right: 30px;
  }
  .calculator .tile-col .background .tile-wrapper .tile .text {
    font-size: 22px;
    display: table-cell;
    vertical-align: middle;
    text-align: left;
    width: 100%;
    padding-left: 15px;
  }
  .calculator .tile-col .background .tile-wrapper .tile:hover {
    padding: 11px;
  }
  .calculator .tile-col .filterList {
    padding: 0px 0px 0px 0px !important;
  }
  .calculator .tile-col .filterList .cat,
  .calculator .tile-col .filterList .sub-cat,
  .calculator .tile-col .filterList .filter-search {
    margin-top: 20px;
  }
  .calculator .tile-col .filterList form.active {
    margin-bottom: 0px !important;
  }
  .calculator .switch-view {
    display: none;
  }
  .calculator #gmap {
    display: none;
  }
  .calculator .list {
    display: block !important;
  }
}
@media (max-width: 480px) {
  .img-wrap .header-img {
    height: 200px;
  }
  .calculator {
    margin-top: -55px;
    margin-bottom: 90px !important;
  }
  .calculator .offer {
    font-size: 30px;
  }
  .calculator .tile-col .background {
    background-color: transparent;
  }
  .calculator .tile-col .background .tile-wrapper .tile.active:hover {
    border-top: 4px solid #b51d28;
    border-left: 1px solid #d2d2d2;
    border-right: 1px solid #d2d2d2;
    background-color: #ffffff;
  }
  .calculator .tile-col .background .tile-wrapper .tile.active:hover .text {
    color: #b51d28;
  }
  .calculator .tile-col .background .tile-wrapper:hover .tile {
    border: 0px solid transparent;
    background-color: #eeeeee;
  }
  .calculator .tile-col .background .tile-wrapper:hover .tile .text {
    color: #333333;
  }
  .calculator .tile-col .background .tile-wrapper .tile {
    display: table;
    height: 80px;
    padding: 0px;
    margin: 0px 0px 1px 0px;
    text-align: left;
  }
  .calculator .tile-col .background .tile-wrapper .tile .icon {
    font-size: 42px;
    line-height: 80px;
    display: inline;
    padding-left: 15px;
    padding-right: 0px;
  }
  .calculator .tile-col .background .tile-wrapper .tile .text {
    display: table-cell;
    font-size: 22px;
    vertical-align: middle;
    text-align: left;
    width: 100%;
    padding-left: 15px;
  }
  .calculator .tile-col .background .tile-wrapper .tile:hover {
    text-decoration: none;
    background-color: #eeeeee;
    border: 0px solid transparent;
    border-top: 0px solid transparent;
    padding: 0px;
    box-sizing: content-box;
  }
  .calculator .tile-col .background .tile-wrapper .tile:hover .text {
    color: #333333;
  }
}
#c3326 .filterList .cat-wrapper[data-cat="31"],
#c3326 .filterList .wrapper .location,
#c3326 .filterList .wrapper .range,
#c3326 .filterList .wrapper .chosen-container,
#c3428 .filterList .cat-wrapper[data-cat="31"],
#c3428 .filterList .wrapper .location,
#c3428 .filterList .wrapper .range,
#c3428 .filterList .wrapper .chosen-container {
  display: none;
}
.gm-style .offer-info img {
  max-width: 100% !important;
}
.gm-style-iw {
  max-height: 500px;
  width: 600px !important;
  top: -2px !important;
  background-color: #ffffff;
  box-shadow: 0 5px 15px 0 rgba(0, 0, 0, 0.5);
}
@media (max-width: 767px) {
  .gm-style-iw {
    width: 300px !important;
    padding: 0 !important;
  }
  .gm-style-iw .gm-style-iw-d {
    overflow: auto !important;
  }
}
.gm-style-iw > div:first-child {
  max-height: 399px !important;
}
.gm-style-iw .offer-details {
  display: table;
  font-family: Calibri, 'PT Sans';
  width: 600px;
  height: auto;
  background-color: #ffffff;
}
@media (max-width: 767px) {
  .gm-style-iw .offer-details {
    width: 100%;
  }
}
.gm-style-iw .offer-details .offer-info {
  float: left;
  width: 50%;
}
.gm-style-iw .offer-details .offer-info .header {
  font-size: 24px;
  color: #333333;
  margin: 20px 20px 0px;
}
.gm-style-iw .offer-details .offer-info .sub-header {
  font-size: 16px;
  color: #b51d28;
  margin: 0px 20px 10px;
}
.gm-style-iw .offer-details .offer-info .adress {
  font-size: 18px;
  color: #333333;
  line-height: 24px;
  margin: 0px 20px 12px 20px;
}
.gm-style-iw .offer-details .offer-info .phone {
  font-size: 18px;
  margin: 0px 20px 12px 20px;
  color: #333333;
}
.gm-style-iw .offer-details .offer-info .phone:before {
  font-family: 'johanneswerk-iconfont' !important;
  color: #b51d28;
  display: inline-block;
  margin-left: 3px;
  /* same as padding-left set on li */
  width: 1.3em;
  /* same as padding-left set on li */
  content: "\e913";
  /* FontAwesome Unicode */
}
.gm-style-iw .offer-details .offer-info a {
  display: block;
  border-radius: 25px;
  height: 29px;
  width: 138px;
  background-color: #b51d28;
  color: #ffffff;
  font-size: 16px;
  line-height: 29px;
  text-align: center;
  margin: 0px 20px 20px;
}
.gm-style-iw .offer-details .offer-info a:hover {
  background-color: #cb6168;
}
@media (max-width: 767px) {
  .gm-style-iw .offer-details .offer-info {
    width: 100%;
  }
  .gm-style-iw .offer-details .offer-info .header,
  .gm-style-iw .offer-details .offer-info .sub-header,
  .gm-style-iw .offer-details .offer-info .adress,
  .gm-style-iw .offer-details .offer-info .phone,
  .gm-style-iw .offer-details .offer-info a {
    margin-left: 10px;
    margin-right: 10px;
    -webkit-hyphens: auto;
    -webkit-hyphenate-limit-chars: auto 3;
    -webkit-hyphenate-limit-lines: 4;
    -ms-hyphens: auto;
    -ms-hyphenate-limit-chars: auto 3;
    -ms-hyphenate-limit-lines: 4;
  }
}
.gm-style-iw .offer-details .checklist {
  float: left;
  width: 50%;
  background-color: #b51d28;
  color: #ffffff;
  height: 100%;
}
@media (max-width: 767px) {
  .gm-style-iw .offer-details .checklist {
    display: none;
  }
}
.gm-style-iw .offer-details .checklist .fact-header {
  font-weight: bold;
  font-size: 16px;
  text-transform: uppercase;
  margin: 30px 20px 15px 20px;
}
.gm-style-iw .offer-details .checklist ul li {
  font-size: 18px;
  line-height: 22px;
  margin-bottom: 20px;
}
.gm-style-iw .offer-details .checklist ul li:before {
  color: #ffffff;
  top: 0px;
  line-height: 20px;
}
.gm-style-iw .offer-details .cluster-info .headline {
  background-color: #b51d28;
  font-size: 24px;
  color: #ffffff;
  padding: 15px 20px;
}
.gm-style-iw .offer-details .cluster-info .offerlist {
  padding: 0px 15px 15px 15px;
}
.gm-style-iw .offer-details .cluster-info .offerlist .single-offer {
  margin: 8px 0px 0px 0px;
  width: 100%;
  min-height: 50px;
  display: table;
}
.gm-style-iw .offer-details .cluster-info .offerlist .single-offer .offer-head {
  float: left;
}
.gm-style-iw .offer-details .cluster-info .offerlist .single-offer .offer-head .header {
  font-size: 24px;
  color: #333333;
  word-wrap: break-word;
  overflow-wrap: break-word;
  -webkit-hyphens: auto;
  -moz-hyphens: auto;
  hyphens: auto;
}
.gm-style-iw .offer-details .cluster-info .offerlist .single-offer .offer-head .sub-header {
  font-size: 16px;
  color: #b51d28;
}
.gm-style-iw .offer-details .cluster-info .offerlist .single-offer a {
  float: right;
  display: block;
  border-radius: 25px;
  height: 29px;
  width: 138px;
  background-color: #b51d28;
  color: #ffffff;
  font-size: 16px;
  line-height: 29px;
  text-align: center;
  margin: 10px 20px 10px;
}
@media (max-width: 767px) {
  .gm-style-iw .offer-details .cluster-info .offerlist .single-offer a {
    float: left;
  }
}
.gm-style-iw .offer-details .cluster-info .offerlist .single-offer a:hover {
  background-color: #cb6168;
}
.coronaHint {
  background-color: #b51d28;
  color: #fff;
  margin-top: -30px;
  margin-bottom: 30px;
  font-size: 18px;
  font-style: italic;
  padding: 15px;
}
.coronaHint p {
  font-size: 18px;
  line-height: 26px;
  color: #fff;
}
.coronaHint p a,
.coronaHint a {
  color: #fff;
  font-weight: bold;
}
.coronaHint p a:hover,
.coronaHint a:hover {
  color: #fff;
  font-weight: bold;
  text-decoration: underline;
}
a.don-button {
  font-weight: bold;
  height: 47px;
  width: 202px;
  border-radius: 25px;
  background-color: #B51D28;
  display: block;
  text-align: center;
  margin: 0 auto;
  color: #ffffff;
  line-height: 47px;
  font-size: 22px;
  text-transform: uppercase;
  box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
}
a.don-button:hover {
  background-color: #cb6168;
  color: #fff;
}
a.text-button {
  font-weight: bold;
  height: 42px;
  width: auto;
  border-radius: 21px;
  background-color: #B51D28;
  display: inline-block;
  text-align: center;
  margin: 0 auto;
  color: #ffffff;
  line-height: 42px;
  font-size: 22px;
  padding: 0 20px;
}
a.text-button:hover {
  background-color: #cb6168;
  color: #fff;
}
.donation-element {
  width: 100%;
  height: 380px;
  background-size: cover;
}
.donation-element h2,
.donation-element h3 {
  color: #ffffff;
  font-size: 48px;
  font-weight: bold;
  line-height: 59px;
  text-align: center;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
}
.donation-element h2:after,
.donation-element h3:after {
  display: none;
  content: "";
  background: transparent;
  position: inherit;
  height: auto;
  margin-left: auto;
  width: auto;
}
.donation-element h2 {
  margin-top: 70px;
  margin-bottom: 20px;
  padding: 0;
}
.donation-element h3 {
  font-size: 30px;
  margin-bottom: 50px;
  line-height: 37px;
  font-weight: normal;
}
.donation-element a.don-button {
  font-weight: bold;
  height: 47px;
  width: 202px;
  border-radius: 25px;
  background-color: #B51D28;
  display: block;
  text-align: center;
  margin: 0 auto;
  color: #ffffff;
  line-height: 47px;
  font-size: 22px;
  text-transform: uppercase;
  box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
}
.donation-element a.don-button:hover {
  background-color: #cb6168;
}
@media (max-width: 767px) {
  .donation-element h2 {
    font-size: 36px;
    line-height: 40px;
    margin-top: 60px;
  }
  .donation-element h3 {
    font-size: 30px;
  }
  .donation-element a.don-button {
    height: 37px;
    line-height: 37px;
    font-size: 18px;
  }
}
@media (max-width: 480px) {
  .donation-element h2 {
    font-size: 36px;
    line-height: 40px;
    margin-top: 60px;
  }
  .donation-element h3 {
    font-size: 30px;
  }
}
.ce-textpic.ce-center audio {
  width: 100%;
}
.ce-textpic.ce-center .ce-inner {
  width: 100%;
}
.ce-textpic.ce-center .ce-column {
  width: 100%;
}
.ce-textpic.ce-center .ce-gallery {
  width: 100%;
}
.ce-textpic.ce-center .ce-gallery .ce-outer {
  position: inherit;
  float: none;
  right: 100%;
  width: 100%;
}
.ce-textpic.ce-center .ce-gallery .ce-outer .ce-inner {
  float: left;
  left: 0;
}
.ce-textpic.ce-center img {
  width: 100%;
  height: auto;
}
.ce-textpic.ce-center figure.video {
  position: relative;
  height: 0;
  padding-bottom: 56.25%;
  display: block;
}
.ce-textpic.ce-center figure.video iframe {
  position: absolute;
  width: 100%;
  height: 100%;
  left: 0;
}
@media (max-width: 767px) {
  .ce-textpic.ce-center figure.video {
    min-height: 300px;
  }
  .ce-textpic.ce-center figure.video div.cc-blocked {
    padding: 20px 10px;
  }
}
.ce-textpic.ce-right .ce-gallery {
  float: right;
  width: 50%;
  margin-right: 0;
  margin-left: 30px;
}
.ce-textpic.ce-right .ce-gallery img {
  width: 100%;
  height: auto;
}
.ce-textpic.ce-left .ce-gallery {
  float: left;
  width: 50%;
}
.ce-textpic.ce-left .ce-gallery img {
  width: 100%;
  height: auto;
}
.ce-textpic .ce-border img,
.ce-textpic .ce-border iframe {
  border: 1px solid #cccccc;
}
@media (max-width: 767px) {
  .ce-textpic.ce-right .ce-gallery {
    margin-left: 0px;
    float: none;
    width: 100%;
  }
  .ce-textpic.ce-right .ce-gallery img {
    width: 100%;
    height: auto;
  }
  .ce-textpic.ce-left .ce-gallery {
    float: none;
    width: 100%;
  }
  .ce-textpic.ce-left .ce-gallery img {
    width: 100%;
    height: auto;
  }
}
.header_wrap,
.mobile-header {
  position: fixed;
  width: 100%;
  z-index: 999;
}
.header_wrap {
  top: 0;
  background: #fff;
  z-index: 999;
}
/*Erzeugt Linie auf Desktop*/
.content_after_sticky,
.content_after_sticky_offer {
  margin-top: 50px;
}
.homepage-header {
  border-top: solid 1px #d2d2d2;
}
@media (max-width: 1199px) {
  .mobile-header {
    top: 0;
    background-color: #ffffff;
  }
}
@media (min-width: 1200px) {
  .content_after_sticky,
  .homepage-header .main-nav .navigation li {
    webkit-transition: margin-top 1000ms ease-out;
    -o-transition: margin-top 1000ms ease-out;
    transition: margin-top 1000ms ease-out;
  }
  .homepage-header .main-nav .navigation li a {
    webkit-transition: line-height 1000ms ease-out, font-size 1000ms ease-out, padding-bottom 1000ms ease-out;
    -o-transition: line-height 1000ms ease-out, font-size 1000ms ease-out, padding-bottom 1000ms ease-out;
    transition: line-height 1000ms ease-out, font-size 1000ms ease-out, padding-bottom 1000ms ease-out;
  }
  .logo,
  .homepage-header .search-icon,
  .homepage-header {
    webkit-transition: all 1000ms ease-out;
    -o-transition: all 1000ms ease-out;
    transition: all 1000ms ease-out;
  }
  .meta-nav a span {
    line-height: 48px;
  }
  .meta-nav a span.icon-icon_arrow_1_left {
    line-height: 47px;
  }
  .content_after_sticky {
    margin-top: 228px;
  }
  .content_after_sticky_offer {
    margin-top: 53px;
  }
  .offerpage .meta-nav {
    height: 51px;
    border-bottom: solid 1px #d2d2d2;
  }
  .mobile-header {
    display: none;
  }
  .homepage-header {
    border-bottom: solid 1px #d2d2d2;
  }
  .homepage-header .nav-wrapper {
    height: 174px;
  }
  .homepage-header .main-nav .navigation li a {
    padding-bottom: 14px;
  }
  body.before-transform-to-sticky .homepage-header,
  body.transform-to-sticky .homepage-header {
    max-height: 59px;
  }
  body.before-transform-to-sticky .homepage-header .nav-wrapper,
  body.transform-to-sticky .homepage-header .nav-wrapper {
    max-height: 57px;
  }
  body.before-transform-to-sticky .search,
  body.transform-to-sticky .search {
    bottom: 3px;
  }
  body.before-transform-to-sticky .logo,
  body.transform-to-sticky .logo {
    width: 112px;
    height: auto;
    margin-top: 10px;
  }
  body.before-transform-to-sticky .offerpage .logo,
  body.transform-to-sticky .offerpage .logo {
    width: 300px;
    margin-top: 45px;
  }
  body.before-transform-to-sticky .homepage-header .main-nav .navigation li,
  body.transform-to-sticky .homepage-header .main-nav .navigation li {
    margin: 15px 20px 25px 20px;
  }
  body.before-transform-to-sticky .homepage-header .main-nav .navigation li a,
  body.transform-to-sticky .homepage-header .main-nav .navigation li a {
    line-height: 29px;
    font-size: 24px;
    padding-bottom: 10px;
  }
  body.before-transform-to-sticky .homepage-header .search-icon,
  body.transform-to-sticky .homepage-header .search-icon {
    line-height: 29px;
    font-size: 24px;
    padding-top: 13px;
    padding-bottom: 8px;
  }
  body.before-transform-to-sticky .content_after_sticky,
  body.transform-to-sticky .content_after_sticky {
    margin-top: 110px;
  }
}
.uc-embedding-container .uc-embedding-wrapper {
  background: #eee;
  box-shadow: 0px none;
  border-radius: 0;
}
.uc-embedding-container .uc-embedding-wrapper > span {
  font-size: 10px;
}
.uc-embedding-container .uc-embedding-wrapper p {
  font-size: 12px;
  line-height: 1.2;
}
.uc-embedding-container .uc-embedding-wrapper h3 {
  font-size: 17px;
}
.uc-embedding-container .uc-embedding-buttons .uc-embedding-accept {
  background-color: #b51d28;
}
.uc-embedding-container .uc-embedding-powered-by {
  font-size: 10px;
}
.video-embed .uc-embedding-container {
  background: #eee;
}
.video-embed .uc-embedding-container img {
  opacity: 0;
}
.video-embed .uc-embedding-container .uc-embedding-wrapper {
  background: #eee;
  box-shadow: 0px 0px 0px 0px;
}
.video-embed .uc-embedding-container .uc-embedding-wrapper .uc-embedding-more-info {
  background-color: #fff;
}
html {
  margin: 0;
  padding: 0;
  height: 100%;
  font-family: Calibri, 'PT Sans';
}
body {
  margin: 0;
  padding: 0;
  height: 100%;
  font-family: Calibri, 'PT Sans';
}
.navigatorpage,
.homepage,
.subpage,
.offerpage,
.allocatorpage {
  position: relative;
  height: auto !important;
  height: 100%;
  min-height: 100%;
  margin: 0px auto 0px;
}
.meta-nav {
  height: 50px;
  width: 100%;
}
.spacer {
  height: 300px;
  clear: both;
}
@media (min-width: 700px) {
  .spacer {
    height: 180px;
  }
}
@media (max-width: 404px) {
  .spacer {
    height: 420px;
  }
}
h1,
h2,
.h1,
.h2,
.h1 > p,
.h2 > p {
  text-align: center;
  font-size: 48px;
  position: relative;
  margin: 0 0 50px 0;
  padding: 0px 20px 20px 20px;
  text-transform: uppercase;
}
h1:after,
h2:after,
.h1:after,
.h2:after,
.h1 > p:after,
.h2 > p:after {
  content: "";
  background: #b51d28;
  position: absolute;
  bottom: 0;
  height: 4px;
  margin-left: -50px;
  width: 100px;
  left: 50%;
}
.subpage h1,
.offerpage h1,
.subpage h2,
.offerpage h2,
.subpage .h1,
.offerpage .h1,
.subpage .h2,
.offerpage .h2,
.subpage .h1 > p,
.offerpage .h1 > p,
.subpage .h2 > p,
.offerpage .h2 > p {
  text-align: left;
  font-size: 48px;
  margin: 0 0 50px 0;
  padding: 0px 20px 20px 0px;
  text-transform: none;
}
.subpage h1:after,
.offerpage h1:after,
.subpage h2:after,
.offerpage h2:after,
.subpage .h1:after,
.offerpage .h1:after,
.subpage .h2:after,
.offerpage .h2:after,
.subpage .h1 > p:after,
.offerpage .h1 > p:after,
.subpage .h2 > p:after,
.offerpage .h2 > p:after {
  display: none;
  content: "";
  background: transparent;
  position: inherit;
  bottom: 0;
  height: 0;
  margin-left: 0;
  width: 0;
  left: 0;
}
.subpage h2,
.offerpage h2,
.subpage .h2,
.offerpage .h2,
.subpage .h2 > p,
.offerpage .h2 > p {
  font-size: 36px;
  margin: 0;
}
.subpage h1,
.subpage .h1,
.subpage .h1 > p {
  margin: 0 0 10px 0;
}
.navigatorpage h1,
.navigatorpage .h1,
.navigatorpage .h1 > p {
  line-height: 1.5em;
  text-align: center;
  color: #ffffff;
  font-size: 48px;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.3);
  text-transform: uppercase;
  font-weight: bold;
  margin-top: -140px;
  min-height: 108px;
}
.navigatorpage h1:after,
.navigatorpage .h1:after,
.navigatorpage .h1 > p:after {
  display: none;
  background: none;
  position: initial;
  height: 0px;
}
h2,
.h2,
.h2 > p {
  font-size: 36px;
  padding-top: 0;
}
h3,
.h3,
.h3 > p {
  color: #333333;
  font-size: 30px;
}
h4,
.h4,
.h4 > p {
  color: #333333;
  font-size: 24px;
}
h5,
.h5,
.h5 > p {
  color: #333333;
  font-size: 18px;
}
h6,
.h6,
.h6 > p {
  color: #333333;
  font-size: 16px;
  font-weight: bold;
}
p,
.ce-bodytext {
  font-size: 22px;
  line-height: 28px;
}
.easy {
  /*.ce-bodytext li, .offer-list li{
    margin-bottom:10px;
  }*/
}
.easy h1,
.easy h2,
.easy h3,
.easy h4,
.easy h5,
.easy h6,
.easy .h1,
.easy .h2,
.easy .h3,
.easy .h4,
.easy .h5,
.easy .h6,
.easy .h1 > p,
.easy .h2 > p,
.easy .h3 > p,
.easy .h4 > p,
.easy .h5 > p,
.easy .h6 > p {
  line-height: 1.5;
}
.easy p,
.easy .ce-bodytext {
  line-height: 42px;
}
.easy p,
.easy .ce-bodytext,
.easy ul,
.easy h1,
.easy h2,
.easy h3,
.easy h4,
.easy h5,
.easy h6,
.easy .ce-intext.ce-right .ce-gallery,
.easy .ce-intext.ce-left .ce-gallery,
.easy .ce-above .ce-gallery {
  margin-bottom: 30px;
}
.easy .navigatorpage h1,
.easy .navigatorpage .h1 {
  margin-top: -180px;
  min-height: 164px;
}
.easy .metaeasy.new.hidden {
  display: block !important;
}
.easy .metaeasy.old {
  display: none;
}
.easy .icon-icon_leichte-sprache.active:before {
  color: #b51d28;
}
.navigatorpage .row-easy {
  margin-bottom: 30px;
}
.offerpage .row-easy {
  position: relative;
  top: -48px;
}
@media (min-width: 768px) {
  .offerpage .row-easy .btn-easy {
    margin-top: 10px;
    margin-bottom: 10px;
  }
}
@media (max-width: 768px) {
  .subpage .row-easy {
    margin-bottom: 30px;
  }
}
.btn-easy {
  margin-top: 30px;
}
.btn-easy a {
  border: 1px solid #d2d2d2;
  border-radius: 25px;
  font-size: 16px;
  font-weight: 600;
  color: #333333;
  line-height: 19px;
  padding: 7px 20px 8px 20px;
}
.btn-easy a span {
  padding-right: 10px;
}
.btn-easy a span:before {
  color: #b51d28;
}
.switch_wrapper {
  margin-right: 5px;
  display: inline-block;
  line-height: 50px;
  position: relative;
  bottom: -4px;
  margin-left: 5px;
}
.switch {
  height: 18px;
  width: 34px;
  border-radius: 9px;
  background-color: #B51D28;
  box-shadow: inset 1px 1px 1px 0 rgba(0, 0, 0, 0.2);
  position: relative;
  padding-top: 2px;
}
.switch .inner-switch {
  height: 14px;
  width: 14px;
  border-radius: 7px;
  background-color: #FFFFFF;
  box-shadow: 1px 1px 0 0 rgba(0, 0, 0, 0.2);
  position: absolute;
  top: 2px;
  left: 18px;
  -webkit-transition: left 1s ease;
  -moz-transition: left 1s ease;
  -o-transition: left 1s ease;
  -ms-transition: left 1s ease;
  transition: left 1s ease;
}
.icon-icon_leichte-sprache.on:before {
  color: #b51d28;
}
.off > .switch {
  background-color: #999;
}
.off > .switch .inner-switch {
  left: 2px;
}
a {
  color: #b51d28;
}
a:hover {
  text-decoration: none;
  color: #cb6168;
}
a:hover .h3,
a:hover .h3:hover {
  color: #b51d28;
}
a h4,
a .h4,
a .h4 > p {
  display: block;
  color: #b51d28;
}
a h4:hover,
a .h4:hover,
a .h4 > p:hover {
  color: #b51d28;
}
a h3,
a .h3,
a .h3 > p {
  display: block;
  color: #333333;
}
a h3:hover,
a .h3:hover,
a .h3 > p:hover {
  color: #333333;
}
footer {
  position: absolute;
  bottom: 0 !important;
  background-color: #E2E2E2;
  width: 100%;
  line-height: 100px;
  font-size: 18px;
}
footer .container {
  line-height: 80px;
  margin: 0 auto;
}
footer .container a {
  color: #333333;
  padding: 0 5px;
}
footer .container a:hover {
  color: #b51d28;
}
footer .light {
  background-color: #EEEEEE;
  text-align: center;
}
footer .light img {
  margin: 20px;
  display: inline;
}
.margin-large {
  margin-bottom: 100px;
}
.margin-normal {
  margin-bottom: 50px;
}
.margin-small {
  margin-bottom: 30px;
}
.homepage h1 {
  font-size: 36px;
  padding-top: 0;
}
.head-navi {
  height: 177px;
}
.clearfix {
  clear: both;
  float: none;
}
.navigatorpage .homepage-header,
.subpage .homepage-header,
.allocatorpage .homepage-header {
  border-top: solid 1px #d2d2d2;
}
/* do not group these rules */
*::-webkit-input-placeholder {
  color: #333333;
}
*:-moz-placeholder {
  /* FF 4-18 */
  color: #333333;
}
*::-moz-placeholder {
  /* FF 19+ */
  color: #333333;
}
*:-ms-input-placeholder {
  /* IE 10+ */
  color: #333333;
}
*:focus {
  outline: none;
}
[class^="icon-"],
[class*=" icon-"] {
  position: relative;
  bottom: -2px;
}
@media (max-width: 1199px) {
  .homepage .container {
    padding-left: 15px;
    padding-right: 15px;
  }
  footer .container {
    line-height: 60px;
    height: auto;
  }
  footer .container .copyright {
    float: left;
  }
  .subpage .spacer,
  .offerpage .spacer,
  .allocatorpage .spacer {
    height: 350px;
  }
}
@media (min-width: 700px) {
  .subpage .spacer,
  .offerpage .spacer,
  .allocatorpage .spacer {
    height: 230px;
  }
}
@media (max-width: 404px) {
  .subpage .spacer,
  .offerpage .spacer,
  .allocatorpage .spacer {
    height: 470px;
  }
}
@media (max-width: 991px) {
  .tx-ig-navigator .row.offerpage {
    margin-left: -15px;
    margin-right: -15px;
  }
  .margin-large {
    margin-bottom: 50px;
  }
  h1,
  .h1 {
    margin: 0px 0px 45px 0px;
  }
  h2,
  .h2 {
    margin: 0px 0px 25px 0px;
  }
  footer {
    line-height: 50px;
    font-size: 16px;
    height: auto;
  }
  footer .container .copyright {
    float: left;
  }
}
@media (max-width: 767px) {
  .margin-large {
    margin-bottom: 50px;
  }
  .homepage-content h1,
  .homepage-content .h1 {
    font-size: 36px;
    line-height: 44px;
    padding: 0px 0px 20px;
    text-align: center;
    /*margin-top: -80px;*/
    margin-bottom: 20px;
  }
  .homepage-content h2,
  .homepage-content .h2 {
    font-size: 30px;
    line-height: 37px;
    text-align: center;
  }
  .homepage-content h3,
  .homepage-content .h3 {
    font-size: 24px;
    line-height: 29px;
  }
  .homepage-content h4,
  .homepage-content .h4 {
    font-size: 18px;
    line-height: 28px;
  }
  .homepage-content h5,
  .homepage-content .h5 {
    font-size: 16px;
    font-weight: bold;
    line-height: 28px;
  }
  .homepage h1,
  .homepage h2,
  .homepage .h1,
  .homepage .h2 {
    font-size: 30px;
  }
  .subpage h1,
  .offerpage h1,
  .subpage h2,
  .offerpage h2,
  .subpage .h1,
  .offerpage .h1,
  .subpage .h2,
  .offerpage .h2 {
    text-align: left;
    margin: 0;
  }
  footer .container {
    line-height: 35px;
    font-size: 16px;
    text-align: center;
  }
  footer .container .copyright {
    float: none;
  }
  .margin-large {
    margin-bottom: 60px;
  }
  .margin-normal {
    margin-bottom: 30px;
  }
  .margin-small {
    margin-bottom: 20px;
  }
  p,
  .ce-bodytext {
    font-size: 18px;
    line-height: 26px;
  }
}
@media (max-width: 480px) {
  .easy .navigatorpage h1 {
    margin-top: 0;
    min-height: 0;
  }
  .navigatorpage h1,
  .navigatorpage .h1 {
    line-height: 1.5em;
    font-size: 32px;
    margin-top: 0px;
    color: #333333;
    text-shadow: none;
    font-weight: normal;
    min-height: inherit;
  }
  .navigatorpage h1:after,
  .navigatorpage .h1:after {
    display: block;
    content: "";
    background: #b51d28;
    position: absolute;
    bottom: 0;
    height: 4px;
    margin-left: -50px;
    width: 100px;
    left: 50%;
  }
  footer {
    padding: 0px;
    height: auto;
  }
  footer .container {
    line-height: 30px;
    font-size: 14px;
    min-width: 300px;
  }
  footer .container a {
    padding: 0px;
  }
}
@media print {
  a[href]:after {
    content: none !important;
  }
  footer {
    display: none;
  }
}
.linkTop {
  font-family: Calibri, 'PT Sans';
  position: fixed;
  bottom: 85px;
  right: 10px;
  z-index: 100;
  background-color: rgba(0, 0, 0, 0.07000000000000001);
  color: #333;
  font-size: 18px;
  padding: 11px 11px;
  line-height: 18px;
  text-decoration: none;
}
.linkTop:focus {
  text-decoration: none;
  color: #cb6168;
  outline: 0;
}
.linkTop .hidden {
  display: none;
}
.karriere .btn-more {
  font-size: 16px;
  border-radius: 25px;
  background-color: #b51d28;
  color: #ffffff;
  padding: 5px 20px;
  display: inline-block;
}
.karriere .btn-more:hover {
  color: #ffffff;
  background-color: #cb6168;
}
.btn-uppercase {
  text-transform: uppercase;
}
hr {
  border-color: #d2d2d2;
}
form.require_recaptcha {
  position: relative;
}
#overlay_blocked_recaptcha {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 10;
  background: rgba(0, 0, 0, 0.2);
  text-align: center;
  font-size: 24px;
  margin: 0 auto;
  border: 1px solid #000;
  display: flex;
  flex-direction: column;
  align-items: center;
}
#overlay_blocked_recaptcha #embed-recaptcha {
  display: contents;
}
.tx-powermail .uc-text-embedding,
.powermail_fieldwrap .uc-text-embedding {
  max-width: 500px;
  background: #eee;
  border: 1px solid #ccc;
  padding: 20px 10px 23px 20px;
  margin: 30px 0px 10px 0px;
  border-radius: 20px;
  line-height: 145%;
}
@media (min-width: 768px) {
  .navigatorpage h1 {
    min-height: inherit;
  }
}
@media (min-width: 1200px) {
  /*.allocatorpage, .navigatorpage{
  .homepage-content{
    .ce-textpic,
    .list-news .news-article{
      width:70%;
      margin-left:15%;
    }

  }
}
.homepage {
  .homepage-content {
    .ce-textpic {
      width: 70%;
      margin-left: 15%;
    }
  }
}*/
  .easy .allocatorpage .homepage-content,
  .easy .allocatorpage .content-bottom {
    max-width: 940px;
    margin: 0 auto;
  }
  .easy .allocatorpage .content-bottom .container,
  .easy .navigatorpage .content-bottom .container,
  .easy .allocatorpage .homepage-content .container .margin-normal,
  .easy .navigatorpage .homepage-content .container .margin-normal {
    max-width: 940px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}
