@charset "UTF-8";
@-webkit-keyframes anime-pop-up {
  0% {
    -webkit-transform: scale(0);
            transform: scale(0);
  }
  50% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  75% {
    -webkit-transform: scale(0.95);
            transform: scale(0.95);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@keyframes anime-pop-up {
  0% {
    -webkit-transform: scale(0);
            transform: scale(0);
  }
  50% {
    -webkit-transform: scale(1.1);
            transform: scale(1.1);
  }
  75% {
    -webkit-transform: scale(0.95);
            transform: scale(0.95);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
@-webkit-keyframes fadein-zoom {
  0% {
    transform: scale(0.8, 0.8);
    -webkit-transform: scale(0.8, 0.8);
  }
  25% {
    opacity: 1;
  }
  70% {
    opacity: 1;
    transform: scale(1.1, 1.1);
    -webkit-transform: scale(1.1, 1.1);
  }
  90% {
    opacity: 1;
    transform: scale(0.95, 0.95);
    -webkit-transform: scale(0.95, 0.95);
  }
  100% {
    opacity: 1;
    transform: scale(1, 1);
    -webkit-transform: scale(1, 1);
  }
}
@keyframes fadein-zoom {
  0% {
    transform: scale(0.8, 0.8);
    -webkit-transform: scale(0.8, 0.8);
  }
  25% {
    opacity: 1;
  }
  70% {
    opacity: 1;
    transform: scale(1.1, 1.1);
    -webkit-transform: scale(1.1, 1.1);
  }
  90% {
    opacity: 1;
    transform: scale(0.95, 0.95);
    -webkit-transform: scale(0.95, 0.95);
  }
  100% {
    opacity: 1;
    transform: scale(1, 1);
    -webkit-transform: scale(1, 1);
  }
}
/*--------------------------------------------------------------
animation
--------------------------------------------------------------*/
@-webkit-keyframes anime-fade-out {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes anime-fade-out {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@-webkit-keyframes anime-fade-out-out {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes anime-fade-out-out {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes anime-fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes anime-fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes anime-fade-in-out {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes anime-fade-in-out {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@-webkit-keyframes anime-fade-in2 {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes anime-fade-in2 {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes anime-fade-up {
  0% {
    -webkit-transform: translateY(30px);
    transform: translateY(30px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateY(0%);
    transform: translateY(0%);
    opacity: 1;
  }
}
@keyframes anime-fade-up {
  0% {
    -webkit-transform: translateY(30px);
    transform: translateY(30px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateY(0%);
    transform: translateY(0%);
    opacity: 1;
  }
}
@-webkit-keyframes anime-up {
  0% {
    -webkit-transform: translateY(100%);
            transform: translateY(100%);
  }
  100% {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
}
@keyframes anime-up {
  0% {
    -webkit-transform: translateY(100%);
            transform: translateY(100%);
  }
  100% {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
}
@-webkit-keyframes anime-up-out {
  0% {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
  100% {
    -webkit-transform: translateY(100%);
            transform: translateY(100%);
  }
}
@keyframes anime-up-out {
  0% {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
  100% {
    -webkit-transform: translateY(100%);
            transform: translateY(100%);
  }
}
@-webkit-keyframes anime-fade-up-out {
  0% {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateY(30px);
            transform: translateY(30px);
    opacity: 0;
  }
}
@keyframes anime-fade-up-out {
  0% {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
    opacity: 1;
  }
  100% {
    -webkit-transform: translateY(30px);
            transform: translateY(30px);
    opacity: 0;
  }
}
@-webkit-keyframes anime-fade-left {
  0% {
    -webkit-transform: translateX(30px);
            transform: translateX(30px);
    opacity: 0;
  }
  70% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translateX(0%);
    transform: translateX(0%);
    opacity: 1;
  }
}
@keyframes anime-fade-left {
  0% {
    -webkit-transform: translateX(30px);
            transform: translateX(30px);
    opacity: 0;
  }
  70% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translateX(0%);
    transform: translateX(0%);
    opacity: 1;
  }
}
@-webkit-keyframes anime-fade-right {
  0% {
    -webkit-transform: translateX(-50px);
    transform: translateX(-50px);
    opacity: 0;
  }
  70% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translateX(0%);
    transform: translateX(0%);
    opacity: 1;
  }
}
@keyframes anime-fade-right {
  0% {
    -webkit-transform: translateX(-50px);
    transform: translateX(-50px);
    opacity: 0;
  }
  70% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translateX(0%);
    transform: translateX(0%);
    opacity: 1;
  }
}
@-webkit-keyframes anime-move-right {
  0% {
    opacity: 0;
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  30% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translateX(0vw);
            transform: translateX(0vw);
    opacity: 1;
  }
}
@keyframes anime-move-right {
  0% {
    opacity: 0;
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  30% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translateX(0vw);
            transform: translateX(0vw);
    opacity: 1;
  }
}
@-webkit-keyframes anime-move-left {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  30% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translateX(0vw);
            transform: translateX(0vw);
    opacity: 1;
  }
}
@keyframes anime-move-left {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  30% {
    opacity: 1;
  }
  100% {
    -webkit-transform: translateX(0vw);
            transform: translateX(0vw);
    opacity: 1;
  }
}
*[data-a=pop-up] {
  -webkit-transform: scale(0);
          transform: scale(0);
}

*[data-a=fade-in-out] {
  opacity: 0;
}

*[data-a=fade-in] {
  opacity: 0;
  -webkit-animation-timing-function: ease-out;
          animation-timing-function: ease-out;
}

*[data-a=fade-in2] {
  opacity: 0;
}

*[data-a=fade-out] {
  opacity: 1;
}

*[data-a=fade-up] {
  opacity: 0;
  -webkit-animation-timing-function: ease-out;
          animation-timing-function: ease-out;
}

*[data-a=fade-down] {
  opacity: 0;
  -webkit-animation-timing-function: ease-out;
          animation-timing-function: ease-out;
}

@-webkit-keyframes anime-fade-down {
  0% {
    -webkit-transform: translateY(-30px);
    transform: translateY(-30px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateY(0%);
    transform: translateY(0%);
    opacity: 1;
  }
}

@keyframes anime-fade-down {
  0% {
    -webkit-transform: translateY(-30px);
    transform: translateY(-30px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateY(0%);
    transform: translateY(0%);
    opacity: 1;
  }
}
*[data-a=up] {
  -webkit-transform: translateY(100%);
          transform: translateY(100%);
  -webkit-animation-timing-function: ease-out;
          animation-timing-function: ease-out;
}

*[data-a=fade-left] {
  opacity: 0;
}

*[data-a=fade-right] {
  opacity: 0;
}

*[data-a=move-left] {
  opacity: 0;
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
}

*[data-a=move-right] {
  opacity: 0;
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
}

*[data-a=tra-fade-in] {
  opacity: 0 !important;
}
*[data-a=tra-fade-in].anime-active {
  opacity: 1 !important;
}

*[data-a=zoom-up] {
  opacity: 0;
}

@-webkit-keyframes anime-zoom-up {
  0% {
    opacity: 0;
    -webkit-transform: scale(0.8, 0.8);
            transform: scale(0.8, 0.8);
  }
  100% {
    opacity: 1;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
}

@keyframes anime-zoom-up {
  0% {
    opacity: 0;
    -webkit-transform: scale(0.8, 0.8);
            transform: scale(0.8, 0.8);
  }
  100% {
    opacity: 1;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
}
@-webkit-keyframes anime-zoom-up-out {
  0% {
    opacity: 1;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  100% {
    opacity: 0;
    -webkit-transform: scale(0.8, 0.8);
            transform: scale(0.8, 0.8);
  }
}
@keyframes anime-zoom-up-out {
  0% {
    opacity: 1;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
  }
  100% {
    opacity: 0;
    -webkit-transform: scale(0.8, 0.8);
            transform: scale(0.8, 0.8);
  }
}
.anime-fade-in2 {
  -webkit-animation-name: anime-fade-in;
          animation-name: anime-fade-in;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-timing-function: ease-in;
          animation-timing-function: ease-in;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

.anime-fade-out {
  -webkit-animation-name: anime-fade-out;
          animation-name: anime-fade-out;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-timing-function: ease-out;
          animation-timing-function: ease-out;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

.anime-fade-in-out {
  -webkit-animation-name: anime-fade-in-out;
          animation-name: anime-fade-in-out;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-timing-function: ease-out;
          animation-timing-function: ease-out;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

.anime-pop-up {
  -webkit-animation-name: anime-pop-up;
          animation-name: anime-pop-up;
  -webkit-animation-timing-function: cubic-bezier(0, 1.07, 0.71, 1.4);
          animation-timing-function: cubic-bezier(0, 1.07, 0.71, 1.4);
}

.anime-fade-left {
  -webkit-animation-name: anime-fade-left;
          animation-name: anime-fade-left;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-timing-function: cubic-bezier(0, 0.91, 0.72, 1);
          animation-timing-function: cubic-bezier(0, 0.91, 0.72, 1);
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

.anime-fade-right {
  -webkit-animation-name: anime-fade-right;
          animation-name: anime-fade-right;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-timing-function: cubic-bezier(0, 0.91, 0.72, 1);
          animation-timing-function: cubic-bezier(0, 0.91, 0.72, 1);
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

.anime-move-left {
  -webkit-animation-name: anime-move-left;
          animation-name: anime-move-left;
  -webkit-animation-duration: 3s;
          animation-duration: 3s;
  -webkit-animation-timing-function: linear;
          animation-timing-function: linear;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

.anime-move-right {
  -webkit-animation-name: anime-move-right;
          animation-name: anime-move-right;
  -webkit-animation-duration: 3s;
          animation-duration: 3s;
  -webkit-animation-timing-function: ease-out;
          animation-timing-function: ease-out;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

*[data-a=slide-mask] {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: block;
  position: relative;
  text-indent: 102%;
  overflow: hidden;
  white-space: nowrap;
}
*[data-a=slide-mask]::before {
  content: "";
  width: 0%;
  height: 110%;
  position: absolute;
  left: 0;
  top: -5%;
  background: #000;
}
*[data-a=slide-mask].anime-active::before {
  -webkit-animation: anime-sm-mask 1s infinite;
          animation: anime-sm-mask 1s infinite;
  -webkit-animation-timing-function: cubic-bezier(0, 0.74, 0.33, 1);
          animation-timing-function: cubic-bezier(0, 0.74, 0.33, 1);
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  z-index: 2;
}

*[data-a=slide-mask-b] {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: block;
  position: relative;
  text-indent: 102%;
  overflow: hidden;
  white-space: nowrap;
  padding: 0px 0 10px;
  margin: 0 0 -10px;
}
*[data-a=slide-mask-b]::before {
  content: "";
  width: 0%;
  height: 110%;
  position: absolute;
  left: 0;
  top: -5%;
  background: rgb(0, 255, 157);
  background: linear-gradient(135deg, rgb(0, 255, 157) 0%, rgb(117, 180, 253) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00ff9d', endColorstr='#75b4fd',GradientType=1 );
}

.anime-slide-mask-b::before {
  -webkit-animation: anime-sm-mask 1s infinite;
          animation: anime-sm-mask 1s infinite;
  -webkit-animation-timing-function: cubic-bezier(0, 0.74, 0.33, 1);
          animation-timing-function: cubic-bezier(0, 0.74, 0.33, 1);
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  z-index: 2;
}

.anime-slide-mask-b {
  -webkit-animation: anime-sm-txt 1s infinite;
          animation: anime-sm-txt 1s infinite;
  -webkit-animation-timing-function: cubic-bezier(0, 0.74, 0.33, 1);
          animation-timing-function: cubic-bezier(0, 0.74, 0.33, 1);
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
}

.anime-slide-mask::before {
  /*
  animation: anime-sm-mask 1s infinite;
  animation-timing-function: cubic-bezier(0, 0.74, 0.33, 1);
  animation-fill-mode: forwards;
  animation-iteration-count: 1;
  z-index: 2;
  */
}

@-webkit-keyframes anime-slide-mask {
  0% {
    text-indent: 102%;
  }
  50% {
    text-indent: 102%;
  }
  51% {
    text-indent: 0%;
  }
  100% {
    text-indent: 0%;
  }
}

@keyframes anime-slide-mask {
  0% {
    text-indent: 102%;
  }
  50% {
    text-indent: 102%;
  }
  51% {
    text-indent: 0%;
  }
  100% {
    text-indent: 0%;
  }
}
@-webkit-keyframes anime-sm-txt {
  0% {
    text-indent: 102%;
  }
  50% {
    text-indent: 102%;
  }
  51% {
    text-indent: 0%;
  }
  100% {
    text-indent: 0%;
  }
}
@keyframes anime-sm-txt {
  0% {
    text-indent: 102%;
  }
  50% {
    text-indent: 102%;
  }
  51% {
    text-indent: 0%;
  }
  100% {
    text-indent: 0%;
  }
}
@-webkit-keyframes anime-sm-mask {
  0% {
    width: 0%;
    left: 0;
    right: auto;
  }
  50% {
    width: 102%;
    left: 0;
    right: auto;
  }
  51% {
    width: 102%;
    left: auto;
    right: -2%;
  }
  100% {
    width: 0%;
    left: auto;
    right: -2%;
  }
}
@keyframes anime-sm-mask {
  0% {
    width: 0%;
    left: 0;
    right: auto;
  }
  50% {
    width: 102%;
    left: 0;
    right: auto;
  }
  51% {
    width: 102%;
    left: auto;
    right: -2%;
  }
  100% {
    width: 0%;
    left: auto;
    right: -2%;
  }
}
*[data-a=mask] {
  -webkit-mask-image: url("../img/specer.png");
          mask-image: url("../img/specer.png");
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: 0 0;
          mask-position: 0 0;
  -webkit-mask-size: 100% 0%;
          mask-size: 100% 0%;
}

.anime-mask {
  -webkit-animation-name: anime-mask;
          animation-name: anime-mask;
  -webkit-animation-duration: 4s;
          animation-duration: 4s;
  -webkit-animation-timing-function: linear;
          animation-timing-function: linear;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

@-webkit-keyframes anime-mask {
  0% {
    -webkit-mask-image: url("../img/specer.png");
            mask-image: url("../img/specer.png");
    -webkit-mask-repeat: no-repeat;
            mask-repeat: no-repeat;
    -webkit-mask-position: 0 0;
            mask-position: 0 0;
    -webkit-mask-size: 100% 0%;
            mask-size: 100% 0%;
  }
  100% {
    -webkit-mask-size: 100% 100%;
            mask-size: 100% 100%;
  }
}

@keyframes anime-mask {
  0% {
    -webkit-mask-image: url("../img/specer.png");
            mask-image: url("../img/specer.png");
    -webkit-mask-repeat: no-repeat;
            mask-repeat: no-repeat;
    -webkit-mask-position: 0 0;
            mask-position: 0 0;
    -webkit-mask-size: 100% 0%;
            mask-size: 100% 0%;
  }
  100% {
    -webkit-mask-size: 100% 100%;
            mask-size: 100% 100%;
  }
}
.anm-fade-up {
  -webkit-animation-name: anime-fade-up;
          animation-name: anime-fade-up;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-timing-function: ease-out;
          animation-timing-function: ease-out;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

.anm-fade-up-out {
  -webkit-animation-name: anime-fade-up-out;
          animation-name: anime-fade-up-out;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-timing-function: ease-out;
          animation-timing-function: ease-out;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

.anime-fade-blur {
  -webkit-animation-name: anime-fade-blur;
          animation-name: anime-fade-blur;
  -webkit-animation-duration: 2s;
          animation-duration: 2s;
  -webkit-animation-timing-function: ease-out;
          animation-timing-function: ease-out;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

*[data-a=bg--gray].anime-active {
  background: #858585 !important;
}

*[data-a=fade-blur] {
  opacity: 0;
  -webkit-filter: blur(10px);
          filter: blur(10px);
}

@-webkit-keyframes anime-fade-blur {
  0% {
    opacity: 0;
    -webkit-filter: blur(10px);
            filter: blur(10px);
  }
  100% {
    opacity: 1;
    -webkit-filter: blur(0px);
            filter: blur(0px);
  }
}

@keyframes anime-fade-blur {
  0% {
    opacity: 0;
    -webkit-filter: blur(10px);
            filter: blur(10px);
  }
  100% {
    opacity: 1;
    -webkit-filter: blur(0px);
            filter: blur(0px);
  }
}
*[data-a=fade-blur] {
  opacity: 0;
  -webkit-filter: blur(30px);
          filter: blur(30px);
}

.anime-shake {
  -webkit-animation-name: anime-shake;
          animation-name: anime-shake;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-direction: alternate;
          animation-direction: alternate;
  -webkit-animation-duration: 100ms;
          animation-duration: 100ms;
}

@-webkit-keyframes anime-shake {
  0% {
    -webkit-transform: translate(0px, -1px);
            transform: translate(0px, -1px);
  }
  10% {
    -webkit-transform: translate(0px, 0px);
            transform: translate(0px, 0px);
  }
  20% {
    -webkit-transform: translate(0px, 1px);
            transform: translate(0px, 1px);
  }
  30% {
    -webkit-transform: translate(-1px, 1px);
            transform: translate(-1px, 1px);
  }
  40% {
    -webkit-transform: translate(-1px, 1px);
            transform: translate(-1px, 1px);
  }
  50% {
    -webkit-transform: translate(0px, 1px);
            transform: translate(0px, 1px);
  }
  60% {
    -webkit-transform: translate(1px, 1px);
            transform: translate(1px, 1px);
  }
  70% {
    -webkit-transform: translate(1px, 1px);
            transform: translate(1px, 1px);
  }
  80% {
    -webkit-transform: translate(1px, -1px);
            transform: translate(1px, -1px);
  }
  90% {
    -webkit-transform: translate(0px, -1px);
            transform: translate(0px, -1px);
  }
  100% {
    -webkit-transform: translate(0px, 0px);
            transform: translate(0px, 0px);
  }
}

@keyframes anime-shake {
  0% {
    -webkit-transform: translate(0px, -1px);
            transform: translate(0px, -1px);
  }
  10% {
    -webkit-transform: translate(0px, 0px);
            transform: translate(0px, 0px);
  }
  20% {
    -webkit-transform: translate(0px, 1px);
            transform: translate(0px, 1px);
  }
  30% {
    -webkit-transform: translate(-1px, 1px);
            transform: translate(-1px, 1px);
  }
  40% {
    -webkit-transform: translate(-1px, 1px);
            transform: translate(-1px, 1px);
  }
  50% {
    -webkit-transform: translate(0px, 1px);
            transform: translate(0px, 1px);
  }
  60% {
    -webkit-transform: translate(1px, 1px);
            transform: translate(1px, 1px);
  }
  70% {
    -webkit-transform: translate(1px, 1px);
            transform: translate(1px, 1px);
  }
  80% {
    -webkit-transform: translate(1px, -1px);
            transform: translate(1px, -1px);
  }
  90% {
    -webkit-transform: translate(0px, -1px);
            transform: translate(0px, -1px);
  }
  100% {
    -webkit-transform: translate(0px, 0px);
            transform: translate(0px, 0px);
  }
}
.anime-shake-x {
  -webkit-animation-name: anime-shake-x;
          animation-name: anime-shake-x;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-direction: alternate;
          animation-direction: alternate;
  -webkit-animation-duration: 100ms;
          animation-duration: 100ms;
}

@-webkit-keyframes anime-shake-x {
  0% {
    -webkit-transform: translate(0px, -2px);
            transform: translate(0px, -2px);
  }
  10% {
    -webkit-transform: translate(0px, 0px);
            transform: translate(0px, 0px);
  }
  20% {
    -webkit-transform: translate(0px, 2px);
            transform: translate(0px, 2px);
  }
  30% {
    -webkit-transform: translate(-2px, 2px);
            transform: translate(-2px, 2px);
  }
  40% {
    -webkit-transform: translate(-2px, 2px);
            transform: translate(-2px, 2px);
  }
  50% {
    -webkit-transform: translate(0px, 2px);
            transform: translate(0px, 2px);
  }
  60% {
    -webkit-transform: translate(2px, 2px);
            transform: translate(2px, 2px);
  }
  70% {
    -webkit-transform: translate(2px, 2px);
            transform: translate(2px, 2px);
  }
  80% {
    -webkit-transform: translate(2px, -2px);
            transform: translate(2px, -2px);
  }
  90% {
    -webkit-transform: translate(0px, -2px);
            transform: translate(0px, -2px);
  }
  100% {
    -webkit-transform: translate(0px, 0px);
            transform: translate(0px, 0px);
  }
}

@keyframes anime-shake-x {
  0% {
    -webkit-transform: translate(0px, -2px);
            transform: translate(0px, -2px);
  }
  10% {
    -webkit-transform: translate(0px, 0px);
            transform: translate(0px, 0px);
  }
  20% {
    -webkit-transform: translate(0px, 2px);
            transform: translate(0px, 2px);
  }
  30% {
    -webkit-transform: translate(-2px, 2px);
            transform: translate(-2px, 2px);
  }
  40% {
    -webkit-transform: translate(-2px, 2px);
            transform: translate(-2px, 2px);
  }
  50% {
    -webkit-transform: translate(0px, 2px);
            transform: translate(0px, 2px);
  }
  60% {
    -webkit-transform: translate(2px, 2px);
            transform: translate(2px, 2px);
  }
  70% {
    -webkit-transform: translate(2px, 2px);
            transform: translate(2px, 2px);
  }
  80% {
    -webkit-transform: translate(2px, -2px);
            transform: translate(2px, -2px);
  }
  90% {
    -webkit-transform: translate(0px, -2px);
            transform: translate(0px, -2px);
  }
  100% {
    -webkit-transform: translate(0px, 0px);
            transform: translate(0px, 0px);
  }
}
.anime-shake-end {
  -webkit-animation-name: anime-shake;
          animation-name: anime-shake;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-direction: alternate;
          animation-direction: alternate;
  -webkit-animation-duration: 100ms;
          animation-duration: 100ms;
  -webkit-animation-iteration-count: 3;
          animation-iteration-count: 3;
}

@-webkit-keyframes anime-shake-end {
  0% {
    -webkit-transform: translate(0px, -2px);
            transform: translate(0px, -2px);
  }
  10% {
    -webkit-transform: translate(0px, 0px);
            transform: translate(0px, 0px);
  }
  20% {
    -webkit-transform: translate(0px, 2px);
            transform: translate(0px, 2px);
  }
  30% {
    -webkit-transform: translate(-2px, 2px);
            transform: translate(-2px, 2px);
  }
  40% {
    -webkit-transform: translate(-2px, 2px);
            transform: translate(-2px, 2px);
  }
  50% {
    -webkit-transform: translate(0px, 2px);
            transform: translate(0px, 2px);
  }
  60% {
    -webkit-transform: translate(2px, 2px);
            transform: translate(2px, 2px);
  }
  70% {
    -webkit-transform: translate(2px, 2px);
            transform: translate(2px, 2px);
  }
  80% {
    -webkit-transform: translate(2px, -2px);
            transform: translate(2px, -2px);
  }
  90% {
    -webkit-transform: translate(0px, -2px);
            transform: translate(0px, -2px);
  }
  100% {
    -webkit-transform: translate(0px, 0px);
            transform: translate(0px, 0px);
  }
}

@keyframes anime-shake-end {
  0% {
    -webkit-transform: translate(0px, -2px);
            transform: translate(0px, -2px);
  }
  10% {
    -webkit-transform: translate(0px, 0px);
            transform: translate(0px, 0px);
  }
  20% {
    -webkit-transform: translate(0px, 2px);
            transform: translate(0px, 2px);
  }
  30% {
    -webkit-transform: translate(-2px, 2px);
            transform: translate(-2px, 2px);
  }
  40% {
    -webkit-transform: translate(-2px, 2px);
            transform: translate(-2px, 2px);
  }
  50% {
    -webkit-transform: translate(0px, 2px);
            transform: translate(0px, 2px);
  }
  60% {
    -webkit-transform: translate(2px, 2px);
            transform: translate(2px, 2px);
  }
  70% {
    -webkit-transform: translate(2px, 2px);
            transform: translate(2px, 2px);
  }
  80% {
    -webkit-transform: translate(2px, -2px);
            transform: translate(2px, -2px);
  }
  90% {
    -webkit-transform: translate(0px, -2px);
            transform: translate(0px, -2px);
  }
  100% {
    -webkit-transform: translate(0px, 0px);
            transform: translate(0px, 0px);
  }
}
.anime-hop {
  -webkit-animation-name: anime-hop;
          animation-name: anime-hop;
  -webkit-animation-iteration-count: infinite;
          animation-iteration-count: infinite;
  -webkit-animation-duration: 100ms;
          animation-duration: 100ms;
}

@-webkit-keyframes anime-hop {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  9% {
    -webkit-transform: scale(1.04);
            transform: scale(1.04);
  }
  13% {
    -webkit-transform: scale(0.98);
            transform: scale(0.98);
  }
  17% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}

@keyframes anime-hop {
  0% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
  9% {
    -webkit-transform: scale(1.04);
            transform: scale(1.04);
  }
  13% {
    -webkit-transform: scale(0.98);
            transform: scale(0.98);
  }
  17% {
    -webkit-transform: scale(1);
            transform: scale(1);
  }
}
.anime-sec--hide {
  display: none;
}

*[data-a=sec--view] {
  display: none;
}

.anime-sec--view {
  display: block;
}

*[data-a=txt--view] {
  display: inline;
  opacity: 0;
  -webkit-transform: translateY(0.5em);
          transform: translateY(0.5em);
}

.anime-txt--view {
  -webkit-animation-name: anime-txt--view;
          animation-name: anime-txt--view;
  -webkit-animation-duration: 0.2s;
          animation-duration: 0.2s;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

@-webkit-keyframes anime-txt--view {
  0% {
    opacity: 0;
    -webkit-transform: translateY(0.5em);
            transform: translateY(0.5em);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0em);
            transform: translateY(0em);
  }
}

@keyframes anime-txt--view {
  0% {
    opacity: 0;
    -webkit-transform: translateY(0.5em);
            transform: translateY(0.5em);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0em);
            transform: translateY(0em);
  }
}
.anime-btn-active .off {
  pointer-events: none;
  display: none;
}
.anime-btn-active button, .anime-btn-active a {
  pointer-events: all !important;
  position: relative;
  z-index: 10;
}

.anime-sec-mask {
  pointer-events: all !important;
}

*[data-a-btn=sec-mask] {
  pointer-events: none;
}

.anime-fade-h-title span {
  -webkit-animation-name: anime-fade-in;
          animation-name: anime-fade-in;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-timing-function: ease-out;
          animation-timing-function: ease-out;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
.anime-fade-h-title::before {
  -webkit-animation-name: anime-h-title-before;
          animation-name: anime-h-title-before;
  -webkit-animation-duration: 0.6s;
          animation-duration: 0.6s;
  -webkit-animation-timing-function: ease-out;
          animation-timing-function: ease-out;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

*[data-a=fade-h-title] span {
  opacity: 0;
}

@-webkit-keyframes anime-fade-h-title {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes anime-fade-h-title {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes anime-h-title-before {
  0% {
    height: 0px;
  }
  100% {
    height: 200px;
  }
}
@keyframes anime-h-title-before {
  0% {
    height: 0px;
  }
  100% {
    height: 200px;
  }
}
*[data-a=fade-test] {
  opacity: 0;
}
*[data-a=fade-test].anime-active {
  opacity: 1;
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
}

.anime-reverse {
  animation-direction: reverse;
}

*[data-a=stroke-line] {
  opacity: 0;
}
*[data-a=stroke-line] path {
  stroke-dasharray: 3000px;
  stroke-dashoffset: 3000px;
}
*[data-a=stroke-line].anime-active {
  opacity: 1;
}
*[data-a=stroke-line].anime-active path {
  -webkit-animation: just 1.2s infinite;
          animation: just 1.2s infinite;
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
  -webkit-animation-timing-function: ease-out;
          animation-timing-function: ease-out;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}

@-webkit-keyframes just {
  0% {
    stroke-dashoffset: 3000px;
  }
  100% {
    stroke-dashoffset: 0px;
  }
}

@keyframes just {
  0% {
    stroke-dashoffset: 3000px;
  }
  100% {
    stroke-dashoffset: 0px;
  }
}
*[data-a=tra-fade-up] {
  opacity: 0 !important;
  -webkit-transform: translateY(30px) !important;
          transform: translateY(30px) !important;
}
*[data-a=tra-fade-up].anime-active {
  opacity: 1 !important;
  -webkit-transform: translateY(0px) !important;
          transform: translateY(0px) !important;
}

*[data-a=tra-fade-in] {
  opacity: 0 !important;
}
*[data-a=tra-fade-in].anime-active {
  opacity: 1 !important;
}

*[data-a=tra-fade-up] {
  opacity: 0 !important;
  -webkit-transform: translateY(30px) !important;
          transform: translateY(30px) !important;
}
*[data-a=tra-fade-up].anime-active {
  opacity: 1 !important;
  -webkit-transform: translateY(0px) !important;
          transform: translateY(0px) !important;
}

*[data-a=mask-move-up] > * {
  display: block;
  overflow: hidden;
}
*[data-a=mask-move-up] > *:nth-child(1) > * {
  -webkit-transition-delay: 0.15s;
          transition-delay: 0.15s;
}
*[data-a=mask-move-up] > *:nth-child(2) > * {
  -webkit-transition-delay: 0.3s;
          transition-delay: 0.3s;
}
*[data-a=mask-move-up] > *:nth-child(3) > * {
  -webkit-transition-delay: 0.45s;
          transition-delay: 0.45s;
}
*[data-a=mask-move-up] > *:nth-child(4) > * {
  -webkit-transition-delay: 0.6s;
          transition-delay: 0.6s;
}
*[data-a=mask-move-up] > *:nth-child(5) > * {
  -webkit-transition-delay: 0.75s;
          transition-delay: 0.75s;
}
*[data-a=mask-move-up] > *:nth-child(6) > * {
  -webkit-transition-delay: 0.9s;
          transition-delay: 0.9s;
}
*[data-a=mask-move-up] > *:nth-child(7) > * {
  -webkit-transition-delay: 1.05s;
          transition-delay: 1.05s;
}
*[data-a=mask-move-up] > *:nth-child(8) > * {
  -webkit-transition-delay: 1.2s;
          transition-delay: 1.2s;
}
*[data-a=mask-move-up] > *:nth-child(9) > * {
  -webkit-transition-delay: 1.35s;
          transition-delay: 1.35s;
}
*[data-a=mask-move-up] > *:nth-child(10) > * {
  -webkit-transition-delay: 1.5s;
          transition-delay: 1.5s;
}
*[data-a=mask-move-up] > * > * {
  display: block;
  -webkit-transform: translateY(150%);
          transform: translateY(150%);
  position: relative;
  -webkit-transition: all 0.8s ease;
  transition: all 0.8s ease;
}
*[data-a=mask-move-up].anime-active > * > * {
  -webkit-transform: translateY(0%);
          transform: translateY(0%);
}

*[data-a=mask-right] {
  will-change: filter;
  position: relative;
  overflow: hidden;
  clip-path: inset(0 100% 0 0);
  -webkit-transition-timing-function: cubic-bezier(0.68, 0, 0.4, 0.99);
          transition-timing-function: cubic-bezier(0.68, 0, 0.4, 0.99);
}
*[data-a=mask-right].anime-active {
  clip-path: inset(0 0% 0 0);
}

*[data-a=mask-left] {
  will-change: filter;
  position: relative;
  overflow: hidden;
  clip-path: inset(0 0% 0 100%);
  -webkit-transition-timing-function: cubic-bezier(0.68, 0, 0.4, 0.99);
          transition-timing-function: cubic-bezier(0.68, 0, 0.4, 0.99);
}
*[data-a=mask-left].anime-active {
  clip-path: inset(0 0% 0 0);
}

@-webkit-keyframes anime-mask-right {
  0% {
    -webkit-mask-size: 0% 100%;
            mask-size: 0% 100%;
  }
  100% {
    -webkit-mask-size: 100% 100%;
            mask-size: 100% 100%;
  }
}

@keyframes anime-mask-right {
  0% {
    -webkit-mask-size: 0% 100%;
            mask-size: 0% 100%;
  }
  100% {
    -webkit-mask-size: 100% 100%;
            mask-size: 100% 100%;
  }
}
*[data-a=slide-bottom] {
  clip-path: inset(0% 0% 100% 0);
  position: relative;
  -webkit-transition-timing-function: cubic-bezier(0.68, 0, 0.4, 0.99);
          transition-timing-function: cubic-bezier(0.68, 0, 0.4, 0.99);
}
*[data-a=slide-bottom].anime-active {
  clip-path: inset(0 0 0 0);
}

*[data-a=slide-right] {
  clip-path: inset(0 100% 0 0);
  position: relative;
  -webkit-transition-timing-function: cubic-bezier(0.68, 0, 0.4, 0.99);
          transition-timing-function: cubic-bezier(0.68, 0, 0.4, 0.99);
}
*[data-a=slide-right].anime-active {
  clip-path: inset(0 0 0 0);
}

*[data-a=slide-left] {
  clip-path: inset(0 0% 0 100%);
  position: relative;
  -webkit-transition-timing-function: cubic-bezier(0.68, 0, 0.4, 0.99);
          transition-timing-function: cubic-bezier(0.68, 0, 0.4, 0.99);
}
*[data-a=slide-left].anime-active {
  clip-path: inset(0 0 0 0);
}

*[data-a=square] {
  opacity: 0;
  right: 0px !important;
  bottom: 260px !important;
  -webkit-transition-timing-function: cubic-bezier(0.68, 0, 0.4, 0.99);
          transition-timing-function: cubic-bezier(0.68, 0, 0.4, 0.99);
}
*[data-a=square].anime-active {
  opacity: 1;
  right: -80px !important;
  bottom: 60px !important;
}

html,
body,
main,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6 blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video,
input {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

@media (min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}

picture {
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

html {
  width: 100%;
  font-size: 62.5%;
  background: #fff;
}
@media (max-width: 767px) {
  html {
    font-size: 62.5%;
  }
}
@media (max-width: 375px) {
  html {
    font-size: 62.5%;
  }
}
html {
  -webkit-overflow-scrolling: touch;
}

body:lang(ja) {
  font-family: "Zen Old Mincho", serif;
}
body:lang(ko) {
  font-family: "Noto Serif KR", serif;
}
body:lang(zh-CN) {
  font-family: "Noto Serif SC", serif;
}
body:lang(en) {
  font-family: "Times New Roman", Times, Georgia, serif;
}
body {
  font-family: "Times New Roman", Times, Georgia, serif;
  font-weight: 400;
  font-size: 1.6rem;
  overflow-y: auto;
  overflow-x: hidden;
  color: #333;
  background: #fff;
}
@media (max-width: 767px) {
  body {
    -webkit-overflow-scrolling: touch;
    letter-spacing: 0em;
  }
}
body.scrollhide {
  overflow-y: hidden;
}

p {
  line-height: 2;
}

menu {
  list-style: none;
}

small {
  font-size: 0.89em;
}

main {
  display: block;
  position: relative;
}

img {
  vertical-align: top;
  -ms-interpolation-mode: bicubic;
  pointer-events: none;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

@media (min-width: 768px) {
  a {
    -webkit-user-select: none;
       -moz-user-select: none;
        -ms-user-select: none;
            user-select: none;
  }
}
a {
  text-decoration: none;
  color: #012257;
}

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

.pic {
  width: 100%;
  height: auto;
}

.sp {
  display: none;
}
@media (max-width: 767px) {
  .sp {
    display: block;
  }
}

@media (max-width: 767px) {
  .pc {
    display: none;
  }
}

main {
  display: block;
}

textarea {
  resize: vertical;
}

.ff--min:lang(ja) {
  font-family: "Zen Old Mincho", serif;
}
.ff--min:lang(ko) {
  font-family: "Noto Serif KR", serif;
}
.ff--min:lang(zh-CN) {
  font-family: "Noto Serif SC", serif;
}
.ff--min:lang(en) {
  font-family: "Times New Roman", Times, Georgia, serif;
}
.ff--min {
  font-style: normal;
  font-weight: 400;
}
.ff--en {
  font-family: "Damion", cursive;
  font-weight: 400;
  font-style: normal;
}

.fc--white {
  color: #fff;
}
.fc--egreen {
  color: #00B9AB;
}
.fc--green {
  color: #5DBF8F;
}
.fc--brown {
  color: #D09660;
}
.fc--blue {
  color: #7ECDCE;
}

body.active .nav-toggle-wrap {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
body.active .nav-toggle-wrap .nav-toggle span:nth-child(2) {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
body.active .global-nav {
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}

.site-header {
  position: fixed;
  left: 20px;
  top: 28px;
  -webkit-transition: all 0.6s ease;
  transition: all 0.6s ease;
}
@media (min-width: 1081px) {
  .site-header {
    opacity: 0;
    -webkit-filter: blur(12px);
            filter: blur(12px);
  }
}
@media (min-width: 1081px) {
  .site-header.view {
    opacity: 1;
    z-index: 800;
    -webkit-filter: blur(0px);
            filter: blur(0px);
  }
}
.site-header__ttl {
  font-size: 2rem;
}
@media (max-width: 1080px) {
  .site-header {
    mix-blend-mode: difference;
    width: 100%;
    height: 60px;
    left: 0;
    top: 0;
    position: fixed;
    z-index: 3000;
    opacity: 1;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    opacity: 1;
  }
  .site-header__ttl {
    font-size: 2rem;
    color: #fff;
    margin-left: 20px;
  }
}

.nav-toggle-wrap {
  display: none;
  cursor: pointer;
}
@media (min-width: 768px) {
  .nav-toggle-wrap {
    -webkit-transition: all 0.4s ease;
    transition: all 0.4s ease;
    cursor: pointer;
  }
  .nav-toggle-wrap:hover {
    background: #fff;
    background: #000;
  }
}
@media (max-width: 1080px) {
  .nav-toggle-wrap {
    display: block;
    width: 40px;
    height: 40px;
  }
}
.nav-toggle-wrap {
  backdrop-filter: blur(12px);
  background: rgb(255, 255, 255);
  background: #000;
  border-radius: 50%;
  right: 10px;
  top: 10px;
  z-index: 4000;
  position: fixed !important;
}
.nav-toggle-wrap .nav-toggle {
  -webkit-transition: all 0s ease;
  transition: all 0s ease;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  z-index: 10;
  width: 22px;
  height: 10px;
}
.nav-toggle-wrap .nav-toggle span {
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  border-radius: 10px;
  background: #000;
  background: #fff;
  display: block;
}
.nav-toggle-wrap .nav-toggle span:nth-child(1) {
  z-index: 2;
  top: 0;
  -webkit-animation-name: anime-nav-toggle-top2;
          animation-name: anime-nav-toggle-top2;
  -webkit-animation-duration: 0s;
          animation-duration: 0s;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
.nav-toggle-wrap .nav-toggle span:nth-child(1).active {
  -webkit-animation-duration: 0.6s;
          animation-duration: 0.6s;
}
.nav-toggle-wrap .nav-toggle span:nth-child(2) {
  display: none;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  -webkit-transition: all 0s ease;
  transition: all 0s ease;
}
.nav-toggle-wrap .nav-toggle span:nth-child(3) {
  z-index: 2;
  bottom: 0;
  -webkit-animation-name: anime-nav-toggle-bottom2;
          animation-name: anime-nav-toggle-bottom2;
  -webkit-animation-duration: 0s;
          animation-duration: 0s;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
.nav-toggle-wrap .nav-toggle span:nth-child(3).active {
  -webkit-animation-duration: 0.6s;
          animation-duration: 0.6s;
}
.nav-toggle-wrap.active span:nth-child(1) {
  -webkit-animation-name: anime-nav-toggle-top;
          animation-name: anime-nav-toggle-top;
  -webkit-animation-duration: 0.6s;
          animation-duration: 0.6s;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
.nav-toggle-wrap.active span:nth-child(2) {
  width: 0;
}
.nav-toggle-wrap.active span:nth-child(3) {
  width: 100%;
  -webkit-animation-name: anime-nav-toggle-bottom;
          animation-name: anime-nav-toggle-bottom;
  -webkit-animation-duration: 0.6s;
          animation-duration: 0.6s;
  -webkit-animation-iteration-count: 1;
          animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
@-webkit-keyframes anime-nav-toggle-top2 {
  0% {
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(45deg);
            transform: translateY(-50%) rotate(45deg);
  }
  50% {
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  100% {
    top: 0%;
  }
}
@keyframes anime-nav-toggle-top2 {
  0% {
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(45deg);
            transform: translateY(-50%) rotate(45deg);
  }
  50% {
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  100% {
    top: 0%;
  }
}
@-webkit-keyframes anime-nav-toggle-top {
  0% {
    top: 0%;
  }
  50% {
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  100% {
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(45deg);
            transform: translateY(-50%) rotate(45deg);
  }
}
@keyframes anime-nav-toggle-top {
  0% {
    top: 0%;
  }
  50% {
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  100% {
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(45deg);
            transform: translateY(-50%) rotate(45deg);
  }
}
@-webkit-keyframes anime-nav-toggle-bottom {
  0% {
    bottom: 0%;
  }
  50% {
    bottom: 50%;
    -webkit-transform: translateY(50%);
            transform: translateY(50%);
  }
  100% {
    bottom: 50%;
    -webkit-transform: translateY(50%) rotate(-45deg);
            transform: translateY(50%) rotate(-45deg);
  }
}
@keyframes anime-nav-toggle-bottom {
  0% {
    bottom: 0%;
  }
  50% {
    bottom: 50%;
    -webkit-transform: translateY(50%);
            transform: translateY(50%);
  }
  100% {
    bottom: 50%;
    -webkit-transform: translateY(50%) rotate(-45deg);
            transform: translateY(50%) rotate(-45deg);
  }
}
@-webkit-keyframes anime-nav-toggle-bottom2 {
  0% {
    bottom: 50%;
    -webkit-transform: translateY(50%) rotate(-45deg);
            transform: translateY(50%) rotate(-45deg);
  }
  50% {
    bottom: 50%;
    -webkit-transform: translateY(50%);
            transform: translateY(50%);
  }
  100% {
    bottom: 0%;
  }
}
@keyframes anime-nav-toggle-bottom2 {
  0% {
    bottom: 50%;
    -webkit-transform: translateY(50%) rotate(-45deg);
            transform: translateY(50%) rotate(-45deg);
  }
  50% {
    bottom: 50%;
    -webkit-transform: translateY(50%);
            transform: translateY(50%);
  }
  100% {
    bottom: 0%;
  }
}

.global-nav {
  position: fixed;
  width: 100%;
  height: 80px;
  z-index: 200;
  left: 0;
  top: 0;
}
@media (max-width: 1080px) {
  .global-nav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media (min-width: 1081px) {
  .global-nav.bg {
    backdrop-filter: blur(6px);
    background: rgba(255, 255, 255, 0.8);
  }
  .global-nav.bg menu li a {
    color: #333;
  }
}
@media (min-width: 1081px) and (min-width: 768px) {
  .global-nav.bg menu li a:hover {
    color: #00B9AB;
  }
  .global-nav.bg menu li a:hover span::after {
    width: 100%;
    background: #00B9AB;
  }
}
@media (min-width: 1081px) {
  .global-nav.bg menu li a span::after {
    background: #333;
  }
}
@media (max-width: 1080px) {
  .global-nav {
    pointer-events: none;
    width: 100%;
    height: 100%;
    opacity: 0;
  }
  .global-nav.active {
    pointer-events: all;
    opacity: 1;
    backdrop-filter: blur(61px);
    background: rgba(255, 255, 255, 0.5);
  }
}
.global-nav__main {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 80px;
}
@media (max-width: 1380px) {
  .global-nav__main {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    padding-left: 160px;
  }
}
@media (max-width: 1080px) {
  .global-nav__main {
    padding-left: 0px;
    padding-top: 80px;
    width: 100%;
    display: block;
    height: auto;
  }
}
.global-nav__main li a {
  color: #fff;
}
.global-nav__main li a:lang(ja) {
  font-family: "Zen Old Mincho", serif;
}
.global-nav__main li a:lang(ko) {
  font-family: "Noto Serif KR", serif;
}
.global-nav__main li a:lang(zh-CN) {
  font-family: "Noto Serif SC", serif;
}
.global-nav__main li a:lang(en) {
  font-family: "Times New Roman", Times, Georgia, serif;
}
.global-nav__main li a {
  font-style: normal;
  font-weight: 400;
  letter-spacing: 0.2em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 80px;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
  padding: 0 36px;
}
@media (max-width: 1230px) {
  .global-nav__main li a {
    padding: 0 18px;
    height: 60px;
  }
}
@media (min-width: 768px) and (min-width: 768px) {
  .global-nav__main li a {
    -webkit-transition: all 0.4s ease;
    transition: all 0.4s ease;
    cursor: pointer;
  }
  .global-nav__main li a:hover span::after {
    width: 100%;
  }
}
@media (max-width: 1080px) {
  .global-nav__main li a {
    color: #333;
  }
}
.global-nav__main li a span {
  position: relative;
}
.global-nav__main li a span::after {
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
  content: "";
  width: 0%;
  height: 1px;
  background: #fff;
  position: absolute;
  left: 0;
  bottom: 0;
}

.header-language {
  position: fixed;
  top: 25px;
  right: 200px;
  z-index: 410;
  border: solid 1px #fff;
  border-radius: 20px;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr;
  grid-template-columns: 1fr;
  -ms-grid-rows: 1fr;
  grid-template-rows: 1fr;
  gap: 5px;
  width: 90px;
  padding: 4px 0;
  text-align: center;
}

.header-language > *:nth-child(1) {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
}
@media (min-width: 1081px) {
  .header-language {
    color: #fff;
  }
}
@media (max-width: 1080px) {
  .header-language {
    display: none;
  }
}
@media (min-width: 1081px) {
  .header-language.view {
    border: rgba(0, 0, 0, 0.2) 1px solid;
  }
}
@media (min-width: 1081px) and (min-width: 768px) {
  .header-language.view {
    -webkit-transition: all 0.2s ease;
    transition: all 0.2s ease;
    cursor: pointer;
  }
  .header-language.view:hover {
    border: solid 1px #fff;
    color: #7ECDCE;
  }
}
@media (min-width: 1081px) {
  .header-language.view li a {
    color: rgba(0, 0, 0, 0.8);
  }
}
@media (min-width: 768px) {
  .header-language:not(.not-hover) {
    -webkit-transition: all 0.4s ease;
    transition: all 0.4s ease;
    cursor: pointer;
  }
  .header-language:not(.not-hover):hover {
    background: #fff;
  }
  .header-language:not(.not-hover):hover li {
    display: block;
  }
  .header-language:not(.not-hover):hover li a {
    color: #333;
  }
}
@media (min-width: 768px) and (min-width: 768px) {
  .header-language:not(.not-hover):hover li a {
    -webkit-transition: all 0.2s ease;
    transition: all 0.2s ease;
    cursor: pointer;
  }
  .header-language:not(.not-hover):hover li a:hover {
    color: #7ECDCE;
  }
}
.header-language li.active {
  -ms-grid-row: 1;
  grid-row: 1;
  display: block;
}
.header-language li {
  display: none;
}
.header-language a {
  padding: 3px 20px;
  display: block;
}
@media (min-width: 1081px) {
  .header-language a {
    color: #fff;
    font-size: 1.2rem;
  }
}

@media (max-width: 1080px) {
  .header-contact {
    display: none;
  }
}
.header-contact.view .btn--reserve {
  border: solid 1px #00B9AB;
  color: #00B9AB;
}
.header-contact.view .btn--reserve span::after {
  color: #00B9AB;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media (min-width: 768px) {
  .header-contact.view .btn--reserve {
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
    cursor: pointer;
  }
  .header-contact.view .btn--reserve:hover {
    border: solid 1px #00B9AB;
    color: #fff;
    background: #00B9AB;
  }
  .header-contact.view .btn--reserve:hover span::after {
    color: #fff;
  }
}
.header-contact .btn--reserve {
  position: fixed;
  right: 20px;
  top: 17px;
  border: solid 1px #fff;
  border-radius: 50px;
  color: #fff;
}
.header-contact .btn--reserve:lang(ja) {
  font-family: "Zen Old Mincho", serif;
}
.header-contact .btn--reserve:lang(ko) {
  font-family: "Noto Serif KR", serif;
}
.header-contact .btn--reserve:lang(zh-CN) {
  font-family: "Noto Serif SC", serif;
}
.header-contact .btn--reserve:lang(en) {
  font-family: "Times New Roman", Times, Georgia, serif;
}
.header-contact .btn--reserve {
  font-style: normal;
  font-weight: 400;
  height: 48px;
  width: 160px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  z-index: 200;
  font-size: 1.8rem;
}
@media (min-width: 768px) {
  .header-contact .btn--reserve {
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
    cursor: pointer;
  }
  .header-contact .btn--reserve:hover {
    border: solid 1px #fff;
    color: #333;
    background: #fff;
  }
  .header-contact .btn--reserve:hover span::after {
    color: #333;
  }
}
.header-contact .btn--reserve span {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
  padding-left: 20px;
}
.header-contact .btn--reserve span::after {
  content: "";
  font-family: "Material Symbols Outlined";
  content: "\e614";
  font-size: 2.6rem;
}
@media (min-width: 1081px) {
  .header-contact .btn--reserve span::after {
    color: #fff;
  }
}
@media (max-width: 1080px) {
  .header-contact .btn--reserve span::after {
    color: #00B9AB;
  }
}
.header-contact .btn--reserve span::after {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

@media (max-width: 1080px) {
  .global-nav {
    display: block;
  }
}
.global-nav .header-language {
  display: none;
}
@media (max-width: 1080px) {
  .global-nav .header-language {
    display: block;
    position: relative;
    top: 0;
    right: 0;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: auto;
    height: auto;
    background: #fff;
  }
  .global-nav .header-language.open li {
    display: block !important;
  }
  .global-nav .header-language.open a {
    pointer-events: all;
  }
  .global-nav .header-language li.active a {
    color: #00B9AB !important;
    pointer-events: none !important;
  }
  .global-nav .header-language a {
    border-radius: 100px;
    font-size: 1.5rem !important;
    pointer-events: none;
    color: #333 !important;
    padding: 7px 40px;
  }
  .global-nav .header-language {
    border: solid 1px #ccc !important;
  }
}
@media (max-width: 1080px) and (max-width: 767px) {
  .global-nav .header-language {
    border: solid none !important;
  }
}
.global-nav .header-contact {
  position: relative;
  margin: 30px auto;
  display: block;
  display: none;
}
@media (max-width: 960px) {
  .global-nav .header-contact {
    display: block;
  }
}
.global-nav .header-contact .btn--reserve {
  right: 0;
  top: 0;
  margin: auto;
  position: relative;
  background: #fff;
  color: #7ECDCE !important;
  border: none !important;
}

.kv {
  position: relative;
  z-index: 2;
  background: #000;
}
.kv .heading {
  position: absolute;
  z-index: 10;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  color: #fff;
  text-align: center;
}
@media (max-width: 767px) {
  .kv .heading {
    top: 50%;
  }
}
.kv .heading strong {
  font-weight: 400;
  font-size: 4rem;
  letter-spacing: 0.1em;
  white-space: nowrap;
}
.kv .heading strong:lang(en) {
  white-space: wrap;
}
@media (max-width: 767px) {
  .kv .heading strong {
    font-size: 2.4rem;
  }
}
.kv .heading img {
  width: 516px;
  height: auto;
  margin: 20px 0;
}
@media (max-width: 767px) {
  .kv .heading img {
    width: 140%;
    -webkit-transform: translateX(-15%);
            transform: translateX(-15%);
  }
}
.kv .heading h2 {
  font-size: 10rem;
  white-space: nowrap;
}
@media (max-width: 767px) {
  .kv .heading h2 {
    font-size: 5rem;
  }
}
.kv {
  width: 100%;
  height: calc(var(--vh, 1vh) * 100);
}
.kv .splide__slide {
  height: calc(var(--vh, 1vh) * 100);
}
.kv .splide__slide.current picture {
  -webkit-transition: all 20s ease;
  transition: all 20s ease;
  -webkit-transform: scale(1.3);
          transform: scale(1.3);
  z-index: 1;
}
.kv picture {
  display: block;
  -webkit-transition: all 100s ease;
  transition: all 100s ease;
  width: 100%;
  height: calc(var(--vh, 1vh) * 100);
}
.kv picture img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: calc(var(--vh, 1vh) * 100);
}

.day_slot {
  position: relative;
}

body .kv-wrap {
  width: 100%;
  height: calc(var(--vh, 1vh) * 100);
  z-index: 3000;
  position: fixed;
  left: 0;
  top: 0;
  pointer-events: none;
  z-index: 1200;
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
  opacity: 1;
}
body .kv-wrap > .heading {
  position: absolute;
  z-index: 10;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  color: #00B9AB;
  text-align: center;
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
  mix-blend-mode: difference;
}
@media (max-width: 767px) {
  body .kv-wrap > .heading {
    top: 50%;
  }
}
body .kv-wrap > .heading strong {
  font-weight: 400;
  font-size: 4rem;
  letter-spacing: 0.1em;
  white-space: nowrap;
}
body .kv-wrap > .heading strong:lang(en) {
  white-space: wrap;
}
@media (max-width: 767px) {
  body .kv-wrap > .heading strong {
    font-size: 2.4rem;
  }
}
body .kv-wrap > .heading h2 {
  font-size: 10rem;
  white-space: nowrap;
}
@media (max-width: 767px) {
  body .kv-wrap > .heading h2 {
    font-size: 5rem;
  }
}
body .kv-wrap > .heading h2 img {
  width: 516px;
  height: auto;
  margin: 20px 0;
}
@media (max-width: 767px) {
  body .kv-wrap > .heading h2 img {
    width: 140%;
    -webkit-transform: translateX(-15%);
            transform: translateX(-15%);
  }
}
body .splash {
  width: 100%;
  height: 100vh;
  z-index: 3000;
  opacity: 1;
  position: fixed;
  left: 0;
  top: 0;
  pointer-events: none;
  background: #FFF;
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
  -webkit-transition-delay: 2s;
          transition-delay: 2s;
  z-index: 900;
}
body.open .kv-wrap {
  opacity: 1;
}
body.active .splash {
  opacity: 0;
}
body.active .kv-wrap .heading {
  -webkit-transition-delay: 1s;
          transition-delay: 1s;
  opacity: 0;
}

.site-wrap {
  background: #fff;
  position: relative;
  overflow: clip;
}

main {
  display: block;
}

.btn--reserve {
  border: solid 1px #D09660;
  border-radius: 50px;
  color: #D09660;
}
.btn--reserve:lang(ja) {
  font-family: "Zen Old Mincho", serif;
}
.btn--reserve:lang(ko) {
  font-family: "Noto Serif KR", serif;
}
.btn--reserve:lang(zh-CN) {
  font-family: "Noto Serif SC", serif;
}
.btn--reserve:lang(en) {
  font-family: "Times New Roman", Times, Georgia, serif;
}
.btn--reserve {
  font-style: normal;
  font-weight: 400;
  height: 48px;
  width: 180px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  z-index: 200;
  font-size: 1.8rem;
}
@media (min-width: 768px) {
  .btn--reserve {
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
    cursor: pointer;
  }
  .btn--reserve:hover {
    border: solid 1px #D09660;
    color: #fff;
    background: #D09660;
  }
  .btn--reserve:hover span::after {
    color: #fff;
  }
}
.btn--reserve span {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
  padding-left: 20px;
}
.btn--reserve span::after {
  content: "";
  font-family: "Material Symbols Outlined";
  content: "\e614";
  font-size: 2.6rem;
  color: #D09660;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.btn--reserve02 {
  border: solid 1px #D09660;
  border-radius: 50px;
  color: #D09660;
  background: #fff;
  margin: 70px auto 0;
}
.btn--reserve02:lang(ja) {
  font-family: "Zen Old Mincho", serif;
}
.btn--reserve02:lang(ko) {
  font-family: "Noto Serif KR", serif;
}
.btn--reserve02:lang(zh-CN) {
  font-family: "Noto Serif SC", serif;
}
.btn--reserve02:lang(en) {
  font-family: "Times New Roman", Times, Georgia, serif;
}
.btn--reserve02 {
  font-style: normal;
  font-weight: 400;
  height: 68px;
  width: 300px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  z-index: 200;
  font-size: 2.4rem;
}
@media (max-width: 767px) {
  .btn--reserve02 {
    height: 54px;
    font-size: 2rem;
    width: 90%;
  }
}
@media (min-width: 768px) {
  .btn--reserve02 {
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
    cursor: pointer;
  }
  .btn--reserve02:hover {
    border: solid 1px #D09660;
    color: #fff;
    background: #D09660;
  }
  .btn--reserve02:hover span::after {
    color: #fff;
  }
}
.btn--reserve02 span {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
  padding-left: 20px;
}
.btn--reserve02 span::after {
  content: "";
  font-family: "Material Symbols Outlined";
  content: "\e614";
  font-size: 2.6rem;
  color: #D09660;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.btn--round {
  color: #5DBF8F;
  border: solid 1px #5DBF8F;
  border-radius: 50px;
  max-width: 240px;
  width: 100%;
  height: 50px;
  font-size: 1.8rem;
  display: block;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.btn--round.color--blue {
  color: #7ECDCE;
  border: solid 1px #7ECDCE;
}
@media (min-width: 768px) {
  .btn--round.color--blue {
    -webkit-transition: all 0.4s ease;
    transition: all 0.4s ease;
    cursor: pointer;
  }
  .btn--round.color--blue:hover {
    background: #7ECDCE;
    color: #fff;
  }
  .btn--round.color--blue:hover .icon--right::after {
    color: #fff;
  }
}
@media (min-width: 768px) {
  .btn--round {
    -webkit-transition: all 0.4s ease;
    transition: all 0.4s ease;
    cursor: pointer;
  }
  .btn--round:hover {
    background: #5DBF8F;
    color: #fff;
  }
  .btn--round:hover .icon--down::after {
    color: #fff;
    -webkit-transform: translateY(0.2em);
            transform: translateY(0.2em);
  }
}
@media (max-width: 767px) {
  .btn--round {
    margin: auto;
  }
}

.icon--pin {
  position: relative;
}
.icon--pin::after {
  position: absolute;
  right: 10px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  content: "";
  font-family: "Material Symbols Outlined";
  content: "\e0c8";
  font-size: 3rem;
  color: #5DBF8F;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media (min-width: 768px) {
  .icon--pin {
    -webkit-transition: all 0.4s ease;
    transition: all 0.4s ease;
    cursor: pointer;
  }
  .icon--pin:hover::after {
    color: #fff;
  }
}
.icon--right {
  padding-left: 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
}
@media (min-width: 768px) {
  .icon--right::after {
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }
}
.icon--right::after {
  content: "";
  font-family: "Material Symbols Outlined";
  content: "\e5cc";
  font-size: 2.6rem;
  color: #5DBF8F;
}
.icon--down {
  padding-left: 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
}
@media (min-width: 768px) {
  .icon--down::after {
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }
}
.icon--down::after {
  content: "";
  font-family: "Material Symbols Outlined";
  content: "\e5cf";
  font-size: 2.6rem;
  color: #5DBF8F;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.sec {
  position: relative;
  z-index: 0;
}

.sns {
  position: fixed;
  left: 50%;
  bottom: 30px;
  z-index: 12;
  color: #fff;
  -webkit-transform: translate(-50%);
          transform: translate(-50%);
  z-index: 700;
  mix-blend-mode: difference;
}
@media (max-width: 767px) {
  .sns img {
    width: 32px;
    height: auto;
  }
}

.concept-wrap {
  position: relative;
  z-index: 100;
}

.scroll-info {
  position: absolute;
  right: 0px;
  bottom: 0px;
  z-index: 12;
}
@media (max-width: 767px) {
  .scroll-info {
    right: 4px;
  }
}
.scroll-info p {
  color: #fff;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  font-size: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  line-height: 1;
  gap: 10px;
}
@media (max-width: 767px) {
  .scroll-info p {
    margin: 0;
    font-size: 1.4rem;
  }
}
.scroll-info p::after {
  content: "";
  width: 1px;
  height: 150px;
  background: #fff;
  -webkit-transform: translateX(0.2em);
          transform: translateX(0.2em);
}
@media (max-width: 767px) {
  .scroll-info p::after {
    height: 100px;
  }
}

.side-info {
  position: sticky;
  bottom: 0px;
  width: 100%;
  font-size: 24px;
  color: #fff;
  z-index: 100;
  mix-blend-mode: difference;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  pointer-events: none;
}
.side-info p {
  white-space: nowrap;
  position: absolute;
  top: 0;
  -webkit-transform: translateY(-100%);
          transform: translateY(-100%);
  font-family: "Damion", cursive;
  font-weight: 400;
  font-size: 2rem;
  text-align: right;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  gap: 10px;
  line-height: 1;
}
@media (max-width: 767px) {
  .side-info p {
    font-size: 1.4rem;
  }
}
@media (max-width: 767px) {
  .side-info p {
    right: -10px;
  }
}
.side-info p::after {
  content: "";
  width: 1px;
  height: 150px;
  background: #fff;
  -webkit-transform: translateX(0.2em);
          transform: translateX(0.2em);
}
@media (max-width: 767px) {
  .side-info p::after {
    height: 100px;
  }
}
.side-info p::after {
  content: "";
}

.backtotop {
  position: absolute;
  right: 0px;
  bottom: 100px;
  z-index: 12;
}
@media (max-width: 767px) {
  .backtotop {
    bottom: 50px;
    margin-right: 4px;
  }
}
.backtotop p {
  color: #333;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  font-size: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  line-height: 1;
  gap: 10px;
}
@media (max-width: 767px) {
  .backtotop p {
    font-size: 1.4rem;
  }
}
.backtotop p::after {
  content: "";
  width: 1px;
  height: 20px;
  background: #333;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  position: absolute;
  top: 0;
  left: 24px;
  -webkit-transform-origin: left top 0;
          transform-origin: left top 0;
}
@media (max-width: 767px) {
  .backtotop p::after {
    height: 15px;
    left: 17px;
  }
}
.backtotop p::before {
  content: "";
  width: 1px;
  height: 120px;
  background: #333;
  -webkit-transform: translateX(0.2em);
          transform: translateX(0.2em);
}
@media (max-width: 767px) {
  .backtotop p::before {
    height: 60px;
  }
}

body.noscroll {
  overflow-y: none;
}

.sec {
  position: relative;
}
.sec__inner {
  max-width: 2000px;
  margin: auto;
  padding: 0 80px;
  position: relative;
}
@media (max-width: 767px) {
  .sec__inner {
    padding: 0 20px;
  }
}
.sec__read {
  text-align: center;
  margin: 70px auto 70px;
  position: relative;
  z-index: 20;
}
.sec__read p {
  line-height: 3;
}
@media (max-width: 767px) {
  .sec__read {
    margin: 40px auto 40px;
  }
}
.sec__header h2 {
  text-align: center;
}
.sec__header h2 span {
  line-height: 1;
  display: block;
  font-size: 10rem;
  margin-bottom: 10px;
}
@media (max-width: 767px) {
  .sec__header h2 span {
    margin-bottom: 15px;
    font-size: 5rem;
  }
}
.sec__header h2 strong {
  line-height: 1;
  font-weight: 400;
  font-size: 2rem;
  display: block;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 10px;
}
@media (max-width: 767px) {
  .sec__header h2 strong {
    gap: 5px;
    font-size: 1.4rem;
  }
}
.sec__header h2 strong::before, .sec__header h2 strong::after {
  content: "";
  height: 1px;
  width: 17px;
  background: #333;
}
@media (max-width: 767px) {
  .sec__header h2 strong::before, .sec__header h2 strong::after {
    width: 12px;
  }
}
.sec--concept {
  height: 100vh;
  min-height: 1080px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
  z-index: 2;
}
.sec--concept > * {
  width: 100%;
}
@media (max-width: 767px) {
  .sec--concept {
    min-height: auto;
    height: auto;
    padding: 160px 30px 80px;
  }
}
.sec--concept {
  background: #fff;
}
@media (max-width: 767px) {
  .sec--concept #video-element-sp {
    opacity: 0.4;
  }
}
@media (min-width: 768px) {
  .sec--concept__main {
    text-shadow: 0px 0px 20px rgba(0, 0, 0, 0.6), 0px 0px 3px rgb(0, 0, 0), 0px 0px 6px rgb(0, 0, 0), 0px 0px 8px rgba(0, 0, 0, 0.8), 0px 0px 30px rgba(0, 0, 0, 0.3);
  }
}
@media (max-width: 767px) {
  .sec--concept__main {
    -webkit-transform: translateY(-60px);
            transform: translateY(-60px);
    text-shadow: 0px 0px 20px rgba(255, 255, 255, 0.6), 0px 0px 3px rgb(255, 255, 255), 0px 0px 6px rgb(255, 255, 255), 0px 0px 8px rgba(255, 255, 255, 0.8), 0px 0px 30px rgba(255, 255, 255, 0.3);
  }
}
.sec--concept__main {
  position: relative;
  z-index: 2;
  max-width: 1280px;
  width: 100%;
}
@media (min-width: 768px) {
  .sec--concept__main {
    width: calc(100% - 80px);
  }
}
@media (min-width: 768px) and (max-width: 1180px) {
  .sec--concept__main {
    width: calc(100% - 80px);
  }
}
.sec--concept__main {
  margin: auto;
}
@media (min-width: 768px) {
  .sec--concept__main header {
    position: absolute;
    right: 0;
  }
  .sec--concept__main header:lang(en) {
    position: relative;
    text-align: center;
    margin-bottom: 2em;
  }
}
@media (min-width: 768px) {
  .sec--concept__main header h2 {
    position: absolute;
    right: 0;
    font-weight: 400;
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    white-space: nowrap;
  }
  .sec--concept__main header h2:lang(en) {
    position: relative;
    -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: lr-tb;
            writing-mode: horizontal-tb;
  }
  .sec--concept__main header h2 {
    font-size: 5rem;
    letter-spacing: 0.2em;
  }
}
@media (min-width: 768px) and (max-width: 1180px) {
  .sec--concept__main header h2 {
    font-size: 4rem;
  }
}
@media (min-width: 768px) and (max-width: 960px) {
  .sec--concept__main header h2 {
    font-size: 3rem;
  }
}
@media (max-width: 767px) {
  .sec--concept__main header h2 {
    font-weight: 600;
    color: #333;
    text-align: center;
    font-size: 3rem;
  }
}
.sec--concept__main p {
  font-size: 2rem;
}
@media (min-width: 768px) {
  .sec--concept__main p {
    padding: 0 140px;
  }
}
@media (min-width: 768px) and (max-width: 1180px) {
  .sec--concept__main p {
    font-size: 1.8rem;
  }
  .sec--concept__main p:lang(en) {
    padding: 0 60px;
  }
}
@media (min-width: 768px) and (max-width: 960px) {
  .sec--concept__main p {
    padding: 0 80px 0;
  }
  .sec--concept__main p br {
    display: block;
  }
}
@media (min-width: 768px) {
  .sec--concept__main p {
    line-height: 3.3;
    letter-spacing: 0.15em;
  }
}
.sec--concept__main p {
  text-align: center;
  margin: 0;
}
@media (max-width: 767px) {
  .sec--concept__main p {
    font-weight: 600;
    color: #333;
    margin-top: 30px;
    line-height: 2.5;
    font-size: 1.6rem;
  }
  .sec--concept__main p:lang(en) {
    text-align: left;
  }
  .sec--concept__main p:lang(en) br {
    display: none;
  }
}
.sec--concept__video {
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  margin: 0px 0 0 auto;
  overflow: hidden;
  z-index: 0;
}
@media (max-width: 767px) {
  .sec--concept__video {
    width: 100%;
    height: 100%;
    margin: auto;
    aspect-ratio: 1/1;
  }
}
.sec--concept__video video {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateX(-50%) translateY(-50%);
          transform: translateX(-50%) translateY(-50%);
  min-width: 100%;
  min-height: 100%;
}
.sec--concept2 {
  background: #FFFAEB;
  padding: 200px 0 0px;
  position: relative;
  z-index: 2;
}
@media (min-width: 768px) {
  .sec--concept2 {
    margin-bottom: -160px;
  }
}
@media (max-width: 767px) {
  .sec--concept2 {
    padding: 80px 0 0px;
  }
}
.sec--concept2 .sec__inner {
  padding: 0 40px;
}
@media (max-width: 1400px) {
  .sec--concept2 .sec__inner {
    padding: 0px;
  }
}
.sec--concept2__main {
  width: 100%;
  margin: auto;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 600px 0.8fr;
  grid-template-columns: 1fr 600px 0.8fr;
  -ms-grid-rows: 1fr;
  grid-template-rows: 1fr;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-bottom: 100px;
}
.sec--concept2__main > *:nth-child(1) {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
}
.sec--concept2__main > *:nth-child(2) {
  -ms-grid-row: 1;
  -ms-grid-column: 2;
}
.sec--concept2__main > *:nth-child(3) {
  -ms-grid-row: 1;
  -ms-grid-column: 3;
}
@media (max-width: 1580px) {
  .sec--concept2__main {
    -ms-grid-columns: 1fr 500px 0.8fr;
    grid-template-columns: 1fr 500px 0.8fr;
    -ms-grid-rows: 1fr;
    grid-template-rows: 1fr;
  }
  .sec--concept2__main > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .sec--concept2__main > *:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .sec--concept2__main > *:nth-child(3) {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
}
@media (max-width: 1400px) {
  .sec--concept2__main {
    -ms-grid-columns: 0.9fr 1fr 0.8fr;
    grid-template-columns: 0.9fr 1fr 0.8fr;
    -ms-grid-rows: 1fr;
    grid-template-rows: 1fr;
  }
  .sec--concept2__main > *:nth-child(1) {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .sec--concept2__main > *:nth-child(2) {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .sec--concept2__main > *:nth-child(3) {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
}
@media (max-width: 767px) {
  .sec--concept2__main {
    padding-bottom: 0px;
    display: block;
  }
  .sec--concept2__main .text {
    padding: 0 20px;
  }
}
.sec--concept2__main .img01 {
  padding: 0 110px;
  position: relative;
  z-index: 2;
}
@media (max-width: 1880px) {
  .sec--concept2__main .img01 {
    padding: 0 90px 0 0;
  }
}
@media (max-width: 1680px) {
  .sec--concept2__main .img01 {
    padding: 0 40px 0 0;
  }
}
@media (max-width: 767px) {
  .sec--concept2__main .img01 {
    padding: 0 0px 0 0;
  }
}
.sec--concept2__main .img01 img:not(.icon--kai) {
  max-width: 435px;
  display: block;
  margin: auto;
}
@media (max-width: 767px) {
  .sec--concept2__main .img01 img:not(.icon--kai) {
    width: 70%;
    margin: 0 0px 40px auto;
  }
}
.sec--concept2__main .text {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 50px;
}
@media (max-width: 767px) {
  .sec--concept2__main .text {
    gap: 30px;
  }
}
.sec--concept2__main .text p {
  margin: 0;
  line-height: 3.5;
}
@media (max-width: 767px) {
  .sec--concept2__main .text p {
    line-height: 2;
  }
}
@media (max-width: 1280px) {
  .sec--concept2__main .text p {
    line-height: 2.5;
    font-size: 1.5rem;
  }
}
@media (max-width: 1580px) {
  .sec--concept2__main .text p br {
    display: none;
  }
}
.sec--concept2__main .img02 {
  padding: 0 0 0 90px;
  position: relative;
  z-index: 2;
}
@media (max-width: 1680px) {
  .sec--concept2__main .img02 {
    padding: 0 0 0 40px;
  }
}
@media (max-width: 767px) {
  .sec--concept2__main .img02 {
    width: calc(100% + 30px);
    margin-top: 40px;
    margin-left: -30px;
    padding: 0;
  }
}
.sec--concept2__main .img02__02 {
  width: 45%;
}
@media (max-width: 1680px) {
  .sec--concept2__main .img02__02 {
    width: 65%;
  }
}
.sec--concept2__main .img02__02 {
  display: block;
  margin-top: 146px;
}
@media (max-width: 767px) {
  .sec--concept2__main .img02__02 {
    width: 40%;
    margin-top: 20px;
    margin-left: auto;
    margin-right: 70px;
  }
}
.sec--concept2 .icon--plant {
  position: absolute;
  left: 0;
  top: 0;
}
@media (max-width: 767px) {
  .sec--concept2 .icon--plant {
    width: 140px;
    height: auto;
  }
}
.sec--concept2 .icon--sandals {
  position: absolute;
  right: 40%;
  top: 54px;
}
@media (max-width: 767px) {
  .sec--concept2 .icon--sandals {
    right: 10%;
    top: -20px;
    width: 40px;
    height: auto;
  }
}
.sec--concept2 .icon--ball {
  position: absolute;
  right: 5%;
  top: 64%;
  width: 20%;
}
@media (max-width: 767px) {
  .sec--concept2 .icon--ball {
    width: 60px;
    height: auto;
    right: 0;
    top: auto;
    bottom: -140px;
  }
}
.sec--concept2 .icon--kai {
  position: absolute;
  left: 40%;
  bottom: -160px;
}
@media (max-width: 767px) {
  .sec--concept2 .icon--kai {
    width: 40px;
    height: auto;
    left: 6%;
    bottom: 30px;
  }
}
.sec--concept2 .icon--hitode {
  position: absolute;
  right: 10%;
  bottom: -120px;
}
@media (max-width: 767px) {
  .sec--concept2 .icon--hitode {
    width: 40px;
    height: auto;
    left: 30px;
    bottom: 60px;
  }
}
.sec--flow {
  position: relative;
  z-index: 3;
}
@media (max-width: 767px) {
  .sec--flow {
    z-index: 0;
  }
}
.sec--flow .bg {
  background: -webkit-gradient(linear, left top, left bottom, from(rgb(213, 239, 238)), color-stop(45%, rgb(213, 239, 238)), color-stop(55%, rgba(255, 190, 111, 0.9)), color-stop(60%, rgba(138, 0, 212, 0)), color-stop(70%, rgba(138, 0, 212, 0)), color-stop(73%, rgb(252, 255, 232)), to(rgb(205, 238, 255)));
  background: linear-gradient(180deg, rgb(213, 239, 238) 0%, rgb(213, 239, 238) 45%, rgba(255, 190, 111, 0.9) 55%, rgba(138, 0, 212, 0) 60%, rgba(138, 0, 212, 0) 70%, rgb(252, 255, 232) 73%, rgb(205, 238, 255) 100%);
}
@media (max-width: 767px) {
  .sec--flow .bg {
    background: -webkit-gradient(linear, left top, left bottom, from(rgb(213, 239, 238)), color-stop(52%, rgb(213, 239, 238)), color-stop(60%, rgba(255, 190, 111, 0.9)), color-stop(70%, rgba(138, 0, 212, 0)), color-stop(75%, rgba(138, 0, 212, 0)), color-stop(80%, rgb(255, 255, 206)), color-stop(90%, rgb(205, 238, 255)));
    background: linear-gradient(180deg, rgb(213, 239, 238) 0%, rgb(213, 239, 238) 52%, rgba(255, 190, 111, 0.9) 60%, rgba(138, 0, 212, 0) 70%, rgba(138, 0, 212, 0) 75%, rgb(255, 255, 206) 80%, rgb(205, 238, 255) 90%);
  }
}
.sec--flow .bg {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
}
@media (min-width: 768px) {
  .sec--flow .bg2 {
    background: url(../img/sec03_bg_0101@2x.png) repeat-x;
    background-size: cover;
    background-position: left bottom;
    background-attachment: fixed;
    width: 100%;
    height: 100%;
    z-index: 1;
    position: absolute;
    left: 0;
    top: 0;
  }
}
@media (max-width: 767px) {
  .sec--flow .bg2 {
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0;
    bottom: 0;
    z-index: 0;
  }
  .sec--flow .bg2 img {
    width: 100%;
    height: 100%;
    bottom: 0;
    -o-object-fit: cover;
       object-fit: cover;
  }
}
.sec--flow {
  background: #D5EFEE;
  position: relative;
  padding: 100px 0 400px;
}
@media (max-width: 767px) {
  .sec--flow {
    padding: 20px 0 140px;
  }
}
.sec--flow .sec__inner {
  position: relative;
  z-index: 10;
}
.sec--flow .sec__inner .sec__header {
  padding-bottom: 180px;
}
@media (max-width: 767px) {
  .sec--flow .sec__inner .sec__header {
    padding-bottom: 100px;
  }
}
.sec--flow__main {
  max-width: 1280px;
  padding: 0px 80px 0;
  margin: auto;
  position: relative;
  z-index: 20;
}
@media (max-width: 767px) {
  .sec--flow__main {
    padding: 0px 25px 0;
  }
}
.sec--flow__main ul {
  list-style: none;
  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;
  gap: 80px;
}
@media (max-width: 767px) {
  .sec--flow__main ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 40px;
  }
}
.sec--flow__main ul::before {
  content: "";
  position: absolute;
}
@media (min-width: 768px) {
  .sec--flow__main ul::before {
    left: 50%;
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.sec--flow__main ul::before {
  width: 3px;
  height: 100%;
  background: #fff;
}
@media (max-width: 767px) {
  .sec--flow__main ul::before {
    width: 2px;
    left: 13px;
  }
}
.sec--flow__main ul li.m-top {
  margin-top: 200px;
}
@media (max-width: 767px) {
  .sec--flow__main ul li.m-top {
    margin-top: 100px;
  }
}
.sec--flow__main ul li:last-child {
  margin-top: 200px;
}
@media (max-width: 767px) {
  .sec--flow__main ul li:last-child {
    margin-top: 0px;
  }
}
.sec--flow__main ul li {
  position: relative;
}
.sec--flow__main ul li::before {
  content: "";
  position: absolute;
}
@media (min-width: 768px) {
  .sec--flow__main ul li::before {
    left: 50%;
  }
}
.sec--flow__main ul li::before {
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #fff;
}
@media (max-width: 767px) {
  .sec--flow__main ul li::before {
    display: none;
    -webkit-transform: translate(0%, -50%);
            transform: translate(0%, -50%);
    top: 56%;
    left: 10px;
    width: 14px;
    height: 14px;
  }
}
.sec--flow__main ul li:nth-child(even) figure > .img {
  -ms-grid-column: 2;
  grid-column: 2;
  -ms-grid-row: 1;
  grid-row: 1;
}
.sec--flow__main ul li:nth-child(even) figure > figcaption {
  -ms-grid-column: 1;
  grid-column: 1;
  -ms-grid-row: 1;
  grid-row: 1;
}
.sec--flow__main ul li figure .img {
  position: relative;
}
.sec--flow__main ul li figure {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 200px 1.05fr;
  grid-template-columns: 1fr 1.05fr;
  -ms-grid-rows: auto;
  grid-template-rows: auto;
  gap: 200px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.sec--flow__main ul li figure > *:nth-child(1) {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
}
.sec--flow__main ul li figure > *:nth-child(2) {
  -ms-grid-row: 1;
  -ms-grid-column: 3;
}
@media (max-width: 1280px) {
  .sec--flow__main ul li figure {
    gap: 100px;
  }
}
@media (max-width: 767px) {
  .sec--flow__main ul li figure {
    display: block;
  }
}
.sec--flow__main ul li figure img {
  border-radius: 10px;
}
.sec--flow__main ul li figure small {
  font-size: 1.2rem;
  display: block;
  text-align: right;
}
@media (max-width: 767px) {
  .sec--flow__main ul li figcaption {
    margin: 20px 0 40px;
    padding-left: 30px;
  }
}
.sec--flow__main ul li figcaption h3 {
  font-size: 3rem;
  font-weight: 400;
}
@media (max-width: 767px) {
  .sec--flow__main ul li figcaption h3 {
    font-size: 2.6rem;
    position: relative;
  }
  .sec--flow__main ul li figcaption h3::before {
    content: "";
    position: absolute;
    left: -22px;
    top: 18px;
    -webkit-transform: translate(0%, -50%);
            transform: translate(0%, -50%);
    width: 12px;
    height: 12px;
    background: #fff;
    border-radius: 50%;
  }
}
.sec--flow__main ul li figcaption p {
  font-size: 1.7rem;
  line-height: 2.5;
}
@media (max-width: 1600px) {
  .sec--flow__main ul li figcaption p {
    font-size: 1.6rem;
  }
}
@media (max-width: 1180px) {
  .sec--flow__main ul li figcaption p {
    font-size: 1.5rem;
  }
}
@media (max-width: 767px) {
  .sec--flow__main ul li figcaption p {
    font-size: 1.5rem;
    line-height: 2;
  }
}
.sec--flow__main ul .serif {
  font-size: 4rem;
}
@media (max-width: 767px) {
  .sec--flow__main ul .serif {
    font-size: 2.4rem;
  }
}
.sec--flow__main ul .serif--01 {
  color: #E0BA78;
  display: block;
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
  position: absolute;
  left: 50%;
  -webkit-transform: translate(-50%, -120%);
          transform: translate(-50%, -120%);
}
.sec--flow__main ul .serif--01::before {
  content: "";
  width: 30px;
  height: 2px;
  -webkit-transform: rotate(55deg);
          transform: rotate(55deg);
  background: #E0BA78;
}
@media (max-width: 767px) {
  .sec--flow__main ul .serif--01::before {
    width: 20px;
  }
}
.sec--flow__main ul .serif--01::after {
  content: "";
  width: 30px;
  height: 2px;
  -webkit-transform: rotate(-55deg);
          transform: rotate(-55deg);
  background: #E0BA78;
  z-index: 5;
}
@media (max-width: 767px) {
  .sec--flow__main ul .serif--01::after {
    width: 20px;
  }
}
.sec--flow__main ul .serif--02 {
  color: #C184ED;
  position: absolute;
  right: -70px;
  top: -50px;
  -webkit-transform: rotate(15deg);
          transform: rotate(15deg);
  z-index: 5;
}
@media (max-width: 767px) {
  .sec--flow__main ul .serif--02 {
    right: -10px;
    top: -30px;
  }
}
.sec--flow__main ul .serif--03 {
  color: #ED8884;
  position: absolute;
  left: -40px;
  top: -70px;
  -webkit-transform: rotate(-20deg);
          transform: rotate(-20deg);
  z-index: 5;
}
@media (max-width: 767px) {
  .sec--flow__main ul .serif--03 {
    left: -10px;
    top: -20px;
  }
}
.sec--flow__main ul .serif--04 {
  color: #FFD110;
  position: absolute;
  right: -70px;
  top: -50px;
  -webkit-transform: rotate(15deg);
          transform: rotate(15deg);
  z-index: 5;
}
@media (max-width: 767px) {
  .sec--flow__main ul .serif--04 {
    right: -10px;
    top: -30px;
  }
}
.sec--flow__main ul .serif--05 {
  color: #84ACED;
  position: absolute;
  right: -70px;
  top: -50px;
  -webkit-transform: rotate(15deg);
          transform: rotate(15deg);
  z-index: 5;
}
@media (max-width: 767px) {
  .sec--flow__main ul .serif--05 {
    right: -10px;
    top: -30px;
  }
}
.sec--flow__main ul .serif--06 {
  color: #E0BA78;
  display: block;
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 10px;
  position: absolute;
  left: 50%;
  -webkit-transform: translate(-50%, -120%);
          transform: translate(-50%, -120%);
  white-space: nowrap;
}
.sec--flow__main ul .serif--06::before {
  content: "";
  width: 30px;
  height: 2px;
  -webkit-transform: rotate(55deg);
          transform: rotate(55deg);
  background: #E0BA78;
}
@media (max-width: 767px) {
  .sec--flow__main ul .serif--06::before {
    width: 20px;
  }
}
.sec--flow__main ul .serif--06::after {
  content: "";
  width: 30px;
  height: 2px;
  -webkit-transform: rotate(-55deg);
          transform: rotate(-55deg);
  background: #E0BA78;
  z-index: 5;
}
@media (max-width: 767px) {
  .sec--flow__main ul .serif--06::after {
    width: 20px;
  }
}
.sec--flow__main ul .serif--07 {
  color: #84ACED;
  position: absolute;
  left: -70px;
  top: -50px;
  -webkit-transform: rotate(-15deg);
          transform: rotate(-15deg);
  z-index: 5;
}
@media (max-width: 767px) {
  .sec--flow__main ul .serif--07 {
    right: -10px;
    top: -30px;
  }
}
.sec--flow__main ul .serif--08 {
  color: #ED8884;
  position: absolute;
  left: -80px;
  top: -30px;
  -webkit-transform: rotate(-20deg);
          transform: rotate(-20deg);
  z-index: 5;
}
@media (max-width: 767px) {
  .sec--flow__main ul .serif--08 {
    left: -10px;
    top: -20px;
  }
}
.sec--flow .icon--kai2 {
  position: absolute;
  left: 12%;
  top: -4%;
}
@media (max-width: 767px) {
  .sec--flow .icon--kai2 {
    top: 5%;
    left: 10px;
    width: 30px;
    z-index: 12;
  }
}
.sec--flow .icon--kame {
  position: absolute;
  right: 6%;
  top: 4%;
  z-index: 12;
}
@media (max-width: 1280px) {
  .sec--flow .icon--kame {
    width: 200px;
    right: 1%;
    top: 8%;
  }
}
@media (max-width: 767px) {
  .sec--flow .icon--kame {
    top: 1%;
    right: -10%;
    width: 120px;
    z-index: 12;
  }
}
.sec--flow .icon--fish01 {
  position: absolute;
  left: 1%;
  top: 24%;
  z-index: 12;
}
@media (max-width: 767px) {
  .sec--flow .icon--fish01 {
    top: 30%;
    left: -20px;
    width: 70px;
    z-index: 12;
  }
}
.sec--flow .icon--fish02 {
  position: absolute;
  right: 2%;
  top: 61%;
  z-index: 12;
}
@media (max-width: 767px) {
  .sec--flow .icon--fish02 {
    top: 51%;
    right: -5%;
    width: 100px;
    z-index: 12;
  }
}
.sec--flow .icon--seadragon {
  position: absolute;
  left: 4%;
  top: 47%;
  z-index: 12;
}
@media (max-width: 767px) {
  .sec--flow .icon--seadragon {
    width: 50px;
    left: 0%;
  }
}
.sec--flow .icon--cloud01 {
  position: absolute;
  left: 0%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  bottom: 8%;
  z-index: 12;
}
@media (max-width: 767px) {
  .sec--flow .icon--cloud01 {
    width: 200px;
    bottom: 3%;
  }
}
.sec--flow .icon--cloud02 {
  position: absolute;
  right: 0%;
  -webkit-transform: translateX(50%);
          transform: translateX(50%);
  bottom: 9%;
  z-index: 12;
}
@media (max-width: 767px) {
  .sec--flow .icon--cloud02 {
    width: 200px;
    bottom: 4%;
  }
}
.sec .pb-400 {
  padding-bottom: 400px;
}
@media (max-width: 767px) {
  .sec .pb-400 {
    padding-bottom: 300px;
  }
}
.sec .pb-200 {
  padding-bottom: 200px;
}
.sec--experience {
  background: #E8FCE0;
  background: -webkit-gradient(linear, left bottom, left top, from(rgb(255, 250, 168)), color-stop(20%, rgb(232, 252, 224)));
  background: linear-gradient(0deg, rgb(255, 250, 168) 0%, rgb(232, 252, 224) 20%);
  padding: 200px 0 0px;
  position: relative;
  z-index: 2;
}
@media (max-width: 767px) {
  .sec--experience {
    padding: 100px 0 0px;
  }
}
.sec--experience .sec__header h2 span {
  color: #5DBF8F;
}
.sec--experience__main {
  position: relative;
  z-index: 2;
}
.sec--experience__main .splide__arrows {
  max-width: 1680px;
  width: 100%;
  height: 100px;
  position: absolute;
  left: 0;
  top: 300px;
  z-index: 100;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media (max-width: 1280px) {
  .sec--experience__main .splide__arrows {
    top: 15vw;
  }
}
@media (max-width: 767px) {
  .sec--experience__main .splide__arrows {
    top: auto;
    bottom: -80px;
  }
}
.sec--experience__main .splide__arrow {
  width: 120px;
  height: 120px;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  border: solid 3px #fff;
  border-radius: 50%;
  backdrop-filter: blur(4px);
}
@media (max-width: 1280px) {
  .sec--experience__main .splide__arrow {
    width: 60px;
    height: 60px;
  }
}
@media (min-width: 768px) {
  .sec--experience__main .splide__arrow {
    -webkit-transition: all 0.4s ease;
    transition: all 0.4s ease;
    cursor: pointer;
  }
  .sec--experience__main .splide__arrow:hover {
    background: rgba(255, 255, 255, 0.4);
  }
}
@media (max-width: 767px) {
  .sec--experience__main .splide__arrow {
    border: solid 1px #333;
    -webkit-transform: translateY(0);
            transform: translateY(0);
    width: 36px;
    height: 36px;
  }
}
.sec--experience__main .splide__arrow--next {
  right: 30px;
}
@media (max-width: 767px) {
  .sec--experience__main .splide__arrow--next {
    right: 10px;
  }
}
.sec--experience__main .splide__arrow--next::after {
  content: "";
  font-family: "Material Symbols Outlined";
  content: "\e5cc";
  font-size: 10rem;
  color: #fff;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media (max-width: 1280px) {
  .sec--experience__main .splide__arrow--next::after {
    font-size: 5rem;
  }
}
@media (max-width: 767px) {
  .sec--experience__main .splide__arrow--next::after {
    color: #333;
    font-size: 4rem;
  }
}
.sec--experience__main .splide__arrow--prev {
  left: 30px;
}
@media (max-width: 767px) {
  .sec--experience__main .splide__arrow--prev {
    left: 10px;
  }
}
.sec--experience__main .splide__arrow--prev::after {
  content: "";
  font-family: "Material Symbols Outlined";
  content: "\e5cb";
  font-size: 10rem;
  color: #fff;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media (max-width: 1280px) {
  .sec--experience__main .splide__arrow--prev::after {
    font-size: 5rem;
  }
}
@media (max-width: 767px) {
  .sec--experience__main .splide__arrow--prev::after {
    color: #333;
    font-size: 4rem;
  }
}
.sec--experience__main .splide__track {
  overflow: visible;
}
.sec--experience__main .splide__slide {
  height: 720px !important;
}
@media (max-width: 1280px) {
  .sec--experience__main .splide__slide {
    height: 40vw !important;
  }
}
@media (max-width: 767px) {
  .sec--experience__main .splide__slide {
    width: 100%;
    height: 360px !important;
  }
}
.sec--experience__main .splide__slide.current img {
  -webkit-transform: scale(1);
          transform: scale(1);
  z-index: 1;
}
.sec--experience__main .splide__slide.current figcaption {
  opacity: 1;
}
.sec--experience__main .splide__slide figcaption {
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
  opacity: 0;
  text-align: center;
}
.sec--experience__main .splide__slide figcaption a {
  margin: auto;
}
.sec--experience__main .splide__slide figcaption p {
  margin: 50px 0 30px;
}
@media (max-width: 767px) {
  .sec--experience__main .splide__slide figcaption p {
    margin: 20px 0 30px;
    padding: 0 60px;
    font-weight: 1.5rem;
  }
}
.sec--experience__main .splide__slide figcaption p span {
  display: inline-block;
}
.sec--experience__main .splide__slide img {
  height: 720px !important;
}
@media (max-width: 1280px) {
  .sec--experience__main .splide__slide img {
    height: 40vw !important;
  }
}
.sec--experience__main .splide__slide img {
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
  -webkit-transform: scale(1);
          transform: scale(1);
}
@media (max-width: 767px) {
  .sec--experience__main .splide__slide img {
    width: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    height: 360px !important;
  }
}
.sec--experience .icon--ushi {
  position: absolute;
  left: 5%;
  top: 2%;
}
@media (max-width: 1280px) {
  .sec--experience .icon--ushi {
    width: 200px;
    top: -26%;
  }
}
@media (max-width: 767px) {
  .sec--experience .icon--ushi {
    width: 100px;
    left: 0%;
    top: -16%;
  }
}
.sec--experience .icon--sotetsu {
  position: absolute;
  right: 5%;
  top: 5%;
}
@media (max-width: 1280px) {
  .sec--experience .icon--sotetsu {
    width: 200px;
  }
}
@media (max-width: 767px) {
  .sec--experience .icon--sotetsu {
    right: 0%;
    top: 68%;
    width: 100px;
    z-index: 0;
  }
}
.sec--experience .icon--bird {
  position: absolute;
  left: 5%;
  bottom: 5%;
}
@media (max-width: 767px) {
  .sec--experience .icon--bird {
    right: 0%;
    bottom: 3%;
    width: 80px;
    z-index: 0;
  }
}
.sec--spacer {
  position: relative;
}
.sec--spacer .bg--nami3 {
  position: absolute;
  left: 0;
  bottom: -1px;
  z-index: 2;
  width: 100%;
  height: auto;
}
.sec--spacer {
  width: 100%;
  position: relative;
  min-height: 920px;
  z-index: 0;
}
@media (max-width: 767px) {
  .sec--spacer {
    min-height: 50vh;
  }
}
.sec--spacer video {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translateX(-50%) translateY(-50%);
          transform: translateX(-50%) translateY(-50%);
  min-width: 100%;
  min-height: 100%;
}
.sec--room {
  background: #fff;
  padding: 100px 0 40px;
}
@media (max-width: 767px) {
  .sec--room {
    padding: 80px 0 40px;
  }
}
.sec--room .splide {
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
}
.sec--room .splide__arrows {
  max-width: 1680px;
  width: 100%;
  height: 100px;
  position: absolute;
  left: 0;
  top: 50%;
  z-index: 100;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media (max-width: 767px) {
  .sec--room .splide__arrows {
    height: 60px;
  }
}
.sec--room .splide__arrow {
  width: 120px;
  height: 120px;
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  border: solid 3px #fff;
  border-radius: 50%;
  backdrop-filter: blur(4px);
}
@media (max-width: 1280px) {
  .sec--room .splide__arrow {
    width: 60px;
    height: 60px;
  }
}
@media (min-width: 768px) {
  .sec--room .splide__arrow {
    -webkit-transition: all 0.4s ease;
    transition: all 0.4s ease;
    cursor: pointer;
  }
  .sec--room .splide__arrow:hover {
    background: rgba(255, 255, 255, 0.4);
  }
}
@media (max-width: 767px) {
  .sec--room .splide__arrow {
    border: solid 2px #fff;
    width: 36px;
    height: 36px;
  }
}
.sec--room .splide__arrow--next {
  right: 30px;
}
@media (max-width: 767px) {
  .sec--room .splide__arrow--next {
    right: 10px;
  }
}
.sec--room .splide__arrow--next::after {
  content: "";
  font-family: "Material Symbols Outlined";
  content: "\e5cc";
  font-size: 10rem;
  color: #fff;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media (max-width: 1280px) {
  .sec--room .splide__arrow--next::after {
    font-size: 5rem;
  }
}
@media (max-width: 767px) {
  .sec--room .splide__arrow--next::after {
    font-size: 4rem;
  }
}
.sec--room .splide__arrow--prev {
  left: 30px;
}
@media (max-width: 767px) {
  .sec--room .splide__arrow--prev {
    left: 10px;
  }
}
.sec--room .splide__arrow--prev::after {
  content: "";
  font-family: "Material Symbols Outlined";
  content: "\e5cb";
  font-size: 10rem;
  color: #fff;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  position: absolute;
  left: 50%;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media (max-width: 1280px) {
  .sec--room .splide__arrow--prev::after {
    font-size: 5rem;
  }
}
@media (max-width: 767px) {
  .sec--room .splide__arrow--prev::after {
    font-size: 4rem;
  }
}
.sec--room .splide__track {
  overflow: visible;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
}
.sec--room .splide__slide {
  height: 520px !important;
}
@media (max-width: 1280px) {
  .sec--room .splide__slide {
    height: 40vw !important;
  }
}
@media (max-width: 767px) {
  .sec--room .splide__slide {
    width: auto;
    height: auto !important;
  }
}
.sec--room .splide__slide.current img {
  -webkit-transform: scale(1);
          transform: scale(1);
  z-index: 1;
}
.sec--room .splide__slide.current figcaption {
  opacity: 1;
}
.sec--room .splide__slide img {
  height: 520px !important;
}
@media (max-width: 1280px) {
  .sec--room .splide__slide img {
    height: 40vw !important;
  }
}
.sec--room .splide__slide img {
  -webkit-transition: all 1s ease;
  transition: all 1s ease;
  -webkit-transform: scale(1);
          transform: scale(1);
}
@media (max-width: 767px) {
  .sec--room .splide__slide img {
    max-width: 80vw;
    width: 100%;
    max-height: 50vw;
    height: auto !important;
  }
}
.sec--room__read a {
  margin: 58px auto;
}
.sec--room__read p {
  text-align: center;
  margin: 40px 0;
}
.sec--room__read picture {
  display: block;
}
.sec--room__read img {
  max-width: 1080px;
  width: 100%;
  height: auto;
  display: block;
  margin: auto;
}
@media (max-width: 767px) {
  .sec--room__read img {
    width: 100%;
    height: auto;
  }
}
.sec--room .room--details {
  max-width: 1420px;
  margin: 90px auto;
  padding: 0 80px;
}
@media (max-width: 767px) {
  .sec--room .room--details {
    margin: 60px auto;
    padding: 0 20px;
  }
}
.sec--room .room--details h3 {
  margin-top: 55px;
  border-bottom: solid 1px #707070;
  padding-bottom: 10px;
  margin-bottom: 10px;
  font-weight: 500;
  font-size: 2.6rem;
}
@media (max-width: 767px) {
  .sec--room .room--details h3 {
    font-size: 2rem;
  }
}
.sec--room .room--details h3 small {
  font-size: 1.4rem;
  margin-left: 40px;
}
@media (max-width: 767px) {
  .sec--room .room--details h3 small {
    font-size: 1.2rem;
    display: block;
    margin: 0;
  }
}
.sec--room .room--details p {
  font-size: 1.8rem;
}
@media (max-width: 767px) {
  .sec--room .room--details p {
    font-size: 1.6rem;
  }
}
.sec--room .room--details strong {
  font-size: 2rem;
  font-weight: 400;
}
@media (max-width: 767px) {
  .sec--room .room--details strong {
    font-size: 1.8rem;
  }
}
.sec--room .room--details table {
  width: 100%;
}
.sec--room .room--details table tr {
  border-bottom: solid 1px #C6C6C6;
}
.sec--room .room--details table th {
  padding: 10px;
}
.sec--room .room--details table th small {
  display: block;
  font-size: 1.2rem;
}
.sec--room .room--details table td small {
  font-size: 1.4rem;
  margin-right: 10px;
}
@media (max-width: 767px) {
  .sec--room .room--details table td small {
    font-size: 1.2rem;
  }
}
.sec--room .room--details table th,
.sec--room .room--details table td {
  padding: 20px 0;
  font-size: 1.8rem;
  font-weight: 400;
  text-align: left;
}
@media (max-width: 767px) {
  .sec--room .room--details table th,
  .sec--room .room--details table td {
    padding: 20px 0;
    font-size: 1.5rem;
  }
}
.sec--room .room--details__price table th {
  width: 200px;
}
@media (max-width: 767px) {
  .sec--room .room--details__price table th {
    width: 100px;
  }
}
.sec--room .room--details__price table th,
.sec--room .room--details__price table td {
  font-weight: 400;
}
.sec--room .room--details__meal table th {
  width: 280px;
}
@media (max-width: 767px) {
  .sec--room .room--details__meal table th {
    width: 200px;
  }
}
.sec--room .room--details__meal table td {
  text-align: right;
}
.sec--room .room--details__meal table th,
.sec--room .room--details__meal table td {
  font-weight: 400;
}
.sec--room .room--details__equipment table th {
  width: 280px;
}
@media (max-width: 767px) {
  .sec--room .room--details__equipment table th {
    padding: 10px 0 5px;
  }
}
@media (max-width: 767px) {
  .sec--room .room--details__equipment table td {
    padding: 5px 0 15px;
  }
}
@media (max-width: 767px) {
  .sec--room .room--details__equipment table th,
  .sec--room .room--details__equipment table td {
    display: block;
    width: 100%;
  }
}
.sec--room .room--details__equipment table th,
.sec--room .room--details__equipment table td {
  font-weight: 400;
}
.sec--room .room--details__cancel-policy div p {
  font-size: 1.6rem;
}
@media (max-width: 767px) {
  .sec--room .room--details__cancel-policy div p {
    font-size: 1.4rem;
  }
}
.sec--room .room--details__cancel-policy div {
  margin-bottom: 30px;
}
.sec--room .room--details__cancel-policy h4 {
  font-size: 2.2rem;
  font-weight: 500;
  margin-bottom: 16px;
}
@media (max-width: 767px) {
  .sec--room .room--details__cancel-policy h4 {
    font-size: 2rem;
  }
}
.sec--room .room--details__cancel-policy h4 + h5 {
  margin-top: 20px;
}
.sec--room .room--details__cancel-policy h5 {
  font-size: 1.8rem;
  font-weight: 400;
  margin-bottom: 12px;
  margin-top: 30px;
}
@media (max-width: 767px) {
  .sec--room .room--details__cancel-policy h5 {
    font-size: 1.6rem;
  }
}
.sec--room .room--details__cancel-policy ul {
  list-style: "・";
  margin: 4px 0;
}
.sec--room .room--details__cancel-policy ul li {
  padding-left: 1.3em;
  margin-bottom: 4px;
  font-size: 1.5rem;
}
@media (max-width: 767px) {
  .sec--room .room--details__cancel-policy ul li {
    padding-left: 0em;
    text-indent: 0em;
    padding-left: 0em;
    font-size: 1.4rem;
  }
}
.sec--room .room--details__cancel-policy ol {
  padding-left: 1em;
  counter-reset: item;
  list-style: none;
  margin: 4px 0;
}
@media (max-width: 767px) {
  .sec--room .room--details__cancel-policy ol {
    padding-left: 0em;
  }
}
.sec--room .room--details__cancel-policy ol > li {
  text-indent: -1.3em;
  padding-left: 1.3em;
  font-size: 1.5rem;
  margin-bottom: 4px;
}
@media (max-width: 767px) {
  .sec--room .room--details__cancel-policy ol > li {
    text-indent: -2em;
    padding-left: 2em;
    font-size: 1.4rem;
  }
}
.sec--room .room--details__cancel-policy ol > li::before {
  counter-increment: item;
  content: "(" counter(item) ")";
  padding-right: 0.5em;
  font-weight: bold;
}
.sec--access {
  padding-top: 100px;
  background: #fff;
}
@media (max-width: 767px) {
  .sec--access {
    padding-top: 20px;
  }
}
.sec--access__details {
  max-width: 1920px;
  margin: 70px auto 0;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 50% 80px 50%;
  grid-template-columns: 50% 50%;
  -ms-grid-rows: 1fr;
  grid-template-rows: 1fr;
  gap: 80px;
  padding-bottom: 177px;
}
.sec--access__details > *:nth-child(1) {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
}
.sec--access__details > *:nth-child(2) {
  -ms-grid-row: 1;
  -ms-grid-column: 3;
}
@media (max-width: 1150px) {
  .sec--access__details {
    -ms-grid-columns: 40% 40px 50%;
    grid-template-columns: 40% 50%;
    gap: 40px;
  }
  .sec--access__details .address {
    padding-right: 20px;
  }
  .sec--access__details table {
    width: 100%;
  }
}
@media (max-width: 960px) {
  .sec--access__details {
    display: block;
    padding-bottom: 100px;
    padding: 0px 25px 70px;
  }
  .sec--access__details iframe {
    height: 300px;
  }
  .sec--access__details .address {
    padding-right: 0px;
  }
}
.sec--access table {
  margin-bottom: 30px;
}
.sec--access table tr:first-child {
  border-bottom: solid 1px #C6C6C6;
}
.sec--access table th,
.sec--access table td {
  padding: 30px 0;
  text-align: left;
}
@media (max-width: 767px) {
  .sec--access table th,
  .sec--access table td {
    padding: 20px 0;
  }
}
.sec--access table th {
  padding-right: 40px;
  font-size: 2.4rem;
}
@media (max-width: 767px) {
  .sec--access table th {
    font-size: 2rem;
  }
}
.sec--reserve {
  background: url(../img/sec06_bg_0101@2x.webp) no-repeat;
  background-size: cover;
  background-attachment: fixed;
  padding: 140px 0 0;
}
@media (max-width: 767px) {
  .sec--reserve {
    background-attachment: scroll;
    padding: 80px 0 0;
  }
}
.sec--reserve .side-info p {
  position: relative;
  -webkit-transform: none;
          transform: none;
}
.sec--reserve__details {
  border-radius: 10px;
  padding: 50px 20px;
  max-width: 1020px;
  margin: auto;
  background: rgba(255, 255, 255, 0.4);
  backdrop-filter: blur(10px);
}
@media (max-width: 767px) {
  .sec--reserve__details {
    padding: 30px 20px;
    margin-bottom: -100px;
  }
}
.sec--reserve__details .sec__read {
  margin: 20px 0;
}
.sec--reserve__details .sec__read p {
  font-size: 2rem;
}
@media (max-width: 767px) {
  .sec--reserve__details .sec__read p {
    font-size: 1.6rem;
    line-height: 1.8;
  }
}
.sec--reserve__details .sec--reserve__tell a {
  color: #333;
  font-size: 5rem;
  text-align: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 10px;
  line-height: 1;
}
@media (max-width: 767px) {
  .sec--reserve__details .sec--reserve__tell a {
    font-size: 3rem;
  }
}
.sec--reserve__details .sec--reserve__tell a img {
  display: block;
  -webkit-transform: translateY(0.08em);
          transform: translateY(0.08em);
  width: 2.4rem;
}
@media (max-width: 767px) {
  .sec--reserve__details .sec--reserve__tell a img {
    width: 2rem;
  }
}
.sec--reserve__details .sec--reserve__tell p {
  margin-top: 10px;
  text-align: center;
}
.sec--reserve__details .btn--reserve {
  background: #fff;
  border: solid 1px #fff;
  margin: auto;
  max-width: 480px;
  width: 100%;
  height: 80px;
  font-size: 3rem;
  padding-left: 40px;
  color: #333;
}
@media (max-width: 767px) {
  .sec--reserve__details .btn--reserve {
    font-size: 2rem;
    height: 70px;
  }
}
@media (min-width: 768px) {
  .sec--reserve__details .btn--reserve {
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
    cursor: pointer;
  }
  .sec--reserve__details .btn--reserve:hover {
    color: #00B9AB;
  }
  .sec--reserve__details .btn--reserve:hover span::after {
    color: #00B9AB;
  }
}
.sec--reserve__details .btn--reserve span {
  gap: 40px;
}
.sec--reserve__details .btn--reserve span::after {
  color: #333;
  font-size: 5rem;
}
@media (max-width: 767px) {
  .sec--reserve__details .btn--reserve span::after {
    font-size: 4rem;
  }
}
.sec--page {
  padding: 150px 0;
}
@media (max-width: 767px) {
  .sec--page {
    padding: 100px 0;
  }
}
.sec--page .sec__header {
  margin-bottom: 100px;
}
@media (max-width: 767px) {
  .sec--page .sec__header {
    margin-bottom: 80px;
  }
}

.site-footer {
  position: relative;
  z-index: 800;
  position: relative;
  background: #fff;
  padding: 60px 0 100px;
}
@media (max-width: 767px) {
  .site-footer {
    padding: 40px 0 50px;
  }
}
.site-footer__inner {
  padding: 0 40px;
  text-align: center;
}
@media (max-width: 767px) {
  .site-footer__inner {
    padding: 0 20px;
  }
}
.site-footer h2 {
  text-align: center;
  font-size: 4rem;
}
@media (max-width: 767px) {
  .site-footer h2 {
    font-size: 3rem;
  }
}
@media (max-width: 767px) {
  .site-footer p {
    font-size: 1.4rem;
  }
}
.site-footer .footer-nav {
  margin: 40px auto 60px;
}
@media (max-width: 767px) {
  .site-footer .footer-nav {
    margin: 20px auto 20px;
  }
}
.site-footer .footer-nav menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media (max-width: 767px) {
  .site-footer .footer-nav menu {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    gap: 10px;
  }
}
.site-footer .footer-nav menu li a {
  color: #333;
  padding: 20px 40px;
}
@media (max-width: 767px) {
  .site-footer .footer-nav menu li a {
    margin: auto;
    padding: 0px 0px;
  }
}
@media (min-width: 768px) and (min-width: 768px) {
  .site-footer .footer-nav menu li a {
    -webkit-transition: all 0.4s ease;
    transition: all 0.4s ease;
    cursor: pointer;
  }
  .site-footer .footer-nav menu li a:hover {
    color: #00B9AB;
  }
  .site-footer .footer-nav menu li a:hover span::after {
    width: 100%;
    background: #00B9AB;
  }
}
.site-footer .footer-nav menu li a span {
  position: relative;
}
.site-footer .footer-nav menu li a span::after {
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
  content: "";
  width: 0%;
  height: 1px;
  background: #fff;
  position: absolute;
  left: 0;
  bottom: 0;
}
.site-footer .copyright {
  font-size: 1.2rem;
}
.site-footer__sns {
  margin: 30px auto;
}
.site-footer__sns a {
  display: block;
}
@media (max-width: 767px) {
  .site-footer__sns img {
    width: 32px;
    height: auto;
  }
}
.site-footer p {
  text-align: center;
}

.bg--nami2 {
  position: relative;
  left: 0;
  margin-bottom: -100px;
  z-index: 13;
  width: 100%;
  height: auto;
  -webkit-transform-origin: center top 0;
          transform-origin: center top 0;
}
.bg--nami2 img {
  position: relative;
  z-index: 2;
}
.bg--nami2::before {
  content: "";
  width: 100%;
  height: 46%;
  position: absolute;
  background: rgb(255, 250, 168);
  top: 0;
  left: 0;
}

.bg--mountain {
  position: relative;
  z-index: 20;
  position: absolute;
  left: 50%;
  bottom: -3.4%;
  max-width: 2200px;
  -webkit-transform: translateX(-53%);
          transform: translateX(-53%);
}
@media (max-width: 1920px) {
  .bg--mountain {
    width: calc(100% + 400px);
  }
}
@media (max-width: 767px) {
  .bg--mountain {
    bottom: -1%;
    width: calc(100% + 200px);
  }
}

.bg--nami {
  width: 100%;
  height: auto;
  background: #FFFAEB;
  position: relative;
  z-index: 2;
}
.bg--nami img {
  max-width: 2600px;
  margin: auto;
  display: block;
  position: relative;
  z-index: 2;
}
@media (max-width: 1920px) {
  .bg--nami img {
    margin: 0 -150px;
    width: calc(100% + 300px);
  }
}
.bg--nami::before {
  content: "";
  width: 100%;
  height: 46%;
  position: absolute;
  background: #D5EFEE;
  bottom: 0;
  left: 0;
}

#booking-package-locale-ja {
  padding-top: 0px !important;
}