@charset "utf-8";

#mv {
  position: relative;
}

.mv__copy {
  position: absolute;
  width: 4.8vw;
  top: 7vw;
  right: 11.9vw;
}

.mv__icon {
  position: absolute;
  right: 9.666vw;
    bottom: 10.9444vw;
  width: 14.72vw;
}

#about {
  padding-top: 20px;
  padding-bottom: 140px;
  position: relative;
}

.about__heading {
  max-width: 478px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 22px;
}

.about__flag {
  max-width: min(300px,20.83vw);
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 32px;
}

.about__desc {
  text-align: center;
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 2.3;
}

.bg01 {
  position: absolute;
  bottom: 0;
}

#open {
  background-image: url(../imgs/index/open_bg.png);
  background-size: 100% 100%;
  background-position-y: top;
  background-position-x: center;
  padding-top: 20px;
  padding-bottom: 140px;
  position: relative;
}

.open__flag {
  max-width: min(300px,20.83vw);
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 32px;
}

.open__list {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 50px;
}

.open__list-item {
  display: flex;
  flex-direction: column;
  width: 28.6%;
}

.open__list-date{
  width: 100%;
  font-size: 14px;
  letter-spacing: 0.05em;
  line-height: 1.81;
  background-color: #fff89b;
  text-align: center;
}
.open__desc {
  font-weight: 500;
  text-align: center;
  font-size: 15px;
  margin-bottom: 50px;
  letter-spacing: 0.08em;
  line-height: 1.86;
}

.open__appWrap{

}
.open__app {
  display: block;
  max-width: 350px;
  margin-left: auto;
  margin-right: auto;
  transition: opacity 0.3s;
}
.open__app:first-child {
  margin-bottom: 20px;
}
.open__app02{
  max-width: 390px;
}


.open__app:hover {
  opacity: 0.8;
}

.open__heading {
  margin-bottom: 40px;
  max-width: 587px;
  margin-left: auto;
  margin-right: auto;
}
.open__heading--typ02 {
  max-width:  100%;
  /* width: 85%; */
  /* width: 36.11vw; */
}

.open__list-ph {
  margin-bottom: 14px;
}

.open__list-btn {
  display: block;
  transition: opacity 0.3s;
  width: 81%;
  margin-left: auto;
  margin-right: auto;
  /* margin-top: auto; */
}

.open__list-btn.mg-btm {
  margin-bottom: 15px;
}

.open__list-btn:hover {
  opacity: 0.8;
}

.bg02 {
  position: absolute;
  bottom: -1px;
}

#news {
  padding-bottom: 120px;
  position: relative;
}

#footer {
}

#stamp {
  position: relative;
  padding-top: 80px;
  padding-bottom: 80px;
  background: url("../imgs/index/stamp_bg.png") center center / cover no-repeat;
}

.stamp__heading {
  max-width: 640px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 30px;
  position: relative;
}

.stamp__desc {
  font-size: 18px;
  font-family: "Zen Maru Gothic", serif;
  font-weight: 900;
  text-align: center;
  line-height: 1.66;
}

.stamp__btn {
  display: block;
  max-width: 233px;
  margin-left: auto;
  margin-right: auto;
  margin-top: 30px;
}

.stamp__phone {
  position: absolute;
  top: 18px;
  right: -84px;
  max-width: 76px;
}

.stamp__deco {
  width: 311px;
  position: absolute;
  bottom: 30px;
  right: 180px;
}

#trip {
  min-height: 409px;
  background: #fabe00 url(../imgs/index/trip_back.png?20240919);
  background-size: cover;
  background-position: center center;
  padding-top: 125px;
  padding-bottom: 50px;
}

.trip__heading-wrap {
  position: relative;
}

.trip__heading {
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 3vw;
}

.trip__list {
  display: flex;
  justify-content: space-between;
  margin-left: auto;
  margin-right: auto;
}

.trip__list-item {
  width: 31.5%;
}

.trip__list-ph {
  margin-bottom: 18px;
}

.trip__list-btn {
  width: 79%;
  margin-left: auto;
  margin-right: auto;
  transition: opacity 0.3s;
  display: block;
}

.trip__list-btn.mg-btm {
  margin-bottom: 15px;
}

.trip__list-btn:hover {
  opacity: 0.8;
}

.trip__deco {
  width: 291px;
  position: absolute;
  bottom: -20px;
  right: -110px;
}

#alacarte {
  padding-top: 100px;
  padding-bottom: 100px;
  background-image: url(../imgs/index/alacarte_back.png);
  background-size: cover;
  background-position: center;
}

.alacarte__book {
  width: 100%;
  height: 456px;
  background-image: url(../imgs/index/alacarte_book.png?20230831);
  background-position: center center;
  background-size: 100% 100%;
  padding-top: 70px;
  padding-left: 58px;
  padding-right: 58px;
  margin-left: auto;
  margin-right: auto;
  position: relative;
}

.alacarte__book-heading {
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 40px;
}

.alacarte__book-obj {
  position: absolute;
  left: 64px;
  top: 38px;
  width: 137px;
  height: auto;
}

.alacarte__list {
  margin-left: auto;
  margin-right: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.alacarte__list-item {
  width: 23%;
}

.alacarte__list-ph {
  margin-bottom: 8px;
}

#recipe {
  padding-top: 100px;
  padding-bottom: 100px;
  background: url("../imgs/index/recipe_bg.png") top center / contain no-repeat;
  position: relative;
}
/* .recipe__bg {
  position: absolute;
  top: 0;
  left: 0;
} */

.recipe__heading {
  width: 60%;
  max-width: 587px;
  margin: 0 auto 20px;
}

.recipe__desc {
  letter-spacing: 0.06em;
  font-family: "Zen Maru Gothic", serif;
  font-weight: 900;
  line-height: 1.5;
  font-size: 18px;
  text-align: center;
  margin-bottom: 34px;
  line-height: 1.75;
}
.recipe__desc--link {
  text-decoration: underline;
  color: #d74715;
}
.recipe__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 30px 0;
}

.recipe__list-item {
  width: 32%;
}

.recipe__list-ph {
  margin-bottom: 16px;
}

.recipe__list-btn {
  display: block;
  transition: opacity 0.3s;
  width: 80%;
  margin-left: auto;
  margin-right: auto;
}

.recipe__list-btn:hover {
  opacity: 0.8;
}

#material {
  background-color: #f4e3bc;
  background-image: url(../imgs/index/material_bg.png?20240920);
  background-size: cover;
  min-height: 328px;
  padding-top: 34px;
  padding-bottom: 134px;
  position: relative;
}

#material a {
  font-family: "Zen Maru Gothic", serif;
  font-weight: 900;
  transition: opacity 0.3s;
}

#material a:hover {
  opacity: 0.8;
}

.material__btns {
  display: flex;
  justify-content: center;
  gap: 10% 20px;
  max-width: 590px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 8px;
}

.material__btns-item {
  width: 47%;
}

.material__box {
  width: 100%;
  max-width: 1030px;
  padding-top: 64px;
  padding-bottom: 64px;
  padding-left: 10%;
  padding-right: 10%;
  margin: 0 auto;
  min-height: 399px;
  background-image: url(../imgs/index/material_box.png?20240920);
  background-size: 100% 100%;
}

.material__box-heading {
  width: 73%;
  max-width: 548px;
  margin-bottom: 14px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 16px;
}

.material__txt {
  font-size: 18px;
  font-family: "Zen Maru Gothic", serif;
  font-weight: 900;
  text-align: center;
  margin-bottom: 28px;
  line-height: 1.6;
}

.material__btn {
  display: block;
  max-width: 409px;
  margin-left: auto;
  margin-right: auto;
}

.material__kiyaku {
  text-align: center;
  margin-bottom: 24px;
  font-size: 13px;
}

#topic {
  padding-top: 20px;
  background: #87c7cc;
}

.topic__btn {
  display: block;
  width: 19vw;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  bottom: 5.97vw;
}

.topic__btn:hover {
  opacity: 0.8;
}

@media screen and (min-width: 1080px) {
  #trip {
    min-height: 797px;
  }
}

@media screen and (max-width: 1440px) {
  .stamp__deco {
    width: 21.666vw;
    position: absolute;
    bottom: 2.083vw;
    right: 12.5vw;
  }

  .trip__deco {
    width: 20.208vw;
    position: absolute;
    bottom: -1.388vw;
    right: -7.638vw;
  }
}

@media screen and (max-width: 1280px) {
  .trip__deco {
    width: 15.208vw;
    right: 0;
  }
}

@media screen and (max-width: 1080px) {
  #trip {
    padding-top: 11.111vw;
  }

  .alacarte__book {
    height: 41.74vw;
    padding-top: 6.48vw;
    padding-left: 5.8vw;
    padding-right: 5.8vw;
  }

  .alacarte__book-obj {
    position: absolute;
    left: 5.9vw;
    top: 3.5vw;
    width: 12.6vw;
    height: auto;
  }

  .alacarte__book-heading {
    margin-bottom: 3.703vw;
  }
}

@media screen and (max-width: 860px) {
  .stamp__phone {
    position: static;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 20px;
  }
}

@media screen and (max-width: 768px) {
  body {
    padding-bottom: 11.979vw;
  }

  #mv{
    margin-bottom: 60px;
  }
  .mv__icon{
    width: 39.25vw;
    max-width: 212px;
    bottom: -20px;
    right:auto;
    left:50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	-moz-transform: translateX(-50%);
	-o-transform: translateX(-50%);

  }

  #news {
    padding-bottom: 80px;
  }

  #about {
    padding-bottom: 12.777vw;
  }

  .about__flag{
    max-width: 150px;
  }

  #open {
    background-size: 1440px 100%;
    /* padding-top: 100px; */
    padding-bottom: 100px;
  }

  .open__list {
    flex-wrap: wrap;
    justify-content: center;
    gap: 35px 25px;
  }

  .open__list-item {
    width: 150px;
  }

  .open__list-btn.mg-btm {
    margin-bottom: 7px;
  }

  .open__app {
    width: 70%;
  }
  .open__app02 {
    width: 78%;
  }

  .about__desc {
    font-size: 14px;
  }

  .open__desc {
    font-size: 14px;
  }

  .open__flag{
    max-width: 150px;
  }

  .open__list-date{
    font-size: 12px;
    line-height: 1.5;
  }

  .stamp__desc {
    font-size: 14px;
  }
  .stamp__deco {
    bottom: 150px;
    right: 20px;
  }

  #trip {
    height: auto;
    padding-bottom: 10vw;
  }

  .trip__heading {
    max-width: 80%;
  }

  .trip__list {
    max-width: 100%;
    flex-wrap: wrap;
    justify-content: center;
    gap: 20px 3%;
  }

  .trip__list-item {
    width: 47%;
  }

  .trip__list-btn.mg-btm {
    margin-bottom: 7px;
  }

  #alacarte {
    padding-top: 50px;
    padding-bottom: 50px;
  }

  .alacarte__list {
    gap: 20px 0;
  }

  .alacarte__list-item {
    width: 46%;
  }

  .alacarte__book {
    padding-top: 30vw;
    padding-bottom: 30vw;
    height: auto;
    padding-left: 10%;
    padding-right: 10%;
  }

  .alacarte__book-obj {
    top: 15vw;
    width: 18vw;
  }

  #recipe {
    padding-top: 13%;
    padding-bottom: 13%;
  }

  .recipe__list {
    justify-content: center;
    gap: 20px 4%;
  }

  .recipe__desc {
    font-size: 14px;
  }

  .recipe__list-item {
    width: 48%;
  }

  #material {
    padding-bottom: 94px;
  }

  .material__txt {
    font-size: 14px;
  }

  .material__box {
    min-height: auto;
    padding-top: 64px;
    padding-bottom: 64px;
    background-size: cover;
    background-position: center center;
  }

  /* .material__box-heading {
    width: 100%;
  } */

  .material__btn {
    max-width: 80%;
  }

  .material__btns-item {
    width: 65%;
  }

  #topic {
    padding-top: 20px;
  }

  .topic__btn {
    width: 36.66vw;
  }
}

@media screen and (max-width: 480px) {
  .stamp__deco {
    width: 104px;
    bottom: 10px;
    right: 10px;
  }
}
