@charset "utf-8";
/* CSS Document */
/*------------------------------------------------------------------
https://www.mizunowo.co.jp
Last Update 2022/09/21
-------------------------------------------------------------------*/
@import url("bootstrap-reboot.min.css");

/*--------------------
Basis
--------------------*/
#coming_soon{height: 400px; padding-top: 100px; text-align: center;}
*{
font-family:"Playfair Display","Gentium Basic","Raleway","Playfair Display", Arial, serif;

}
html, body {
  margin: 0;
  padding: 0;
}
body {
	background: url("../img/bg.gif");
	color: #433d3c;
	/*overflow-x: hidden;*/
	box-sizing : border-box;	
}
body.fixed {
	position: fixed;
	width: 100%;
	height: 100%;
	left: 0;
}
br,p,span,ul{margin: 0; padding: 0;}

.wrapper{overflow-x: hidden;}

h2, h3, h4, h5, h6 {
	font-weight: 300;
	/*letter-spacing: .2rem;*/
	color: #468384;
	text-align: center;
}
h2{font-size: 2.5rem;}
#mainvisual h2{font-size: 2.5rem; position: absolute; top:130px; left:0; right:0; background: url(../img/ttl_icon.png)no-repeat; color: #FFF; background-position: center top; padding-top: 20px; line-height: .6; }
h2 .sttl,h3 .sttl{font-size: 1.2rem; letter-spacing: .2rem;}
#mainvisual h2 span{display: block; line-height: 1; padding-top: 18px;}
h3 span{display: block; line-height: 2;}
.clear{clear: both;}

ruby[data-ruby] {
    position: relative;
	line-height: 2.8;
	
}
ruby[data-ruby]::before {
    content: attr(data-ruby);
    position: absolute;
    left:-2em;
  top:-2em;
  right:-2em;
  text-align:center;
    font-size: 0.5em;
	white-space: nowrap;
	
}
rt{display: none;}
/*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,#main-contents_top a:link,#sticky a:link{color: #3A546B; text-decoration: none;}
#main-contents a:visited,#main-contents_top a:visited,#sticky a:visited{color: #787CAC; opacity: 0.7; text-decoration: none;}
#main-contents a:hover,#main-contents_top a:hover,#sticky a:hover{color: #527798; opacity: 0.7; text-decoration: none;}
#main-contents a:active,#main-contents_top a:active,#sticky a:active{color: #527798; text-decoration: none;}
.no-gutters {
  margin:0;
  padding:0;
}
 
.no-gutters　> .col,
.no-gutters　> [class*="col-"] {
  margin:0;
  padding:0;
}

.js-fadein {
  opacity: 0; 
  visibility: hidden;
  transform: translateY(40px);
  transition: all 1s;
}
.js-fadein.is-show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0px);
}
.pannellum_warp 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{position: relative; width: 220px; margin: 10px auto 0 auto; text-align: center;}
.more_warp1{position: relative; width: 140px; display: block; padding: .8em .2em 0 0; margin: 10px 0; text-align: left;}
.more_warp2{position: relative; width: 150px; display: block; padding: 0 .2em 0 0; margin: 10px 0; text-align: left;}
.more_warp3{position: relative; width: 190px; display: block; padding: 0 .2em 0 0; margin: 10px 0; text-align: left;}
.more_warp4{position: relative; width: 330px; display: block; padding: .8em .2em 0 0; margin: 10px 0; text-align: left;}
.more_warp5{position: relative; width: 140px; display: block; padding: .8em .2em 0 0; margin: 10px auto; text-align: left;}
.more_warp6{position: relative; width: 220px; display: block; padding: .8em .2em 0 0; margin: 10px auto; text-align: left;}
.more_warp7{position: relative; width: 240px; display: block; padding: .8em .2em 0 0; margin: 10px auto; text-align: left;}

.more_warp10{position: relative; width: 270px; display: block; padding: .8em; border: 1px solid #3A546B; margin: 10px auto; text-align: center;}

.more_warp20{width: 300px; display: block; padding: .8em; border: 1px solid #3A546B; margin: 10px auto; text-align: center; background-color:#3A546B ;}
.more_warp21{width: 300px; display: block; padding: .8em; border: 1px solid #3A546B; margin: 10px 0; text-align: center; background-color:#3A546B ;}
.more_warp22{position: relative; width: 220px; display: block; padding: .8em; border: 1px solid #3A546B; margin: 10px auto; text-align: center; background-color:#3A546B ;}
.more_warp23{position: relative; width: 240px; display: block; padding: .8em; border: 1px solid #3A546B; margin: 10px 0; text-align: center; background-color:#3A546B ;}
.more_warp24{width: 100%; display: block; padding: .8em; border: 1px solid #3A546B; margin: 10px auto; text-align: center; background-color:#3A546B ;}
.more_btn,.more1,.more2,.more3,.more4{font-size: 1rem;}
.more1 img{
    position: absolute;
    top: 5px;
    right: 13px;
}
.more2 img{
    width: 30px;
	height: 6px;
	padding-bottom: 2px;
	margin-left:10px;
}
.more3 img{
    position: absolute;
    top: 20px;
    right: 13px;
}
.more4 img{
    position: absolute;
    top: 7px;
    right: 13px;
}
.more5 img{
    position: absolute;
    top: 18px;
    right: 20px;
}
.more_btn img{
    position: absolute;
    top: 20px;
    right: 20px;
}

.more_btn p:hover img,.more1 p:hover img,.more2 p:hover img,.more3 p:hover img,.more4 p:hover img,.more5 p:hover img {
	
    transform: translateX(7px);
    transition: all 0.1s;
}

.more_btn p img:hover,.more1 p img:hover,.more2 p img:hover,.more3 p img:hover,.more4 p img:hover,.more5 p img:hover {
    transform: none;
}
.more1 a{color: #3A546B; text-decoration: none;}
.more1 a:visited{color: #787CAC; opacity: 0.7; text-decoration: none;}
.more1 a:hover{color: #527798; opacity: 0.7; text-decoration: none;}
.more1 a:active{color: #2C4B79; text-decoration: none;}
.more_btn a p,.more4 a p,.more5 a p{color: #3A546B; text-decoration: none;}
.more_btn a:visited p,.more4 a:visited p,.more5 a:visited p{color: #787CAC; opacity: 0.7; text-decoration: none;}
.more_btn a:hover p,.more4 a:hover p,.more5 a:hover p{color: #527798; opacity: 0.7; text-decoration: none;}
.more_btn a:active p,.more4 a:active p,.more5 a:active p{color: #2C4B79; text-decoration: none;}
.more2 a p,.more3 a p{color: #FFF; text-decoration: none;}
.more2 a:visited p,.more3 a:visited p{color: #eee; opacity: 0.7; text-decoration: none;}
.more2 a:hover p,.more3 a:hover p{color: #EEE; opacity: 0.7; text-decoration: none;}
.more2 a:active p,.more3 a:active p{color: #fff; 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_bottom: 1px solid rgba(58,84,107,1);
  text-align: center;
  text-decoration: none;
  transition: all .3s;
	font-size: 0.9rem;
	color: #AB6953;
}
.btn2 {
  position: relative;
width: auto;
	height: auto;
  display: block;
  padding: .9em 1em;
  margin: 5px auto 0 auto;
  border-bottom: 1px solid rgba(204,204,204,1);
  text-align: center;
  text-decoration: none;
  transition: all .3s;
	font-size: 0.9rem;
	color: #3A546B;
}
.btn2_on {
  position: relative;
width: auto;
	height: auto;
  display: block;
  padding: .9em 1em;
  margin: 5px auto 0 auto;
	border-bottom: 1px solid rgba(58,84,107,1);
  text-align: center;
  text-decoration: none;
  transition: all .3s;
	font-size: 0.9rem;
	color: #3A546B;
}
.btn1:hover,.btn1_on:hover,.btn2:hover,.btn2_on:hover {
	
  border-bottom: 1px solid rgba(58,84,107,1);
  color: #3A546B;
	text-decoration: none;
}
.button {
    text-indent: -1em;
    margin-left: 1em;
}
.button:before {
    content: '';
    display: inline-block;
    width: 0;
    height: 0;
    margin-right: 5px;
    margin-left: 5px;
    border: transparent solid 6px;
    border-left-color: #3A546B;

}
.txt_red01{color: #C00;}
.txt_pink {color: #C30039;}
.txt_pink01{color: #e9546b; font-weight: bold;}
.txt_pink02 {
	color: #F36;
	font-weight: bold;
}
.strong_or{color: #F39208; font-weight: 700;}
.under{ background: linear-gradient(transparent 70%, #ffadad 70%);
  font-weight: bold;
border-radius: 4px;}
/*--------------------------------
dropmenu_language
---------------------------------*/
#lng {
	width:140px;
	height: 40px;
	line-height: 1.8;
	float: right;
	display: inline-block;
	 z-index: 5;
margin-bottom: 50px;
	background-color: #3A614F;
	color: #fff;

}

#lng i{padding-right: 10px;}
.arrow1 {
display: block;
position: relative;
font-size: 1rem;
text-decoration: none;
}

.arrow1:after {
display: block;
content: "";
position: absolute;
top: 50%;
right: 0px;
width: 6px;
height: 6px;
margin: -4px 0 0 0;
border-top: solid 1px #fff;
border-right: solid 1px #fff;
-webkit-transform: rotate(135deg);
        transform: rotate(135deg);
}
/*--------------------------------
dropmenu_language
---------------------------------*/
#fade-in2 {
	position: relative;
	z-index: 5;
}
#fade-in2 li ul {
	opacity: 0;
	margin-top: 10px;
	visibility: hidden;
	transition: .5s;
}
#fade-in2 li:hover ul {
	top: 100%;
	visibility: visible;
	opacity: 1;
}
.dropmenu {
 *zoom: 1;
	list-style-type: none;
	width: auto;
	margin: 5px auto 30px;
	padding: 0;
}
.dropmenu:before, .dropmenu:after {
	content: "";
	display: table;
}
.dropmenu:after {
	clear: both;
}
.dropmenu li {
	position: relative;
	width: 130px;
	float: left;
	margin: 0;
	padding: 0;
	text-align: center;
}
.dropmenu li a {
	display: block;
	margin: 0;
	padding: 15px 0 11px;
	color: #333;
	line-height: 1;
	background-color: rgba( 255, 255, 255, 0.80 );
	text-decoration: none;
}
.dropmenu li ul {
	
	position: absolute;
	z-index: 9999;
	top: 100%;
	left: 0;
	margin: 0;
	padding: 0px;
}
.dropmenu li ul li {
	width: 100%;
}
.dropmenu li ul li a {
	padding: 13px 15px;
	border-bottom: 1px solid #CCC;
	text-align: center;
}
.dropmenu li:hover > a {
	color: #333;
}
.dropmenu li a:hover {
	background-color: rgba( 255, 255, 255, 1.0 );
}
* {
	box-sizing: border-box;
}
/*--------------------
Contacts
--------------------*/
header{z-index: 20;}
#header-container{ position: absolute; width: 100%; margin:0; padding: 0; background-position: 0% 50%; background-size: cover; height: auto; z-index: 50;  }
#gnav-section:before{ background-image: linear-gradient(0deg, transparent 0 60%, #000 100%);
position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	content: ' ';
height: 400px;}
#reserve { font-size: .9rem; width: 100%; height: auto; position: absolute; top: 0px; right: 50px; clear: both; z-index: 100;}
#reserve #tel{position: absolute; top: 10px; right: 160px;}
#reserve .res{display: block; position: fixed; right: 50px; top: 0px; color: #FFF; background-color: #3A546B; width: 142px; height: 50px; line-height: 3; text-align: center; }
#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-left: 100px; 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:10px; padding: 10px; /*background-color: rgba(0,0,0,0.5);*/}
#late_bn p{border-bottom: 1px dotted #FFF; padding-bottom: 5px; margin-bottom: 10px;}
/* gnav
------------------------------------------------------------------- */
#gnav-section {
	width: 100%;
	font-size: 0.9rem;
	position: absolute;
	z-index: 20;
	
}
#gnav-section-inner {
padding-top: 80px;
	padding-right: 10px;
	margin:0 auto;
	text-align: center;
}

#gnav li {
	width: 100px;
	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%;
}
input {
	display: none;
}
/*menuコンテンツ*/
.cp_fullscreenmenu .menu {
	position: fixed;
	top: 0;
	left: 0;
	visibility: hidden;
	width: 100%;
	height: 100%;
	transition: all 0.3s ease-in-out;
	opacity: 0;
	background: rgba(67,61,60,0.9);
	overflow-y: auto; /* 縦スクロールを有効化 */
	z-index: 190;
}
.cp_fullscreenmenu .menu ul {
	/*position: absolute;
	top: 170px;
	left: 0;*/
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
	list-style-type: none;
	transition: all 0.3s ease-in-out;
	-webkit-transform: translateX(-0%);
	        transform: translateX(-0%);
}
.cp_fullscreenmenu .menu ul li {
	-webkit-transform: translateY(50px);
	        transform: translateY(50px);
	opacity: 0;
}
.cp_fullscreenmenu .menu ul li a {
	/*font-size: 1rem;*/
	display: block;
	padding: 10px 0;
	transition: all 0.2s ease-in-out;
	text-align: left;
	text-decoration: none;
	color: #ffffff;
	
}
.cp_fullscreenmenu .menu ul li a:hover {
	color: rgba(255,255,255,0.8);
	
}
/*クリックしたらメニューが開閉の動作*/
.cp_fullscreenmenu #toggle:checked ~ .menu {
	visibility: visible;
	opacity: 1;
	display: block;
}
.cp_fullscreenmenu #toggle:checked ~ .menu ul {
	top: 70px;
}

.cp_fullscreenmenu #toggle:checked ~ .menu ul li {
	-webkit-transform: translateY(0px);
	        transform: translateY(0px);
	opacity: 1;
}

.cp_fullscreenmenu #toggle:checked + label.hamburger .bar {
	background-color: rgba(255,255,255 ,1);
	
}
.cp_fullscreenmenu #toggle:checked + label.hamburger .bar:nth-child(2) {
	-webkit-transform: translateX(50px);
	        transform: translateX(50px);
	opacity: 0;
	
}
.cp_fullscreenmenu #toggle:checked + label.hamburger .bar:nth-child(1) {
	-webkit-transform: translateY(10px) rotate(45deg);
	        transform: translateY(10px) rotate(45deg);
	
  
}
.cp_fullscreenmenu #toggle:checked + label.hamburger .bar:nth-child(3) {
	-webkit-transform: translateY(-8px) rotate(-45deg);
	        transform: translateY(-8px) rotate(-45deg);

}
/* 背景スクロールを防ぐ */
.cp_fullscreenmenu #toggle:checked ~ body {
  overflow: hidden;
}
.cp_fullscreenmenu .hamburger .bar:nth-child(2) {
  top:18px;
  
}
.cp_fullscreenmenu .hamburger .bar:nth-child(1) {
	
	top: 9px;
}
.cp_fullscreenmenu .hamburger .bar:nth-child(3) {
	
	top:27px;
}
/*ハンバーガー*/
.cp_fullscreenmenu .hamburger {

	position:fixed;
	z-index: 195;
	top: 0px;
	right: 0px;
	display: block;
	width: 50px;
  height: 50px;
	cursor: pointer;
	 text-align: center;
	background-color: #000;
}

.cp_fullscreenmenu .hamburger .bar{

	background-color: rgba(255,255,255 ,1);
	/*mix-blend-mode: difference;*/
	position: absolute;
	top: 15px;
	right: 10px;
	width: 30px;
	height: 2px;
	margin: 7px auto;
	transition: all 0.3s ease-in-out;
	
	z-index: 199;
	display: block;
}


.menu_lng {
	font-size: 0.9rem;
	align-items:center;
	justify-content: center;
	text-align: center;
	margin-top: 50px;

}

.menu_lng div{
	display: inline-block;
	line-height: 2;
	margin-bottom: 5px;
	margin-top: 50px;
}
.menu_lng  div+ div::before {
	
	content: "/";
	color: #fff;
	margin-left: .5em;  
  margin-right: .5em; 
  	
}

.menu_foot {
	
	align-items:center;
    text-align: center;
    height: 300px;
    justify-content: center;
	width: 100%;
	color: #fff;
	line-height: 2.4;
}

.menu_foot .logo{width: 180px; height: auto; margin: 10px auto;}
.menu_lng a{ color: #fff; text-decoration: none; transition: .5s;}
.menu_lng a:hover{ color: rgba(255,255,255,0.8); }

.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 .cap_logo img {
	position: absolute;
	top: 40%;
    left: 50%;
    transform: translate(-50%, -60%);
    -webkit-transform: translate(-50%, -60%);
    -ms-transform: translate(-50%, -60%);
  opacity:initial;
	object-fit: none;
}
.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;

	width: 100%;
	}

#main-contents{padding-top: 50px; background: url(../img/bg.gif); overflow-x: hidden;}
#main-contents_top{margin-top: -90px; background: url(../img/bg.gif); overflow-x: hidden;}
.navbar-brand{position: absolute; top:10px; left:20px;}



/*--------------------
Main
--------------------*/
#mainvisual,#mainvisual1,#mainvisual2,#mainvisual3,#mainvisual4{width: 100%;
  height: auto;
  padding-top: calc(500 / 1920 * 100%); /* calc(画像高さ ÷ 画像横幅 × 100%) */
	/*margin-top: 130px;*/
	position: relative;
}
#mainvisual:before{background-color: rgba(0, 0, 0, 0.3); /*background-image: linear-gradient(0deg, transparent 0 60%, #000 100%);*/
position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	content: ' ';}

.breadcrumb-warp {
	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:50px auto 100px auto;}
.cap{font-size: 0.8rem; text-align:right; margin-top: 5px;}
.cap p{margin:0px; padding:0px;}
#booking_sp{margin-bottom: 100px;}
#booking_sp #ttl img{ margin: 10px 0 15px 0;}
#booking_sp #ttl .cap{border-top: 1px solid #AFC9CA; padding-top: 10px; font-size: 0.9em; text-align: center;}
#booking_sp #best_rate{ background-color: #87643E; text-align: center; border: 1px solid #FFF; padding: 15px;}
#booking_sp .gift{min-height: 105px; text-align: center; background-color: #918D43; border: 1px solid #FFF;}
#booking_sp span{display: inline-block;}
#jan_gt{border: 1px solid #B7282E; margin-bottom: 10px;}
#jan_gt .ttl{margin: 0 auto; background-color: #B7282E; width: 100%; height: 40px;}
#jan_gt .txt{padding: 10px; text-align: left; font-weight: bold;}
#ticket{margin-top: 30px;}
#ticket .ttl{margin-bottom: 15px;}
/* 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: #3A546B 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 .aut{background:#EEEAD1; }
.price_table01 .spr{background:#D6E9CA; }
.price_table01 .sum{background:#C1E4E9; }
.price_table01 .win{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;}

/*--------------------
slick_slider
--------------------*/
* {
  box-sizing: border-box;
}
.sliderArea {
  max-width: 100%;
  margin: 0 auto;
  padding: 0 24px;
}
/*.sliderArea.w900 {
  max-width: 900px;
}*/
.slick-slide {
  margin: 0 0px;
	position: relative;
}
.slick-slide img {
  width: 100%;
  height: auto;
}
/*.slick-prev, .slick-next {
  z-index: 1;
}
.slick-prev:before, .slick-next:before {
  color: #000;
}*/
.slick-slide {
  transition: all ease-in-out .3s;
  opacity: .2;
}
.slick-active {
  opacity: 1;
}
.slick-current {
  opacity: 1;
}
.thumb {
  margin: 20px 0 0;
}
.thumb .slick-slide {
  cursor: pointer;
}
.thumb .slick-slide:hover {
  opacity: .7;
}
/*.full-screen .slick-slide:not(.slick-center) {
-webkit-filter: grayscale(100%);
-moz-filter: grayscale(100%);
-o-filter: grayscale(100%);
-ms-filter: grayscale(100%);
filter: grayscale(100%);
transition: 0.2s linear;
}
*/
.slick-arrow {
  display: block;
  position: absolute;
  top: 50%;
  /*bottom: 0;*/
  margin: auto;
  padding: 0;
  width: 20px;
  height: 38px;
  color: transparent;
  z-index: 1;
  transition: opacity 0.5s;
  z-index: 1;
}
.slick-arrow:hover {
  opacity: 0.7;
}

/* 共通設定 */

.slick-next::before,
.slick-next::after,
.slick-prev::before,
.slick-prev::after {
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
}
.slick-next::after,
.slick-prev::after {
  width: 26px;
  height: 26px;
  border-top: 1px solid #3A546B;
  border-right: 1px solid #3A546B;
}

/* next */

.slick-next {
  right: 26px;
}
.slick-next::after {
  right: -50px;
  transform: rotate(45deg);
}

/* prev */

.slick-prev {
  left: 26px;
}
.slick-prev::after {
  left: -50px;
  transform: rotate(-135deg);
}

@media screen and (max-width: 767px) {
	.sliderArea {
  margin: 0 auto;
  padding: 0 15px;
}
  .slick-next::after,
  .slick-prev::after {
    width: 15px;
    height: 15px;
  }
  /*.slick-next {
    right: -10px;
  }
  .slick-prev {
    left: -10px;
  }
  .slick-next::after {
    right: 4px;
  }*/
}
.textphoto { 
    width:    100%;
    font-size:100%;
    text-align:left;
    bottom:    10px;
    margin:    0;
    padding:8px 0;
    color:    #FFF;
    background:rgba(0,0,0,0.4); 
    position:absolute;
    padding-left:1rem;
	
}
.textphoto span{font-size: 0.8em;}
/*--------------------
intro-section
--------------------*/
#intro-section{margin: 0px auto;}
#intro-section2{padding: 50px 0 0 0;}
#intro-section h2,#intro-section2 h2{
	font-size: 3rem;
	margin-bottom: 50px;
}
#intro-section #contents_nav {margin: 50px auto 100px auto;}
#intro-section #contents_nav a{color: #3A546B;}
#intro-section .lead{font-size: 1.5rem; margin-bottom: 20px;}
#intro-section .lead p{font-size: 1.2rem; margin: 10px auto 20px auto;}
#intro-section .lead span{display: inline-block;}
#intro-section .and{font-size:2rem}
.title{border: 1px solid #AFC9CA; padding: 50px; z-index: 50; }

.title h3,.title2 h3 {
	font-size: 2rem;
	/*color: #432F2F;
	font-weight: 900;
	letter-spacing: 1px;*/
	position: relative;
	padding-bottom: 10px;
	/*margin-top: 0.5rem;*/
	line-height: 1.2;
	ruby-align:center;
}
.title h3 span,.title2 h3 span{display: inline-block;}

.title h3 .sub_ttl,.title2 h3 .sub_ttl{font-size: 1.4rem; letter-spacing: .2rem; }

.title .lead,.title2 .lead{ font-size: 1rem; text-align: left;}
.title .txt_box{max-width: 320px; margin: 0px auto 0 auto; text-align: left; }
.section-title h3,.section-title2 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;
}
.section-title h3 span{display: inline-block;}
.section-title .sub_ttl{font-size: 1.6rem;}
.section-title .lead{font-size: 1.2rem; margin-bottom: 30px;}

.section-title .text {text-align: left; margin-bottom: 30px;}

.warp_line{border: 1px solid #AFC9CA;}
.inner_line{margin: 15px;}





#info-section .heading-section {
	margin-bottom: 1em;
	margin-top: 50px;
}
#info-section h3 {
	border-bottom : double 3px #AFC9CA;
	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 #AFC9CA;*/
	padding-bottom: 2em;
	margin:0 auto;
}
#info-section table{border-collapse:collapse; width:100%; border: solid 1px #AFC9CA; margin-bottom: 10px;}
#info-section th{
	
	padding:10px;
	text-align:center;
	background-color:#d4dcda;
	min-height: 40px;
	border: solid 1px #AFC9CA;
	line-height: 30px;
	white-space: nowrap;
}
#info-section th.ttl{width: 30%;}
#info-section td{
	
	padding:10px;
	border: solid 1px #AFC9CA;
	text-align:left;
	min-height: 40px;
	
}
#info-section td span{display: inline-block;}


/*--------------------
Footer
--------------------*/
#web_nav {
	width: 100%;

	border-top: 1px solid #AFC9CA;
	text-align: center;
	line-height: 4;
}
#web_nav .line1{border-bottom: 1px solid #AFC9CA; }
#web_nav .line2{border-right: 1px solid #AFC9CA; border-bottom: 1px solid #AFC9CA; }
#web_nav p:hover{opacity: 0.7;}
#web_nav a{color: #3A546B; text-decoration: none;}
#web_nav a:visited{color: #787CAC; opacity: 0.7; text-decoration: none;}
#web_nav a:hover{color: #527798; opacity: 0.7; text-decoration: none;}
#web_nav a:active{color: #527798; 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; text-align: left;}
#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;

}



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

#footer-gr{width: 100%; margin:0 auto; background-color: #f3f3f2; text-align: center;}
#footer-gr .container{padding: 30px 0;}
#footer-gr .bnr{ padding-bottom: 5px; border-bottom: 1px dotted #333; margin-bottom:10px;}
#footer-gr .shun{ margin-bottom: 30px;}
#footer-gr a:hover img{opacity: 0.5 ;}
/* 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: #3A546B;
  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;
	
  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;}

.bg_onetime_popup {
    position: fixed;
    top: 0px;
    left: 0px;
    z-index: 9999;
    width: 100vw;
    height: 100vh;
    background-color: rgba(0, 0, 0, 0.5);
    opacity: 0;
    visibility: hidden;
    transition: 0.5s;
}
.popup_plan{margin-top: 10px;}
.bg_onetime_popup.js_active {
    opacity: 1;
    visibility: visible;
}

.onetime_popup {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    width: 50%;
    min-width: 400px;
    background-color: #fff;
    cursor: pointer;
	
}

.onetime_popup_title {
    position: relative;
    padding: 5px 30px;
    margin: 0px;
    background-color: #000;
    color: #fff;
    font-size: 18px;
    text-align: center;
    line-height: 1.5;
}
.onetime_popup_title::before,
.onetime_popup_title::after {
    position: absolute;
    top: 50%;
    right: 30px;
    transform: translateY(-50%);
    width: 30px;
    height: 4px;
    background-color: #fff;
    content: "";
	
}
.onetime_popup_title::before {
    transform: rotate(45deg);
}
.onetime_popup_title::after {
    transform: rotate(-45deg);
}

.onetime_popup_content {
    padding: 20px 30px;
    text-align: center;
}


@media (max-width: 1020px) and (min-width: 768px){
  
	#gnav-section-inner {
padding-top: 120px;
}

}
@media screen and (max-width: 768px) {
/*↓カラム間のガター幅が5px、カラムの左右の余白が5pxになる*/
.o-2column .col-md-6,.o-2column .col-6  { padding: 0 5px;}
.o-2column {margin: 0 -5px;}
.o-3column .col-md-4 ,.o-3column .col-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;}
.fb-warp{margin-top: 50px;}
	#info-section .heading-section h3 {
	font-size: 1.4rem;
}	
}
@media screen and (max-width:767px) {
	#mainvisual,#mainvisual1,#mainvisual2,#mainvisual3,#mainvisual4  {
width: 100%;
		min-height: 200px;
		/*margin-top: 100px;
	  */
object-fit: cover;
	}
.img_box1{margin-bottom: 10px;}
.img_box2{margin-bottom: 20px;}
.img_box3{margin-bottom: 30px;}

}
@media only screen and (max-width: 767px) {
	.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
}
	#main-contents_top{margin-top: 30px;}
	h2{font-size: 1.8rem;}
	h2 .sttl,h3 .sttl{font-size: 0.9rem;}
	
	#mainvisual h2{font-size: 1.8rem; position: absolute; top:70px; left:0; right:0; background: url(../img/ttl_icon_s.png)no-repeat; color: #FFF; background-position: center top;}
	
  
.pannellum_warp h4{font-size: 1rem;}
#carousel-1 .carousel-caption{

font-size: 1.6rem;
font-weight: 300;
white-space: nowrap;
	
	
	}
	
	.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: 100px; height: auto;}
	#late_bn{position: absolute; z-index: 3; top:60%; left:0; /*right: 10px;*/ background: none;
	}
	#contact {width: auto; height:auto; position: absolute; top: 60px; right: 5px;}
	.header-warp2{ height: 100px;}
.cp_fullscreenmenu .menu ul li { padding: 5px 0 5px 10px; border-bottom: 1px #666 solid; margin: 0 10px; font-size: 0.9rem;}


.plan_table01,.price_table02 {
	  font-size: 0.8rem;
  }
	.price_table01{width: 100%;}


	.title h3 {font-size: 1.8rem;}
	.title{padding: 15px;}
	.title h3 .sub_ttl,.title2 h3 .sub_ttl{font-size: 1.2rem;}
	.title .txt_box,.title2 .txt_box{width: auto; margin: 0 auto; text-align: left; }
.section-title h3 {
	  font-size: 1.6rem;
  }
	.section-title2 h3 {
	  font-size: 1.5rem;
  }
	.section-title2 p{text-align: left;}
.section-title .sub_ttl{font-size:1.4rem;}
.section-title .lead{ font-size: 1rem; text-align: left;}
	#intro-section #contents_nav {margin: 50px auto;}
#intro-section h2,#intro-section2 h2{
	font-size: 2.3rem;
	margin-bottom: 50px;
}
	#intro-section .lead{font-size: 1.3rem;}
	#intro-section .lead p{font-size: 1.1rem;}
	#intro-section .txt{text-align: left;}
	

 
	#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) left/cover no-repeat; /*fixedをトル！*/
  -webkit-background-size:cover;/*Android4*/
  }
}
@media screen and (max-width: 480px) {
#info-section dt {
	width: 100%;
	float: none;
	height: auto;
}

}