@charset "UTF-8";
:root {
  --font: 游ゴシック体, YuGothic, 游ゴシック Medium, Yu Gothic, メイリオ, sans-serif;
  --font-en: ivyjournal, sans-serif;
  --font-credit: elza, sans-serif;
  --font-mincho: yu-mincho-pr6n, ヒラギノ明朝 Pro W3, Hiragino Mincho Pro, ＭＳ Ｐ明朝, MS PMincho, serif;
  --pc-width: 1400;
  --tb-width: 768;
  --sp-width: 750;
}

* > .main-area {
  font-family: var(--font);
  font-weight: var(--fontweight-medium);
  font-feature-settings: normal;
  font-style: normal;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow: unset;
  min-width: auto;
}

@media only screen and (max-width: 1400) and (min-width: 768px) {
  html {
    font-size: calc(10 * (100vw/1400));
  }
}
@media only screen and (max-width: 767px) {
  html {
    font-size: calc(10 * (100vw/750));
  }
  * > .main-area {
    font-family: var(--font-hiragino);
  }
}
.main-area * {
  box-sizing: border-box;
}
.main-area img {
  height: auto;
  opacity: 1;
  width: 100%;
}
.main-area a {
  text-decoration: none;
}
.main-area picture {
  display: block;
}
.main-area p, .main-area ul, .main-area ol, .main-area dl {
  list-style: none;
}
@media only screen and (max-width: 767px) {
  .main-area .pc_only {
    display: none;
  }
  .main-area .sp_only {
    display: block;
  }
}

@media only screen and (min-width: 768px) {
  .main-area .pc_only {
    display: block;
  }
  .main-area .sp_only {
    display: none;
  }
}
@keyframes js-moveUp {
  0% {
    opacity: 0;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
    -webkit-clip-path: inset(100% 0 0 0);
    clip-path: inset(100% 0 0 0);
  }
  50% {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    filter: blur(30px) brightness(1.1);
  }
  100% {
    opacity: 1;
    -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
    filter: blur(0) brightness(1);
    -webkit-clip-path: inset(0 0 0 0);
    clip-path: inset(0 0 0 0);
  }
}
.js-fadeIn-load {
  opacity: 0;
  transition: opacity 3s;
}

.js-fadeIn-load--02 {
  opacity: 0;
  transition: opacity 1s 0.8s;
}

.js-fadeIn-load.js-active, .js-fadeIn-load--02.js-active {
  opacity: 1;
}

.js-fadeUp-load {
  opacity: 0;
  transition: opacity 1s, transform 1s;
  transform: translateY(10px);
}

.js-fadeUp-load.js-active {
  opacity: 1;
  transform: translateY(0);
}

.js-fadeUp, .js-fadeUp-credit {
  opacity: 0;
  transition: opacity 1s, transform 1s;
  transform: translateY(30px);
}

.js-fadeUp.js-active, .js-fadeUp-credit.js-active {
  opacity: 1;
  transform: translateY(0);
}

.js-fadeLeft {
  opacity: 0;
  transition: opacity 1s, transform 1s;
  transform: translateX(-30px);
}

.js-fadeRight {
  opacity: 0;
  transition: opacity 1s, transform 1s;
  transform: translateX(30px);
}

.js-fadeLeft.js-active, .js-fadeRight.js-active {
  opacity: 1;
  transform: translateX(0);
}

.js-fadeIn {
  opacity: 0;
  transition: opacity 2s;
}

.js-fadeIn.js-active {
  opacity: 1;
}

.js-arrow img {
  transform: translateY(-100%);
  transition: transform 0.8s ease-in-out;
}

.js-arrow.js-active img {
  transform: translateY(0);
}

.js-moveUp {
  opacity: 0;
  clip-path: inset(94% 0 0 0);
  filter: blur(30px) brightness(1.1);
}

.js-moveUp.js-active {
  animation: js-moveUp 0.95s ease-out forwards;
}

.footer {
  padding: 0;
}

.footer .toTop {
  z-index: 100;
}

#MO250424SS2nd {
  --image: 64.5rem;
}

#MO250424SS2nd {
  margin: 0 auto;
  padding: 0 0 0 0;
  color: #000000;
  font-weight: 400;
  letter-spacing: 0.05em;
  /* メインビジュアル */
}
#MO250424SS2nd .intro {
  margin: 0 auto;
  text-align: center;
  z-index: 1;
}
#MO250424SS2nd .firstview {
  width: 100%;
  margin: 0 auto;
  position: relative;
  background-color: #000;
}
#MO250424SS2nd .firstview a {
  width: 100vw;
  display: block;
  margin: 0 auto;
}
#MO250424SS2nd .firstview video {
  width: 100%;
}
#MO250424SS2nd .intro__titleWrap {
  position: fixed;
  max-width: 140rem;
  width: 100%;
  height: 4.9rem;
  z-index: 3;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  margin: 0;
  pointer-events: none;
}
#MO250424SS2nd .intro__titleWrap .intro__title--brand {
  width: 22.3rem;
  margin: 0 0 0 12.2rem;
  position: absolute;
  top: 0;
}
#MO250424SS2nd .intro__titleWrap .intro__title--theme {
  width: 18.5rem;
  margin: 0 15.1rem 0 auto;
  position: absolute;
  top: 0;
  left: auto;
  right: 0;
}
#MO250424SS2nd .intro__titleWrap .svg_path {
  fill: transparent;
}
#MO250424SS2nd .intro__titleWrap.color_01 .svg_path {
  fill: #96b2c4;
}
#MO250424SS2nd .intro__titleWrap.color_02 .svg_path {
  fill: #c52c29;
}
#MO250424SS2nd .intro__titleWrap.color_03 .svg_path {
  fill: transparent;
}
#MO250424SS2nd #mvVisual {
  position: relative;
}
#MO250424SS2nd #mvVideo {
  width: 100%;
}
#MO250424SS2nd #togglemvSound {
  cursor: pointer;
}
#MO250424SS2nd #togglemvSound {
  display: block;
  width: 3rem;
  height: 3rem;
  cursor: pointer;
  background-size: 100% auto;
  position: absolute;
  right: 1.8rem;
  bottom: 1.8rem;
  z-index: 1;
}
#MO250424SS2nd #togglemvSound .soundOff {
  display: block;
  width: 100%;
  height: 100%;
  background: url(../img/sound_off.svg) no-repeat;
}
#MO250424SS2nd #togglemvSound .soundON {
  display: block;
  width: 100%;
  height: 100%;
  background: url(../img/sound_on.svg) no-repeat;
}
#MO250424SS2nd .product__block {
  width: 100%;
}
#MO250424SS2nd .product__block .product__block-inner {
  position: relative; /* fixedやabsoluteは避ける */
}
#MO250424SS2nd .product__block .product__block-inner.product__block-inner--03 {
  width: 140rem;
  margin: 0 auto;
}
#MO250424SS2nd .product__block .product__image-wrap {
  position: relative;
}
#MO250424SS2nd .product__block .product__image {
  width: 43rem;
  margin: 0 auto;
  position: relative;
}
#MO250424SS2nd .product__block .product__image.product__image--01_3 {
  background-color: #fff;
}
#MO250424SS2nd .product__block .product__image.product__image--02_4 {
  background-color: #fff;
}
#MO250424SS2nd .product__block .product__image.product__image--03_3 {
  background-color: #fff;
}
#MO250424SS2nd .product__block .product__image.product__image--04_3 {
  background-color: #fff;
}
#MO250424SS2nd .product__block .product__image.product__image--05_1 {
  background-color: #fff;
}
#MO250424SS2nd .product__block .product__image.product__image--04_5 a.scroll_link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 86rem;
}
#MO250424SS2nd .product__block .product__image.product__image--05_4 a.scroll_link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 86rem;
}
#MO250424SS2nd .product__block .product__image.product__image--05_4 .product__scrollOuter {
  transform: translate(0px, 0px) !important;
}
#MO250424SS2nd .product__block .product__image.product__image--bottom {
  width: 22.9rem;
  margin: 0 0 0 45.7rem;
}
#MO250424SS2nd .product__block .product__scrollOuter {
  width: 43rem;
  position: relative;
  height: 64.5rem;
  overflow: hidden;
}
#MO250424SS2nd .product__block .product__scrollInner {
  width: 86rem;
  position: absolute;
  left: 0;
  display: flex;
}
#MO250424SS2nd .product__block .product__credit {
  position: absolute;
  left: 1.8rem;
  bottom: 1.5rem;
  font-family: var(--font-credit);
  font-size: 1rem;
  font-weight: 200;
  letter-spacing: 0.06em;
  line-height: 1.491;
  color: #fff;
}
#MO250424SS2nd .product__block .product__credit a {
  display: inline-block;
  margin: 0 0.7rem 0 0;
}
#MO250424SS2nd .product__block .product__credit a._slash {
  position: relative;
  margin: 0 0.7rem 0 0.7rem;
}
#MO250424SS2nd .product__block .product__credit a._slash::after {
  position: absolute;
  content: "/";
  display: block;
  top: 0;
  left: -1rem;
  line-height: 1.491;
  color: #fff;
}
#MO250424SS2nd .product__block .product__credit.credit__black {
  color: #606060;
  left: 7.6rem;
  bottom: 9.5rem;
}
#MO250424SS2nd .product__block .product__credit.credit__black a._slash::after {
  color: #606060;
}
#MO250424SS2nd .product__block .product__credit.product__credit--01 {
  display: inline-block;
  position: absolute;
  text-align: left;
  left: -12.2rem;
  bottom: -0.7rem;
}
#MO250424SS2nd .product__block--intro {
  position: relative;
  z-index: 0;
}
#MO250424SS2nd .product__block--intro .product__block-inner {
  width: 100%;
}
#MO250424SS2nd .product__block--01 {
  margin: 0 auto 0;
  position: relative;
  z-index: 1;
  background-color: #e8ebf0;
}
#MO250424SS2nd .product__block--01 .product__slider {
  background-color: #e8ebf0;
}
#MO250424SS2nd .product__block--02 {
  margin: 0 auto 0;
  background-color: #f3dfd3;
  position: relative;
  z-index: 2;
}
#MO250424SS2nd .product__block--02 .product__slider {
  background-color: #f3dfd3;
}
#MO250424SS2nd .product__block--03 {
  margin: 0 0 0;
  padding: 19.1rem 0 21rem 0;
  position: relative;
  z-index: 3;
  background-color: #fff;
}
#MO250424SS2nd .product__block--03 .bottom__logo {
  width: 22.3rem;
  position: absolute;
  top: 9.3rem;
  left: 74.4rem;
}
#MO250424SS2nd .button__all {
  display: inline-block;
  margin: 0 auto 0;
  color: #231815;
  font-family: var(--font-en);
  font-size: 1.2rem;
  letter-spacing: 0.18em;
  line-height: 1;
  position: absolute;
  top: 19rem;
  left: 75.2rem;
  z-index: 2;
}
#MO250424SS2nd .staff__area {
  text-align: left;
  position: absolute;
  top: 25rem;
  left: 75.2rem;
  z-index: 2;
  font-family: var(--font-credit);
}
#MO250424SS2nd .staff__area .staff__title {
  font-family: var(--font-en);
  font-size: 1.6rem;
  line-height: 1;
  letter-spacing: 0.15em;
}
#MO250424SS2nd .staff__area .staff__name {
  font-family: var(--font-credit);
  font-size: 0.9rem;
  line-height: 1.7833333333;
  letter-spacing: 0.06em;
}

@media only screen and (max-width: 767px) {
  .footer {
    z-index: 100;
    position: relative;
  }
  .footer .page-top {
    margin: 0;
    position: absolute;
    top: calc(-120 * (100vw/750));
    right: calc(30 * (100vw/750));
  }
  #MO250424SS2nd {
    margin: 0;
    padding: 0 0 0 0;
    max-width: calc(750 * (100vw/750));
    font-feature-settings: "palt";
    font-weight: 400;
    letter-spacing: 0.05em;
    /* メインビジュアル */
    /*#toggleModalSound {
      margin-left: 10px;
    }*/
  }
  #MO250424SS2nd .intro {
    text-align: center;
    width: 100%;
  }
  #MO250424SS2nd .firstview {
    width: 100%;
    margin: 0 auto;
    padding: 0 0 0 0;
  }
  #MO250424SS2nd .firstview a {
    width: 100%;
    display: block;
  }
  #MO250424SS2nd .intro__titleWrap {
    margin: 0;
    max-width: calc(88 * (100vw/750));
    width: calc(88 * (100vw/750));
    left: auto;
    right: calc(46 * (100vw/750));
    top: calc(110px + 80 * (100vw/750));
    transform: translate(0%, -50%);
  }
  #MO250424SS2nd .intro__titleWrap .intro__title--brand {
    width: calc(281 * (100vw/750));
    margin: 0 auto;
  }
  #MO250424SS2nd .intro__titleWrap .intro__title--theme {
    width: calc(76 * (100vw/750));
    margin: calc(0 * (100vw/750)) auto 0;
  }
  #MO250424SS2nd .intro__titleWrap .svg_path {
    fill: transparent;
    transition: fill 0.5s;
  }
  #MO250424SS2nd .intro__titleWrap.color_01 .svg_path {
    fill: #fff;
  }
  #MO250424SS2nd .intro__titleWrap.color_02 .svg_path {
    fill: #fff;
  }
  #MO250424SS2nd .intro__titleWrap.color_03 .svg_path {
    fill: transparent;
  }
  #MO250424SS2nd .intro__titleWrap .color_blue .svg_path {
    fill: #96b1c6;
  }
  #MO250424SS2nd .intro__titleWrap .color_red .svg_path {
    fill: #c52c29;
  }
  #MO250424SS2nd #togglemvSound {
    width: calc(40 * (100vw/750));
    height: calc(40 * (100vw/750));
    right: 2.1%;
    bottom: 1.5%;
    padding: 0;
  }
  #MO250424SS2nd #togglemvSound.soundOff {
    background-size: 100%;
  }
  #MO250424SS2nd #toggleModalSound {
    display: inline-block;
    margin-top: calc(10 * (100vw/750));
    padding: calc(10 * (100vw/750)) calc(20 * (100vw/750));
    background-color: #333;
    color: #fff;
    border: none;
    border-radius: calc(4 * (100vw/750));
    cursor: pointer;
  }
  #MO250424SS2nd .product__block {
    width: 100%;
  }
  #MO250424SS2nd .product__block .product__block-inner.product__block-inner--03 {
    width: 100%;
    margin: 0 auto;
  }
  #MO250424SS2nd .product__block .product__image-wrap {
    position: relative;
  }
  #MO250424SS2nd .product__block .product__image {
    width: calc(750 * (100vw/750));
  }
  #MO250424SS2nd .product__block .product__image.product__image--04_5 a.scroll_link {
    width: calc(1500 * (100vw/750));
  }
  #MO250424SS2nd .product__block .product__image.product__image--05_4 a.scroll_link {
    width: calc(1500 * (100vw/750));
  }
  #MO250424SS2nd .product__block .product__image.product__image--bottom {
    width: calc(400 * (100vw/750));
    margin: 0 0 0 calc(75 * (100vw/750));
  }
  #MO250424SS2nd .product__block .product__scrollOuter {
    width: calc(750 * (100vw/750));
    height: calc(1125 * (100vw/750));
  }
  #MO250424SS2nd .product__block .product__scrollInner {
    width: calc(1500 * (100vw/750));
  }
  #MO250424SS2nd .product__block .product__credit {
    left: calc(32 * (100vw/750));
    bottom: calc(28 * (100vw/750));
    font-size: calc(16 * (100vw/750));
    line-height: 1.625;
  }
  #MO250424SS2nd .product__block .product__credit a {
    margin: 0 calc(10 * (100vw/750)) 0 0;
  }
  #MO250424SS2nd .product__block .product__credit a._slash {
    margin: 0 calc(6 * (100vw/750)) 0 calc(6 * (100vw/750));
  }
  #MO250424SS2nd .product__block .product__credit a._slash::after {
    line-height: 1.625;
  }
  #MO250424SS2nd .product__block .product__credit.credit__black {
    left: calc(75 * (100vw/750));
    bottom: calc(165 * (100vw/750));
  }
  #MO250424SS2nd .product__block .product__credit.product__credit--01 {
    display: block;
    position: static;
    text-align: center;
  }
  #MO250424SS2nd .product__block--03 {
    margin: 0 0 0;
    padding: calc(187 * (100vw/750)) 0 0 0;
    position: relative;
    z-index: 3;
    background-color: #fff;
  }
  #MO250424SS2nd .product__block--03 .bottom__logo {
    display: none;
  }
  #MO250424SS2nd .lp__bottom-area {
    padding: 0;
    margin: calc(168 * (100vw/750)) 0 0 0;
  }
  #MO250424SS2nd .button__all {
    position: static;
    display: block;
    margin: calc(121 * (100vw/750)) 0 0 calc(291 * (100vw/750));
    font-size: calc(23 * (100vw/750));
    letter-spacing: 0.1em;
  }
  #MO250424SS2nd .staff__area {
    position: static;
    margin: calc(56 * (100vw/750)) 0 0 calc(291 * (100vw/750));
    padding: 0 0 calc(317 * (100vw/750)) 0;
    text-align: left;
  }
  #MO250424SS2nd .staff__area .staff__title {
    font-size: calc(26 * (100vw/750));
    line-height: 1;
    letter-spacing: 0.15em;
  }
  #MO250424SS2nd .staff__area .staff__name {
    margin: 0;
    font-size: calc(16 * (100vw/750));
    line-height: 1.75;
    letter-spacing: 0.06em;
  }
}/*# sourceMappingURL=style.css.map */