@charset "UTF-8";
/*--------------------------------------*
* foundation
*--------------------------------------*/
/*--------------------------------------*
* ベースカラー
*--------------------------------------*/
/*--------------------------------------*
* フォント
*--------------------------------------*/
/*--------------------------------------*
* ブレイクポイント
*--------------------------------------*/
/*--------------------------------------*
* vw変換(SP用)
*--------------------------------------*/
/*--------------------------------------*
* vw変換(PC用)
*--------------------------------------*/
/*--------------------------------------*
* デフォルトスタイル
*--------------------------------------*/
html,
body {
  width: 100%;
  font-size: 16px;
  margin: 0 auto;
  font-family: "orpheuspro", serif;
  font-weight: 400;
  font-style: normal;
}

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

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

@media screen and (min-width: 958px) {
  .pcNone {
    display: none;
  }
}
@media screen and (max-width: 960px) {
  .pcNone {
    display: block;
  }
}

/*--------------------------------------*
* aタグ
*--------------------------------------*/
a {
  display: block;
  text-decoration: none;
  transition: all 0.4s;
  color: #000;
}
@media screen and (min-width: 958px) {
  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 {
  padding: 200px 0 40px;
}
footer .link_wrap a {
  width: 260px;
  margin: 0 auto;
  font-size: 14px;
  color: #fff;
  text-align: center;
  padding: 12px 0;
  background-color: #7f1e23;
}
footer .link_wrap a.instagram {
  display: flex;
  gap: 5px;
  justify-content: center;
  margin: 10px auto 0;
}
footer .instagram span {
  display: block;
  width: 13px;
}
footer .logo {
  margin: 150px auto 20px;
  width: 225px;
}
footer .copy {
  font-size: 10px;
  text-align: center;
}

/*--------------------------------------*
* object
*--------------------------------------*/
/*-------------------
* component
-------------------*/
/*--------------------------------------*
* foundation
*--------------------------------------*/
/*--------------------------------------*
* コンテンツ幅
*--------------------------------------*/
/*-------------------
* project
-------------------*/
/*--------------------------------------*
* foundation
*--------------------------------------*/
/*--------------------------------------*
* FV
*--------------------------------------*/
.fv {
  height: 100vh;
  position: relative;
}
.fv img {
  object-fit: cover;
  height: 100%;
}
.fv .title_wrap {
  position: absolute;
  z-index: 30;
}

@media screen and (max-width: 960px) {
  .fv {
    height: 100svh;
  }
  .fv .title_wrap {
    position: absolute;
    translate: -50% -50%;
    top: 50%;
    left: 50%;
    width: 100%;
    text-align: center;
    color: #fff;
  }
  .fv h1 {
    font-size: 13.8666666667vw;
  }
  .fv h2 {
    font-size: 4.2666666667vw;
  }
}
@media screen and (min-width: 958px) {
  .fv .title_wrap {
    translate: 0 -50%;
    top: 50%;
    width: fit-content;
    text-align: center;
    left: 9.1666666667vw;
  }
  .fv h1 {
    font-size: 4.1666666667vw;
    padding-bottom: 1.25vw;
  }
  .fv h2 {
    font-size: 1.5vw;
  }
}
/*--------------------------------------*
* foundation
*--------------------------------------*/
/*--------------------------------------*
* lead
*--------------------------------------*/
/*--------------------------------------*
* foundation
*--------------------------------------*/
/*--------------------------------------*
* セクション共通
*--------------------------------------*/
section {
  margin-top: 40vw;
}
section .section_title {
  display: flex;
  gap: 5px;
  align-items: flex-end;
  padding-bottom: 1.3333333333vw;
}
section .section_title .look {
  font-size: 5.3333333333vw;
}
section .section_title .sub_title {
  font-size: 3.7333333333vw;
}
section .section_title.rl_title {
  display: block;
  padding: 0 0 0 1.3333333333vw;
}
section .section_title.rl_title p {
  writing-mode: vertical-rl;
}
section .section_title.rl_title .sub_title {
  padding: 1.3333333333vw 0 0 0;
}
section .section_title.one_title {
  display: block;
}
section .section_title.one_title p {
  writing-mode: vertical-rl;
}
section .section_title.one_title .sub_title {
  padding: 2.6666666667vw 0.5333333333vw 0;
}

.flex {
  display: flex;
}

.bg {
  background-color: #7f1e23;
  margin: 100px 0;
}

@media screen and (max-width: 960px) {
  #snap_wrap1,
  #snap_wrap2,
  #snap_wrap3 {
    overflow: hidden;
  }
  section .section_title.one_title {
    width: 5.6022408964vw;
  }
  #sec1 {
    width: 77.3333333333vw;
    margin: 26.6666666667vw auto 0 5.3333333333vw;
  }
  #sec2 .flex {
    flex-direction: row-reverse;
    margin: 0 auto 0 14.6666666667vw;
    width: fit-content;
  }
  #sec2 .fade_slider {
    width: 68vw;
  }
  #sec2 .img2,
  #sec2 .img3 {
    width: 74.6666666667vw;
  }
  #sec2 .img2 {
    margin: 4vw 0 4vw auto;
  }
  #sec2 .img3 {
    margin: 0 auto;
  }
  #sec3 .fade_slider {
    width: 80vw;
  }
  #sec3 .flex {
    justify-content: center;
    gap: 1.3333333333vw;
  }
  #sec4 .section_title {
    padding: 1.3333333333vw 0 0 2.6666666667vw;
    align-items: center;
  }
  #sec4 .grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  #sec4 .grid > div {
    width: 50vw;
  }
  #sec4 .grid > div img {
    object-fit: cover;
    height: 100%;
  }
  #sec5 .section_title {
    padding: 1.3333333333vw 1.3333333333vw 0 0;
    justify-content: right;
    align-items: center;
  }
  #sec5 .img2 {
    width: 69.3333333333vw;
    margin: 8vw 9.3333333333vw 0 auto;
    position: relative;
    box-shadow: 6.6666666667vw -6.6666666667vw #7f1e23;
  }
  #sec6 .img1 {
    width: 49.3333333333vw;
    margin: 0 auto 0 5.3333333333vw;
  }
  #sec6 .img2 {
    width: 66.6666666667vw;
  }
  #sec6 .flex {
    justify-content: right;
    gap: 1.3333333333vw;
    margin: -14.0056022409vw 5.3333333333vw 0 auto;
  }
  #sec7 .section_title {
    color: #fff;
    position: absolute;
    top: 2.6666666667vw;
    right: 2.6666666667vw;
  }
  #sec7 .grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  #sec7 .img1 {
    grid-column: 1/3;
    position: relative;
  }
  #sec8 .section_title {
    padding: 0 0 0 1.3333333333vw;
  }
  #sec8 .img1 {
    width: 88vw;
  }
  #snap_wrap1 .bg {
    position: relative;
    height: 60vw;
  }
  #snap_wrap1 .snap1,
  #snap_wrap1 .snap2,
  #snap_wrap1 .snap3 {
    width: 40vw;
    position: absolute;
  }
  #snap_wrap1 .snap1 {
    rotate: 8deg;
    top: -17.3333333333vw;
    left: 14.6666666667vw;
  }
  #snap_wrap1 .snap2 {
    top: -6.4vw;
    right: 8.5333333333vw;
  }
  #snap_wrap1 .snap3 {
    rotate: -7deg;
    bottom: -21.3333333333vw;
    left: 21.3333333333vw;
  }
  #snap_wrap2 .bg {
    position: relative;
    height: 48vw;
  }
  #snap_wrap2 .snap1,
  #snap_wrap2 .snap2 {
    width: 40vw;
    position: absolute;
  }
  #snap_wrap2 .snap1 {
    top: -14.6666666667vw;
    left: 14.6666666667vw;
    rotate: 5deg;
  }
  #snap_wrap2 .snap2 {
    bottom: -14.6666666667vw;
    right: 14.6666666667vw;
    rotate: -2deg;
  }
  #snap_wrap3 .bg {
    position: relative;
    height: 58.6666666667vw;
  }
  #snap_wrap3 .snap1,
  #snap_wrap3 .snap2,
  #snap_wrap3 .snap3 {
    width: 40vw;
    position: absolute;
  }
  #snap_wrap3 .snap1 {
    top: -22.6666666667vw;
    right: 14.6666666667vw;
    rotate: 7deg;
  }
  #snap_wrap3 .snap2 {
    bottom: 5.3333333333vw;
    left: 8.5333333333vw;
    rotate: -6deg;
  }
  #snap_wrap3 .snap3 {
    rotate: -3deg;
    right: 11.5789473684vw;
    bottom: -14.6666666667vw;
  }
}
@media screen and (min-width: 958px) {
  section {
    margin-top: 8.3333333333vw;
  }
  section .section_title {
    padding-bottom: 0.4166666667vw;
  }
  section .section_title .look {
    font-size: 1.6666666667vw;
  }
  section .section_title .sub_title {
    font-size: 1.1666666667vw;
  }
  section .section_title.rl_title .sub_title, section .section_title.one_title .sub_title {
    padding: 0.8333333333vw 0.1666666667vw 0;
  }
  .bg {
    margin: 16.6666666667vw 0;
  }
  #sec1,
  #sec6 {
    width: 69.1666666667vw;
    margin: 8.3333333333vw auto;
  }
  #sec1 .pc_flex,
  #sec6 .pc_flex {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  #sec2 {
    position: relative;
    margin-bottom: 33.3333333333vw;
  }
  #sec2 .section_title {
    padding: 0;
  }
  #sec2 .flex {
    flex-direction: row-reverse;
    gap: 0.4166666667vw;
    margin: 0 15vw 0 auto;
  }
  #sec2 .img1 {
    width: 30.8333333333vw;
  }
  #sec2 .img2,
  #sec2 .img3 {
    width: 35vw;
    position: absolute;
  }
  #sec2 .img2 {
    top: 10vw;
    left: 15vw;
  }
  #sec2 .img3 {
    top: 35vw;
    left: 9.1666666667vw;
  }
  #sec3 .flex {
    justify-content: center;
    gap: 0.4166666667vw;
  }
  #sec3 .img1 {
    width: 34.5833333333vw;
  }
  #sec4 .section_title {
    width: 69.1666666667vw;
    margin: 0 auto;
    padding-top: 0.4166666667vw;
  }
  #sec4 .fade_slider {
    height: 100%;
  }
  #sec4 .grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: fit-content;
    margin: 0 auto;
  }
  #sec4 .grid > div {
    width: 34.5833333333vw;
  }
  #sec4 .grid > div img {
    object-fit: cover;
    height: 100%;
  }
  #sec5 .img1,
  #sec5 .section_title {
    width: 54.1666666667vw;
    margin: 0 auto 0 7.5vw;
  }
  #sec5 .section_title {
    padding-top: 0.4166666667vw;
  }
  #sec5 .img2 {
    width: 35.8333333333vw;
    box-shadow: 4.1666666667vw -4.1666666667vw #7f1e23;
    margin: -16.6666666667vw 14.1666666667vw 0 auto;
  }
  #sec7 {
    margin: 16.6666666667vw auto;
  }
  #sec7 .grid {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
  }
  #sec7 .img1 .section_title {
    position: absolute;
    color: #fff;
    top: 0.8333333333vw;
    right: 0.8333333333vw;
  }
  #sec7 img {
    object-fit: cover;
    height: 100%;
  }
  #sec8 {
    width: 34.5833333333vw;
    margin: 8.3333333333vw auto;
  }
  #snap_wrap1 {
    position: relative;
  }
  #snap_wrap1 .bg {
    height: 10.8333333333vw;
  }
  #snap_wrap1 .snap1,
  #snap_wrap1 .snap2,
  #snap_wrap1 .snap3 {
    width: 16.6666666667vw;
    position: absolute;
  }
  #snap_wrap1 .snap1 {
    rotate: -5deg;
    left: 23.3333333333vw;
    top: -5.8333333333vw;
  }
  #snap_wrap1 .snap2 {
    rotate: 4deg;
    left: 40vw;
    top: -4.1666666667vw;
  }
  #snap_wrap1 .snap3 {
    rotate: 0deg;
    right: 26.6666666667vw;
    top: -5.8333333333vw;
  }
  #snap_wrap2 {
    position: relative;
  }
  #snap_wrap2 .bg {
    height: 26.6666666667vw;
  }
  #snap_wrap2 .snap1,
  #snap_wrap2 .snap2 {
    width: 16.6666666667vw;
    position: absolute;
  }
  #snap_wrap2 .snap1 {
    rotate: 9deg;
    left: 35vw;
    top: -4.1666666667vw;
  }
  #snap_wrap2 .snap2 {
    rotate: -2deg;
    bottom: -4.1666666667vw;
    right: 35vw;
  }
  #snap_wrap3 {
    position: relative;
  }
  #snap_wrap3 .bg {
    height: 26.6666666667vw;
  }
  #snap_wrap3 .snap1,
  #snap_wrap3 .snap2,
  #snap_wrap3 .snap3 {
    width: 16.6666666667vw;
    position: absolute;
  }
  #snap_wrap3 .snap1 {
    left: 27.5vw;
    top: -2.5vw;
  }
  #snap_wrap3 .snap2 {
    rotate: -8deg;
    top: 3.75vw;
    right: 39.5833333333vw;
  }
  #snap_wrap3 .snap3 {
    rotate: 8deg;
    bottom: -3.5833333333vw;
    right: 25vw;
  }
}
/*--------------------------------------*
* foundation
*--------------------------------------*/
.credit_card {
  position: relative;
  font-size: 13px;
  cursor: pointer;
}
.credit_card .credit {
  position: absolute;
  z-index: 10;
  background: linear-gradient(to top, #000, transparent);
  width: 100%;
  height: 100%;
  inset: 0;
}
.credit_card .plus {
  transition: all 0.4s;
  width: 25px;
  height: 25px;
  position: absolute;
  bottom: 10px;
  right: 10px;
  z-index: 10;
  border: 0.5px solid #fff;
  border-radius: 100vmax;
}
.credit_card .plus:before, .credit_card .plus:after {
  content: "";
  translate: -50% -50%;
  left: 50%;
  top: 50%;
  background-color: #fff;
  position: absolute;
}
.credit_card .plus:before {
  width: 12px;
  height: 0.5px;
}
.credit_card .plus:after {
  width: 0.5px;
  height: 12px;
}
.credit_card.active > .plus {
  rotate: 45deg;
  transition: all 0.4s;
}
.credit_card.open > .plus {
  rotate: 45deg;
  transition: all 0.4s;
}
.credit_card .credit {
  display: flex;
  justify-content: center;
  align-items: flex-end;
}
.credit_card .credit ol {
  margin-bottom: 50px;
  padding: 0 10px;
}
.credit_card .credit li:not(li:last-child) {
  margin-bottom: 7px;
}
.credit_card .credit li a {
  color: #fff;
  line-height: 1.3;
}
.credit_card .credit li a:has(span) {
  color: #797979;
}
.credit_card .credit li span {
  white-space: nowrap;
}/*# sourceMappingURL=style.css.map */