.hvfb-story,
.hvfb-mosaic {
  position: relative;
  width: 100%;
  max-width: 100%;
  height: var(--hvfb-story-height, auto);
  min-height: 240px;
  margin: 28px 0;
  overflow: hidden;
  background: #f4f7f9;
  border-radius: 18px;
}

.hvfb-story-block,
.hvfb-mosaic-item {
  position: absolute;
  margin: 0;
  background: #fff;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 6px 20px rgba(0,0,0,.28);
  max-width: 100%;
  transform-origin: center center;
}

.hvfb-story-text {
  padding: 14px 16px;
  line-height: 1.55;
  box-sizing: border-box;
}

.hvfb-story-text p:first-child {
  margin-top: 0;
}

.hvfb-story-text p:last-child {
  margin-bottom: 0;
}

.hvfb-photo-frame {
  width: 100%;
  overflow: hidden;
  background: #eef3f6;
  aspect-ratio: 4 / 3;
}

.hvfb-story-photo img,
.hvfb-mosaic-item img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hvfb-story-photo figcaption,
.hvfb-mosaic-item figcaption {
  padding: 10px 12px;
  font-size: 15px;
  line-height: 1.35;
  background: #fff;
}

@media (max-width: 800px) {
  .hvfb-story,
  .hvfb-mosaic {
    min-height: auto;
    display: block;
    background: transparent;
    overflow: visible;
  }

  .hvfb-story-block,
  .hvfb-mosaic-item {
    position: relative;
    left: auto !important;
    top: auto !important;
    width: 100% !important;
    transform: none !important;
    margin: 0 0 18px;
  }
}
