.block-text-image {
  .container {
    display: flex;
    flex-direction: column-reverse;
    gap: 30px;

    @media (min-width: 768px) {
      flex-direction: row;
      align-items: center;
      gap: calc(100% / 12);

    }
  }

  &.reverse {
    .container {
      flex-direction: column-reverse;
      gap: 30px;

      @media (min-width: 768px) {
        flex-direction: row-reverse;
        align-items: center;
        gap: calc(100% / 12);

      }
    }
  }
}

.block-text-image-content {
  width: 100%;

  @media (min-width: 768px) {
    width: calc(100% / 12 * 5 + 10px);
  }
}

.block-text-image-media {
  width: 100%;

  @media (min-width: 768px) {
    width: calc(100% / 12 * 6 - 10px);
  }
}
