@charset "utf-8";
/*===================
ローディング
===================*/
.loader {
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  background: #fff;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 1;
  transition: opacity 1s ease;
}
.loader.hide {
  opacity: 0;
}
.loader__logo {
  width: 171px;
  opacity: 0;
}



/*===================
fv
===================*/
/* 1   */
.fv-wrap{
  /* position: sticky; */
  top: 0;
  width: 100%;
  height:  100vh;
  position: relative;
  z-index: 1;
 }
 .fv__img{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  width: 100%;
  max-width: 460px;
  max-height: 70vh;
  overflow: hidden;
 }
 .fv__img img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
 }
 .fv__text{
 position: fixed;
  top: 50%;
  right: 30px;
  transform: translateY(-50%);
  z-index: 5;
  opacity: 0;
  transition: .3s;
 }
 .fv.is-active .fv__text{
  opacity: 1;
 }
.fv__text p{
  font-size: 11px;
  font-family: "Libre Bodoni", serif;
  color: #060606;
}


@media screen and (max-width: 750px) {
  .fv__imgWrap{
    margin-bottom: 10px;
    max-width: 320px;
  }
  .fv__imgWrap{
    font-size: 14px;
  }
  .fv__img{
    width: 100%;
    max-width: 300px;
  }
  .fv__text{
    top: auto;
    bottom: 40px;
    right: 15px;
    /* font-size: 15px; */
  }
}
@media screen and (max-width: 480px) {
 .fv__img{
    max-width: 268px;
  }
}




/*===================
intro-story
===================*/

.intro-story{
  /* margin-top: -100vh; */
  height: 100vh;
  position: relative;
  overflow: hidden;
  z-index: 3;
}
.intro-story__bg{
  position: absolute;
  inset: 0;
  z-index: 1;
  border: 15px solid rgba(255, 255, 255, 0);
}
.bg-overlay {
    position: absolute;
    inset: 0;
    background-color: rgba(0,0,0,0.5); /* 初期は半透明黒 */
    opacity: 0; /* 最初は透明 */
    z-index: 3; /* 画像より上、テキストより下 */
    pointer-events: none;

}
.bg-gradient,
.bg-image{
  position: absolute;
  inset: 0;
  z-index:2;
}
.bg-image{
  /* background: url(../imgs/index/intro-story_bg.jpg) center/cover no-repeat; */
  background-size: cover;
  background-position: center;
  opacity: 0;
}
.intro-storyWrap{
  width: 100%;
  max-width: calc(550px + 5vw );
  padding:0 5vw 0 20px;
  margin: 0 auto;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 5;
}
.intro-storyHead{
  margin-bottom: 55px;
  font-size: 16px;
  line-height: 1.2;
}
.intro-storyText p{
  font-size: 11px;
  line-height: 3.15;
}
.intro-storyText--first{
  margin-bottom: 40px;
}
@media screen and (max-width:750px){
  .intro-storyWrap{
    padding: 60px 40px 0;
  }
  .intro-storyHead{
    margin-bottom: 20px;
    font-size: 15px;
    line-height: 1.75;
  }
  .intro-storyText--first{
    margin-bottom: 15px;
  }
  .intro-storyText p{
    line-height: 2.1;
  }
}

/*===================
art
===================*/
.art{
  padding-top: clamp(60px,12.5vw,180px);
  position: relative;
  z-index: 3;
}
.art__head{
  margin-bottom: 85px;
  position: relative;
}
.art__title{
  margin-bottom: 6px;
}
.art .swiper-wrapper {
  transition-timing-function: linear !important;
}
.art__contsWrap{
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 20px;
  position: relative;
}
.art__contsCatch{
  /* font-family: "Libre Bodoni", serif; */
  font-size: 18px;
  letter-spacing: 0;
}
.art__contsLine{
  max-width: 566px;
}
.art__contsText{
  margin-bottom: 20px;
  font-size:12px ;
  line-height: 2.39;
}

@media screen and (max-width:980px){
.art__contsWrap{
  display: block;
}
.art__head{
  margin-bottom: 50px;
}
.art__contsCatch{
  margin-bottom: 20px;
}
.art__contsText{
  width: 100%;
  max-width: 100%;
}

}
@media screen and (max-width:750px){
.art__head{
  margin-bottom: 30px;
}
.art__contsCatch{
  font-size: 16px;
}
 .art__swiperSlide{
  height: 250px;
 }
  .art__swiperSlide img{
    height: 100%;
    width: 100%;
    object-fit: cover;
  }
}
@media screen and (max-width:375px){
 .art__swiperSlide{
  height: 230px;
 }
}

/*===================
onsen
===================*/
.onsen{
  padding-top: clamp(80px,13.61vw,196px);
  position: relative;
  z-index: 3;
}
.onsen__inner{
  width: 100%;
  /* max-width: 720px; */
  margin: 0 auto 83px;
}
.onsen__title{
  margin-bottom: 20px;
}
.onsen__wrap01{
  display: flex;
  justify-content: start;
  align-items: start;
}
.onsen__wrap01--left{
  width: 57%;
}
.onsen__wrap01--img{
  width: 100%;
  max-width: 660px;
}
.onsen__wrap01--right{
  margin-top: 8px;
  width: 36%;
  padding-left: 25px;
  /* min-width: 280px; */
}
.onsen__catch{
  /* font-family: "Libre Bodoni", serif; */
  font-size: 18px;
  margin-bottom: 20px;
  letter-spacing: 0;
}
.onsen__text--ttl{
  margin-bottom: 4px;
  font-size: 16px;
}
.onsen__text{
  font-size: 12px;
  line-height: 2.39;
}
.onsen__text--hid{
  line-height: 1.89;
}
.onsen__wrap02{
  margin-bottom: 80px;
  width: 100%;
  display: flex;
  justify-content: end;
  align-items: center;
  gap:3%;
}
.onsen__wrap02--leftBox{
  margin-bottom: 30px;
}
.onsen__wrap02--right{
  width: 64%;
  max-width:660px ;
}
.swiper-slide__text{
  padding-top: 10px;
  font-family: "Instrument Sans", sans-serif;
  font-size:13px ;
  /* font-weight: 500; */
}
.onsen__btn{
  margin-top: 30px;
  margin-bottom: 30px;
  display: flex;
  flex-direction: column;
  align-items: start;
  justify-content: start;
  gap: 15px;
}
.onsen__note{
  font-size: 12px;
}
.onsen__wrap03{
  width: 100%;
  max-width: 376px;
  margin: 0 auto;
}
.onsen__wrap03--note{
  padding-top: 20px;
  font-size: 12px;
}
.onsen__wrap03--ttl{
  margin-bottom: 20px;
}

@media screen and (max-width:750px){
.onsen__catch{
  font-size: 16px;
}
.onsen__inner{
  margin-bottom: 50px;
}
.onsen__wrap01--left{
  width:50%;
}
.onsen__wrap01--right{
  width: 50%;
}
.onsen__wrap02{
  margin-bottom: 50px;
  justify-content: end;
  gap: 30px;
}
.onsen__wrap02--right{
  width: 50%;
}

}
@media screen and (max-width:680px){
  .onsen__wrap01{
    display: block;
  }
  .onsen__wrap01--left{
    width: 100%;
    max-width: 100%;
    margin: 0 auto 20px 0;
  }
  .onsen__wrap01--right{
    width: 100%;
    max-width: 350px;
    margin: 0 auto;
    padding-left: 0;
  }
  .onsen__wrap02{
    display: block;
  }
  .onsen__wrap02--left{
    width: 100%;
    max-width: 350px;
    margin: 0 auto 20px;
  }
  .onsen__wrap02--right{
    width: 100%;
    max-width: 550px;
    margin: 0 0 0 auto;
  }
  .onsen__wrap02--leftBox{
    margin-bottom: 20px;
  }
  .onsen__wrap02--leftBox:last-child{
    margin-bottom: 0;
  }

}


/* 共通 */
.modal__btn a{
  display: inline-block;
  font-size: 12px;
  line-height: 2.39;
  border-bottom: 1px solid #000;
  position: relative;
  transition: .3s;
}
.modal__btn a:after{
  content: '';
  display: block;
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 0;
  height: 1px;
  background-color: #fff;
  transition: .3s;
  z-index: 2;
}
.modal__btn a:hover{
  color: #fff;
}
.modal__btn a:hover:after{
  width: 100%;
}
/*===================
Public Kitchen
===================*/
.kitchen{
  padding-top: clamp(60px,18.05vw,260px);
  position: relative;
  z-index: 3;
}
.kitchen__wrap{
  display: flex;
  justify-content: space-between;
  align-items: start;
}
.kitchen-pc{
  display: block;
}
.kitchen-sp{
  display: none;
}
.kitchen__img{
  width: 66%;
  max-width: 657px;
}
.kitchen__inner{
  width: 30%;
}
.kitchen__title{
  margin-bottom: 35px;
}
.kitchen__text{
  margin-bottom: 30px;
  font-size: 12px;
  line-height: 2.39;
}
@media screen and (max-width:1100px){
.kitchen__img{
  width: 50%;
}
.kitchen__inner{
  width: 47%;
}
}
@media screen and (max-width:680px){
.kitchen-pc{
  display: none;
}
.kitchen-sp{
  display: block;
}
.kitchen__title {
  margin-bottom: 20px;
}
.kitchen__wrap{
  display: block;
}
.kitchen__img{
  margin-bottom: 10px;
  width: 100%;
  max-width: 100%;
}
.kitchen__inner{
  width: 100%;
}
.kitchen__text{
  margin-bottom: 20px;
}
}



/*===================
room
===================*/
.room{
  padding-top: clamp(60px,18.05vw,260px);
  position: relative;
  z-index: 3;
}
.room__title{
  margin-bottom: 10px;
}
.room__contsHead{
  margin-bottom: 20px;
}

.room__wrap{
  margin-bottom: 30px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.room__img{
  width: 60%;
  max-width: 590px;
}
.room__right{
  width: 45%;
  max-width: 335px;

}
.room__textWrap{
  margin-bottom: 30px;
}
.room__contsTtl{
  /* padding-top: 46px; */
  margin-bottom: 16px;
  font-family: "Instrument Sans", sans-serif;
}
.room__text{
  margin-bottom: 1em;
  font-size: 12px;
  line-height: 2.39;
}
.room__text:last-child{
  margin-bottom: 0;
}

.tab__btn{
  margin-bottom: 10px;
  display: block;
  padding: 5px 0;
  font-family: "Instrument Sans", sans-serif;
  font-size: 13px;
  white-space: nowrap;
  border-bottom: 1px solid #efa30b10;
}
.tab__btn:hover{
  border-bottom: 1px solid #000;
}
.room__amenity{
  display: flex;
  /* flex-direction: column; */
  justify-content: start;
  align-items: start;
  gap: 20px;
}
.room__amenity a{
  display: inline-block;
  font-size: 12px;
  line-height: 3.2;
  border-bottom: 1px solid #000;
}
.room__catch{
  margin-top: 20px;
  margin-bottom: 20px;
  /* font-family: "Libre Bodoni", serif; */
  font-size: 18px;
  line-height: 1.75;
letter-spacing: 0;
}
.room__btmText{
  font-size: 12px;
  line-height: 2.39;
}

.remodal{
  border-radius: 10px;
}
.remodal-close{
  left: auto;
  right: 0;
  color: #000;
}

.room__amenityText{
  margin-bottom: 2em;
  font-size: 12px;
  line-height: 2.39;
  text-align: left;
}
.room__amenityText:last-child{
  margin-bottom: 0;
}
.room__amenityText--ttl{
  font-size: 13px;
}
.room__modlImg{
  width: 100%;
  max-width: 463px;
  margin: 0 auto 30px;
}


@media screen and (max-width:980px){
  .room__img{
    width: 50%;
  }
  .room__right{
    height: auto;
    width: 48%;
  }
  .room__textWrap{
    margin-bottom: 30px;
  }
  .room__contsTtl{
    padding-top: 0;
  }
}
@media screen and (max-width:750px){
  .room__title{
    max-width: 500px;
    margin: 0 auto 20px;
  }
  .room__conts{
    position: relative;
    padding-top: 50px;
  }
  .room__wrap{
    display: block;
    width: 100%;
    max-width: 500px;
    margin: 0 auto;
  }
  .room__img{
    width: 100%;
    margin-bottom: 10px;
  }
  .room__right{
    width: 100%;
  }
  .room__textWrap{
    margin-bottom: 10px;
  }
  .room__contsTtl{
    margin-bottom: 10px;
  }
  .room__btnWrap{
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	-moz-transform: translateX(-50%);
	-o-transform: translateX(-50%);
    display: flex;
    justify-content: start;
    align-items: center;
    gap: 20px ;
  }
  .tab__btn{
    margin-bottom: 0;
  }
  .room__amenity{
    margin-top: 10px;
    flex-direction: column;
    gap:5px;
  }
  .room__amenity a{
    line-height: 2;
  }
  .room__contsBtm{
    width: 100%;
    max-width: 500px;
    margin: 40px auto 0;
  }
  .room__catch{
    margin-bottom: 15px;
    font-size: 16px;
  }
}
@media screen and (max-width:480px){
    .room__conts{
    padding-top:  100px;
  }
  .room__btnWrap{
    display: block;
    left: 0;
    transform: translateX(0);
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    -moz-transform: translateX(0);
    -o-transform: translateX(0)
  }
  .tab__btn{
    position: relative;
    margin-bottom: 8px;
    padding: 3px 13px 3px 0;
  }
  .tab__btn::after{
    content:'';
    display: block;
    width: 9px;
    height: 9px;
    background-image: url(../imgs/common/link-anc.svg);
    background-size: contain;
    background-position: center center;
    background-repeat: no-repeat;
    position: absolute;
    top: 9px;
    right: 0;
  }

}
@media screen and (max-width:375px){
  /* .room__title{
    margin-bottom: 20px;
  } */

}

/*===================
go-shiretoko
===================*/
.go-shiretoko{
  width: 100%;
  margin: 0 auto ;
  padding:clamp(80px,17.36vw,250px) 20px 20px 20px;
  position: relative;
  z-index: 3;
}
.go-shiretoko__inner{

}
.go-shiretoko__title {
  margin-bottom: 10px;
  text-align: center;
}
.go-shiretoko__wrap{
  width: 100%;
  /* height: calc(100vh - 100px); */
  height: 100vh;
  position: relative;
}

#page-wrap {
  width: 100%;
  height: 100vh;
  position: relative;
  overflow: hidden;
}
/*** canvas ***/
#canvas {
  width: 100%;
  height: 100%;
  position: absolute;
  inset: 0; /* ← これに変更 */
  z-index: 0 !important;
}

/*** textures ***/
.multi-textures {
  position: absolute;
  inset: 0; /* ← これに変更 */
  width: 100%;
  height: 100%;
  z-index: 0;
}

/*** img ***/
.multi-textures img {
  display: none;
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  top: 0;
  left: 0;
}

    .slider-ui {
      position: absolute;
      bottom: 40px;
      left: 5%;
      width: 90%;
      padding: 0 40px;
      z-index: 10;
      color: #fff;
    }
    .slider-ui__wrap{
      position: relative;
    }
    /* カウント */
    .slider-ui__count {
      width: fit-content;
      margin: 0 auto 10px;
      font-size: 12px;
      letter-spacing: 0.1em;
      display: flex;
      justify-content: center;
      align-items: center;
    }
    .slider-ui__count span{
      font-family: "Instrument Sans", sans-serif;
      font-size: 12px;
      margin-top: 10px;
    }
    .slider-ui__count .current {
      font-size: 13px;
      margin-bottom: 10px;
      margin-top: 0;
    }

    .slider-ui__count .slash {
      margin: 0 3px;
      opacity: 0.6;
      font-size: 20px;
    }

    .slider-ui__count .total {
      opacity: 0.6;
    }

    /* プログレス */
    .progress {
      flex: 1;
      margin: 0 30px;
      height: 2px;
      background: rgba(255,255,255,0.3);
      position: relative;
    }

    .progress__bar {
      width: 0%;
      height: 100%;
      background: #fff;
      transition: width 0.1s linear;
    }

    /* ナビ */
    .nav {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
      width: 95%;
      display: flex;
      justify-content: space-between;
      gap: 10px;
    }

    .nav button {
      background: transparent;
      color: #fff;
      cursor: pointer;
      transition: all 0.2s ease;
      font-size: 12px;
      font-family: "Instrument Sans", sans-serif;
    }

    .nav button:hover {
      background: rgba(255,255,255,0.2);
    }

    /* sp用 */
    .goSwiper {
      width: 100%;
      height: 100%;
    }
    .goSwiper .swiper-slide {
      width: 100%;
      height: 100%;
    }
    .goSwiper img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }

@media screen and (max-width:1300px){
  .go-shiretoko{
    padding-top: 100px;
  }
}
@media screen and (max-width:750px){
  .go-shiretoko{
    padding: 60px 10px 10px;
  }
  .go-shiretoko__title{
    top: 40px;
  }
  .go-panel{
    position: sticky;
    top: 100px;
    height: calc(100vh - 100px);
  }
  .slider-ui{
    width: 100%;
    left: 0;
    bottom: 20px;
    padding: 0 10px;
  }
  .nav{
    width: 90%;
  }
}
@media screen and (max-width:480px){
  .go-shiretoko__title{
    top: 100px;
  }
  .go-panel{
    position: sticky;
    top: 140px;
    height: calc(100vh - 140px);
  }
  .progress{
      margin: 0;
  }
  .nav {
    width: 100%;
  }
  .slider-ui__count {
    margin-bottom: 5px;
  }
}


/*===================
location
===================*/
.location{
  padding-top: clamp(80px,18.75vw,270px);
}
.location__inner{
  width: 100%;
  max-width: 600px;
  margin: 0 auto;
}
.location__title{
  margin-bottom: 10px;
  text-align: center;
}
.location__map{
  width: 100%;
  max-width: 600px;
  height: auto;
  margin: 0 auto 23px;
  overflow: hidden;
}
.location__map iframe{
  width:100%;
  height:100%;
  aspect-ratio: 600 / 600;
  border:0;
   -webkit-filter: grayscale(100%);
  -moz-filter: grayscale(100%);
  -ms-filter: grayscale(100%);
  -o-filter: grayscale(100%);
  filter: grayscale(100%);
}
.location__text{
  font-size: 12px;
  line-height: 2.39;
}
.location__access{
  width: calc(100% - 40px);
  max-width: 913px;
  margin: 80px auto 0;
}
.location__access dt{
  margin-bottom: 35px;
  font-size: 16px;
  font-weight: bold;
}
.location__access dd{
  margin-bottom: 80px;
}
/* .location__access dd.access__bus div {
  min-height: 83px;
}
.location__access dd.access__bus div p img{
  height: 100%;
} */
.location__access dd:last-child{
  margin-bottom: 0;
}
.location__access dd .inblk{
  margin-bottom: 10px;
}
.js-scrollable {
  overflow-x: auto;
  overflow-y: hidden;
  line-height: 0;
}
.js-scrollable img {
 min-width: 500px;
  height: auto;
}
.inblk.js-scrollable {
  overflow-x: auto !important;
  overflow-y: hidden !important;
  min-height: 120px !important;
}
.access__list{
  margin-top: 30px;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 15px 3%;
}
.access__list li{
  width: auto;
}
.access__list li a{
  display: block;
  width: 100%;
  text-align: center;
  font-size: 12px;
  line-height: 2.3;
  border-bottom: 1px solid #231815;
}
.access__list li a:hover{
  opacity: 0.7;
}

@media screen and (max-width:750px){
  .location__inner{
    padding: 0 20px;
  }
  .location__map{
    max-width: 580px;
  }
  .access__list li{
    margin-top: 10px;
  }
}
@media screen and (max-width:480px){
  .location__map{
    margin-bottom: 15px;
  }
  .access__list li a{
    font-size: 12px;
  }
}


/*===================
faq
===================*/
.faq{
  padding-top: clamp(60px,17.7vw,255px);
  padding-bottom: clamp(60px,17.7vw,255px);
  position: relative;
  z-index: 3;
}
.faq__wrap{
  position: relative;
  z-index: 12;
}
.faq__title{
  margin-bottom: 30px;
}

.accordion-item{
  padding-bottom: 20px;
}
/* アコーディオン */

.accordion-title {
  display: flex;
  justify-content: start;
  align-items: center;
  gap: 20px;
  padding: 20px 0 0 0;
  cursor: pointer;
  font-size: 12px;
  line-height: 1.8;
}
.accordion-btn span {
  display: block;
  width: 17px;
  height: 2px;
  background: #222;
  position: relative;
}
.accordion-btn span::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 17px;
  height: 2px;
  background: #222;
  transform: rotate(90deg);
  transition: 0.3s;
}

/* 開いたら「−」になる */

.accordion-title.open .accordion-btn span::after {
  transform: rotate(0deg);
}
.accordion-content {
  margin-left: 50px;
  padding:10px 20px 0;
  height: 0;
  transition: height .35s cubic-bezier(.4,0,.2,1);
  font-size: 12px;
  line-height: 2.3;
  overflow: hidden;
}

@media screen and (max-width:1439px){
.faq__inner{
  max-width: 750px;
  margin: 0 auto;
}
}
@media screen and (max-width:750px){
  .faq__inner{
    max-width: 560px;
  }
  .faq__title{
    margin-bottom: 15px;
  }
  .accordion-content{
    padding: 10px 0 0;
    margin-left: 40px;
  }
  .accordion-item{
    padding-bottom: 0;
  }
}


/* hight700px以下 */
@media screen and (max-height: 730px) {
  /* fv */
  .fv__img{
    top: 140px;
    left: 50%;
    transform: translateX(-50%);
  }
  
}