@charset "UTF-8";

html {
  font-size: 10px;
}

html {
  font-size: calc(10 * (100vw / 1366));
  scroll-behavior: smooth;
  scroll-padding-top: 90px;
}

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
i,
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 {
  margin: 0;
  padding: 0;
  border: 0;
  vertical-align: baseline;
  box-sizing: border-box;
}

.l-footer {
  padding: 0;
}

.pc-footer {
  margin: 0;
}

#feature {
  box-sizing: border-box;
  color: #050505;
  overflow: clip;
  position: relative;
  display: block;
  width: 100%;
  font-family: "Zen Kaku Gothic Antique", sans-serif;
  font-weight: 700;
  font-style: normal;
}

#feature .wrap {
  width: 100%;
  display: flex;
  position: relative;
  background: #f1aacc;
}

#feature .left,
#feature .right {
  align-items: center;
  display: flex;
  position: sticky;
  top: 80px;
  height: calc(100vh - 80px);
  width: calc((100% - (415.42 * (100vw / 1366))) / 2);
  z-index: 10;
}

#feature .left {
  order: 1;
}

#feature .left figure {
  width: calc(250 * (100vw / 1400));
  margin: 0 auto;
}

#feature .right {
  order: 3;
}

#feature .right figure {
  width: calc(250 * (100vw / 1400));
  margin: 0 auto;
}

#feature .feature__inner {
  width: calc(415.42 * (100vw / 1366));
  position: relative;
  order: 2;
  overflow: visible;
  /* background: #f1aacc; */
}

#feature .sec01 {
  position: relative;
  margin: 0 auto;
  padding-top: calc(86 * (100vw / 1366));
  padding-bottom: calc(91 * (100vw / 1366));
}

#feature .sec01::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  height: 100%;
  background: #f1aacc;
  z-index: 9;
}

#feature a {
  color: #000;
  transition: all 0.3s ease-in-out;
  transform: none;
  text-decoration: none;
}

#feature a:hover {
  opacity: 0.7;
  transition: 0.3s;
}

#feature img,
svg,
video {
  width: 100%;
  height: auto;
  display: block;
}

.l-container {
  width: 100%;
  overflow: clip;
}

/*-------------------------
 fade_anim
-------------------------*/
/** A **/
.fadeMain {
  position: relative;
  overflow: hidden;
}

.fadeMain::before {
  content: "";
  position: absolute;
  inset: 0;
  background: #fff;
  transform: translateY(0);
  transition: transform 1.4s cubic-bezier(.075, .82, .79, 1);
  will-change: transform;
  z-index: 2;
}

.fadeMain.active::before {
  transform: translateY(-100%);
}

.fadeMain {
  transform: translateY(20%);
  opacity: 0;
  transition: transform 1.4s cubic-bezier(.075, .82, .79, 1),
    opacity 1.4s cubic-bezier(.075, .82, .79, 1);
  will-change: transform, opacity;
}

.fadeMain.active {
  transform: translateY(0);
  opacity: 1;
}

/** B **/
.bounce {
  opacity: 0;
  transform: scale(0.5) translateY(100px);
}

.bounce.active {
  animation: bounceAnimation 1s ease-out forwards;
}

@keyframes bounceAnimation {
  0% {
    opacity: 0;
    transform: scale(0.5) translateY(100px);
  }

  30% {
    opacity: 1;
    transform: scale(1.2) translateY(-30px);
  }

  50% {
    opacity: 1;
    transform: scale(0.9) translateY(10px);
  }

  65% {
    opacity: 1;
    transform: scale(1.05) translateY(-10px);
  }

  75% {
    opacity: 1;
    transform: scale(0.98) translateY(5px);
  }

  85% {
    opacity: 1;
    transform: scale(1.02) translateY(-3px);
  }

  100% {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

/**C**/
.typing {
  visibility: hidden;
}

.typing.is-start {
  visibility: visible;
}

.typing span {
  opacity: 0;
}

.typing span.active {
  opacity: 1;
}

#feature .typing a {
  color: #fff;
}

/** @D @**/
.knock path {
  opacity: 0;
}

#pass_624,
#pass_625,
#pass_626,
#pass_627,
#pass_628,
#pass_629 {
  opacity: 1;
  animation: hideBoth 2s infinite;
}

#pass_630,
#pass_631,
#pass_632,
#pass_633,
#pass_634,
#pass_635 {
  animation: showThenHide 2s infinite;
}

@keyframes showThenHide {

  0%,
  40% {
    opacity: 0;
  }

  41%,
  75% {
    opacity: 1;
  }

  76%,
  100% {
    opacity: 0;
  }
}

@keyframes hideBoth {

  0%,
  75% {
    opacity: 1;
  }

  76%,
  100% {
    opacity: 0;
  }
}

/** @E @**/
#feature .scroll-section {
  position: relative;
  width: 100%;
  height: auto;
  overflow: visible;
}

#feature .image-container {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

#feature .image-container .scroll_img01 {
  width: calc(311.97 * (100vw / 1366));
  height: auto;
  padding-top: calc(94 * (100vw / 1366));
}

#feature .image-container .scroll_img02 {
  width: calc(358.74 * (100vw / 1366));
  height: auto;
  padding-top: calc(115 * (100vw / 1366));
}

#feature .image-container .scroll_img03 {
  width: calc(288.28 * (100vw / 1366));
  height: auto;
  padding-top: calc(315 * (100vw / 1366));
}

/** F **/
#feature .turn {
  visibility: hidden;
  opacity: 0;
  -webkit-transform-style: preserve-3d;
  transform-style: preserve-3d;
  -webkit-transform: rotateY(180deg);
  transform: rotateY(180deg);
  -webkit-transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94), -webkit-transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94), -webkit-transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94), -webkit-transform 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

#feature .turn.active {
  visibility: visible;
  -webkit-transform: rotateY(0);
  transform: rotateY(0);
  opacity: 1;
}

/** G **/
.fadeIn_left {
  opacity: 0;
  transform: translate3d(40px, 80px, 0) rotate(-5deg);
  transition:
    opacity 1s ease-out,
    transform 0.7s ease-out;
}

.fadeIn_left.active {
  opacity: 1;
  transform: translate3d(0, 0, 0) rotate(0deg);
}

/** I **/
.fadeUp {
  opacity: 0;
  will-change: opacity, transform;
  -webkit-transition:
    ease-in, opacity 1500ms, -webkit-transform 1000ms;
  transition:
    ease-in, opacity 1500ms, -webkit-transform 1000ms;
  transition:
    ease-in, opacity 1500ms, transform 1000ms;
  transition:
    ease-in, opacity 1500ms, transform 1000ms, -webkit-transform 1000ms;
  -webkit-transform: translate3d(0, 2.5rem, 0);
  transform: translate3d(0, 2.5rem, 0);
}

.fadeUp.active {
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

/*-------------------------
 hero
-------------------------*/
#feature .hero {
  width: 100%;
  height: fit-content;
  position: relative;
  background: #f1aacc;
}

#feature .hero_img {
  width: 100%;
  height: fit-content;
  margin: auto;
}

#feature .hero_ttl {
  width: calc(327.39 * (100vw / 1366));
  position: absolute;
  top: 46.3%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}

#feature .lead {
  padding-top: calc(23 * (100vw / 1366));
  margin-left: auto;
  font-size: calc(10 * (100vw / 1366));
  line-height: 2.2;
  text-align: center;
  color: #fff;
  background: #f1aacc;
}

#feature .lead p:nth-of-type(n+2) {
  margin-top: calc(22 * (100vw / 1366));
}

/*-------------------------
 content
-------------------------*/
#feature .section__inner,
#feature .section__inner figure {
  position: relative;
  overflow: hidden;
}

#feature .block_area {
  position: relative;
  height: fit-content;
}

#feature .swiper-container figure {
  background: #fff;
}

#feature .sec01 {
  position: relative;
  margin: 0 auto;
  padding-top: calc(86 * (100vw / 1366));
  padding-bottom: calc(97 * (100vw / 1366));
}

#feature .sec01::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  height: 100%;
  background: #f1aacc;
  z-index: -1;
}

#feature .sec02 {
  position: relative;
  padding-top: calc(46 * (100vw / 1366));
}

#feature .sec02::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  height: 100%;
  background: #006e22;
  z-index: 0;
}

#feature .blinking {
  width: calc(143.62 * (100vw / 1366));
  margin: 0 auto 0 calc(143.62 * (100vw / 1366));
}

#feature .door {
  width: calc(386 * (100vw / 1366));
  margin: calc(25 * (100vw / 1366)) auto 0;
}

#feature .img01 {
  width: calc(338 * (100vw / 1366));
  margin: calc(91 * (100vw / 1366)) auto 0;
}

#feature .img02 {
  width: calc(188 * (100vw / 1366));
  margin: calc(19 * (100vw / 1366)) calc(19 * (100vw / 1366)) 0 auto;
  position: relative;
  z-index: 20;
}

#feature .sec02 .blinking {
  margin-left: calc(136 * (100vw / 1366));
}

#feature .img03 {
  width: 100%;
  margin: calc(-16 * (100vw / 1366)) auto 0;
  padding-bottom: calc(50 * (100vw / 1366));
}


#feature .swiper01 {
  width: calc(377.57 * (100vw / 1366));
  height: calc(471.92 * (100vw / 1366));
  overflow: hidden;
  margin: 0 auto 0 0;
}

#feature .img07-2 {
  width: calc(169 * (100vw / 1366));
  margin: calc(125 * (100vw / 1366)) auto 0 0;
}

#feature .img07 {
  width: calc(238 * (100vw / 1366));
  margin: calc(-141 * (100vw / 1366)) 0 0 auto;
  position: relative;
  z-index: 20;
}


#feature .img08 {
  width: calc(305 * (100vw / 1366));
  margin: calc(-22 * (100vw / 1366)) auto 0 0;
  position: relative;
  z-index: 10;
}

#feature .img09 {
  width: 100%;
  margin: calc(-41 * (100vw / 1366)) auto 0;
}


#feature .swiper02 {
  width: 100%;
  height: fit-content;
  overflow: hidden;
  margin: calc(131 * (100vw / 1366)) auto 0 0;
}

#feature .swiper03 {
  width: 100%;
  height: fit-content;
  margin-top: calc(9 * (100vw / 1366));
}

#feature .swiper03 .swiper-slide {
  width: calc(235 * (100vw / 1366));
}

#feature .swiper03 .swiper-wrapper {
  transition-timing-function: linear;
}

#feature .img12 {
  width: calc(270 * (100vw / 1366));
  margin: calc(15 * (100vw / 1366)) auto 0 0;
}

#feature .img13 {
  width: calc(337 * (100vw / 1366));
  margin: calc(120 * (100vw / 1366)) auto 0;
}

#feature .sec02 .turn {
  position: relative;
  z-index: 20;
}

#feature .img14 {
  width: 100%;
  margin: calc(-29 * (100vw / 1366)) auto 0;
}

#feature .img15 {
  width: calc(333 * (100vw / 1366));
  margin: calc(24 * (100vw / 1366)) auto 0;
}

#feature .img16 {
  width: calc(208 * (100vw / 1366));
  margin: calc(14 * (100vw / 1366)) auto 0 0;
}

#feature .img17 {
  width: calc(208 * (100vw / 1366));
  margin: calc(-187 * (100vw / 1366)) 0 0 auto;
  position: relative;
  z-index: 20;
}

#feature .img18 {
  width: calc(252 * (100vw / 1366));
  margin: calc(-43 * (100vw / 1366)) auto 0 0;
}

#feature .img19-2 {
  width: calc(168 * (100vw / 1366));
  margin: calc(129 * (100vw / 1366)) 0 0 auto;
  position: relative;
  z-index: 20;
}

#feature .img19 {
  width: calc(281 * (100vw / 1366));
  margin: calc(-129 * (100vw / 1366)) auto 0 0;
}

#feature .img20 {
  width: 100%;
  margin: calc(10 * (100vw / 1366)) auto 0;
}

#feature .swiper04 {
  width: calc(325 * (100vw / 1366));
  height: fit-content;
  margin: calc(11 * (100vw / 1366)) auto 0;
}

#feature .img21 {
  width: 100%;
  margin: calc(132 * (100vw / 1366)) auto 0;
}

#feature .img22 {
  width: 100%;
  margin: calc(40 * (100vw / 1366)) auto 0;
}

#feature .img23 {
  width: calc(372 * (100vw / 1366));
  margin: calc(9 * (100vw / 1366)) 0 0 auto;
}

#feature .img24 {
  width: calc(275 * (100vw / 1366));
  margin: calc(10 * (100vw / 1366)) auto 0;
}


#feature .img25 {
  width: calc(259.24 * (100vw / 1366));
  margin: calc(175 * (100vw / 1366)) auto 0;
}

#feature .staff {
  width: calc(365 * (100vw / 1366));
  margin: calc(105 * (100vw / 1366)) auto 0;
  color: #fff;
}

#feature .staff h3 {
  font-size: calc(7 * (100vw / 1366));
  letter-spacing: 0;
  line-height: 1.66;
  font-family: "roboto", sans-serif;
  font-weight: 900;
  font-style: italic;
}

#feature .staff p {
  font-size: calc(6.94 * (100vw / 1366));
  letter-spacing: 0;
  margin-top: calc(7 * (100vw / 1366));
  padding-bottom: calc(82 * (100vw / 1366));
  line-height: 1.3;
  font-family: "roboto", sans-serif;
  font-weight: 900;
  font-style: normal;
}

#feature .credit p {
  color: #fff;
}

#feature .credit {
  font-size: calc(9 * (100vw / 1366));
  letter-spacing: 0;
  line-height: 1.75;
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto;
  font-weight: 900;
  font-style: normal;
  font-variation-settings:
    "wdth" 100;
}

#feature .credit p {
  font-size: calc(6 * (100vw / 1366));
  margin-top: calc(6 * (100vw / 1366));
  margin-left: calc(-1 * (100vw / 1366));
}

#feature .credit01 {
  margin: calc(8 * (100vw / 1366)) 0 0 calc(11 * (100vw / 1366));
}

#feature .credit02 {
  margin: calc(9 * (100vw / 1366)) 0 0 calc(10 * (100vw / 1366));
}

#feature .credit03 {
  margin: calc(9 * (100vw / 1366)) 0 0 calc(18 * (100vw / 1366));
}

#feature .credit04 {
  margin: calc(11 * (100vw / 1366)) 0 0 calc(19 * (100vw / 1366));
}

#feature .credit05 {
  margin: calc(9 * (100vw / 1366)) 0 0 calc(46 * (100vw / 1366));
}

#feature .credit06 {
  margin: calc(10 * (100vw / 1366)) 0 0 calc(72 * (100vw / 1366));
  position: relative;
  z-index: 20;
}
