@charset "UTF-8";
/*--------------------------------------*
* 基本設定
*--------------------------------------*/
/*--------------------------------------*
* ベースカラー
*--------------------------------------*/
/*--------------------------------------*
* フォント
*--------------------------------------*/
/*--------------------------------------*
* ブレイクポイント
*--------------------------------------*/
/*--------------------------------------*
* vw変換(SP用)
*--------------------------------------*/
/*--------------------------------------*
* vw変換(PC用)
*--------------------------------------*/
/*--------------------------------------*
* デフォルトスタイル
*--------------------------------------*/
html,
body {
  width: 100%;
  font-size: 16px;
  margin: 0 auto;
  font-family: "futura-pt", sans-serif; /* M:500 */
  background-color: #fff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

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: #000;
}
@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;
}

/*-------------------
* コンテンツのスタイル
-------------------*/
/*--------------------------------------*
* 基本設定
*--------------------------------------*/
/*--------------------------------------*
* FV
*--------------------------------------*/
/*--------------------------------------*
* 基本設定
*--------------------------------------*/
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes fadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
.opacity {
  opacity: 0;
}

@keyframes maskLeft {
  0% {
    mask-position: left;
    -webkit-mask-position: left;
  }
  100% {
    mask-position: right;
    -webkit-mask-position: right;
  }
}
@keyframes maskRight {
  0% {
    mask-position: right;
    -webkit-mask-position: right;
  }
  100% {
    mask-position: left;
    -webkit-mask-position: left;
  }
}
.mask_left {
  clip-path: polygon(0 0, 0 0, 0 100%, 0% 100%);
}

.mask_right {
  clip-path: polygon(100% 0, 100% 0, 100% 100%, 100% 100%);
}

.mask_full {
  clip-path: polygon(100% 0, 0 0, 0 100%, 100% 100%);
}

@keyframes zoomIn {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.2);
  }
}
@keyframes zoomOut {
  0% {
    transform: scale(1.2);
  }
  100% {
    transform: scale(1);
  }
}
figure.zoom {
  overflow: hidden;
}

/*--------------------------------------*
* セクション共通
*--------------------------------------*/
img {
  width: 100%;
  height: auto;
}

main {
  overflow: clip;
}

.main__wrapper {
  opacity: 0;
  transition: opacity 0.5s ease-in-out;
}
.main__wrapper.on {
  opacity: 1;
}

.fv {
  position: relative;
}
.fv figure {
  width: 100%;
}
@media screen and (max-width: 768px) {
  .fv figure {
    aspect-ratio: 750/1334;
  }
}
@media screen and (min-width: 769px) {
  .fv figure {
    aspect-ratio: 1440/800;
  }
}
.fv img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 768px) {
  .fv__title {
    position: absolute;
    width: 92vw;
    top: 4vw;
    left: 50%;
    transform: translateX(-50%);
  }
}
.fv__title .fv__title__logo {
  opacity: 0;
  transition: opacity 0.5s 1s ease-in-out;
}
.fv__title.on .fv__title__logo {
  opacity: 1;
}
.fv__title-sub {
  font-family: "athena", sans-serif; /* R:400 */
  color: #fff;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 768px) {
  .fv__title-sub {
    position: absolute;
    font-size: 5.3333333333vw;
    right: 4vw;
    bottom: 4vw;
  }
}
@media screen and (min-width: 769px) {
  .fv__title-sub {
    font-size: 2.0833333333vw;
    text-align: center;
    margin-top: 3.4722222222vw;
  }
}
.fv__title-sub .fv__title-sub__text {
  opacity: 0;
  transition: opacity 0.5s 1s ease-in-out;
}
.fv__title-sub.on .fv__title-sub__text {
  opacity: 1;
}
@media screen and (min-width: 769px) {
  .fv__title__pc .fv__title {
    position: absolute;
    left: 2%;
    bottom: 94%;
    transform: rotate(90deg) translateX(-3%);
    width: 51.3888888889vw;
    transform-origin: bottom left;
  }
  .fv__title__pc .fv__title-sub {
    position: absolute;
    right: 2%;
    bottom: 3%;
    font-size: 1.6666666667vw;
  }
}

.credit {
  text-align: center;
}
@media screen and (max-width: 768px) {
  .credit {
    margin-top: 4vw;
  }
}
@media screen and (min-width: 769px) {
  .credit {
    margin-top: 1.3888888889vw;
  }
}
.credit__inner {
  width: 100%;
  height: 100%;
  position: relative;
}
.credit__list__item a {
  display: block;
  color: #000;
  font-family: "futura-pt", sans-serif; /* M:500 */
  line-height: 1.6363636364;
  letter-spacing: 0.05em;
  text-wrap: nowrap;
}
@media screen and (max-width: 768px) {
  .credit__list__item a {
    font-size: 2.9333333333vw;
  }
}
@media screen and (min-width: 769px) {
  .credit__list__item a {
    font-size: 0.8333333333vw;
  }
}

/* sec共通 -------------------------------------------- */
@media screen and (max-width: 768px) {
  .sec {
    margin-bottom: 26.6666666667vw;
  }
}

/* sec1 -------------------------------------------- */
.sec__1 {
  position: relative;
}
@media screen and (max-width: 768px) {
  .sec__1 {
    padding-top: 20vw;
    margin-bottom: 20.6666666667vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__1 {
    display: flex;
    gap: 13.8888888889vw;
    width: 76.3888888889vw;
    padding-top: 20.8333333333vw;
    margin: 0 auto 19.7916666667vw 13.8888888889vw;
  }
}
@media screen and (max-width: 768px) {
  .sec__1 .img-1__wrapper {
    position: relative;
    z-index: 10;
  }
}
@media screen and (max-width: 768px) {
  .sec__1 .img-1__wrapper .img-1 {
    width: 80vw;
    margin-left: 0;
    margin-bottom: 4vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__1 .img-1__wrapper .img-1 {
    width: 25vw;
    margin-top: 8.3333333333vw;
  }
}
.sec__1 .img-2__wrapper {
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 769px) {
  .sec__1 .img-2__wrapper {
    width: 37.5vw;
  }
}
.sec__1 .img-2__wrapper .img-2 {
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .sec__1 .img-2__wrapper .img-2 {
    width: 80vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__1 .img-2__wrapper .img-2 {
    width: 37.5vw;
  }
}
.sec__1 .img-2__wrapper .img-2 img {
  position: relative;
  z-index: 1;
}
.sec__1 .img-2__wrapper .img-bg {
  position: absolute;
}
@media screen and (max-width: 768px) {
  .sec__1 .img-2__wrapper .img-bg {
    top: -97.3333333333vw;
    right: 0;
    width: 80vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__1 .img-2__wrapper .img-bg {
    top: 4.8611111111vw;
    right: -4.8611111111vw;
    width: 33.3333333333vw;
  }
}
.sec__1 .credit {
  text-align: left;
}
@media screen and (max-width: 768px) {
  .sec__1 .credit {
    margin-left: 10vw;
  }
}

/* sec2,5 -------------------------------------------- */
@media screen and (min-width: 769px) {
  .sec__2,
  .sec__5 {
    width: 37.5vw;
    margin: 0 auto 12.8472222222vw;
  }
}
.sec__2 .sec__img__area,
.sec__5 .sec__img__area {
  position: relative;
}
@media screen and (max-width: 768px) {
  .sec__2 .sec__img__area,
  .sec__5 .sec__img__area {
    width: 80vw;
    margin: 0 auto;
  }
}
.sec__2 .sec__img__area .sticky_wrapper,
.sec__5 .sec__img__area .sticky_wrapper {
  position: relative;
}
.sec__2 .sec__img__area__list,
.sec__5 .sec__img__area__list {
  position: relative;
  margin: 0;
  padding: 0;
  overflow: clip;
}
@media screen and (max-width: 768px) {
  .sec__2 .sec__img__area__list,
  .sec__5 .sec__img__area__list {
    top: 33.3333333333vw;
    height: 106.6666666667vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__2 .sec__img__area__list,
  .sec__5 .sec__img__area__list {
    height: 50vw;
  }
}
.sec__2 .sec__img__area__list__item,
.sec__5 .sec__img__area__list__item {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.sec__2 .sec__img__area__list__item__1,
.sec__5 .sec__img__area__list__item__1 {
  z-index: 1;
}
.sec__2 .sec__img__area__list__item__2,
.sec__5 .sec__img__area__list__item__2 {
  z-index: 2;
}
.sec__2 .sec__img__area__list__item__3,
.sec__5 .sec__img__area__list__item__3 {
  z-index: 3;
}
@media screen and (max-width: 768px) {
  .sec__2 .sec__img__area__list__img,
  .sec__5 .sec__img__area__list__img {
    height: 106.6666666667vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__2 .sec__img__area__list__img,
  .sec__5 .sec__img__area__list__img {
    height: 50vw;
  }
}
.sec__2 .sec__img__area__list__img img,
.sec__5 .sec__img__area__list__img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.sec__2 .credit,
.sec__5 .credit {
  opacity: 0;
  transition: opacity 0.5s ease-in-out;
}
.sec__2 .credit.on,
.sec__5 .credit.on {
  opacity: 1;
}

/* sec3 -------------------------------------------- */
@media screen and (min-width: 769px) {
  .sec__3 {
    margin-bottom: 12.8472222222vw;
  }
}
.sec__3 .sec__img__area {
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 768px) {
  .sec__3 .sec__img__area {
    gap: 1.3333333333vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__3 .sec__img__area {
    gap: 0.6944444444vw;
  }
}
@media screen and (max-width: 768px) {
  .sec__3 .sec__img__area__item {
    width: 46.6666666667vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__3 .sec__img__area__item {
    width: 22.9166666667vw;
  }
}

/* sec4 -------------------------------------------- */
@media screen and (min-width: 769px) {
  .sec__4 {
    margin-bottom: 16.3194444444vw;
  }
}

/* sec6 -------------------------------------------- */
@media screen and (min-width: 769px) {
  .sec__6 {
    margin-bottom: 12.8472222222vw;
  }
  .sec__6 .pc-swiper {
    display: grid;
    margin-left: 9.7222222222vw;
    width: 78.4722222222vw;
    grid-template-columns: 37.5vw 21.8055555556vw;
    gap: 11.8055555556vw;
  }
  .sec__6 .pc-swiper .img-2 {
    margin-top: 14.0972222222vw;
  }
  .sec__6 .credit {
    text-align: left;
  }
}

/* sec7 -------------------------------------------- */
.sec__7 {
  background-color: #fff8ea;
}
@media screen and (max-width: 768px) {
  .sec__7 {
    padding-top: 13.3333333333vw;
    padding-bottom: 8.6666666667vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__7 {
    padding-top: 13.8888888889vw;
    padding-bottom: 10.0694444444vw;
    margin-bottom: 22.2222222222vw;
  }
}
.sec__7 .move-img__list {
  display: grid;
  justify-content: center;
  margin: 0 auto;
  grid-template-columns: repeat(2, 1fr);
  overflow: clip;
}
@media screen and (max-width: 768px) {
  .sec__7 .move-img__list {
    gap: 1.3333333333vw;
    width: 94.6666666667vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__7 .move-img__list {
    gap: 1.3888888889vw;
    width: 38.0555555556vw;
  }
}
.sec__7 .move-img__list__item {
  overflow: clip;
}
@media screen and (max-width: 768px) {
  .sec__7 .move-img__list__item {
    width: 46.6666666667vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__7 .move-img__list__item {
    width: 18.2638888889vw;
  }
}

/* sec8 -------------------------------------------- */
@media screen and (min-width: 769px) {
  .sec__8 {
    margin-bottom: 11.4583333333vw;
  }
}
.sec__8 .sec__img__area {
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .sec__8 .sec__img__area {
    width: 64vw;
    display: grid;
    gap: 1.3333333333vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__8 .sec__img__area {
    display: flex;
    width: 63.8888888889vw;
    gap: 0.6944444444vw;
  }
}

/* sec9 -------------------------------------------- */
@media screen and (min-width: 769px) {
  .sec__9 {
    margin-bottom: 22.2222222222vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__9 .sec__img__area {
    width: 72.3611111111vw;
    margin: 0 auto;
    position: relative;
  }
}
.sec__9 .sec__img__area .img-1 {
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .sec__9 .sec__img__area .img-1 {
    width: 80vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__9 .sec__img__area .img-1 {
    width: 31.25vw;
  }
}
@media screen and (max-width: 768px) {
  .sec__9 .sec__img__area .img-2 {
    margin-top: -6.6666666667vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__9 .sec__img__area .img-2 {
    width: 34.1666666667vw;
    position: absolute;
    top: 18.4722222222vw;
    right: 0;
  }
}
@media screen and (max-width: 768px) {
  .sec__9 .sec__img__area .img-3 {
    width: 80vw;
    margin-top: -8vw;
    margin-left: auto;
  }
}
@media screen and (min-width: 769px) {
  .sec__9 .sec__img__area .img-3 {
    margin-top: 6.9444444444vw;
    margin-left: 6.9444444444vw;
    text-align: left;
    display: flex;
    align-items: end;
    gap: 1.3888888889vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__9 .sec__img__area .img-3 img {
    width: 33.3333333333vw;
  }
}
.sec__9 .sec__img__area .img-3 .credit {
  text-align: left;
}

/* sec10 -------------------------------------------- */
.sec__10 {
  position: relative;
}
@media screen and (max-width: 768px) {
  .sec__10 {
    padding-top: 20vw;
    margin-bottom: 20.6666666667vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__10 {
    display: flex;
    flex-direction: row-reverse;
    gap: 13.8888888889vw;
    width: 72.2222222222vw;
    margin-left: 9.7222222222vw;
    margin-bottom: 22.2222222222vw;
  }
}
.sec__10 .img-1 {
  position: relative;
  z-index: 10;
}
@media screen and (max-width: 768px) {
  .sec__10 .img-1 {
    width: 80vw;
    margin-bottom: 4vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__10 .img-1 {
    width: 20.8333333333vw;
    margin-top: 11.1111111111vw;
  }
}
.sec__10 .img-2__wrapper {
  position: relative;
  z-index: 2;
}
.sec__10 .img-2__wrapper .img-2 {
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 768px) {
  .sec__10 .img-2__wrapper .img-2 {
    width: 80vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__10 .img-2__wrapper .img-2 {
    width: 37.5vw;
  }
}
@media screen and (max-width: 768px) {
  .sec__10 .img-2__wrapper .img-2 .credit {
    text-align: right;
  }
}
.sec__10 .img-2__wrapper .img-bg {
  position: absolute;
}
@media screen and (max-width: 768px) {
  .sec__10 .img-2__wrapper .img-bg {
    top: -97.3333333333vw;
    right: 0;
    width: 80vw;
  }
}
@media screen and (min-width: 769px) {
  .sec__10 .img-2__wrapper .img-bg {
    top: -4.8611111111vw;
    left: -4.8611111111vw;
    width: 33.3333333333vw;
  }
}

/* sec11 -------------------------------------------- */
@media screen and (max-width: 768px) {
  .sec__11 .sp-img {
    width: 90vw;
    margin: 0 auto;
  }
}
@media screen and (min-width: 769px) {
  .sec__11 {
    margin-bottom: 27.7777777778vw;
  }
  .sec__11 .pc-img {
    display: grid;
    grid-template-columns: 22.9166666667vw 22.9166666667vw;
    gap: 0.6944444444vw;
    justify-content: center;
  }
  .sec__11 .pc-img .credit {
    grid-column: 1/4;
  }
}

.footer {
  width: 100%;
  position: relative;
}
@media screen and (max-width: 768px) {
  .footer {
    height: 100vh;
  }
}
@media screen and (min-width: 769px) {
  .footer-img {
    width: 20.8333333333vw;
    margin: 0 auto;
    padding-bottom: 23.1944444444vw;
  }
}
@media screen and (max-width: 768px) {
  .footer-img img {
    height: 100vh;
  }
}
.footer__inner {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 768px) {
  .footer__inner {
    bottom: 20vw;
  }
}
@media screen and (min-width: 769px) {
  .footer__inner {
    bottom: 6.9444444444vw;
  }
}
@media screen and (max-width: 768px) {
  .footer__logo {
    width: 32vw;
    margin: 0 auto 12vw;
  }
}
@media screen and (min-width: 769px) {
  .footer__logo {
    width: 7.2222222222vw;
    margin: 0 auto 2.5vw;
  }
}
.footer__icon {
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  .footer__icon {
    width: 6.9333333333vw;
  }
}
@media screen and (min-width: 769px) {
  .footer__icon {
    width: 2.1527777778vw;
  }
}

.js-clip {
  transition: all 1s ease;
}
.js-clip.clip-l {
  clip-path: inset(0 100% 0 0);
}
.js-clip.clip-r {
  clip-path: inset(0 0 0 100%);
}
.js-clip.on {
  clip-path: inset(0 0 0 0);
}

@media screen and (max-width: 768px) {
  .js-left,
  .js-down {
    opacity: 0;
  }
}

@media screen and (min-width: 769px) {
  .js-fade-pc {
    opacity: 0;
  }
}/*# sourceMappingURL=style.css.map */