/* 2列のレイアウト */
.type3,
.type4,
.type5 {
  display: flex;
  gap: 1rem;
  justify-content: space-between;
  flex-wrap: wrap;
}
.type3 div,
.type4 div,
.type5 div {
  flex-basis: 0;
}

/* レイアウト4は逆順になる */
.type4 {
  flex-direction: row-reverse;
}

/* 画像は必ず横幅100% */
.type2 img,
.type3 img,
.type4 img,
.type5 img {
  width: 100%;
}

@media only screen and (max-width: 940px) {
  .type4 {
    flex-wrap: wrap-reverse;
  }

  .type1 > div,
  .type2 > div,
  .type3 > div,
  .type4 > div,
  .type5 > div {
    flex-basis: auto;
    width: 100%;
  }
}
