@charset "UTF-8";
/* html {
  font-size: 62.5%;
}

@media (max-width: 1400px) and (min-width: 768px) {
  html {
    font-size: 0.7142857143vw;
  }
}

@media only screen and (min-width: 1401px) {
  html {
    font-size: 62.5%;
  }
} */

#st250820banner {
  --white: #fff;
  --black: #000;
  --font-ja: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴシック", "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic", "メイリオ", sans-serif;
  --font-aktiv: aktiv-grotesk-condensed, sans-serif;
  --font-input: input-mono-narrow, monospace;
  --fw-ex-light: 200;
  --fw-light: 300;
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
  --fw-extrabold: 800;

  font-style: normal;
}


/* ▼ -----------可変設定---------- ▼ */
#st250820banner {
  --pc-width: 1400;/*PCデザイン幅*/
  --sp-width: 750;/*SPデザイン幅*/
  --pc-artboard-width: 480;/*SP共通デザイン幅*/
  --sp-artboard-width: 750;/*PC共通デザイン幅*/
}

/* PC画面幅 1400px以上 固定 */
@media (min-width: 1400px) {
  #st250820banner {
  --ratio: calc(var(--pc-artboard-width) / var(--sp-artboard-width)); /* PCとSPのデザイン幅の比率 */
  --variable: 1px; /* 固定値（可変しない） */
  }
}

 /* PC画面幅 768～1400px 可変 */
@media (min-width: 768px) and (max-width: 1400px) {
  #st250820banner {
  --ratio: calc(var(--pc-artboard-width) / var(--sp-artboard-width)); /* PCとSPのデザイン幅の比率 */
  --variable: calc(100vw / var(--pc-width)); /* 画面幅に基づく可変値 */
  }
}

 /* SP画面幅 767px以下 可変 */
@media (max-width: 767px) {
  #st250820banner {
  --ratio: 1; /* 比率は1（変わらない） */
  --variable: calc(100vw / var(--sp-width)); /* 画面幅に基づく可変値 */
  }
}
/* ▲ -----------可変設定---------- ▲ */
/*----------共通設定 pc----------*/
* {
  font-feature-settings: "palt"; 
}

* > #st250820banner {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  /* overflow: clip; */
}

.main-area {
  padding-top: 0;
}

@media screen and (min-width: 768px) {
  .main-area {
    padding-top: 10.2rem;
  }

  #st250820banner a:hover{
    transition: .3s;
    opacity: .7;
  }
}

@media screen and (max-width: 767px) {
  .main-area {
    padding-top: calc(170*(100vw / 750));
  }
  .main-area .main-inner{
    padding-left: 0;
    padding-right: 0;
  }
  .footer{
    padding-top: 0;
  }
}

/*----------LP normalize SP----------*/
#st250820banner * {
  box-sizing: border-box;
}

#st250820banner img {
  height: auto;
  opacity: 1;
  width: 100%;
}

#st250820banner li{
  display: inline-block;
}

#st250820banner a {
  display: inline;
  text-decoration: none;
  color: #000000;
}


/* #st250820banner p{
  color: #000000;
} */

#st250820banner img,
#st250820banner picture,
#st250820banner video{
  display: inline-block;
  width: 100%;
  height: auto;
}

#st250820banner p,
#st250820banner ul,
#st250820banner ol,
#st250820banner dl {
  margin: 0;
  list-style: none;
}


/*============ ▼ 共通部分 ▼ ============*/

#st250820banner .crdt__wrapper{
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: nowrap;
  margin-top: calc(28* var(--variable)* var(--ratio));
  column-gap: calc(9* var(--variable)* var(--ratio));
}

#st250820banner .crdt,
#st250820banner .crdt__wrapper a {
  font-size: calc(22 * var(--variable) * var(--ratio));
  font-family: var(--font-aktiv);
  white-space: nowrap;
  letter-spacing: 0.06em;
  line-height: 1;
  color: #000;
  pointer-events: all;
}

#st250820banner .crdt__wrapper .crdt:last-child a{
  padding-right: 0;
}

.img_number{
  font-family: var(--font-aktiv);
  font-weight: var(--fw-light)!important;
  font-size: calc(42 * var(--variable)* var(--ratio));
  letter-spacing: 0.12em;
  line-height: 1;
}

.sec01 .sec_txt__block,
.sec03 .sec_txt__block,
.sec04 .sec_txt__block,
.sec05 .sec_txt__block{
  position: relative;
}

.sec01 .sec_img__txt,
.sec03 .sec_img__txt,
.sec04 .sec_img__txt{
  position: absolute;
  z-index: 10;
}

.sec01 .sec_img__txt,
.sec02 .sec_img__txt,
.sec03 .sec_img__txt,
.sec04 .sec_img__txt{
  display: flex;
  flex-direction: column;
  row-gap: calc(19 * var(--variable)* var(--ratio));
}

.img_title{
  font-family: var(--font-input);
  font-weight: var(--fw-regular);
  font-size: calc(27 * var(--variable)* var(--ratio));
  letter-spacing: 0.04em;
  line-height: 1;
}

@media only screen and (max-width: 767px) {
  #st250820banner{
    overflow-x: clip;
    margin-top: calc(22 * var(--variable) * var(--ratio));
  }

  #st250820banner .sp_only {
    display: block;
  }
  #st250820banner .pc_only {
    display: none;
  }
}

@media screen and (min-width: 768px) {
  #st250820banner .sp_only{
    display: none;
  }

  #st250820banner .pc_only{
    display: block;
  }
}

/*
//////////////////////////////////////////////////////////////////////////////////////////////
  mv / intro
//////////////////////////////////////////////////////////////////////////////////////////////
*/
#st250820banner .mvWrap{
  position: relative;
}
#st250820banner .mvWrap .mvWrap__img{
  width: 100%;
}

/*
//////////////////////////////////////////////////////////////////////////////////////////////
  sec
//////////////////////////////////////////////////////////////////////////////////////////////
*/

#st250820banner .sec{
  width: calc(750* var(--variable)* var(--ratio));
  margin: 0 auto;
}

/*============ ▼ sec01 ▼ ============*/
#st250820banner .sec01{
  margin-bottom: calc(220* var(--variable)* var(--ratio));
}

#st250820banner .sec01 .grid_block{
  display: grid;
  grid-template-columns: calc(250 * var(--variable)* var(--ratio)) calc(290 * var(--variable)* var(--ratio)) auto;
  grid-template-rows: calc(710 * var(--variable)* var(--ratio)) calc(100 * var(--variable)* var(--ratio)) auto;
  width: calc(710* var(--variable)* var(--ratio));
  margin: 0 0 calc(80 * var(--variable)* var(--ratio)) auto;
}

.sec01 .img01{
  width: calc(540* var(--variable)* var(--ratio));
  grid-column: 1 / 3;
  grid-row: 1 / 3;
}

.sec01 .img02{
  width: calc(460* var(--variable)* var(--ratio));
  grid-column: 2 / 4;
  grid-row: 2 / 4;
}

.sec01 .sec_txt__block{
  width: calc(520* var(--variable)* var(--ratio));
  height: calc(360* var(--variable)* var(--ratio));
  margin: 0 auto calc(140 * var(--variable)* var(--ratio)) 0;
}

.sec01 .sec_img__txt{
  align-items: flex-start;
  justify-content: left;
  bottom: calc(37 * var(--variable)* var(--ratio));
  left: calc(40 * var(--variable)* var(--ratio));
}

.sec01 .img_number,
.sec01 .img_title{
  color: #fff;
}

/*============ ▲ sec01 ▲ ============*/

/*============ ▼ sec02 ▼ ============*/
#st250820banner .sec02{
  margin-bottom: calc(202* var(--variable)* var(--ratio));
}

/* .sec02 .img01{
  width: calc(540* var(--variable)* var(--ratio));
}

.sec02 .img02{
  width: calc(580* var(--variable)* var(--ratio));
} */

.sec02 .sec_img__txt{
  position: absolute;
  justify-content: center;
  align-items: center;
  top: calc(98.7 * var(--variable) * var(--ratio));
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  width: 100%;
}

.sec02 .img_number,
.sec02 .img_title{
  color: #000;
}

#st250820banner .sec02 .crdt__wrapper{
  position: absolute;
  bottom: calc(126 * var(--variable) * var(--ratio));
  left: 50%;
  transform: translateX(-50%);
  margin-top: 0;
  z-index: 10;
}

/* -----------------------  .scroll-section */
.scroll-img__section {
  position: relative;
  width: 100%;
  /* height: calc(calc(2932 * var(--variable) * var(--ratio)) - 100vh)!important; */
  overflow: hidden;
}

@media only screen and (max-width: 767px) {
  .scroll-img__section {
    margin-top: calc(250* (100vw /750))!important;
  }
}

@media only screen and (min-width: 768px) {
  .scroll-img__section {
    margin-top: 5rem!important;
  }
}

.scroll-img__content{
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
  background-image: url(../img/sec02_hover-bg.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  /* padding-top: calc(calc(calc(1276 * var(--variable) * var(--ratio)) - 100vh) / 2) */
}

.scroll-img__wrapper {
  position: relative;
  top: 0;
  /* transform: translateY(-50%); */
  display: flex;
  align-items: center;
  justify-content: center;
  height: calc(1276 * var(--variable) * var(--ratio));
  /* height: 100vh; */
  z-index: 1;
  /* margin-top: calc(220 * var(--variable) * var(--ratio)); */
}

.sec_img-slide {
  position: absolute;
  /* top: 50%;
  left: 50%; */
}

/* .sec_img-slide .img01{
  transform: translate(-50%, -50%)!important;
} */

.sec_img-slide .inner {
  width: calc(580* var(--variable)* var(--ratio));
  height: auto;
  margin-top: calc(46 * var(--variable) * var(--ratio));
}


/* .scroll-img__section {
  position: sticky;
  top: 50%;
  transform: translateY(-50%);
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
  background-image: url(../img/sec02_hover-bg.jpg);
  background-repeat: no-repeat;
  background-size: cover;
} */

.scroll-img__container {
  position: absolute;
  top: 0;
  left: 100%;
  width: 100%;
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  pointer-events: none;
}
/*============ ▲ sec02 ▲ ============*/

/*============ ▼ sec03 ▼ ============*/
#st250820banner .sec03{
  margin-bottom: calc(200* var(--variable)* var(--ratio));
}

#st250820banner .sec03 .grid_block{
  display: grid;
  grid-template-columns: calc(115 * var(--variable)* var(--ratio)) calc(255 * var(--variable)* var(--ratio)) auto;
  grid-template-rows: calc(585 * var(--variable)* var(--ratio)) calc(255 * var(--variable)* var(--ratio)) auto;
  width: calc(675* var(--variable)* var(--ratio));
  margin: 0 auto calc(140 * var(--variable)* var(--ratio));
}

.sec03 .img01{
  position: relative;
  z-index: 1;
  width: calc(560* var(--variable)* var(--ratio));
  grid-column: 2 / 4;
  grid-row: 1 / 3;
}

.sec03 .sec_txt__block{
  width: calc(420* var(--variable)* var(--ratio));
  height: calc(560* var(--variable)* var(--ratio));
  row-gap: calc(16 * var(--variable) * var(--ratio));
  grid-column: 1 / 3;
  grid-row: 2 / 4;
}

.sec03 .sec_img__txt{
  align-items: flex-start;
  justify-content: left;
  bottom: calc(38 * var(--variable)* var(--ratio));
  left: calc(40 * var(--variable)* var(--ratio));
  color: #000;
}

.sec03 .img_number{
  font-size: calc(44 * var(--variable) * var(--ratio));
  letter-spacing: 0.1em;
}

.sec03 .img_number,
.sec03 .img_title{
  color: #000;
}
/*============ ▲ sec03 ▲ ============*/

/*============ ▼ sec04 ▼ ============*/
#st250820banner .sec04{
  margin-bottom: calc(220* var(--variable)* var(--ratio));
}

#st250820banner .sec04 .grid_block{
  display: grid;
  grid-template-columns: calc(160 * var(--variable)* var(--ratio)) calc(290 * var(--variable)* var(--ratio)) auto;
  grid-template-rows: calc(745 * var(--variable)* var(--ratio)) calc(80 * var(--variable)* var(--ratio)) calc(475 * var(--variable)* var(--ratio)) auto;
  width: calc(710* var(--variable)* var(--ratio));
  margin: 0 0 calc(140 * var(--variable)* var(--ratio)) auto;
}

.sec04 .img01{
  width: calc(550* var(--variable)* var(--ratio));
  grid-column: 2 / 4;
  grid-row: 1 / 3;
}

.sec04 .img02{
  width: calc(450* var(--variable)* var(--ratio));
  grid-column: 1 / 3;
  grid-row: 2 / 5;
}

.sec04 .sec_txt__block{
  position: relative;
  z-index: -1;
  width: calc(500* var(--variable)* var(--ratio));
  height: calc(340* var(--variable)* var(--ratio));
  grid-column: 2 / 4;
  grid-row: 4 / 6;
  margin-left: calc(10 * var(--variable) * var(--ratio));
}

.sec04 .sec_img__txt{
  align-items: end;
  bottom: calc(40.8 * var(--variable) * var(--ratio));
  right: calc(34.3 * var(--variable) * var(--ratio));
  row-gap: calc(19 * var(--variable) * var(--ratio));
}

.sec04 .img_number,
.sec04 .img_title{
  color: #fff;
}

.sec04 .img_number{
  letter-spacing: 0.1em;
}

.sec04 .img_title{
  letter-spacing: 0.03em;
}

/*============ ▲ sec04 ▲ ============*/

/*============ ▼ sec05 ▼ ============*/
#st250820banner .sec05{
  margin-bottom: calc(140* var(--variable)* var(--ratio));
}

.sec05 .img01{
  margin-bottom: calc(80* var(--variable)* var(--ratio));
}

.sec05 .sec_img01__container{
  position: relative;
  z-index: 1;
  width: 100%;
}

.sec05 .img_number{
  position: absolute;
  z-index: 10;
  top: calc(38.7 * var(--variable) * var(--ratio));
  left: calc(40 * var(--variable) * var(--ratio));
  letter-spacing: 0.075em;
}

#st250820banner .sec05 .flex_block{
  display: flex;
  justify-content: space-between;
  width: calc(688* var(--variable)* var(--ratio));
  margin: 0 0 0 auto;
}

.sec05 .img02{
  width: calc(450* var(--variable)* var(--ratio));
  grid-column: 2 / 4;
  grid-row: 1 / 3;
}

.sec05 .sec_txt__block{
  width: calc(220* var(--variable)* var(--ratio));
}

#st250820banner .sec05 .crdt__wrapper{
  position: absolute;
  flex-direction: column;
  align-items: flex-start;
  bottom: calc(26.5 * var(--variable) * var(--ratio));
  left: 47%;
  transform: translateX(-50%);
  row-gap: calc(16 * var(--variable) * var(--ratio));
}

.sec05 .sec_img__txt{
  position: absolute;
  top: calc(29 * var(--variable)* var(--ratio));
  left: calc(38.5 * var(--variable)* var(--ratio));
}

.sec05 .sec_img__txt .img_title{
  writing-mode: vertical-rl;
}

.sec05 .img_number,
.sec05 .img_title{
  color: #000;
}

/*============ ▲ sec05 ▲ ============*/



/* ====== ▼ "check all items" ▼ ====== */
#st250820banner .btn__wrapper{
  width: calc(480* var(--variable)* var(--ratio));
  margin: calc(70* var(--variable)* var(--ratio)) auto 0;
}
/* ====== ▲ "check all items" ▲ ====== */


/* ====== ▼ "staff" ▼ ====== */
#st250820banner .staff__wrapper{
  width: calc(750* var(--variable)* var(--ratio));
  margin: calc(140* var(--variable)* var(--ratio)) auto calc(120* var(--variable)* var(--ratio));
  border-top: solid calc(1* var(--variable)* var(--ratio)) #808080;
  border-bottom: solid calc(1* var(--variable)* var(--ratio)) #808080;
  padding-block: calc(29* var(--variable)* var(--ratio));
}

#st250820banner .staff__box{
  width: calc(385* var(--variable)* var(--ratio));
  margin-left: calc(50* var(--variable)* var(--ratio));
}

#st250820banner .staff__txt{
  font-size: calc(22* var(--variable)* var(--ratio));
  font-family: var(--font-aktiv);
  font-weight: var(--fw-regular);
  line-height: 1.8181818182;
  letter-spacing: 0.06em;
  white-space: nowrap; 
  color: #000;
}
/* ====== ▲ "staff" ▲ ====== */


/*============ ▼ animation ▼ ============*/

/* .js-fadeIn */
#st250820banner .js-show.fadeIn {
  opacity: 0;
  visibility: hidden;
  transition: all 2s;
}

#st250820banner .js-show.fadeIn.onView {
  opacity: 1;
  visibility: visible;
}

/* .js-fadeUp */
#st250820banner .js-show.fadeUp {
  opacity: 0;
  -webkit-transform: translate3d(0, 50px, 0);
  transform: translate3d(0, 50px, 0);
}

#st250820banner .js-show.fadeUp.onView {
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  -webkit-transition: opacity 650ms, -webkit-transform 1100ms cubic-bezier(0.23, 1, 0.32, 1);
  transition: opacity 650ms, -webkit-transform 1100ms cubic-bezier(0.23, 1, 0.32, 1);
  transition: opacity 650ms, transform 1100ms cubic-bezier(0.23, 1, 0.32, 1);
  transition: opacity 650ms, transform 1100ms cubic-bezier(0.23, 1, 0.32, 1), -webkit-transform 1100ms cubic-bezier(0.23, 1, 0.32, 1);
}

#st250820banner .js-show.delay_anim{
  opacity: 0;
  -webkit-transform: translate3d(0, 40px, 0);
  transform: translate3d(0, 40px, 0);
}

#st250820banner .js-show.onView.delay_anim{
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
  -webkit-transition: opacity 1400ms, -webkit-transform 1000ms cubic-bezier(0.19, 1, 0.22, 1);
  transition: opacity 1400ms, -webkit-transform 1000ms cubic-bezier(0.19, 1, 0.22, 1);
  transition: opacity 1400ms, transform 1000ms cubic-bezier(0.19, 1, 0.22, 1);
  transition: opacity 1400ms, transform 1000ms cubic-bezier(0.19, 1, 0.22, 1), -webkit-transform 1000ms cubic-bezier(0.19, 1, 0.22, 1);
  -webkit-transition-delay: 1450ms;
  -webkit-transition-delay: 1450ms;
  transition-delay: 1450ms;
}

#st250820banner .delay01 {
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}
#st250820banner .delay02 {
  -webkit-transition-delay: 0.8s;
  transition-delay: 0.8s;
}
#st250820banner .delay03 {
  -webkit-transition-delay: 1.2s;
  transition-delay: 1.2s;
}


/*============ ▲ animation ▲ ============*/

/* ランダムに出現するテキスト ___________________________*/

.js-typingText span {
  display: none;
}

/*文字列後ろの線の設定*/
.js-typingText::after {
  content: "";
  animation: typinganime 1s ease infinite;
}

@keyframes typinganime{
  from{opacity:0}
  to{opacity:1}
}

/*
//////////////////////////////////////////////////////////////////////////////////////////////
  pc 固定
//////////////////////////////////////////////////////////////////////////////////////////////
*/
@media (max-width: 767px) {
  .mainVisual_pc {
    display: none;
  }

  .mvWrap__img{
    margin-bottom: calc(160 * var(--variable)* var(--ratio));
  }
}

@media (min-width: 768px) {
  .sticky-container {
    display: flex;
  }

  .mainVisual_pc {
    width: 50%;
    height: 100vh;
    position: sticky;
    left: 0px;
    top: 0px;
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .mainVisual_pc .mainVisual_inner {
    position: relative;
    width: 100%;
    height: 100%;
  }

  .sticky-contents {
    width: 50%;
  }

  #st250820banner .mainVisual_inner .mvWrap__img img {
    height: 100vh;
    width: 100%;
    object-fit: cover;
    object-position: center;
    position: absolute;
    right: 0;
    top: 0;
  }

  #st250820banner .mainVisual_inner{
    position: relative;
    z-index: 1;
  }

  #st250820banner .mainVisual_inner::after{
    content: "";
    position: absolute;
    top: 64%;
    left: 50%;
    transform: translate(-50%, -50%);
    background-image: url(../img/SVG/mv_ttl.svg);
    background-size: contain;
    background-repeat: no-repeat;
    width: calc(376.72 * (100vw / 1400));
    height: calc(161.04 * (100vw / 1400));
    z-index: 5;
  }

  #st250820banner .js-show.fadeIn.delay_pc {
    -webkit-transition-delay: 2s;
    transition-delay: 2s;
  }

}