
/*　home 共通
------------------------------------------------------------------------------------------------*/

.fv{
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: calc(100vh - 8rem);
  color: #fff;
  position: relative;
}
.fv::before{
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(to bottom,transparent,rgba(0, 0, 0, 0.6));
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
}
.fv-swiper{
  position: absolute;
  left: 0;
  top: 0;
  z-index: 0;
}
.fv-swiper,
.fv-swiper .swiper-wrapper,
.fv-swiper .swiper-slide,
.fv-swiper .swiper-slide img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.fv-swiper .swiper-slide-active img,
.fv-swiper .swiper-slide-duplicate-active img,
.fv-swiper .swiper-slide-prev img{
  animation: zoomUp 10s linear 0s 1 normal both;  
}
@keyframes zoomUp {
  0% {
    transform: scale(1);
  }
  100% {
    transform: scale(1.15);
  }
}
.fv h1,
.fv p{
  text-align: center;
  letter-spacing: 0.5em;
}
.fv h1{
  font-size: 4.8rem;
}
.fv p{
  font-weight: 600;
  margin-top: 4rem;
}

.scroll{
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 1px;
  height: 10rem;
  background: rgba(255,255,255,0.3);
  z-index: 2;
}
.scroll:before{
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 1px;
  height: 10rem;
  background: #fff;
  animation: sdl01 2s cubic-bezier(1, 0, 0, 1) infinite;
}
@keyframes sdl01 {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  50.1% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}


.home-video{
  width: 100rem;
  max-width: 100%;
  margin: 10rem auto 0;
  position: relative;
}
.home-video #video{
  display: block;
  width: 100%;
}
.home-video #play{
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  cursor: pointer;
}
.home-video #play img{
  width: 8rem;
  transition: transform 0.4s;
}
.home-video #play:hover img{
  transform: scale(1.1);
}
.home-video .hidden{ display: none; }


.home-intro{
  text-align: center;
  position: relative;
  margin-top: 16rem;
}
.home-intro::before{
  content: "";
  display: block;
  width: 1px;
  height: 16.8rem;
  background: #000;
  margin: 0 auto 5rem;
}
.home-intro::after{
  content: "";
  display: block;
  width: 31.4rem;
  aspect-ratio: 100 / 106;
  background: url(../images/home/bg-img1.png) center center no-repeat;
  background-size: contain;
  position: absolute;
  left: 0;
  top: -1rem;
  z-index: 0;
}
.home-intro h2{
  font-size: 4rem;
  font-weight: 500;
}
.home-intro p{
  font-size: 1.8rem;
  line-height: 2;
  margin-top: 2.6rem;
}
.home-intro .img-wrap{
  margin-top: 4rem;
  display: grid;
  grid-template-columns: 1fr 38%;
  grid-template-rows: repeat(2, 1fr);
  gap: 0.8rem;
}
.home-intro .img-wrap picture.img1 { grid-area: 1 / 1 / 3 / 2; }
.home-intro .img-wrap picture.img2 { grid-area: 1 / 2 / 2 / 3; }
.home-intro .img-wrap picture.img3 { grid-area: 2 / 2 / 3 / 3; }
.home-intro .img-wrap picture img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}


.bumpy-sec{
  margin-top: 20rem;
  padding-bottom: 5rem;
  position: relative;
}
.bumpy-sec .img{
  width: calc(50% + 20.6rem);
  aspect-ratio: 100 / 55.2;
  max-height: 52.8rem;
  object-fit: cover;
  position: relative;
  z-index: 1;
}
.bumpy-sec.ri .img{
  margin-left: auto;
}
.bumpy-sec .box{
  width: 50%;
  height: 35rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: #fff;
  box-shadow: 2rem 1rem 2rem rgba(0, 0, 0, 0.1);
  position: absolute;
  bottom: -5rem;
}
.bumpy-sec.ri .box{
  left: 5rem;
}
.bumpy-sec.le .box{
  right: 5rem;
}
.bumpy-sec .box h2{
  font-size: 3.2rem;
  font-weight: 500;
}
.bumpy-sec .box .h2-en{
  margin-top: 0.5em;
}


.home-architecture::before{
  content: "";
  display: block;
  width: 26.2rem;
  aspect-ratio: 100 / 249;
  background: url(../images/home/bg-img2.png) center center no-repeat;
  background-size: contain;
  position: absolute;
  right: 0;
  bottom: 10.4rem;
  z-index: 0;
}


.bg-3{
  width: calc(50% + 30rem);
  margin-top: 8rem;
}


.home-outro{
  margin-top: -3.6vw;
}
.home-outro::before{
  content: "";
  display: block;
  width: 1px;
  height: 20rem;
  background: #000;
  margin: 0 auto 5rem;
}
.home-outro h2{
  font-size: 3.2rem;
  font-weight: 500;
  line-height: 1.75;
  text-align: center;
}
.home-outro .obi{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  margin-top: 4rem;
}
.home-outro .obi picture img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}


.home-bnr{
  margin-top: 10rem;
}
.home-bnr .content{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3.2rem;
}
.home-bnr a{
  display: flex;
  justify-content: center;
  align-items: center;
  aspect-ratio: 100 / 34.9;
  opacity: 1;
  position: relative;
  overflow: hidden;
  will-change: transform;
}
.home-bnr a img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s;
  position: absolute;
  left: 0;
  top: 0;
  z-index: 0;
}
.home-bnr a:hover img{
  transform: scale3d(1.11,1.11,1.11);
}
.home-bnr span{
  font-size: 3.2rem;
  letter-spacing: 0.2em;
  position: relative;
  z-index: 1;
}
.home-bnr span.ext::after{
  width: 0.59em;
  vertical-align: 0.07em;
}




/*　下層 共通
------------------------------------------------------------------------------------------------*/

.main .read{
  max-width: 108rem;
  font-size: 2rem;
  text-align: center;
  margin: 0 auto 8rem;
}
.main .read:has( + .read){
  margin-bottom: 0;
}

.main h2{
  font-size: 3.2rem;
  font-weight: 600;
  padding-bottom: 0.8em;
  margin: min(10.66vw,16rem) 0 3.5rem;
  border-bottom: 1px solid;
}
.main .read + h2{
  margin-top: 0;
}

.main h3{
  font-size: 2.4rem;
  font-weight: 600;
  padding-left: 2rem;
  margin: 3.5rem 0 2rem;
  position: relative;
}
.main h3::before{
  content: "";
  display: block;
  width: 0.4rem;
  height: 91%;
  background: #000;
  position: absolute;
  left: 0;
  top: 5%;
}

.main p + p{
  margin-top: 1.5em;
}

.main .wp-block-table table{
  width: 100%;
  background: #fff;
  border: none;
  border-top: 1px solid #BFBFBF;
}
.main .wp-block-table table th,
.main .wp-block-table table td{
  box-sizing: border-box;
  padding: 2rem 2.4rem;
  border: none;
  border-bottom: 1px solid #BFBFBF;
  line-height: 1.5;
}
.main .wp-block-table table th,
.main .wp-block-table table td:first-child{
  width: 38.33%;
  background: #E3E3E3;
  font-weight: 600;
  text-align: left;
}

.main .wp-block-image{
  width: 100%;
  max-width: 100rem;
  margin: 4rem auto;
}
.main .wp-block-image img{
  width: 100% !important;
  height: auto !important;
  aspect-ratio: 100 / 55.9;
  object-fit: cover;
}
.main .wp-block-image figcaption{
  font-size: 1.2rem;
  margin-top: 0.4em;
}
.main .wp-block-columns{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3.2rem;
  margin: 4rem auto;
}
.main .wp-block-columns .wp-block-image{
  margin: 0;
}

.main ul,
.main ol{
  margin: 2.4rem 0;
}
.main ul li{
  display: block;
  padding-left: 1.8rem;
  position: relative;
}
.main ol li{
  margin-left: 1.5em;
}
.main ul li + li,
.main ol li + li{
  margin-top: 0.5em;
}
.main ul li::before{
  content: "";
  display: block;
  width: 1rem;
  height: 1rem;
  border-radius: 100%;
  background: #000;
  position: absolute;
  left: 0;
  top: 0.6em;
}

.main ul.notes{
  font-size: 1.2rem;
  margin: 1em 0;
}
.main ul.notes li{
  padding-left: 1.2em;
}
.main ul.notes li + li{
  margin-top: 0.5em;
}
.main ul.notes li::before{
  content: "※";
  width: auto;
  height: auto;
  border-radius: unset;
  background: unset;
  top: 0;
}

.border{
  border: 1px solid;
  padding: 2.4rem;
  margin: 2.4rem 0;
}
.border + .border{
  margin-top: 1.6rem;
}
.border:has( + .border),
.border:has( + .notes){
  margin-bottom: 0;
}




/*　スマホ
------------------------------------------------------------------------------------------------*/
@media (max-width: 768px){

.fv{
  height: calc(100svh - 4.8rem);
}
.fv h1{
  font-size: 3rem;
  line-height: 2;
}
.fv p{
  font-size: 1.2rem;
  margin-top: 2rem;
  line-height: 2.33;
}


.home-video{
  margin-top: 5.6rem;
}
.home-video #play img{
  width: 4.4rem;
}


.home-intro{
  margin-top: 5.6rem;
}
.home-intro::before{
  height: 9rem;
  margin: 0 auto 3rem;
}
.home-intro::after{
  width: 12.8rem;
  background: url(../images/home/bg-img1_sp.png) center center no-repeat;
  background-size: contain;
  top: -2rem;
}
.home-intro h2{
  font-size: 2.4rem;
}
.home-intro p{
  font-size: 1.6rem;
  line-height: 1.67;
  text-align: left;
  margin-top: 2rem;
}
.home-intro .img-wrap{
  margin-top: 3rem;
  grid-template-columns: repeat(2, 1fr);
  grid-template-rows: unset;
  gap: 0.4rem;
}
.home-intro .img-wrap picture.img1 { grid-area: 1 / 1 / 2 / 3; }
.home-intro .img-wrap picture.img2 { grid-area: 2 / 1 / 3 / 2; }
.home-intro .img-wrap picture.img3 { grid-area: 2 / 2 / 3 / 3; }


.bumpy-sec{
  margin-top: 8rem;
  padding-bottom: 0;
}
.bumpy-sec .img{
  width: 100%;
}
.bumpy-sec .box{
  width: 100%;
  height: 19.2rem;
  box-shadow: 1rem 0.5rem 1rem rgba(0, 0, 0, 0.1);
  position: relative;
  bottom: unset;
  margin-top: -6.3rem;
}
.bumpy-sec.ri .box{
  left: unset;
}
.bumpy-sec.le .box{
  right: unset;
}
.bumpy-sec .box h2{
  font-size: 2rem;
}
.bumpy-sec .box .h2-en{
  margin-top: 0.2em;
}


.home-architecture::before{
  width: 13.7rem;
  background: url(../images/home/bg-img2_sp.png) center center no-repeat;
  background-size: contain;
  bottom: 8.5rem;
}


.bg-3{
  width: 100%;
  margin-top: 0;
}


.home-outro{
  margin-top: 4.5rem;
}
.home-outro::before{
  height: 9rem;
  margin: 0 auto 3.4rem;
}
.home-outro h2{
  font-size: 2rem;
  line-height: 1.67;
}
.home-outro .obi{
  margin-top: 3rem;
}


.home-bnr{
  margin-top: 5rem;
}
.home-bnr .content{
  grid-template-columns: 100%;
  gap: 1.6rem;
}
.home-bnr span{
  font-size: 1.7rem;
}
.home-bnr span.ext::after{
  width: 0.66em;
  vertical-align: 0.01em;
}




/*　下層 SP
------------------------------------------------------------------------------------------------*/

.main .read{
  font-size: 1.6rem;
  text-align: left;
  margin: 0 auto 4rem;
}

.main h2{
  font-size: 2rem;
  margin: 3rem 0 1.5rem;
}

.main h3{
  font-size: 1.8rem;
  padding-left: 1.6rem;
  margin: 1.5rem 0;
}

.main .wp-block-table table th,
.main .wp-block-table table td{
  display: block;
  padding: 1.5rem;
}
.main .wp-block-table table th,
.main .wp-block-table table td:first-child{
  width: 100%;
  background: unset;
  border-bottom: 0;
  padding-bottom: 0.3em;
}
.main .wp-block-table table th + td,
.main .wp-block-table table td:first-child + td{
  padding-top: 0;
}

.main .wp-block-image{
  margin: 2rem auto;
}
.main .wp-block-columns{
  gap: 0.7rem;
  margin: 2rem auto;
}

.main ul,
.main ol{
  margin: 2rem 0;
}
.main ul li{
  padding-left: 1.5rem;
}
.main ul li::before{
  width: 0.7rem;
  height: 0.7rem;
}

.border{
  padding: 2rem;
  margin: 2rem 0;
}
.border + .border{
  margin-top: 1.6rem;
}




}/*　スマホここまで */



