@charset "UTF-8";
/*//////////////////////////////////////////////////
	TOP
//////////////////////////////////////////////////*/
/*--------------------------------------------------
	オープニングの設定
--------------------------------------------------*/
.inactive {
  height: 100vh;
  height: 100dvh;
  overflow: hidden;
}

.opening {
  position: fixed;
  z-index: 1000;
  top: 0;
  left: 0;
  width: 100vw;
  width: 100dvw;
  height: 100vh;
  height: 100dvh;
  background: #030303;
}
.opening * {
  font-size: 0;
}
.opening [class^=op-phase-] {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 100vw;
  width: 100dvw;
  height: 100vh;
  height: 100dvh;
}
.opening [class^=op-phase-] .item {
  overflow: hidden;
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
}
.opening [class^=op-phase-] .item:first-child .texture-wrap img {
  object-position: 50% 0;
}
.opening [class^=op-phase-] .item:last-child .texture-wrap img {
  object-position: 50% -50vh;
}
.opening [class^=op-phase-] .item .op-phase_copy {
  opacity: 0;
  position: absolute;
  z-index: 2;
  top: 25%;
  width: 100%;
  text-align: center;
  filter: blur(3px);
  transition: filter 1s ease-out, opacity 1s ease-out;
}
.opening [class^=op-phase-] .item .op-phase_copy img {
  object-fit: fill;
  width: auto;
  height: 1.5rem;
}
.opening [class^=op-phase-] .item .item_inner {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  transform: translateY(100%);
}
.opening [class^=op-phase-] .item .item_inner * {
  width: 100%;
  height: 100%;
}
.opening [class^=op-phase-] .item .item_inner img {
  object-fit: cover;
}
.opening [class^=op-phase-] .item .texture-wrap {
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}
.opening [class^=op-phase-] .item .texture-wrap img {
  width: 100vw;
  height: 100vh;
}
.opening [class^=op-phase-] .item img {
  object-fit: cover;
}
.opening [class^=op-phase-]:not(.op-phase-01) {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 50vh 50vh;
  align-items: center;
  justify-content: center;
}
.opening .op-phase-01 {
  position: relative;
  z-index: 2;
}
.opening .op-phase-01 .op-copy {
  opacity: 0;
  position: absolute;
  bottom: 50vh;
  left: 50%;
  transform: translateX(-50%);
  width: 14.6rem;
  filter: blur(3px);
}
.opening .op-phase-07 .item_inner {
  background: #030303;
}
.opening [class^=op-phase-].active .op-copy {
  opacity: 1;
  filter: blur(0);
  transition: filter 1s ease-out, opacity 1s ease-out;
}
.opening [class^=op-phase-].active .item_inner {
  transform: translate(0) !important;
  transition: transform 1s ease;
}
.opening [class^=op-phase-].active .op-phase_copy.on {
  opacity: 1;
  filter: blur(0) drop-shadow(0 0 2px rgb(0, 0, 0));
}
.opening [class^=op-phase-].active .texture-wrap.on {
  /*
  transform: translateY(-100%);
  */
  opacity: 0;
  transition: opacity 0.6s ease-in;
}
.opening .op_skip {
  display: flex;
  align-items: center;
  justify-content: center;
  column-gap: 0.5em;
  cursor: pointer;
  position: absolute;
  z-index: 3;
  bottom: 1rem;
  right: 2rem;
  padding: 1rem 1rem 0.6rem 1.4rem;
  line-height: 1;
  color: #fff;
  font-size: 1.1rem;
  border: 1px solid #fff;
}
.opening .op_skip::after {
  content: "";
  width: 1em;
  height: 0.5rem;
  border-bottom: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: translateY(-50%) skewX(35deg);
}

@media screen and (min-width: 769px) {
  .opening [class^=op-phase-] .item {
    position: revert;
  }
  .opening [class^=op-phase-] .item:first-child .texture-wrap img {
    object-position: 0 0;
  }
  .opening [class^=op-phase-] .item:last-child .texture-wrap img {
    object-position: -50vw 0;
  }
  .opening [class^=op-phase-] .item .op-phase_copy {
    top: 80%;
    right: 0;
  }
  .opening [class^=op-phase-] .item .op-phase_copy img {
    height: 3.45rem;
  }
  .opening [class^=op-phase-]:not(.op-phase-01) {
    grid-template-columns: 50vw 50vw;
    grid-template-rows: 1fr;
  }
  .opening .op-phase-01 .op-copy {
    bottom: 50%;
    width: 38rem;
    transform: translate(-50%, 36%);
  }
  .opening .op-phase-02 .item:first-child .item_inner {
    transform: translateY(-100%);
  }
  .opening .op-phase-02 .item:last-child .item_inner {
    transform: translateY(100%);
  }
  .opening .op-phase-03 .item .item_inner {
    transform: translateX(-100%);
  }
  .opening .op-phase-04 .item .item_inner {
    transform: translateX(100%);
  }
  .opening .op-phase-05 .item:first-child .item_inner {
    transform: translateX(-100%);
  }
  .opening .op-phase-05 .item:last-child .item_inner {
    transform: translateX(100%);
  }
  .opening .op-phase-06 .item .item_inner {
    transform: translateX(-100%);
  }
  .opening .op-phase-07 .item .item_inner {
    transform: translateX(100%);
  }
  .opening .op_skip {
    bottom: 5rem;
    right: 5rem;
    padding: 1rem 2rem 0.6rem 2.4rem;
    font-size: 1.8rem;
  }
}
/*--------------------------------------------------
	MV
--------------------------------------------------*/
.mv {
  position: relative;
  z-index: 1;
}
.mv .mv__copy {
  position: absolute;
  z-index: 1;
  top: 2rem;
  left: 50%;
  width: 14.8rem;
  transform: translateX(-50%);
}
.mv .mv__ttl {
  width: 100%;
  text-align: center;
  transform: translateY(-50%);
}
.mv .mv__ttl .attent {
  text-align: right;
  font-size: 0.8rem;
}
.mv .mv__ttl img {
  width: 21.2rem;
}

@media screen and (min-width: 769px) {
  .mv .mv__copy {
    top: 1rem;
    left: 0;
    width: 44.2rem;
    transform: translateX(0);
  }
  .mv .mv__ttl {
    transform: translateY(-100%);
  }
  .mv .mv__ttl .attent {
    font-size: 1rem;
  }
  .mv .mv__ttl img {
    width: 43.8rem;
  }
}
/*--------------------------------------------------
	メインコンテンツ
--------------------------------------------------*/
.merritt {
  margin-bottom: 2.4rem;
}
.merritt .merritt-inner {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  width: 80%;
  margin: 0 auto;
  border-top: 1px solid #fff;
}
.merritt .item {
  flex: 0 0 100%;
  padding: 1rem 0;
  text-align: center;
  border-bottom: 1px solid #fff;
}
.merritt .item p {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  line-height: 1;
  font-size: 2rem;
}
.merritt .item p ._s,
.merritt .item p ._ss {
  font-size: 0.48em;
}
.merritt .item p ._ll {
  font-size: 1.6em;
}
.merritt .item p .num {
  margin: 0 0.1em;
  transform: translateY(4%);
}
.merritt .item .sub {
  margin-bottom: 0.5rem;
}

@media screen and (min-width: 769px) {
  .merritt {
    margin-bottom: 9rem;
  }
  .merritt .merritt-inner {
    row-gap: 3.6rem;
    max-width: 1200px;
    border-top: none;
  }
  .merritt .item {
    flex: 0 0 auto;
    padding: 0.4rem 2rem;
    border-right: 1px solid #fff;
    border-bottom: none;
  }
  .merritt .item:first-child {
    border-left: 1px solid #fff;
  }
  .merritt .item:last-child {
    border-right: none;
  }
  .merritt .item:nth-child(1) .sub, .merritt .item:nth-child(2) .sub {
    position: absolute;
    bottom: 3rem;
    left: 0;
  }
  .merritt .item .pos {
    position: relative;
    z-index: 1;
  }
  .merritt .item p {
    justify-content: flex-start;
    font-size: 3rem;
    text-align: left;
  }
  .merritt .item p ._ss {
    font-size: 0.42em;
  }
  .merritt .item p ._s {
    font-size: 0.58em;
  }
  .merritt .item p ._ll {
    font-size: 2.4em;
  }
  .merritt .item p .num {
    transform: translateY(10%);
  }
  .merritt .item .sub {
    margin-bottom: 1rem;
  }
}
/*--------------------------------------------------
	コンバージョン
--------------------------------------------------*/
.conversion_box .conversion-inner {
  display: flex;
  flex-flow: column nowrap;
  align-items: center;
  justify-content: center;
  aspect-ratio: 375/264;
  margin-bottom: 2.8rem;
  background: url("/assets/img/home/background_entry-sp.jpg") center/cover no-repeat;
}
.conversion_box .conversion-ttl {
  margin-bottom: 0.5rem;
  text-align: center;
  font-size: 1.6rem;
  letter-spacing: 0.1em;
}
.conversion_box .conversion-txt {
  margin-bottom: 1.8rem;
  text-align: center;
  font-size: 1rem;
  text-align: center;
  letter-spacing: 0;
}
.conversion_box .conversion-limited {
  margin-top: 2rem;
}
.conversion_box .conversion-limited .txt {
  text-align: center;
  font-size: 1rem;
  letter-spacing: 0;
}
.conversion_box .c-button {
  flex-flow: column wrap;
}
.conversion_box .c-button .c-button_btn {
  flex: 0 0 auto;
  grid-template-columns: 1fr;
  width: 15.4rem;
  height: 3.6rem;
  text-align: center;
  font-size: 1.32rem;
  background: linear-gradient(to right, #b99615 0%, #533907 100%);
}
.conversion_box .c-button .c-button_btn::before, .conversion_box .c-button .c-button_btn::after {
  content: none;
}

@media screen and (min-width: 769px) {
  .conversion_box .conversion-inner {
    row-gap: 2rem;
    aspect-ratio: 168/58;
    margin-bottom: 8rem;
    background: url("/assets/img/home/background_entry-pc.jpg?2025062301") center/cover no-repeat;
  }
  .conversion_box .conversion-ttl {
    padding: 0.4rem 0;
    font-size: 3.8rem;
    border-top: 1px solid #fff;
    border-bottom: 1px solid #fff;
  }
  .conversion_box .conversion-txt {
    margin-bottom: 1.8rem;
    font-size: 1.6rem;
  }
  .conversion_box .conversion-limited {
    margin-top: 2rem;
  }
  .conversion_box .conversion-limited .txt {
    font-size: 1.6rem;
  }
  .conversion_box .c-button {
    flex-flow: row wrap;
    column-gap: 4rem;
  }
  .conversion_box .c-button .c-button_btn {
    flex: 0 0 28rem;
    width: 28rem;
    height: 5.4rem;
    font-size: 2rem;
  }
}
/*--------------------------------------------------
	動画
--------------------------------------------------*/
.movie {
  margin-bottom: 2.4rem;
}
.movie .movie-ttl {
  margin-bottom: 1.2rem;
  text-align: center;
  font-size: 1.3rem;
}
.movie .movie-item video {
  width: min(1000px, 100%);
}

@media screen and (min-width: 769px) {
  .movie {
    margin-bottom: 4rem;
  }
  .movie .movie-inner {
    max-width: 1000px;
  }
  .movie .movie-ttl {
    margin-bottom: 2.8rem;
    font-size: 3rem;
  }
  .movie .movie-ttl img {
    width: 34rem;
  }
}
.p-attent {
  margin-bottom: 2.6rem;
}

@media screen and (min-width: 769px) {
  .p-attent {
    margin-bottom: 2.6rem;
  }
  .p-attent .c-inner {
    max-width: 1000px;
  }
}
/*# sourceMappingURL=style.css.map */
