@import url("https://fonts.googleapis.com/css2?family=Alumni+Sans+Pinstripe&family=Dosis:wght@500&family=Noto+Sans+JP:wght@600&display=swap");
.inner {
  margin-left: auto;
  margin-right: auto;
  width: 94%;
}
@media screen and (min-width: 988px) {
  .inner {
    width: 87.5%;
  }
}

.inner-slim {
  width: 76%;
  margin-left: auto;
  margin-right: auto;
}
.text-black {
  color: #000000;
}

.text-white {
  color: #ffffff;
}

.text-yellow {
  color: #ffc400;
}

.text-green {
  color: #2d7b2a;
}

.text-green_lighten {
  color: rgba(45, 123, 42, 0.5);
}

.text-red {
  color: #e22f00;
}

.text-red_lighten {
  color: rgba(226, 47, 0, 0.6);
}

.base-black {
  background-color: #000000;
}

.base-white {
  background-color: #ffffff;
}

.base-yellow {
  background-color: #ffc400;
}

.base-green {
  background-color: #2d7b2a;
}

.base-green_lighten {
  background-color: rgba(45, 123, 42, 0.5);
}

.base-red {
  background-color: #e22f00;
}

.base-red_lighten {
  background-color: #fad6cd;
}

.base-red_alpha {
  background-color: rgba(226, 47, 0, 0.6);
}

html,
body,
main,
div,
section,
article,
header,
footer,
nav,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
li,
ol,
table,
tbody,
tr,
th,
td,
a,
button,
p,
span,
b,
strong,
small,
blockquote,
canvas,
figure,
picture,
img,
audio,
video,
form,
label,
input,
select,
textarea {
  margin: 0;
  padding: 0;
  border: 0;
  -webkit-box-sizing: initial;
          box-sizing: initial;
  vertical-align: baseline;
}

html {
  line-height: 1;
  -webkit-text-size-adjust: 100%;
}

body {
  margin: 0;
}

main {
  display: block;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: normal;
}

ul,
ol {
  list-style: none;
}

a {
  display: inline-block;
  color: initial;
  background-color: transparent;
  text-decoration: none;
}

b,
strong {
  font-weight: bold;
}

small {
  font-size: 90%;
}

img {
  width: 100%;
  height: auto;
  -o-object-fit: contain;
     object-fit: contain;
  vertical-align: top;
}

button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  font-size: 100%;
  line-height: 1.15;
  color: initial;
  outline: none;
  text-align: left;
  -webkit-appearance: none;
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
  background-color: transparent;
}

button,
[type=button],
[type=reset],
[type=submit] {
  cursor: pointer;
}

button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

[type=checkbox],
[type=radio] {
  -webkit-box-sizing: border-box;
          box-sizing: border-box; /* 1 */
  padding: 0; /* 2 */
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

textarea {
  overflow: auto;
}

[hidden] {
  display: none;
}

@media only screen and (max-width: 980px) {
  html {
    height: -webkit-fill-available;
    height: 100svh;
    font-size: 2.666666667vw;
  }
  html body {
    min-height: 100svh;
    max-height: 100svh;
  }
}
html .wf-loading {
  opacity: 0;
  visibility: hidden;
}

h1,
h2,
h3,
h4,
h5,
h6,
a,
p,
span,
button,
b,
strong,
label,
input,
textarea,
select,
th,
td {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  font-size: 16px;
  font-style: normal;
  font-weight: 600;
  line-height: 1.65;
  letter-spacing: 0.06em;
  font-feature-settings: "palt" 1;
  -webkit-font-feature-settings: "palt" 1;
  font-smoothing: antialiased;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1:before,
h1:after,
h2:before,
h2:after,
h3:before,
h3:after,
h4:before,
h4:after,
h5:before,
h5:after,
h6:before,
h6:after,
a:before,
a:after,
p:before,
p:after,
span:before,
span:after,
button:before,
button:after,
b:before,
b:after,
strong:before,
strong:after,
label:before,
label:after,
input:before,
input:after,
textarea:before,
textarea:after,
select:before,
select:after,
th:before,
th:after,
td:before,
td:after {
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
  font-feature-settings: "palt" 0;
  -webkit-font-feature-settings: "palt" 0;
}

@media only screen and (max-width: 980px) {
  h1,
  h2,
  h3,
  h4,
  h5,
  h6,
  a,
  p,
  span,
  button,
  b,
  strong,
  label,
  input,
  textarea,
  select,
  th,
  td {
    font-size: 1rem;
  }
}
a *,
button * {
  pointer-events: none;
}

p,
p * {
  letter-spacing: 0;
  font-feature-settings: "palt" 0;
  -webkit-font-feature-settings: "palt" 0;
}

.bold,
.bold *,
b,
b *,
strong,
strong * {
  font-weight: 500;
}

body {
  font-family: "Noto Sans JP", sans-serif;
}

.sp {
  display: block !important;
}
@media screen and (min-width: 988px) {
  .sp {
    display: none !important;
  }
}

.pc {
  display: none !important;
}
@media screen and (min-width: 988px) {
  .pc {
    display: block !important;
  }
}

.eng01 {
  font-family: "Alumni Sans Pinstripe", sans-serif;
  text-shadow: 0px 0px 1px #000;
}

.eng02 {
  font-family: "Dosis", sans-serif;
  font-weight: 500;
}

.jpn {
  font-family: "Noto Sans JP", sans-serif;
}

.round {
  border-radius: 20px;
}
@media screen and (min-width: 988px) {
  .round {
    border-radius: 40px;
  }
}
.round-20 {
  border-radius: 10px;
}
@media screen and (min-width: 988px) {
  .round-20 {
    border-radius: 20px;
  }
}
.round-30 {
  border-radius: 15px;
}
@media screen and (min-width: 988px) {
  .round-30 {
    border-radius: 30px;
  }
}

.shadow {
  position: relative;
}
.shadow > * {
  position: relative;
  z-index: 1;
}
.shadow:after {
  z-index: 0;
  content: "";
  position: absolute;
  top: min(20px, 2.6666666667vw);
  left: min(10px, 1.3333333333vw);
  width: 100%;
  height: 100%;
  display: block;
  background: #000;
  border-radius: 20px;
}
@media screen and (min-width: 988px) {
  .shadow:after {
    border-radius: 40px;
  }
}
.shadow-20:after {
  top: 5px;
  left: 5px;
  border-radius: 10px;
}
@media screen and (min-width: 988px) {
  .shadow-20:after {
    border-radius: 20px;
  }
}
.shadow-footer:after {
  top: 7px;
  left: 7px;
  border-radius: 40px;
}
@media screen and (min-width: 988px) {
  .shadow-footer:after {
    border-radius: 40px;
  }
}

.border-black {
  border: 3px solid #000;
}

.text-12 {
  font-size: 12px;
}

.text-16 {
  font-size: 15px;
}

.text-18 {
  font-size: min(16px, 2.8vw);
}

.text-19 {
  font-size: min(17px, 3.6vw);
}

.text-20 {
  font-size: min(20px, 4.9333333333vw);
}

.text-22 {
  font-size: 21px;
}

.text-25 {
  font-size: min(23px, 3.6vw);
}

.text-30 {
  font-size: min(28px, 5.0666666667vw);
}

.text-35 {
  font-size: min(33px, 4.9333333333vw);
}

.text-40 {
  font-size: min(36px, 5.0666666667vw);
}

.text-60 {
  font-size: min(11vw, 60px);
}

.buttons .button {
  display: inline-block;
  position: relative;
  -webkit-transform: translate(0, 0);
          transform: translate(0, 0);
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
.buttons .button:after {
  content: "";
  width: 100%;
  height: min(90px, 21.3333333333vw);
  display: block;
  border-radius: 99999px;
  z-index: 1;
  top: min(5px, 0.6666666667vw);
  left: min(6px, 0.8vw);
  background: #000;
  position: absolute;
}
.buttons .button a {
  border: 3px solid #000;
  position: relative;
  z-index: 10;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: min(90px, 21.3333333333vw);
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: min(220px, 52vw);
  padding-left: min(40px, 5.3333333333vw);
  padding-right: min(23px, 3.0666666667vw);
  border-radius: 99999px;
  white-space: nowrap;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
.buttons .button a .label {
  letter-spacing: 0.04em;
}
.buttons .button a .icon {
  width: min(48px, 11.3333333333vw);
}
.buttons .button:hover a {
  -webkit-transform: translate(4px, 4px);
          transform: translate(4px, 4px);
}
.buttons .button.--map a {
  padding-left: min(30px, 6vw);
}

.js-target {
  opacity: 0;
  -webkit-transition: opacity ease 0.5s;
  transition: opacity ease 0.5s;
}

.is-jumpin {
  -webkit-animation: jumpin 0.6s ease-in-out;
          animation: jumpin 0.6s ease-in-out;
  opacity: 1;
}

@-webkit-keyframes jumpin {
  0% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
    opacity: 0;
  }
  38% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
    opacity: 1;
  }
  55% {
    -webkit-transform: scale(0.95);
            transform: scale(0.95);
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  72% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
  81% {
    -webkit-transform: scale(0.96);
            transform: scale(0.96);
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  90% {
    -webkit-transform: scale(1.01);
            transform: scale(1.01);
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
  95% {
    -webkit-transform: scale(0.99);
            transform: scale(0.99);
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
}

@keyframes jumpin {
  0% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
    opacity: 0;
  }
  38% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
    opacity: 1;
  }
  55% {
    -webkit-transform: scale(0.95);
            transform: scale(0.95);
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  72% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
  81% {
    -webkit-transform: scale(0.96);
            transform: scale(0.96);
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  90% {
    -webkit-transform: scale(1.01);
            transform: scale(1.01);
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
  95% {
    -webkit-transform: scale(0.99);
            transform: scale(0.99);
    -webkit-animation-timing-function: ease-in;
            animation-timing-function: ease-in;
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-animation-timing-function: ease-out;
            animation-timing-function: ease-out;
  }
}
.js-slide-left {
  position: relative;
  left: -120px;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}

.is-slide-left {
  left: 0;
  opacity: 1;
}

.js-slide-right {
  position: relative;
  right: -120px;
  -webkit-transition: 0.4s;
  transition: 0.4s;
}

.is-slide-right {
  right: 0;
  opacity: 1;
}

.js-slide-top {
  position: relative;
  top: 60px;
  -webkit-transition: 0.8s;
  transition: 0.8s;
}

.is-slide-top {
  top: 0;
  opacity: 1;
}

.footer_copy {
  text-align: center;
  padding: min(50px, 10vw) 10px;
}
.footer_body__inner {
  padding: min(120px, 20vw) min(50px, 1.3333333333vw) min(110px, 11.7333333333vw);
}
@media screen and (min-width: 988px) {
  .footer_body__inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.footer_main .image {
  position: relative;
  width: 86%;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: min(36px, 6.9333333333vw);
}
@media screen and (min-width: 988px) {
  .footer_main .image {
    margin-left: 0;
    width: 384px;
  }
}
.footer_main .image img {
  width: 100%;
}
.footer_main .image_frame {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  overflow: hidden;
  border: 3px solid #000;
  border-radius: 40px;
}
.footer_main .contents {
  margin-bottom: min(30px, 6.4vw);
  text-align: center;
}
.footer_main .contents p,
.footer_main .contents a {
  font-size: min(19px, 4vw);
}
.footer_main .contents a {
  position: relative;
}
.footer_main .contents a:after {
  position: absolute;
  bottom: 0;
  left: 0;
  content: "";
  width: 0;
  height: 2px;
  background: #000;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.footer_main .contents a:hover:after {
  width: 100%;
}
@media screen and (min-width: 988px) {
  .footer_main .contents {
    text-align: left;
  }
}
.footer_main .buttons {
  text-align: center;
}
@media screen and (min-width: 988px) {
  .footer_main .buttons {
    text-align: left;
  }
}
.footer_id {
  padding-top: 17.3333333333vw;
  text-align: center;
}
@media screen and (min-width: 988px) {
  .footer_id {
    padding-top: 0;
    text-align: right;
  }
}
.footer_id .logo {
  display: inline-block;
  width: min(220px, 41.3333333333vw);
}
.footer_id .logo img {
  width: 100%;
}
.footer_id .id {
  margin-top: min(45px, 2vw);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 988px) {
  .footer_id .id {
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
}
.footer_id .id .label {
  padding-right: 15px;
  font-size: min(23px, 4.2666666667vw);
}
.footer_id .id .name {
  font-size: min(30px, 6.1333333333vw);
}

.header_body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 90px;
}
@media screen and (min-width: 988px) {
  .header_body {
    height: 140px;
  }
}
.header_day {
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-flex: 1;
      -ms-flex: 1 1 100%;
          flex: 1 1 100%;
}
.header_day .icon {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 min(45px, 8.6666666667vw);
          flex: 0 0 min(45px, 8.6666666667vw);
  margin-right: 6px;
  line-height: 1;
}
.header_day .icon img {
  width: 100%;
}
.header_day .contents {
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
}
.header_day .container {
  overflow: hidden;
  width: 100%;
  height: 50px;
}
.header_day .scroll-parent {
  overflow: hidden;
  position: relative;
  width: 36em;
  height: inherit;
}
@media screen and (min-width: 988px) {
  .header_day .scroll-parent {
    width: 30em;
  }
}
.header_day .scroll-child {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  position: absolute;
  left: 0%;
  top: 0%;
  font-size: inherit;
  width: inherit;
  white-space: nowrap;
  height: inherit;
  -webkit-animation-duration: 14s;
          animation-duration: 14s;
  -webkit-animation-timing-function: linear;
          animation-timing-function: linear;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  font-size: 3.7333333333vw;
}
@media screen and (min-width: 988px) {
  .header_day .scroll-child {
    font-size: 0.9vw;
    font-size: inherit;
  }
}
.header_day .scroll-child:nth-child(1) {
  -webkit-animation-name: first;
          animation-name: first;
}
.header_day .scroll-child:nth-child(2) {
  -webkit-animation-name: second;
          animation-name: second;
}
@-webkit-keyframes first {
  from {
    left: 0%;
  }
  to {
    left: -100%;
  }
}
@keyframes first {
  from {
    left: 0%;
  }
  to {
    left: -100%;
  }
}
@-webkit-keyframes second {
  from {
    left: 100%;
  }
  to {
    left: 0%;
  }
}
@keyframes second {
  from {
    left: 100%;
  }
  to {
    left: 0%;
  }
}
.header_map {
  padding-left: 20px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.header_map .icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-right: 20px;
}
.header_map .icon .img {
  width: 25px;
}
.header_map .icon .img img {
  width: 100%;
}
.header_map .icon .label {
  font-size: 22px;
  margin-left: 8px;
  position: relative;
}
.header_map .icon .label:after {
  position: absolute;
  bottom: 0;
  left: 0;
  content: "";
  width: 0;
  height: 2px;
  background: #000;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.header_map .icon:hover .label:after {
  width: 100%;
}
.header_map .address {
  white-space: nowrap;
  font-size: 15px;
}

.hero {
  border-bottom: 3px solid #000;
}
.hero_container {
  position: relative;
  overflow: hidden;
  padding-bottom: min(120px, 13.3333333333vw);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
}
.hero_frame {
  position: relative;
  width: 12%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.hero_frame__group {
  position: relative;
  display: block;
  text-align: center;
  height: 100%;
}
.hero_frame__list {
  margin-left: auto;
  margin-right: auto;
  width: 50%;
  height: 100%;
  min-height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.hero_frame__list img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: auto;
}
.hero_frame__list img + img {
  margin-top: 2vw;
}
.hero_body {
  width: 94%;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 988px) {
  .hero_body {
    margin-left: 0;
    margin-right: 0;
    width: 76%;
  }
}
.hero_inner {
  border: 3px solid #000;
}

.hero_header {
  position: relative;
  z-index: 10;
  padding: min(30px, 4vw) min(40px, 3.3333333333vw) 0 min(60px, 6.6666666667vw);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.hero_header__id {
  width: min(240px, 36.6666666667vw);
}
.hero_header__id img {
  width: 100%;
  height: auto;
}
.hero_header__link {
  display: block;
  border: none;
  outline: none;
}
.hero_header__box {
  width: min(206px, 34.1333333333vw);
  height: min(160px, 24.2666666667vw);
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transform: translate(0, 0);
          transform: translate(0, 0);
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
.hero_header__box .logo {
  width: min(50px, 6.6666666667vw);
}
.hero_header__box .label {
  margin-top: min(13px, 1.7333333333vw);
}
.hero_header__link:hover .hero_header__box {
  -webkit-transform: translate(4px, 4px);
          transform: translate(4px, 4px);
}

.hero_main {
  position: relative;
  z-index: 1;
  padding: 4vw 3vw 0;
}
@media screen and (min-width: 988px) {
  .hero_main {
    padding: 40px 35px 0;
  }
}
.hero_main__box {
  border: 3px solid #000;
  padding: 0 0 min(40px, 5.3333333333vw);
}
.hero_main__image {
  position: relative;
  margin-top: -2vw;
  margin-left: -10vw;
  margin-right: -10vw;
}
@media screen and (min-width: 988px) {
  .hero_main__image {
    margin-top: -150px;
    margin-left: -45px;
    margin-right: -45px;
  }
}
.hero_main__base {
  position: relative;
  position: absolute;
  top: 9%;
  left: 9%;
  height: 82%;
  width: 82%;
}
@media screen and (min-width: 988px) {
  .hero_main__base {
    top: 12%;
    left: 12%;
    height: 76%;
    width: 76%;
  }
}
.hero_main__base .spoon {
  position: absolute;
  top: 3%;
  left: -10%;
  width: 70%;
}
.hero_main__base .curry {
  position: relative;
}
.hero_main__base .curry-rotation {
  -webkit-animation: loading 24s linear infinite;
          animation: loading 24s linear infinite;
}
@-webkit-keyframes loading {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
@keyframes loading {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
.hero_main__time {
  margin-top: -10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (min-width: 988px) {
  .hero_main__time {
    margin-top: -30px;
  }
}
.hero_main__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 min(35px, 5.3333333333vw);
}
@media screen and (min-width: 988px) {
  .hero_main__item {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
.hero_main__item .label {
  position: relative;
}
.hero_main__item .label_inner {
  font-size: min(24px, 4.5333333333vw);
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: min(55px, 10vw);
  padding: 0 min(20px, 3.3333333333vw);
  border-radius: 100px;
  border: 3px solid #000;
}
.hero_main__item .label:after {
  content: "";
  width: 100%;
  z-index: 0;
  height: 100%;
  display: block;
  background: black;
  position: absolute;
  top: 2px;
  left: 2px;
  border-radius: 100px;
}
.hero_main__item .time {
  padding-left: 0;
  font-size: min(35px, 6.2666666667vw);
  margin-top: 10px;
}
@media screen and (min-width: 988px) {
  .hero_main__item .time {
    margin-top: 0;
    padding-left: 10px;
  }
}

.hero_concept {
  padding: min(55px, 7.3333333333vw) 0 min(65px, 8.6666666667vw);
  text-align: center;
}
.hero_concept__title .label {
  display: inline-block;
  font-size: min(35px, 6.2666666667vw);
  border: 3px solid #000;
  padding: min(30px, 4.6666666667vw) min(50px, 8vw);
  border-radius: 50%;
  text-shadow: 1px 1px 0px black;
}
.hero_concept__body {
  position: relative;
  padding-top: min(40px, 5.3333333333vw);
}
.hero_concept__body .lead {
  display: block;
  padding-bottom: min(35px, 7.3333333333vw);
}
.hero_concept__body .contents {
  line-height: 1.9;
}
.hero_concept__item {
  position: absolute;
}
.hero_concept__item.--01 {
  top: -40%;
  width: 42.4%;
  right: 0;
  -webkit-transform: translate(30%, -55%);
          transform: translate(30%, -55%);
}
.hero_concept__item.--02 {
  top: 40%;
  width: 41.4%;
  max-width: 387px;
  left: 0;
  -webkit-transform: translate(-30%, 5%);
          transform: translate(-30%, 5%);
}
.hero_concept__image {
  width: 100%;
  position: absolute;
}

.menu {
  border-bottom: 3px solid #000;
}
.menu_container {
  text-align: center;
  padding-top: min(75px, 12.6666666667vw);
}
.menu_frame {
  height: 24vw;
  width: 100%;
  overflow: hidden;
}
@media screen and (min-width: 988px) {
  .menu_frame {
    height: 15.5vw;
  }
}
.menu_frame.--bottom {
  padding: min(100px, 8.2666666667vw) 0 min(85px, 12.6666666667vw);
}
.menu_frame__group {
  overflow: hidden;
  position: relative;
  width: 100%;
  height: inherit;
}
.menu_frame .scroll-child {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-pack: distribute;
      justify-content: space-around;
  position: absolute;
  left: 0%;
  top: 0%;
  width: 100%;
  height: inherit;
  -webkit-animation-duration: 22s;
          animation-duration: 22s;
  -webkit-animation-timing-function: linear;
          animation-timing-function: linear;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
}
.menu_frame .scroll-child > img {
  width: 22%;
  margin: 0 1.5%;
}
@media screen and (min-width: 988px) {
  .menu_frame .scroll-child > img {
    width: 17%;
    margin: 0 1.5%;
  }
}
.menu_frame .scroll-child:nth-child(1) {
  -webkit-animation-name: first;
          animation-name: first;
}
.menu_frame .scroll-child:nth-child(2) {
  -webkit-animation-name: second;
          animation-name: second;
}

.menu_title {
  margin-top: min(75px, 15.3333333333vw);
  position: relative;
  text-align: center;
}
.menu_title__inner {
  display: inline-block;
  position: relative;
}
.menu_title__inner:after {
  display: inline-block;
  content: "";
  width: 100%;
  height: 100%;
  border-radius: 50px;
  background: #000;
  position: absolute;
  top: min(7px, 0.9333333333vw);
  left: min(10px, 1.3333333333vw);
}
.menu_title .label {
  position: relative;
  z-index: 1;
  border-radius: 100px;
  font-size: min(40px, 7.4666666667vw);
  padding: 0 50px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: min(98px, 17.3333333333vw);
  border: 3px solid #000;
}

.menu_main {
  text-align: center;
}
.menu_main__title {
  border-bottom: 6px solid #e22f00;
  padding: min(35px, 5.3333333333vw) 0;
}
.menu_main__list {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: distribute;
      justify-content: space-around;
}
.menu_main__list li {
  text-align: center;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 100%;
          flex: 0 0 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: start;
  text-align: left;
  border-bottom: 3px solid #e22f00;
  height: min(100px, 16vw);
}
@media screen and (min-width: 988px) {
  .menu_main__list li {
    -webkit-box-flex: 0;
        -ms-flex: 0 0 50%;
            flex: 0 0 50%;
  }
}
@media screen and (min-width: 988px) {
  .menu_main__list li:nth-child(even) {
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
}
.menu_main__list li.contents {
  height: auto;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  padding-bottom: min(70px, 10.6666666667vw);
}
.menu_main__list li.wide {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-flex: 0;
      -ms-flex: 0 0 100%;
          flex: 0 0 100%;
}
.menu_main__list .title {
  -webkit-transform: translateY(-30%);
          transform: translateY(-30%);
}
.menu_main__list .title .label {
  font-size: min(27px, 4vw);
  border-radius: 50%;
  border: 3px solid #000;
  display: inline-block;
  padding: min(30px, 5.3333333333vw) min(65px, 9.3333333333vw);
}
.menu_main__list .name {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
}
@media screen and (min-width: 988px) {
  .menu_main__list .name {
    width: 70%;
  }
}
.menu_main__list .name .ja {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  text-align: left;
  padding-left: 2vw;
}
@media screen and (min-width: 988px) {
  .menu_main__list .name .ja {
    text-align: left;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
            flex: 0 0 auto;
    padding-left: 18px;
  }
}
.menu_main__list .name .en {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  text-align: right;
}
@media screen and (min-width: 988px) {
  .menu_main__list .name .en {
    text-align: left;
    -webkit-box-flex: 0;
        -ms-flex: 0 0 auto;
            flex: 0 0 auto;
  }
}
.menu_main__list .image {
  margin-left: auto;
  margin-right: auto;
  width: 100%;
  max-width: min(940px, 97.3333333333vw);
  margin-top: -8vw;
}
@media screen and (min-width: 640px) {
  .menu_main__list .image {
    margin-top: -6vw;
  }
}
@media screen and (min-width: 988px) {
  .menu_main__list .image {
    width: 76%;
    margin-top: -60px;
  }
}
.menu_main__list .image img {
  width: 100%;
}
.menu_main__list .detail {
  text-align: center;
}
.menu_main__list .detail_title {
  font-size: min(50px, 6.6666666667vw);
}
.menu_main__list .detail_name {
  font-size: min(26px, 3.8666666667vw);
}
.menu_main__list .detail_contents {
  font-size: min(24px, 3.6vw);
}
.menu_main__note {
  display: block;
  padding: min(30px, 4vw) 10px 0;
  text-align: center;
  font-size: min(19px, 2.9333333333vw);
}
.menu_main__note .link {
  display: inline-block;
  color: #e22f00;
  padding-top: 10px;
  font-weight: bold;
  font-size: min(31px, 4.5333333333vw);
  position: relative;
  padding-bottom: 2px;
}
.menu_main__note .link::after {
  -webkit-transition: all 300ms;
  transition: all 300ms;
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: #e22f00;
}
.menu_main__note .link:hover::after {
  opacity: 0;
}
.menu_main__note .hover {
  display: inline-block;
  color: #e22f00;
  padding-top: 10px;
  font-weight: bold;
  font-size: min(31px, 4.5333333333vw);
  position: relative;
  padding-bottom: 2px;
  text-decoration: underline;
}
.menu_main__note .hover:hover {
  text-decoration: none;
}

.menu_bottom {
  position: relative;
}
.menu_bottom__line {
  display: block;
  height: 100px;
  border-bottom: 3px solid #e22f00;
}
.menu_bottom__title {
  margin-top: 3vw;
  position: relative;
  z-index: 10;
  text-align: center;
}
@media screen and (min-width: 988px) {
  .menu_bottom__title {
    margin-top: -160px;
  }
}
.menu_bottom__title .name {
  position: relative;
  z-index: 10;
  display: inline-block;
}
.menu_bottom__title .name:before {
  z-index: 10;
  position: absolute;
  top: 52px;
  right: 67.5px;
  width: 0;
  height: 0;
  content: "";
  border-top: 0px solid transparent;
  border-right: 0px solid transparent;
  border-left: 33px solid white;
  border-bottom: 50px solid transparent;
  -webkit-transform: skewX(-0.035turn);
          transform: skewX(-0.035turn);
}
.menu_bottom__title .name:after {
  z-index: 0;
  position: absolute;
  top: 60px;
  right: 70px;
  width: 0;
  height: 0;
  content: "";
  border-top: 0px solid transparent;
  border-right: 0px solid transparent;
  border-left: 35px solid #000;
  border-bottom: 50px solid transparent;
  -webkit-transform: skewX(-0.03turn);
          transform: skewX(-0.03turn);
}
.menu_bottom__title .name .label {
  position: relative;
  z-index: 1;
  border-radius: 50px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: min(75px, 12.6666666667vw);
  padding: 0 min(55px, 10vw);
  border: 3px solid #000;
}
.menu_bottom__badge {
  position: relative;
  z-index: 1;
  width: min(384px, 66.1333333333vw);
  margin-left: auto;
  margin-right: auto;
}
.menu_bottom__badge .badge_container {
  display: block;
  overflow: hidden;
  height: 13vw;
  max-height: 77px;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.menu_bottom__badge .badge_parent {
  position: relative;
  margin: 0 auto;
  width: 20em;
  height: 100%;
  display: block;
  overflow: hidden;
}
.menu_bottom__badge .badge_child {
  position: absolute;
  left: 0%;
  top: 0%;
  display: block;
  width: inherit;
  height: inherit;
  -webkit-animation-duration: 10s;
          animation-duration: 10s;
  -webkit-animation-timing-function: linear;
          animation-timing-function: linear;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  font-size: min(28px, 4.8vw);
  white-space: nowrap;
  letter-spacing: 0.1em;
  line-height: 2.7em;
}
@media screen and (min-width: 988px) {
  .menu_bottom__badge .badge_child {
    line-height: 2.4em;
  }
}
.menu_bottom__badge .badge_child:nth-child(1) {
  -webkit-animation-name: first;
          animation-name: first;
}
.menu_bottom__badge .badge_child:nth-child(2) {
  -webkit-animation-name: second;
          animation-name: second;
}
@keyframes first {
  from {
    left: 0%;
  }
  to {
    left: -100%;
  }
}
@keyframes second {
  from {
    left: 100%;
  }
  to {
    left: 0%;
  }
}
.menu_bottom__link {
  position: relative;
  z-index: 0;
  margin-top: -70px;
}
.menu_bottom__link .label {
  width: min(220px, 38vw);
  height: min(220px, 38vw);
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  border-radius: 500px;
  border: 3px solid #000;
  position: relative;
  z-index: 10;
  -webkit-transform: translate(0, 0);
          transform: translate(0, 0);
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
.menu_bottom__link:after {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  top: min(10px, 1.3333333333vw);
  left: 0;
  border-radius: 500px;
  display: block;
  background: #000;
}
.menu_bottom__link:hover .label {
  -webkit-transform: translate(0, 10px);
          transform: translate(0, 10px);
}
.menu_bottom__img {
  position: relative;
  z-index: 1;
  margin-top: -120px;
  width: 96vw;
  max-width: initial;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 988px) {
  .menu_bottom__img {
    width: 72%;
    max-width: 934px;
  }
}
.menu_bottom__img img {
  width: 100%;
  height: auto;
}
.menu_bottom .menu_frame {
  position: absolute;
  z-index: 0;
  bottom: 38vw;
  left: 0;
}
@media screen and (min-width: 988px) {
  .menu_bottom .menu_frame {
    bottom: 20%;
  }
}

.commitment {
  border-bottom: 3px solid #000;
}
.commitment_container {
  position: relative;
  z-index: 10;
  padding: min(240px, 42.6666666667vw) 0 min(130px, 20vw);
}
.commitment_main {
  position: relative;
  text-align: center;
}
.commitment_main__inner {
  border: 3px solid #000;
  padding: min(165px, 18.6666666667vw) 0 0;
}
.commitment_title {
  display: inline-block;
  position: absolute;
  top: -25vw;
  left: 50%;
  z-index: 99;
  -webkit-transform: translate(-50%, 0);
          transform: translate(-50%, 0);
}
@media screen and (min-width: 988px) {
  .commitment_title {
    top: -145px;
  }
}
.commitment_title__badge {
  position: relative;
  z-index: 1;
  text-align: right;
}
.commitment_title__badge .label {
  display: inline-block;
  border-radius: 50%;
  border: 3px solid #000;
  height: min(114px, 17.3333333333vw);
  padding: 0 min(40px, 5.3333333333vw);
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.commitment_title__main {
  display: inline-block;
  position: relative;
  z-index: 0;
  top: min(-30px, -4vw);
  width: min(550px, 81.3333333333vw);
}
.commitment_img .img {
  overflow: hidden;
  border-radius: 50px;
  border: 3px solid #000;
  width: min(700px, 74.4vw);
  margin-left: auto;
  margin-right: auto;
}
.commitment_body {
  overflow: hidden;
  padding: 7vw 0 4vw;
}
@media screen and (min-width: 988px) {
  .commitment_body {
    padding: 70px 4%;
  }
}
.commitment_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 988px) {
  .commitment_list {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
@media screen and (min-width: 988px) {
  .commitment_list:after {
    content: "";
    background: black;
    position: absolute;
    width: 3px;
    height: 100%;
    top: 0;
    left: 50%;
    -webkit-transform: translate(-50%, 0);
            transform: translate(-50%, 0);
  }
}
.commitment_item {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 50%;
          flex: 0 0 50%;
}
.commitment_item + .commitment_item {
  padding-top: 5vw;
  border-top: 3px solid #000;
}
@media screen and (min-width: 988px) {
  .commitment_item + .commitment_item {
    border-top: none;
    padding-top: 0;
  }
}
.commitment_item__inner {
  margin: 0 auto;
  text-align: center;
  width: 80%;
  padding: 30px 0;
}
@media screen and (min-width: 988px) {
  .commitment_item__inner {
    width: 82%;
    padding: 30px 0;
  }
}
.commitment_item__title {
  position: relative;
}
.commitment_item__title .number {
  position: absolute;
  top: -20px;
  z-index: 10;
  width: min(12vw, 80px);
  height: min(12vw, 80px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 988px) {
  .commitment_item__title .number {
    top: -30px;
  }
}
.commitment_item__title .title {
  z-index: 1;
  display: inline-block;
  position: relative;
  width: 90%;
  margin-left: 5%;
}
@media screen and (min-width: 988px) {
  .commitment_item__title .title {
    width: 80%;
  }
}
.commitment_item__title .title:before {
  content: "";
  position: absolute;
  top: 8px;
  left: 12px;
  width: 100%;
  height: 100%;
  display: block;
  border-radius: 1000px;
  background: black;
  z-index: 1;
}
.commitment_item__title .title .label {
  position: relative;
  z-index: 10;
  border: 3px solid #000;
  border-radius: 1000px;
  width: 100%;
  height: min(90px, 15.4666666667vw);
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.commitment_item__body {
  padding-top: 30px;
  text-align: left;
}
.commitment_item__body p {
  line-height: 2;
  letter-spacing: 0.04em;
  font-size: min(18px, 4vw);
}

.commitment {
  position: relative;
}
.commitment_frame {
  overflow: hidden;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
}
.commitment_frame__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  height: 360vw;
  -webkit-transform: translate(-60%, -10%) rotate(20deg);
          transform: translate(-60%, -10%) rotate(20deg);
}
@media screen and (min-width: 988px) {
  .commitment_frame__inner {
    -webkit-transform: translate(-20%, -25%) rotate(30deg);
            transform: translate(-20%, -25%) rotate(30deg);
    height: 187vw;
  }
}
.commitment_frame__container {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 12.5vw;
          flex: 0 0 12.5vw;
  height: inherit;
  margin: 0 0.5vw;
  overflow: hidden;
}
.commitment_frame__parent {
  overflow: hidden;
  position: relative;
  height: inherit;
}
.commitment_frame__child {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: absolute;
  left: 0%;
  top: 0%;
  width: inherit;
  height: inherit;
  -webkit-animation-duration: 80s;
          animation-duration: 80s;
  -webkit-animation-timing-function: linear;
          animation-timing-function: linear;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
}
.commitment_frame__child > img {
  width: 12.5vw;
  width: 12.115vw;
  height: 15vw;
}
.commitment_frame__container.--up .commitment_frame__child:nth-child(1) {
  -webkit-animation-name: first_up;
          animation-name: first_up;
}
.commitment_frame__container.--up .commitment_frame__child:nth-child(2) {
  -webkit-animation-name: second_up;
          animation-name: second_up;
}
@-webkit-keyframes first_up {
  from {
    top: 0%;
  }
  to {
    top: -100%;
  }
}
@keyframes first_up {
  from {
    top: 0%;
  }
  to {
    top: -100%;
  }
}
@-webkit-keyframes second_up {
  from {
    top: 100%;
  }
  to {
    top: 0%;
  }
}
@keyframes second_up {
  from {
    top: 100%;
  }
  to {
    top: 0%;
  }
}
.commitment_frame__container.--down .commitment_frame__child:nth-child(1) {
  -webkit-animation-name: first_down;
          animation-name: first_down;
}
.commitment_frame__container.--down .commitment_frame__child:nth-child(2) {
  -webkit-animation-name: second_down;
          animation-name: second_down;
}
@-webkit-keyframes first_down {
  from {
    top: 0%;
  }
  to {
    top: 100%;
  }
}
@keyframes first_down {
  from {
    top: 0%;
  }
  to {
    top: 100%;
  }
}
@-webkit-keyframes second_down {
  from {
    top: -100%;
  }
  to {
    top: 0%;
  }
}
@keyframes second_down {
  from {
    top: -100%;
  }
  to {
    top: 0%;
  }
}

.recruit {
  border-bottom: 3px solid #000;
}
.recruit_container {
  text-align: center;
  padding: min(95px, 14.6666666667vw) 2% min(95px, 18.6666666667vw);
}
.recruit .content {
  margin-bottom: min(30px, 5.3333333333vw);
  margin-top: min(20px, 5.3333333333vw);
}
/*# sourceMappingURL=style.css.map */