.mainvisual_loading {
  position: absolute;
  z-index: 999;
  inset: 0;
  opacity: 1;
  visibility: visible;
  transition: opacity 1s, visibility 1s;
}
.mainvisual_loading.is-hidden {
  opacity: 0;
  visibility: hidden;
}
.mainvisual_loading picture {
  display: block;
  width: 100%;
  height: 100vh;
}
@media screen and (min-width: 620px) {
  .mainvisual_loading picture {
    height: 56.25vw;
  }
}
.mainvisual_loading img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top right;
}
@media (max-width: 767px) {
  .mainvisual_loading img {
    object-fit: cover;
    object-position: center;
  }
}

@media screen and (min-width: 1025px) {
  .mainvisual_loading picture {
    height: 100vh;
  }
}
.header {
  opacity: 0;
  visibility: hidden;
  transition: opacity 1s, visibility 1s;
}
.header.is-visible {
  opacity: 1;
  visibility: visible;
}

.bg_mov_wrap {
  position: fixed;
  width: 100vw;
  height: 100vh;
  top: 0;
  left: 0;
}
.bg_mov_wrap video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 177.778vh;
  height: 56.25vw;
  min-height: 100%;
  min-width: 100%;
  min-height: 110%;
  min-width: 110%;
  transform: translate(-50%, -50%);
  pointer-events: none;
}

.top-wrapper {
  overflow: hidden;
  position: relative;
  z-index: 0;
}
.top-wrapper_bg {
  position: fixed;
  z-index: -1;
  inset: 0;
}
.top-wrapper_bg::before {
  position: absolute;
  inset: 0;
  content: "";
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.1) 0%, rgba(0, 0, 0, 0.2) 100%);
}
.top-wrapper_bg video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

main > *:not(.top-wrapper),
.caption-container,
footer {
  position: relative;
  z-index: 1;
}

.top-container {
  position: relative;
  max-width: min(76.5625vw, 980px);
  margin-inline: auto;
}
@media (max-width: 767px) {
  .top-container {
    max-width: 94.2857142857vw;
  }
}

.top-caption {
  display: block;
  font-size: min(0.78125vw, 10px);
  font-feature-settings: "palt";
  letter-spacing: 0.1em;
}
@media (max-width: 767px) {
  .top-caption {
    font-size: 2vw;
  }
}
.top-caption._right {
  text-align: right;
}

.top-intro {
  overflow: hidden;
  z-index: 0;
  position: relative;
  height: 91.015625vw;
}
@media (max-width: 767px) {
  .top-intro {
    height: 142.8571428571vw;
  }
}
.top-intro_copy {
  position: absolute;
  top: 13.046875vw;
  left: 50%;
  translate: -50% 0;
  width: min(71.875vw, 920px);
}
@media (max-width: 767px) {
  .top-intro_copy {
    top: 31.4285714286vw;
    width: 85.7142857143vw;
  }
}
.top-intro_bg {
  position: absolute;
  z-index: -1;
  inset: 0;
}
.top-intro_bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center bottom;
}
.top-intro .cap {
  position: absolute;
  right: 15px;
  bottom: 10px;
  color: #fff;
  font-size: 12px;
  font-weight: bold;
}
.top-intro #particleCanvas {
  display: block;
  position: absolute;
  z-index: 2;
  width: 29%;
  height: 45%;
  bottom: 13%;
  left: 20%;
  background: #000;
  mix-blend-mode: plus-lighter;
}
@media (max-width: 767px) {
  .top-intro #particleCanvas {
    width: 35%;
    height: 45%;
    bottom: 13%;
    left: 10%;
  }
}
.top-intro .kirakira_move {
  display: none;
  position: absolute;
  z-index: 2;
  width: 25%;
  height: 30%;
  bottom: 13%;
  left: 21%;
  overflow: hidden;
  transform: rotate(180deg);
  mix-blend-mode: plus-lighter;
}
.top-intro .kirakira_move video {
  width: auto;
  height: 100%;
  filter: blur(0px) contrast(110%);
}

.top-concept {
  color: #000;
  background-image: url(../img/top/concept_bg_pc.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  margin-top: 80px;
  padding: min(9.375vw, 120px) 0;
}
@media (max-width: 767px) {
  .top-concept {
    padding: 25.7142857143vw 0;
    background-image: url(../img/top/concept_bg_sp.jpg);
  }
}
.top-concept_title {
  width: min(31.875vw, 408px);
  margin: 0 auto;
}
@media (max-width: 767px) {
  .top-concept_title {
    width: 75.7142857143vw;
  }
}
.top-concept_img {
  width: min(33.828125vw, 433px);
  margin: min(1.5625vw, 20px) auto;
}
@media (max-width: 767px) {
  .top-concept_img {
    width: 80.4285714286vw;
  }
}
.top-concept_text {
  margin-top: min(4.6875vw, 60px);
  font-size: min(1.171875vw, 15px);
  font-feature-settings: "palt";
  letter-spacing: 0.06em;
  line-height: 2.8;
  text-align: center;
}
.top-concept_text strong {
  font-size: 230%;
  font-weight: 500;
  letter-spacing: 0.1em;
}
@media (max-width: 767px) {
  .top-concept_text {
    margin-top: 11.4285714286vw;
    font-size: 2.8571428571vw;
  }
  .top-concept_text strong {
    font-size: 170%;
    font-weight: 500;
    letter-spacing: 0.05em;
  }
}

.top-section {
  padding: min(9.375vw, 120px) 0;
  color: #fff;
}
@media (max-width: 767px) {
  .top-section {
    padding: 25.7142857143vw 0;
  }
}
.top-section_inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: end;
  gap: min(4.6875vw, 60px);
  max-width: min(76.5625vw, 980px);
  margin-inline: auto;
}
@media (max-width: 767px) {
  .top-section_inner {
    grid-template-columns: auto;
    gap: 10vw;
    max-width: 100%;
  }
}
.top-section_inner._reverse > *:nth-child(1) {
  order: 2;
}
.top-section_inner._reverse > *:nth-child(2) {
  order: 1;
}
@media (max-width: 767px) {
  .top-section_inner._reverse > *:nth-child(1) {
    order: 1;
  }
  .top-section_inner._reverse > *:nth-child(2) {
    order: 2;
  }
}
.top-section_content {
  margin-left: min(2.34375vw, 30px);
}
@media (max-width: 767px) {
  .top-section_content {
    margin-left: 0;
  }
}
.top-section_title h2 {
  font-size: min(4.8vw, 50px);
  font-weight: 500;
  letter-spacing: 0.1em;
}
@media (max-width: 767px) {
  .top-section_title h2 {
    font-size: min(8vw, 50px);
    font-weight: 500;
    letter-spacing: 0.1em;
  }
}
.top-section_title p {
  margin-top: 10px;
  font-size: min(2.5vw, 32px);
  font-feature-settings: "palt";
  letter-spacing: 0.05em;
  line-height: 1;
  font-family: "Cinzel", serif;
}
@media (max-width: 767px) {
  .top-section_title p {
    font-size: 6vw;
  }
}
.top-section_text {
  margin-top: min(5.078125vw, 65px);
  font-size: min(1.015625vw, 13px);
  font-feature-settings: "palt";
  letter-spacing: 0.06em;
  line-height: 2.8461538462;
}
@media (max-width: 767px) {
  .top-section_text {
    margin-top: 14.2857142857vw;
    font-size: 2.8571428571vw;
  }
}
.top-section_btn {
  width: min(31.25vw, 400px);
  height: min(5.625vw, 72px);
  display: grid;
  place-content: center;
  border-radius: 100vmax;
  margin-bottom: min(7.8125vw, 100px);
  font-size: min(1.875vw, 24px);
  font-feature-settings: "palt";
  letter-spacing: 0.05em;
  line-height: 1;
  font-family: "Cinzel", serif;
  text-transform: uppercase;
  color: #fff !important;
  background: #151515;
}
@media (max-width: 767px) {
  .top-section_btn {
    width: 57.1428571429vw;
    height: 12.5714285714vw;
    margin-bottom: 0;
    font-size: 3.4285714286vw;
  }
}
.top-section_photos {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
@media (max-width: 767px) {
  .top-section_photos {
    flex-direction: column;
    gap: 10vw;
  }
}
.top-section_photo:nth-of-type(1) {
  width: min(30.078125vw, 385px);
}
@media (max-width: 767px) {
  .top-section_photo:nth-of-type(1) {
    width: 90vw;
    margin-right: -10vw;
  }
}
.top-section_photo:nth-of-type(2) {
  margin-top: min(23.4375vw, 300px);
  width: min(32.109375vw, 411px);
}
@media (max-width: 767px) {
  .top-section_photo:nth-of-type(2) {
    margin-top: 0;
    margin-left: 5vw;
    width: 75vw;
  }
}
.top-section_photo.plan_image {
  margin-left: 20%;
}
@media (max-width: 767px) {
  .top-section_photo.plan_image {
    margin-left: 10%;
    width: 80vw;
  }
}
.top-section_photo .top-caption {
  color: #fff;
}

.top_foot_text {
  text-align: center;
  padding: 50px 0 100px;
  font-size: min(4.8vw, 50px);
  color: #fff;
  letter-spacing: 0.05em;
}

@media (max-width: 767px) {
  .top_foot_text {
    text-align: center;
    padding: 0px 0 60px;
    font-size: min(6vw, 50px);
  }
}
.simpleParallax.simple-parallax-initialized {
  height: 100%;
}

.js-fadeIn {
  opacity: 0;
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
  transform: translateY(20px);
}
.js-fadeIn[data-scroll-anima=true] {
  opacity: 1;
  transform: translateY(0);
}/*# sourceMappingURL=top_contents.css.map */