/* Mixin */
/* fv */
.fv {
  position: relative;
  height: 105vw;
  overflow: hidden;
  -webkit-clip-path: polygon(0% 0%, 100% 0%, 100% 86.5%, 0% 100%);
          clip-path: polygon(0% 0%, 100% 0%, 100% 86.5%, 0% 100%);
}
@media screen and ( width >= 920px) {
  .fv {
    height: 420px;
  }
}
.fv__text {
  display: flex;
  position: relative;
  top: 35vw;
  flex-direction: column;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  font-weight: 900;
}
@media screen and ( width >= 920px) {
  .fv__text {
    top: 140px;
  }
}
.fv__text--bubble {
  display: block;
  position: absolute;
  top: -24vw;
  left: -13vw;
  width: 34vw;
  height: 17vw;
  background-image: url(/home/img/fv__text--bubble.png);
  background-size: cover;
  background-repeat: no-repeat;
  text-align: center;
  line-height: 3.8;
  transform: rotate(-13deg);
}
@media screen and ( width >= 920px) {
  .fv__text--bubble {
    top: -96px;
    left: -52px;
    width: 136px;
    height: 68px;
  }
}
.fv__text--absolute {
  display: block;
  position: absolute;
  top: -7vw;
  left: -1vw;
  width: 36.5vw;
  height: 17.5vw;
  text-indent: 110%;
  white-space: nowrap;
  overflow: hidden;
  background-image: url(/home/img/fv__text--absolute.png);
  background-size: cover;
  background-repeat: no-repeat;
}
@media screen and ( width >= 920px) {
  .fv__text--absolute {
    top: -28px;
    left: -4px;
    width: 146px;
    height: 70px;
  }
}
.fv__text--every, .fv__text--career, .fv__text--can {
  display: block;
  width: 60vw;
  line-height: 1.2;
  text-align: center;
}
@media screen and ( width >= 920px) {
  .fv__text--every, .fv__text--career, .fv__text--can {
    width: 240px;
  }
}
.fv__text--every {
  text-align: right;
}
.fv__logo {
  display: block;
  position: absolute;
  top: 68vw;
  left: 50%;
  width: 24.25vw;
  height: 12.75vw;
  text-indent: 110%;
  white-space: nowrap;
  overflow: hidden;
  background-image: url(/common/img/logo.webp);
  background-size: cover;
  background-repeat: no-repeat;
  transform: translateX(-50%);
}
@media screen and ( width >= 920px) {
  .fv__logo {
    top: 272px;
    width: 97px;
    height: 51px;
  }
}
.fv__circle-item--white, .fv__circle-item--purple, .fv__circle-item--orange, .fv__circle-item--green {
  display: block;
  position: absolute;
  border-radius: 50%;
  z-index: -1;
  top: 49vw;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
}
@media screen and ( width >= 920px) {
  .fv__circle-item--white, .fv__circle-item--purple, .fv__circle-item--orange, .fv__circle-item--green {
    top: 196px;
  }
}
.fv__circle-item--white {
  width: 74.5vw;
  height: 74.5vw;
  border: 1vw solid #000000;
  background-color: #FFFFFF;
}
@media screen and ( width >= 920px) {
  .fv__circle-item--white {
    width: 298px;
    height: 298px;
    border: 4px solid #000000;
  }
}
.fv__circle-item--purple {
  width: 90vw;
  height: 90vw;
  border: 1vw solid #000000;
  background-color: #D494FF;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 20 20"><rect x="9" y="6" width="2" height="8" fill="%23DDA9FF"/><rect x="14" y="9" width="2" height="8" transform="rotate(90 14 9)" fill="%23DDA9FF"/></svg>');
  background-size: 5vw 5vw;
}
@media screen and ( width >= 920px) {
  .fv__circle-item--purple {
    width: 360px;
    height: 360px;
    border: 4px solid #000000;
    background-size: 20px 20px;
  }
}
.fv__circle-item--orange {
  width: 113vw;
  height: 113vw;
  border: 1.5vw solid #000000;
  background-color: #FF9538;
  background-image: repeating-linear-gradient(315deg, #FF9538, #FF9538 5vw, #FFAA60 5vw, #FFAA60 10vw);
}
@media screen and ( width >= 920px) {
  .fv__circle-item--orange {
    width: 452px;
    height: 452px;
    border: 6px solid #000000;
    background-image: repeating-linear-gradient(315deg, #FF9538, #FF9538 20px, #FFAA60 20px, #FFAA60 40px);
  }
}
.fv__circle-item--green {
  width: 145vw;
  height: 145vw;
  border: 1.5vw solid #000000;
  background-color: #8FFF78;
  background-image: linear-gradient(45deg, #A5FF93 25%, transparent 25%, transparent 75%, #A5FF93 75%), linear-gradient(45deg, #A5FF93 25%, transparent 25%, transparent 75%, #A5FF93 75%);
  background-position: 0 0, 5vw 5vw;
  background-size: 10vw 10vw;
  background-origin: border-box;
}
@media screen and ( width >= 920px) {
  .fv__circle-item--green {
    width: 580px;
    height: 580px;
    border: 6px solid #000000;
    background-position: 0 0, 20px 20px;
    background-size: 40px 40px;
  }
}
.fv .flow-text {
  position: absolute;
  bottom: 7.75vw;
  background-color: #FF0000;
  color: #FFFFFF;
  transform: rotate(-8deg);
  box-shadow: 0 0.75vw 0 0 #000000;
}
@media screen and ( width >= 920px) {
  .fv .flow-text {
    bottom: 31px;
    box-shadow: 0 3px 0 0 #000000;
  }
}

/* attraction */
.attraction {
  position: relative;
  margin-top: -14vw;
  padding-top: 17vw;
  padding-bottom: 25vw;
  background-color: #74DAFF;
  background-image: repeating-linear-gradient(315deg, #74DAFF, #74DAFF 10vw, #90E1FF 10vw, #90E1FF 20vw);
  -webkit-clip-path: polygon(0% 5.9%, 100% 0%, 100% 100%, 0% 94.5%);
          clip-path: polygon(0% 5.9%, 100% 0%, 100% 100%, 0% 94.5%);
}
@media screen and ( width >= 920px) {
  .attraction {
    margin-top: -56px;
    padding-top: 68px;
    padding-bottom: 100px;
    background-image: repeating-linear-gradient(315deg, #74DAFF, #74DAFF 40px, #90E1FF 40px, #90E1FF 80px);
  }
}
.attraction::after {
  position: absolute;
  display: block;
  width: 21.75vw;
  height: 21.75vw;
  bottom: 25vw;
  right: 6vw;
  background-image: url(/home/img/attraction__sparkles.svg);
  background-size: cover;
  background-repeat: no-repeat;
  content: "";
}
@media screen and ( width >= 920px) {
  .attraction::after {
    width: 87px;
    height: 87px;
    bottom: 100px;
    right: 24px;
  }
}
.attraction__catch {
  display: block;
  width: 82.5vw;
  height: 37vw;
  margin: 0 auto;
  text-indent: 110%;
  white-space: nowrap;
  overflow: hidden;
  background-image: url(/home/img/attraction__catch.png);
  background-size: cover;
  background-repeat: no-repeat;
}
@media screen and ( width >= 920px) {
  .attraction__catch {
    width: 330px;
    height: 148px;
  }
}
.attraction__heading--2 {
  position: relative;
  margin-top: 7.5vw;
}
@media screen and ( width >= 920px) {
  .attraction__heading--2 {
    margin-top: 30px;
  }
}
.attraction__heading--2::before {
  position: absolute;
  display: block;
  width: 21.75vw;
  height: 21.75vw;
  top: -11vw;
  left: 6vw;
  background-image: url(/home/img/attraction__sparkles.svg);
  background-size: cover;
  background-repeat: no-repeat;
  content: "";
}
@media screen and ( width >= 920px) {
  .attraction__heading--2::before {
    width: 87px;
    height: 87px;
    top: -44px;
    left: 24px;
  }
}
.attraction__wrap {
  display: flex;
  justify-content: center;
}
.attraction__wrap:nth-of-type(1) {
  margin-top: 2vw;
}
@media screen and ( width >= 920px) {
  .attraction__wrap:nth-of-type(1) {
    margin-top: 8px;
  }
}
.attraction__wrap:last-child {
  margin-top: -5vw;
}
@media screen and ( width >= 920px) {
  .attraction__wrap:last-child {
    margin-top: -20px;
  }
}
.attraction [class*=__item] {
  display: flex;
  justify-content: center;
  align-items: center;
  background-size: cover;
}
.attraction [class*=__item] p {
  font-weight: 700;
  text-align: center;
}
.attraction [class*=__item] .text--dela {
  color: #FF0000;
}
.attraction__item--octagon {
  width: 43.75vw;
  height: 43.75vw;
  background-image: url(/home/img/attraction__octagon.png);
  transform: rotate(-8deg);
}
@media screen and ( width >= 920px) {
  .attraction__item--octagon {
    width: 175px;
    height: 175px;
  }
}
.attraction__item--octagon p {
  line-height: 1.2;
}
.attraction__item--octagon .text--dela {
  line-height: 1.1;
}
.attraction__item--star {
  width: 46vw;
  height: 46vw;
  background-image: url(/home/img/attraction__star.png);
  transform: rotate(8deg);
}
@media screen and ( width >= 920px) {
  .attraction__item--star {
    width: 184px;
    height: 184px;
  }
}
.attraction__item--star p {
  line-height: 1.1;
}
.attraction__item--diamond {
  width: 47.5vw;
  height: 47.5vw;
  background-image: url(/home/img/attraction__diamond.png);
  transform: rotate(-8deg);
}
@media screen and ( width >= 920px) {
  .attraction__item--diamond {
    width: 190px;
    height: 190px;
  }
}
.attraction__item--diamond p {
  line-height: 1.2;
}
.attraction__item--jagged {
  width: 45vw;
  height: 45vw;
  background-image: url(/home/img/attraction__jagged.png);
  transform: rotate(8deg);
}
@media screen and ( width >= 920px) {
  .attraction__item--jagged {
    width: 180px;
    height: 180px;
  }
}
.attraction__item--jagged p {
  line-height: 1.2;
}
.attraction__item--circle {
  width: 44vw;
  height: 44vw;
  background-image: url(/home/img/attraction__circle.png);
  transform: rotate(-8deg);
}
@media screen and ( width >= 920px) {
  .attraction__item--circle {
    width: 176px;
    height: 176px;
  }
}
.attraction__item--circle p {
  line-height: 1.1;
}

/* interview */
.interview {
  position: relative;
  margin-top: -7vw;
  padding-top: 25vw;
  padding-bottom: 25vw;
  background-color: #FFFFFF;
  background-image: linear-gradient(90deg, #D9D9D9 0.25vw, transparent 0.25vw), linear-gradient(#D9D9D9 0.25vw, transparent 0.25vw);
  background-position: 0 0;
  background-size: 10vw 10vw;
  -webkit-clip-path: polygon(0% -2.2%, 100% 2.2%, 100% 100%, 0% 100%);
          clip-path: polygon(0% -2.2%, 100% 2.2%, 100% 100%, 0% 100%);
}
@media screen and ( width >= 920px) {
  .interview {
    margin-top: -28px;
    padding-top: 100px;
    padding-bottom: 100px;
    background-image: linear-gradient(90deg, #D9D9D9 1px, transparent 1px), linear-gradient(#D9D9D9 1px, transparent 1px);
    background-size: 40px 40px;
  }
}
.interview .flow-text {
  position: absolute;
  top: 0;
  background-color: #D494FF;
  color: #000000;
  transform: rotate(8deg);
  box-shadow: 0 0.75vw 0 0 #8FFF78;
}
@media screen and ( width >= 920px) {
  .interview .flow-text {
    box-shadow: 0 3px 0 0 #8FFF78;
  }
}
.interview__heading--2 {
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: 25vw;
}
@media screen and ( width >= 920px) {
  .interview__heading--2 {
    margin-left: 100px;
  }
}
.interview__heading--2 span {
  width: -moz-fit-content;
  width: fit-content;
}
.interview__heading--2::after {
  position: absolute;
  display: block;
  width: 12vw;
  height: 18vw;
  top: 1vw;
  left: -15vw;
  background-image: url(/common/img/interview__heading.svg);
  background-size: cover;
  background-repeat: no-repeat;
  content: "";
}
@media screen and ( width >= 920px) {
  .interview__heading--2::after {
    width: 48px;
    height: 72px;
    top: 4px;
    left: -60px;
  }
}
.interview__lead {
  margin-top: 5vw;
  margin-bottom: 8.5vw;
  text-align: center;
  font-weight: 700;
  line-height: 2;
}
@media screen and ( width >= 920px) {
  .interview__lead {
    margin-top: 20px;
    margin-bottom: 34px;
  }
}
.interview [class*=interview__wrap] {
  position: relative;
  display: block;
  width: 75vw;
  height: 75vw;
  padding: 5vw 6vw;
  border-radius: 4vw;
  color: #FFFFFF;
  overflow: hidden;
}
@media screen and ( width >= 920px) {
  .interview [class*=interview__wrap] {
    width: 300px;
    height: 300px;
    padding: 20px 24px;
    border-radius: 16px;
  }
}
.interview [class*=interview__wrap] p {
  font-weight: 900;
}
.interview__wrap--red {
  margin-left: 14vw;
  background-color: #FF0000;
  transform: rotate(-5deg);
  box-shadow: 1.5vw 1.5vw 0 #74DAFF;
}
@media screen and ( width >= 920px) {
  .interview__wrap--red {
    margin-left: 56px;
    box-shadow: 6px 6px 0 #74DAFF;
  }
}
.interview__wrap--blue {
  margin-left: 10vw;
  background-color: #74DAFF;
  transform: rotate(5deg);
  box-shadow: 1.5vw 1.5vw 0 #FF0000;
}
@media screen and ( width >= 920px) {
  .interview__wrap--blue {
    margin-left: 40px;
    box-shadow: 6px 6px 0 #FF0000;
  }
}
.interview__img {
  position: absolute;
  width: 75vw;
  height: 75vw;
  top: 0;
  left: 0;
}
@media screen and ( width >= 920px) {
  .interview__img {
    width: 300px;
    height: 300px;
  }
}
.interview__img img {
  width: 100%;
  height: auto;
}

/* movie */
.movie {
  position: relative;
  margin-top: -7vw;
  padding-top: 24vw;
  padding-bottom: 24vw;
  background-color: #D494FF;
  background-image: linear-gradient(45deg, #D89EFF 25%, transparent 25%, transparent 75%, #D89EFF 75%), linear-gradient(45deg, #D89EFF 25%, transparent 25%, transparent 75%, #D89EFF 75%);
  background-position: 0 0, 5vw 5vw;
  background-size: 10vw 10vw;
  background-origin: border-box;
  -webkit-clip-path: polygon(0% 4.6%, 100% -4.8%, 100% 100%, 0% 90.7%);
          clip-path: polygon(0% 4.6%, 100% -4.8%, 100% 100%, 0% 90.7%);
}
@media screen and ( width >= 920px) {
  .movie {
    margin-top: -28px;
    padding-top: 96px;
    padding-bottom: 96px;
    background-position: 0 0, 20px 20px;
    background-size: 40px 40px;
  }
}
.movie .flow-text {
  position: absolute;
  top: 0;
  background-color: #8FFF78;
  color: #000000;
  transform: rotate(-8deg);
  box-shadow: 0 0.75vw 0 0 #FF9538;
}
@media screen and ( width >= 920px) {
  .movie .flow-text {
    box-shadow: 0 3px 0 0 #FF9538;
  }
}
.movie__heading--2 {
  position: relative;
}
.movie__heading--2::after, .movie__heading--2::before {
  position: absolute;
  display: block;
  background-size: cover;
  background-repeat: no-repeat;
  content: "";
}
.movie__heading--2::before {
  width: 11.5vw;
  height: 12.5vw;
  top: 5vw;
  left: 19vw;
  background-image: url(/home/img/movie__heading--film.svg);
}
@media screen and ( width >= 920px) {
  .movie__heading--2::before {
    width: 46px;
    height: 60px;
    top: 20px;
    left: 76px;
  }
}
.movie__heading--2::after {
  width: 16vw;
  height: 10.75vw;
  top: 2vw;
  right: 13vw;
  background-image: url(/home/img/movie__heading--camera.svg);
}
@media screen and ( width >= 920px) {
  .movie__heading--2::after {
    width: 64px;
    height: 43px;
    top: 8px;
    right: 52px;
  }
}
.movie video {
  display: block;
  width: 90vw;
  margin: 7.5vw auto 0;
  border-radius: 4vw;
  border: 0.5vw solid #000000;
  box-shadow: 0 0.75vw 0 #000000;
}
@media screen and ( width >= 920px) {
  .movie video {
    width: 360px;
    margin: 30px auto 0;
    border-radius: 16px;
    border: 2px solid #000000;
    box-shadow: 0 3px 0 #000000;
  }
}
.movie__tiktok {
  position: relative;
  display: block;
  width: 75vw;
  margin: 10vw auto 0;
  padding: 4vw;
  background-color: #000000;
  font-weight: 900;
  color: #FFFFFF;
  box-shadow: 0 0.75vw 0 #FF0000;
  text-align: center;
  border-radius: 9999px;
}
@media screen and ( width >= 920px) {
  .movie__tiktok {
    width: 300px;
    margin: 40px auto 0;
    padding: 16px;
    box-shadow: 0 3px 0 #FF0000;
  }
}
.movie__tiktok::after {
  position: relative;
  display: inline-block;
  width: 6vw;
  height: 6vw;
  top: 1vw;
  margin-left: 1vw;
  background-image: url(/common/img/icon__external--white.svg);
  background-size: cover;
  background-repeat: no-repeat;
  content: "";
}
@media screen and ( width >= 920px) {
  .movie__tiktok::after {
    width: 24px;
    height: 24px;
    top: 4px;
    margin-left: 4px;
  }
}

/* information */
.information {
  position: relative;
  margin-top: -7vw;
  padding-top: 24vw;
  padding-bottom: 57.5vw;
  background-color: #FFFFFF;
  background-image: radial-gradient(circle, #E6E6E6 0.5vw, transparent 0.5vw);
  background-size: 5vw 5vw;
  -webkit-clip-path: polygon(0% -2.8%, 100% 2.7%, 100% 100%, 0% 100%);
          clip-path: polygon(0% -2.8%, 100% 2.7%, 100% 100%, 0% 100%);
}
@media screen and ( width >= 920px) {
  .information {
    margin-top: -28px;
    padding-top: 96px;
    padding-bottom: 230px;
    background-image: radial-gradient(circle, #E6E6E6 2px, transparent 2px);
    background-size: 20px 20px;
  }
}
.information .flow-text {
  position: absolute;
  top: 0;
  background-color: #FF9538;
  color: #000000;
  transform: rotate(8deg);
  box-shadow: 0 0.75vw 0 0 #FFEE32;
}
@media screen and ( width >= 920px) {
  .information .flow-text {
    box-shadow: 0 3px 0 0 #FFEE32;
  }
}
.information__heading--2 {
  position: relative;
}
.information__heading--2::before {
  position: absolute;
  display: block;
  width: 10.5vw;
  height: 14vw;
  top: 5.5vw;
  left: 9vw;
  background-image: url(/home/img/information__heading.svg);
  background-size: cover;
  background-repeat: no-repeat;
  content: "";
  z-index: -1;
}
@media screen and ( width >= 920px) {
  .information__heading--2::before {
    width: 42px;
    height: 56px;
    top: 22px;
    left: 36px;
  }
}
.information__lead {
  margin-top: 7.5vw;
  text-align: center;
  font-weight: 700;
  line-height: 2;
}
@media screen and ( width >= 920px) {
  .information__lead {
    margin-top: 30px;
  }
}
.information__wrap {
  display: flex;
  gap: 4vw;
  margin: 7.5vw 4vw 4vw;
}
@media screen and ( width >= 920px) {
  .information__wrap {
    gap: 16px;
    margin: 30px 16px 16px;
  }
}
.information [class*=__inner] {
  padding: 3.5vw;
  border: 0.5vw solid #000000;
  border-radius: 4vw;
  box-shadow: 0 0.75vw 0 #000000;
  color: #000000;
}
@media screen and ( width >= 920px) {
  .information [class*=__inner] {
    padding: 14px;
    border: 2px solid #000000;
    border-radius: 16px;
    box-shadow: 0 3px 0 #000000;
  }
}
.information [class*=__inner] figure {
  width: 15vw;
  height: 15vw;
  margin: 2.5vw 0 0;
}
@media screen and ( width >= 920px) {
  .information [class*=__inner] figure {
    width: 60px;
    height: 60px;
    margin: 10px 0 0;
  }
}
.information [class*=__inner] figure img {
  width: 100%;
  height: auto;
}
.information [class*=__inner] p {
  margin-top: 2.5vw;
  font-weight: 700;
}
@media screen and ( width >= 920px) {
  .information [class*=__inner] p {
    margin-top: 10px;
  }
}
.information__inner {
  display: block;
  margin: 0 4vw;
  background-color: #74DAFF;
}
@media screen and ( width >= 920px) {
  .information__inner {
    margin: 0 16px;
  }
}
.information__inner .information__heading--3 {
  text-align: center;
}
.information__inner--2col {
  display: flex;
  width: 50%;
  flex-direction: column;
  align-items: center;
}
.information__inner--2col:nth-child(1) {
  background-color: #8FFF78;
}
.information__inner--2col:nth-child(2) {
  background-color: #FFEE32;
}
.information__heading--3::after {
  position: relative;
  display: inline-block;
  width: 6.5vw;
  height: 6vw;
  top: 0.5vw;
  margin-left: 1vw;
  background-image: url(/common/img/icon__arrow.svg);
  background-size: cover;
  background-repeat: no-repeat;
  content: "";
}
@media screen and ( width >= 920px) {
  .information__heading--3::after {
    width: 26px;
    height: 24px;
    top: 2px;
    margin-left: 4px;
  }
}
.information__guidelines {
  display: flex;
}
.information__guidelines p {
  width: 69vw;
}
@media screen and ( width >= 920px) {
  .information__guidelines p {
    width: 276px;
  }
}/*# sourceMappingURL=home.css.map */