.header {
  position: absolute;
  right: 0;
  left: 0;
  z-index: 10px;
  color: #fff;
}

.header_item::after {
  background: #fff;
}

.mv {
  position: relative;
  z-index: -10;
  width: 100%;
  height: 800px;
}

.mv_image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  opacity: 0;
  animation: slider-1 24s linear infinite;
}

.mv_image:nth-child(1) {
  background-image: url(../image/mv_1.jpg);
  animation-delay: -2s;
}

.mv_image:nth-child(2) {
  background-image: url(../image/mv_2.jpg);
  animation-delay: 4s;
}

.mv_image:nth-child(3) {
  background-image: url(../image/mv_3.jpg);
  animation-delay: 10s;
}

.mv_image:nth-child(4) {
  background-image: url(../image/mv_4.jpg);
  animation-delay: 16s;
}

@keyframes slider-1 {
  0% {
    opacity: 0;
    /* transform: scale(1); */
  }

  4.16% {
    opacity: 1;
  }

  25% {
    opacity: 1;
  }

  33.33% {
    opacity: 0;
    /* transform: scale(1.2); */
  }

  100% {
    opacity: 0;
  }
}

.mv_maintitle,
.mv_subtitle {
  position: absolute;
  bottom: 10%;
  left: 2%;
  color: #fff;
  text-align: left;
  font-weight: bold;
  font-size: 20px;
  font-family: 'Noto Serif JP', serif;
}

.mv_subtitle {
  bottom: 8%;
}

.mv::before {
  content: '';
  position: absolute;
  right: 4%;
  bottom: 50px;
  z-index: 40;
  display: inline-block;
  width: 150px;
  height: 150px;
  background-image: url(../image/downscroll.png);
  background-position: center;
  background-repeat: no-repeat;
  animation: rotation 20s linear infinite;
}

@keyframes rotation {
  0% {
    transform: rotate(0);
  }

  100% {
    transform: rotate(360deg);
  }
}

.mv::after {
  content: '';
  position: absolute;
  right: 4%;
  z-index: 40;
  display: inline-block;
  width: 150px;
  height: 40px;
  background-image: url(../image/arrow.png);
  background-position: center;
  background-repeat: no-repeat;
  animation: arrowmove 1.2s ease-in-out infinite;
}

@keyframes arrowmove {
  0% {
    bottom: 90px;
  }

  50% {
    bottom: 110px;
  }

  100% {
    bottom: 90px;
  }
}

/* ABOUT */
.about {
  position: relative;
  padding-top: 110px;
  padding-bottom: 160px;
}

.about_group {
  width: 55%;
}

.about_subtitle {
  margin-top: 53px;
}

.about_text {
  margin-top: 37px;
  font-family: 'Noto Sans JP', sans-serif;
  line-height: 2.2;
}

.about_image_first {
  margin-left: 13%;
  max-width: 298px;
}

.about_image_second {
  width: 68%;
}

.pizza_illust {
  position: absolute;
  top: 30%;
  right: 0;
  z-index: 30;
  width: 300px;
}

.about_wrapper {
  display: flex;
  align-items: end;
  margin-bottom: 90px;
}

.about::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  z-index: -20;
  display: block;
  max-width: 50px;
  width: 4vw;
  height: 670px;
  background: #309a35;
}

.pasta_illust {
  position: absolute;
  bottom: 45px;
  left: 0;
  z-index: 30;
  width: 280px;
}

.about_image_thirdbox {
  position: absolute;
}

.about_image_third {
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 30;
  width: 25%;
}

/* FEATURES */

.features {
  position: relative;
  padding-top: 80px;
  padding-bottom: 95px;
  background-image: url(../image/backtexture.jpg);
  background-repeat: repeat;
}

.features_wrapper {
  box-sizing: border-box;
}

.features_jp_title {
  color: #6e6049;
  text-align: center;
  text-transform: uppercase;
  font-weight: 800;
}

.wine_illust {
  position: absolute;
  top: 36%;
  right: 0;
  z-index: 60;
  max-width: 255px;
  width: 15%;
}

.features_wrapper {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 100px;
  color: #fff;
}

.features_image {
  position: relative;
  z-index: 30;
  display: block;
  max-width: 502px;
  width: 100%;
}

.features_wrapper:first-of-type {
  margin-top: 70px;
}

.features_subtitle {
  position: relative;
  z-index: 30;
  margin-top: 20px;
  font-weight: bold;
  font-size: 24px;
}

.features_text {
  margin-top: 30px;
  max-width: 447px;
  font-family: 'Noto Sans JP', sans-serif;
}

.features_group {
  position: relative;
  margin-left: 2%;
  max-width: 447px;
}

.features_second {
  margin-right: 2%;
  margin-left: 0;
}

.reasonable_image {
  position: absolute;
  top: -10%;
  z-index: 10;
  margin-left: 44%;
  max-width: 370px;
  width: 24vw;
}

.special_image {
  position: absolute;
  top: -10%;
  z-index: 10;
  margin-left: 39%;
  max-width: 370px;
  width: 22vw;
}

.homely_image {
  position: absolute;
  top: -10%;
  z-index: 10;
  margin-left: 52%;
  max-width: 370px;
  width: 18vw;
}

.features_reverse {
  flex-direction: row-reverse;
}

.features_title {
  position: absolute;
  top: 20%;
  z-index: 10;
  height: 1044px;
  color: #fdfdfd;
  font-size: min(8vw, 128px);
  line-height: .6;
  opacity: 20%;

  writing-mode: vertical-rl;
}

.features_button {
  margin-top: 90px;
  color: #fff;
}

.white_button::before {
  background-image: url(../image/white_circle.png);
}

.white_button::after {
  background-image: url(../image/white_arrow.png);
}

/* メニュー */

.topmenu {
  position: relative;
  padding-top: 120px;
  padding-bottom: 120px;
}

.topmenu::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  z-index: -20;
  display: block;
  width: 21vw;
  height: 82%;
  background: #309a35;
}

.topmenu_wrapper {
  position: relative;
  display: flex;
  align-items: center;
}

.topmenu_title {
  text-align: center;
}

.topmenu_subtitle {
  font-size: min(2vw, 28px);
  line-height: 1.5;
}

.topmenu_group {
  margin-right: 3%;
  margin-left: 10%;
  max-width: 448px;
  width: 60%;
}

.topmenu_text {
  margin-top: 23px;
  font-size: min(1.2vw, 16px);
  font-family: 'Noto Sans JP', sans-serif;
}

.halfpizza_illust {
  position: absolute;
  top: 60px;
  left: 0;
  z-index: -10;
  max-width: 410px;
  width: 30%;
}

.winebottle_illust {
  position: absolute;
  bottom: 5%;
  left: 2%;
  max-width: 148px;
  width: 13%;
}

.swiper {
  margin-right: 0;
}

.menu_swiper {
  position: relative;
  right: 0;
  z-index: 50;
  padding-top: 60px;
  padding-bottom: 60px;
}

.menu_cursor {
  position: relative;
  right: -70%;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: -18px;
  min-width: 130px;
  width: 130px;
  height: 2.4rem;
}

.menu_br {
  display: none;
}

/* 前へ次への矢印カスタマイズ */
.menu-prev,
.menu-next {
  width: 28px;
  height: 28px;
  border: 1px solid #fff;
  border-radius: 50%;
}

/* 前への矢印カスタマイズ */
.swiper-button-prev::after {
  content: '';
  width: 16px;
  height: 16px;
  background-image: url(../image/sumall_arrow_next.png);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  transform: scale(-1, 1);
}

/* 次への矢印カスタマイズ */
.swiper-button-next::after {
  content: '';
  width: 16px;
  height: 16px;
  background-image: url(../image/sumall_arrow_next.png);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}

.menu-pagination {
  top: -1px;
  left: 35%;
  width: 40px;
  color: #fff;
}

.swiper-slide {
  width: 100%;
  height: auto;
}

.topmenu_button {
  margin-top: 30px;
}

/* インスタグラム */

.instagram_image {
  position: relative;
  z-index: -10;
}

.instagram_wrapper {
  z-index: -20;
  margin-top: -12%;
  margin-right: auto;
  margin-left: auto;
  padding-top: 80px;
  padding-bottom: 80px;
  max-width: 910px;
  width: 90%;
  background-image: url(../image/backtexture.jpg);
  background-repeat: repeat;
  text-align: center;
}

.instagram_title {
  position: relative;
  margin: 0 auto;
  width: 289px;
  color: #6e6049;
  text-align: center;
  text-transform: uppercase;
  font-weight: 800;
  font-size: 42px;
  line-height: 1;
}

.instagram_title::after {
  content: '';
  position: absolute;
  margin-left: 20px;
  max-width: 250px;
  width: 78%;
  height: 170px;
  background-image: url(../image/Check.png);
  background-size: contain;
  background-repeat: no-repeat;
}

.instagram_text {
  margin-top: 30px;
  font-family: 'Noto Sans JP', sans-serif;
}

.lightwidget {
  margin-right: auto;
  margin-left: auto;
  width: 90%;
}

.lightwidget iframe {
  margin-top: 30px;
  max-width: 690px;
}

.instagram_button {
  margin-top: 45px;
}

.instagram_link {
  position: relative;
}

.instagram_link::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #333;
  transition: transform .3s;
  transform: scale(0, 1);
  transform-origin: left top;
}

.instagram_link:hover::after {
  transform: scale(1, 1);
}

@media (max-width: 768px) {
  .hamburger_bar {
    background-color: #fff;
  }

  .hamburger_bar.headerColorScroll {
    background-color: #333;
  }

  .show.header {
    filter: none;
  }

  .mv {
    height: 600px;
  }

  .mv_maintitle {
    width: 70%;
  }

  .mv_subtitle {
    font-size: 16px;
  }

  .mv_maintitle,
  .mv_subtitle {
    left: 3%;
  }

  .mv_image:nth-child(1) {
    background-image: url(../image/mv_sp_1.jpg);
  }

  .mv_image:nth-child(2) {
    background-image: url(../image/mv_sp_2.jpg);
  }

  .mv_image:nth-child(3) {
    background-image: url(../image/mv_sp_3.jpg);
  }

  .mv_image:nth-child(4) {
    background-image: url(../image/mv_sp_4.jpg);
  }

  /* ABOUT */
  .about {
    padding-top: 60px;
    padding-bottom: 90px;
  }

  .about::before {
    height: 550px;
  }

  .about_wrapper {
    align-items: center;
    flex-direction: column;
    margin-bottom: 18px;
  }

  .about_group {
    width: auto;
    text-align: center;
  }

  .about_subtitle {
    margin-top: 40px;
  }

  .about_text {
    margin-right: auto;
    margin-left: auto;
    max-width: 500px;
    text-align: left;
  }

  .about_image_firstbox {
    text-align: center;
  }

  .about_image_first {
    margin-left: 40%;
    width: 70%;
  }

  .pizza_illust {
    top: 36%;
    width: 200px;
  }

  .about_image_third {
    width: 29%;
  }

  .pasta_illust {
    bottom: 45px;
    width: 140px;
  }

  /* FEATURES */
  .features {
    padding-top: 60px;
    padding-bottom: 60px;
  }

  .features_wrapper {
    flex-direction: column-reverse;
    margin-top: 80px;
  }

  .features_wrapper:first-of-type {
    margin-top: 55px;
  }

  .features_image {
    margin-right: auto;
    margin-left: auto;
  }

  .features_text {
    margin-top: 25px;
  }

  .features_group {
    margin-bottom: 40px;
    margin-left: 0;
  }

  .features_second {
    margin-right: auto;
    margin-left: auto;
  }

  .reasonable_image {
    top: -10%;
    margin-left: 44%;
    width: 45vw;
  }

  .special_image {
    margin-left: 39%;
    width: 40vw;
  }

  .homely_image {
    width: 36vw;
  }

  .wine_illust {
    top: 45%;
    width: 20%;
  }

  .features_button {
    margin-top: 55px;
  }

  /* INSTAGRAM */

  .instagram_title {
    font-size: 28px;
  }

  .instagram_wrapper {
    padding-top: 40px;
    padding-bottom: 40px;
  }

  .instagram_text {
    margin-top: 24px;
  }

  .instagram_title::after {
    top: 70px;
    margin-left: -10px;
    width: 60%;
  }

  .instagram_button {
    margin-top: 30px;
  }

  /* メニュー */

  .topmenu {
    padding-top: 60px;
    padding-bottom: 60px;
  }

  .topmenu_wrapper {
    align-items: center;
    flex-direction: column;
    margin-top: 40px;
  }

  .topmenu_group {
    margin-right: 0;
    margin-left: 0;
    max-width: 500px;
    width: 93%;
  }

  .topmenu_subtitle {
    font-size: 20px;
  }

  .topmenu_text {
    font-size: 16px;
  }

  .halfpizza_illust {
    position: absolute;
    top: 60px;
    left: 0;
    z-index: -10;
    width: 35%;
  }

  .topmenu::before {
    width: 10%;
  }

  /* Swiper */

  .menu_swiper {
    margin-left: 5%;
    padding-top: 0;
    padding-bottom: 0;
  }

  .topmenu_button {
    margin-top: 50px;
  }

  .menu_cursor {
    position: static;
    display: block;
  }

  .swiper-wrapper {
    padding-bottom: 40px;
  }

  .menu-prev,
  .menu-next {
    display: none;
  }

  .swiper-pagination-bullet {
    background-color: #9e876a;
  }
}

@media (max-width: 500px) {
  .about_image_first {
    width: 40%;
  }

  .pizza_illust {
    top: 385px;
    width: 120px;
  }

  .about_image_second {
    width: 66%;
  }

  .about_image_third {
    width: 29%;
  }

  .reasonable_image {
    top: -10%;
    margin-left: 30%;
    width: 60vw;
  }

  .special_image {
    top: -15%;
    margin-left: 30%;
    width: 55vw;
  }

  .homely_image {
    top: -14%;
    margin-left: 40%;
    width: 50vw;
  }

  .wine_illust {
    top: 49%;
    width: 25%;
  }

  .topmenu_subtitle {
    text-align: center;
  }

  .menu_br {
    display: block;
  }

  .instagram_title::after {
    top: 90px;
    margin-left: -30px;
    width: 35%;
  }

  .instagram_button {
    margin-right: 6%;
  }

  .topmenu::before {
    width: 5%;
  }

  .mv_maintitle {
    width: 85%;
  }

  .mv_subtitle {
    font-size: 14px;
  }

  .mv::before {
    bottom: 146px;
    width: 27%;
    background-size: contain;
  }

  .mv::after {
    right: 16%;
    width: 3%;
    height: 3%;
    background-size: contain;
  }

  @keyframes arrowmove {
    0% {
      bottom: 198px;
    }

    50% {
      bottom: 213px;
    }

    100% {
      bottom: 198px;
    }
  }

  .winebottle_illust {
    bottom: 5%;
    width: 22%;
  }
}