@charset "UTF-8";
.Hero {
  display: flex;
  position: relative;
  width: 100vw;
  justify-content: center;
  align-items: center;
  font-size: 0px;
  padding: 0;
  margin: 0;
  height: 100vh;
  height: 100dvh
}

@supports (-webkit-touch-callout: none) {
  .Hero {
    height: -webkit-fill-available
  }
}

.Hero_vi {
  display: block;
  position: absolute;
  font-size: 0px;
  margin: 0;
  padding: 0;
  z-index: 3;
  animation-name:fadeInAnime-Hero_vi;
  animation-duration:3s;
  animation-fill-mode:forwards;
  opacity:0;
}
  
@keyframes fadeInAnime-Hero_vi{
  0% {
    opacity: 0;
  }
  50% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

.Hero .Vi {
  display: block;
  position: relative;
  fill: #fff
}

.Hero .Vi {
  width: 330.56px;
  height: 67.67px
}
@media screen and (max-width: 1024px) {
  .Hero .Vi {
    width: 200.61px;
    height: 41.07px
  }
}

.Hero_slide {
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  transition: opacity .6s ease-out 0s;
  will-change: opacity
}

.Hero_slide.-hidden {
  opacity: 0
}

.Hero_slide.-opened {
  opacity: 1
}

.Slide {
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0px;
  right: 0px;
  bottom: 0px;
  left: 0px;
  font-size: 0px;
  letter-spacing: 0em;
  margin: 0;
  padding: 0
}

.Slide_show {
  display: block;
  position: absolute;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: 50% 50%;
  opacity: 0;
  transition: opacity 2s ease-in-out 0s
}
.Slide.slides {
  display: block;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: 50% 50%;
  opacity: 1;
  animation: first-previw-none 0.5s ease-in 6s forwards;
}
@keyframes first-previw-none {
  to {
    background: none;
  }
}

.flex-direction-nav .flex-nav-prev a{
  position: absolute;
  top: 0;
  left: 0;
  width: 50%;
  height: 100%;
  z-index: 2;
}
.flex-direction-nav .flex-nav-next a{
  position: absolute;
  top: 0;
  right: 0;
  width: 50%;
  height: 100%;
  z-index: 2;
}


.Hero_enter {
  display: block;
  position: absolute;
  z-index: 1;
  bottom: 0px;
  animation-name:fadeInAnime-Hero_enter;
  animation-duration:4s;
  animation-fill-mode:forwards;
  opacity:0;
}

@keyframes fadeInAnime-Hero_enter{
  0% {
    opacity: 0;
  }
  80% {
    opacity: 0;
  }
  100% {
      opacity: 1;
  }
}

.Enter {
  display: flex;
  position: relative;
  width: 50px;
  justify-content: center
}

.Enter_label {
  display: none;
  position: absolute;
  top: 0px
}

.L .Enter {
  height: 120px;
  bottom: -60px
}

.S .Enter {
  height: 84px;
  bottom: -42px
}
.Enter_bar {
  display: block;
  position: absolute;
  font-size: 0px;
  width: .6px;
}

.L .Enter_bar {
  height: 120px
}
.S .Enter_bar {
  height: 84px
}

.Enter_bar.-top {
  height: 50%;
  background-color: #FFFFFF;
  z-index: 3;
  animation: scrollDown-top 4s ease infinite;
}

.Enter_bar.-bottom {
  height: 50%;
  bottom: 0;
  background-color: #b9b9b9;
  z-index: 2;
  animation: scrollDown-bottom 4s ease infinite;
}

.Enter{
}

@keyframes scrollDown-top{
  0%{
      transform-origin: top;
      transform: scaleY(0);
  }
  10%{
      transform-origin: top;
      transform: scaleY(1);
  }
  40%{
      transform-origin: top;
      transform: scaleY(1);
  }
  60%{
      transform-origin: bottom;
      transform: scaleY(1);
  }
  70%{
      transform-origin: bottom;
      transform: scaleY(0);
  }
  100%{
      transform-origin: bottom;
      transform: scaleY(0);
  }
}
@keyframes scrollDown-bottom{
  0%{
      transform-origin: top;
      transform: scaleY(0);
  }
  5%{
      transform-origin: top;
      transform: scaleY(0);
  }
  16%{
      transform-origin: top;
      transform: scaleY(1);
  }
  60%{
      transform-origin: bottom;
      transform: scaleY(1);
  }
  66%{
      transform-origin: bottom;
      transform: scaleY(1);
  }
  76%{
      transform-origin: bottom;
      transform: scaleY(0);
  }
  100%{
      transform-origin: bottom;
      transform: scaleY(0);
  }
}

.L .Section.-story {
  padding-top: 173px;
  padding-bottom: 180px
}

.S .Section.-story {
  padding-top: 90px;
  padding-bottom: 148px
}
.Story {
  display: block;
  position: relative
}
.Story_body {
  padding-top: 43px
}
.S .Story_body{
  padding-top: 19px;
  padding-left: 30px;
  padding-right: 30px
}
.Section.-concept {
  background-repeat: no-repeat;
  background-size: cover;
}
.L .Section.-concept {
  padding-top: 146px;
  padding-bottom: 150px;
  background-size: cover;
  background-repeat: no-repeat;
}

.S .Section.-concept {
  padding-top: 115px;
  padding-bottom: 202px
}
.Concept {
  display: block;
  position: relative;
}

.Concept_heading {
  color: #FFFFFF;
}
.Concept_body {
  padding-top: 45px;
  color: #FFFFFF;
}
.S .Concept_body{
  padding-top: 29px;
  padding-left: 30px;
  padding-right: 30px;
}
.L .Content {
  display: flex;
  position: relative;
  justify-content: center;
  align-items: flex-start;
  padding: 180px 6.25vw 0px 6.25vw
}
.L .Content.no-margin {
  padding-top: 0
}
.L .Section.-content {
  padding-top: 21px;
  padding-bottom: 159px;
  background-size: cover;
  background-repeat: no-repeat;
}

.S .Section.-content {
  padding-top: 90px;
  padding-bottom: 58px
}
.L .Content_text {
  display: block;
  position: relative;
  width: 46.15384615384615%;
  padding-left: 0;
}

.L .Content_figure {
  display: block;
  position: relative;
  width: 55.5%;
  padding-top: 42%
}

.L .Content_figure img {
  display: block;
  position: absolute;
  width: 100%;
  top: 0px;
  left: 0px
}

.L .Content_heading, .L .Content_body {
  display: block;
  text-align: left;
}
.L .Content_body {
  padding-top: 48px;
  padding-right: 45px
}
.L .Content_button {
  display: block;
  text-align: left;
  padding: 45px 0 0 0;
}

.S .Content {
  display: block;
  position: relative;
  padding-top: 60px
}
.S .Content.no-margin {
  padding-top: 0
}
.S .Content_text {
  display: block;
  position: relative;
  width: 100%
}

.S .Content_figure {
  display: block;
  position: relative;
  width: 100%;
  margin: 0 auto
}

.S .Content_figure img {
  display: block;
  position: relative;
  width: 100%;
  height: auto
}

.S .Content_heading {
  display: block;
  text-align: left;
  padding: 22px 30px 0;
}

.S .Content_body {
  display: block;
  text-align: left;
  padding: 22px 30px 0;
}
.S .Content_button {
  display: block;
  text-align: left;
  padding: 35px 30px 90px
}

.Section.-sushi {
  background-color: #f8f8f8
}

.L .Section.-sushi {
  padding-top: 0;
  padding-bottom: 0
}

.S .Section.-sushi {
  padding-top: 0;
  padding-bottom: 0
}
.L .Oyakata {
  display: flex;
  position: relative;
  justify-content: center;
  align-items: center;
  padding-left: 0;
  padding-right: 0;
  padding-top: 0
}

.L .Oyakata_figure {
  display: block;
  position: relative;
  width: 46%;
  padding-top: 32.7%;
  top: 0px;
  left: 0px
}

.L .Oyakata_figure img {
  display: block;
  position: absolute;
  width: 100%;
  top: 0px;
  left: 0px
}

.L .Oyakata_text {
  display: block;
  position: relative;
  width: 46%;
  padding-left: 8.55%;
  text-align: left
}

.L .Oyakata_heading {
  display: block;
  text-align: left;
  padding-top: 0
}
.L.en .Oyakata_heading {
  margin-top: 60px
}

.L .Oyakata_heading .H1 {
  font-size: 38px;
  line-height: 38px;
  padding: 0
}

.L .Oyakata_body {
  display: block;
  text-align: left;
  padding-top: 2rem
}
.L.en .Oyakata_body {
  margin-bottom: 50px;
  padding-right: 100px;
}

.S .Oyakata {
  display: block;
  position: relative;
  padding-top: 0
}

.S .Oyakata_figure {
  display: block;
  position: relative;
  width: 100%;
  max-width: 662px;
  margin: 0 auto
}

.S .Oyakata_figure img {
  display: block;
  position: relative;
  width: 100%;
  height: auto
}

.S .Oyakata_text {
  display: block;
  position: relative;
  text-align: left;
  max-width: 660px;
  margin: 0 auto
}

.S .Oyakata_heading {
  display: block;
  text-align: left;
  padding: 51px 30px 0
}

.S .Oyakata_heading .H1 {
  font-size: 26px;
  line-height: 26px;
  padding: 0
}

.S .Oyakata_body {
  display: block;
  text-align: left;
  padding: 2rem 30px 2.6rem 30px;
}

.L .Map {
  padding-top: 220px;
  max-height: 480px;
}
.S .Map {
  padding-top: 150px;
  max-height: 480px;
}

.googlemap {
  position: relative;
  padding-bottom: 68%;
  height: 0;
  overflow: hidden;
}
.L .googlemap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 50%;
}
.S .googlemap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.gmap-gray-scale iframe{
  filter: grayscale(100%);
} 
.gmap-gray-scale-hover iframe{
  filter: grayscale(100%);
  transition: filter 0.5s ease-in-out;
} 
.gmap-gray-scale-hover iframe:hover{
  filter: grayscale(100%);
} 

.L .Section.-access {
  padding-top: 84px;
  padding-bottom: 177px
}

.L .Access_body {
  padding-top: 3em
}

.S .Access_body {
  padding-top: 0
}

.S .Section.-access {
  padding-top: 26px;
  padding-bottom: 143px
}

.S .Access .Content_heading,
.S .Access .Content_body {
  text-align: center;
}