
* {
  margin: 0;
}


.section1{padding-top: 100px;}

/* beforeSection5{padding-top: 100px;} */
.section5{padding-top: 500px;}

footer{padding-top:30vh;}




.pictureText {
  text-align: center;
}
.pictureText2 {
  padding-top:10px;
}

.pictureText span{
  opacity: 0;
  color: #000;
}

.pictureText span.visible {
  opacity: 1;
  transform: translateY(0);
}

.pictureTextWarpper{
  font-family: "Special Elite", serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1.5rem;
  letter-spacing: 0.05rem;
}

img.newyorkpic{padding: 30px 50px 0 50px;}

@media screen and (max-width: 991px) {
  .pictureTextWarpper{
    font-size: 1.2rem;
  }

  img.newyorkpic{padding: 20px 0 0 0 ;}

}


.box-02 {
  width: 100%;
  height: 100vh;
  display: flex;
  justify-content: center;
  align-items: center;
}


.slides-wrapper {
  display: flex;
  /* gap: 30px; */
  /* width: calc(100% - 50px); */
  margin: 0 auto;
  overflow: hidden;
  /* background-color: black; */
  padding: 20px;
}

img.slide-img {
  width: 100%;
}


/* 画像のスタイル */
.look-image {
  position: relative;
  display: block;
  margin: 0 auto;
}

@media screen and (max-width: 991px) {
  .box-02 {
    height: 100vh;
    /* コンテナを少し大きく */
  }

  .slide-img {
    width: 80vw;
    height: 100%;
  }

  /* .look-image{
    width: 80vw;
    height: 70vh;  
  }*/
}




* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}


.image_area img {
  width: 100%;
}

/* 画像のスタイル */
.look-image {
  position: relative;
  display: block;
  margin: 0 auto;

}

@media screen and (max-width: 991px) {
  .look-image {
    margin-bottom: 50px;
  }
}





.look-image img {
  display: block;
}

/* オーバーレイのスタイル */
.overlay_area {
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  /* 	background:-webkit-linear-gradient(280deg, rgba(0, 0, 0, 0) 0%, #000 100%); */
  background-color: rgba(0, 0, 0, 0.8);
  color: white;
  text-align: left;
  box-sizing: border-box;
  font-size: 18px;
  transition: opacity 0.7s ease;
  pointer-events: none;
}

.look-image.show .overlay_area {
  opacity: 1;
  pointer-events: auto;
}

.slide.show .overlay_area {
  opacity: 1;
  pointer-events: auto;
}

.credit {
  font-family: "Helvetica Neue", Arial, Meiryo, "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Noto Sans", sans-serif;
  font-weight: 200;
  height: 100%;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}

.credit ul {
  width: 100%;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  row-gap: 0px;
  padding-bottom: 50px;
}

.credit ul li {
  list-style: none;
  line-height: 1.5rem;
}

.credit ul li a {
  text-decoration: none;
  color: #fff;
  font-size: 1.1rem;
  letter-spacing: 0.1em;
}
.credit ul li {
  text-decoration: none;
  color: #fff;
  padding-left: 20px;
  font-size: 1.1rem;
  letter-spacing: 0.1em;
}
.see_link {
  padding-left: 10px;
  text-decoration: underline;
}
@media screen and (max-width: 991px) {
  .credit ul{
    padding-bottom: 30px;
  }
  .credit ul li a {
    font-size: 13px;
    line-height: 17px;
    }
    .credit ul li {
      font-size: 13px;
      line-height: 17px;
      padding-bottom:10px;
      }
  }

/* ボタンのスタイル */
.look__btn {
  position: absolute;
  bottom: 15px;
  /* より下部に配置 */
  right: 15px;
  /* より右端に配置 */
  content: "";
  display: block;
  width: 30px;
  height: 30px;
  background: none;
  /* 背景をリセット */
  border: none;
  /* 枠線をリセット */
  outline: none;
  /* フォーカス時のアウトラインをリセット */
  padding: 0;
  /* 内側の余白をリセット */
}

.look__btn::before,
.look__btn::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 1px;
  /* 棒の幅（太さ） */
  height: 20px;
  /* 棒の高さ */
  background: #ffffff;
  transition: transform 0.6s ease, background-color 0.6s ease;
}

.look__btn.look_btn_black::before,
.look__btn.look_btn_black::after{
  background: #000000;
}
.look__btn::before {
  transform: translate(-50%, -50%) rotate(90deg);
}

.look__btn::after {
  transform: translate(-50%, -50%) rotate(0deg);
}

.look__btn.open::before {
  transform: translate(-50%, -50%) rotate(90deg);
  );
}

.look__btn.open::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.look__btn.open::before {
  transform: translate(-50%, -50%) rotate(90deg);
  );
}

.look__btn.open::after {
  transform: translate(-50%, -50%) rotate(90deg);
}
.look__btn.look_btn_black.open::before,
.look__btn.look_btn_black.open::after{
  background: #ffffff;
}

.button_area {
  position: relative;
  z-index: 10;
  /* ボタンを最前面に表示 */
}

.overlay_area {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1;
  /* オーバーレイをボタンの背面に表示 */
}



.overlay_area {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9;
}

.credit {
  position: relative;
  z-index: 10;
}


.section1 {}



.p-interview__question {
  text-align: center;
}

.p-interview__question span {
  opacity: 0;
  font-size: 2rem;
  ;
  color: #fff;
}

.p-interview__question span.visible {
  opacity: 1;
  transform: translateY(0);
}

.p-interview__question_topTitle span.visible {
  opacity: 1;
  transform: translateY(0);
}

.blackBackgroundArea{
  height: 80vh;
  background-color: #000;
}
.backgroundBlack {
  opacity: 0;
  position: fixed;
  top: 0;
  left: 0;
width: 100vw;
height: 100vh;
z-index: -1;
overflow: hidden; /* 不要なスクロールを防ぐ */
}
.addBlack {
background-color: #000;
}
.row.blackAddArea.dark-mode {
background-color: #000;
}
.backgroundBlack.addOpacity {
opacity: 0;
}


/* フェードイン(初期値) */
.js-fade {
  opacity: 0; /* 最初は非表示 */
  transition: opacity 0.8s, transform 0.8s; /* 透過率と縦方向の移動を0.8秒 */
}
/* フェードイン(スクロールした後) */
.js-fade.is-inview {
  opacity: 1; /* 表示領域に入ったら表示 */
  /* transition-delay: .1s; /* フェード開始を0.5秒遅らせる */
}

/* フェードイン(初期値) */
.js-fadeLate {
  opacity: 0; /* 最初は非表示 */
  transition: opacity 2s ease, transform 2s ease;
}
/* フェードイン(スクロールした後) */
.js-fadeLate.is-inview {
  opacity: 1; /* 表示領域に入ったら表示 */
  transition-delay: 0.3s;
}

/* フェードイン(初期値) */
.js-fadeBottom {
  opacity: 0; /* 最初は非表示 */
  transform: translateY(50px);
  transition: opacity 2s ease, transform 2s ease;
}
/* フェードイン(スクロールした後) */
.js-fadeBottom.is-inview {
  transform: translateY(0px);
  opacity: 1; /* 表示領域に入ったら表示 */
  transition-timing-function: ease;
  /* transition-delay: .1s; /* フェード開始を0.5秒遅らせる */
}

/* フェードイン(初期値) */
.js-fadeRight {
  opacity: 0; /* 最初は非表示 */
  transform: translateX(-50px);
  transition: opacity 1s ease, transform 1s ease;
}
/* フェードイン(スクロールした後) */
.js-fadeRight.is-inview {
  transform: translateX(0px);
  opacity: 1; /* 表示領域に入ったら表示 */
  /* transition-delay: .1s; /* フェード開始を0.5秒遅らせる */
}
/* フェードイン(初期値) */
.js-fadeRightLate {
  opacity: 0; /* 最初は非表示 */
  transform: translateX(-50px);
  transition: opacity 1.5s ease, transform 1.5s ease;
}
/* フェードイン(スクロールした後) */
.js-fadeRightLate.is-inview {
  transform: translateX(0px);
  opacity: 1; /* 表示領域に入ったら表示 */
  transition-delay: 0.3s;
}

/* フェードイン(初期値) */
.js-fadeLeft {
  opacity: 0; /* 最初は非表示 */
  transform: translateX(50px);
  transition: opacity 1s ease, transform 1s ease;
}
/* フェードイン(スクロールした後) */
.js-fadeLeft.is-inview {
  transform: translateX(0px);
  opacity: 1; /* 表示領域に入ったら表示 */
  /* transition-delay: .1s; /* フェード開始を0.5秒遅らせる */
}
/* フェードイン(初期値) */
.js-fadeLeftLate {
  opacity: 0; /* 最初は非表示 */
  transform: translateX(50px);
  transition: opacity 1s ease, transform 1s ease;
}
/* フェードイン(スクロールした後) */
.js-fadeLeftLate.is-inview {
  transform: translateX(0px);
  opacity: 1; /* 表示領域に入ったら表示 */
  transition-delay: 0.3s;
}

.fadeHorizontal {
  overflow-x: hidden;
}



h3.sidescroll{
  font-size: 1.3rem;
  font-family: serif;
  text-align: center;
  margin-top: 2vh;
}
h2.sidescroll{
  font-size: 2rem;
  text-align: center;
  font-family:Georgia, serif; font-style: italic; 
  margin: 0;
  padding-bottom: 5vh;
}

p.youtubeText{
  font-weight: bold;
  font-size: 1.1rem;
  font-family: sans-serif;
  text-align: center;
  padding-top: 20vh;
  padding-bottom: 20px;
}



@media screen and (max-width: 991px) {
  h3.sidescroll{
    margin-top: 5vh;
  }
  p.youtubeText{
  padding-top: 15vh;
}

}





.line {
  display: block;
  position: relative;
}

.line::after {
  background: #000;
  content: '';
  display: block;
  height: 1px;
  width: 0;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  transition: width 1s;
}

.line.inview::after {
  width: 100%;
}

.p10-vertical {
	padding: 10vh 0;
}
.p10-side {
	padding: 10vh 0;
}
.p5_vertical-p10_side {
	padding: 5vh 10vh;
}
.p10-bottom {
	padding-bottom: 10vh;
}

.staffCredit{
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
text-align: center;
}

.staffCreditTitle{
  font-weight: bold;
  font-size: 1.3rem;
  padding-top: 10vh;
  padding-bottom: 20px;
  letter-spacing: 0.1rem;
}

.staffCreditText{
  font-size: 1.2rem;
  letter-spacing: 0.01rem;
  padding-bottom:5px;
}


.footer__logo {
  text-align: center;
  padding-top: 100px;
}
.footer__logo img {
  width: 180px;
  margin: 0 auto;
  padding-bottom: 30px;
}
.l-footer__sns {
  margin-bottom: 65px;
  margin-left: 10px;
  display: flex;
  justify-content: center;
  }
.l-footer__sns li {
  padding:15px;
}
ul.l-footer__sns li img{width: 25px;}
ol, ul {
  list-style-type: none;
}

.section4 {
overflow: hidden;
}
.section5 {
  width: 100%;
}
/* slide */
/* アクティブなスライドのスタイル */
.splide__slide .look-image {
  /* opacity: 0.5;  */
}

/* スライド共通のスタイル */
.splide__slide .look-image {
  /* transform: scale(.8); 左右のスライドを小さくする */
  transition: .7s; /* ゆっくり小さくさせる */
}
/* アクティブなスライドのスタイル */
.splide__slide.is-active .look-image {
  opacity: 1; /* 中央のスライドは薄くしない */
  /* transform: scale(1); 中央のスライドは小さくしない */
  z-index: 1; /* 中央のスライドを一番上にする */
}


.splide__slide{
  margin:0 10px;
}


.col-lg-10-right, .col-lg-11-right {
    max-width: 100%;
    box-sizing: border-box;
}
.row {
    overflow-x: hidden;
}

@media screen and (max-width: 991px) {
  .splide__slide{
    margin:0 5px;
  }
  .splide__arrow{
    width: 3em;
  }
  .splide__arrow--prev{left:0;}  
  .splide__arrow--next{right:0;}  
}

/* スライドのサイズ調整 */
.splide__slide img {
  height: auto;
  width: 100%;
}
/* レイアウトの為のスタイル */
.wrapper {
  margin-inline: auto;
  margin-top: 10px;
  max-width: 600px;
  width: 100%;
}

.blackArea{
  overflow: hidden;
}
/* lookimage調整 */
.look2{
  margin-bottom: 200px;
}
.lookimage4{
  margin-bottom: 50px;
}

.lookimage5{
  padding: 0;
}

.lookimage9{
  padding: 10vh;
}


.lookimage6{
  padding: 50px;
  padding-top: 300px;
}

.lookimage7{
  margin-bottom: 200px;
}

.lookimage8{
  padding: 20px;
}
    .lookimage09{
    padding:20px;
  }
.look-image{
  margin-bottom: 50px;
}
.pc-6 {
	width: 100%;
}
.pc-7 {
	width: 100%;
	margin-top: 10vh;
}
.pt10 {
	padding-top: 10vh;
}


.col-lg-6-right {
	float: right;
}
.col-lg-6-right .lookimage6 {
	padding-top: 2vh;
}
.look-image.lookimage7 .image_area img {
    height: auto;
    object-fit: cover;
    object-position: 0% 15%;
}
.js-fadeBottom.lookimage6.is-inview .look.look-image .image_area img.margin100 {
    height: 370px;
    object-fit: cover;
    object-position: 0% 15%;
}
.col-xs-5.full-left {
    width: 50%;
    padding: 10vh 5vh 10vh 10vh;
}
.col-xs-5.full-right {
    width: 50%;
    padding: 10vh 10vh 10vh 5vh;
}
.col-xs-5.full .lookimage8, .col-xs-5.full .lookimage09 {
    padding: 0;
}
.col-lg-10-right {
	width: 80%;
}

.lookimage16{
  padding: 100px;
}
.lookimage17{
  margin-bottom: 200px;
}
.lookimage18{
  /* padding: 0 2vw; */
  transform: translate(0px, 0px) !important;
  z-index: -3;
}
.lookimage10{
  padding: 10vh;
}
.lookimage16{
  padding: 10vh;
}
.col-lg-11 .lookimage6 {
	padding: 0;
	padding-top: 30vh;
}
.lookimage17 {
	padding-right: 30vh;
}
.lookimage20 {
	padding-top: 0;
}
.lookimage22 {
	padding: 0 20vh;
}
.mt-20vh {
	margin-top: -20vh;
}

.col-xs-5.full-left.num-14 {
    width: 66.66666%;
	padding: 10vh 7vh 10vh 10vh;
}
.col-xs-5.full-right.num-15 {
    width: 33.33333%;
	margin-top: 20px;
}


@media screen and (min-width: 1200px) {
    .col-lg-10 {
        width: 45%;
    }
	.col-lg-11 {
        width: 55%;
    }
}

@media screen and (min-width: 991px) {
.look__btn::before, .look__btn::after {
    width: 2px;
}
}


.lookimage18-cover {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: white;
  opacity: 0;
  transition: opacity 0.5s ease;
  z-index: -2;
}



.lookimage19{
      margin-left: -100px;
      padding-right: 100px;
}
.lookimage20{
      margin-right: -100px;
      padding-left: 100px;
}


img.lookimage10{
  margin-left:10vw;
  position: relative;
  z-index: 11;
}


img.lookimage15_sp{
  margin-left:10vw;
  position: relative;
  z-index: 11;
}




@media screen and (max-width: 991px) {
  .lookimage5{
    padding: 0px;
  }
  .lookimage6{
    padding: 0px;
    margin-bottom: 0px;
  }
.lookimage8{
  padding: 0px;
}
    .lookimage09{
    padding:0px;
  }
  img.lookimage10{
    margin-left:4vw;
  }
  img.lookimage15_sp{
    margin-left:4vw;
  }
  .lookimage16{
    padding: 0px;
  }
  
.lookimage19{
      margin-left: 0px;
      padding-right:0px;
      padding-top: 50px;
}
.lookimage20{
      margin-right: 0px;
      padding-left: 0px;
}

  .section5{
    padding-top: 100px;
  }
  .look-image{
    margin-bottom: 50px;
  }
	.look-image.lookimage7.num-5 .image_area img {
    height: 400px;
    object-fit: cover;
    object-position: 30% 15%;
}
	.look-image.lookimage7.num-10 .image_area img {
    height: 400px;
    object-fit: cover;
    object-position: 35% 15%;
}
	.look-image.num-14 .image_area img {
    height: 370px;
    object-fit: cover;
    object-position: 35% 15%;
}
	.col-xs-10.num-14 {
		width: 88%;
	}
	.look-image.lookimage7.num-15 .image_area img {
    height: 370px;
    object-fit: cover;
    object-position: 0% 15%;
}
	.look-image.lookimage7.num-21 .image_area img {
    height: 280px;
    object-fit: cover;
    object-position: 5% 15%;
}
	.js-fadeBottom.lookimage6.is-inview.num-22 .look.look-image .image_area img.margin100 {
    height: 300px;
    object-fit: cover;
    object-position: 0% 15%;
}
	.look-image.lookimage7.num-15 {
    width: 92%;
}
	.num-2 {
		width: 80%;
	}
	
.look-image.lookimage12.num-9 {
    width: 90%;
}
	.look-image.lookimage12.num-9 .image_area img {
    width: 100%;
    height: 400px;
    object-fit: cover;
	object-position: 0% 15%;
}
}


.splide__arrow {
  background: none !important;
  border: none !important;
}
.splide__arrow{
  width: 5em;
}

.look2 {
    margin-bottom: 130px;
    padding: 0 1vh;
}
.col-lg-10-right {
    width: 80%;
}
.col-lg-11-right {
	width: 100%;
}
.col-lg-21-right {
	width: 85%;
}
.col-lg-16-right {
	width: 75%;
}
section.section3 {
    padding-top: 5vh;
}
.pd10 {
	padding: 10px;
}

section.loadingSection {
  width: 100%;
  height: 100vh;
  height: 100dvh; /* 新しいビューポート単位 */
  min-height: -webkit-fill-available; /* iOS Safari対応 */
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #000;
}

/* iOS Safari用のフォールバック */
@supports (-webkit-touch-callout: none) {
  section.loadingSection {
    height: -webkit-fill-available;
  }
}



/* footer */

.l-footer__nav {
  text-align: center;
  font-size: 1.1rem;
  letter-spacing: 0.05rem;
  display: flex;
  justify-content: center;
  padding-bottom:5vh;
}

.l-footer__nav li a {
  color: var(--primary);
}
.l-footer__nav li:not(:last-child) {
    margin-right: 30px;
}

.l-footer__nav li a {
  color:#000;
  font-weight: bold;
}

@media screen and (max-width: 991px) {
.l-footer__nav li {
  margin: 10px;
    justify-content: center;

}
footer {
    padding-top: 15vh;
}
}

/* splide */
.splide__arrow{top:38%;}
.splide__pagination__page.is-active {
    background: #000;
}
.splide__pagination__page{
      bottom: 150px;
}
@media screen and (max-width: 991px) {
.splide__pagination__page{bottom: 0px;}
.splide__arrow{top:43%;}
}
#pagetop {
  /* レイアウト */
  position: fixed;
  right: 10px;
  bottom: 10px;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: center;
  /* 見た目 */
  width: 60px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  cursor: pointer;
  color: #fff;
  transition: 0.3s;

  /* デフォルトは非表示 */
  opacity: 0;
  visibility: hidden;
  transition: 0.2s;
}

/* 矢印 */
.pagetop-arrow {
  height: 15px;
  width: 15px;
  border-top: 1px solid #000000;
  border-right: 1px solid #000000;
  transform: translateY(20%) rotate(-45deg);
}

/* スクロールされたときに適用されるCSS */
#pagetop.visible {
  opacity: 1;
  visibility: visible;
}



/* youtubevideo */
.js-fadeupvideo {
  position: relative;
  overflow: hidden;
}

.js-fadeupvideo::after {
  content: "";
  width: 100%;
  height: 102%;
  background-color: #fff; /* $color-white を直接 #fff に置き換え */
  position: absolute;
  top: 0;
  left: 0;
  transition: transform 1s cubic-bezier(0, 0.5, 0.355, 1) 0.5s;
  transform: translate3d(0, 0%, 0);
}

.js-fadeupvideo.js-after::after {
  transform: translate3d(0, -102%, 0);
}

.js-fadeupvideo.js-after img {
  opacity: 1;
  transform: scale(1);
}

.js-fadeupvideo img {
  width: 100%;
  height: auto;
  display: block;
  opacity: 0;
  transform: scale(1);
  transition: transform 2s cubic-bezier(0, 0.3, 0.355, 1) 1s, 
              opacity .5s cubic-bezier(0, 0.2, 0, 1) 0.8s;
}


/* all style items */

      /* animation */
      .button-border4 {
        text-align: center;
        border: 1px solid #ffffff;
        padding: 20px 40px;
        position: relative;
        display: inline-block;
        color: #000000;
        text-decoration: none;
        background-color: #ffffff;
        font-family: "Noto Serif JP", serif;
        font-size: 1.5rem;
        line-height: 3rem;
        margin: 100px;
        width: 300px;
      }

      @media screen and (max-width: 991px) {
      .button-border4 {
        margin:100px 0;
      }

      }

      .button-border4::after,
      .button-border4::before,
      .button-border4 span::after,
      .button-border4 span::before {
        background-color: #000000;
        content: '';
        display: block;
        position: absolute;
        z-index: 10;
        transition: all 1s ease;
      }

      .button-border4::after {
        width: 0px;
        height: 1px;
        top: -1px;
        left: -1px;
      }

      .button-border4::before {
        width: 0px;
        height: 1px;
        right: -1px;
        bottom: -1px;
      }

      .button-border4 span::after {
        width: 1px;
        height: 0px;
        left: -1px;
        bottom: -1px;
      }

      .button-border4 span::before {
        width: 1px;
        height: 0px;
        top: -1px;
        right: -1px;
      }

      .button-border4.is-inview::after,
      .button-border4.is-inview::before {
        width: calc(100% + 1px);
      }

      .button-border4.is-inview span::after,
      .button-border4.is-inview span::before {
        height: calc(100% + 1px);
      }

      @keyframes fadeIn {
        from {
          opacity: 0;
          transform: translateY(20px);
        }

        to {
          opacity: 1;
          transform: translateY(0);
        }
      }
      
.button-border4:hover {
  background-color: #000;
  color: #fff;
}

.button-border4:hover .carticon img {
  filter: brightness(0) invert(1);
}