body, html {
	margin: 0;
	padding: 0;
	height: 100%;
}
.mb0{
	margin-bottom:0px !important;
}
.mb10{
	margin-bottom:10px !important;
}
.mb20{
	margin-bottom:20px !important;
}
.mb30{
	margin-bottom:30px !important;
}
.mb40{
	margin-bottom:40px !important;
}
.mb50{
	margin-bottom:50px !important;
}
/* #header */
#header {
	height: 730px;
	background: url(../images/topimg_01.webp) no-repeat center top;
	background-size: cover;
	text-align: center;
	transition: opacity 0.5s;
}
.hidden {
	display: none;
}
#header .logo {
	width: 200px;
	height: auto;
	float: left;
	margin-top: 20px;
	margin-left: 30px;
	z-index: 1000;
	position: relative;
}
#header .logo img {
	width: 100%;
	height: auto;
}
#header .logo02{
	display:none;
}
#header .reservation {
	width: 235px;
	height: 50px;
	height: auto;
	float: right;
	margin-top: 20px;
	margin-right: 30px;
	z-index: 1000;
	position: relative;

}
#header .reservation a {
	display: block;
	width: 100%;
	height: 50px;
	background: #8ec31f;
	line-height: 50px;
	color: #FFF;
	text-align: center;
	font-size: 18px;
	border: 1px solid #8ec31f;
	transition: color 0.5s ease 0s;
}
#header .reservation a:link, #header .reservation a:visited, #header .reservation a:hover, #header .reservation a:active, #header .reservation a:focus {
	text-decoration: none;
}
#header .reservation a:hover {
	background: #fff;
	color: #8eb346;
}
#header #arch {
	padding-top: 200px;
	clear: both;
	font-size: 30px;
	font-family: "Noto Serif JP", serif;
	font-weight: 200;
	font-style: normal;
	color: #FFF;
	letter-spacing: 2px;
	margin-bottom: 30px;
}
#header h2 {
	font-weight: bold;
	font-size: 64px;
	color: #FFF;
	margin-bottom: 10px;
}
#header p.header-text {
	font-size: 16px;
	color: #FFF;
}
#header.smallhead{
    opacity:1 !important;
}
#header.smallhead #navi{
	background: rgba(255,255,255,0.8) !important;
	border-bottom: 1px solid #f0f5fa;
	height:80px;
	width:100%;
	margin:0;
	position:fixed;
	top:0;
	z-index:10000;
}
#header.smallhead .logo,
#header.smallhead #arch,
#header.smallhead h2,
#header.smallhead p.header-text {
	display:none;
}
#header.smallhead .logo02{
	display:block;
	width:150px;
	padding-top:12px;
	padding-left:30px;
	float:left;
}
#header.smallhead .logo02 img{
	width:150px;
	height:auto;
}
#header.smallhead .reservation {
    margin-top:14px;
	z-index:10000;
}
/* #movie */
#movie {
	text-align: center;
	padding-top:50px;
}
#movie h3.title01 {
	font-size: 20px;
	text-align: center;
	color: #8ec31f;
	font-weight: normal;
}
#movie h2.title01 {
	font-size: 32px;
	text-align: center;
	color: #000;
	margin-bottom: 50px;
	font-weight: normal;
}
#movie .img {
	width: 800px;
	margin: 0px auto 50px;
}
#movie .img img {
	width: 100%;
	height: auto;
}
.button {
	width: 300px;
	margin: 0 auto 50px;
}
.button a {
	display: block;
	width: 100%;
	height: 40px;
	line-height: 40px;
	color: #FFF;
	border-radius: 10px;
	background: #8ec31f;
	text-align: center;
	border: 1px solid #8ec31f;
}
.button a:link, .button a:visited, .button a:hover, .button a:active, .button a:focus {
	text-decoration: none;
	transition: color 0.5s ease 0s;
}
.button a:hover {
	background: #fff;
	color: #8eb346;
}
/* #about */
#about {
	text-align: center;
	padding-top:50px;
	padding-bottom:0px;
	border-bottom:1px solid #CCC;
}
#about h3.title01 {
	font-size: 20px;
	text-align: center;
	color: #8ec31f;
	font-weight: normal;
}
#about h2.title01 {
	font-size: 32px;
	text-align: center;
	color: #000;
	margin-bottom: 50px;
	font-weight: normal;
}
#about ul{
	width: 90%;
	margin:0 auto 30px;
	display: flex;
	justify-content: space-between;
}
#about ul li{
	width: 30%;
}
#about ul li img {
	width: 100%;
	height: auto;
}
#about p.text {
	font-size:16px;
	text-align: center;
	color: #000;
	margin-bottom:30px;
	font-weight: normal;
}
/* #facility */
#facility {
	background: #e7f5e9;
	padding-top: 50px;
	overflow: hidden;
}
#facility h3.title01 {
	font-size: 20px;
	text-align: center;
	color: #8ec31f;
	font-weight: normal;
}
#facility h2.title01 {
	font-size: 32px;
	text-align: center;
	color: #000;
	margin-bottom: 50px;
	font-weight: normal;
}
#facility dl {
	width: 90%;
	margin: auto;
	display: flex;
}
#facility dl.right {
	flex-direction: row-reverse;
}
#facility dl dt, #facility dl dd {
	width: 50%;
}
#facility dl dt img {
	width: 100%;
	height: auto;
}
#facility dl dd {
	box-sizing: border-box;
	padding: 30px;
	background: #FFF;
	text-align: left;
}
#facility dl dd .no {
	font-size: 44px;
	color: #8ec31f;
	font-style: italic;
	margin: 0;
}
#facility dl dd h3.title02 {
	font-size: 16px;
	font-weight: normal;
}
#facility dl dd h2.title02 {
	font-size: 22px;
	padding-bottom: 10px;
	border-bottom: 1px solid #000;
	margin-bottom: 20px;
	font-weight: normal;
}
#facility .button {
	margin: 50px auto 50px;
}
/* .slideshow */
.slick-slider {
	position: relative;
	display: block;
	box-sizing: border-box;
	-webkit-user-select: none;
	-moz-user-select: none;
	-ms-user-select: none;
	user-select: none;
	-webkit-touch-callout: none;
	-khtml-user-select: none;
	-ms-touch-action: pan-y;
	touch-action: pan-y;
	-webkit-tap-highlight-color: transparent;
}
.slick-list {
	position: relative;
	display: block;
	overflow: hidden;
	margin: 0;
	padding: 0;
}
.slick-list:focus {
	outline: none;
}
.slick-list.dragging {
	cursor: pointer;
	cursor: hand;
}
.slick-slider .slick-track, .slick-slider .slick-list {
	-webkit-transform: translate3d(0, 0, 0);
	-moz-transform: translate3d(0, 0, 0);
	-ms-transform: translate3d(0, 0, 0);
	-o-transform: translate3d(0, 0, 0);
	transform: translate3d(0, 0, 0);
}
.slick-track {
	position: relative;
	top: 0;
	left: 0;
	display: block;
	margin-left: auto;
	margin-right: auto;
}
.slick-track:before, .slick-track:after {
	display: table;
	content: '';
}
.slick-track:after {
	clear: both;
}
.slick-loading .slick-track {
	visibility: hidden;
}
.slick-slide {
	display: none;
	float: left;
	height: 100%;
	min-height: 1px;
}
[dir='rtl'] .slick-slide {
	float: right;
}
.slick-slide img {
	display: block;
}
.slick-slide.slick-loading img {
	display: none;
}
.slick-slide.dragging img {
	pointer-events: none;
}
.slick-initialized .slick-slide {
	display: block;
}
.slick-loading .slick-slide {
	visibility: hidden;
}
.slick-vertical .slick-slide {
	display: block;
	height: auto;
	border: 1px solid transparent;
}
.slick-arrow.slick-hidden {
	display: none;
}
.slideshow {
}
.slideshow li {
	width: 250px;
	float:left;
}
.slideshow li img {
	width: 100%;
	height: auto;
}
/* #room */
#room {
	padding-top: 50px;
	overflow: hidden;
}
#room h3.title01 {
	font-size: 20px;
	text-align: center;
	color: #8ec31f;
	font-weight: normal;
}
#room h2.title01 {
	font-size: 32px;
	text-align: center;
	color: #000;
	margin-bottom:20px;
	font-weight: normal;
}
#room p.text {
	font-size:16px;
	text-align: center;
	color: #000;
	margin-bottom: 50px;
	font-weight: normal;
}
#room ul {
	width: 90%;
	margin: auto;
	display: flex;
	justify-content: space-between;
}
#room ul li{
	width: 48%;
	margin-bottom:50px;
}
#room ul li .img {
	margin-bottom:0px;
}
#room ul li .img img{
	width: 100%;
	height: auto;
}
#room ul li .box{
	padding:20px;
}
#room ul li h3.title02 {
	font-size: 16px;
	font-weight: normal;
}
#room ul li h2.title02 {
	font-size: 22px;
	padding-bottom: 10px;
	border-bottom: 1px solid #000;
	margin-bottom: 20px;
	font-weight: normal;
}
#room ul li h2.title02 span{
	display:inline-block;
	float:right;
	font-size: 16px;
}
#room ul li p{
	margin-bottom:20px;
}
#room .button {
	margin:auto;
}

/* #meal */
#meal {
	padding-top: 50px;
	overflow: hidden;
	background:#f8f6ef;
}
#meal h3.title01 {
	font-size: 20px;
	text-align: center;
	color: #8ec31f;
	font-weight: normal;
}
#meal h2.title01 {
	font-size: 32px;
	text-align: center;
	color: #000;
	margin-bottom:20px;
	font-weight: normal;
}
#meal p.text {
	font-size:16px;
	text-align: center;
	color: #000;
	margin-bottom: 50px;
	font-weight: normal;
}
#meal ul {
	width: 80%;
	margin: auto;
}
#meal ul li{
	width: 100%;
	margin-bottom:50px;
	overflow:hidden;
	background:#FFF;
}
#meal ul li .img {
	margin-bottom:0px;
}
#meal ul li .img img{
	width: 100%;
	height: auto;
}
#meal ul li .box{
	padding:20px 10%;
}
#meal ul li h2.title02 {
	font-size: 22px;
	padding-bottom: 10px;
	border-bottom: 1px solid #000;
	margin-bottom: 20px;
	font-weight: normal;
}
#meal ul li p{
	margin-bottom:20px;
}
#meal ul li dl{
	display:flex;
}
#meal ul li dl dt{
	width:60%;
}
#meal ul li dl dd{
	width:40%;
}
#meal .button {
	margin:0 auto 50px;
}
/* #faq */
#faq {
	padding-top: 50px;
	overflow: hidden;
	background:#FFF;
}
#faq h3.title01 {
	font-size: 20px;
	text-align: center;
	color: #8ec31f;
	font-weight: normal;
}
#faq h2.title01 {
	font-size: 32px;
	text-align: center;
	color: #000;
	margin-bottom:20px;
	font-weight: normal;
}
#faq h4.title01 {
	background:#f5f0dc;
	text-align:center;
	font-size:20px;
	padding:10px 0;
	border-top:1px solid #000;
	border-bottom:1px solid #000;
	font-weight:normal;
	width:90%;
	margin:0 auto 20px;
}
#faq .accordion_row {
  margin-bottom: 15px;
  border-radius: 10px;
  overflow: hidden;
  position: relative;
  width: 86%;
  margin:0 auto 10px;
}
#faq .accordion_row:last-child {
  margin-bottom: 0;
}
#faq .accordion_header {
  cursor: pointer;
  position: relative;
  height:35px;
}
#faq .accordion_header b{
	font-size:26px;
	color:#999999;
	font-weight:normal;
	padding-right:10px;
}
#faq .accordion_barBox {
  display: block;
  width:35px;
  height:35px;
  position: absolute;
  top: 50%;
  right: 1.5em;
  background:#999;
  border-radius:50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
}
#faq .accordion_bar {
  display: block;
  width: 0.8em;
  height: 2px;
  background: #FFF;
  position: absolute;
  top: 50%;
  left: 50%;
}
#faq .accordion_bar:nth-of-type(1) {
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
#faq .accordion_bar:nth-of-type(2) {
  -webkit-transform: translate(-50%, -50%) rotate(90deg);
  -ms-transform: translate(-50%, -50%) rotate(90deg);
  transform: translate(-50%, -50%) rotate(90deg);
  transition: 0.3s linear;
}
#faq .accordion_content {
  display: none;
  width: 100%;
  height: 0;
  transition: 0.3s linear;
}
#faq .accordion_content b{
	font-size:26px;
	color:#ff9999;
	font-weight:normal;
	padding-right:10px;
}
#faq .accordion_row.-active .accordion_bar:nth-of-type(2) {
  opacity: 0;
}
/* #access */
#access {
	padding-top: 50px;
	overflow: hidden;
	background:#f8f6ef;
	text-align:center;
}
#access h3.title01 {
	font-size: 20px;
	text-align: center;
	color: #8ec31f;
	font-weight: normal;
}
#access h2.title01 {
	font-size: 32px;
	text-align: center;
	color: #000;
	margin-bottom:20px;
	font-weight: normal;
}
#access p.text {
	font-size:16px;
	text-align: center;
	color: #000;
	margin-bottom: 50px;
	font-weight: normal;
}
#access p.img{
	width:90%;
	margin:0 auto 50px;
}
#access p.img img{
	width:100%;
	height:auto;
}
#access table{
	width:90%;
	margin:0 auto 50px;
	border-collapse:collapse;
	border-bottom:1px solid #CCC;
}
#access table tr{
	display:flex;
	width:100%;
	border-top:1px solid #CCC;
	padding-top:2px;
	margin-bottom:2px;
}
#access table th{
	background:#8ec31f;
	padding:10px;
	color:#FFF;
	min-height:80px;
	text-align:center;
	width:30%;
	box-sizing:border-box;
	vertical-align:middle;
}
#access table td{
	text-align:left;
	padding:10px 20px;
	width:70%;
	box-sizing:border-box;
}
#access iframe{
	width:90%;
	height:400px;
	margin:0 auto 50px;
}

/* #footer */
footer {
    background-color: #002231;
	padding-top:50px;
	padding-bottom:50px;
	text-align:center;
}
footer .logo{
	width:150px;
	margin:0 auto 30px;
}
footer .logo img{
	width:100%;
	height:auto;
}
footer .tel{
	width:400px;
	padding:20px;
	color:#FFF;
	border:1px solid #FFF;
	height:auto;
	margin:0 auto 30px;
	font-size:20px;
}
footer .copyright{
	color:#FFF;
	margin:0;
}
/* #pageTop */
#pageTop {
	bottom: 0;
	right: 0;
	display: block;
	position: fixed
}
#pageTop a {
	width: 100px;
	height: 100px;
	display: block;
	color: #fff;
	background: #f8f6ef;
	background: rgba(142,195,31,0.4);
	position: relative;
	overflow: hidden;
	z-index: 999
}
#pageTop a:hover {
	background: rgba(142,195,31,0.6)
}
#pageTop a:hover:after {
	margin-top: -8px
}
#pageTop a:after {
	content: '';
	width: 14px;
	height: 14px;
	border: 0;
	border-top: solid 2px #FFF;
	border-right: solid 2px #FFF;
	position: absolute;
	top: 50%;
	left: 50%;
	margin-top: -5px;
	margin-left: -8px;
	transform: rotate(-45deg);
	transition: all 0.4s ease
}
.slick-prev,
.slick-next{
    font-size: 0;
    line-height: 0;
    position: absolute;
    top: 50%;
    display: block;
    width:30px;
    height:30px;
    padding: 0;
    -webkit-transform: translate(0, -50%);
    -ms-transform: translate(0, -50%);
    transform: translate(0, -50%);
    cursor: pointer;
    color: transparent;
    border: none;
    outline: none;
    background:none;
	z-index:1000;
}
.slick-prev{
    left:10px;
}
.slick-next{
    right:10px;
}
.slick-prev::before,
.slick-next::before{
	content: '';
    width:30px;
	height:30px;
	display:block;
	-webkit-border-radius: 50%;
	border-radius:50%;
	background:#FFF;
}
.slick-prev::after,
.slick-next::after{
	content: '';
	display:block;
	position:relative;
	top:-21px;
	width:10px;
	height:10px;
	border-top: 1px solid #000;
	border-right: 1px solid #000;
	transition: all 0.4s ease;
}
.slick-prev::after{
	-webkit-transform: rotate(230deg);
	transform: rotate(230deg);
	left:11px;
}
.slick-prev:hover:after {
	left:8px;
}
.slick-next::after{
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
	left:7px;
}
.slick-next:hover:after {
	left:10px;
}
.slick-slide img {
	width:100%;
	height:auto;
}