@charset "UTF-8";
/*--------------------------------------*
* foundation
*--------------------------------------*/
/*--------------------------------------*
* ベースカラー
*--------------------------------------*/
/*--------------------------------------*
* フォント
*--------------------------------------*/
/*--------------------------------------*
* ブレイクポイント
*--------------------------------------*/
/*--------------------------------------*
* vw変換(SP用)
*--------------------------------------*/
/*--------------------------------------*
* vw変換(PC用)
*--------------------------------------*/
/*--------------------------------------*
* デフォルトスタイル
*--------------------------------------*/

@media screen and (min-width: 769px) {
  .spNone {
    display: block;
  }
}
@media screen and (max-width: 768px) {
  .spNone {
    display: none;
  }
}

@media screen and (min-width: 769px) {
  .pcNone {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .pcNone {
    display: block;
  }
}
.dummy {
  position: sticky;
  top: 0;
  z-index: -1;
  height: 500px;
  width: 100%;
}

@media screen and (max-width: 768px) {
  .wrap1,
  .wrap7 {
    margin: 20vw auto;
  }
}
@media screen and (max-width: 768px) {
  .wrap1 .img1,
  .wrap1 .img2,
  .wrap7 .img1,
  .wrap7 .img2 {
    width: 56vw;
    margin-inline: auto;
  }
}
@media screen and (max-width: 768px) {
  .wrap1 .img2,
  .wrap7 .img2 {
    margin: 1.8666666667vw auto 0;
  }
}

@media screen and (max-width: 768px) {
  .wrap2 {
    margin-bottom: 13.3333333333vw;
  }
}

.wrap2 .img1,
.wrap2 .img2,
.wrap5 .img1,
.wrap5 .img2 {
  position: sticky;
  top: 0;
  margin-inline: auto;
}
@media screen and (max-width: 768px) {
  .wrap2 .img1,
  .wrap5 .img1 {
    padding: calc((100svh - 160vw) / 2) 0;
  }
}
@media screen and (max-width: 768px) {
  .wrap2 .img2,
  .wrap5 .img2 {
    width: 84vw;
    padding: calc((100svh - 123.4666666667vw) / 2) 0;
  }
}

@media screen and (max-width: 768px) {
  .wrap3 {
    margin-bottom: 25.3333333333vw;
  }
}
@media screen and (max-width: 768px) {
  .wrap3 .inner {
    margin: 0 auto;
    width: 80vw;
    position: sticky !important;
    top: calc((100svh - 120vw) / 2);
  }
}
.wrap3 .inner .inner_li > li:not(li:first-child) {
  position: absolute;
  top: 0;
  left: 0;
}

@media screen and (max-width: 768px) {
  .wrap4 {
    margin: 0 auto 13.3333333333vw;
    width: 66.6666666667vw;
  }
}

.wrap6 {
  position: relative;
}
.wrap6 .img1 {
  margin: 0 auto;
  position: sticky;
  top: 0;
}
@media screen and (max-width: 768px) {
  .wrap6 .img1 {
    width: 80vw;
    padding: calc((100svh - 120vw) / 2) 0;
  }
}
@media screen and (max-width: 768px) {
  .wrap6 .plus {
    bottom: inherit;
    right: 8vw;
    top: 10.6666666667vw;
  }
}
.wrap6 .double_wrap {
  margin: 0 auto;
  position: absolute;
  transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
}
@media screen and (max-width: 768px) {
  .wrap6 .double_wrap {
    width: 85.3333333333vw;
  }
}
.wrap6 .inner {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .wrap6 .img2 {
    width: 40vw;
  }
}
@media screen and (max-width: 768px) {
  .wrap6 .img3 {
    margin: -5.3333333333vw 0 0 auto;
    width: 50.6666666667vw;
  }
}

@media screen and (max-width: 768px) {
  .wrap8 .img1,
  .wrap8 .img2,
  .wrap8 .img3 {
    position: sticky;
    top: 0;
  }
  .wrap8 .img1 {
    height: 154.6666666667vw;
    top: calc((100svh - 154.6666666667vw) / 2);
  }
  .wrap8 .img2 {
    top: calc(77.3333333333vw + (100svh - 154.6666666667vw) / 2);
    margin-top: -77.3333333333vw;
  }
  .wrap8 .img3 {
    width: 46.6666666667vw;
    max-height: 100svh;
    padding-top: calc(77.3333333333vw + (100svh - 154.6666666667vw) / 2 + 2.1333333333vw);
    padding-left: 2.6666666667vw;
  }
  .wrap8 .credit {
    height: 154.6666666667vw;
    top: 0;
    z-index: 10;
  }
  .wrap8 .credit_space {
    height: 154.6666666667vw;
    position: sticky;
    top: calc((100svh - 154.6666666667vw) / 2);
    z-index: 10;
  }
  .wrap8 .box {
    margin-top: -154.6666666667vw;
  }
}

.wrap9 {
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .wrap9 {
    width: 92vw;
    margin: 20vw auto 0;
  }
}

@media screen and (min-width: 769px) {
  .height,
  .harf {
    object-fit: contain;
  }
  .harf {
    display: flex;
    align-items: center;
    height: 100vh;
  }
  .wrap1,
  .wrap7 {
    margin: min(10.4166666667vw, 150px) auto;
    display: flex;
    justify-content: center;
    gap: min(1.3888888889vw, 20px);
  }
  .wrap1 .img1,
  .wrap1 .img2,
  .wrap7 .img1,
  .wrap7 .img2 {
    width: min(34.7222222222vw, 500px);
  }
  .wrap2 .img1,
  .wrap5 .img1 {
    width: min(48.6111111111vw, 700px);
  }
  .wrap2 .img2,
  .wrap5 .img2 {
    width: min(40.7638888889vw, 587px);
  }
  .wrap3 .inner {
    width: min(34.7222222222vw, 500px);
  }
  .wrap4 {
    display: flex;
    align-items: center;
    width: min(40.2777777778vw, 580px);
  }
  .pc_flex1 {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: row-reverse;
    gap: min(5.5555555556vw, 80px);
    position: sticky;
    top: 0;
    height: 100vh;
    margin: min(5.5555555556vw, 80px) 0;
  }
  .pc_flex .dummy {
    height: 100vh;
  }
  .wrap6 {
    margin-top: min(10.4166666667vw, 150px);
  }
  .wrap6 .img1 {
    width: min(38.8888888889vw, 560px);
    padding: calc((100svh - 62.5vw) / 2) 0;
  }
  .wrap6 .img2 {
    width: min(19.4444444444vw, 280px);
  }
  .wrap6 .img3 {
    margin: max(-2.7777777778vw, -40px) 0 0 auto;
    width: min(24.3055555556vw, 350px);
  }
  .wrap6 .plus {
    bottom: inherit;
    right: min(3.4722222222vw, 50px);
    top: min(4.1666666667vw, 60px);
  }
  .wrap6 .double_wrap {
    width: min(41.6666666667vw, 600px);
  }
  .wrap7 {
    align-items: center;
    gap: min(5.5555555556vw, 80px);
  }
  .wrap7 .img1 {
    width: min(34.7222222222vw, 500px);
  }
  .wrap7 .img2 {
    width: min(40.2777777778vw, 580px);
  }
  .wrap8 .img2,
  .wrap8 .img3 {
    position: sticky;
    top: 0;
  }
  .wrap8 .img3 {
    width: min(34.7222222222vw, 500px);
    margin: 0 0 0 min(4.1666666667vw, 60px);
    height: 100vh;
    display: flex;
    align-items: center;
  }
  .wrap9 {
    width: min(44.6527777778vw, 643px);
    margin: min(10.4166666667vw, 150px) auto 0;
  }
}
/*-------------------
* project
-------------------*/
/*--------------------------------------*
* foundation
*--------------------------------------*/
/*--------------------------------------*
* FV
*--------------------------------------*/
.fv {
  position: relative;
}
@media screen and (max-width: 768px) {
  .fv {
    min-height: 166.6666666667vw;
  }
}
@media screen and (min-width: 769px) {
  .fv {
    height: 100vh;
    height: calc(var(--vh, 1vh) * 100);
    margin-bottom: min(3.4722222222vw, 50px);
    overflow: hidden;
  }
}
.fv .fv_bg {
  position: absolute;
  top: 0;
  z-index: -1;
  height: 100vh;
  height: calc(var(--vh, 1vh) * 100);
}
.fv .fv_bg img {
  object-fit: cover;
  height: auto;
}
@media screen and (max-width: 768px) {
  .fv .logo {
    width: 33.3333333333vw;
    padding: 6.6666666667vw 0 0 0;
    margin: 0 auto;
  }
}
@media screen and (min-width: 769px) {
  .fv .logo {
    width: min(22.9166666667vw, 330px);
    margin-bottom: min(2.0833333333vw, 30px);
  }
}
.fv h1 {
  font-family: "Avenir", sans-serif;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .fv h1 {
    position: absolute;
    width: 100%;
    bottom: 5.3333333333vw;
    font-size: 4.8vw;
  }
}
@media screen and (min-width: 769px) {
  .fv h1 {
    font-size: min(1.7361111111vw, 25px);
  }
}
@media screen and (min-width: 769px) {
  .fv .title {
    width: fit-content;
    position: absolute;
    transform: translateY(-50%);
    top: 50%;
    left: min(6.25vw, 90px);
  }
}

/*--------------------------------------*
* foundation
*--------------------------------------*/
/*--------------------------------------*
* FV
*--------------------------------------*/
/*--------------------------------------*
* foundation
*--------------------------------------*/
