/***** in this file ***************
  base styling cards
  - specific for S/M & L

  hover & focus effects cards
  - viewport L only

  focus effect CTA
***********************************/
.teaser {
  border-radius: 8px;
  color: var(--color-white);
  height: 500px;
  overflow: hidden;
  position: relative;
  text-decoration: none;
  width: 100%; }
  @media (max-width: 940px) {
    .teaser {
      margin-right: 5px; } }
  @media (min-width: 941px) {
    .teaser--large {
      height: 550px; } }
  .teaser--small {
    height: 400px; }
  .teaser .list--checks li::before,
  .teaser [style="list-style-type: check"] li::before {
    background-color: var(--color-white); }

.teaser__content {
  padding: 30px 20px; }

.teaser__gradient,
.teaser__img {
  border-radius: 8px;
  height: 100%;
  left: 0;
  object-fit: cover;
  position: absolute;
  text-decoration: none;
  top: 0;
  width: 100%; }

.teaser .teaser__shade {
  background: rgba(15, 25, 65, 0.7);
  opacity: 0;
  transition: opacity .3s ease;
  height: 100%;
  width: 100%; }

.teaser a {
  text-decoration: none; }

.teaser__gradient {
  background: linear-gradient(-180deg, rgba(15, 25, 65, 0) 33%, #0f1941 100%);
  cursor: pointer;
  transition: all 0.3s ease -1s;
  display: flex;
  padding: 30px 20px; }
  @media (min-width: 941px) {
    .teaser__gradient {
      padding: 40px; }
      .cards__list--halves .teaser__gradient {
        background: linear-gradient(-180deg, rgba(15, 25, 65, 0) 50%, #0f1941 100%); } }

@media (min-width: 941px) {
  .teaser__body {
    margin-top: auto;
    max-height: 338px;
    position: relative;
    transform: translateY(100%);
    transition: transform 0.3s ease; } }

@media (min-width: 941px) {
  .teaser--large .teaser__body {
    max-height: 365px; } }

.teaser--small .teaser__body {
  max-height: 256px; }

@media (max-width: 940px) {
  .teaser__header {
    bottom: 70px;
    left: 20px;
    position: absolute;
    right: 20px; } }

@media (min-width: 941px) {
  .teaser__header {
    height: 100%;
    margin-bottom: -30px;
    transform: translateY(-100%); } }

.teaser__date {
  color: var(--color-white);
  margin-bottom: 10px; }

.teaser__title {
  font-size: 26px;
  letter-spacing: -1px;
  line-height: 30px;
  -webkit-line-clamp: 9;
  -webkit-box-orient: vertical;
  display: -webkit-box;
  overflow: hidden;
  color: var(--color-white);
  margin-bottom: unset;
  max-height: 270px; }

.teaser__description {
  color: var(--color-white);
  opacity: 0; }
  @media (min-width: 941px) {
    .teaser__description {
      margin-bottom: unset;
      padding-top: 20px;
      transition: opacity 0.3s ease; } }

@media (min-width: 941px) {
  .teaser__cta {
    bottom: -40px;
    opacity: 0;
    position: absolute;
    transition: transform 0.3s; } }

@media (min-width: 941px) {
  .cards__list--quarters .teaser__cta {
    bottom: -30px; } }

@media (max-width: 940px) {
  .teaser__icon {
    bottom: 30px;
    color: var(--color-white);
    left: 20px;
    position: absolute;
    top: auto; } }

@media (min-width: 941px) {
  .teaser:hover img,
  .teaser:focus img {
    filter: blur(5px);
    transition: filter 0.5s; }
  .teaser:hover .teaser__shade,
  .teaser:focus .teaser__shade {
    border-radius: 8px;
    opacity: 1;
    position: absolute;
    text-decoration: none;
    transition: opacity .3s ease; }
  .teaser:hover .teaser__body,
  .teaser:focus .teaser__body {
    -webkit-line-clamp: 6;
    -webkit-box-orient: vertical;
    display: -webkit-box;
    overflow: hidden;
    margin-bottom: 90px;
    margin-top: auto;
    transform: translateY(0);
    transition: transform 0.3s; }
  .teaser:hover.teaser--small .teaser__body,
  .teaser:focus.teaser--small .teaser__body {
    margin-bottom: 70px;
    -webkit-line-clamp: 8; }
  .teaser:hover .teaser__header,
  .teaser:focus .teaser__header {
    transform: translateY(0%);
    margin-bottom: unset; }
  .teaser:hover .teaser__title,
  .teaser:focus .teaser__title {
    max-height: unset;
    overflow: unset;
    -webkit-line-clamp: 10; }
  .teaser:hover .teaser__description,
  .teaser:focus .teaser__description {
    opacity: 1;
    transition: transform 0.3s ease 0.1s; }
  .teaser:hover .teaser__cta,
  .teaser:focus .teaser__cta {
    opacity: 1;
    bottom: 40px;
    transition: all 0.2s ease-out 0.1s; }
    .cards__list--quarters .teaser:hover .teaser__cta, .cards__list--quarters
    .teaser:focus .teaser__cta {
      bottom: 30px; }
  .teaser__cta:focus {
    opacity: 1;
    bottom: 40px; }
    .teaser__cta:focus + .teaser__body {
      margin-bottom: 90px;
      overflow: hidden;
      transform: translateY(0); }
      .teaser__cta:focus + .teaser__body .teaser__header {
        transform: translateY(0%);
        margin-bottom: unset; }
      .teaser__cta:focus + .teaser__body .teaser__description {
        opacity: 1; } }

@media (min-width: 941px) {
  .rand-teaser .block__wrapper {
    padding-top: 110px;
    padding-bottom: 80px; } }

.rand-teaser .teaser .button {
  border-color: var(--color-white);
  color: var(--color-white); }
  .rand-teaser .teaser .button:hover, .rand-teaser .teaser .button:focus {
    background: #fff;
    border-color: #fff;
    color: #0f1941; }
    .rand-teaser .teaser .button:hover .icon svg, .rand-teaser .teaser .button:focus .icon svg {
      fill: var(--color-brand-secondary); }
  .rand-teaser .teaser .button:active {
    background: var(--color-gray-20);
    border-color: var(--color-gray-20);
    color: var(--color-brand-secondary); }
  @media (hover: none) {
    .rand-teaser .teaser .button:hover {
      background: var(--color-gray-20);
      border-color: var(--color-gray-20);
      color: var(--color-brand-secondary); } }
  .rand-teaser .teaser .button .icon svg {
    fill: var(--color-white); }
  .rand-teaser .teaser .button.button--filled .icon svg {
    fill: var(--color-brand-secondary); }

@media (max-width: 940px) {
  .rand-teaser .description--until-l .teaser__body {
    max-height: calc(100% - 30px); }
  .rand-teaser .description--until-l .teaser__shade {
    border-radius: 8px;
    opacity: 1; }
  .rand-teaser .description--until-l .teaser__body {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    margin-top: auto;
    margin-bottom: 70px;
    -webkit-line-clamp: 9; }
  .rand-teaser .description--until-l .teaser__header {
    position: unset; }
  .rand-teaser .description--until-l .teaser__description {
    opacity: 1;
    padding-top: 20px; }
  .rand-teaser .description--until-l .teaser__gradient {
    background: rgba(15, 25, 65, 0.7); } }

@media (min-width: 941px) {
  @supports (display: grid) {
    .rand-teaser .cards__list {
      grid-row-gap: 40px; } } }

.teaser__description hr {
  margin: 10px 0; }

/*# sourceMappingURL=teaser.css.map */
