.story-page {
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
  background: #fff;
}

.story-header {
  padding: 34px 22px 30px;
  text-align: center;
}

.story-header__eyebrow {
  margin: 0;
  color: #9b9b9b;
  font-size: 12px;
  line-height: 1.6;
  font-weight: 600;
}

.story-header__title {
  margin: 8px 0 0;
  color: #111;
  font-size: 22px;
  line-height: 1.45;
  font-weight: 800;
  word-break: keep-all;
}

.story-photo {
  padding: 0;
}

.story-photo__frame {
  display: block;
  width: 100%;
  overflow: hidden;
  position: relative;
  background: #d8d8d8;
}

.story-photo__frame.is-story-image,
.story-photo__frame.is-hero {
  aspect-ratio: 3 / 2;
}

.story-photo__frame.is-landscape {
  aspect-ratio: 16 / 9;
}

.story-photo__frame.is-portrait {
  aspect-ratio: 3 / 4;
}

.story-photo__frame.is-square {
  aspect-ratio: 1 / 1;
}

.story-photo__frame.is-free {
  aspect-ratio: auto;
}

.story-photo__frame.is-free img {
  position: static;
  width: 100%;
  height: auto;
  transform: none !important;
}

.story-photo__frame img {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform: translate(-50%, -50%) scale(1);
}

.story-dates {
  padding: 30px 22px 38px;
  text-align: center;
}

.story-dates__item + .story-dates__item {
  margin-top: 18px;
}

.story-dates__date {
  margin: 0;
  color: #111;
  font-size: 19px;
  line-height: 1.35;
  font-weight: 700;
}

.story-dates__label {
  margin: 5px 0 0;
  color: #9a9a9a;
  font-size: 12px;
  line-height: 1.5;
  font-weight: 500;
}

.preview-edit {
  padding: 42px 22px 32px;
  border-top: 1px solid #ededeb;
}

.revew-q {
  display: block;
  margin: 0 0 12px;
  color: #111;
  font-size: 14px;
  line-height: 1.75;
  font-weight: 900;
  word-break: keep-all;
}

.revew-a {
  margin-bottom: 38px;
}

.revew-a p {
  margin: 0;
  color: #777;
  font-size: 12px;
  line-height: 2;
  font-weight: 500;
  word-break: keep-all;
}

.story-ending {
  padding: 0;
}