html, body {
  margin: 0;
  padding: 0;
  height: 100%;
  width: 100%;
  overflow: hidden; /* スクロール防止 */
}

.main-visual {
  position: fixed;  /* 画面に固定 */
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
}

.main-image {
  width: 100%;
  height: 100%;
  object-fit: cover; /* 横画像は画面いっぱい */
  display: block;
}

/* 縦向き時は contain で全体を表示 */
@media (orientation: portrait) {
  .main-image {
    object-fit: contain;
    background-color: #fdcdb1
    ;
  }
}
