@charset "UTF-8";
/*--------------------------------------*
* foundation
*--------------------------------------*/
/*--------------------------------------*
* ベースカラー
*--------------------------------------*/
/*--------------------------------------*
* フォント
*--------------------------------------*/
/*--------------------------------------*
* ブレイクポイント
*--------------------------------------*/
/*--------------------------------------*
* vw変換(SP用)
*--------------------------------------*/
/*--------------------------------------*
* vw変換(PC用)
*--------------------------------------*/
/*--------------------------------------*
* デフォルトスタイル
*--------------------------------------*/
html,
body {
  width: 100%;
  font-size: 16px;
  margin: 0 auto;
  font-family: "sherborne-variable", sans-serif;
  font-variation-settings: "opsz" 12, "wght" 700;
  color: #fff;
}

.en {
  font-family: "nimbus-sans", sans-serif;
  font-weight: 400;
  font-style: normal;
}

img,
video,
object {
  width: 100%;
  border: none;
  display: block;
}

@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;
  }
}

/*--------------------------------------*
* aタグ
*--------------------------------------*/
a {
  display: block;
  text-decoration: none;
  transition: all 0.4s;
  color: #fff;
}
@media screen and (min-width: 769px) {
  a:hover {
    opacity: 0.6;
    transition: all 0.4s;
  }
}
a[href=""] {
  pointer-events: none;
}

/*--------------------------------------*
* ローディング
*--------------------------------------*/
#loading-bg {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0px;
  left: 0px;
  background: #fff;
  z-index: 999;
}

/*--------------------------------------*
* layout
*--------------------------------------*/
/*--------------------------------------*
* foundation
*--------------------------------------*/
/*--------------------------------------*
* ヘッダー
*--------------------------------------*/
/*--------------------------------------*
* foundation
*--------------------------------------*/
/*--------------------------------------*
* フッター
*--------------------------------------*/
footer {
  color: #000;
}
footer .staff_credit {
  text-align: center;
  line-height: 2.5;
}
@media screen and (max-width: 768px) {
  footer .staff_credit {
    font-size: 2.9333333333vw;
    padding: 53.3333333333vw 0;
  }
}
@media screen and (min-width: 769px) {
  footer .staff_credit {
    font-size: min(1.0416666667vw, 15px);
    padding: min(10.4166666667vw, 150px) 0;
  }
}
footer a {
  color: #000;
}
footer .insta_box a {
  text-align: center;
  width: fit-content;
  margin: 0 auto 50px;
  display: flex;
  align-items: center;
  gap: 5px;
  text-decoration: underline;
}
footer .insta_box a .ico {
  width: 15px;
}
footer .gemini_btn {
  border: 1px solid #000;
  padding: 20px 0;
  text-align: center;
  margin: 0 auto;
  max-width: 300px;
}
footer .gemini_btn.top {
  margin: 0 auto 10px;
}
@media screen and (min-width: 769px) {
  footer .gemini_btn {
    max-width: 500px;
  }
}
footer .copyright {
  text-align: center;
  font-size: 10px;
  padding: 20px 0 100px;
}

/*--------------------------------------*
* object
*--------------------------------------*/
/*-------------------
* component
-------------------*/
/*--------------------------------------*
* foundation
*--------------------------------------*/
/*--------------------------------------*
* コンテンツ幅
*--------------------------------------*/
/*--------------------------------------*
* foundation
*--------------------------------------*/
/*--------------------------------------*
* 共通ボタン
*--------------------------------------*/
/*--------------------------------------*
* foundation
*--------------------------------------*/
/*--------------------------------------*
* セクション共通
*--------------------------------------*/
.inner {
  height: fit-content;
  position: relative;
}

.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
*--------------------------------------*/
/*--------------------------------------*
* credit
*--------------------------------------*/
.credit_card {
  position: relative;
}
.credit_card.active .plus {
  transform: rotate(45deg);
  transition: all 0.4s;
}

.credit {
  position: absolute;
  top: 0;
  transform: translateX(-50%);
  left: 50%;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  display: flex;
  justify-content: center;
  align-items: flex-end;
  z-index: 10;
}

@media screen and (max-width: 768px) {
  .credit_li {
    margin-bottom: 14.6666666667vw;
    font-size: 3.2vw;
    max-width: 64vw;
  }
}
@media screen and (min-width: 769px) {
  .credit_li {
    font-size: vw(16);
    margin-bottom: min(6.9444444444vw, 100px);
    max-width: 64vw;
  }
}
@media screen and (max-width: 768px) {
  .credit_li li {
    margin-bottom: 1.6vw;
  }
}
@media screen and (min-width: 769px) {
  .credit_li li {
    margin-bottom: min(0.6944444444vw, 10px);
  }
}
.credit_li span {
  font-size: 10px;
  border: 1px solid #fff;
  padding: 3px 5px;
  white-space: nowrap;
}

.plus {
  position: absolute;
  transition: all 0.4s;
  z-index: 15;
}
@media screen and (max-width: 768px) {
  .plus {
    width: 5.3333333333vw;
    height: 5.3333333333vw;
    bottom: 5.3333333333vw;
    right: 5.3333333333vw;
  }
}
@media screen and (min-width: 769px) {
  .plus {
    width: min(1.7361111111vw, 25px);
    height: min(1.7361111111vw, 25px);
    bottom: min(2.0833333333vw, 30px);
    right: min(2.0833333333vw, 30px);
  }
}
.plus:before, .plus:after {
  content: "";
  background-color: #fff;
  position: absolute;
  transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
}
@media screen and (max-width: 768px) {
  .plus:before {
    width: 5.3333333333vw;
    height: 1px;
  }
}
@media screen and (min-width: 769px) {
  .plus:before {
    width: min(1.7361111111vw, 25px);
    height: 1px;
  }
}
@media screen and (max-width: 768px) {
  .plus:after {
    width: 1px;
    height: 5.3333333333vw;
  }
}
@media screen and (min-width: 769px) {
  .plus:after {
    width: 1px;
    height: min(1.7361111111vw, 25px);
  }
}/*# sourceMappingURL=style.css.map */