@charset "UTF-8";

/*---------------------------
fv
---------------------------*/
#fv .swiper {
  width: 100%;
}
#fv .swiper .swiper-slide {
  min-height: 600px;
  height: calc(100vh - 80px);
  width: 100vw;
  position: relative;
}
#fv .swiper .swiper-slide img {
  max-width: none;
  height: 100%;
  position: absolute;
  object-fit: cover;
  width: 100%;
}

#fv .container{
  position: absolute;
  right:0;
  bottom:3em;
  left:0;
  padding:0;
  margin:auto;
}
#fv #fv-main h1.title{
  font-family: "Cormorant", serif;
  font-size:5.75em;
  color:#fff;
  text-shadow:0 0 9px rgba(0,0,0,.39);
  letter-spacing: .19em;
}
#fv .container > *{
  width:100%
}

@media only screen and (max-width: 767px) {
  #fv .swiper {
    aspect-ratio: 1 / 1;
  }
  #fv .swiper .swiper-slide {
    min-height: auto;
    height: 100%;
  }
}

/*modal*/
#modal_member .modalttl{
  margin-bottom: 1.5em;
  text-align: center;
  font-size:1.125em;
  color:#4B595D;
}
#modal_member .member-panel{
  gap:0  4.75em
}
#modal_member .member-panel > .flexlist{
  gap:0  .5em
}

#modal_member .graphic-area img{
  width:auto;
  height:9.1875em;
}
#modal_member .panel-area{
  flex:1;
  font-size: 1.5em;
  color:#4B595D;
  text-align: center;
  /* line-height: ; */
}
/* #modal_member .panel-area .num-area{
  width:100%;
} */
#modal_member .panel-area .form-style3{
  width:1.5em;
  font-size: 1.5em;
  color:#4B595D;
  font-family: "Shippori Mincho", serif;
  margin-left: .5em;
}

#modal_member .panel-area .num-btn{
  position: relative;
  width:100%;
  height:2.75em;
  margin: 0;
  padding:0;
  border: none;
  outline: none;
  background: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  cursor: pointer;
}
#modal_member .panel-area .num-btn::after{
  position: absolute;
  top:0;
  right:0;
  bottom:0;
  left:0;
  width:2.75em;
  height:2.75em;
  margin: auto;
  content:"";
  border-radius: 50%;
}
#modal_member .panel-area .num-btn.plus::after{
  background: url(../images/common/ic-plus.png) center / 42% 42% no-repeat #5F6E74;
}
#modal_member .panel-area .num-btn.minus::after {
  background: url(../images/common/ic-minus.png) center / 42% 42% no-repeat #5F6E74;
}
#modal_member .panel-area .num-btn.minus{
  margin-bottom: .5em;
}
#modal_member .panel-area .num-btn.plus{
  margin-top: .5em;
}

#modal_member button.btn{
  width:100%;
  margin-top: 1.5em;
  font-size:1.125em;
}
/* #modal_member [class*="num-"]{
  width:1em;
  display: inline-block;
} */


/*---------------------------
hotel
---------------------------*/
.hotel-graphic-area img{
  width:100%;
}
#hotel .title-area{
  margin-top:3em;
}
#hotel .toggle-area{
  border-bottom:1px solid #5F6E74;
}
#hotel .togglebtn{
  color: #4B595D;
  font-size: 1.5em;
  letter-spacing: .16em;
  padding:.5em 3em .5em .42em ;
  line-height: 1.875;
}
#hotel .hotel-list{
  padding: .5em .75em 1.75em .75em;
  gap:1.375em 0;
  font-size:1em;
}


@media only screen and (max-width: 767px) {
  #hotel .preface {
    margin-bottom: 1.725em;
  }
}

/*---------------------------
fcmc
---------------------------*/
#fcmc {
  background: url(../images/top/02_bg_img.jpg) no-repeat 50% 50%;
  background-size: cover;
}
#fcmc .title-area {
  padding-bottom: 1em;
}
#fcmc .title-area .content-title {
  line-height: 1.2;
}
#fcmc .title-area .content-title span {
  display: inline-block;
  margin: 0 .25em;
  vertical-align: baseline;
}
#fcmc .main-area .fcmc-graph01{
  margin: auto;
}
#fcmc .main-area .fcmc-graph01 img{
  width:100%;
  height:auto;
}
#fcmc .btn-view-more{
  margin:2em auto 0;
}
@media only screen and (max-width: 767px) {
  #fcmc .container {
    padding-top: 3.85em;
  }
  #fcmc .title-area {
    margin-bottom: 1.85em;
  }
  #fcmc .title-area .content-title {
    font-size: 2em;
  }
  #fcmc .preface {
    margin-bottom: .5em;
  }
}


/*---------------------------
gallary
---------------------------*/
#gallary {
  background:#FFFEFB;
}
#gallary .main-area{
  gap:1.875em 0
}
#gallary .gallary-shelf img{
  height:auto;
}
#gallary .gallary-shelf{
  position: relative;
  width:93.5%;
}
#gallary .gallary-photo01,#gallary .gallary-photo05{
  width:39.3%;
}
#gallary .gallary-photo02,#gallary .gallary-photo04{
  position: absolute;
  width:20.5%;
}
#gallary .gallary-photo02{
  left:0;
  bottom:0;
}
#gallary .gallary-photo04{
  top:0;
  right:0;
}
#gallary .gallary-photo03{
  width:53.65%;
}
/*---------------------------
gallary2
---------------------------*/
#gallary2 {
  background:url(../images/top/03_photo-c01.jpg) center / cover no-repeat;
  z-index: 1;
  position: relative;
}
#gallary2 .container{
  padding:12.25em .8125em 12.25em;
}
#gallary2 .bg-black3{
  position: absolute;
  content:'';
  width:100%;
  height:100%;
  z-index: -2 !important;
}
#gallary2 .preface{
  font-size:1.125em
}
#gallary2 .btn-view-more{
  margin:2em auto 0;
}



/*---------------------------
location
---------------------------*/
#location .container {
  overflow: hidden;
}

#location .container {
  padding-top: 4.245em;
}
/*tab*/
#location .tab-menu .swiper-pagination{
  -webkit-box-pack: center;
  justify-content: center;
  gap: 0 2em;
  display: flex;
  position: static;
  margin-bottom: .5em;
}
#location .tab-menu .swiper-pagination .swiper-pagination-bullet {
  background: none;
  height: auto;
  border-radius: 0;
  opacity: 1;
  width: auto;
  padding:.25em 0 .25em;
  font-family: "Cormorant", serif;
  font-size: 1.5em;
  color:#4B595D;
  position: relative;
  margin-bottom: .5em;
  cursor: pointer;
}
#location .tab-menu .swiper-pagination .swiper-pagination-bullet-active::after{
  position: absolute;
  content:'';
  width:3.0625em;
  height:1px;
  right:0;
  bottom:0;
  left:0;
  margin: auto;
  background:#5F6E74;
}

#location .swiper-slide {
  background: #fff;
}
#location img{
  width:100%;
  height:auto;
  border-radius:.25em;
}
#location .map-area{
  position: relative;
  -webkit-box-align: start;
  align-items:flex-start;
  min-height: 482px;
}
#location .map-area h2.area-title{
  position: relative;
  font-family: "Cormorant", serif;
  font-size:5.375em;
  color:#4B595D;
  letter-spacing: .09em;
  line-height: 1.5;
  margin-top:.325em;
}
#location .map-area h2.area-title::after{
  position: absolute;
  content:'';
  width:1.68em;
  height:1px;
  left:.17em;
  bottom:0;
  background:#5F6E74;
}
#location .map-area .line {
  position: absolute;
  top: 42%;
  right: calc(22.5% + 12px);
  width: auto;
  z-index: 2;
}
#location #tokyo .map-area .line {
  margin-top: 30px;
}
#location #fukuoka .map-area .line {
  margin-top: -15px;
}
#location #nagasaki .map-area .line {
  margin-top: -25px;
}
#location #okinawa .map-area .line {
  margin-top: 24px;
  right: calc(22.5% + 35px);
}
#location .map-area .map{
  position: absolute;
  width:78%;
  height:auto;
  top:0;
  left:0;
  z-index: -1;
}
#location .map-area .thumbnail-area {
  width:22.5%;
  gap:.9375em;
  margin-top: 6.625em;
}
#location .map-area .thumbnail-area .graphic-area {
position: relative;
}
#location .map-area .thumbnail-area .name {
  position: absolute;
  right:0;
  bottom:0;
  left:0;
  margin:auto;
  padding-bottom:.5em;
  line-height: 1.25;
  letter-spacing: .125em;
  font-size:1em;
  color:#fff;
}
#location .map-area .thumbnail-area .btn-area {
  gap:0 .625em;
}
#location .map-area .thumbnail-area .btn-area .btn{
  width:100%; 
  padding:.5em;
  border-radius: .5em;
  font-size:.875em;
}
#location .map-area .thumbnail-area .btn-area .btn.btn-g{
  background:#7C898B;
}
#location .map-area .thumbnail-area .prevnext-area{
  position: relative;
  height:1.1em;
}
/*swiper*/
.prevnext-area .swiper-button-next, .prevnext-area .swiper-button-prev {
  width:3.5625em;
}
.prevnext-area .swiper-button-next {
  right:0
}
.prevnext-area .swiper-button-prev {
  left:0
}
.prevnext-area .swiper-button-next::after, .prevnext-area .swiper-button-prev::after {
  content:"";
  width:3.5625em;
  height:1.1em;
}
.prevnext-area .swiper-button-next::after {
  background: url(../images/common/ic-next.png) right center / contain no-repeat;
}
.prevnext-area .swiper-button-prev::after {
  background: url(../images/common/ic-prev.png) left center / contain no-repeat;
}
#location .map-area .thumbnail-area .hotel-detail{
  position: relative;
  padding:.5em;
  border-radius: .5em;
  background: #333;
  font-size:.875em;
  letter-spacing: .14em;
  color:#fff;
}
#location .map-area .thumbnail-area .hotel-detail button{
  display: block;
  padding:.5em;
  font-size:.9em;
  letter-spacing: .1em;
  color: #fff;
  cursor: pointer;
  text-align: center;
  font-family: "Shippori Mincho", serif;
  width: 100%;
}
/*#location版togglebtn*/
#location .hotel-detail .list{
  margin-top: .5em;
}
#location .hotel-detail .togglebtn::after{
  position: absolute;
  top:0;
  right:.5em;
  bottom:0;
  content:"＋";
  width:1em;
  height:1em;
  background: none;
  line-height: 1;
  margin: auto;
  transition: all .3s;
}
#location .hotel-detail .togglebtn.active::after {
  transform: rotate(-180deg);
  content:"−";
  background: none;
}
#location .pickup-area .pickup-title{
  margin-bottom: .8333em;
  font-size:1.5em;
  line-height: 1.875;
  letter-spacing: .15em;
}
#location .pickup-area .flexlist{
  gap:1.185em;
}
#location .pickup-area .flexlist li{
  position: relative;
}
#location .pickup-area .flexlist .pickup-name{
  font-size:1.185em;
  margin-top:.5em;
  line-height: 1.22;
}

@media only screen and (max-width: 1199px) {
  #location .map-area .line {
    display: none;
  }
}
@media only screen and (max-width: 767px) {
  #location .container {
    padding-top: 3.75em;
    padding-bottom: 3.75em;
  }
}

/*pcのみ*/
@media only screen and (min-width: 768px) {
  /*---------------------------
  fv
  ---------------------------*/
  
  /*---------------------------
  fcmc
  ---------------------------*/
  #fcmc .main-area .fcmc-graph01{
    width:72.75%;
  }
  /*---------------------------
  hotel
  ---------------------------*/
  #hotel .main-area{
    gap:0 12.25%;
  }
  #hotel .hotel-graphic-area{
    width:50.5%;
  }
  #hotel .hotel-text-area{
    width:37.25%;
  }

}



/*PCの基本の長さからSPまでの間*/
@media only screen and (max-width: 1199px) {
  /*------------------------------
  共通
  ------------------------------*/
  .container{
    width:100%;
  }
}

/*SP*/
@media only screen and (max-width: 767px) {
  /*---------------------------
  fv
  ---------------------------*/
  #fv .container{
    flex-direction: column;
    position: relative;
    padding:3em 1em 1em 1em;
    margin-top: -3em;
  }

  #fv #fv-main h1.title{
    display: none;
  }
  #fv .container > *{
    width:100%
  }
 
/*modal*/
  #modal_member .modalttl{
    font-size:1.1em;
  }
  #modal_member .member-panel{
    gap:0 1.5em
  }
  #modal_member .graphic-area img{
    height:7em;
  }
  #modal_member .panel-area{
    font-size: 1.17em;
  }
  #modal_member .panel-area .form-style3{
    width:1.17em;
    font-size: 1.17em;
    margin-left: .5em;
  }
  #modal_member .panel-area .num-btn{
    height:2.75em;
  }
  #modal_member .panel-area .num-btn::after{
    width:2.75em;
    height:2.75em;
  }


  /*---------------------------
  fcmc
  ---------------------------*/
  #fcmc h2.content-title{
    font-size: 1.42em;
    letter-spacing: .1em;
  }
  #fcmc .main-area .fcmc-graph01{
    height: auto;
  }

  /*---------------------------
  hotel
  ---------------------------*/
  #hotel .container{
    padding-top:0;
  }
  #hotel .main-area{
    flex-direction: column;
  }
  #hotel .togglebtn{
    font-size: 1.285em;
    letter-spacing: .22em;
  }


  /*---------------------------
  gallary2
  ---------------------------*/
  #gallary2 .container{
    padding:6em 1em 6em;
  }


  /*---------------------------
  location
  ---------------------------*/
  /*tab*/
  #location {
    background-color: #fff;
  }
  #location .tab-menu .swiper-pagination{
    -webkit-box-pack: center;
    justify-content: center;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
    gap:0 2em;
  }
  #location .tab-menu .swiper-slide {
    font-size: 1.25em;
  }
  #location .map-area{
    min-height: auto;
    flex-direction: column;
  }
  #location .map-area h2.area-title{
    font-size: 2em;
    letter-spacing: .09em;
    padding-bottom: .2em;
  }
  #location .map-area h2.area-title::after {
    left: .04em;
  }
  #location .map-area .map{
    position: relative;
    width:100%;
    top:auto;
    left:auto;
  }
  #location .map-area .thumbnail-area {
    width:80%;
    gap:.9375em;
    margin: 1em auto;
  }
  #location .map-area .thumbnail-area .name{
    font-size: 1em;
  }
  #location .map-area .thumbnail-area .btn-area .btn{
    font-size:1em;
  }
  #location .map-area .thumbnail-area .hotel-detail{
    font-size:.95em;
  }
  #location .pickup-area .pickup-title{
    margin-bottom: 1.25em;
    font-size: 1.1em;
    line-height: 1.5;
    letter-spacing: .1em;
  }
  #location .pickup-area .flexlist{
    gap:1em;
      -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-flex-flow: row wrap;
    flex-flow: row wrap;
  }
  #location .pickup-area .flexlist li{
    width:calc(50% - .5em);
  }
  #location .pickup-area .flexlist .pickup-name{
    font-size:.85em;
    letter-spacing: .1em;
  }

}



#gallary {
  position: relative;
  overflow: hidden;
}
/* @media only screen and (min-width: 768px) {
  #gallary {
    margin-bottom: -4rem;
  }
} */
#gallary .gallary_grid {
  position: relative;
  z-index: 1;
}
#gallary .gallary_main {
  height: 100dvh;
  display: flex;
  align-items: center;
}
#gallary .gallary_main_wrap {
  padding: 0 12.864vw;
  position: absolute;
  width: 100%;
}
@media only screen and (max-width: 767px) {
  #gallary .gallary_main_wrap {
    padding: 0;
    margin-left: -2.5rem;
    margin-right: -2.5rem;
    width: calc(100% + 5rem);
  }
}
#gallary .gallary_main .gallary_main_image {
  display: flex;
  position: absolute;
  align-items: center;
  justify-content: center;
  width: 100vw;
  height: 100dvh;
}
#gallary .gallary_main .gallary_main_image .img {
  position: relative;
  overflow: hidden;
}
@media only screen and (min-width: 768px) {
  #gallary .gallary_main .gallary_main_image .img {
    min-height: 25vw;
    min-width: 41.6vw;
  }
}
@media only screen and (max-width: 767px) {
  #gallary .gallary_main .gallary_main_image .img {
    min-height: 111vw;
    min-width: 65.3vw;
  }
}
#gallary .gallary_main .gallary_main_image .img::before {
  padding-top: 56.25%;
  float: left;
  content: "";
}
#gallary .gallary_main .gallary_main_image .img::after {
  display: block;
  clear: both;
  content: "";
}
#gallary .gallary_main .gallary_main_image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#gallary .gallary_main .gallary_main_image .overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5019607843);
  opacity: 0;
}
#gallary .gallary_main_row {
  display: flex;
  flex-flow: row wrap;
  justify-content: flex-start;
  align-items: flex-start;
}
#gallary .gallary_main_row.images-middle {
  justify-content: center;
  margin: 1.5vw 0;
}
@media only screen and (max-width: 767px) {
  #gallary .gallary_main_row.images-middle {
    margin: 1.1rem 0;
  }
}
#gallary .gallary_main_row .img {
  position: relative;
  overflow: hidden;
}
#gallary .gallary_main_row .img.img01 {
  width: 38%;
  margin-left: auto;
}
#gallary .gallary_main_row .img.img02 {
  width: 19.6%;
  margin-right: auto;
  align-self: flex-end;
}
#gallary .gallary_main_row .img.img03 {
  visibility: hidden;
  min-height: 25vw;
  width: 53.6%;
}
#gallary .gallary_main_row .img.img04 {
  width: 19.6%;
  margin-left: auto;
}
#gallary .gallary_main_row .img.img05 {
  width: 38%;
  margin-right: auto;
}
.gallary-text {
  opacity: 0;
  visibility: hidden;
  transition: 3600ms cubic-bezier(0.23, 1, 0.32, 1);
  position: relative;
  z-index: 99;
}
@media only screen and (max-width: 767px) {
  .gallary-text {
    padding: 8vw;
  }
}
.gallary-text.active {
  opacity: 1;
  visibility: inherit;
}
.gallary-text .container {
  padding: 36.8dvh 0.625rem 22dvh;
}
@media only screen and (max-width: 767px) {
  .gallary-text .container {
    padding: 50% 0 0;
  }
}
.gallary-text .preface {
  color: #fff;
}
@media only screen and (max-width: 767px) {
  .gallary-text .preface {
    font-size: 0.875rem;
    margin-bottom: 1.25rem;
  }
}
@media only screen and (max-width: 350px) {
  .gallary-text .preface {
    font-size: 3.8vw;
  }
}
.gallary-text .content-title {
  color: #fff;
}
@media only screen and (max-width: 767px) {
  .gallary-text .content-title {
    font-size: 1.525rem;
  }
}
@media only screen and (max-width: 350px) {
  .gallary-text .content-title {
    font-size: 6.5vw;
  }
}
.gallary-text .title-area::after {
  background: #fff;
}
.gallary-text .main-area {
  text-align: center;
}
.gallary-text .btn-view-more {
  margin: 2em auto 0;
}
@media only screen and (max-width: 767px) {
  .gallary-text .btn-view-more {
    margin-top: 1.25rem;
  }
}