@charset "UTF-8";

/* Scss Document */
/* Font Size デザインカンプ　750/psd:1366px/break:1920px/
--------------------------------------------------------- */
/* VWはSPのみ利用
--------------------------------------------------------- */
/* % only
--------------------------------------------------------- */
/* 
--------------------------------------------------------- */
/* =========================================================
 MV
========================================================= */
.s-mv {
  display: flex;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .s-mv {
    padding-top: 33.86vw;
  }
}


/* 画像 */
.s-mv__ph {
  width: 70%;
  overflow: hidden;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .s-mv__ph {
    width: 54.6vw;
  }
}

.s-mv__ph img {
  width: 100%;
  vertical-align: top;
  -webkit-backface-visibility: hidden;
  animation: animationZoom1 5s ease-in-out forwards;
}

@keyframes animationZoom1 {
  100% {
    transform: scale(1.1);
  }
}

/* 見出し */
.s-mv__heading {
  width: 30%;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .s-mv__heading {
    width: 45.4vw;
    align-items: start;
  }
}

.s-mv__heading__inner {
  display: flex;
  flex-direction: row-reverse;
  justify-content: center;
  margin-top: 0.667vw;
  color: #000;
}

.s-mv__heading h2 {
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  font-weight: 400;
  font-size: 44px;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .s-mv__heading h2 {
    font-size: 7.2vw;
  }
}

.s-mv__heading p {
  writing-mode: vertical-rl;
  font-family: "Times New Roman", Times, "serif";
  font-size: 16px;
  padding-left: 15px;
  letter-spacing: 0.1em;
  box-sizing: border-box;
  margin-top: 4px;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .s-mv__heading p {
    font-size: 3.2vw;
    padding-left: 3.5vw;
    margin-top: 0.8vw;
  }
}

.h-kv__txt_scroll {
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 10;
}


/* =========================================================
STORY
========================================================= */
.story-sec01-wrap {
  background: #FFF;
  padding: 0 0;
}

.story-sec01-wrap .story-sec01 {
  display: flex;
  width: 100%;
  height: 400px;
  justify-content: center;
  align-items: center;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01-wrap .story-sec01 {
    max-height: 64vw;
  }
}

.story-sec01-wrap .story-sec01 .text-story {
  font-family: "Times New Roman", Times, "serif";
  position: absolute;
  color: #f5f5f5;
  font-size: 180px;
  letter-spacing: .8rem;
  z-index: 1;
}

@media (max-width: 750px) {
  .story-sec01-wrap .story-sec01 .text-story {
    font-size: 18vw;
  }
}

.story-sec01-wrap .story-sec01 .text-story-text {
  position: absolute;
  color: #000;
  font-size: 16px;
  line-height: 1.8em;
  text-align: center;
  z-index: 2;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01-wrap .story-sec01 .text-story-text {
    font-size: 3.2vw;
    white-space: nowrap;
  }
}

.story-sec01-wrap .btmtab {
  padding: 110px 0;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01-wrap .btmtab {
    padding: 14.5vw 0;
  }
}

.story-sec01-wrap .head-tab {
  border-top: 1px solid #D7D7D7;
  padding-bottom: 80px;
}

.story-sec01-wrap .story-sec01--tab {
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01-wrap .story-sec01--tab {
    width: 89.333vw;
  }
}

.story-sec01-wrap .story-sec01--tab .tab--list {
  display: flex;
  justify-content: center;
  flex-wrap: nowrap;
}

.story-sec01-wrap .story-sec01--tab .tab--list .select {
  border-top: solid #000 3px;
  font-weight: bold;
  color: #000;
  box-sizing: border-box;
  display: inline-block;
}

.story-sec01-wrap .story-sec01--tab .tab--list .toptab {
  padding: 39px 0;
  line-height: 1.6em;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01-wrap .story-sec01--tab .tab--list .toptab {
    padding: 5.333vw 0;
    line-height: 1.7em;
  }
}

.story-sec01-wrap .story-sec01--tab .tab--list li {
  cursor: pointer;
  color: #999999;
  text-align: center;
  width: 320px;
  display: block;
  height: 100%;
  font-size: 14px;
}

@media (max-width: 750px) {
  .story-sec01-wrap .story-sec01--tab .tab--list li {
    font-size: 2.6666666667vw;
    line-height: 1.7em;
  }
}

.story-sec01-wrap .story-sec01--tab .tab--list li span {
  display: block;
  padding-top: 0.8em;
  font-size: 12px;
  font-family: "Times New Roman", Times, "serif";
  letter-spacing: 0.15em;
}

@media (max-width: 750px) {
  .story-sec01-wrap .story-sec01--tab .tab--list li span {
    font-size: 2.6666666667vw;
  }
}

.story-sec01--tab--contents .tab--contents--wrap {
  background: #fcf7dd;
  display: none;
  color: #000;
}

.story-sec01--tab--contents .tab--contents--wrap .h-story-mv {
  position: absolute;
  display: block;
  vertical-align: bottom;
  width: 100%;
  max-width: 1285px;
  margin-top: -75px;
}

.story-sec01--tab--contents .tab--contents--wrap .h-story-mv img {
  vertical-align: bottom;
  width: 100%;
  height: auto;
}

.story-sec01--tab--contents .tab--contents--wrap .h-story-mv .mv--ttl {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 440px;
  height: 180px;
  background: #FFF;
  display: block;
  box-sizing: border-box;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01--tab--contents .tab--contents--wrap .h-story-mv .mv--ttl {
    width: 93.333vw;
    height: 33.333vw;
    margin-bottom: -23.333vw;
  }
}

.story-sec01--tab--contents .tab--contents--wrap .h-story-mv .mv--ttl p {
  left: 80px;
  top: 46px;
  position: absolute;
  font-weight: 600;
  font-size: 24px;
  letter-spacing: .2rem;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01--tab--contents .tab--contents--wrap .h-story-mv .mv--ttl p {
    font-size: 4.8vw;
    left: 8vw;
    top: 9vw;
  }
}

.story-sec01--tab--contents .tab--contents--wrap .h-story-mv .mv--ttl p span {
  font-size: 16px;
  display: block;
  font-weight: normal;
  margin-top: 17px;
}

@media (max-width: 750px) {
  .story-sec01--tab--contents .tab--contents--wrap .h-story-mv .mv--ttl p span {
    font-size: 3.2vw;
    margin-top: 2.5vw;
  }
}

.story-sec01--tab--contents .tab--contents--wrap .h-story-in-contents {
  max-width: 960px;
  width: 100%;
  margin: 0 auto 0 auto;
  padding-top: 450px;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01--tab--contents .tab--contents--wrap .h-story-in-contents {
    padding-top: 80vw;
    width: 86.6666666667vw;
  }
}

.story-sec01--tab--contents .tab--contents--wrap .h-story-in-contents .h-story-grid {
  color: #000;
  display: grid;
  /*grid-template-rows: auto;*/
  grid-template-columns: 120px 1fr;
}

@media (max-width: 750px) {
  .story-sec01--tab--contents .tab--contents--wrap .h-story-in-contents .h-story-grid {
    grid-template-columns: 9.333vw 1fr;
  }
}

.story-sec01--tab--contents .tab--contents--wrap .h-story-in-contents .h-story-grid .grid--ttl01 {
  grid-column: 1 / 2;
  grid-row: 1 / 4;
  padding-top: 54px;
  margin-top: 14px;
  font-family: 'Noto Serif JP', serif;
  font-size: 80%;
  -ms-writing-mode: tb-lr;
  writing-mode: vertical-lr;
  letter-spacing: 0.15em;
  font-weight: 200;
  width: 120px;
  text-align: left;
  position: relative;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01--tab--contents .tab--contents--wrap .h-story-in-contents .h-story-grid .grid--ttl01 {
    font-size: 2.8vw;
  }
}

.story-sec01--tab--contents .tab--contents--wrap .h-story-in-contents .h-story-grid .grid--ttl01:before {
  content: "";
  background: #535558;
  width: 1px;
  height: 37px;
  position: absolute;
  top: 0;
  left: 7%;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01--tab--contents .tab--contents--wrap .h-story-in-contents .h-story-grid .grid--ttl01:before {
    left: 1.8vw;
  }
}

.story-sec01--tab--contents .tab--contents--wrap .h-story-in-contents .h-story-grid .grid--ttl02 {
  grid-column: 2 / 3;
  grid-row: 1 / 2;
  font-size: 30px;
  line-height: 1.7em;
  padding-bottom: 50px;
  letter-spacing: .2rem;
  text-align: justify;
text-justify: inter-ideograph;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01--tab--contents .tab--contents--wrap .h-story-in-contents .h-story-grid .grid--ttl02 {
    font-size: 5.366vw;
    padding-bottom: 9vw;
    line-height: 1.8em;
    letter-spacing: 0em;
  }
}

.story-sec01--tab--contents .tab--contents--wrap .h-story-in-contents .h-story-grid .grid--text {
  grid-column: 2 / 3;
  grid-row: 2 / 3;
  padding-bottom: 80px;
  max-width: 840px;
  line-height: 2;
  font-size: 16px;
}

@media (max-width: 750px) {
  .story-sec01--tab--contents .tab--contents--wrap .h-story-in-contents .h-story-grid .grid--text {
    font-size: 3.2vw;
    padding-bottom: 12vw;
  }
}

.story-sec01--tab--contents .tab--contents--wrap .h-story-in-contents .h-story-grid .grid--img {
  grid-column: 2 / 3;
  grid-row: 3 / 4;
  display: flex;
  vertical-align: bottom;
  padding-bottom: 115px;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01--tab--contents .tab--contents--wrap .h-story-in-contents .h-story-grid .grid--img {
    display: block;
    width: 100%;
    padding-bottom: 18vw;
  }
}

.story-sec01--tab--contents .tab--contents--wrap .h-story-in-contents .h-story-grid .grid--img img {
  vertical-align: bottom;
  max-width: 420px;
  height: auto;
}

@media (max-width: 750px) {
  .story-sec01--tab--contents .tab--contents--wrap .h-story-in-contents .h-story-grid .grid--img img {
    width: 100%;
    max-width: 100%;
    height: auto;
  }
}

.story-sec01--tab--contents .show {
  display: block;
}

.story-sec01--tab--contents .story-nav-under {
  padding: 0 0 8em 0;
}
@media only screen and (max-width:750px) {
  .story-sec01--tab--contents .story-nav-under {
    padding: 0 0 26.666vw 0;
  }
}

.story-sec01--tab--contents .story-nav-under .story-nav-group--list {
  display: flex;
  justify-content: center;
  color: #FFF;
  padding: 60px 0 70px 0;
  border-top: solid 1px #2D2D2D;
}

.story-nav-group--list__ttl {
  letter-spacing: 0.1em;
  font-weight: 200;
}
@media (max-width: 750px) {
  .story-nav-group--list__ttl {
    font-size: 3.2vw;
  }
}

@media (max-width: 750px) {
  .story-sec01--tab--contents .story-nav-under .story-nav-group--list {
    display: block;
  }
}

.story-sec01--tab--contents .story-nav-under .story-nav-group--list li {
  width: 50%;
}

@media (max-width: 750px) {
  .story-sec01--tab--contents .story-nav-under .story-nav-group--list li {
    width: 100%;
  }
}

.story-sec01--tab--contents .story-nav-under .story-nav-group--list li:first-child {
  padding: 3em 0;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01--tab--contents .story-nav-under .story-nav-group--list li:first-child {
    padding: 0 0 9vw 0;
  }
}

.story-sec01--tab--contents .story-nav-under .story-nav-group--list li dl {
  padding: 3em 0;
  font-size: 14px;
  line-height: 1.5em;
  font-weight: 200;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01--tab--contents .story-nav-under .story-nav-group--list li dl {
    font-size: 2.933vw;
    padding: 2.3em 0;
  }
}

.story-sec01--tab--contents .story-nav-under .story-nav-group--list li dl dd {
  margin-top: 10px;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01--tab--contents .story-nav-under .story-nav-group--list li dl dd {
    margin-top: 2vw;
  }
}

.story-sec01--tab--contents .story-nav-under .story-nav-group--list li dl dd span {
  font-family: 'Noto Sans JP', sans-serif !important;
  font-size: 12px;
  line-height: 1.5em;
  font-weight: 200;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01--tab--contents .story-nav-under .story-nav-group--list li dl dd {
    font-size: 2.666vw;
  }
}

.story-sec01--tab--contents .story-nav-under .story-nav-group--list li dl:nth-child(2) {
  border-top: solid 1px #2D2D2D;
}

.story-sec01--tab--contents .story-nav-under .story-nav-group--btn a {
  box-sizing: border-box;
  padding: 45px 60px 50px 60px;
  display: flex;
  align-items: center;
  background: #FFF;
  color: #000;
  width: 100%;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01--tab--contents .story-nav-under .story-nav-group--btn a {
    padding: 7.8vw; 6.66vw 7.8vw; 6.66vw;
  }
}

.story-sec01--tab--contents .story-nav-under .story-nav-group--btn a span {
  font-family: "Times New Roman", Times, "serif";
  letter-spacing: 0.1em;
  font-size: 16px;
  color: #999999;
  padding-bottom: 18px;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01--tab--contents .story-nav-under .story-nav-group--btn a span {
    font-size: 3.2vw;
  }
}

.story-sec01--tab--contents .story-nav-under .story-nav-group--btn a div p {
  font-size: 19px;
  margin-top: 6px;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .story-sec01--tab--contents .story-nav-under .story-nav-group--btn a div p {
    font-size: 3.7vw;
    margin-top: 2vw;
  }
}

.rec--arrow {
  display: block;
  margin-left: auto;
  width: 36px;
  height: 16px;
  position: relative;
  overflow: hidden;
  box-sizing: border-box;
}
/********* sp *********/
@media only screen and (max-width: 750px) {
  .rec--arrow {
    width: 8vw;
    height: 3.066vw;
  }
}

.rec--arrow::before,
.rec--arrow::after {
  content: "";
  width: 36px;
  height: 16px;
  background: url(../image/arrow.svg);
  background-repeat: no-repeat;
  background-size: cover;
  position: absolute;
  top: 0;
  left: 0;
}
/********* sp *********/
@media only screen and (max-width: 750px) {
  .rec--arrow::before,
  .rec--arrow::after {
    background-size: contain;
    width: 8vw;
    height: 3.066vw;
  }
}

/********* pc *********/
@media only screen and (min-width: 751px) {
  .story-nav-group--btn:hover .rec--arrow::before {
    animation-name: arrow_ani_01;
    animation-fill-mode: backwards;
    animation-duration: 1s;
    animation-delay: 0;
  }

  @keyframes arrow_ani_01 {
    0% {
      left: 0;
      opacity: 1;
    }

    100% {
      left: 60px;
    }
  }

  .story-nav-group--btn:hover .rec--arrow::after {
    animation-name: arrow_ani_02;
    animation-fill-mode: backwards;
    animation-duration: 1s;
    animation-delay: 0;
  }

  @keyframes arrow_ani_02 {
    0% {
      left: -60px;
    }

    100% {
      left: 0;
    }
  }
}