@charset "UTF-8";

.mynavmenu > li > div,
.mynavmenu li > ul,
.mynavmenu > li:hover > div,
.mynavmenu li:hover > ul {
	display:none ;
	z-index:-1;
}
.mynavmenu > li.nav-opened > div,
.mynavmenu li.sm-opened > ul {
display:block;
z-index:20;
}
@media screen and (min-width: 1020px) {
	.pc-hide{
		display: none;
	}
}
@media screen and (max-width: 1019px) {
	.sp-hide{
		display: none;
	}
}

/* ::::::::::::::::::::::::::::::::: HEADER ::::::::::::::::::::::::::::::::: */
header.mainHeader {
	height: 120px;
	width: 100%;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 1010;
	background: #FFF;
	box-shadow:0px 0px 5px 0px rgba(0,0,0,0.05);
	transition: opacity 0.4s ease;
}
header.mainHeader div.siteTitle {
	width: 200px;
	height: 90px;
	position: absolute;
	left: 50px;
	top: 15px;
	z-index: 2;
}
header.mainHeader img.small {
	display: none;
}
header.mainHeader ul.mainList {
	position: absolute;
	width: 85%;
	right: 0;
	bottom: 0px;
	height: 49px;
}
header.mainHeader ul.mainList li {
	display: inline-block;
	font-size: 16px;
	padding: 0 1.9%;
	vertical-align: top;
	/* height: 49px; */
}
@media  (min-width: 1020px) and (max-width: 1140px) {
	header.mainHeader ul.mainList li {
		font-size: 15px;
	}	
}

header.mainHeader ul.mainList li a {
	position: relative;
	line-height: 30px;
	color: #2b3034;
	display: block;
	z-index: 1;
	overflow: visible;
	/* height: 49px; */
}
header.mainHeader ul.mainList li a span {
	display: none;
	opacity: 0;

	position: absolute;
	left: 0;
	right: 0;
	bottom: -23px;
	margin: auto;
	width: 10px;
	height: 10px;
	background: #fff;
	transform: rotate(45deg);
}
header.mainHeader ul.mainList li.nav-opened a span {
	display: block;
	opacity: 1;
	transition: opacity 0.1s ease
}
header.mainHeader ul.mainList li a:hover {
	color: #777;
}
header.mainHeader ul.mainList li.active a {
	position: relative;
}
header.mainHeader ul.mainList li.active a::after {
	position: absolute;
	border-bottom: 1px solid #2b3034;
	width: 100%;
	content: "";
	left: 0;
	bottom: 0;
	margin: 0 auto;
}
header.mainHeader ul.mainList li .mainSubList {
/* 	opacity: 0; */
/* 	display: none; */
	position: absolute;
	width: 100vw;
	background: #5A5D61;
	right: 0;
	top: 49px;
	transition: opacity 0.4s ease;
	z-index: 0;
}
header.mainHeader ul.mainList li.on .mainSubList {
	opacity: 1;
	display: block;
}
header.mainHeader ul.mainList li .mainSubList .mainSubListInner {
	display: flex;
	padding: 10px 100px;
	justify-content: center;
	flex-wrap: wrap;
	box-sizing: border-box;
}
header.mainHeader ul.mainList li .mainSubList .mainSubListInner span {
	position: relative;
	display: inline-block;
	margin: 0;
}
header.mainHeader ul.mainList li .mainSubList .mainSubListInner span a {
	box-sizing: border-box;
	padding: 5px 25px;
	color: #FFF;
	font-size: 14px;
	height: auto;
}
header.mainHeader ul.mainList li.active .mainSubList .mainSubListInner span a::after {
	display: none;
}

header.mainHeader ul.mainList li .mainSubList .mainSubListInner span a:hover {
	color: #eee
}


header.mainHeader ul.bookingList {
	/* width: 360px; */
	height: 50px;
	position: absolute;
	right: 0;
	top: 0;
	display: flex;
}
header.mainHeader ul.bookingList li.lang,
header.mainHeader ul.bookingList li.booking {
	display: table-cell;
	vertical-align: top;
}
.mainHeader .bookingList li a {
	background: #8e835b;
	color: #FFF;
	display: block;
	font-size: 14px;
}
.bookingList .booking .search{
	padding: 0;
}
.bookingList .booking .search a{
	height: 100%;
	background: #2badbd url(../img/common/vector_small_bottom_white.svg) no-repeat right 10px top 21px;
	background-size: 7px 7px;
}
header.mainHeader.small .booking .search a {
	background-position: right 10px top 26px;
}
@media (min-width: 1021px){
	.bookingList .booking .search{
		width: 106px;
		height: 50px;
	}
}
@media (max-width: 1020px){
	.bookingListSp .booking .search{
		width: 60px;
		height: 60px;
		z-index: 2000;
		cursor: pointer;
		font-size: 14px;
		line-height: 1;
		a{
			display: flex;
			align-items: center;
			justify-content: center;
			width: 100%;
			height: 100%;
			background: #2badbd url(../img/common/vector_small_bottom_white.svg) no-repeat center bottom 9px;
			background-size: 7px 7px;
			color: #FFF;
			span{
				position: relative;
        top: -3px;
			}
		}
	}
}
.bookingList button {
	color: #FFF;
	line-height: 50px;
	display: block;
	font-size: 15px;
	width: 100%;
	height: 50px;
	background: #2badbd url(../img/common/vector_small_bottom_white.svg) no-repeat right 10px top 21px;
	background-size: 7px 7px;
	text-indent: -10px;
	padding: 0 30px;
}
.restaurant .bookingList .booking button,
.banquet .bookingList .booking button,
.rentalDress .bookingList .booking button{
	width: 240px;
}
header.mainHeader ul.bookingList li button.on {
	background-image: url(../img/common/vector_small_top_white.svg);
}
.bookingList .inquiry button{
	background-color: #008ccf;
}
.mainHeader .bookingList li{
	flex: auto;
}
/* header.mainHeader ul.bookingList li.lang {
	width: 120px;
} */
header.mainHeader ul.bookingList li.lang button {
	background-color: #2b3034;
	font-size: 13px;
}
/* header.mainHeader ul.bookingList li.booking {
	width: 240px;
} */
header.mainHeader ul.headerLangList {
	position: relative;
	display: none;
	background: #3c4145;
	color: #FFF;
	font-size: 13px;
	z-index: 1;
}
header.mainHeader ul.headerLangList li {
	display: block;
	border-bottom: 1px solid #2b3034;
}
header.mainHeader ul.headerLangList li:last-child {
	border: none;
}
header.mainHeader ul.headerLangList li span,
header.mainHeader ul.headerLangList li a {
	font-size: 13px;
	line-height: 40px;
}
header.mainHeader ul.headerLangList li span {
	font-weight: bold;
}
header.mainHeader ul.headerLangList li a {
	background: none;
	text-decoration: underline;
	color: #BBB;
}
header.mainHeader ul.headerLangList li a:hover {
	color: #999;
}
.mainHeader .subBlock {
	width: calc(100% - 870px);
	position: absolute;
	right: 560px;
	top: 18px;
	display: flex;
	justify-content: space-between;
}
.restaurant .mainHeader .subBlock,
.banquet .mainHeader .subBlock,
.rentalDress .mainHeader .subBlock{
	width: calc(100% - 690px);
	right: 410px;
}
.mainHeader h1 {
	font-weight: normal;
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, 'Hiragino Kaku Gothic ProN','メイリオ',Meiryo,'ＭＳ Ｐゴシック', sans-serif!important;
	font-size: 13px;
	text-align: left;
	color: #86898c;
	/* width: 65%; */
	max-height: 44px;
	overflow: hidden;
}
header.mainHeader div.subBlock ul {
	display: flex;
}
header.mainHeader div.subBlock ul li {
	display: inline-block;
	font-size: 13px;
	vertical-align: top;
}
header.mainHeader div.subBlock ul li::after {
	content: "";
	border-right: 1px solid #86898c;
	padding: 0 0 0 15px;
	margin: 0 10px 0 0;
}
header.mainHeader div.subBlock ul li:last-child::after {
	display: none;
	padding: 0;
}
header.mainHeader div.subBlock ul li a {
	color: #86898c;
	text-decoration: underline;
}
header.mainHeader div.subBlock ul li a:hover {
	color: #2badbd;
}

header.mainHeader.small {
	position: fixed;
	height: 60px;
}
header.mainHeader.small div.siteTitle {
	width: 195px;
	height: 36px;
	position: absolute;
	left: 30px;
	top: 12px;
}
header.mainHeader.small img.small {
	display: inherit;
}
header.mainHeader.small img.large {
	display: none;
}
header.mainHeader.small ul.mainList {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	width: 100%;
	/* right: 390px;
	left: 230px; */
	bottom: 0;
	height: 60px;
	/* padding: 0 390px 0 230px; */
	box-sizing: border-box;
}
header.mainHeader.small ul.mainList li {
	padding: 0 15px;
	font-size: 15px;
	/* height: 30px; */
}
@media (min-width: 1411px){
	header.mainHeader.small ul.mainList {
			padding: 0 390px 0 230px;
	}
	.restaurant header.mainHeader.small ul.mainList,
	.banquet header.mainHeader.small ul.mainList,
	.rentalDress header.mainHeader.small ul.mainList{
		padding: 0 240px 0 230px;
	}
}
@media (max-width: 1410px){
	header.mainHeader.small ul.mainList {
    right: 0;
		left: 0;
    top: 60px;
		height: 40px;
    background-color: #ffffff;
    width: 100%;
    gap: 30px;
		/* box-shadow: 0 5px 5px rgba(0,0,0,0.1) inset, 0 5px 5px rgba(0,0,0,0.1); */
	}
	.restaurant header.mainHeader.small ul.mainList,
	.banquet header.mainHeader.small ul.mainList,
	.rentalDress header.mainHeader.small ul.mainList{
		top: 0;
		height: 60px;
		gap: calc( 20 / 1410 * 100vw );
	}
	.restaurant header.mainHeader.small ul.mainList li,
	.banquet header.mainHeader.small ul.mainList li,
	.rentalDress header.mainHeader.small ul.mainList li{
		padding: 0;
	}
}
@media (max-width: 1150px){
	.restaurant header.mainHeader.small ul.mainList,
	.banquet header.mainHeader.small ul.mainList,
	.rentalDress header.mainHeader.small ul.mainList{
		gap: calc(7 / 1150* 100vw);
		margin-left: -1.5vw;
	}
}

header.mainHeader.small ul.mainList li a {
	line-height: 24px;
	/* height: 41px; */
}
/*header.mainHeader.small ul.mainList li a span {
	bottom: -22px;
}*/

header.mainHeader.small ul.mainList li.active a::after {
	bottom: 0;
}

header.mainHeader.small ul.mainList li .mainSubList {
	width: 102vw;
	right: 0;
	top: 60px;
}

header.mainHeader.small ul.bookingList {
	/* width: 190px; */
	height: 60px;
}
header.mainHeader.small ul.bookingList li.lang {
	display: none;
}
header.mainHeader.small ul.bookingList li button {
	color: #FFF;
	line-height: 60px;
	height: 60px;
	background-position: right 10px top 26px;
	font-size: 15px;
}
header.mainHeader.small div.subBlock {
	display: none;
}

.onlineShopLink{
	position: absolute;
	right: 0;
	top: 50px;
	z-index: 1011;
  width: 240px;
}
.onlineShopLink a{
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 70px;
	background: #ef6c93;
	box-sizing: border-box;
	color: #ffffff;
	font-weight: bold;
}
.onlineShopLink a span{
	position: relative;
	top: 2px;
}
.onlineShopLink .icon{
	margin-right: 5px;
	margin-top: -2px;
}
/* IE10 & IE11 */
_:-ms-input-placeholder, :root .onlineShopLink a span{
	top: 3px;
}
@media screen and (min-width: 1701px) {
	header.mainHeader ul.mainList {
		width: 92%;
	}
	header.mainHeader ul.mainList li {
		padding: 0 1%;
	}
}
@media screen and (max-width: 1700px) {
	header.mainHeader ul.mainList {
		position: absolute;
		width: 99%;
	}
	header.mainHeader ul.mainList li {
		padding: 0 1.5%;
	}
}
@media screen and (max-width: 1600px) {
	header.mainHeader ul.mainList {
		width: 96%;
	}
	header.mainHeader ul.mainList li {
		padding: 0 0.8%;
	}
	[lang="en"] header.mainHeader ul.mainList{
		width:100%;
	}
	[lang="en"] header.mainHeader ul.mainList li {
		padding: 0 0.3%;
	}
}
@media screen and (min-width: 1451px) {
	.mainHeader .subBlock {
		h1{
			flex: 1;
		}
		gap: 20px;
	}
}
@media screen and (max-width: 1450px) {
	.mainHeader .subBlock {
		flex-direction: column;
		left: 260px;
		right: auto;
		top: 8px;
		width: auto;
	}
}
@media screen and (max-width: 1340px) {
	header.mainHeader div.siteTitle {
		left: 10px;
	}
	.mainHeader .subBlock {
		left: 230px;
	}
	header.mainHeader ul.mainList {
		width: 100%;
	}
	header.mainHeader ul.mainList li {
		padding: 0 0.6%;
	}
	[lang="en"] header.mainHeader ul.mainList li {
		padding: 0 0.3%;
	}
}
@media screen and (max-width: 1200px) {
	.mainHeader .subBlock {
		justify-content: flex-end;
		top: 18px;
	}
	header.mainHeader div.subBlock h1 {
		display: none;
	}
}
@media screen and (max-width: 1200px) {
	header.mainHeader div.subBlock {
		justify-content: flex-end;
	}
	header.mainHeader div.subBlock h1 {
		display: none;
	}
	header.mainHeader ul.mainList li {
		padding: 0 0.3%;
	}
	header.mainHeader.small div.siteTitle {
		left: 15px;
	}
	header.mainHeader.small ul.mainList {
		/* right: 65px; */
	}
	header.mainHeader.small ul.mainList li {
		padding: 0 7px;
		font-size: 14px;
	}
}
@media screen and (max-width: 1135px) {
	header.mainHeader div.siteTitle{
		left: 1.5vw;
		width: 16.5vw;
	}
	.siteTitle img{
		width: 100%;
	}
	header.mainHeader ul.mainList {
    width: 102%;
	}
}
@media screen and (max-width: 1100px) {
	header.mainHeader div.siteTitle {
    width: 15.5vw;
	}
	.mainHeader .subBlock {
		left: 18.5vw;
	}
	header.mainHeader ul.mainList li {
		padding: 0 0.1%;
	}
	header.mainHeader ul.mainList {
		width: 107%;
	}
}
@media screen and (max-width: 1019px) {
	/* HEADER */
	.siteTitle img{
		width: auto;
	}
	header.spHeader {
		height: 60px;
		width: 100%;
		position: fixed;
		left: 0;
		top: 0;
		z-index: 1011;
		background: #FFF;
		box-shadow:0px 0px 5px 0px rgba(0,0,0,0.05);
	}
	header.spHeader div.siteTitle {
		height: 30px;
		padding: 15px 0 0 4%;
		text-align: left;
	}

	.spHeader{
		display: flex;
		justify-content: space-between;
	}
	.bookingListSp{
		display: flex;
	}
	button.modalOpenBtn.sp {
		width: 60px;
		height: 60px;
		background: #2badbd url(../img/common/vector_small_bottom_white.svg) no-repeat center 45px;
		background-size: 7px 7px;
		color: #FFF;
		/* position: fixed;
		right: 60px;
		top: 0; */
		z-index: 2000;
		cursor: pointer;
		font-size: 14px;
		line-height: 1;
	}
	button.modalOpenBtn span{
		position: relative;
		top: -3px;
	}
	button.spMenuBtn {
		position: relative;
		width: 60px;
		height: 60px;
		background: #2b3034;
		color: #FFF;
		/* position: fixed;
		right: 0;
		top: 0; */
		z-index: 2100;
		cursor: pointer;
		font-size: 8px;
	}
	button.spMenuBtn span.open,
	button.spMenuBtn span.close {
		padding: 30px 0 0;
		display: block;
	}
	button.spMenuBtn span.close {
		display: none;
	}
	button.spMenuBtn span.line {
		width: 18px;
		position: absolute;
		left: 0;
		right: 0;
		margin: 0 auto;
		border-top: 2px solid #f5f5f5;
		transition: all 0.2s ease;
	}
	button.spMenuBtn span.line1 {
		top: 18px;
	}
	button.spMenuBtn span.line2 {
		top: 28px;
	}
	button.spMenuBtn.open {
		background: #464b4f;
	}
	button.spMenuBtn.open span.open {
		display: none;
	}
	button.spMenuBtn.open span.close {
		display: block;
	}
	button.spMenuBtn.open span.line1 {
		top: 25px;
		transform: rotate(45deg);
	}
	button.spMenuBtn.open span.line2 {
		top: 25px;
		transform: rotate(-45deg);
	}

	button.modalOpenBtn.spTelBtn {
		width: 60px;
		height: 60px;
		background-color: #008ccf;
		background-size: 7px auto;
		/* color: #464B4F; */
		/* position: fixed;
		right: 120px;
		top: 0; */
		z-index: 1900;
		cursor: pointer;
		font-size: 8px;
	}

	button.spTelBtn span{	
		background: url(../img/common/mark_tel_white.svg) no-repeat center 15px / 16px 21px;
	}
	button.spTelBtn a {
		display: inline;
	}
	button.spTelBtn span {
		padding: 40px 0 0;
		display: block;
		top: -10px;
	}


	ul.spFixList {
		position: fixed;
		z-index: 1020;
		width: 100%;
		height: 50px;
		left: 0;
		bottom: -50px;
		display: table;
		table-layout: fixed;
		transition: bottom 0.6s ease;
	}
	ul.spFixList.on {
		bottom: 0;
	}
	ul.spFixList li {
		display: table-cell;
		vertical-align: bottom;
		text-align: center;
	}
	ul.spFixList li a {
		line-height: 50px;
		font-size: 14px;
		color: #FFF;
		background: #8e835b;
		display: block;
	}
	ul.spFixList li:last-child a {
		background: #153055;
	}

	.onlineShopLink {
		top: 80px;
		right: 20px;
		width: auto;
		border: 2px solid #e91e63;
	}
	.onlineShopLink a{
		width: 60px;
		height: auto;
		padding: 0;
	}
	.onlineShopLink a::before{
		display: none;
	}
	/* .onlineShopLink img{
		width: 100%;
	} */
}
@media screen and (max-width: 365px) {
	.noticeWrap{
		width: 207px;
	}
	.noticeWrap .sp{
		display: none !important;
	}
}
@media screen and (max-width: 340px) {
	header.spHeader div.siteTitle img {
		width: 120px;
		height: auto;
		margin: 5px 0 0;
	}
}


/* ::::::::::::::::::::::::::::::::: FOOTER ::::::::::::::::::::::::::::::::: */


footer.mainFooter {}
footer.mainFooter a {
	color: #FFF;
}
footer.mainFooter div.bnWrap {
	background: #e6e6e9;
	padding: 30px 0;
	overflow: hidden;
}
@media screen and (max-width: 1160px) {
	footer.mainFooter div.bnWrap {
		padding: 30px 0;
	}
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.bnWrap {
		padding: 30px 0;
	}
}
footer.mainFooter div.bnWrap div.inner {
	width: 990px;
	margin: 0 auto;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.bnWrap div.inner {
		width: auto;
		margin: 0 50px;
	}
}
footer.mainFooter div.bnWrap ul.footerBannerSlick {
	position: relative;
}
footer.mainFooter div.bnWrap ul.footerBannerSlick::after {
	content: "";
	clear: both;
	display: block;
}
footer.mainFooter div.bnWrap ul.footerBannerSlick button.slick-prev,
footer.mainFooter div.bnWrap ul.footerBannerSlick button.slick-next {
	position: absolute;
	width: 40px;
	height: 40px;
	top: 0;
	bottom: 0;
	margin: auto;
	overflow: hidden;
	text-indent: -999px;
}
footer.mainFooter div.bnWrap ul.footerBannerSlick button.slick-prev:hover,
footer.mainFooter div.bnWrap ul.footerBannerSlick button.slick-next:hover {
	opacity: 0.7;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.bnWrap ul.footerBannerSlick button.slick-prev:hover,
	footer.mainFooter div.bnWrap ul.footerBannerSlick button.slick-next:hover {
		opacity: 1;
	}
}
footer.mainFooter div.bnWrap ul.footerBannerSlick button.slick-prev {
	left: -60px;
	background: url(../img/common/vector_circle_left_black.svg) no-repeat center left;
	background-size: 40px 40px;
}
@media screen and (max-width: 1160px) {
	footer.mainFooter div.bnWrap ul.footerBannerSlick button.slick-prev {
		left: -40px;
	}
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.bnWrap ul.footerBannerSlick button.slick-prev {
		left: -45px;
	}
}
footer.mainFooter div.bnWrap ul.footerBannerSlick button.slick-next {
	right: -60px;
	background: url(../img/common/vector_circle_right_black.svg) no-repeat center left;
	background-size: 40px 40px;
}
@media screen and (max-width: 1160px) {
	footer.mainFooter div.bnWrap ul.footerBannerSlick button.slick-next {
		right: -40px;
	}
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.bnWrap ul.footerBannerSlick button.slick-next {
		right: -45px;
	}
}
@media screen and (max-width: 1160px) {
	footer.mainFooter div.bnWrap ul.footerBannerSlick ul.slick-dots {
		clear: both;
		margin: 0;
		padding: 28px 0 6px;
		width: 100%;
		max-width: 100%;
		text-align: center;
	}
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.bnWrap ul.footerBannerSlick ul.slick-dots {
		padding: 5px 0 7px;
	}
}
@media screen and (max-width: 1160px) {
	footer.mainFooter div.bnWrap ul.footerBannerSlick ul.slick-dots li {
		display: inline-block;
		width: 8px;
		height: 8px;
		cursor: pointer;
		background: #FFF;
		margin: 0 4px;
		padding: 0;
		overflow: hidden;
		text-indent: -999px;
		border-radius: 50%;
		float: none;
		box-sizing: border-box;
	}
	footer.mainFooter div.bnWrap ul.footerBannerSlick ul.slick-dots li.slick-active {
		background: #2b3034;
		border: none;
	}
}
footer.mainFooter div.bnWrap ul {
	width: auto;
	/*width: 990px;*/
	_zoom: 1;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.bnWrap ul {
		/*width: auto;
		width: 75vw;
		padding: 0 50px;*/
	}
}
footer.mainFooter div.bnWrap ul li {
	/*width: 310px;*/
	float: left;
	padding: 0 15px;
}
@media screen and (max-width: 1160px) {
	footer.mainFooter div.bnWrap ul li {
		padding: 0 5px;
	}
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.bnWrap ul li {
		padding: 0 5px;
	}
}
/*footer.mainFooter div.bnWrap ul li:last-child {
	padding: 0;
}*/
@media screen and (max-width: 1019px) {
	/*footer.mainFooter div.bnWrap ul li:last-child {
		padding: 0 15px 20px;
	}*/
	footer.mainFooter div.bnWrap ul li img {
		width: 100%;
		height: auto;
	}
}

footer.mainFooter div.mainWrap {
	background: #353a3e;
}
footer.mainFooter div.mainWrap div.inner {
	padding: 10px 40px 50px;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.mainWrap div.inner {
		padding: 0 15px 50px;
	}
}
footer.mainFooter div.mainWrap ul.breadcrumbs {
	border-bottom: 1px solid #53575b;
	padding: 20px 10px;
	font-size: 11px;
	text-align: left;
	color: #CCC;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.mainWrap ul.breadcrumbs {
		padding: 15px 0;
	}
}
footer.mainFooter div.mainWrap ul.breadcrumbs a {
	color: #CCC;
}
footer.mainFooter div.mainWrap ul.breadcrumbs a:hover {
	text-decoration: underline;
}
footer.mainFooter div.mainWrap ul.breadcrumbs li {
	display: inline-block;
	padding: 0 8px 0 20px;
	background: url(../img/common/breadcrumbs_page.svg) no-repeat 0px 3px;
	background-size: 12px 12px;
}
footer.mainFooter div.mainWrap ul.breadcrumbs li:first-child {
	background-image: url(../img/common/breadcrumbs_home.svg);
}

footer.mainFooter div.mainWrap h2 {
	color: #b3b3b3;
	font-size: 12px;
	text-align: left;
	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, 'Hiragino Kaku Gothic ProN','メイリオ',Meiryo,'ＭＳ Ｐゴシック', sans-serif!important;
	width: 90%;
	margin: 0 auto;
	padding: 45px 0 0;
	box-sizing: border-box;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.mainWrap h2 {
		padding: 25px 15px;
		width: 100%;
	}
}

footer.mainFooter div.mainWrap ul.snsList {
	text-align: right;
	padding: 45px 0 0;
	margin: 0 0 -25px;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.mainWrap ul.snsList {
		padding: 25px 15px 0 0;
		margin: 0 0 -25px;
	}
}
footer.mainFooter div.mainWrap ul.snsList li {
	display: inline-block;
	padding: 0 0 0 15px;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.mainWrap ul.snsList li {
		padding: 0 0 0 8px;
	}
}
footer.mainFooter div.listWrap {
	text-align: left;
	display: table;
	width: 90%;
	margin: 0 5% 60px;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.listWrap {
		display: block;
		width: auto;
		padding: 0 15px;
		margin: 0 0 50px;
	}
}
footer.mainFooter div.listWrap div {
	display: table-cell;
	padding: 0 30px 0 0;
	width: 23%;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.listWrap div {
		display: block;
		padding: 0;
		width: 100%;
	}
}
footer.mainFooter div.listWrap div.line1,
footer.mainFooter div.listWrap div.line3 {
	width: 16%;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.listWrap div.line1,
	footer.mainFooter div.listWrap div.line3 {
		width: 100%;
	}
}
footer.mainFooter div.listWrap ul {
	margin: 0 0 20px;
	font-size: 15px;
}
footer.mainFooter div.listWrap ul li {
	margin: 0 0 5px;
}
footer.mainFooter div.listWrap ul a {
	display: block;
}
footer.mainFooter div.listWrap ul a:hover {
	text-decoration: underline;
}
footer.mainFooter div.listWrap ul a.serif {
	margin: 0 0 10px;
}
footer.mainFooter div.listWrap ul ul {
	font-size: 14px;
	padding: 0;
}
footer.mainFooter div.listWrap ul ul li {
	padding: 0 0 0 15px;
	position: relative;
}
footer.mainFooter div.listWrap ul ul {
	font-size: 14px;
	padding: 0;
}
footer.mainFooter div.listWrap ul ul li::before {
	position: absolute;
	content: "";
	width: 4px;
	height: 4px;
	left: 0;
	top: 8px;
	border-radius: 50%;
	border: 1px solid #FFF;
}
footer.mainFooter div.infoWrap {
	background: #FFF;
	border-radius: 50px;
	display: flex;
	justify-content: flex-start;
	text-align: left;
	align-items: center;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.infoWrap {
		border-radius: 6px;
		display: block;
		text-align: center;
		padding: 30px 15px 35px;
	}
}
footer.mainFooter div.infoWrap div.left {
	padding: 26px 40px 26px 55px;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.infoWrap div.left {
		padding: 0 0 15px;
	}
	footer.mainFooter div.infoWrap div.left img {
		width: 238px;
		height: 44px;
	}
}
footer.mainFooter div.infoWrap div.center {}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.infoWrap div.center {
		padding: 0 0 15px;
	}
}
footer.mainFooter div.infoWrap div.center p.title {
	font-size: 15px;
	text-align: left;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.infoWrap div.center p.title {
		text-align: center;
	}
}
footer.mainFooter div.infoWrap div.center p.checkIn {
	font-size: 11px;
	text-align: left;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.infoWrap div.center p.checkIn {
		text-align: center;
	}
}
footer.mainFooter div.infoWrap div.right {
	padding: 10px 50px 10px 60px;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.infoWrap div.right {
		padding: 0;
	}
}

footer.mainFooter div.infoWrap div.right p.tel {
	font-size: 22px;
	line-height: 1.2;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.infoWrap div.right p.tel {
		padding: 0 0 15px;
	}
}
footer.mainFooter div.infoWrap div.right p.tel span {
	color: #2badbd;
	font-size: 30px;
}
.mainFooter .address .tel a {
	color: #2b3034;
}
footer.mainFooter div.infoWrap div.right p.address {
	font-size: 14px;
}
footer.mainFooter div.bottomBar {
	background: #2b3034;
	position: relative;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.bottomBar {
		padding: 0 0 60px;
		height: 140px;
	}
}
footer.mainFooter div.bottomBar ul.linkList {
	font-size: 15px;
	text-align: left;
	width: 350px;
	position: absolute;
	left: 40px;
	top: 10px;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.bottomBar ul.linkList {
		text-align: center;
		width: 100%;
		position: relative;
		left: 0;
		top: 0;
	}
}
footer.mainFooter div.bottomBar ul.linkList li {
	float: left;
	padding: 0 20px 0 0;
	line-height: 1.5;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.bottomBar ul.linkList{
		padding-top: 25px;
	}
	footer.mainFooter div.bottomBar ul.linkList li {
		float: none;
		padding: 0 10px;
		display: inline-block;
	}
}
footer.mainFooter div.bottomBar ul.linkList li a {
	color: #DDD;
}
footer.mainFooter div.bottomBar ul.linkList li a:hover {
	text-decoration: underline;
}
footer.mainFooter div.bottomBar p.pageTop {
	background: rgba(43,48,52,0.9);
	width: 190px;
	position: fixed;
	right: 0;
	bottom: -60px;
	z-index: 2001;
	transition: all 0.5s ease;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.bottomBar p.pageTop {
		width: 60px;
		height: 60px;
		overflow: hidden;
	}
}
footer.mainFooter div.bottomBar p.pageTop.on {
	bottom: 0;
}
footer.mainFooter div.bottomBar p.pageTop.end {
	bottom: 0;
	background: #575b5e;
	width: 240px;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.bottomBar p.pageTop.end {
		bottom: 0;
		width: 100%;
	}
}
footer.mainFooter div.bottomBar p.pageTop a {
	line-height: 60px;
	display: block;
	width: 100%;
	color: #FFF;
	font-size: 15px;
	background: url(../img/common/vector_line_top_white.svg) no-repeat right 15px top 20px;
	background-size: 20px 20px;
}
@media screen and (max-width: 1019px) {
	footer.mainFooter div.bottomBar p.pageTop a {
		width: 100vw;
		position: absolute;
		right: 0;
		bottom: 0;
		background-position: right 20px top 20px;
	}
}
footer.mainFooter div.bottomBar p.copyright {
	color: #AAA;
	font-size: 10px;
	line-height: 60px;
}

div.spMenuWrap {
	display: none;
}
@media screen and (max-width: 1019px) {
	/* SP MENU */
	div.spMenuWrap {
		height: 100%;
		height: calc(100% - 60px);
		overflow: hidden;
		position: fixed;
		width: 100%;
		left: 0;
		top: 60px;
		z-index: 2000;
		display: block;
		opacity: 0;
		transition: all 0.4s ease;
		visibility: hidden;
	}
	div.spMenuWrap div.base {
		position: absolute;
		width: 100%;
		height: 100%;
		overflow-y: auto;
		left: 0;
		top: 0;
		background: #34393d;
		background: rgba(52,57,61,0.95);
		-webkit-overflow-scrolling: touch;
		overflow-scrolling: touch;
	}
	div.spMenuWrap div.inside {
		width: 100%;
		margin: 0 0 0 100%;
		transition: margin 0.4s ease;
		position: relative;
		z-index: 10;
	}
	div.spMenuWrap div.topBlock {
		background: #FFF;
		padding: 30px 15px 35px;
		display: block;
		text-align: center;
	}
	div.spMenuWrap div.topBlock p.title {
		font-size: 15px;
		margin: 0 0 5px;
	}
	div.spMenuWrap div.topBlock p.checkIn {
		font-size: 11px;
		margin: 0 0 15px;
	}
	div.spMenuWrap div.topBlock p.tel {
		font-size: 22px;
		line-height: 1.2;
		margin: 0 0 10px;
	}
	div.spMenuWrap div.topBlock p.tel span {
		color: #2badbd;
		font-size: 30px;
	}
	div.spMenuWrap div.topBlock p.address {
		font-size: 14px;
	}
	div.spMenuWrap ul.langList {
		padding: 17px 10px 17px;
		font-size: 13px;
		background: #e6e6e9;
	}
	div.spMenuWrap ul.langList li {
		display: inline-block;
	}
	div.spMenuWrap ul.langList li::after {
		content: "/";
		padding: 0 1px 0 2px;
		color: #a1a2a4;
	}
	div.spMenuWrap ul.langList li:last-child::after {
		display: none;
		padding: 0;
	}
	div.spMenuWrap ul.langList li span {
		color: #2b3034;
		font-weight: bold;
	}
	div.spMenuWrap ul.langList li a {
		color: #a1a2a4;
		text-decoration: underline;
	}
	div.spMenuWrap div.listWrap {
		padding: 5px 20px;
	}
	div.spMenuWrap div.listWrap ul {
		text-align: left;
	}
	div.spMenuWrap div.listWrap ul li {
		border-bottom: #555 1px solid;
		border-color: rgba(255,255,255,0.15);
		font-size: 15px;
		position: relative;
	}
	div.spMenuWrap div.listWrap ul li a {
		color: #FFF;
		display: block;
		padding: 15px 0;
	}
	div.spMenuWrap div.listWrap ul ul {
		margin: -4px 0 17px;
		display: none;
	}
	div.spMenuWrap div.listWrap ul ul li {
		border: none;
		padding: 0 0 0 30px;
		position: relative;
	}
	div.spMenuWrap div.listWrap ul ul li::before {
		position: absolute;
		content: "";
		width: 4px;
		height: 4px;
		left: 15px;
		top: 10px;
		border-radius: 50%;
		border: 1px solid #FFF;
	}
	div.spMenuWrap div.listWrap ul ul li a {
		padding: 0;
		font-size: 14px;
		line-height: 2;
	}
	div.spMenuWrap div.listWrap span.spToggleMenu {
		width: 25px;
		height: 25px;
		position: absolute;
		right: 5px;
		top: 15px;
		background: url(../img/common/mark_a_open.svg) no-repeat center center;
		background-size: 15px 15px;
		display: block;
		cursor: pointer;
	}
	div.spMenuWrap div.listWrap span.spToggleMenu.on {
		background-image: url(../img/common/mark_a_close.svg);
	}
	div.spMenuWrap ul.bottomList {
		padding: 20px 15px 25px;
		opacity: 0.8;
		color: #FFF;
		font-size: 13px;
	}
	div.spMenuWrap ul.bottomList li {
		padding: 0 12px 0 10px;
		display: inline-block;
		position: relative;
	}
	div.spMenuWrap ul.bottomList li::after {
		content: "";
		border-right: 1px solid #FFF;
		position: absolute;
		height: 12px;
		right: 0;
		top: 0;
		bottom: 0;
		margin: auto 0;
	}
	div.spMenuWrap ul.bottomList li:last-child::after {
		display: none;
	}
	div.spMenuWrap ul.bottomList li a {
		text-decoration: underline;
		color: #FFF;
	}

	div.spMenuWrap.on {
		opacity: 1;
		left: 0;
		visibility: visible;
	}
	div.spMenuWrap.on div.inside {
		margin: 0;
	}

}
