@charset "utf-8";
html {
  margin: 0;
  padding: 0;
  overflow-y: scroll;
  height: 100%;
  font-size: 0.67vw;
  font-size: 62.5%;
  background-color: #fdac09;
  background-color: #fdac09;
}

body {
  margin: 0;
  padding: 0;
  font-family: YuGothic, "Yu Gothic medium", "Hiragino Sans", Meiryo, sans-serif;
  color: #1e2123;
  font-size: 1.4rem;
  font-feature-settings: "palt" 1;
}

ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

ul li {
  list-style: none;
  display: inline;
  margin-right: 0px;
}

header,
main,
footer {
  width: 100%;
  /*max-width: 1920px;*/
  margin: 0 auto;
}
/* リンクなど ----------------------------------------------------*/

a {
  text-decoration: underline;
}

a:link {
  text-decoration: underline;
}

a:visited {
  text-decoration: underline;
}

a:hover {
  text-decoration: none;
}

a:active {
  color: rgba(71, 71, 71, 1);
}

a img {
  transition: 0.5s;
}

a:hover img {
  opacity: 0.8;
  transition: 0.5s;
}

img {
  max-width: 100%;
  height: auto;
}
@media screen and (min-width: 598px) {
  a.tel_link {
    color: inherit;
    text-decoration: none;
  }
}

#globalHeader {
  background-color: #ffffff;
}
#globalHeader .logo {
  padding: 14px 0 12px 12px;
}

#globalHeader h1 {
  margin: 0;
  position: absolute;
  left: 50%;
  top: 8px;
  transform: translateX(-50%);
}
@media screen and (min-width: 736px) {
  #globalHeader .logo {
    padding: 18px 0 18px 12px;
  }

  #globalHeader .logo img {
    width: 190px;
    height: auto;
  }
  #globalHeader h1 {
    top: 12px;
  }
  #globalHeader h1 img {
    width: 240px;
    height: auto;
  }
}
@media screen and (max-width: 320px) {
  #globalHeader .logo img {
    width: 90px;
    height: auto;
  }
  #globalHeader h1 img {
    width: 100px;
    height: auto;
  }
}
/*　head__anime　-------------------------------------------------------*/

.head__anime {
  position: relative;
}

.bg_food {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 2;
}

.bg_base {
  position: relative;
  z-index: 0;
}

.bg_base .bg_anime {
  position: absolute;
  z-index: 4;
  left: 0px;
  bottom: -13px;
  width: 100%;
  margin-top: 77.86%;
}

.bg_base .bg_anime.anime_start {
  animation: cheeseAnime 3s ease-in-out 1s forwards;
}

@keyframes cheeseAnime {
  0% {
    transform: translateY(0);
  }

  100% {
    transform: translateY(11.3333333%);
  }
}

.text_anime {
  position: absolute;
  z-index: 4;
  left: 0px;
  top: 0;
  width: 100%;
  overflow: hidden;
}

.text_anime:before {
  content: "";
  display: block;
  padding-top: 100%;
}

.text_anime div {
  position: absolute;
  opacity: 0;
}

.text_anime div img {
  width: 100%;
  height: auto;
}
.text_anime {
  --txt_svg_large: 4.25%;
  --txt_svg_small: 3.65%;
}
.anime01 {
  width: calc(var(--txt_svg_large) * 0.8);
  top: 15.5%;
  left: 24.5%;
  z-index: 12;
  animation: textAnime 0.5s ease 1s forwards;
}

.anime02 {
  width: calc(var(--txt_svg_large) * 0.8);
  top: 13.8%;
  left: 26.3%;
  z-index: 11;
  animation: textAnime 0.5s ease 1.1s forwards;
}

.anime03 {
  width: calc(var(--txt_svg_large) * 0.8);
  top: 13%;
  left: 28.5%;
  z-index: 10;
  animation: textAnime 0.5s ease 1.2s forwards;
}

.anime04 {
  width: calc(var(--txt_svg_small) * 0.8);
  top: 12.5%;
  left: 30.6%;
  z-index: 12;
  animation: textAnime 0.5s ease 1.3s forwards;
}

.anime05 {
  width: calc(var(--txt_svg_large) * 0.8);
  top: 12%;
  left: 32.7%;
  z-index: 12;
  animation: textAnime 0.5s ease 1.4s forwards;
}

.anime06 {
  width: calc(var(--txt_svg_large) * 0.8);
  top: 12%;
  left: 35.35%;
  z-index: 12;
  animation: textAnime 0.5s ease 1.5s forwards;
}

.anime07 {
  width: calc(var(--txt_svg_small) * 0.8);
  top: 12%;
  left: 38%;
  z-index: 14;
  animation: textAnime 0.5s ease 1.6s forwards;
}

.anime08 {
  width: calc(var(--txt_svg_large) * 0.8);
  top: 16%;
  left: 28%;
  z-index: 5;
  animation: textAnime 0.5s ease 1.7s forwards;
}

.anime09 {
  width: calc(var(--txt_svg_large) * 0.8);
  top: 15%;
  left: 30.3%;
  z-index: 4;
  animation: textAnime 0.5s ease 1.8s forwards;
}

.anime10 {
  width: calc(var(--txt_svg_large) * 0.8);
  top: 14.5%;
  left: 32.5%;
  z-index: 3;
  animation: textAnime 0.5s ease 1.9s forwards;
}

.anime11 {
  width: calc(var(--txt_svg_large) * 0.8);
  top: 14.6%;
  left: 34.9%;
  z-index: 13;
  animation: textAnime 0.5s ease 2s forwards;
}

.anime12 {
  width: calc(var(--txt_svg_large) * 0.8);
  top: 14.5%;
  left: 37.2%;
  z-index: 1;
  animation: textAnime 0.5s ease 2.1s forwards;
}

.anime13 {
  width: calc(var(--txt_svg_large) * 0.8);
  top: 14.4%;
  left: 38.7%;
  z-index: 0;
  animation: textAnime 0.5s ease 2.2s forwards;
}

.anime14 {
  width: calc(925 / 1920 * 100%);
  top: 17.5%;
  left: 26%;
  z-index: -1;
  animation: textAnime 0.5s ease 2.3s forwards;
}

@keyframes textAnime {
  0% {
    opacity: 0;
    transform: translateY(100%);
  }

  90% {
    opacity: 1;
    transform: translateY(-10%);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

.page__title.pc {
  width: 100%;
  position: relative;
  z-index: 3;
  /* margin-top: -19.5%; */
}
/*
.page__title::before,
.page__title::after {
  content: "";
  width: calc(40 / 1920 * 100vw);
  height: calc(128 / 1920 * 100vw);
  background: url("../images/ico_blink01.png") center center / contain no-repeat;
  position: absolute;
  top: calc(414 / 1920 * 100vw);
  left: calc(565 / 1920 * 100vw);
}
  */
.page__title.pc img {
  margin-top: -1px;
}
@media (max-width: 736px) {
  .page__title::before,
  .page__title::after {
    width: calc(36 / 750 * 100vw);
    height: calc(124 / 750 * 100vw);
    top: calc(134 / 750 * 100vw);
    left: calc(52 / 750 * 100vw);
  }
  .page__title.smp img {
    margin-top: -2px;
  }
}
/*
.page__title::after {
  height: calc(118 / 1920 * 100vw);
  background: url("../images/ico_blink02.png") center center / contain no-repeat;
  top: calc(420 / 1920 * 100vw);
  right: calc(565 / 1920 * 100vw);
  left: auto;
}
  */
@media (max-width: 736px) {
  .page__title::after {
    top: calc(138 / 750 * 100vw);
    height: calc(114 / 750 * 100vw);
    right: calc(42 / 750 * 100vw);
  }
}

.flash::before,
.flash::after {
  animation: flash 2s 0.5s ease-in;
}
@keyframes flash {
  0% {
    opacity: 1;
  }

  25% {
    opacity: 0.25;
  }
  50% {
    opacity: 1;
  }
  75% {
    opacity: 0.25;
  }

  100% {
    opacity: 1;
  }
}

.head__movie {
  width: calc(1000 / 1440 * 100vw);
  margin: 0 auto;
  padding: 4% 0 12%;
}
.head__movie_in {
  padding-top: 56.25%;
  position: relative;
}
.head__movie_in iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.head_ill {
  text-align: center;
  margin-top: 0;
  margin-bottom: 50px;
}
@media (max-width: 736px) {
  .head_ill {
    max-width: calc(100% - 20px);
    margin-inline: auto;
  }
}
h2.title {
  width: 65.7333%;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  z-index: 10;
}

.point {
  background-image: url(../images/bg_point_pc.jpg);
  padding-top: 5%;
  text-align: center;
  background-size: 100% auto;
  background-position: center 0%;
  background-repeat: no-repeat;
  margin: calc(-220 / 1920 * 100vw) 0 0 0;
}

.point h2 {
  padding-top: 10%;
  width: 33.4375%;
  width: calc(1116 / 3840 * 100%);
}

.point__inner {
  position: relative;
  background-image: url(../images/bg_point_finish_pc.jpg);
  padding-top: 0;
  text-align: center;
  background-size: 100% auto;
  background-position: center bottom;
  background-repeat: no-repeat;
}

.point1 {
  margin-top: 1.5%;
  position: relative;
}
.point1_b {
  position: absolute;
  transform-origin: center;
}
.point1_b img {
  width: 100%;
}
.point1_b01 {
  width: calc(228 / 1920 * 100vw);
  top: calc(335 / 1920 * 100vw);
  right: calc(962 / 1920 * 100vw);
  animation: anime_move 1s linear 0s infinite alternate;
}
@media (max-width: 736px) {
  .point1_b01 {
    width: calc(257 / 750 * 100vw);
    top: calc(410 / 750 * 100vw);
    right: calc(450 / 750 * 100vw);
    animation: anime_move 1s linear 0s infinite alternate;
  }
}
.point1_b02 {
  width: calc(218 / 1920 * 100vw);
  top: calc(675 / 1920 * 100vw);
  right: calc(776 / 1920 * 100vw);
  animation: anime_move 1s linear 0.5s infinite alternate;
}
@media (max-width: 736px) {
  .point1_b02 {
    width: calc(231 / 750 * 100vw);
    top: calc(846 / 750 * 100vw);
    right: calc(54 / 750 * 100vw);
    animation: anime_move 1s linear 0.5s infinite alternate;
  }
}
@keyframes anime_move {
  from {
    transform: scale(0.9, 0.9);
  }
  to {
    transform: scale(1.1, 1.1);
  }
}

.point2 {
  margin: -4% 0 0;
}

.point3 {
  margin: 0 0 0;
}

.menu {
  /* 
  background-image: url(../images/bg_menu.jpg);
  background-repeat: repeat-y;
  background-position: center 0px;
  background-size: 100% auto;
  */
  background-color: #fdf6cc;
  position: relative;
  overflow-x: hidden;
  overflow-y: hidden;
  transform: translateY(-1px);
}

.bg_finish {
  z-index: 1;
  position: absolute;
  bottom: 0px;
  left: 0px;
  width: 100%;
  margin-bottom: -1px;
}

.menu h2 {
  width: 33.4375%;
  width: calc(1116 / 3840 * 100%);
  text-align: center;
  margin: 0 auto;
  padding-top: 15px;
}

.menu__inner {
  position: relative;
  z-index: 2;
}

.bg_spl {
  position: absolute;
  top: 0px;
  left: 0px;
}

.menu__inner .menu__inner_box {
  position: relative;
}

.menu__inner .menu__inner_box:after {
  content: "";
  display: block;
  width: auto;
}

.block01 {
  padding-top: 50%;
}

.block02 {
  padding-top: 42%;
}

.block03 {
  padding-top: 40%;
}

.block04 {
  padding-top: 47%;
}

.block05 {
  padding-top: 40%;
  padding-bottom: 22.6%;
}

.menu__inner h3 {
  position: absolute;
}

.menu__inner h3 img {
  width: 100%;
  height: auto;
}

.sub_title01 {
  width: 22.38583333%;
  top: 2.5%;
  left: 50%;
  transform: translateX(-50%);
}

.sub_title02 {
  width: 22.38583333%;
  top: 2.5%;
  left: 50%;
  transform: translateX(-50%);
}

.sub_title03 {
  width: 22.38583333%;
  top: 2.5%;
  left: 50%;
  transform: translateX(-50%);
}

.sub_title04 {
  width: 22.38583333%;
  top: 2.5%;
  left: 50%;
  transform: translateX(-50%);
}

.menu__box {
  position: absolute;
}

.menu__box img {
  width: 100%;
  height: auto;
}

.menu__box.menu01 {
  width: 28.589375%;
  top: 28%;
  right: 9%;
}

.menu__box.menu02 {
  width: 25.15%;
  top: 32%;
  left: 15%;
}

.menu__box.menu03 {
  width: 25.625%;
  top: 39%;
  left: 39%;
}

.menu__box.menu04 {
  width: 25.15%;
  top: 33%;
  left: 53%;
}

.menu__box.menu05 {
  width: 25.15%;
  top: 32%;
  left: 23%;
}

.menu__box.menu06 {
  width: 34.84375%;
  top: 21%;
  left: 17%;
}

.menu__box.menu07 {
  width: 30.72916%;
  top: 32%;
  right: 20%;
}

.menu__box.menu08 {
  width: 31.5625%;
  top: 35%;
  right: 20%;
}

.menu__box.menu09 {
  width: 32.65625%;
  top: 35%;
  left: 16%;
}

.menu__box.menu10 {
  width: 33.125%;
  top: 2%;
  left: 50%;
  transform: translateX(-50%);
}
/*  footer#globalFooter　----------------------------------------------------*/

footer#globalFooter {
  margin-top: -2px;
  text-align: center;
  position: relative;
  z-index: 2;
  background: url("../images/bg_footer_pc.jpg") top center / 100% no-repeat;
}

footer#globalFooter .product {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

footer#globalFooter .btn {
  display: flex;
  justify-content: center;
  width: calc(920 / 1920 * 100vw);
  margin-left: auto;
  margin-right: auto;
  padding-bottom: calc(120 / 1920 * 100vw);
}
footer#globalFooter .btn a {
  width: 35%;
  margin: 0 8%;
}

.copyright {
  width: 100%;
  padding-top: 22px;
  padding-bottom: 18px;
  text-align: center;
  background-color: #ffffff;
}

.copyright p {
  color: #553512;
  font-size: 12px;
  letter-spacing: 0.1rem;
}
#fnav {
  padding-top: 4rem;
  padding-bottom: 4rem;
  width: 100%;
  max-width: 1000px;
  margin-right: auto;
  margin-left: auto;
}
#fnav .flex {
  display: flex;
  justify-content: space-between;
}
#fnav .flex li {
}
#fnav a {
  color: #111111;
}
.smp {
  display: none;
}

@media (max-width: 736px) {
  .smp {
    display: block;
  }

  .pc {
    display: none;
  }

  header,
  main,
  footer {
    width: 100%;
    max-width: 736px;
    margin: 0 auto;
  }

  .bg_base .bg_anime {
    position: absolute;
    z-index: 4;
    left: 0px;
    bottom: 0px;
    width: 100%;
    margin-top: 77.86%;
  }
  .head__anime {
    overflow: hidden;
  }
  .text_anime {
    position: absolute;
    z-index: 4;
    left: 0px;
    top: 8%;
    width: 100%;
    transform: scale(1.8);
  }

  .text_anime:before {
    content: "";
    display: block;
    padding-top: 100%;
  }

  .text_anime div {
    position: absolute;
    opacity: 0;
  }

  .text_anime div img {
    width: 100%;
    height: auto;
  }
  /*
    .anime01 {
        width: calc(4.93333333% * 2.25);
        top: 46%;
        left: 0%;
        animation: textAnime 0.5s ease 1s forwards;
    }

    .anime02 {
        width: calc(4.5333333% * 2.4);
        top: 43%;
        left: 6.5%;
        animation: textAnime 0.5s ease 1.1s forwards;
    }

    .anime03 {
        width: calc(4.93333333% * 2.4);
        top: 40%;
        left: 12%;
        animation: textAnime 0.5s ease 1.2s forwards;
    }

    .anime04 {
        width: calc(3.6% * 3.2);
        top: 38%;
        left: 17.5%;
        animation: textAnime 0.5s ease 1.3s forwards;
    }

    .anime05 {
        width: calc(6.4% * 1.9);
        top: 35.5%;
        left: 23.5%;
        animation: textAnime 0.5s ease 1.4s forwards;
    }

    .anime06 {
        width: calc(5.2% * 2.1);
        top: 35%;
        left: 32%;
        animation: textAnime 0.5s ease 1.5s forwards;
    }

    .anime07 {
        width: calc(3.333333333% * 3.2);
        top: 36.5%;
        left: 38.5%;
        animation: textAnime 0.5s ease 1.6s forwards;
    }

    .anime08 {
        width: 30.5%;
        top: 49.5%;
        left: -2%;
        animation: textAnime 0.5s ease 1.7s forwards;
    }

    .anime09 {
        width: 30.5%;
        top: 47%;
        left: 18%;
        animation: textAnime 0.5s ease 1.8s forwards;
    }

    .anime10 {
        width: 27.5%;
        top: 40.5%;
        left: 36.5%;
        animation: textAnime 0.5s ease 1.9s forwards;
    }

    .anime11 {
        width: 32%;
        top: 42%;
        left: 50%;
        animation: textAnime 0.5s ease 2s forwards;
    }

    .anime12 {
        width: 30.5%;
        top: 39.5%;
        left: 67%;
        animation: textAnime 0.5s ease 2.1s forwards;
    }

    .anime13 {
			width: 18%;
			top: 40%;
			left: 85%;
			animation: textAnime 0.5s ease 2.2s forwards;
	}
*/
  .anime14 {
    /*width: calc(516 / 750 * 100vw);
		top: 64%;
		left: 16%;
		animation: textAnime 0.5s ease 2.3s forwards;
        */
    margin-top: 20%;
  }

  .page__title {
    /* width: 87.6%; */
    position: relative;
    z-index: 3;
    margin-left: auto;
    margin-right: auto;
    /* margin-top: -12%; */
    margin-bottom: calc(50 / 750 * 100vw);
  }
  .head__movie {
    width: calc(660 / 750 * 100vw);
    margin: 0 auto;
    padding: 4% 0 100px;
  }

  h2.title {
    /* width: 65.7333%; */
    width: calc(474 / 750 * 100vw);
    margin-left: auto;
    margin-right: auto;
  }

  .point {
    background-image: url(../images/bg_point.jpg);
    padding-top: 12px;
    text-align: center;
    background-size: 100% auto;
    background-position: center 0%;
    background-repeat: no-repeat;
  }

  .point h2 {
    padding-top: 16%;
  }

  .point__inner {
    position: relative;
    background-image: url(../images/bg_point_finish.jpg);
    padding-top: 0;
    text-align: center;
    background-size: 100% auto;
    background-position: center bottom;
    background-repeat: no-repeat;
  }

  .point1 {
    margin-top: 0;
  }

  .point2 {
    margin: -10% 0 0 auto;
    max-width: calc(100% - 40px);
  }

  .point3 {
    margin: 0 auto;
    padding-bottom: 12%;
    max-width: calc(100% - 42px);
  }

  .bg_finish {
    z-index: 1;
    position: absolute;
    bottom: 0px;
    left: 0px;
    width: 100%;
    margin-bottom: -1px;
  }

  .menu h2 {
    text-align: center;
    margin: 0 auto;
    padding-top: 0;
    padding-bottom: 0;
  }

  .menu__inner {
    position: relative;
    z-index: 2;
  }

  .bg_spl {
    position: absolute;
    top: 0px;
    left: 0px;
  }

  .menu__inner .menu__inner_box {
    position: relative;
  }

  .menu__inner .menu__inner_box:after {
    content: "";
    display: block;
    width: auto;
  }

  .block01 {
    padding-top: 119%;
  }

  .block02 {
    padding-top: 83.47%;
  }

  .block03 {
    padding-top: 80%;
  }

  .block04 {
    padding-top: 78.4%;
  }

  .block05 {
    padding-top: 78.8%;
    padding-bottom: 22.6%;
  }

  .menu__inner h3 {
    position: absolute;
  }

  .menu__inner h3 img {
    width: 100%;
    height: auto;
  }

  .sub_title01 {
    width: 50.333333%;
    top: 0%;
    left: 31%;
    right: auto;
  }

  .sub_title02 {
    width: 45.2%;
    top: -17%;
    left: 30%;
    right: auto;
  }

  .sub_title03 {
    width: 51.0666666%;
    top: -14%;
    right: -23%;
    left: auto;
  }

  .sub_title04 {
    width: 46.4%;
    top: -22%;
    left: 32%;
    right: auto;
  }

  .sub_title05 {
    width: 47.86666666%;
    top: -25%;
    left: 4%;
    right: auto;
  }

  .menu__box {
    position: absolute;
  }

  .menu__box img {
    width: 100%;
    height: auto;
  }

  .menu__box.menu01 {
    width: 54.5333333%;
    top: 7%;
    left: 44%;
    right: auto;
  }

  .menu__box.menu02 {
    width: 52.8%;
    top: 32%;
    left: 1%;
    right: auto;
  }

  .menu__box.menu03 {
    width: 56.93333333%;
    top: 46%;
    right: -1%;
    left: auto;
  }

  .menu__box.menu04 {
    width: 53.6%;
    top: -2%;
    right: 0%;
    left: auto;
  }

  .menu__box.menu05 {
    width: 59.47%;
    top: 32%;
    left: -2%;
    right: auto;
  }

  .menu__box.menu06 {
    width: 63.93%;
    top: 0%;
    left: 0%;
    right: auto;
  }

  .menu__box.menu07 {
    width: 62.6%;
    top: 26%;
    right: -1%;
    left: auto;
  }

  .menu__box.menu08 {
    width: 74.93%;
    top: -19%;
    right: -12%;
    left: auto;
  }

  .menu__box.menu09 {
    width: 65.4%;
    top: 26%;
    left: 0%;
    right: auto;
  }
  .menu__box.menu10 {
    width: 66.6666666%;
    top: -8%;
    left: 50%;
    transform: translateX(-50%);
    right: auto;
  }

  /*  footer#globalFooter　----------------------------------------------------*/

  footer#globalFooter {
    text-align: center;
    margin-top: -4.6%;
    position: relative;
    z-index: 2;
  }

  footer#globalFooter .product {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }

  footer#globalFooter .btn {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: calc(120 / 750 * 100vw);
    padding-left: 1%;
  }
  footer#globalFooter .btn a {
    width: 45%;
    margin: 0 4%;
  }

  .copyright {
    width: 100%;
    padding-top: 22px;
    padding-bottom: 18px;
    text-align: center;
    background-color: #ffffff;
  }

  .copyright p {
    color: #553512;
    font-size: 12px;
    letter-spacing: 0.1rem;
  }
  #fnav .flex {
    display: block;
    text-align: center;
  }
  #fnav .flex li {
    display: block;
    padding-bottom: 2rem;
  }
}

@media (max-width: 414px) {
}

@media (max-width: 320px) {
}

.menu img {
  width: 100%;
}
.menu-main {
  width: calc(1152 / 1920 * 100vw);
  height: calc(2785 / 1920 * 100vw);
  background: #feeb9f;
  border-radius: calc(100 / 1920 * 100vw);
  margin: calc(-88 / 1920 * 100vw) auto calc(85 / 1920 * 100vw);
  position: relative;
}
@media (max-width: 736px) {
  .menu-main {
    width: calc(680 / 750 * 100vw);
    height: calc(2430 / 750 * 100vw);
    border-radius: calc(40 / 750 * 100vw);
    margin: calc(-90 / 750 * 100vw) auto calc(56 / 750 * 100vw);
  }
}
.menu-main::before {
  content: "";
  width: calc(1186 / 1920 * 100vw);
  height: calc(2785 / 1920 * 100vw);
  background: linear-gradient(
    to right,
    #2f528d 0%,
    #2f528d 50%,
    #dc3f00 50%,
    #dc3f00 100%
  );
  position: absolute;
  left: calc(-18 / 1920 * 100vw);
  top: calc(-18 / 1920 * 100vw);
  border-radius: calc(114 / 1920 * 100vw);
}
@media (max-width: 736px) {
  .menu-main::before {
    width: calc(695 / 750 * 100vw);
    bottom: calc(-20 / 750 * 100vw);
    height: calc(2446 / 750 * 100vw);
  }
}
.menu-main-top {
  height: calc(2750 / 1920 * 100vw);
  background: linear-gradient(
    to right,
    #cee0e9 0%,
    #cee0e9 50%,
    #efb9ac 50%,
    #efb9ac 100%
  );
  border-radius: calc(100 / 1920 * 100vw);
  position: relative;
}
@media (max-width: 736px) {
  .menu-main-top {
    height: calc(2430 / 750 * 100vw);
    border-radius: calc(40 / 750 * 100vw);
  }
}
.menu-main-cheese {
  position: absolute;
  z-index: 11;
}
.menu-main-cheese.cheese01 {
  width: calc(508 / 1920 * 100vw);
  top: calc(14 / 1920 * 100vw);
  left: calc(50 / 1920 * 100vw);
}
.menu-main-cheese.cheese02 {
  width: calc(510 / 1920 * 100vw);
  top: calc(14 / 1920 * 100vw);
  right: calc(44 / 1920 * 100vw);
}
@media (max-width: 736px) {
  .menu-main-cheese.cheese01 {
    width: calc(337 / 750 * 100vw);
    top: calc(38 / 750 * 100vw);
    left: calc(-16 / 750 * 100vw);
  }
  .menu-main-cheese.cheese02 {
    width: calc(337 / 750 * 100vw);
    top: calc(28 / 750 * 100vw);
    right: calc(-12 / 750 * 100vw);
  }
}
.menu-main-sub {
  width: calc(280 / 1920 * 100vw);
  position: absolute;
  right: 0;
  left: 0;
  margin: auto;
}
.menu-main-sub.sub01 {
  top: calc(555 / 1920 * 100vw);
}
.menu-main-sub.sub02 {
  top: calc(1050 / 1920 * 100vw);
}
.menu-main-sub.sub03 {
  top: calc(1455 / 1920 * 100vw);
}
.menu-main-sub.sub04 {
  top: calc(1805 / 1920 * 100vw);
}
.menu-main-sub.sub05 {
  top: calc(2205 / 1920 * 100vw);
}
@media (max-width: 736px) {
  .menu-main-sub.sub01 {
    width: calc(280 / 750 * 100vw);
    top: calc(255 / 750 * 100vw);
  }
  .menu-main-sub.sub02 {
    width: calc(278 / 750 * 100vw);
    top: calc(888 / 750 * 100vw);
  }
  .menu-main-sub.sub03 {
    width: calc(286 / 750 * 100vw);
    top: calc(1286 / 750 * 100vw);
  }
  .menu-main-sub.sub04 {
    width: calc(294 / 750 * 100vw);
    top: calc(1608 / 750 * 100vw);
  }
  .menu-main-sub.sub05 {
    width: calc(286 / 750 * 100vw);
    top: calc(2002 / 750 * 100vw);
  }
}
.menu-main-img {
  position: absolute;
  z-index: 1;
}
.menu-main-img.img01 {
  width: calc(420 / 1920 * 100vw);
  top: calc(397 / 1920 * 100vw);
  left: calc(65 / 1920 * 100vw);
}
.menu-main-img.img02 {
  width: calc(408 / 1920 * 100vw);
  top: calc(398 / 1920 * 100vw);
  right: calc(61 / 1920 * 100vw);
}
.menu-main-img.img03 {
  width: calc(581 / 1920 * 100vw);
  top: calc(723 / 1920 * 100vw);
  left: calc(76 / 1920 * 100vw);
}
.menu-main-img.img04 {
  width: calc(561 / 1920 * 100vw);
  top: calc(710 / 1920 * 100vw);
  right: calc(57 / 1920 * 100vw);
}
.menu-main-img.img05 {
  width: calc(576 / 1920 * 100vw);
  top: calc(1123 / 1920 * 100vw);
  left: calc(-19 / 1920 * 100vw);
}
.menu-main-img.img06 {
  width: calc(539 / 1920 * 100vw);
  top: calc(1130 / 1920 * 100vw);
  right: calc(14 / 1920 * 100vw);
}
.menu-main-img.img07 {
  width: calc(426 / 1920 * 100vw);
  top: calc(1556 / 1920 * 100vw);
  left: calc(78 / 1920 * 100vw);
}
.menu-main-img.img08 {
  width: calc(418 / 1920 * 100vw);
  top: calc(1471 / 1920 * 100vw);
  right: calc(77 / 1920 * 100vw);
}
.menu-main-img.img09 {
  width: calc(481 / 1920 * 100vw);
  top: calc(1901 / 1920 * 100vw);
  left: calc(78 / 1920 * 100vw);
}
.menu-main-img.img10 {
  width: calc(434 / 1920 * 100vw);
  top: calc(1912 / 1920 * 100vw);
  right: calc(70 / 1920 * 100vw);
}
.menu-main-img.img11 {
  width: calc(530 / 1920 * 100vw);
  top: calc(2271 / 1920 * 100vw);
  left: calc(56 / 1920 * 100vw);
}
.menu-main-img.img12 {
  width: calc(504 / 1920 * 100vw);
  top: calc(2326 / 1920 * 100vw);
  right: calc(62 / 1920 * 100vw);
}
.menu-main-img.ill01 {
  width: calc(175 / 1920 * 100vw);
  top: calc(779 / 1920 * 100vw);
  right: calc(46 / 1920 * 100vw);
  transition-delay: 1s;
  pointer-events: none;
}
.menu-main-img.ill02 {
  width: calc(296 / 1920 * 100vw);
  top: calc(1690 / 1920 * 100vw);
  left: calc(262 / 1920 * 100vw);
  transition-delay: 1s;
  pointer-events: none;
}
@media (max-width: 736px) {
  .menu-main-img.img01 {
    width: calc(339 / 750 * 100vw);
    top: calc(279 / 750 * 100vw);
    left: calc(-12 / 750 * 100vw);
  }
  .menu-main-img.img02 {
    width: calc(326 / 750 * 100vw);
    top: calc(261 / 750 * 100vw);
    right: calc(-23 / 750 * 100vw);
  }
  .menu-main-img.img03 {
    width: calc(475 / 750 * 100vw);
    top: calc(580 / 750 * 100vw);
    left: calc(-48 / 750 * 100vw);
  }
  .menu-main-img.img04 {
    width: calc(456 / 750 * 100vw);
    top: calc(580 / 750 * 100vw);
    right: calc(-28 / 750 * 100vw);
  }
  .menu-main-img.img05 {
    width: calc(471 / 750 * 100vw);
    top: calc(950 / 750 * 100vw);
    left: calc(-80 / 750 * 100vw);
  }
  .menu-main-img.img06 {
    width: calc(422 / 750 * 100vw);
    top: calc(950 / 750 * 100vw);
    right: calc(-67 / 750 * 100vw);
  }
  .menu-main-img.img07 {
    width: calc(375 / 750 * 100vw);
    top: calc(1342 / 750 * 100vw);
    left: calc(-35 / 750 * 100vw);
  }
  .menu-main-img.img08 {
    width: calc(336 / 750 * 100vw);
    top: calc(1293 / 750 * 100vw);
    right: calc(-35 / 750 * 100vw);
  }
  .menu-main-img.img09 {
    width: calc(401 / 750 * 100vw);
    top: calc(1646 / 750 * 100vw);
    left: calc(-30 / 750 * 100vw);
  }
  .menu-main-img.img10 {
    width: calc(332 / 750 * 100vw);
    top: calc(1595 / 750 * 100vw);
    right: calc(-16 / 750 * 100vw);
  }
  .menu-main-img.img11 {
    width: calc(410 / 750 * 100vw);
    top: calc(2017 / 750 * 100vw);
    left: calc(-35 / 750 * 100vw);
  }
  .menu-main-img.img12 {
    width: calc(375 / 750 * 100vw);
    top: calc(2107 / 750 * 100vw);
    right: calc(-24 / 750 * 100vw);
  }
  .menu-main-img.ill01 {
    width: calc(355 / 1920 * 100vw);
    top: calc(1631 / 1920 * 100vw);
    right: calc(-3 / 1920 * 100vw);
  }

  .menu-main-img.ill02 {
    width: calc(252 / 750 * 100vw);
    top: calc(1182 / 750 * 100vw);
    left: calc(10 / 750 * 100vw);
  }
}
.menu-main-txt {
  width: calc(232 / 1920 * 100vw);
  position: absolute;
  right: calc(88 / 1920 * 100vw);
  bottom: calc(35 / 1920 * 100vw);
}
@media (max-width: 736px) {
  .menu-main-txt {
    width: calc(232 / 750 * 100vw);
    right: calc(25 / 750 * 100vw);
    bottom: calc(30 / 750 * 100vw);
  }
}
.menu-main-bottom {
  height: calc(100% - 2702 / 1920 * 100vw);
  background: #feeb9f;
  border-radius: 0 0 calc(100 / 1920 * 100vw) calc(100 / 1920 * 100vw);
  position: relative;
}
@media (max-width: 736px) {
  .menu-main-bottom {
    height: calc(100% - 2430 / 750 * 100vw);
    border-radius: 0 0 calc(40 / 750 * 100vw) calc(40 / 750 * 100vw);
  }
}
.menu-main-sub.other {
  width: calc(420 / 1920 * 100vw);
  top: calc(66 / 1920 * 100vw);
}
@media (max-width: 736px) {
  .menu-main-sub.other {
    width: calc(290 / 750 * 100vw);
    top: calc(56 / 750 * 100vw);
  }
}
.menu-main-img.other {
  width: 100%;
  top: calc(234 / 1920 * 100vw);
  left: 0;
}
@media (max-width: 736px) {
  .menu-main-img.other01 {
    width: 100vw;
    top: calc(170 / 750 * 100vw);
    left: calc(-35 / 750 * 100vw);
  }
  .menu-main-img.other02 {
    width: 100vw;
    top: calc(534 / 750 * 100vw);
    left: calc(-35 / 750 * 100vw);
  }
}
.menu-more {
  width: calc(1152 / 1920 * 100vw);
  height: calc(4380 / 1920 * 100vw);
  background: #fdcf09;
  border-radius: calc(100 / 1920 * 100vw);
  margin: 0 auto calc(134 / 1920 * 100vw);
  position: relative;
}
@media (max-width: 736px) {
  .menu-more {
    width: calc(680 / 750 * 100vw);
    height: calc(4750 / 750 * 100vw);
    border-radius: calc(40 / 750 * 100vw);
    margin: 0 auto calc(80 / 750 * 100vw);
  }
}
.menu-more-sub {
  position: absolute;
  right: 0;
  left: 0;
  margin: auto;
}
.menu-more-sub.sub01 {
  width: calc(496 / 1920 * 100vw);
  top: calc(70 / 1920 * 100vw);
}
@media (max-width: 736px) {
  .menu-more-sub.sub01 {
    width: calc(420 / 750 * 100vw);
    top: calc(58 / 750 * 100vw);
  }
}
.menu-more-sub.sub02 {
  width: calc(608 / 1920 * 100vw);
  top: calc(980 / 1920 * 100vw);
}
@media (max-width: 736px) {
  .menu-more-sub.sub02 {
    width: calc(468 / 750 * 100vw);
    top: calc(786 / 750 * 100vw);
  }
}
.menu-more-img {
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
}
.menu-more-img.img01 {
  width: calc(1000 / 1920 * 100vw);
  top: calc(288 / 1920 * 100vw);
}
@media (max-width: 736px) {
  .menu-more-img.img01 {
    width: 100%;
    top: calc(220 / 750 * 100vw);
  }
}
.menu-more-img.img02 {
  width: 100%;
  top: calc(1170 / 1920 * 100vw);
}
@media (max-width: 736px) {
  .menu-more-img.img02 {
    width: 100%;
    top: calc(936 / 750 * 100vw);
  }
}
.menu-more-img.img03 {
  width: 114%;
  max-width: inherit;
  top: calc(1670 / 1920 * 100vw);
  left: -4%;
}
@media (max-width: 736px) {
  .menu-more-img.img03 {
    width: 100%;
    top: calc(1865 / 750 * 100vw);
  }
}
.menu-more-img.img04 {
  width: 114%;
  max-width: inherit;
  top: calc(2470 / 1920 * 100vw);
  left: -4%;
}
@media (max-width: 736px) {
  .menu-more-img.img04 {
    width: 100%;
    top: calc(2730 / 750 * 100vw);
    left: 1%;
  }
}
.menu-more-img.img05 {
  width: 114%;
  max-width: inherit;
  top: calc(3340 / 1920 * 100vw);
  left: -4%;
}
@media (max-width: 736px) {
  .menu-more-img.img05 {
    top: calc(3727 / 750 * 100vw);
    width: 106%;
    left: 4px;
  }
}
.blink::before,
.blink::after {
  content: "";
  width: calc(40 / 1920 * 100vw);
  height: calc(128 / 1920 * 100vw);
  background: url("../images/ico_blink01.png") center center / contain no-repeat;
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc(-80 / 1920 * 100vw);
  margin: auto;
}
@media (max-width: 736px) {
  .blink::before,
  .blink::after {
    width: calc(36 / 750 * 100vw);
    height: calc(124 / 750 * 100vw);
    left: calc(-80 / 750 * 100vw);
  }
}
.blink::after {
  height: calc(118 / 1920 * 100vw);
  background: url("../images/ico_blink02.png") center center / contain no-repeat;
  right: calc(-80 / 1920 * 100vw);
  left: auto;
}
@media (max-width: 736px) {
  .blink::after {
    height: calc(114 / 750 * 100vw);
    right: calc(-80 / 750 * 100vw);
  }
}

#loader {
  width: 100vw;
  height: 100vh;
  background: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
}
/* #loader.loaded {
	animation: fadeOut 1s forwards;
} */
.loader_logo {
  height: 100px;
  position: relative;
}
@media (max-width: 736px) {
  .loader_logo {
    height: 50px;
  }
}
.loader_logo::after {
  content: "";
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.5);
  position: absolute;
  top: 0;
  left: 0;
  animation: curtain 3s forwards;
}
.loader_logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}
.loader_body {
  display: none;
}
@keyframes curtain {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(-100px);
  }
}
@media (max-width: 736px) {
  @keyframes curtain {
    from {
      transform: translateY(0);
    }
    to {
      transform: translateY(-50px);
    }
  }
}
/* @keyframes fadeOut {
	from {
		opacity: 1;
	}
	to {
		display: none;
		opacity: 0;
		z-index: -1;
	}
} */

.fadeIn,
.fadeIn_200,
.fadeIn_400,
.fadeIn_600 {
  transition: 0.8s;
  opacity: 0;
  transform: translate(0, 60px);
  -webkit-transform: translate(0, 60px);
}

.fadeIn_left {
  transition: 0.8s;
  opacity: 0;
  transform: translate(-60px, 0);
  -webkit-transform: translate(-60px, 0);
}

.fadeIn_right {
  transition: 0.8s;
  opacity: 0;
  transform: translate(60px, 0);
  -webkit-transform: translate(-60px, 0);
}
.fadeInMove {
  opacity: 1;
  transform: translate(0, 0);
  -webkit-transform: translate(0, 0);
}

/* modal */
.answer-leaflet {
  background-image: url(../images/bg_menu.jpg);
  background-repeat: repeat-y;
  background-position: center 0px;
  background-size: 100% auto;
  position: relative;
  overflow-x: hidden;
  overflow-y: hidden;
  padding: 5% 0;
  margin: -2px 0 0;
}
.answer-leaflet .btn-wrapper {
  text-align: center;
  width: 80%;
  margin: 0 auto;
  max-width: 400px;
}
@media (max-width: 736px) {
  .answer-leaflet .btn-wrapper {
    margin: 4% auto 8%;
    width: 80%;
  }
}
.answer-leaflet a {
  cursor: pointer;
}
.modal-wrapper {
  z-index: 999;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  padding: 60px 10px;
  text-align: center;
}

.modal-wrapper:not(:target) {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s, visibility 0.3s;
}

.modal-wrapper:target {
  opacity: 1;
  visibility: visible;
  transition: opacity 0.4s, visibility 0.4s;
}

.modal-wrapper::after {
  display: inline-block;
  height: 100%;
  margin-left: -0.05em;
  vertical-align: middle;
  content: "";
}

.modal-wrapper .modal-window {
  box-sizing: border-box;
  display: inline-block;
  z-index: 20;
  position: relative;
  width: 70%;
  max-width: 1200px;
  padding: 30px 30px 15px;
  border-radius: 2px;
  background: #fff;
  box-shadow: 0 0 30px rgba(0, 0, 0, 0.6);
  vertical-align: middle;
}
@media (max-width: 736px) {
  .modal-wrapper .modal-window {
    width: calc(100% - 20px);
    padding: 10px;
  }
}
.modal-wrapper .modal-window .modal-content {
  max-height: 80vh;
  overflow-y: auto;
}

.modal-overlay {
  z-index: 10;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.8);
}

.modal-wrapper .modal-close {
  z-index: 20;
  position: absolute;
  top: 0;
  right: 0;
  width: 35px;
  color: #95979c !important;
  font-size: 20px;
  font-weight: 700;
  line-height: 35px;
  text-align: center;
  text-decoration: none;
  text-indent: 0;
}

.modal-wrapper .modal-close:hover {
  color: #2b2e38 !important;
}

.fixed-banner {
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 200px;
  z-index: 99;
  transition: all 0.3s ease;
}
.fixed-banner a {
}
@media (max-width: 736px) {
  .fixed-banner {
    width: 128px;
  }
}

.mv_panel {
    position: absolute;
    top: 0;
    height: 80vh;
    width: 100%;
}
.mv_lead_l {
width: 70vw;
    top: 0vw;
    position: absolute;
    transform: translateX(-50%);
    left: 50%;
}
.mv_lead_s {
    position: absolute;
    transform: translateX(-50%);
    left: 50%;
    width: 49vw;
    top: 22vw;
}
    
.mv_title {
position: absolute;
    transform: translateX(-50%);
    left: 50%;
    width: 45vw;
    top: 41vw;
}
    
.mv_red {
    position: absolute;
    right: 11vw;
    width: 15vw;
    top: 34vw;
}
    
.mv_b {
    position: absolute;
    left: 11vw;
    width: 15vw;
    top: 34vw;
}
    

.mv_txt_image {
    position: absolute;
    right: 1vw;
    width: 14vw;
    top: 65vw;
}