@charset "utf-8";

/* -----------------------------------------------
 * Common
 ---------------------------------------------- */

html {
	-ms-text-size-adjust: 100%;
	-webkit-text-size-adjust: 100%;
	font-size: 62.5%;
	overflow-y: scroll;
}

body {
	color: #333333;
	font-family: 'Noto Sans JP', '游ゴシック', YuGothic, 'Hiragino Kaku Gothic ProN', 'Hiragino Kaku Gothic Pro', 'ＭＳ ゴシック', sans-serif;
	font-size: 1.6rem;
	font-weight: 400;
}

.sans {
	font-family: 'Noto Sans JP', '游ゴシック', YuGothic, 'Hiragino Kaku Gothic ProN', 'Hiragino Kaku Gothic Pro', 'ＭＳ ゴシック', sans-serif;
}

.serif {
	font-family: 'Noto Serif JP', "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

::-moz-selection {
	background-color: rgba(254, 83, 24, 1.00);
	color: #ffffff;
}

::-webkit-selection {
	background-color: rgba(254, 83, 24, 1.00);
	color: #ffffff;
}

::selection {
	background-color: rgba(254, 83, 24, 1.00);
	color: #ffffff;
}

img::-moz-selection {
	background-color: rgba(254, 83, 24, 0.75);
}
img::selection {
	background-color: rgba(254, 83, 24, 0.75);
}
img::-moz-selection {
	background-color: rgba(254, 83, 24, 0.75);
}

a {
	color: #333333;
	text-decoration: none;
	-webkit-transition: color .5s cubic-bezier(.68, -.55, .265, 1.55) 0s;
	transition: color .5s cubic-bezier(.68, -.55, .265, 1.55) 0s;
}

a:hover,
a:hover * {
	color: #fe5318;
	text-decoration: none;
}

img, svg {
	vertical-align: top;
	max-width: 100%;
	height: auto;
}

*,
*:after,
*:before {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

a[href^="tel:"] {
	pointer-events: auto;
	cursor: pointer;
	text-decoration: underline;
}

@media screen and (min-width: 1024px) {
	a[href^="tel:"] {
		pointer-events: none;
		cursor: default;
		text-decoration: none;
	}
}

/* -----------------------------------------------
 * Wrapper
 ---------------------------------------------- */

.wrapper {
	overflow: hidden;
	position: relative;
	width: 100%;
	padding: 70px 0 0;
	-webkit-transition: opacity 0.8s linear 0s;
	transition: opacity 0.8s linear 0s;
	opacity: 0;
}

@media screen and (min-width: 1024px) {
	.wrapper {
		padding: 150px 0 0;
	}
}

/* ! Is Nav Complete
----------------------------------------------- */

.is-complete .wrapper {
	opacity: 1
}

/* -----------------------------------------------
 * Header
 ---------------------------------------------- */

.header {
	background: #fff;
	position: fixed;
	left: 0;
	top: 0;
	width: 100%;
	/*height: 70px;*/
	z-index: 10;
}

@media screen and (min-width: 1024px) {
	.header {
		/*height: 100px;*/
	}
}

/* Wrapper
 ---------------------------------------------- */

.header__wrapper {
	position: relative;
	/*height: 100%;*/
}

@media screen and (min-width: 1024px) {
	.header__wrapper {
		max-width: 1000px;
		margin: 0 auto;
	}
}

/* Upper
 ---------------------------------------------- */

.header__upper {
	display: flex;
	justify-content: space-between;
	align-items: center;
	height: 70px;
}

@media screen and (min-width: 1024px) {
	.header__upper {
		height: 100px;
	}
}


/* Logo
 ---------------------------------------------- */

.header__logo {
	/*position: absolute;
	top: 50%;
	left: 20px;*/
	width: 135px;
	margin: 0 0 0 20px;
	padding: 0;
	line-height: 1;
	/*transform: translateY(-50%);*/
}

@media screen and (min-width: 1024px) {
	.header__logo {
		/*left: 0;*/
		width: 185px;
		margin: 0;
	}
}

.header__logo a {
	display: block;
	transition: opacity 0.25s linear;
	opacity: 1;
}

.header__logo a:hover {
	opacity: .75
}

.header__logo img {
	display: block;
	width: 100%;
	height: auto;
}


/* Utility
 ---------------------------------------------- */

.header__utility {
	display: none;
}

@media screen and (min-width: 1024px) {
	.header__utility {
		display: flex;
		align-items: center;
	}
}

/* Inquiry
 ---------------------------------------------- */

.header__inquiry a {
	display: block;
	padding: 13px 25px;
	background-color: #104e3d;
	color: #ffffff;
	font-family: 'Noto Serif JP', "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-size: 16px;
}


/* Sns
 ---------------------------------------------- */

.header__sns ul {
	display: flex;
	margin: 0;
	padding: 0;
	list-style: none;
}

.header__sns li {
	margin: 0 0 0 20px;
}


.header__sns a::after {
	display: block;
	content: "";
	margin: auto;
	color: #1e1e1e;
	font-family: "Font Awesome 5 Brands";
	font-size: 3.2rem;
	font-weight: 400;
}

.header__sns li.instagram a::after {
	content: "\f16d";
}

.header__sns li.facebook a::after {
	content: "\f09a";
}

.header__sns li a span {
	display: none;
}

/* Bottom
 ---------------------------------------------- */

.header__bottom {
	display: none;
}

@media screen and (min-width: 1024px) {
	.header__bottom {
		display: block;
		height: 50px;
	}
}


/* Navigation
 ---------------------------------------------- */

.header__navigation {
	display: block;
	position: fixed;
	left: calc((100% - 80px) * -1);
	top: 0;
	background-color: #595959;
	width: calc((100% - 80px));
	height: 100%;
	-webkit-transition: left .5s cubic-bezier(.77, 0, .175, 1) 0s;
	transition: left .5s cubic-bezier(.77, 0, .175, 1) 0s;
	-webkit-overflow-scrolling: touch;
	overflow-scrolling: touch;
	overflow-y: auto
}

@media screen and (min-width: 1024px) {
	.header__navigation {
		position: static;
		top: auto;
		left: auto;
		/*right: 0;*/
		background-color: transparent;
		width: auto;
		height: auto;
		overflow-y: inherit;
	}
}

@media (max-width:1024px) {
	.is-nav-open .header__navigation {
		left: 0;
	}
}

/* Navigation Ul */

.header__navigation ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

@media screen and (min-width: 1024px) {
	.header__navigation ul {
		display: flex;
		/*-webkit-justify-content: flex-end;
		justify-content: flex-end;*/
		justify-content: space-between;
	}
}

/* Navigation Li */

.header__navigation li {
	margin: 0;
	padding: 0;
	border-bottom: 1px solid rgba(255, 255, 255, .1);
}

@media screen and (min-width: 1024px) {
	.header__navigation li {
		/*margin-left: 27px;*/
		border-bottom: 0;
	}
}

@media screen and (min-width: 1024px) {
	.header__navigation li:first-child {
		/*display: none;*/
	}
}

/* Navigation A */

.header__navigation a {
	position: relative;
	display: block;
	padding: 2.0rem 1.5rem;
	color: #fff;
	text-decoration: none;
	font-family: 'Noto Serif JP', "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-size: 1.6rem;
	font-weight: 700;
	-webkit-transition: color .25s linear 0s;
	transition: color .25s linear 0s;
}

@media screen and (min-width: 1024px) {
	.header__navigation a {
		/*display: flex;
		align-items: center;*/
		height: 50px;
		padding: 0;
		color: #1e1e1e;
		font-size: 1.7rem;
	}
}

.header__navigation a:before {
	content: '';
}

@media screen and (min-width: 1024px) {
	.header__navigation a:before {
		position: absolute;
		display: block;
		bottom: 0;
		left: 50%;
		background-color: #104e3d;
		width: 0;
		height: 2px;
		transform: translateX(-50%);
		transition: width .5s cubic-bezier(.68, -.55, .265, 1.55) 0s;
	}
}

@media screen and (min-width: 1024px) {
	.header__navigation a:hover:before,
	.facilities .header__navigation .facilities a:before,
	.usecharge .header__navigation .usecharge a:before,
	.useguide .header__navigation .useguide a:before,
	.reservation .header__navigation .reservation a:before,
	.rental .header__navigation .rental a:before,
	.access .header__navigation .access a:before,
	.inquiry .header__navigation .inquiry a:before {
		width: 50px;
	}
}


/* Humberger
 ---------------------------------------------- */

.header .humb {
	display: block;
	position: absolute;
	bottom: 50%;
	right: 20px;
	width: 40px;
	height: 40px;
	-webkit-transform: translate(0, 50%);
	-ms-transform: translate(0, 50%);
	transform: translate(0, 50%);
	cursor: pointer;
	z-index: 200;
}

@media screen and (min-width: 1024px) {
	.header .humb {
		display: none
	}
}

.header .humb span {
	display: block;
	width: 30px;
	height: 2px;
	background: #333333;
	-webkit-transition: all .5s cubic-bezier(.68, -.55, .265, 1.55) 0s;
	transition: all .5s cubic-bezier(.68, -.55, .265, 1.55) 0s;
	position: absolute;
	right: 50%;
	bottom: 50%;
	-webkit-transform: translate(50%, 50%);
	-ms-transform: translate(50%, 50%);
	transform: translate(50%, 50%)
}

.header .humb span:nth-of-type(1) {
	-webkit-transform: translate(50%, calc(50% - (40px * .12)));
	-ms-transform: translate(50%, calc(50% - (40px * .12)));
	transform: translate(50%, calc(50% - (40px * .12)));
}

.header .humb span:nth-of-type(2) {
	display: none;
}

.header .humb span:nth-of-type(3) {
	-webkit-transform: translate(50%, calc(50% + (40px * .12)));
	-ms-transform: translate(50%, calc(50% + (40px * .12)));
	transform: translate(50%, calc(50% + (40px * .12)));
}

.is-nav-open .header .humb span:nth-of-type(1) {
	-webkit-transform: translate(50%, 50%) rotate(135deg);
	-ms-transform: translate(50%, 50%) rotate(135deg);
	transform: translate(50%, 50%) rotate(135deg);
}

.is-nav-open .header .humb span:nth-of-type(2) {
	-webkit-transform: translate(75%, 50%);
	-ms-transform: translate(75%, 50%);
	transform: translate(75%, 50%);
	opacity: 0;
}

.is-nav-open .header .humb span:nth-of-type(3) {
	-webkit-transform: translate(50%, 50%) rotate(-135deg);
	-ms-transform: translate(50%, 50%) rotate(-135deg);
	transform: translate(50%, 50%) rotate(-135deg);
}



/* -----------------------------------------------------------
 * Drawer
----------------------------------------------------------- */

.drawer {
	display: block;
	position: fixed;
	left: calc((100% - 80px) * -1);
	top: 0;
	background-color: #595959;
	width: calc((100% - 80px));
	height: 100%;
	-webkit-transition: left .5s cubic-bezier(.77, 0, .175, 1) 0s;
	transition: left .5s cubic-bezier(.77, 0, .175, 1) 0s;
	-webkit-overflow-scrolling: touch;
	overflow-scrolling: touch;
	overflow-y: auto;
	z-index: 100;
}

@media (max-width:1024px) {
	.is-nav-open .drawer {
		left: 0;
	}
}


.drawer__navigation {
	margin: 0;
	padding: 0;
	list-style: none;
}

.drawer__navigation li {
	margin: 0;
	padding: 0;
	border-bottom: 1px solid rgba(255, 255, 255, .1);
}

.drawer__navigation a {
	position: relative;
	display: block;
	padding: 2.0rem 1.5rem;
	color: #fff;
	text-decoration: none;
	font-family: 'Noto Serif JP', "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-size: 1.6rem;
	font-weight: 700;
	transition: color .25s linear 0s;
}


/* Inquiry
 ---------------------------------------------- */

.drawer__inquiry a {
	display: block;
	padding: 2.0rem 1.5rem;
	background-color: #104e3d;
	color: #ffffff;
	font-family: 'Noto Serif JP', "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	font-size: 16px;
	font-weight: 700;
	border-bottom: 1px solid rgba(255, 255, 255, .1);
}


/* Social Icons
 ---------------------------------------------- */
.drawer__sns {
	display: flex;
	margin: 0;
	padding: 0;
	list-style: none;
}

.drawer__sns li {
	margin-left: 20px;
	border-bottom: 0;
}

.drawer__sns a {
	display: block;
	padding: 2.0rem 1.5rem;
}

.drawer__sns li a::after {
	display: block;
	content: "";
	margin: auto;
	color: #ffffff;
	font-family: "Font Awesome 5 Brands";
	font-size: 2.6rem;
	font-weight: 400;
}


.drawer__sns li.instagram a::after {
	content: "\f16d";
}

.drawer__sns li.facebook a::after {
	content: "\f09a";
}

.drawer__sns li a span {
	display: none;
}






/* -----------------------------------------------------------
 * Footer
----------------------------------------------------------- */
.footer {
	position: relative;
	background-color: #f5f5f5;
}

@media screen and (min-width: 1024px) {
	.footer {

	}
}

/* Banners
 ---------------------------------------------- */
.footer__banners {
	background-color: #f5f5f5;
}

.footer__banners ul {
	display: flex;
	justify-content: space-between;
	margin: 0 2.0rem;
	padding: 2.0rem 0;
	list-style: none;
}

@media screen and (min-width: 567px) {
	.footer__banners ul {
		max-width: 566px;
		margin: 0 auto;
	}
}

.footer__banners ul li {
	margin: 0 auto;
	line-height: 1;
}

.footer__banners ul li:first-child {
	margin-right: 2.0rem;
}

@media screen and (min-width: 567px) {
	.footer__banners ul li:first-child {
		margin-right: auto;
	}
}

.footer__banners ul li a {
	display: block;
	width: 100%;
	max-width: 233px;
	margin: 0 auto;
	border: 1px solid #eee;
}

/* お問い合わせ
 ---------------------------------------------- */
.footer__contact {
	padding: 2.0rem 20px;
	background: url("/assets/images/page_footer.jpg");
	background-position: center;
	background-size: cover;
	position: relative;
	min-height: 85px;
}

/*
.footer__contact:after {
	content: "";
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.1);
	position: absolute;
	top: 0;left: 0;
}
*/

.footer__contact ul {
	padding: 0;
	margin: 0;
	z-index: 1;
	position: relative;
}

.footer__contact ul li {
	margin: 0 auto;
	line-height: 1;
	list-style: none;
}

.footer__contact ul li + li {
	margin-top: 10px;
}

.footer__contact ul li a {
	display: block;
	width: 100%;
	max-width: 400px;
	background-color: #104e3d;
	text-align: center;
	padding: 16px 20px;
	color: #fff;
	font-size: 1.3rem;
	margin: 0 auto;
}

@media screen and (min-width: 567px) {
	.footer__contact {
		min-height: 200px;
	}

	.footer__contact ul {
		max-width: 650px;
		margin-left: auto;
		margin-right: auto;
		padding: 50px 0;
		display: flex;
		justify-content: space-between;
	}

	.footer__contact ul li {
		width: 100%;
	}

	.footer__contact ul li + li {
		margin-top: 0;
		margin-left: 50px;
	}

	.footer__contact ul li a {
		padding: 20px 0;
		font-size: 1.6rem;
		transition: all .2s;
	}

	.footer__contact ul li a:hover {
		transition: all .2s;
		background-color: #fe5318;
	}
}

/* Copyright
 ---------------------------------------------- */
.footer__copyright {
	background-color: #000000;
	color: #ffffff;
	font-family: Arial, sans-serif;
	position: relative;
}

.footer__copyright .inner {
	width: calc(100% - 15px);
	margin: 0 auto;
}

.footer__copyright p {
	margin: 0;
	padding: 1.0rem 0;
	font-size: 1.2rem;
	font-weight: 400;
	letter-spacing: 0.05em;
	text-align: center;
}

.footer__copyright p + p  {
	padding-top: 0;
}

.footer__copyright .footer__policy a {
	color: #ffffff;
	position: relative;
}

.footer__copyright .footer__policy a:before {
    content: '';
    display: inline-block;
    vertical-align: middle;
    width: 0.3em;
    height: 0.3em;
    border-top: 1px solid #a4a4a4;
    border-right: 1px solid #a4a4a4;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
    margin: -2px 1em 0 0;
}

.footer__copyright .footer__policy a:hover {
	color: #fe5318;
}



@media screen and (min-width: 1024px) {

	.footer__copyright .inner {
		width: 1000px;
		display: flex;
		justify-content: space-between;
	}

	.footer__copyright .footer__policy p {
		width: 50%;
	}

	.footer__copyright .footer__policy {
		text-align: right;
	}

	.footer__copyright p {
		padding: 2.0rem 0;
	}

	.footer__copyright p + p {
		padding-top: 2.0rem;
	}

}



/* inview
 ---------------------------------------------- */
/*
.inview {
	opacity: 0;
	transform: translate3d(0, 30px, 0);
	transition: opacity .5s ease-out .25s, transform .5s ease-out .25s;
}
.is-view.inview {
	opacity: 1;
	transform: translate3d(0, 0px, 0);
}
.inview-right {
	opacity: 0;
	transform: translate3d(30px, 30px, 0);
	transition: opacity .5s ease-out .25s, transform .5s ease-out .25s;
}
.is-view.inview-right {
	opacity: 1;
	transform: translate3d(0px, 0px, 0);
}
.inview-left {
	opacity: 0;
	transform: translate3d(-30px, 30px, 0);
	transition: opacity .5s ease-out .25s, transform .5s ease-out .25s;
}
.is-view.inview-left {
	opacity: 1;
	transform: translate3d(0px, 0px, 0);
}
*/