.frame-layout-teaser img {
  height: 450px;
  object-fit: cover;
}

.frame-layout-teaser .ce-textpic {
  position: relative;
}

.frame-layout-teaser .ce-textpic .ce-bodytext {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80vw;
}

.frame-layout-teaser .ce-textpic .ce-bodytext a {
  text-align: center;
  transition: all .4s;
  border: 1px solid var(--ci-color);
  padding: 15px;
  color: var(--white);
  font-size: 10pt;
  position: relative;
  text-transform: uppercase;
  letter-spacing: 2.5px;
  font-weight: bold;
}

.frame-layout-teaser .ce-textpic .ce-bodytext p {
  line-height: 5;
  text-align: center;
}

@media (min-width: 768px) {
  .frame-layout-teaser .ce-textpic .ce-bodytext {
    display: inline-flex;
  }

  .frame-layout-teaser .ce-textpic .ce-bodytext p {
    margin: auto;
  }

  .frame-layout-teaser .ce-bodytext a:hover {
    color: var(--white);
    text-decoration: none;
    cursor: pointer;
  }

  .frame-layout-teaser .ce-bodytext a:after {
    position: absolute;
    z-index: -1;
    width: 0;
    height: 100%;
    left: 0;
    bottom: 0;
    content: '';
    transition: all .4s;
  }

  .frame-layout-teaser .ce-bodytext a:hover:after {
    width: 100%;
    background: var(--ci-color);
  }
}
