@charset "UTF-8";
/*---------- reset ----------*/
.main-inner {
  width: 100% !important;
}

.main-area {
  overflow-x: visible !important;
}

/*---------- reset ----------*/
/*---------- all common ----------*/
html {
  font-size: 62.5%;
  box-sizing: border-box;
}

.LB220803 img {
  width: 100%;
  height: auto;
}
.LB220803 a, .LB220803 picture {
  display: block;
}
.LB220803 .pc-only {
  display: none;
}
@media screen and (min-width: 768px) {
  .LB220803 .pc-only {
    display: block;
  }
}
@media screen and (min-width: 768px) {
  .LB220803 .sp-only {
    display: none;
  }
}

/*---------- all common ----------*/
/*---------- animation ----------*/
.js-first-fade-Vr,
.js-fade-Vr {
  opacity: 0;
  transition-duration: 1.2s;
}

.js-first-fade-Vr.active,
.js-fade-Vr.active {
  opacity: 1;
}

/*---------- animation ----------*/
/*---------- font ----------*/
.firstviewArea__subTtl,
.firstviewArea__mainTtl--inspired,
.firstviewArea__mainTtl--issue,
.sec-ttl__style,
.sec-ttl__item,
.sec-credit a,
.LB220803__btn,
.sec-staff span {
  font-family: mencken-std-head, sans-serif;
  font-style: normal;
  color: #000;
}

.firstviewArea__mainTtl--jp,
.introArea__txt {
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "Yu Gothic", "Open Sans", "メイリオ", sans-serif;
  font-weight: 500;
  font-style: normal;
}

.firstviewArea__mainTtl,
.sec-ttl,
.sec-credit,
.sec-staff {
  line-height: 1;
}
.firstviewArea__mainTtl span,
.sec-ttl span,
.sec-credit span,
.sec-staff span {
  line-height: 1;
}

.firstviewArea__subTtl {
  color: #fff;
  font-weight: 400;
  font-size: calc(35 *(100vw / 750));
  letter-spacing: 0.02em;
}
@media screen and (min-width: 768px) {
  .firstviewArea__subTtl {
    font-size: 25px;
  }
}

.firstviewArea__mainTtl--inspired {
  color: #fff;
  font-weight: 700;
  font-size: calc(82 *(100vw / 750));
}
@media screen and (min-width: 768px) {
  .firstviewArea__mainTtl--inspired {
    font-size: 59px;
  }
}

.firstviewArea__mainTtl--issue {
  color: #fff;
  font-weight: 400;
  font-size: calc(41 *(100vw / 750));
}
@media screen and (min-width: 768px) {
  .firstviewArea__mainTtl--issue {
    font-size: 29px;
  }
}

.firstviewArea__mainTtl--jp {
  color: #fff;
  font-size: calc(33 *(100vw / 750));
  font-feature-settings: "palt";
  letter-spacing: 0.03em;
}
@media screen and (min-width: 768px) {
  .firstviewArea__mainTtl--jp {
    font-size: 22px;
  }
}

.introArea__txt {
  font-size: calc(23 *(100vw / 750));
  line-height: 1.8260869565;
  letter-spacing: 0.15em;
  font-feature-settings: "palt";
}
@media screen and (min-width: 768px) {
  .introArea__txt {
    font-size: 14px;
    line-height: 2.5;
    letter-spacing: 0.08em;
  }
}

.sec-ttl__style {
  font-size: calc(27 *(100vw / 750));
}
@media screen and (min-width: 768px) {
  .sec-ttl__style {
    font-size: 21px;
  }
}

.sec-ttl__style--num {
  font-size: calc(29 *(100vw / 750));
}
@media screen and (min-width: 768px) {
  .sec-ttl__style--num {
    font-size: 23px;
  }
}

.sec-ttl__item {
  font-weight: 700;
  font-size: calc(42 *(100vw / 750));
}
@media screen and (min-width: 768px) {
  .sec-ttl__item {
    font-size: 39px;
  }
}

.sec-credit span {
  font-size: calc(23 *(100vw / 750));
  letter-spacing: 0.04em;
  font-feature-settings: "palt";
}
@media screen and (min-width: 768px) {
  .sec-credit span {
    font-size: 15px;
  }
}

.LB220803__btn {
  font-size: calc(36 *(100vw / 750));
  letter-spacing: 0.04em;
  font-feature-settings: "palt";
}
@media screen and (min-width: 768px) {
  .LB220803__btn {
    font-size: 20px;
  }
}

.sec-staff {
  font-size: calc(22 *(100vw / 750));
  letter-spacing: 0.04em;
  font-feature-settings: "palt";
}
@media screen and (min-width: 768px) {
  .sec-staff {
    font-size: 14px;
  }
}

/*---------- font ----------*/
/*
//////////////////////////////////////////////////////////////////////////////////////////////
                                          for mobile
//////////////////////////////////////////////////////////////////////////////////////////////
*/
/*---------- 最後消す！ ----------*/
/*---------- 最後消す！ ----------*/
/*---------- common ----------*/
.sec {
  margin-bottom: calc(144 *(100vw / 750));
}
.sec__wrap {
  position: relative;
}

.sec-ttl {
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  text-align: center;
}
.sec-ttl__style {
  display: block;
  margin-bottom: calc(20 *(100vw / 750));
}

.sec-credit {
  text-align: center;
}
.sec-credit span {
  display: inline-block;
  margin: 0 calc(10 *(100vw / 750));
  margin-bottom: calc(16 *(100vw / 750));
}

.model-image101,
.model-image301,
.model-image302,
.model-image401 {
  margin-bottom: calc(80 *(100vw / 750));
}

.model-image102,
.model-image202,
.model-image303,
.model-image402 {
  margin-bottom: calc(70 *(100vw / 750));
}

/*---------- common ----------*/
/*---------- img ----------*/
.model-image102 {
  width: calc(540 *(100vw / 750));
}

.model-image201 {
  width: calc(630 *(100vw / 750));
}

.model-image301 {
  width: calc(560 *(100vw / 750));
}

.model-image303 {
  width: calc(630 *(100vw / 750));
}

.model-image401 {
  width: calc(600 *(100vw / 750));
}

/*---------- img ----------*/
.LB220803 {
  padding-bottom: calc(184 *(100vw / 750));
}
.LB220803__wrapper {
  position: relative;
  padding-top: calc(150 *(100vw / 750));
  z-index: 10;
  background-color: #fff;
}

.firstviewArea {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: -1;
}
.firstviewArea__wrap {
  position: relative;
}
.firstviewArea__ttl {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: calc(680 *(100vw / 750));
  margin: auto;
}
.firstviewArea__img{
  z-index: -10;
}

.introArea {
  margin-bottom: calc(150 *(100vw / 750));
}
.introArea__txt {
  text-align: center;
}

.sec01 .sec-ttl {
  top: calc(52 *(100vw / 750));
}

.sec02__wrap {
  margin-top: calc(-64 *(100vw / 750));
}
.sec02 .model-image201 {
  position: relative;
  margin: 0 auto;
  z-index: 10;
}
.sec02 .sec-ttl {
  top: calc(115 *(100vw / 750));
}

.sec03__wrap {
  margin: 0 auto;
}
.sec03 .model-image301 {
  margin: 0 auto;
  margin-bottom: calc(80 *(100vw / 750));
}
.sec03 .model-image303 {
  margin-left: auto;
  margin-right: 0;
}
.sec03 .sec-ttl {
  bottom: calc(168 *(100vw / 750));
}

.sec04 .sec-ttl {
  top: calc(80 *(100vw / 750));
}

.LB220803__btn a {
  display: flex !important;
  justify-content: center;
  align-items: center;
  width: calc(675 *(100vw / 750));
  height: calc(146 *(100vw / 750));
  margin: 0 auto;
  margin-bottom: calc(120 *(100vw / 750));
  border: solid 1px #000;
  box-sizing: border-box;
}

.sec-staff {
  text-align: center;
}
.sec-staff span {
  display: inline-block;
  margin: 0 calc(9 *(100vw / 750));
  margin-bottom: calc(16 *(100vw / 750));
}

/*
//////////////////////////////////////////////////////////////////////////////////////////////
                                          for desktop
//////////////////////////////////////////////////////////////////////////////////////////////
*/
@media screen and (min-width: 768px) {
  html {
    font-size: 62.5%;
  }
  /*---------- common ----------*/
  .sec {
    margin-bottom: 108px;
  }
  .sec__wrapper {
    margin: 0 auto;
    width: 95%;
  }
  .sec-ttl__style {
    margin-bottom: 18px;
  }
  .sec-credit span {
    margin: 0 7px;
    margin-bottom: 12px;
  }
  .firstviewArea__wrap,
.sec__wrap {
    margin: 0 auto;
  }
  .model-image101,
.sec03__wrap,
.model-image302,
.model-image401 {
    margin-bottom: 70px;
  }
  .model-image301 {
    margin-bottom: 0;
  }
  .model-image102,
.model-image202,
.model-image303,
.model-image402 {
    margin-bottom: 60px;
  }
  /*---------- common ----------*/
  /*---------- img ----------*/
  .firstviewArea__wrap {
    width: 650px;
  }
  .sec01__wrap {
    width: 600px;
  }
  .model-image102 {
    width: 450px;
  }
  .model-image201 {
    width: 540px;
  }
  .sec02__wrap {
    width: 730px;
  }
  .sec03__wrap {
    width: 520px;
  }
  .model-image301 {
    width: 100%;
  }
  .model-image302 {
    width: 580px;
  }
  .model-image303 {
    width: 500px;
  }
  .model-image401 {
    width: 450px;
  }
  .sec04__wrap {
    width: 600px;
  }
  /*---------- img ----------*/
  .LB220803 {
    padding-top: 30px;
    padding-bottom: 128px;
  }
  .LB220803__wrapper {
    padding-top: 110px;
  }
  .firstviewArea {
    position: static;
    z-index: 0;
  }
  .firstviewArea__ttl {
    top: 32px;
    width: 512px;
  }
  .introArea {
    margin-bottom: 140px;
  }
  .introArea__txt {
    text-align: center;
  }
  .sec01__wrapper {
    max-width: 900px;
  }
  .sec01 .sec-ttl {
    top: 28px;
  }
  .sec02__wrap {
    margin-top: -82px;
  }
  .sec02 .sec-ttl {
    top: 129px;
  }
  .sec03__wrapper {
    max-width: 850px;
  }
  .sec03 .model-image301 {
    margin-bottom: 0;
  }
  .sec03 .model-image303 {
    margin-left: auto;
    margin-right: 3rem;
  }
  .sec03 .sec-ttl {
    bottom: 234px;
  }
  .sec04__wrapper {
    max-width: 760px;
  }
  .sec04 .sec-ttl {
    top: 60px;
  }
  .LB220803__btn a {
    width: 420px;
    height: 74px;
    margin-bottom: 60px;
  }
  .sec-staff span {
    margin: 0 6px;
    margin-bottom: 12px;
  }
}
/*
//////////////////////////////////////////////////////////////////////////////////////////////
                                          for tablet
//////////////////////////////////////////////////////////////////////////////////////////////
*/
@media (max-width: 1400px) and (min-width: 768px) {
  html {
    font-size: 0.7142857143vw;
  }
}