@charset "UTF-8";
html {
  font-size: 10px;
}


body {
  background-color: #F4F5F2;
  margin: 0;
  -moz-text-size-adjust: none;
       text-size-adjust: none;
  -webkit-text-size-adjust: none;
  font-size: 1.2rem;
  color: #1a1a1a;
  font-family: "Zen Kaku Gothic New", sans-serif;
  line-height: 1.2;
-webkit-font-smoothing: antialiased;
}
body.en {
/*font-family: "neue-haas-grotesk-display", sans-serif;*/
}

img {
  border: none;
  height: auto;
}

p {
  line-height: 1.5em;
  margin-top: 0;
}

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

td, th {
  line-height: 1.5em;
  font-weight:inherit;
}

h1, h2, h3, h4, h5, h6, strong, .b {
  font-weight:inherit;
}

h1, h2, h3, h4, h5, h6 {
  padding: 1rem 0;
}
a{
  color: #1a1a1a;
 text-decoration: none;
}

li {
  line-height: 1.4;
}

.en1 {
  font-family: "avenir-next-lt-pro", sans-serif;
  font-weight: 900;
font-style: normal;
  letter-spacing: 0em;
  line-height: 1.4em;
}
.en2 {
font-family: "neue-haas-grotesk-display", sans-serif;
font-weight: 700;
font-style: normal;
  letter-spacing: 0em;
  line-height: 1.4em;
}

.b9{font-weight:900}
.b7{font-weight:700}
.b6{font-weight:600}

body.jp .en { display: none; }
body.en .jp { display: none; }

.fd{
  opacity: 0;
  transition: opacity 1.5s ease;
}
.fd.show {
  opacity: 1;
}

#container{overflow: hidden;}

.contents {
  z-index: 5;
  position: relative;
}

header a,
main a{
  word-break: break-all;
}


header .spnav,
header .spnav a{color:#F7F3E9;}

main{padding-bottom:3rem}
footer,
footer a{color:#F7F3E9;}
footer{background-color:#003618;
}

/*footer*/
.footer-copy p{font-size: 2.2rem; line-height:1.2em;}

.blc-link h2{font-size: 2.2rem; padding: 0}
.blc-link .blc-spot {font-size: 1.7rem; margin-top: .6rem;}
.blc-link .blc-spot li {line-height: 1.5}
.blc-link .blc-spot li span+span{margin-left: .6em}

footer .blc-link .blc-spot {min-height: 10em}


.blc-other .blc-link2 {margin-top: 8rem}
.blc-other .blc-link2 li {line-height: 1.5em;}
.blc-other .blc-sns {margin-top: 1.6rem}
.blc-other .blc-sns img {width: 1.6rem}

.blc-other .copyright {margin-top: 1rem}
.footer-logo {
  margin-top: 2.5rem;
}

.footer-logo img{
width: 100%;
}

/*spnav*/

.spnav .lang{
  position:absolute;
}
.spnav .lang .btn{
  display:flex;
  align-items:center;
  font-size: 1.7rem;
}
body.jp .spnav .lang .lang-jp a,
body.en .spnav .lang .lang-en a{
  color:#E74F3D ;
  pointer-events: none;
}

.spnav .lang .box a{
  background-color: #F7F3E9;
  width:3.3rem; height: 1.8rem;
  display: block;
  border-radius:.9rem;
  margin: 0 .6rem;
  position:relative;
}
.spnav .lang .box a:before{
  content:'';
  background-color: #E74F3D;
  width:1.4rem; height: 1.4rem;
  border-radius:50%;
  display: block;
  position:absolute;
  top: .2rem; left: .2rem;
}
body.en .spnav .lang .box a:before{
  top: .2rem; right: .2rem; left: auto;
}
.spnav .blc-link .link-top{font-size: 2.2rem;}
.spnav .blc-link h2{margin-top: 2rem}

header{
position:fixed; z-index: 9999;
width: 100%;
}
header .block-hamburger {
/*background-color:rgba(244, 245, 242, 1) ;*/
height: 7rem;
padding: 0 4rem;
display: flex; align-items:center; justify-content:space-between;
}
header .block-hamburger .box-hamburger{
background-color:rgba(244, 245, 242, 1) ;
display:flex; align-items: center;
z-index: 99999;
padding: 0 2rem; border-radius:6rem;
}
body.active header .block-hamburger .box-hamburger{
background-color:rgba(244, 245, 242, 0) ;
}
header .block-hamburger h1{
padding: 1.2rem 0 .8rem;
}
header .block-hamburger h1 img{
width: 16rem;
}
header .block-hamburger h1 .bl,
header .block-hamburger h1 .wh{
  transition:opacity .3s;
}

body.active header .block-hamburger h1 .bl{
  opacity:0;
  display:none;
}
body:not(.active) header .block-hamburger h1 .bl{
  opacity:1;
  display:block;
}
body.active header .block-hamburger h1 .wh{
  opacity:1;
  display:block;
}
body:not(.active) header .block-hamburger h1 .wh{
  opacity:0;
  display:none;
}


header .block{
  background-color: #003618;
  min-height: 100vh; 
  min-height: 100dvh; 
}
main{margin-top:7rem;}

.link-reserve a{
margin-left: auto;
margin-right: auto;
display: inline-block;
background-color: #003618;
border-radius: 3rem;
color: #F7F3E9;
padding: 1rem 2rem;
font-size: 1.5rem;
line-height:1;
border:.2rem solid #F7F3E9;
}
.link-reserve a .en1 {
font-size: 2rem;
}
.link-reserve a .en1+span{
  margin-left:1rem;
  vertical-align: .15rem;
}

.home .section1 .inner .copy2{
  z-index: 5;
  position:relative;
}
.home .mainimage.splide{
  position:absolute;
  top: 0;
  z-index: 0;
  width: 100%; height: 100%;
  margin: 0;
}
.home .mainimage.splide img{
  width: 100%; height: 100%;
  object-fit:cover;
}
.home .mainimage.splide .splide__track{
  height: 100%;
}

.home .section1{
  /*background:url(/common/images/section1_sp.jpg) no-repeat center center;*/
  /*background-size:cover;*/
  min-height: 60rem;
  position:relative;
  overflow: hidden;
}
.home .section2 .inner{
  background:url(/common/images/section2_sp.jpg) no-repeat center center;
  background-size:cover;
  min-height: 60rem;
  position:relative;
}

.home .section-spot.spot1,
.motohakone .section-spot{
  background:url(/motohakone/images/spot_image_sp.jpg) no-repeat center center;
  background-size:cover;
  min-height: 60rem;
  position:relative;
}

.home .section-spot.spot1{
  min-height: 50em;
}
.motohakone .spot-map{
  background:url(/motohakone/images/map_sp.jpg) no-repeat center center;
  background-size:cover;
  min-height: 60rem;
  position:relative;
}

.section h2.index{line-height:1.1;}

.section+.section{margin-top: 2rem}
h2+.section.r{
  margin-top: 1.5rem
}
.section.r,
.inner.r{
  margin-left: 2rem; margin-right: 2rem;
border-radius:2rem;
}
.section.n{
  margin-top: 4rem; 
}
.section.line:before{
  content:'';
  display:block;
  border-top: .1rem solid;
  margin-top: 5rem;
  margin-bottom: 2rem;
}

.section.color{
background-color: #D5CDBB;
padding: 4.3rem 0;
  margin-top: 6rem; 
}

.section1{color: #fff;}
.section2{color: #fff;}

.section2 .copy{
  position:absolute;
  top: 50%; left: 50%;
  transform:translate(-50%, -50%);
  text-align:center;
}
.section2 .copy h3{
  font-size: 2rem;
}
.section2 .copy h2{
  font-size: 2.5rem;
  padding: 5rem 0 2rem;
}

.section h2 sup{
  font-size: 0.5em;
  font-weight:800;
  vertical-align:super;
  margin-left: 1rem;
  top: -0.3em;
position: relative;
}
.blc-splide h3{font-size: 2.3rem; padding: 0 ;}
.blc-splide h4{font-size: 1.5rem; padding: 0 ;}

.blc-splide li img{border-radius:2rem; margin-top: 1.6rem; width: 100%; object-fit: cover}
.col2.blc-splide li img{aspect-ratio:630/400;}
.col3.blc-splide li img{aspect-ratio:300/375;}
.blc-splide li p{ padding:  1.5rem 0;}

.splide .splide__track {
  overflow: visible; 
}
.blc-splide{
position: relative;
padding-bottom: 6rem;
}
.blc-splide .splide {
position: static;
}
.blc-splide .splide__pagination {
bottom: 2rem;
left: 0;
padding: 0 1em;
position: absolute;
right: 0;
z-index: 1;
}
.blc-splide .splide__pagination__page.is-active {
background: #000;
transform: scale(1);
z-index: 1;
}
.blc-splide .splide__pagination__page {
background: #b0b0b0;
height: .8rem;
width: .8rem;
margin: .3rem;
opacity: .7;
}
.blc-splide .splide__arrow{
  width: 6rem; height:6em;
  transform: translateY(-120%);
  background: none;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

.blc-splide .splide__arrow img{
  width: 100%; height:100%;
}
.blc-splide .splide__arrow:hover:not(:disabled) {
opacity: 1;
}

.blc-splide .splide__arrow--prev img{
transform:rotate(180deg);
}

.blc-splide .move .splide__arrow--next{
/*opacity: 0!important;
pointer-events:none;*/
}
.blc-splide .splide.is-active .splide__arrow {
  opacity: 1;
  pointer-events: auto;
}
.blc-splide .splide .splide__arrow.is-disabled {
  opacity: 0;
  pointer-events: none;
}
.section-spot .inner{position:absolute; top: calc(50% - 5rem); color: #fff; text-align:center; width: 100%;}
.section-spot .name{font-size: 3rem; padding: 2rem 0 2rem}
.section-spot .spot-number{font-size: 3rem;}
.section-spot p{font-size: 1.4rem; max-width: 90%; margin: 0 auto}
.spot-link a{
  margin-top: 5rem;
    background: rgba(255, 255, 255, 0.2); /* 半透明で背景を透過 */
  backdrop-filter: blur(5px);          /* 下の背景をぼかす */
  -webkit-backdrop-filter: blur(5px);  /* Safari対応 */
  padding: 1rem 4rem;
  border-radius: 3rem;
  border:.2rem solid #fff;
  display:inline-block;
  color: #fff;
  font-size: 1.9rem;
}
.spot-access .blc-map{
width: 100%; height: 29rem;
}
.blc-address{margin-top: 3rem}


/*page spot*/

.spot-map{color: #fff}
.spot-map .text-map h2{font-size:1.8rem; line-height: 1.2; padding: 0 0 1rem}

.blc-spec h3{
font-size: 1.2rem;
}
.blc-spec .blc-facilities li{display:flex; align-items:center; margin-bottom:.5em}
.blc-address li{display:flex; margin-bottom:1.5em;}

.blc-spec .icon,
.blc-address .icon{margin-right: 1em}
.blc-spec .icon img,
.blc-address .icon img{width: 2.6rem; display:block; }

.blc-floor{
  aspect-ratio:8/7;
}
.blc-floor img{
  border-radius: 2rem;
  width: 100%;
  height: 100%;
  object-fit:cover;
}

.blc-spec th{white-space: nowrap}
.blc-spec th,
.blc-spec td{
border-bottom: .1rem solid;
padding: .5em .4em .5em 0;
}
.blc-spec tr:last-child th,
.blc-spec tr:last-child td{
border-bottom: none;
}

.spot-location .blc-comment h3{font-size: 2rem; margin-bottom: 2em}
.spot-location .blc-image img{border-radius:2rem}

.blc-map iframe{
  border-radius:2rem;
    -moz-filter: grayscale(100%);
  -ms-filter: grayscale(100%);
  -o-filter: grayscale(100%);
  filter: grayscale(100%);
  display: block;
  width: 100%; height: 100%;
}

.blc-address ul{margin-top: 2em}
.blc-address li span+span{padding-top: .5em}




/*////////////////////////////////*/
/*hamburger*/

.spnav .block{display: none;}

.spnav{
user-select: none;
-moz-user-select: none;
-webkit-user-select: none;
-ms-user-select: none;
}
.spnav-inner{
margin:0 auto;
width: 100%;
}
.spnav .block{
position: fixed;
width: 100%;
z-index: 2500;
/*top:60px;*/
top:0;
}
.spnav .block .inner{
margin : 0 auto 0;
overflow-y:scroll;
-webkit-overflow-scrolling: touch;
/*height:calc(100vh - 60px);*/
height:100vh;
height:100dvh;
}
.fade{
width: 100%; height: 1000vh;
position:fixed;top:0;
background-color:#bbd1d1;
z-index:1000;
}

.hamburger span {
transition: all .2s;
box-sizing: border-box;
}
.hamburger {
cursor: pointer;
z-index: 99999;
margin-right: 1.2rem;
}
.hamburger .box {
width: 2rem; height: 2.5rem; position: relative;
margin: 0 auto .2rem;
}
.hamburger .box span {
position: absolute;
width:100%;
height: 2px;
background-color: #000;
}
body.active .hamburger .box span {
background-color: #fff;
}
.hamburger .box span:nth-of-type(1) {
top: calc(25% - 1px);
}
.hamburger .box span:nth-of-type(2) {
top: 50%;
}
.hamburger .box span:nth-of-type(3) {
top: calc(75% + 1px);
}
.hamburger.active .box span:nth-of-type(1) {
top: 50%;
-webkit-transform: rotate(-45deg);
transform: rotate(-45deg);
}

.hamburger.active .box span:nth-of-type(2) {
opacity:0;
}
.hamburger.active .box span:nth-of-type(3) {
top: 50%;
-webkit-transform: rotate(45deg);
transform: rotate(45deg);
}

/*page*/
.page main {
margin-top: 8rem;
}
.page .title h1{
  font-size: 3.2rem; line-height: 1.2;
  padding:0;
}
.page .title p{
  font-size: 1.5rem;
}
.page .title {margin-bottom: 3rem}

/*faq*/

.body-faq{
border-top: .1rem solid ;
margin-bottom: 5rem;
}
.blc-faq{
border-bottom: .1rem solid ;
position:relative;
}
.faq-q{padding: 1em 0; cursor:pointer; transition:opacity .3s;
  user-select: none; 
  -webkit-user-select: none;
  -moz-user-select: none; 
  -ms-user-select: none;
}
.faq-q:hover{opacity: .6}
.faq-a{
  padding: 0 0 2em 0; 
  display:none;
}
.faq-q .inner,
.faq-a .inner{display:flex;}
.faq-q p,
.faq-a p{flex:1; margin-top: 0}
.faq-q p{padding-top: .2rem;padding-right: 3.5rem}
.faq-q .inner:before,
.faq-a .inner:before{
content: "Q";
font-family: "neue-haas-grotesk-display", sans-serif;
font-weight: 700;
font-size: 1.5rem;
width: 2.4rem; height: 2.4rem;
display:flex;
align-items:center;
justify-content: center;
border-radius:50%;
border:.2rem solid #1a1a1a;
margin-right: 1em;
}
.faq-a .inner:before{
content: "A";
color: #fff;
background-color:#003618;
color: #F4F5F2;
border:none;
}
.faq-btn{width: 1.7rem; height: 1.7rem;
position:absolute; right: 1rem; top: 1.6rem;
}
.faq-btn:before,
.faq-btn:after{
content: "";
width: 70%; height: .2rem;
background-color: #000;
position:absolute;
top: calc(50% - .1rem);
left: 15%;
transition: transform .3s;
}
.faq-btn:after{
transform:rotate(90deg);
}
.blc-faq.open .faq-btn:after{
transform:rotate(0);
}




/*terms*/

/*privacypolicy*/

.body-terms,
.body-pp{
margin-bottom: 5rem;
}



/*////////////*/

 /*table.border*/
.blc-table  table.border {width:65rem; margin-top:.6rem;}
.blc-table  table.border th,
.blc-table  table.border td{border:1px solid; padding: .6em}
.blc-table  table.border th{white-space: nowrap; width:18rem; border-left: none; vertical-align:middle} 
.blc-table  table.border td{min-width: 11.75rem}
.blc-table  table.border td.tc{text-align:center}
.blc-table  table.border tr td:last-child{border-right: none}


