/*! otm, Compiled at 2025-09-05 09:02:45 */
/**
 * Oldenburg
 *
 * LICENSE
 *
 * This software and its source code is protected by copyright law (Sec. 69a ff. UrhG).
 * It is not allowed to make any kinds of modifications, nor must it be copied,
 * or published without explicit permission. Misuse will lead to persecution.
 *
 * @copyright  2016 infomax websolutions GmbH
 * @link       http://www.infomax-it.de
 * @package    css
 * @author     Matthias Kracke <kracke@infomax-it.de>
 * @since      2016-11-24
 * @version    $$Id$$
 **/
/**
 * OTM - Hauptportal 2016
 *
 * LICENSE
 *
 * This software and its source code is protected by copyright law (Sec. 69a ff. UrhG).
 * It is not allowed to make any kinds of modifications, nor must it be copied,
 * or published without explicit permission. Misuse will lead to persecution.
 *
 * @copyright  2015 infomax websolutions GmbH
 * @link       http://www.infomax-it.de
 * @package    css
 * @subpackage teaserSlider
 * @author     gueldner
 * @since      25.10.2016
 * @version    $Id$
 **/
/*  =========================================================
basic config
general structure
slider container
slider row
arrows
dots
========================================================== */
/*  =========================================================
basic config
========================================================= */
/* dimensions */
/* ultra tiny introduced for iPhone 5s */
/* corporate design */
/* @see src/portal/assets/styles/_brand for css variables */
/* other colors */
/* percentage dimensions */
/* percentage margins */
/* percentage paddings */
/* default font settings */
/* vertical aligns */
.verticalAlignHelper {
  content: '';
  display: inline-block;
  vertical-align: middle;
  width: 0;
  height: 100%;
  margin: 0;
}
/*  =========================================================
general structure
========================================================= */
/* the main container */
@media all {
  .teaserSlider {
    position: relative;
  }
}
/*  =========================================================
slider container
========================================================= */
@media all {
  .teaserSlider__slider {
    overflow: hidden;
  }
}
/*  =========================================================
slider row
========================================================= */
@media all {
  .teaserSlider__slider__row {
    width: 100%;
  }
}
/*  =========================================================
arrows
========================================================= */
@media all {
  .teaserSlider > .icon-arrowLeft,
  .teaserSlider > .icon-arrowRight {
    position: absolute;
    top: 50%;
    margin-top: -31px;
    display: block;
    width: 62px;
    height: 62px;
    border-radius: 50%;
    cursor: pointer;
    color: rgb(var(--color-white));
    font-size: 30px;
    line-height: 62px;
    text-align: center;
  }
  .teaserSlider__arrow--hidden {
    visibility: hidden;
  }
  /* microsite specific */
  html:not(.-css-microsite-gruenkohl) .teaserSlider > .icon-arrowLeft,
  html:not(.-css-microsite-gruenkohl) .teaserSlider > .icon-arrowRight {
    background: rgb(var(--color-button-default));
  }
  html.-css-microsite-gruenkohl .teaserSlider > .icon-arrowLeft,
  html.-css-microsite-gruenkohl .teaserSlider > .icon-arrowRight {
    background: rgb(var(--color-white)) url('../images/_branding/background_microsite1.a4cf9239.jpg') 0 0 repeat;
  }
}
@media all and (max-width: 1000px) {
  .teaserSlider > .icon-arrowLeft,
  .teaserSlider > .icon-arrowRight {
    display: none;
  }
}
@media all {
  .teaserSlider > .icon-arrowLeft {
    left: 0.5952381%;
  }
  .teaserSlider > .icon-arrowRight {
    right: 0.5952381%;
  }
}
/*  =========================================================
dots
========================================================= */
@media all {
  .teaserSlider__dots {
    width: 100%;
    text-align: center;
    padding-top: 20px;
  }
}
@media all {
  .teaserSlider__dots__element {
    display: inline-block;
    width: 16px;
    height: 16px;
    margin: 0 2px 2px 2px;
    border-radius: 50%;
    cursor: pointer;
  }
  .teaserSlider__dots__element:not(.teaserSlider__dots__element--active) {
    opacity: 0.5;
  }
  /* microsite specific */
  html:not(.-css-microsite-gruenkohl) .teaserSlider__dots__element {
    background: rgb(var(--color-button-default));
  }
  html.-css-microsite-gruenkohl .teaserSlider__dots__element {
    background: #006b37;
  }
  .teaserSlider__slider .cmplazypreviewiframe {
    background: none !important;
    position: absolute;
    display: block;
    height: 100% !important;
    width: 60% !important;
    left: 21%;
    top: 0;
    z-index: 10;
    overflow: hidden;
  }
  .teaserSlider__slider .cmplazypreviewiframe .cmplazypreviewmsg {
    background: 0 #fff !important;
  }
}
/**
 * OTM - Hauptportal 2016
 *
 * LICENSE
 *
 * This software and its source code is protected by copyright law (Sec. 69a ff. UrhG).
 * It is not allowed to make any kinds of modifications, nor must it be copied,
 * or published without explicit permission. Misuse will lead to persecution.
 *
 * @copyright  2015 infomax websolutions GmbH
 * @link       http://www.infomax-it.de
 * @package    css
 * @subpackage teaserSlider
 * @author     gueldner
 * @since      25.10.2016
 * @version    $Id$
 **/
/*  =========================================================
basic config
general structure
link
image
speech booble
headline
subtitle
========================================================== */
/*  =========================================================
basic config
========================================================= */
/**
 * oldenburg
 *
 * LICENSE
 *
 * This software and its source code is protected by copyright law (Sec. 69a ff. UrhG).
 * It is not allowed to make any kinds of modifications, nor must it be copied,
 * or published without explicit permission. Misuse will lead to persecution.
 *
 * @copyright  2020 infomax websolutions GmbH
 * @link       https://www.infomax-online.de
 * @author     Florian Sauer <sauer@infomax-it.de>
 * @since      2020-12-03
 */
/*  =========================================================
general structure
========================================================= */
@media all {
  .teaserSlider__element {
    display: inline-block;
    position: relative;
    width: 100%;
  }
}
/*  =========================================================
link
========================================================= */
@media all {
  .teaserSlider__element > a {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    display: block;
    width: 100%;
    height: 100%;
    text-indent: -1000%;
  }
}
/*  =========================================================
image
========================================================= */
@media all {
  .teaserSlider__element picture {
    display: block;
    width: 100%;
    overflow: hidden;
  }
  .teaserSlider__element picture > img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
  }
}
@media all and (min-width: 701px) {
  .teaserSlider__element picture {
    height: 0;
    padding-bottom: 37.7245509%;
  }
}
@media all and (max-width: 700px) {
  .teaserSlider__element picture {
    height: 0;
    padding-bottom: 133.33333333%;
  }
}
/*  =========================================================
speech booble
========================================================= */
@media all {
  .teaserSlider__element__speechBooble {
    position: absolute;
    bottom: 20px;
    left: 0;
    display: inline-block;
    color: rgb(var(--color-black));
    text-align: left;
  }
  .teaserSlider__element__speechBooble--teaserTextBlockColorDefault,
  .teaserSlider__element__speechBooble--teaserTextBlockColorYellow {
    color: rgb(var(--color-black));
  }
  .teaserSlider__element__speechBooble--teaserTextBlockColorRed {
    color: rgb(var(--color-white));
  }
  html:not(.-css-microsite-club) .teaserSlider__element__speechBooble.teaserSlider__element__speechBooble--cutout > h3,
  html:not(.-css-microsite-club) .teaserSlider__element__speechBooble:not(.teaserSlider__element__speechBooble--cutout) > .subtitle {
    -webkit-clip-path: polygon(13% 0, 13% 13px, calc(13% + 14px) 0, 100% 0, 100% 100%, 0 100%, 0 0);
            clip-path: polygon(13% 0, 13% 13px, calc(13% + 14px) 0, 100% 0, 100% 100%, 0 100%, 0 0);
  }
  .teaserSlider__element__speechBooble:not(.teaserSlider__element__speechBooble--cutout) > .subtitle {
    padding: 18px 15px 3px 15px;
    display: block;
  }
}
@media all and (min-width: 1401px) {
  .teaserSlider__element__speechBooble {
    margin: 30px;
  }
}
@media all and (min-width: 1001px) and (max-width: 1400px) {
  .teaserSlider__element__speechBooble {
    margin: 20px;
  }
}
@media all and (max-width: 1000px) {
  .teaserSlider__element__speechBooble {
    margin: 15px;
    bottom: 45px;
  }
}
/*  =========================================================
headline
========================================================= */
@media all {
  .teaserSlider__element__speechBooble > h3 {
    margin: 0;
    font: 400 normal 4rem/1em 'HalvarEngschrift', Arial, sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 4rem;
    line-height: 1em;
  }
  html.-css-microsite-club .teaserSlider__element__speechBooble > h3 {
    font: 600 normal 3.5rem/1.2em 'Open Sans', Arial, sans-serif;
    font-weight: 600;
    font-style: normal;
    font-size: 3.5rem;
    line-height: 1.2em;
    padding-top: 8px;
    padding-bottom: 5px;
  }
  .teaserSlider__element__speechBooble.teaserSlider__element__speechBooble--cutout > h3 {
    padding: 23px 45px 8px 15px;
  }
  .teaserSlider__element__speechBooble:not(.teaserSlider__element__speechBooble--cutout) > h3 {
    padding: 10px 45px 8px 15px;
  }
  .teaserSlider__element__speechBooble.teaserSlider__element__speechBooble--teaserTextBlockColorDefault > span,
  .teaserSlider__element__speechBooble.teaserSlider__element__speechBooble--teaserTextBlockColorDefault > h3 {
    background: rgb(var(--color-white));
  }
  .teaserSlider__element__speechBooble.teaserSlider__element__speechBooble--teaserTextBlockColorRed > span,
  .teaserSlider__element__speechBooble.teaserSlider__element__speechBooble--teaserTextBlockColorRed > h3 {
    background: rgb(var(--color-cdRed1));
  }
  .teaserSlider__element__speechBooble.teaserSlider__element__speechBooble--teaserTextBlockColorYellow > span,
  .teaserSlider__element__speechBooble.teaserSlider__element__speechBooble--teaserTextBlockColorYellow > h3 {
    background: rgb(var(--color-cdYellow1));
  }
  .teaserSlider__element__speechBooble h3 > span {
    font-size: 17px;
    position: absolute;
    right: 0;
    padding: 0 15px 14px 0;
    bottom: 0;
  }
}
@media all and (min-width: 1001px) and (max-width: 1400px) {
  .teaserSlider__element__speechBooble > h3 {
    font-size: 4.44444444rem;
  }
}
@media all and (min-width: 1001px) and (max-width: 1400px) {
  html.-css-microsite-club .teaserSlider__element__speechBooble > h3 {
    font-size: 3.55555556rem;
  }
}
@media all and (min-width: 701px) and (max-width: 1000px) {
  html.-css-microsite-club .teaserSlider__element__speechBooble > h3 {
    font-size: 3.75rem;
  }
}
@media all and (max-width: 700px) {
  html.-css-microsite-club .teaserSlider__element__speechBooble > h3 {
    font-size: 4rem;
  }
}
/*  =========================================================
subtitle
========================================================= */
@media all {
  .teaserSlider__element__speechBooble > .subtitle {
    position: relative;
    bottom: -1px;
    padding: 5px 15px 3px 15px;
    margin: 0;
    background: rgb(var(--color-white));
    font: 400 normal 2rem/1em 'Open Sans', Arial, sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 2rem;
    line-height: 1em;
  }
  html.-css-microsite-club .teaserSlider__element__speechBooble > .subtitle {
    font: 300 normal 1.4rem/1.5em 'Open Sans', Arial, sans-serif;
    font-weight: 300;
    font-style: normal;
    font-size: 1.4rem;
    line-height: 1.5em;
    padding-top: 2px;
    padding-bottom: 0;
    margin-bottom: -10px;
  }
}
@media all and (min-width: 1001px) and (max-width: 1400px) {
  .teaserSlider__element__speechBooble > .subtitle {
    font-size: 1.77777778rem;
  }
}
@media all and (min-width: 1001px) and (max-width: 1400px) {
  html.-css-microsite-club .teaserSlider__element__speechBooble > .subtitle {
    font-size: 1.55555556rem;
  }
}
@media all and (min-width: 701px) and (max-width: 1000px) {
  html.-css-microsite-club .teaserSlider__element__speechBooble > .subtitle {
    font-size: 1.75rem;
  }
}
@media all and (max-width: 700px) {
  html.-css-microsite-club .teaserSlider__element__speechBooble > .subtitle {
    font-size: 2rem;
  }
}
/*  =========================================================
video element speechBooble button
========================================================= */
@media all {
  .teaserSlider__element__speechBooble > .videoElementText {
    display: inline-block;
    background: #fff;
    font: 700 normal 20px/40px 'Open Sans', Arial, sans-serif;
    font-weight: 700;
    font-style: normal;
    font-size: 20px;
    line-height: 40px;
    height: 40px;
    padding: 0 15px;
  }
  .teaserSlider__element__speechBooble > .videoElementText--wrapper {
    background: #fff;
    padding: 2px 15px 10px 15px;
  }
}
/**
 * oldenburg
 *
 * LICENSE
 *
 * This software and its source code is protected by copyright law (Sec. 69a ff. UrhG).
 * It is not allowed to make any kinds of modifications, nor must it be copied,
 * or published without explicit permission. Misuse will lead to persecution.
 *
 * @copyright  2019 infomax websolutions GmbH
 * @link       https://www.infomax-online.de
 * @author     Florian Sauer <sauer@infomax-it.de>
 * @since      2019-09-18
 */
/**

/*  =========================================================
basic config
general structure
cropping
stop button
========================================================== */
/*  =========================================================
basic config
========================================================= */
/*  =========================================================
general structure
========================================================= */
@media all {
  .teaserSlider__element--video__videoContainer {
    height: 100%;
    overflow: hidden;
    width: 100%;
    position: absolute;
    left: 0;
    z-index: 1;
    text-align: center;
    cursor: pointer;
    transition: opacity 0.5s ease, top 0.1s linear;
  }
  .teaserSlider__element--video__videoContainer > iframe {
    position: absolute;
    left: 50%;
    top: 50%;
    display: block;
    width: 100%;
    height: 100%;
    opacity: 1;
    -webkit-transform: translateX(-50%) translateY(-50%);
        -ms-transform: translateX(-50%) translateY(-50%);
            transform: translateX(-50%) translateY(-50%);
    transition: visibility 0.5s, opacity 0.5s linear;
  }
  .teaserSlider__element--video__videoContainer:not(.teaserSlider__element--video__videoContainer--playing) {
    top: 0;
    opacity: 0;
    transition-delay: 0s, 0.5s;
    z-index: 1;
  }
  .headerImage__mediaContainer__image {
    z-index: 3;
    pointer-events: none;
  }
  .headerImage__textContainer {
    z-index: 2;
    pointer-events: none;
  }
  .headerImage__textContainer a {
    pointer-events: all;
  }
  .teaserSlider__element--video__videoContainer.teaserSlider__element--video__videoContainer--selfHosted,
  .teaserSlider__element--video__videoContainer.teaserSlider__element--video__videoContainer--playing {
    top: 0;
    opacity: 1;
    transition-delay: 0.1s, 0s;
  }
}
@media all and (min-width: 701px) {
  .teaserSlider__element--video__videoContainer {
    box-sizing: border-box;
  }
}
@media all {
  .teaserSlider__element--video__videoContainer {
    width: 100%;
    height: 100%;
  }
  .teaserSlider__element--video__videoContainer--selfHosted {
    position: relative;
  }
  .teaserSlider__element--video__videoContainer__video {
    width: 100%;
    height: 100%;
  }
  .teaserSlider__element--video__videoContainer video {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
}
@media all and (min-width: 701px) {
  .teaserSlider__element--video__videoContainer {
    aspect-ratio: auto 1390 / 524;
  }
}
@media all and (max-width: 700px) {
  .teaserSlider__element--video__videoContainer {
    aspect-ratio: auto 528 / 704;
  }
}
/*  =========================================================
stop button
========================================================= */
@media all {
  .teaserSlider__element--video__videoContainer__button {
    border: 0;
    position: absolute;
    top: 50%;
    left: 50%;
    margin: -75px 0 0 -75px;
    width: 150px;
    height: 150px;
    background: rgba(255, 255, 255, 0.25);
    border-radius: 50%;
    overflow: hidden;
    cursor: pointer;
    transition: opacity 0.25s ease;
    z-index: 3;
  }
  .teaserSlider__element--video__videoContainer__button .playVideo,
  .teaserSlider__element--video__videoContainer__button .stopVideo {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(1px, 1px, 1px, 1px);
  }
  .teaserSlider__element--video__videoContainer__button::before {
    content: '';
    position: absolute;
    top: -50%;
    left: -50%;
    width: 200%;
    height: 100%;
    background: rgba(255, 255, 255, 0.15);
    border-radius: 50%;
  }
  .teaserSlider__element--video__videoContainer.teaserSlider__element--video__videoContainer--playing .teaserSlider__element--video__videoContainer__button::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    margin: -25px 0 0 -25px;
    display: block;
    width: 50px;
    height: 50px;
    border: 3px rgba(255, 255, 255, 0.75) solid;
    box-sizing: border-box;
    border-radius: 5px;
  }
  .teaserSlider__element--video__videoContainer:not(.teaserSlider__element--video__videoContainer--playing) .teaserSlider__element--video__videoContainer__button::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    margin: -25px 0 0 -25px;
    display: block;
    border-top: 25px solid transparent;
    border-left: 50px solid rgba(255, 255, 255, 0.75);
    border-bottom: 25px solid transparent;
    box-sizing: border-box;
  }
  .teaserSlider__element--video__videoContainer__button:focus {
    opacity: 1 !important;
  }
  .teaserSlider__element--video__videoContainer.teaserSlider__element--video__videoContainer--playing .teaserSlider__element--video__videoContainer__button .playVideo {
    display: none;
  }
  .teaserSlider__element--video__videoContainer:not(.teaserSlider__element--video__videoContainer--playing) .teaserSlider__element--video__videoContainer__button .stopVideo {
    display: none;
  }
  .-js-teaserSlider__element--video__videoContainer--gui.teaserSlider__element--video__videoContainer--playing > .teaserSlider__element--video__videoContainer__button {
    opacity: 1;
  }
  .teaserSlider__element--video__videoContainer--playing:not(.-js-teaserSlider__element--video__videoContainer--gui) > .teaserSlider__element--video__videoContainer__button {
    opacity: 0;
  }
  .teaserSlider__element--video__videoContainer__mutebutton {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 40px;
    height: 40px;
    background: rgba(255, 255, 255, 0.25);
    overflow: hidden;
    cursor: pointer;
    border: 0;
  }
  .teaserSlider__element--video__videoContainer__mutebutton:focus {
    border: 1px solid rgb(var(--color-white));
  }
  .teaserSlider__element--video__videoContainer__mutebutton .speaker {
    height: 30px;
    width: 30px;
    position: relative;
    overflow: hidden;
    display: inline-block;
  }
  .teaserSlider__element--video__videoContainer__mutebutton .speaker .speakerSound {
    display: block;
    width: 8px;
    height: 8px;
    background: #fff;
    margin: 11px 0 0 2px;
  }
  .teaserSlider__element--video__videoContainer__mutebutton .speaker .speakerSound::after {
    content: '';
    position: absolute;
    width: 0;
    height: 0;
    border-style: solid;
    border-color: transparent #fff transparent transparent;
    border-width: 10px 14px 10px 15px;
    left: -13px;
    top: 5px;
  }
  .teaserSlider__element--video__videoContainer__mutebutton .speaker .speakerSound::before {
    -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
            transform: rotate(45deg);
    border-radius: 0 50px 0 0;
    content: '';
    position: absolute;
    width: 5px;
    height: 5px;
    border-style: double;
    border-color: #fff;
    border-width: 7px 7px 0 0;
    left: 18px;
    top: 9px;
    transition: all 0.2s ease-out;
  }
  .teaserSlider__element--video__videoContainer__mutebutton .speaker .speakerSound .muted,
  .teaserSlider__element--video__videoContainer__mutebutton .speaker .speakerSound .unmuted {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(1px, 1px, 1px, 1px);
  }
  .teaserSlider__element--video__videoContainer__mutebutton .speaker:hover .speakerSound::before {
    -webkit-transform: scale(0.8) translate(-3px, 0) rotate(42deg);
        -ms-transform: scale(0.8) translate(-3px, 0) rotate(42deg);
            transform: scale(0.8) translate(-3px, 0) rotate(42deg);
  }
  .teaserSlider__element--video__videoContainer.teaserSlider__element--video__videoContainer--muted .teaserSlider__element--video__videoContainer__mutebutton .speaker .speakerSound::before {
    -webkit-transform: scale(0.5) translate(-15px, 0) rotate(36deg);
        -ms-transform: scale(0.5) translate(-15px, 0) rotate(36deg);
            transform: scale(0.5) translate(-15px, 0) rotate(36deg);
    opacity: 0;
  }
  .teaserSlider__element--video__videoContainer.teaserSlider__element--video__videoContainer--muted .teaserSlider__element--video__videoContainer__mutebutton .speaker .unmuted {
    display: none;
  }
  .teaserSlider__element--video__videoContainer:not(.teaserSlider__element--video__videoContainer--muted) .teaserSlider__element--video__videoContainer__mutebutton .speaker .muted {
    display: none;
  }
}
/**
 * oldenburg
 *
 * LICENSE
 *
 * This software and its source code is protected by copyright law (Sec. 69a ff. UrhG).
 * It is not allowed to make any kinds of modifications, nor must it be copied,
 * or published without explicit permission. Misuse will lead to persecution.
 *
 * @copyright  2019 infomax websolutions GmbH
 * @link       https://www.infomax-online.de
 * @author     Florian Sauer <sauer@infomax-it.de>
 * @since      2019-09-18
 */
/**

/*  =========================================================
basic config
general structure
speech booble
========================================================== */
/*  =========================================================
basic config
========================================================= */
/*  =========================================================
general structure
========================================================= */
@media all {
  .teaserSlider__element--pano__mediaContainer {
    display: block;
    overflow: hidden;
    width: 100%;
  }
  .teaserSlider__element--pano__mediaContainer__pano {
    display: block;
    width: 100%;
    height: 100%;
    padding: 0;
    position: absolute;
  }
  .gm-iv-address-link {
    display: none;
  }
}
@media all and (min-width: 701px) {
  .teaserSlider__element--pano__mediaContainer {
    display: block;
    overflow: hidden;
    width: 100%;
    padding-bottom: 37.7245509%;
  }
}
@media all and (max-width: 700px) {
  .teaserSlider__element--pano__mediaContainer {
    display: block;
    overflow: hidden;
    width: 100%;
    padding-bottom: 132.724551%;
  }
}
/*  =========================================================
speech booble
========================================================= */
.teaserSlider__element__speechBooble--pano {
  z-index: 1;
}
