@charset "utf-8";

html {
  width: 100%;
  height: 100%;
    overflow: auto
}

body {
	margin: 0;padding:0;
    overflow: hidden
}

img {
  border: none;
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}

a:hover img {
    opacity: 0.7;
    transition: 0.3s;
}


.contents {
  clear: both;
  overflow: hidden;
  padding: 50px 0px; /*上下、左右へのボックス内の余白*/
}


/*メイン画像
---------------------------------------------------------------------------*/

.main-box img {
	position: relative;
	width: 100%;
	height: 750px;
	object-fit: cover;
}

.main-logo-img img {
	width: 400px;
	height: 100%;
}

.main-logo-text {
position: absolute;
top: 45% ;
left: 25%;
transform: translate(-50%,-50%);
  color: #fff;
  font-size: 35px;
  text-align: left;
  line-height: 1.5;
  letter-spacing: .2em;
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
}



/*inner共通
---------------------------------------------------------------------------*/
.inner {
  max-width: 1200px; /*サイトの最大幅　※下の方の「画面幅1200px以上の設定」にも関連するので変更の際は注意して下さい。*/
  margin: 0 auto;
}

p {
  margin: 0 0 5px;
}
p.lead {
  font-weight: 100;
}

ul, figure {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline
}
ol, ul {
  list-style: none
}


a {
  color: #000;
  -webkit-transition: all .2s ease-in-out;
  -moz-transition: all .2s ease-in-out;
  transition: all .2s ease-in-out;
  text-decoration: none;
}
a:hover, a:focus {
  text-decoration: none;
  color: #483f3a;
}
a.anchor {
  display: block;
  padding-top: 70px;
  margin-top: -70px;
}
/* misc */
hr {
  margin-top: 5px;
}
hr.bold {
  border-top: 2px solid #000;
}


.obi-text {
position: absolute;
top: 45% ;
left: 50%;
transform: translate(-50%,-50%);
color: #ffffff;
font-size: 34px;
letter-spacing: 5px;
}


.obi-text_s {
position: absolute;
top: 60% ;
left: 50%;
transform: translate(-50%,-50%);
color: #ffffff;
font-size: 19px;
letter-spacing: 5px;
}
 .menu_title1 {
        writing-mode: vertical-rl;
     font-size: 30px;
     letter-spacing: 20px;
     color: #48583b;
     text-align: center;
     margin: 0 auto;
    }

 .menu_title2 {
     font-size: 16px;
     letter-spacing: 10px;
     color: #48583b;
     text-align: center;
    }

.button01 a {
    background: #ffffff;
    border: solid 1px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 20px auto;
    max-width: 240px;
    padding: 10px 25px;
    color: #000000;
    transition: 0.3s ease-in-out;
    z-index:0;
}
.button01 a:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 0;
    display: block;
    background: #48583b;
    transition: .3s;
    left:0;
}
.button01 a:hover {
    color: #FFF;
    border: solid 1px #48583b;
}
.button01 a:hover:before {
    width: 100%;
    z-index: -1;

}

.button02 a {
    background: #ffffff;
    font-size: 13px;
    border: solid 1px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    max-width: 240px;
    padding: 5px 10px;
    color: #000000;
    transition: 0.3s ease-in-out;
    z-index:0;
    margin: 10px 0px;
}
.button02 a:before {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 0;
    display: block;
    background: #48583b;
    transition: .3s;
    left:0;
}
.button02 a:hover {
    color: #FFF;
    border: solid 1px #48583b;
}
.button02 a:hover:before {
    width: 100%;
    z-index: -1;

}

.bg-white {
    background-color: #ffffff;
    padding: 100px 0px;
}

.bg-white_l {
    background-color: #ffffff;
    padding: 100px 0px 30px 0px;
}

.bg-gray {
    padding: 100px 0px;
    background-color: #ecedee;
  background-image: url("../images/bg-gray.png");
     background-size: cover;
}

.bg-white_k {
    background-color: #ffffff;
    padding: 50px 0px;
}


/*足跡
---------------------------------------------------------------------------*/
.scroll_up1 {
  transition: 0.8s ease-in-out;
  transform: translateY(30px);
  opacity: 0;
    margin-left: 100px;
}
.scroll_up1.on {
  transform: translateY(0);
    opacity: 1.0;
}

.scroll_up2 {
  transition: 1.5s ease-in-out;
  transform: translateY(30px);
  opacity: 0;
}
.scroll_up2.on {
  transform: translateY(0);
  opacity: 1.0;
}
     
.scroll_up3 {
  transition: 2.3s ease-in-out;
  transform: translateY(30px);
  opacity: 0;
    margin-left: 100px;
}
.scroll_up3.on {
  transform: translateY(0);
  opacity: 1.0;
}
    
.scroll_up4 {
  transition: 3.1s ease-in-out;
  transform: translateY(30px);
  opacity: 0;
}
.scroll_up4.on {
  transform: translateY(0);
  opacity: 1.0;
}

/*------------------------*/
/*------------------------*/
/*------- layout -------*/
ul.box {
  width: 80%;
  max-width: 300px;
  margin: 0 auto;
  list-style: none;
    margin-top: -500px;
    margin-left: -100px;
}
ul.box li {
  margin-bottom: 50px;
  }


table.t-sns {
	width:500px;
    margin: 50px auto 0;
    padding: 0px;
}
table.t-sns td {
	width:33%;
}

table.bn_t {
    margin: 20px auto 0px;
    padding: 0px;
}

.insta_title {
    font-size: 30px;
    margin: 20px 0;
    font-weight: bold;
}

/*NEWS
---------------------------------------------------------------------------*/
.news_text {
    font-size: 17px;
}

.news_text a:hover {
    color: #274e2c;
}

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

.k-title-img {
    margin-top: -250px;
    text-align: center;
    z-index: 99999999;
    
}

.kobi {
  font-size: 30px;
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
letter-spacing: 3px;
    margin-bottom: 10px;   
}

.title2 {
  font-size: 30px;
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
}

.t-title{
  font-size: 20px;
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
letter-spacing: 1px;
    margin-right: 30px; 
}

.ktable td {
  padding: 15px 0;   
}

.flex {
	display: flex;
}

#service1 ul {
	margin: 0;
	padding: 0;
    flex-direction: row;
    justify-content: space-between;
    flex-wrap: wrap;
}

#service1 ul li:nth-of-type(2){
	transition-delay: .7s;
}
#service1 ul li:nth-of-type(3){
	transition-delay: 1s;
}
#service1 ul li:nth-of-type(4){
	transition-delay: 1.5s;
}


#service2 ul {
	margin: 0;
	padding: 0;
    flex-direction: row;
    justify-content: space-between;
    flex-wrap: wrap;
}

#service2 ul li:nth-of-type(2){
	transition-delay: .7s;
}
#service2 ul li:nth-of-type(3){
	transition-delay: 1s;
}
#service2 ul li:nth-of-type(4){
	transition-delay: 1.5s;
}

.wrap{
	clear: both;
	width: 100%;
}

img.service{
	width: 100%;
	height: auto;
}

img.service-title{
	margin-bottom: 30px;
}

@media only screen and (min-width: 1024px){
	/* SEC02 MESSAGE
	-----------------*/
	.bg{
		width: 47%;
		float: left;
		display: table;
		margin-bottom: 0px;
	}
    
    .txt {
		width: 40%;
		float: left;
		display: table;
		margin-bottom: 0px;
	}
    
	#sec02_02 .txt, #sec02_02 .bg{
		float: right;
	}

	.vMid{
		display: table-cell;
		padding: 0 70px;
		vertical-align: middle;
	}
	.vMid p{
		line-height: 2;
	}
	
}

@media screen and (max-width: 1024px) {
	.wrap{
	clear: both;
	width: 95%;
		margin: 0 auto;
}
    .txt{
		width: 90%;
        margin: 0 auto;
	}
	}

.titleimg{
  position: relative;
  text-align: center;
padding-top: 90px;
}
.titleimg img.imagup{
  position: absolute;
  top:57%;
  left: 50%;
  transform: translate(-50%,-50%);
  color: #fff;
  filter: drop-shadow(2px 2px 3px #000);
}

.titleimg_text {
  position: absolute;
  top:57%;
  left: 50%;
  transform: translate(-50%,-50%);
  color: #fff;
     filter: drop-shadow(2px 2px 3px #000);
    writing-mode: vertical-rl;
    letter-spacing: 3px;
    font-size: 22px;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
}

/*観光情報
---------------------------------------------------------------------------*/
.tourism-title {
    font-size: 20px;
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
letter-spacing: 1px;
    margin: 10px 0px;
}

.tourism-text {
    font-size: 15px;
letter-spacing: 1px;
    margin-bottom: 10px;
}

/*施設案内
---------------------------------------------------------------------------*/

.facility-title {
    font-size: 20px;
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
letter-spacing: 1px;
    margin: 20px 0px 10px;
    border-bottom: 1px solid;
}

.facility-text {
    font-size: 15px;
letter-spacing: 1px;
    margin-bottom: 10px;
    line-height: 1.8;
}

.kobi2 {
  font-size: 30px;
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
letter-spacing: 3px;
    margin-bottom: 30px;
    text-align: center;
}

table.ktable_s {
    width: 700px;
    margin: 0px auto;
}

table.ktable_s td {
    padding: 20px;
    border-bottom: 1px dotted;
    
}

table.ktable_s td.left {
    font-weight: 700;
    width: 40%;
}

table.ktable_m {
    width: 100%;
    margin: 0px auto 50px;
    border-collapse: collapse;
}

table.ktable_m th {
    border: 1px solid;
    padding: 20px;
    margin: 0px;
    
}

table.ktable_m td {
    border: 1px solid;
    padding: 20px;
    margin: 0px;
}

table.ktable_r {
    width: 700px;
    margin: 0px auto;
}

table.ktable_r td {
    padding: 20px;
    border-bottom: 1px dotted;
    
}

table.ktable_r td.left {
    font-weight: 700;
    width: 20%;
}

/*宿泊プラン
---------------------------------------------------------------------------*/

table.ktable_p {
    width: 700px;
    margin: 0px auto 50px;
}

table.ktable_p td {
    padding: 20px;
    border-bottom: 1px dotted;    
}

table.ktable_p td.left {
    font-weight: 700;
    width: 45%;
}

.k-p1 {
    font-weight: normal;
    font-size: 15px;
    color: #cc0000;
}

.k-p2 {
    font-weight: 700;
    font-size: 22px;
    color: #cc0000;
}

.kobi2_c-title {
    font-size: 18px;
    letter-spacing: 0px;
}

.p-subtitle {
    font-weight: normal;
    font-size: 15px;
    letter-spacing: 0px;
}

/*お部屋
---------------------------------------------------------------------------*/
/*メニューブロック全体*/

.p-media-content__heading{
  border-left: 1px solid;
}

  .p-list-room__block {
    margin: 2vw 0
  }
  .p-list-room__block .c-heading-section {
    margin-bottom: 3vw
  }

.c-text {
  font-size: 18px;
    line-height: 2;
    font-family: serif;
}

.c-text2 {
  font-size: 15px;
    line-height: 2;
    font-family: serif;
}


/*埋め込みインスタ
---------------------------------------------------------------------------*/
.iframe_insta {
    width: 1200px;
    height: 670px;
}

/*フッターメニュー
---------------------------------------------------------------------------*/
/*メニューブロック全体*/

.bg-footer {
    padding: 20px 0px;
  background-color: #48583b;
  color: #ffffff;
}

#footermenu {
	margin: 0 !important;
	padding: 20px;		/*ブロック内の余白*/
	text-align: center;	/*テキストを中央に*/
	font-size: 0.8rem;	/*文字サイズ。bodyのfont-sizeの80%です。*/
    background-color: #48583b;
    color: #ffffff;
    line-height: 1.5;
    
}

/*メニュー１個あたり*/
#footermenu li {
	display: inline-block;	/*簡易的に横並びにする*/
	padding: 0 30px;		/*上下、左右への余白*/
    color: #ffffff;
    border-right: 1px solid #ffffff;
    line-height: 1;
    letter-spacing: 2px;
}

#footermenu li:last-child {
    border-right: none;
}

#footermenu li a {
    color: #ffffff;  
    margin: 0px;
    padding: 0px;
}

.f-text {
    font-size: 12px;
    text-align: center;
    color: #ffffff;
}

.logo_text {
    font-size: 12px;
    text-align: center;
    color: #ffffff;
    margin: 10px 0;
}

.footer_tel {
    font-size: 30px;
    text-align: center;
    color: #ffffff;
    margin: 10px 0;
    font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
    letter-spacing: 2px;
}

.pc {
  display: block !important;
}
.sp {
  display: none !important;
}

@media screen and (max-width: 1280px) {
    .inner {
  max-width: 90%;
  margin: 0 auto;
}
    
/*埋め込みインスタ
---------------------------------------------------------------------------*/
.iframe_insta {
    width: 100%;
  margin: 0 auto;
    height: 670px;
}
  
.titleimg img.imagup{
  position: absolute;
  top:50%;
  left: 50%;
  transform: translate(-50%,-50%);
  color: #fff;
  filter: drop-shadow(2px 2px 3px #000);
    width: 50px;
}
    
}
@media only screen and (max-width: 1024px) {
  .pc {
    display: none !important;
  }
  .sp {
    display: block !important;
  }
  
html {
  font-size: 15px;
    line-height: 2;
    letter-spacing: 1px;
}
    
.inner {
  width: 95%;
  margin: 0 auto;
}
    
.button01 a {
    background: #ffffff;
    border: solid 1px;
    position: relative;
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 50px auto;
    max-width: 240px;
    padding: 10px 25px;
    color: #000000;
    transition: 0.3s ease-in-out;
    z-index:0;
}
    
 .blog_img {
    width: 240px;
} 

    
/*メイン画像
---------------------------------------------------------------------------*/

.main-box img {
	position: relative;
	width: 100%;
	height: 350px;
	object-fit: cover;
}

.main-logo-img img {
	width: 100%;
	height: 100%;
}

.main-logo-text {
    width: 100%;
position: absolute;
top: 22% ;
left: 55%;
transform: translate(-50%,-50%);
  color: #fff;
  font-size: 19px;
  text-align: left;
  line-height: 1.5;
  letter-spacing: .2em;
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
}
  
  
    
    
/*下層
---------------------------------------------------------------------------*/
    
.bg-white {
    background-color: #ffffff;
    padding: 20px 0px;
}
 
.bg-white_l {
    background-color: #ffffff;
    padding: 20px 0px;
}
    
.bg-gray {
    padding: 20px 0px;
}
    
.titleimg{
  margin-top: -30px;
}
    
.titleimg img.imagup{
  position: absolute;
  top:72%;
  left: 50%;
  transform: translate(-50%,-50%);
  color: #fff;
  filter: drop-shadow(2px 2px 3px #000);
    width: 100px;
}
    
.titleimg_text {
    writing-mode: horizontal-tb;
    letter-spacing: 5px;
    font-size: 22px;
    top:70%;
  left: 50%;
}
    
.kobi {
  font-size: 20px;
letter-spacing: 3px;
    margin-bottom: 10px;   
}
  
.kobi2 {
  font-size: 20px;
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
letter-spacing: 3px;
    margin-bottom: 5px;
    text-align: center;
}
    
.t-title{
  font-size: 18px;
letter-spacing: 1px;
    margin-right: 10px; 
}

.title2 {
  font-size: 22px;
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
}
    
.ktable tr {
    display: block;
  padding: 5px 0;   
}
    
.ktable td {
    display: block;
  padding: 0px 0;   
}
 
table.ktable_s {
    width: 100%;
    margin: 0px auto;
    font-size: 13px;
}

table.ktable_s td {
    padding: 10px;
    border-bottom: 1px dotted;
    
}

table.ktable_s td.left {
    font-weight: 700;
    width: 50%;
}
    
table.ktable_m {
    width: 100%;
    margin: 0px auto 50px;
    border-collapse: collapse;
    font-size: 13px;
}

table.ktable_m th {
    border: 1px solid;
    padding: 5px;
    margin: 0px;
    
}

table.ktable_m td {
    border: 1px solid;
    padding: 5px;
    margin: 0px;
}
  
table.ktable_r {
    width: 100%;
    margin: 0px auto;
    font-size: 13px;
}

table.ktable_r td {
    padding: 10px;
    border-bottom: 1px dotted;
    
}

table.ktable_r td.left {
    font-weight: 700;
    width: 30%;
}
    
    
/*観光情報
---------------------------------------------------------------------------*/
.tourism-title {
    font-size: 20px;
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
letter-spacing: 1px;
    margin: 0px 0px;
}

.tourism-text {
    font-size: 15px;
letter-spacing: 1px;
    margin-bottom: 10px;
}
    
/*宿泊プラン
---------------------------------------------------------------------------*/

table.ktable_p {
    width: 100%;
    margin: 0px auto 20px;
}

table.ktable_p td {
    padding: 10px;
    border-bottom: 1px dotted;    
}

table.ktable_p td.left {
    font-weight: 700;
    width: 45%;
}

.k-p1 {
    font-weight: normal;
    font-size: 15px;
    color: #cc0000;
    line-height: 0.5;
}

.k-p2 {
    font-weight: 700;
    font-size: 22px;
    color: #cc0000;
}

.kobi2_c-title {
    font-size: 18px;
    letter-spacing: 0px;
}

.p-subtitle {
    font-weight: normal;
    font-size: 15px;
    letter-spacing: 0px;
}
  
/*お部屋
---------------------------------------------------------------------------*/

.p-list-room__block {
    margin: 10px 0;
  }
  .p-list-room__block .c-heading-section {
    margin-bottom: 10px;
  }
    
.p-media-content__heading{
  margin-bottom: -30px;
    border-left: none;
}
    
.c-heading-vertical__jp {
    font-weight: normal;
    font-size: 20px;
    margin: 0px;
}
 
.c-text {
  font-size: 15px;
    line-height: 2;
    font-family: serif;
}
    
.c-text2 {
  font-size: 15px;
    line-height: 2;
    font-family: serif;
    width: 90%;
    margin: 0 auto;
}
  
/*埋め込みインスタ
---------------------------------------------------------------------------*/
.iframe_insta {
    width: 100%;
    height: 2000px;
}
    
/*フッターメニュー
---------------------------------------------------------------------------*/
/*メニューブロック全体*/

.bg-footer {
    padding: 20px 0px 50px;
  background-color: #48583b;
  color: #ffffff;
}
    
#footermenu {
	margin: 0 !important;
	padding: 10px;		/*ブロック内の余白*/
	text-align: center;	/*テキストを中央に*/
	font-size: 0.8rem;	/*文字サイズ。bodyのfont-sizeの80%です。*/
    background-color: #48583b;
    color: #ffffff;
    line-height: 1.5;
    
}

/*メニュー１個あたり*/
#footermenu li {
	display: inline-block;	/*簡易的に横並びにする*/
	padding: 0 15px;		/*上下、左右への余白*/
    color: #ffffff;
    border-right: 1px solid #ffffff;
    line-height: 1;
    letter-spacing: 1.5px;
}

#footermenu li:last-child {
    border-right: none;
}

#footermenu li a {
    color: #ffffff;  
    margin: 0px;
    padding: 0px;
}
.f-text {
    font-size: 10px;
    text-align: center;
    color: #ffffff;
    margin-bottom: 30px;
}
    
    
.scroll_up1 {
    margin-left: 50px;
}
    
.scroll_up3 {
    margin-left: 50px;
}

.insta_title {
    font-size: 20px;
    margin: 15px 0;
    font-weight: bold;
}
 
.insta_title img {
    width: 30px;
}
    
ul.box {
  width: 80%;
  max-width: 300px;
  margin: 0 auto;
  list-style: none;
    margin-top: -250px;
    margin-left: 0px;
}
ul.box li {
  margin-bottom: 20px;
  }
    ul.box li img {
  width: 30px;
  }
    
table.t-sns {
	width:100%;
    margin: 50px auto 0;
    padding: 0px;
}
table.t-sns td {
	width:33%;
} 
}

@media only screen and (max-width: 430px) {
    
.main-logo-text {
    width: 100%;
position: absolute;
top: 40% ;
left: 55%;
transform: translate(-50%,-50%);
  color: #fff;
  font-size: 19px;
  text-align: left;
  line-height: 1.5;
  letter-spacing: .2em;
  font-family: YuMincho, "Yu Mincho", "Hiragino Mincho ProN", "serif";
}
    
    /*埋め込みインスタ
---------------------------------------------------------------------------*/
.iframe_insta {
    width: 100%;
    height: 960px;
}
    }
