@charset "utf-8";
/* CSS Document */
/*------------------------------------------------------------------
https://www.satsukibessou.com/
Last Update 2021/12/02
-------------------------------------------------------------------*/
@import url("bootstrap-reboot.min.css");

/*--------------------
Basis
--------------------*/
#coming_soon{height: 400px; padding-top: 100px; text-align: center;}

html, body {
  margin: 0;
  padding: 0;
}
body {
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
	background: url("../img/bg.gif");
	color: #433d3c;
	/*overflow-x: hidden;*/
	box-sizing : border-box;	
}
body.fixed {
	position: fixed;
	width: 100%;
	height: 100%;
	left: 0;
}
iframe{overflow: hidden;
	border: none; 
        }
br,p,span,ul{margin: 0; padding: 0;}

.wrapper{overflow-x: hidden;}

h2, h3, h4, h5, h6 {
	font-weight: 300;
	/*letter-spacing: .2rem;*/
	font-family: "Gentium Basic","Raleway","游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", Sans-serif;
	/*font-family: "Raleway", Sans-serif;*/
	/*font-family: "Playfair Display", Arial, serif;*/
	color: #634950;
	text-align: center;
}
h2{font-size: 2.5rem;}
h2 .sttl{font-size: 1rem; font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;}
h3 .sttl{font-size: 1rem; font-family: "Gentium Basic","Raleway","游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", Sans-serif;}
h2{margin-bottom: 30px;}
h2.ttl {line-height:1;}
.clear{clear: both;}
/*img {margin: 0; padding: 0;}*/
@media screen and (min-width: 769px){	
  .br-pc { display:block; }
  .br-sp { display:none; }
}
/* スマートフォンで見たときは"sp"のclassがついた画像が表示される */
@media screen and (max-width: 768px){	
  .br-pc { display:none; }
  .br-sp { display:block; }
}
li{list-style: none;}
#main-contents a:link,#sticky a:link{color: #771144; text-decoration: none;}
#main-contents a:visited,#sticky a:visited{color: #A2525A; opacity: 0.7; text-decoration: none;}
#main-contents a:hover,#sticky a:hover{color: #BB5555; opacity: 0.7; text-decoration: none;}
#main-contents a:active,#sticky a:active{color: #650E39; text-decoration: none;}
.no-gutters {
  margin:0;
  padding:0;
}
 
.no-gutters　> .col,
.no-gutters　> [class*="col-"] {
  margin:0;
  padding:0;
}
@media screen and (max-width: 768px) {
/*↓カラム間のガター幅が5px、カラムの左右の余白が5pxになる*/
.o-2column .col-6 { padding: 0 5px;}
.o-2column {margin: 0 -5px;}
.o-3column .col-md-4 { padding: 0 5px;}
/*カラムの左右の余白を15pxに戻す*/
.o-3column {margin: 0 -5px;}

.o-4column .col-md-3 { padding: 0 5px;}
.o-4column {margin: 0 -5px;}

.o-6column .col-md-2 { padding: 0 5px;}
.o-6column {margin: 0 -5px;}
}
.js-fadein {
  opacity: 0; 
  visibility: hidden;
  transform: translateY(40px);
  transition: all 1s;
}
.js-fadein.is-show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0px);
}
.pannellum_wrap h4{margin-top: 30px;}
.youtube,.pannellum {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
	margin-bottom: 10px;
}
.youtube iframe,.pannellum iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
	border: none;
}
.fa-tripadvisor::before {
content: url("../img/i_f262.png");

}
.more_plan {
    width: 100%;
    margin: 10px auto 0 auto;
    text-align: center;
}
.more_warp {
    width: 100%;
    display: block;
    margin: 10px 0;
    text-align: left;
	
}
.more_warp2 {
    width: 100%;
    display: block;
    margin: 10px 0 10px 0;
    text-align: left;
	
	
}
.more_btn1 {
    width: 300px;
    display: block;
    padding: .8em;
    border: 1px solid #771144;
    margin: 10px auto;
    text-align: center;
    
}
.more_btn2 {
    width: 300px;
    display: block;
    padding: .8em;
    border: 1px solid #771144;
    margin: 10px 0;
    text-align: center;
    
}
.more_btn3 {
    width: 300px;
    display: block;
    padding: .8em;
    border: 1px solid #771144;
    margin: 20px auto;
    text-align: center;
    
}
.more {
    font-size: 0.9rem;
}
.more1 {
    font-size: 0.9rem;
	padding: 20px 0;
}
.more img,.more1 img {
	width: 30px;
	height: 6px;
	padding-bottom: 2px;
	margin-left:10px;
}


.more p:hover img, .more1 p:hover img{
    transform: translateX(7px);
    transition: all 0.1s;
}
.more p img:hover, .more1 p img:hover {
    transform: none;
}

.more a,.more1 a p{
    color: #771144;
    text-decoration: none;
}
.more a:visited,.more1 a:visited p {
    color: #A54348;
    opacity: 0.7;
    text-decoration: none;
}
.more a:hover,.more1 a:hover p{
    color: #BB5555;
    opacity: 0.7;
    text-decoration: none;
}
.more a:active,.more1 a:active p {
    color: #6C2C2F;
    text-decoration: none;
}

.btn1 {
  position: relative;
width: 180px;
	height: auto;
  display: block;
  padding: .9em 1em;
  margin: 5px auto 0 auto;
  border: 1px solid rgba(171,105,83,0.3);
  text-align: center;
  text-decoration: none;
  transition: all .3s;
	font-size: 0.9rem;
	color: #AB6953;
}
.btn1_on {
  position: relative;
width: 180px;
	height: auto;
  display: block;
  padding: .9em 1em;
  margin: 5px auto 0 auto;
	border: 1px solid rgba(171,105,83,1);
  text-align: center;
  text-decoration: none;
  transition: all .3s;
	font-size: 0.9rem;
	color: #AB6953;
}
.btn2 {
  position: relative;
width: 210px;
	height: auto;
  display: block;
  padding: .9em 1em;
  margin: 5px auto 0 auto;
  border: 1px solid rgba(171,105,83,0.3);
  text-align: center;
  text-decoration: none;
  transition: all .3s;
	font-size: 0.9rem;
	color: #AB6953;
}
.btn2_on {
  position: relative;
width: 210px;
	height: auto;
  display: block;
  padding: .9em 1em;
  margin: 5px auto 0 auto;
	border: 1px solid rgba(171,105,83,1);
  text-align: center;
  text-decoration: none;
  transition: all .3s;
	font-size: 0.9rem;
	color: #AB6953;
}
.btn1:hover,.btn1_on:hover,.btn2:hover,.btn2_on:hover {
  border:1px solid rgba(171,105,83,1);
  color: #AB6953;
	text-decoration: none;
}
.txt_red01{color: #C00;}
.txt_pink01{color: #e9546b; font-weight: bold; font-size: 1.2rem;}
.under{ background: linear-gradient(transparent 70%, #ffadad 70%);
  font-weight: bold;
border-radius: 4px;}
/*--------------------
Contacts
--------------------*/
header{z-index: 20;}
.header-wrap{position: absolute; background: url("../img/bg_header.png") repeat-x; background-position: 0 0; z-index: 20; width: 100%; height: 200px;}
.header-wrap2{position: absolute; background: url("../img/bg_header.png") repeat-x; background-position: 0 0; background-color: #000; z-index: 15; width: 100%; height: 150px;}
#header-container{ position: absolute; width: 100%; margin:0; padding: 0; background-position: 0% 50%; background-size: cover; height: auto;} 

#reserve { font-size: .9rem; width: 100%; height: auto; position: absolute; top: 0px; right: 50px; clear: both; /*z-index: 100;*/}
#reserve #lng{position: absolute; top: 10px; right: 150px; z-index: 100;}
#reserve a.lng{ font-size: 0.8rem; display: inline-block;  width: 190px; height: 40px; text-decoration: none; color:#FFF; border: 1px solid #FFF; text-align: center; line-height: 40px;
  background-position: left 10px center, 0 0;
  background-size: 16px 16px, contain;}
#reserve a.lng:hover{text-decoration: none; background-color:#000; color: #FFF; border-color:#000; }
#reserve #group{position: absolute; top: 10px; right: 350px;}
#reserve a.group{ font-size: 0.8rem; display: inline-block;  width: 100px; height: 40px; text-decoration: none; color:#FFF; border: 1px solid #FFF; text-align: center; line-height: 40px; background-position: left 10px center, 0 0;
  background-size: 16px 16px, contain; }
#reserve a.group:hover{text-decoration: none; background-color:#000; color: #FFF; border-color:#000; }


#reserve .res{display: block; position: fixed; right: 50px; top: 0px; color: #FFF; background-color: #771144; width: 142px; height: 50px; line-height: 3; text-align: center; z-index: 100;}
#reserve .res a{ display: block; text-decoration: none; color: #FFF;}
#reserve .res a:hover{display: block; text-decoration: none; color: #FFF; opacity: 0.5 ; }

#contact {width: auto; height:auto; position: absolute; top: 150px; right: 5px;}

#contact .sec i{font-size: 1.2rem; line-height: 1.5; padding-right: 10px; display: flex;
    align-items: center;
    justify-content: center; z-index: 20;}

#contact .sec a{color:#FFF; text-decoration: none;}
#contact .sec a:hover{ text-decoration: none; color: #FFF;}
#contact .sec a:hover i{opacity: 0.7 ;}
#late_bn{position: absolute; z-index: 3; bottom:5%; /*left:20px;*/ right:20px;}
.late_bn_inner{ background-color: rgba(0,0,0,0.5); padding: 10px;}
.late_bn_inner2{ background-color: rgba(0,0,0,0.5);}
/* gnav
------------------------------------------------------------------- */
#gnav-section {
	width: 100%;
	font-family: "Playfair Display", Arial, serif;
	font-size: 0.9rem;
	position: absolute;
	z-index: 30;
	
}
#gnav-section-inner {
padding-top: 80px;
	padding-right: 10px;
	margin:0 auto;
	text-align: center;
}

#gnav li {
	width: 115px;
	float: right;
	height: 35px;
	padding: 0px 20px;
	text-decoration: none;
	
}

#gnav li a {
	
	display: block;
	overflow: hidden;
	color: #FFF;
	text-decoration: none;
	
	
}

/* navbar-nav下線アニメーション */
#gnav ul {
  display: flex;
 
}
#gnav li {
  padding: 5px;
}
#gnav a {
  display: block;
  padding: 0 0 20px;
  position: relative;
  text-decoration: none;
}
#gnav a::before,
#gnav a::after {
  border-bottom: solid 1px #FFF;
  bottom: 0;
  content: "";
  display: block;
  position: absolute;
  transition: all .3s ease;
  -webkit-transition: all .3s ease;
  width: 0;
}
#gnav a::before {
  left: 50%;
}
#gnav a::after {
  right: 50%;
}
#gnav a:hover::before,
#gnav a:hover::after {
  width: 50%;
}
#gnav .nav-on a{
	display: block;
  
  position: relative;
  text-decoration: none;
	
	
}
#gnav .nav-on a::before,
#gnav .nav-on a::after{
	border-bottom: solid 1px #FFF;
  bottom: 0;
  content: "";
display: block;
  position: absolute;
  transition: all .3s ease;
  -webkit-transition: all .3s ease;
  width: 100%;
}
#gnav .nav-on a::before {
  left: 0%;
}
#gnav .nav-on a::after {
  right: 0%;
}
#gnav .nav-on a:hover::before,
#gnav .nav-on a:hover::after {
  width: 100%;
}
/*menu*/
.menu_btn {
    display: block;
    position: fixed;    /* bodyに対しての絶対位置指定 */
    right: 0px;
    top: 0px;
	width: 50px;
	height: 50px;
	cursor: pointer;
    text-align: center;
	background-color: #000;
	z-index: 190;
}
.menu{
    height: 20px;
    position: fixed;
    right: 10px;
    top: 15px;
    width: 30px;
    z-index: 199;	
}
.menu__line{
    background: #fff;
    display: block;
    height: 2px;
    position: absolute;
    transition:transform .3s;
    width: 100%;
	
}
.menu__line--center{
    top: 9px;
}
.menu__line--bottom{
    bottom: 0;
}
.menu__line--top.active{
    top: 8px;
    transform: rotate(45deg);
}
.menu__line--center.active{
    transform:scaleX(0);
}
.menu__line--bottom.active{
    bottom: 10px;
    transform: rotate(135deg);
}
/*gnav*/
.gnav{
    background: rgba(67,61,60,0.9);
    display: none;
    height: 100%;
    position: fixed;
    width: 100%;
    z-index: 98;
	
}
.gnav__wrap{
    overflow-y: auto !important; 
   /*align-items:center;*/
	display: flex;
    height: 100%;
    justify-content: center;
    position: absolute;
    width: 100%;
	
	
}

.gnav__menu__item{
    margin: 20px 0;
	text-decoration: none;
}

.gnav__menu__item a{
    color: #fff;
    font-size: 1rem;
    font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
	/*font-family: "Playfair Display", Arial, serif;*/
    /*padding: 5px;*/
    text-decoration: none;
    transition: .5s;
	display: block;

}
.gnav__menu__item a:hover{
    color: #666;
}
.gnav_foot {
	font-size: 0.8rem;
	align-items:center;
    text-align: center;
    height: auto;
    justify-content: center;
	width: 100%;
	color: #FFF;
	line-height: 2.4;
}

.gnav_foot .logo{width: 168px; height: auto; margin: 10px auto;}
.gnav_lng {
	/*
    
height: auto;
    
    position: absolute;
	bottom: 25%;
	width: 100%;*/
	font-size: 0.9rem;
	align-items:center;
	justify-content: center;
	text-align: center;

}

.gnav_lng li{
	display: inline-block;
	line-height: 2;
	margin-bottom: 5px;
	/*text-align: left;*/
}
.gnav_lng li::before {
	 font-family: "Font Awesome 5 Free";
   content: "\f35d";
	font-weight: 900;
	color: #FFF;
	margin-left: .5em;  
  margin-right: .5em; 
  	
}
.gnav_lng a{ color: #FFF; text-decoration: none; transition: .5s;}
.gnav_lng a:hover{ color: #666; }

.container{overflow: hidden; margin: 0 auto;}
#container2{overflow:visible;}
#slide_sec{position: relative; overflow: hidden; }
.carousel-item .img-fluid {
  width:100%;
  height:100vh;
	object-fit: cover;
}

.carousel-item{
  height: auto;
background-color: #000;
	
}
.carousel-item img {
  opacity: 0.7;
}

.carousel-item a {
  display: block;
  width:100%;
}


#carousel-1{
width:100%; overflow: hidden;}
#carousel-1 .carousel-caption{
position: absolute;
top: 60%;
left: 50%;
-ms-transform: translate(-50%,-60%);
-webkit-transform: translate(-50%,-60%);
transform: translate(-50%,-60%);
margin:0;
padding:0;
z-index: 10;
color: #fff;
text-align: center;
font-size: 2.5rem;
font-weight: 400;
line-height: 1.2;
font-family: "Playfair Display", Adobe Garamond Pro, serif;
	width: 100%;
	}

#main-contents{padding-top: 50px; background: url(../img/bg.gif); overflow-x: hidden;}

.navbar-brand{position: absolute; top:10px; left:20px;}

@media (min-width: 576px) {
/* sm */


}
   
@media (min-width: 768px) {
/* md */

}
   
@media (min-width: 992px) {
/* lg */

	
}
   
@media (min-width: 1200px) {
/* xl */

	
}
@media only screen and (max-width: 767px) {
	h2{font-size: 2rem;}
  /*.carousel-item img {
	  width: 100%;
	  height: 400px;
object-fit: cover;
  }*/
.pannellum_wrap h4{font-size: 1rem;}
#carousel-1 .carousel-caption{

font-size: 1.6rem;
font-weight: 300;
white-space: nowrap;
	
	
	}
.carousel-indicators li {
    box-sizing: content-box;
    -ms-flex: 0 1 auto;
    flex: 0 1 auto;
    width: 30px;
    height: 3px;
    margin-right: 3px;
    margin-left: 3px;
    text-indent: -999px;
    cursor: pointer;
    background-color: #fff;
    background-clip: padding-box;
    border-top: 10px solid transparent;
    border-bottom: 70px solid transparent;/*インジケーター位置*/
    opacity: .5;
    transition: opacity .6s ease
}	
	.gnav .gnav__wrap .container{padding-top: 50px; overflow-y: auto !important;}
	li.gnav__menu__item { padding-bottom: 10px; border-bottom: 1px #666 solid;}
	.gnav__menu__item{font-size: 90%;}
	
	/*.slide_left{ display: none;}*/
	#group,#lng,#gnav-section{display: none;}

	
.navbar-brand{position: absolute; top:5px; left:10px; width: 150px; height: auto;}
	#late_bn{ width: 110px; height: 110px; position: absolute; z-index: 3; bottom:30%; left:10px; /*right: 10px;*/ }
	.late_bn_inner{ background-color: rgba(0,0,0,0.5); padding: 5px;}
.late_bn_inner2{ background-color: rgba(0,0,0,0.5);}
	#contact {width: auto; height:auto; position: absolute; top: 60px; right: 5px;}
	.header-wrap2{ height: 100px;}
}

@media (max-width: 1020px) and (min-width: 768px){
  /*.carousel-item img {
	  width: 100%;
	  height: 600px;
object-fit: cover;  
  }*/
	#gnav-section-inner {
padding-top: 120px;
}

}
/*--------------------
Main
--------------------*/
#mainvisual,#mainvisual1,#mainvisual2,#mainvisual3,#mainvisual4{width: 100%;
  height: auto;
  padding-top: calc(300 / 1920 * 100%); /* calc(画像高さ ÷ 画像横幅 × 100%) */
	margin-top: 130px;
}
@media screen and (max-width:767px) {
	#mainvisual,#mainvisual1,#mainvisual2,#mainvisual3,#mainvisual4  {
width: 100%;
		margin-top: 100px;
	  min-height: 100px;
object-fit: cover;
	}
.img_box1{margin-bottom: 10px;}
.img_box2{margin-bottom: 20px;}
.img_box3{margin-bottom: 30px;}

}
.breadcrumb-wrap {
	background-color: #EAE5E3;
width: 100%;
	margin: -50px 0 50px 0;
	font-size: 90%;
}
.breadcrumb {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  padding: 0.75rem 1rem;
  margin-bottom: 1rem;
  list-style: none;
  background-color: #EAE5E3;
  border-radius: 0.25rem;
}

.breadcrumb-item + .breadcrumb-item {
  padding-left: 0.5rem;
}

.breadcrumb-item + .breadcrumb-item::before {
  display: inline-block;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
  padding-right: 0.5rem;
  color: #433d3c;
  content: "\f105";
}

.breadcrumb-item + .breadcrumb-item:hover::before {
  text-decoration: underline;
}

.breadcrumb-item + .breadcrumb-item:hover::before {
  text-decoration: none;
}

.breadcrumb-item.active {
  color: #433d3c;
}
#map{margin-bottom: 100px;}
.cap{font-size: 0.8rem; text-align:right; margin-top: 5px;}
.cap p{margin:0px; padding:0px;}
/* plan-table
------------------------------------------------------------------- */
.table>tbody>tr>td, .table>tbody>tr>th, .table>tfoot>tr>td, .table>tfoot>tr>th, .table>thead>tr>td, .table>thead>tr>th {
vertical-align: middle;
}

.plan_table01 {
	text-align: left; margin: 12px 0 36px 0; border-top: #771144 4px solid;
	line-height: 1.5; width:100%;
}
	
.plan_table01 th {
	padding: 4px; background: #e5e4e6;
	border-bottom: #ccc 1px solid; border-left: #ccc 1px solid; border-right: #ccc 1px solid;
	white-space: nowrap;
	text-align:center; font-weight: normal;}

.plan_table01 td.txt {
	padding: 4px; background: #FFF;
	
	text-align:left; font-weight: normal;}

	
.plan_table01 td {
	padding: 4px; background: #FFF;
	border-bottom: #ccc 1px solid; border-left: #ccc 1px solid; border-right: #ccc 1px solid;}

.plan_table01 td.pttl {
	padding: 0px;
	}

.plan_table01 p.btn_book{padding:5px;}
[class^="img-flex-"] {
	margin-bottom: 10px;
	display: -ms-flexbox;
    display: -webkit-box;
    display: -webkit-flex;
    display: flex;
	margin: 0 auto;
	-webkit-justify-content: center;       /* Safari etc. */
    -ms-justify-content    : center;       /* IE10        */
	justify-content: center;
	/*-webkit-justify-content: space-between;
	justify-content: space-between;*/

}

.img-flex-3 img { width: 33%; height: auto; max-width: 200px; padding: 4px; align-self: flex-start;
  }

.price_table01 .std{background:#EEEAD1; }
.price_table01 .spe{background:#D6E9CA; }
.price_table01 .dlx{background:#C1E4E9; }
.price_table01 .sui{background:#DBD0E6; }
/*.price_table01 th.rt,.price_table02 th.rt{background-color: #FF2626; color: #FFF;}
.price_table01 th.rt a:link{color: #FFF;}
.price_table01 th.rt a:visited{color: #FFF;}
.price_table01 th.rt a:hover{color: #FFF;}
.price_table01 th.rt a:active{color: #FFF;}*/
.price_table01 p,.price_table02 p{margin-bottom: 5px;}
.price_table01,.price_table02 {
	margin: 0 0 5px 0;
	border-top: #ccc 1px solid;
	text-align: left; line-height: 1.2;}
.price_table01{float: left; width: 50%;}
.price_table01 th,.price_table02 th {padding: 5px; background: #e5e4e6;
	border-bottom: #ccc 1px solid; border-left: #ccc 1px solid; border-right: #ccc 1px solid;
	text-align:center; font-weight: normal;}
.price_table01 th{
	white-space: nowrap;}	
.price_table01 td,.price_table02 td {width: 100px;
	padding: 5px; background: #fff;
	border-bottom: #ccc 1px solid; border-right: #ccc 1px solid; text-align:right;}


.comm{ font-size: 0.7rem;}
@media only screen and (max-width: 767px) {
.plan_table01,.price_table02 {
	  font-size: 0.8rem;
  }
	.price_table01{width: 100%;}
}
/*--------------------
intro-section
--------------------*/
#intro-section{margin: 50px auto;}
#intro-section2{padding: 50px 0 0 0;}
#intro-section h2,#intro-section2 h2{
	font-size: 3rem;
	margin-bottom: 50px;
	/*font-family: "Playfair Display", Adobe Garamond Pro, serif;*/
}
#intro-section #contents_nav {margin: 0 auto;}
#intro-section #contents_nav a{color: #AB6953;}
#intro-section .lead{/*font-size: 1.2rem;*/ /*font-family: "Playfair Display", Adobe Garamond Pro,serif;*/  margin-bottom: 20px;}
#intro-section .lead span{display: inline-block;}
#intro-section .and{font-size:2rem}
.section-title h3 {
	font-size: 2rem;
	/*color: #432F2F;
	font-weight: 900;
	letter-spacing: 1px;*/
	position: relative;
	padding-bottom: 30px;
	/*margin-top: 0.5rem;*/
	line-height: 1.2;
	/*font-family: "Playfair Display", Adobe Garamond Pro, serif;*/
}
.section-title h3 span{display: inline-block;}
.section-title .sub_ttl{font-size: 1.6rem; /*font-family: "Playfair Display", Adobe Garamond Pro, serif;*/}
.section-title .lead{font-size: 1.2rem; /*font-family: "Playfair Display", Adobe Garamond Pro, serif;*/ margin-bottom: 30px;}

.section-title .text {text-align: left;}




@media only screen and (max-width: 767px) {
.section-title h3 {
	  font-size: 1.6rem;
  }
.section-title .sub_ttl{font-size:1.4rem;}
.section-title .lead{ font-size: 1rem; text-align: left;}
#intro-section h2,#intro-section2 h2{
	font-size: 2.3rem;
	margin-bottom: 50px;
	/*font-family: "Playfair Display", Adobe Garamond Pro, serif;*/
}
	#intro-section .lead{font-size: 1rem;}
}
#info-section .heading-section {
	margin-bottom: 2em;
}
#info-section h3 {
	border-bottom : double 3px #C9A696;
	padding-bottom: 0.5em;
	text-align: center;
}
#info-section dl {
	width: 100%;
	height: auto;
	border-bottom: 1px dotted #333;

	margin:0 auto 0.5em auto; 
}
#info-section dl:last-child {
	width: 100%;
	height: auto;
	border-bottom: double 3px #C9A696;
	padding-bottom: 2em;
	margin:0 auto;
}

@media screen and (max-width:768px) {
.fb-wrap{margin-top: 50px;}
}
@media screen and (max-width: 480px) {
#info-section dt {
	width: 100%;
	float: none;
	height: auto;
}

}
/*--------------------
Footer
--------------------*/
#web_nav {
	width: 100%;
	font-size: 0.8rem;
	border-top: 1px solid #EAE5E3;
	text-align: center;
	line-height: 4;
}
#web_nav .line1{border-bottom: 1px solid #EAE5E3; }
#web_nav .line2{border-right: 1px solid #EAE5E3; border-bottom: 1px solid #EAE5E3; }
#web_nav p:hover{opacity: 0.7;}
#web_nav a{color: #771144; text-decoration: none;}
#web_nav a:visited{color: #A2525A; opacity: 0.7; text-decoration: none;}
#web_nav a:hover{color: #BB5555; opacity: 0.7; text-decoration: none;}
#web_nav a:active{color: #650E39; text-decoration: none;}
#footer ul{margin: 0; padding: 0;}
#footer {
	
	padding: 3em 0;
	color: #FFF;
	background:url(../img/bg_footer.jpg) center/cover no-repeat fixed;
}

#footer a {
	color: #FFF;
}
#footer a:hover, #footer a:focus,#footer i:hover{
	text-decoration: none;
	color: rgba(204, 204, 204, 1);
	
}

#footer #add h6{margin-top: 0; color: #FFF; padding-top: 0; font-family: "Playfair Display", Adobe Garamond Pro, serif; text-align: left;}
#footer #add{font-family: "Playfair Display", Adobe Garamond Pro, serif;}
#footer #logo img{width: 180px; height: auto; margin: 5px 0;}

#footer i{padding: 0 10px;}

#ftr-nav {
	width: 100%;
	text-align: center;
	font-size: 0.8rem;
	margin: 10px auto 20px auto;
}
#ftr-nav li {
	display: inline-block;
	line-height: 1;

}
#ftr-nav li+ li::before {
   content: "/";
	color: #FFF;
	margin-left: .5em;  
  margin-right: .5em; 	
} 
#ftr-nav2 {
	width: 100%;
	text-align: center;
	font-size: 0.8rem;
	margin: 0px auto 20px auto;
}
#ftr-nav2 li {
	display: inline-block;
	line-height: 1;
	margin-left: .5em;  
  margin-right: .5em;

}


#ftr-nav3 {
	width: 100%;
	text-align: center;
	margin: 0px auto 10px auto;
}

.sns_ttl{border-bottom: 1px solid #FFFFFF; width: 200px; margin: 0 auto 5px auto; letter-spacing: 0.3em; font-family: "Playfair Display", Adobe Garamond Pro, serif;}
.social-icon a {
	font-size: 1.3rem;
}
.social-icon a i {
	color: #FFF;
}
.social-icon a:hover, .social-icon a:focus {
	text-decoration: none;
}
@media only screen and (max-width: 767px) { 
	#footer {background:none} /*PC用の背景はオフ*/
body::before {
  content:"";
  display:block;
  position:fixed;
  top:0;
  left:0;
  z-index:-1;
  width:100%;
  height:100vh;
  background:url(../img/bg_footer.jpg) center/cover no-repeat; /*fixedをトル！*/
  -webkit-background-size:cover;/*Android4*/
  }
}

#footer .copy-right {
	font-size: 0.7rem;
	width: 100%;
	height: auto;
	text-align: center;
	padding: 10px 0;
	color: #FFF;
	letter-spacing: 1px;
}

/* page_top button
---------------------------------- */
#page_top{
  width: 90px;
  height: 90px;
  position: fixed;
  right: 10px;
  bottom: 10px;
  display: none;
	z-index: 200;
	

}
#page_top a{
  position: relative;
  display: block;
  width: 90px;
  height: 90px;
  text-decoration: none;
	background: #771144;
  border-radius: 50%;
	/* background color transition */
	-webkit-transition: 1s;
	-moz-transition: 1s;
	transition: 1s;
	

}
#page_top a::before{
  font-family: "Font Awesome 5 Free";
font-weight: 900;
	display: inline-block;
  content: "\f106";
  font-size: 25px;
  color: #fff;
  position: absolute;
  width: 25px;
  height: 25px;
  top: -40px;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;

}
#page_top a::after{
  content: 'PAGE TOP';
  font-size: 13px;
  color: #fff;
  position: absolute;
  top: 45px;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}
#page_top a:hover {
	-ms-filter: "alpha( opacity=80 )"; /* IE8 */
	filter: alpha( opacity=80 ); /* IE6とIE7 */
	opacity: 0.80; /* IE以外 */
	text-decoration: none;
}
@media only screen and (min-width : 320px) and (max-width : 480px) {

#page_top a {
	position: relative;
	display: block;
	width: 70px;
	height: 70px;
	margin: auto;

}
	#page_top a::before{
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
	display: inline-block;
  content: "\f106";
  font-size: 25px;
  color: #fff;
  position: absolute;
  width: 25px;
  height: 25px;
  top: -40px;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;

}
#page_top a::after{
  content: 'PAGE TOP';
  font-size: 0.7rem;
  color: #fff;
  position: absolute;
  top: 35px;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}
}
/*--------------------
scroll
--------------------*/
#scroll a {
  display: inline-block;
  position: absolute;
  /*right: 40px;*/
	left:40px;
  bottom: 0;
  z-index: 2;
  padding: 10px 10px 110px;
  overflow: hidden;
  color: #fff;
  font-size: 12px;
  font-family: 'Josefin Sans', sans-serif;
  line-height: 1;
  letter-spacing: .2em;
  text-transform: uppercase;
  text-decoration: none;
  writing-mode: vertical-lr;
}
#scroll a::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  width: 1px;
  height: 100px;
  background: #fff;
}
#scroll a::after {
  animation: sdl 2s cubic-bezier(1, 0, 0, 1) infinite;
}
@keyframes sdl {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  35% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  35.1% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  70%, 100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}
.slider-text{margin-top: 5px;}
