@charset "UTF-8";
:root {
  --vw: (100vw / 1400)* var(--ratio);
  --ratio: calc(var(--pc-width) / 750);
  --pc-width: 700;
  --scrollbar: 0;
}

/*アニメーション
----------------------------*/
.js-spread {
  clip-path: polygon(50% 50%, 50% 50%, 50% 50%, 50% 50%);
  -webkit-transition: clip-path 0.4s ease-out;
  transition: clip-path 0.4s ease-out;
}
.js-spread.is-show {
  clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
  -webkit-transition-delay: 0.1s;
          transition-delay: 0.1s;
}

.swiper {
  width: calc(630 * var(--vw));
}

/*共通
----------------------------*/
.l-container {
  width: 100%;
}

.l-header {
  padding: 0;
  position: relative;
  z-index: 999;
  background-color: #fff;
  overflow-x: clip;
}

.l-footer {
  padding: 0;
  position: relative;
  z-index: 999;
  background-color: #fff;
  overflow-x: clip;
}

.pc-footer {
  margin: 0;
}

#feature {
  width: 100%;
  margin: 0 auto;
  color: #000;
  background-color: #fff;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  font-family: "hiragino-kaku-gothic-pron", sans-serif;
  font-weight: 400;
  font-style: normal;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  position: relative;
  overflow: clip;
}
#feature * {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 0;
  margin: 0;
  -webkit-margin-before: 0;
          margin-block-start: 0;
  -webkit-margin-after: 0;
          margin-block-end: 0;
}
#feature a {
  width: 100%;
  height: auto;
  display: block;
  color: #000;
  text-decoration: none;
}
#feature a:hover {
  opacity: 1;
}
#feature img, #feature svg {
  max-width: 100%;
  width: 100%;
  height: auto;
  display: block;
}
#feature .inner {
  width: 100%;
  margin: 0 auto;
  position: relative;
}

/*Wrap
----------------------------*/
#feature .contentsWrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: calc(100vw - var(--scrollbar));
  position: relative;
}
#feature .leftWrap {
  position: sticky;
  top: 80px;
  height: calc(100vh - 80px);
  width: 50vw;
}
#feature .leftWrap .leftWrap__img {
  width: 100%;
}
#feature .leftWrap .leftWrap__img img {
  width: 100%;
  height: calc(100vh - 80px);
  -o-object-position: center;
     object-position: center;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 700/800;
}
#feature .leftWrap .leftWrap__txt {
  width: 30.1428571429vw;
  position: absolute;
  bottom: 1svh;
  left: 1.0714285714vw;
  z-index: 5;
}
#feature .mainWrap {
  width: 50vw;
}
#feature .mainWrap .inner {
  overflow: clip;
}

/*メインビジュアル（.hero)
----------------------------*/
#feature .hero {
  position: relative;
}
#feature .hero .hero__img--wrapper {
  width: calc(750 * var(--vw));
  height: calc(998 * var(--vw));
  background-color: #f7d7d5;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#feature .hero .hero__img {
  width: calc(712 * var(--vw));
}

/*.credit
----------------------------*/
#feature .sec__credit {
  position: absolute;
  z-index: 5;
}
#feature .sec__credit .item {
  display: inline-block;
  font-family: "neue-haas-grotesk-display", sans-serif;
  font-weight: 500;
  font-size: calc(22 * var(--vw));
  letter-spacing: 0.09em;
  line-height: 1;
  margin-right: calc(20 * var(--vw));
}
#feature .sec__credit .item.-mr0, #feature .sec__credit .item:last-of-type {
  margin-right: 0;
}

/*.sec
----------------------------*/
#feature .sec {
  position: relative;
}
#feature .sec .sec__img, #feature .sec .sec__box {
  position: relative;
  z-index: 1;
  width: auto;
}
#feature .sec .sec__img-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}
#feature .sec .parallax-container .sec__img-wrapper {
  width: 100%;
  height: 100%;
}
#feature .sec .sec__box {
  width: 100%;
  height: calc(1340 * var(--vw));
}
#feature .sec .sec__inner {
  width: 100%;
  height: 100%;
}
#feature .sec .sec__txt {
  font-family: "neue-haas-grotesk-display", sans-serif;
  font-size: calc(28 * var(--vw));
  font-weight: 500;
  font-style: normal;
  letter-spacing: 0.04em;
  line-height: 1;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
}
#feature .sec01 .lead__txt {
  position: relative;
  padding: calc(90 * var(--vw)) calc(48 * var(--vw)) 0;
  margin-bottom: calc(276 * var(--vw));
}
#feature .sec01 .lead__txt .jp {
  font-family: "hiragino-kaku-gothic-pron", sans-serif;
  font-size: calc(24 * var(--vw));
  font-weight: 300;
  font-style: normal;
  line-height: 1.75;
  letter-spacing: 0.06em;
  margin-bottom: calc(25 * var(--vw));
}
#feature .sec01 .lead__txt .en {
  font-family: "neue-haas-grotesk-display", sans-serif;
  font-size: calc(20 * var(--vw));
  font-weight: 500;
  line-height: 1.75;
  letter-spacing: 0.09em;
}
#feature .sec01 .scroll {
  position: absolute;
  width: 100%;
  bottom: calc(-265 * var(--vw));
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  text-align: center;
}
#feature .sec01 .scroll span {
  position: relative;
  display: block;
  font-family: "neue-haas-grotesk-display", sans-serif;
  font-size: calc(24 * var(--vw));
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #000;
  padding: 0 0 calc(140 * var(--vw));
}
#feature .sec01 .scroll span::after {
  content: "";
  position: absolute;
  width: calc(2 * var(--vw));
  height: calc(71 * var(--vw));
  left: 0;
  right: 0;
  bottom: calc(45 * var(--vw));
  margin: 0 auto;
  background-image: url(../img/scroll_arrow.png);
  background-size: 100%;
  -webkit-animation: arrow-move 2s infinite;
          animation: arrow-move 2s infinite;
}
@-webkit-keyframes arrow-move {
  0% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
  20% {
    -webkit-transform: translate(0, 10px);
            transform: translate(0, 10px);
  }
  40% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}
@keyframes arrow-move {
  0% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
  20% {
    -webkit-transform: translate(0, 10px);
            transform: translate(0, 10px);
  }
  40% {
    -webkit-transform: translate(0, 0);
            transform: translate(0, 0);
  }
}
#feature .sec01 .box01 {
  z-index: 10;
  background-color: transparent;
}
#feature .sec01 .box01 .img01 {
  width: calc(750 * var(--vw));
  height: calc(var(--vh, 1vh) * 100);
}
#feature .sec01 .box01 .txt01 {
  width: calc(329 * var(--vw));
  position: absolute;
  bottom: 1svh;
  left: calc(15 * var(--vw));
  z-index: 5;
  pointer-events: none;
}
#feature .sec01 .box01 .credit01 {
  bottom: 2svh;
  right: calc(40 * var(--vw));
  text-align: end;
}
#feature .sec01 .box01 .credit01 .item {
  margin-bottom: calc(10 * var(--vw));
}
#feature .sec01 .box02 {
  z-index: 20;
  background-color: #f7d7d5;
}
#feature .sec01 .box02 .sec__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#feature .sec01 .box02 .img02 {
  width: calc(590 * var(--vw));
  margin: 0 auto;
}
#feature .sec01 .box02 .txt01 {
  position: absolute;
  left: calc(40 * var(--vw));
  height: calc(787 * var(--vw));
}
#feature .sec01 .box02 .txt02 {
  position: absolute;
  left: calc(680 * var(--vw));
  height: calc(787 * var(--vw));
  text-align: end;
}
#feature .sec01 .box02 .credit02 {
  bottom: 0;
  left: 0;
  margin-bottom: -9%;
}
#feature .sec01 .box03 {
  z-index: 30;
  background-color: transparent;
}
#feature .sec01 .box03 .sec__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
#feature .sec01 .box03 .img03 {
  width: calc(750 * var(--vw));
  height: calc(var(--vh, 1vh) * 100);
}
#feature .sec01 .box03 .txt01 {
  width: calc(383 * var(--vw));
  position: absolute;
  bottom: 1svh;
  left: calc(15 * var(--vw));
  z-index: 5;
  pointer-events: none;
}
#feature .sec01 .box03 .credit03 {
  bottom: 2svh;
  right: calc(40 * var(--vw));
  text-align: end;
}
#feature .sec01 .box03 .credit03 .item {
  margin-bottom: calc(10 * var(--vw));
}
#feature .sec01 .box04 {
  z-index: 40;
  background-color: #cfe8e8;
}
#feature .sec01 .box04 .sec__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#feature .sec01 .box04 .img04 {
  width: calc(630 * var(--vw));
}
#feature .sec01 .box04 .credit04 {
  top: 0;
  left: calc(640 * var(--vw));
  height: calc(840 * var(--vw));
  margin-bottom: -9%;
  text-align: end;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
}
#feature .sec01 .box04 .credit04 .item {
  margin: 0 calc(10 * var(--vw)) calc(20 * var(--vw)) 0;
}
#feature .sec01 .box04 .credit04 .item.-mr0, #feature .sec01 .box04 .credit04 .item.item:last-of-type {
  margin-bottom: 0;
}
#feature .sec01 .box05 {
  z-index: 50;
  background-color: #fff;
}
#feature .sec01 .box05 .sec__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#feature .sec01 .box05 .img05 {
  width: calc(590 * var(--vw));
  margin: 0 auto;
}
#feature .sec01 .box05 .txt01 {
  position: absolute;
  left: calc(40 * var(--vw));
  height: calc(787 * var(--vw));
}
#feature .sec01 .box05 .txt02 {
  position: absolute;
  left: calc(680 * var(--vw));
  height: calc(787 * var(--vw));
  text-align: end;
}
#feature .sec01 .box05 .credit05 {
  bottom: 0;
  left: 0;
  margin-bottom: -9%;
}
#feature .sec01 .box06 {
  z-index: 60;
  background-color: #f7d7d5;
}
#feature .sec01 .box06 .sec__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#feature .sec01 .box06 .img06 {
  width: calc(670 * var(--vw));
}
#feature .sec01 .box06 .credit06 {
  top: 0;
  left: calc(680 * var(--vw));
  height: calc(893 * var(--vw));
  text-align: end;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
}
#feature .sec01 .box06 .credit06 .item {
  margin: 0 0 calc(20 * var(--vw)) 0;
}
#feature .sec01 .box06 .credit06 .item.-mr0, #feature .sec01 .box06 .credit06 .item.item:last-of-type {
  margin-bottom: 0;
}
#feature .sec01 .box07 {
  z-index: 70;
  background-color: #fff;
  height: calc(1340 * var(--vw));
  display: block;
  padding: calc(164 * var(--vw)) 0 0;
}
#feature .sec01 .box07 .box07__ttl {
  font-family: "neue-haas-grotesk-display", sans-serif;
  font-size: calc(60 * var(--vw));
  font-weight: 500;
  font-style: normal;
  letter-spacing: 0.09em;
  margin: 0 auto calc(50 * var(--vw)) calc(40 * var(--vw));
}
#feature .sec01 .box07 .box07__ttl span {
  display: block;
  font-size: calc(28 * var(--vw));
  letter-spacing: 0.09em;
  margin-top: calc(4 * var(--vw));
}
#feature .sec01 .box07 .slick-slider__wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: calc(670 * var(--vw));
  margin: 0 auto;
}
#feature .sec01 .box07 .main-slider {
  width: calc(490 * var(--vw));
}
#feature .sec01 .box07 .thumbnail {
  width: calc(95 * var(--vw));
  margin-right: calc(3 * var(--vw));
}
#feature .sec01 .box07 .thumbnail .thumbnail-img {
  padding-bottom: calc(20 * var(--vw));
}
#feature .sec01 .box07 .thumbnail .thumbnail-img:nth-of-type(6) {
  padding-bottom: 0;
}
#feature .sec01 .box07 .thumbnail .slick-track {
  -webkit-transform: unset !important;
          transform: unset !important;
  height: calc(786 * var(--vw)) !important;
}
#feature .sec01 .box07 .thumbnail .slick-list {
  height: calc(786 * var(--vw)) !important;
}
#feature .sec01 .box07 .thumbnail .slick-current {
  border: calc(2 * var(--vw)) solid #ccc;
}
#feature .sec01 .box07 .slide-arrow {
  position: absolute;
  top: calc(592 * var(--vw));
  cursor: pointer;
  width: calc(74 * var(--vw));
  height: calc(12 * var(--vw));
  z-index: 5;
}
#feature .sec01 .box07 .prev-arrow {
  left: calc(152 * var(--vw));
}
#feature .sec01 .box07 .next-arrow {
  left: calc(260 * var(--vw));
}
#feature .sec01 .box07 .link-list {
  position: absolute;
  top: calc(1040 * var(--vw));
  left: calc(40 * var(--vw));
}
#feature .sec01 .box07 .link-list li {
  margin-bottom: calc(24 * var(--vw));
}
#feature .sec01 .box07 .link-list li a {
  position: relative;
  font-family: "neue-haas-grotesk-display", sans-serif;
  font-weight: 500;
  font-style: normal;
  font-size: calc(28 * var(--vw));
  letter-spacing: 0.09em;
  display: inline-block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
#feature .sec01 .box07 .link-list li::after {
  content: "";
  background: url(../img/link-arrow.png) no-repeat;
  background-size: 100%;
  display: inline-block;
  width: calc(19 * var(--vw));
  height: calc(24 * var(--vw));
  margin-left: calc(38 * var(--vw));
  padding-bottom: 2px;
  vertical-align: text-bottom;
}
#feature .sec02 .sec__staff {
  position: relative;
  display: block;
  top: 0;
  z-index: 80;
  height: calc(843 * var(--vw));
  background: url(../img/staff_bg01.jpg?260428) no-repeat 0 0, url(../img/staff_bg02.jpg?260428) no-repeat 0 calc(556 * var(--vw));
  background-size: 100%, 100%;
  padding: calc(26 * var(--vw)) calc(24 * var(--vw)) 0;
}
#feature .sec02 .sec__staff p {
  font-family: "neue-haas-grotesk-display", sans-serif;
  font-weight: 500;
  font-size: calc(18 * var(--vw));
  letter-spacing: 0.09em;
  line-height: 1.4;
}

/*1400px以上 
----------------------------*/
@media screen and (min-width: 1350px) {
  :root {
    --vw: 1px * var(--ratio);
    --pc-width: 500;
  }
  #feature .mainWrap .inner {
    width: 500px;
    margin: 0 auto;
  }
}/*# sourceMappingURL=style.css.map */