.stl_section--hero,
p[data-ap] {
  opacity: 0;
  animation: .4s ease-in .3s forwards animAp;
}

@keyframes animAp {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

.ap {
  position: relative;
  border: 1px dotted #ff8c00;
}

.ap::before {
  content: attr(data-ap);
  display: block;
  position: absolute;
  color: #ff8c00;
  font-size: small;
  font-weight: 500;
  top: -1rem;
  z-index: 1;
  right: 0
}

.ap-option {
  display: none;
}

.ap-option .stl_tag:empty {
  display: none;
}

/* Protect spécifique */
.stl_card--af-verticale .stl_tag {
  color: #fff;
  background-color: #000;
}

.stl_tag[data-ap="jeuTagLabelOffresOption"] {
  color: #fff;
  background-color: #E2010B
}

.stl_card--af-verticale .stl_card-body img.icon-red {
  width: 24px;
  height: 24px;
  filter: brightness(0) saturate(100%) invert(13%) sepia(100%) saturate(7018%) hue-rotate(355deg) brightness(87%) contrast(104%);
}

.plus {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto 2.5rem;
  height: 48px;
  width: 48px;
  border-radius: 100%;
  background-color: #010035;
}

@media screen and (min-width: 64rem) {
  .plus {
    margin-bottom: 5rem;
  }
}

.plus span {
  font-size: 3rem;
  color: #fff;
}

p[data-ap="jeuMentionsLabelOffresOption"] a {
  color: #545454;
}