@charset "utf-8";
body{
	font-size: 1rem;
	font-weight: 400;
	line-height: 1.5;
	color: #212529;
}
body:before{
	content: "";
	position: fixed;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	background: #2d2726;
	z-index: -1;
}
.lightcase-open body{overflow: auto;}
a{color:#323232;}
a,
a img,
button{
	transition: all 0.4s;
	cursor: pointer;
}
a img{backface-visibility:hidden;}
a.opacity{text-decoration: none;}
a.opacity:hover,
a:hover img,
button:hover{opacity: 0.7;}
section sub,
section sup{font-size: 50%;}
.alphL,
#function .functionList li:before{
	font-family: "Heebo","Helvetica Neue",sans-serif!important;
	font-weight:lighter;
}
.alph,
footer #ftMenu .subFtMenu>li,
#titleBlock h2,
#titleBlock.subBefore h2 .title1{
	font-family:"Heebo","Helvetica Neue",sans-serif!important;
	font-weight:normal;
	letter-spacing: 0.1rem;
}
section h2,
.alphB,
header .navigations li a span.enName,
footer #ftMenu>li,
#titleBlock.subBefore h2 .title2,
#titleBlock.subBefore h2 .enName,
#goTop a{
	font-family: "Heebo","Helvetica Neue",sans-serif!important;
	font-weight: bold;
	letter-spacing: 0.15rem;
}
#action{
	position:fixed;
	bottom:0;
	left:0;
	width: 100%;
	height: 100%;
	z-index:10000;
	opacity:0.8;
	background:#2d2726 url(/common/img/plugin/ajax-loader.svg) no-repeat center center;
	transition:all 0.4s linear 0.75s;
}
span[data-ruby]{position: relative;}
span[data-ruby]:before{
	content:attr(data-ruby);
	position:absolute;
	top:-1rem;
	left:0;
	right:0;
	margin:auto;
	font-size:1.0rem;
	text-align: center;
	line-height:1.0;
	transform-origin: center bottom;
	transform:scale(0.7);
}
#mainWrap{margin-top: 56px;}
.incEnd #action{
	height:0;
	bottom:-100px;
	opacity: 0;
}
.incEnd section.centerMv h3{animation:textDelay 0.8s ease 1.0s forwards normal;}
.incEnd section.centerMv p{animation:textDelay 0.8s ease 1.6s forwards normal;}


/************************************
header
*************************************/
header{
	position:fixed;
	top:0;
	left:0;
	z-index:5;
	width:100%;
	text-align:center;
	background:#2d2726;
	transition: all 0.4s;
}
header:after{
	content: "";
	display: block;
	clear: both;
}
header *{display: block;}
header h1{padding:15px;}
header h1 a{width:95px;}
header h1 img{width: 100%;}
header .myPage{float:right;padding:14px 15px;}
header .myPage a{
	width: 26px;
	height: 26px;
	text-indent: -9999px;
	background:url(/common/img/icon-mypage-white.svg) no-repeat center center;
	background-size:contain;
}
header .navigations *{transition: all 0.4s;}
header .navigations li a{color: #fff;}
header .navigations li a span{
	display: block;
	font-size:1.0rem;
}
header .navigations li.myroomBtn a{
	background:#ffffff;
	color:#2d2726;
	border-radius: 4px;
}
header .navigations li.myroomBtn a .jpName{color:#2d2726;}
header .navigations li.contactBtn a{
	background:#007bff;
	border-radius: 4px;
}
header #mainNavi li.parents .subMenu li .credit-txt{
	position: absolute;
	right: 5px;
	bottom: 3px;
}
header #mainNavi > li.contactBtn > a:after{content: none;}
header .navigations li span.jpName{
	margin-top: 5px;
	color: #b1afae;
	letter-spacing: 0.11rem;
	font-weight:bold;
}
header .navigations li.contactBtn span.jpName{color:#ffe7e7;}
header #mainNavi{
	display:flex;
	justify-content:space-between;
	padding:0;
	margin:0 auto;
	text-align: center;
	line-height:1.0;
}
header #mainNavi li{
	display: inline-block;
	font-size: 1.2rem;
}
header #mainNavi li.parents{position: relative;}
header #langNav li{
	text-align:right;
	display: inline-block;
}
header #langNav li+li:before{
	content:"/";
	margin-right: 4px;
	display: inline-block;
	color: #fff;
}
header #langNav li a{
	display: inline-block;
	color: #fff;
	font-size: 1.3rem;
}
html[lang="ja"] header #langNav li[data-lang="en"] a,
html[lang="en"] header #langNav li[data-lang="ja"] a{color: #9ea8b2;}


/************************************
footer
*************************************/
#ftBanner{
	width:100%;
	max-width:initial;
	padding:62px 0;
	background: #fff;
	text-align: center;
}
#ftBanner ul,
#ftBanner ul li{
	list-style: none;
	padding: 0;
	display: inline-block;
	margin: 0 auto;
}
#ftBanner ul li{margin: 0 6px;}
#ftBanner ul li:last-child{
	width:100%;
	margin: 0 auto;
}
#ftBanner ul li a{display: block;}
#ftBanner ul li:last-child a{display: inline-block;}
footer{
	position: relative;
	background:#a1a1a1;
	text-align: center;
}
footer:before{
	display: block;
	content: "";
	width: 100%;
	height: 1px;
}
footer > *{
	position: relative;
	max-width:1048px;
	width: 90vw;
	margin: 0 auto;
}
footer .breadcrumbs{
	display: block;
	border-bottom: 1px solid #ababab;
	text-align:left;
	font-family: "Heebo","Helvetica Neue","Helvetica Neue", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif;
	color: #fff;
	font-size: 1.2rem;
	vertical-align: middle;
}
footer .breadcrumbs li{
	display: inline-block;
	padding-bottom: 6px;
	font-weight:bold;
	letter-spacing: 0.1rem;
}
footer .breadcrumbs a{
	display: block;
	font-weight:normal;
	color: #fff;
}
footer .breadcrumbs a:after{
	content: "";
	display: inline-block;
	width: 6px;
	height: 9px;
	margin: 0 8px 0 10px;
	background:url(/common/img/gray-arrow-next.svg) no-repeat center center;
	background-size: contain;
}
footer #translation{
	position:absolute;
	right:0;
	top: -52px;
}
footer label[for="translationSelect"]{
	display: inline-block;
	padding: 2px 0;
	margin: 0;
	color: #fff;
}
footer #translationSelect{
	display: inline-block;
	padding:2px 30px 2px 2px;
	-webkit-appearance: none;
	appearance: none;
	width:auto;
	border:none;
	outline: none;
	background:#fff url(/common/img/pink-arrow-down.svg) no-repeat 98% 50%;
	-webkit-background-size:12px;
	background-size:12px;
	font-family:sans-serif;
}
footer select#translationSelect:focus{
	background-color: #fff4f4;
	border-bottom: 0.3rem solid #f35454;
}
footer select#translationSelect:focus{background-image: url(/common/img/pink-arrow-up.svg);}
footer #ftMenu{
	padding: 0;
	margin: 0 auto;
	text-align: left;
}
footer #ftMenu li{list-style:none;}
footer #ftMenu>li{
	display: inline-block;
	vertical-align:top;
	font-size: 1.4rem;
	text-align: left;
}
footer #ftMenu li a{color: #fff;}
footer #ftMenu .subFtMenu{padding:0;}
footer #ftMenu .subFtMenu>li{
	margin-top:8px;
	opacity: 0.6;
	font-size:1.2rem;
}
footer .copyrights{
	display: block;
	padding:22px 0 8px!important;
	margin: 0 auto;
	border-top: 1px solid #ababab;
	color: #fff;
	font-size: 1.2rem;
	text-align: center;
	line-height: 1.0;
	letter-spacing: 0.1rem;
}
footer #btmNavi{
	padding: 0 0 48px;
	width: 100%;
	margin: 0 auto;
	font-size:0;
}
footer #btmNavi li{
	display: inline-block;
	padding: 0 10px;
	list-style: none;
	font-size: 1.1rem;
}
footer #btmNavi a{
	display:block;
	color: #fff;
}
@media all and (-ms-high-contrast:none){
	#ftBanner{max-width:auto;}
}


/************************************
titleBlock
*************************************/
#titleBlock{text-align: center;}
#titleBlock h2{
	text-align: center;
	color: #000;
}
#titleBlock.logoBefore h2{
	margin:0 auto;
	width:244px;
	font-size:1.8rem;
}
#titleBlock.logoBefore h2:before{
	content: "";
	display: block;
	width:100%;
	height:0;
	padding-top:26.666%;
	margin:0 auto 35px;
	background:url(/common/img/logo.svg) no-repeat center top;
	background-size: contain;
}
#titleBlock.logoBefore h2 span{display: block;}
#titleBlock.subBefore h2:not(:last-child){margin-bottom: 25px;}
#titleBlock.subBefore h2 span{display: block;}
#titleBlock.subBefore h2 .title1{font-size: 2.0rem;}
#titleBlock.subBefore h2 .title2{
	margin: 15px auto 0;
	font-size:4.5rem;
}
#titleBlock.subBefore h2 .enName{
	margin: 0 auto 15px;
	font-size:4.5rem;
}
#titleBlock.subBefore h2 .jpName{font-size: 2.0rem;}
#titleBlock.subBefore p{
	display: block;
	width: 50vw;
	margin: 0 auto;
	font-size: 1.8rem;
	line-height:2.0;
	color: #393939;
	font-weight: bold;
}

@media screen and (min-width:641px){
	#main{height: auto;}
}
@media screen and (min-width:769px){
	#titleBlock.logoBefore h2:before{margin-top: -15px;}
	footer #ftMenu{display: block;}
	footer #ftMenu > li{display:inline-block;}
	footer #ftMenu>li .jpName{display: none;}
	footer #btmNavi li{border-right: 1px solid #fff;}
	footer #btmNavi li:last-child{border-right:none;}
}
@media screen and (min-width:1081px){
	/************************************
	header
	*************************************/
	header h1{float:left;}
	header .navigations{
		display:block;
		padding: 15px 110px;
	}
	header #mainNavi{width:740px;}
	header #mainNavi li.parents:before{
		content: "";
		display: block;
		position: absolute;
		top: -14px;
		left:-6px;
		width:calc(100% + 12px);
		z-index: 1;
		opacity: 0;
		background:#362f2e;
		transition: all 0.4s;
	}
	header #mainNavi li.parents a{
		position: relative;
		z-index: 2;
	}
	header #mainNavi li.parents:hover:before{
		height: calc(100% + 32px);
		opacity: 1;
	}
	header #mainNavi li.parents .subMenu,
	header #mainNavi li.parents .subMenu *{transition: all 0.6s;}
	header #mainNavi li.parents .subMenu{
		position:fixed;
		top:55px;
		left:0;
		width: 100%;
		height: 0;
		padding:0;
		overflow: hidden;
		background:#2d2726;
	}

	header #mainNavi li.parents:hover .subMenu{
		justify-content: center;
		height: auto;
		padding-top: 16px;
    	padding-bottom: 16px;
		background:#362f2e;
	}
	header #mainNavi li.parents .subMenu li{
		position: relative;
		display: inline-block;
		width: calc(33% - 24px);
		max-width: 287px;
		margin: 0 5px;
		text-align: center;
		white-space: nowrap;
	}
	header #mainNavi li.parents .subMenu li:nth-child(n+5){margin-top:10px;}
	header #mainNavi li.parents .subMenu li:before{
		content: "";
		width:100%;
		height: 0;
		padding-top: 59.93%;
		display: block;
	}
	header #mainNavi li.parents .subMenu li a{
		position:absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		display:flex;
		flex-direction:column;
		align-items: center;
		justify-content: center;
		width: 100%;
		height: 100%;
		color: #fff;
		background-repeat: no-repeat;
		background-position: center center;
		background-size: cover;
	}
	header #mainNavi li.parents .subMenu li a:before{
		content:"";
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background:rgba(0,0,0,0.25);
		z-index: 0;
	}


	header #mainNavi li.parents .subMenu li[data-category="harajuku"] a{background-image: url(/common/img/gnav/gnav_locations_harajuku.jpg);}
	header #mainNavi li.parents .subMenu li[data-category="hisayaodori"] a{background-image: url(/common/img/gnav/gnav_locations_hisayaodori.jpg);}
	header #mainNavi li.parents .subMenu li[data-category="otemachi"] a{background-image: url(/common/img/gnav/gnav_locations_otemachi.jpg);}
	header #mainNavi li.parents .subMenu li[data-category="akihabara"] a{background-image: url(/common/img/gnav/gnav_locations_akihabara.jpg);}
	header #mainNavi li.parents .subMenu li[data-category="minamiaoyama"] a{background-image: url(/common/img/gnav/gnav_locations_minamiaoyama.jpg);}
	header #mainNavi li.parents .subMenu li[data-category="akihabara2"] a{background-image: url(/common/img/gnav/gnav_locations_akihabara2.jpg);}
	header #mainNavi li.parents .subMenu li[data-category="kamikitazawa"] a{background-image: url(/common/img/gnav/gnav_locations_kamikitazawa.jpg);}
	header #mainNavi li.parents .subMenu li[data-category="kawasaki"] a{background-image: url(/common/img/gnav/gnav_locations_kawasaki.jpg);}
	header #mainNavi li.parents .subMenu li[data-category="l-lab"] a{background-image: url(/common/img/gnav/gnav_locations_l-lab.jpg);}
	header #mainNavi li.parents .subMenu li[data-category="workspace"] a{background-image: url(/common/img/gnav/gnav_locations_workroom.jpg);}
	header #mainNavi li.parents .subMenu li[data-category="rentalspace"] a{background-image: url(/common/img/gnav/gnav_locations_rentalroom.jpg);}
	header #mainNavi li.parents .subMenu li[data-category="share"] a{background-image: url(/common/img/gnav/gnav_locations_share.jpg);}
	header #mainNavi li.parents .subMenu li[data-category="rentallounge"] a{background-image: url(/common/img/gnav/gnav_locations_rentallounge.jpg);}
	header #mainNavi li.parents .subMenu li span{
		display: block;
		text-shadow: 1px 1px 2px rgba(0,0,0,0.5);
	}
	header #mainNavi li.parents .subMenu li a span{
		position: relative;
		z-index: 1;
	}
	header #mainNavi li.parents .subMenu li .jpName{
		font-size: 1.2rem;
		color: #fff;
	}
	header #mainNavi li.parents .subMenu li .enName{
		margin-top:10px;
		font-size: 1.5rem;
	}
	header #langNav{
		position: absolute;
		top:20px;
		right:24px;
		text-align:right;
	}
	header #mainNavi li a{
		display: block;
		position: relative;
		padding: 0 6px;
	}
	header #mainNavi li.contactBtn a,
	header #mainNavi li.myroomBtn a{
		padding: 9px 18px;
		margin: -9px 0;
	}
	header #mainNavi > li > a:after{
		content: "";
		position: absolute;
		left: 0;
		top: calc(100% + 12px);
		width: 100%;
		height: 4px;
		background: #fff;
		opacity: 0;
		transition: all 0.4s;
	}
	header #mainNavi li a{text-decoration: none;}
	header #mainNavi li a:hover{opacity: 0.4;}
	header #mainNavi li.myroomBtn a:after{content: none;}
	header #mainNavi > li > a:hover:after,
	header #mainNavi > li > a.active:after{opacity: 1;}
	header .navigationsInner{overflow:visible!important;}

	/************************************
	footer
	*************************************/
	footer > *{width:80vw;}
	footer .breadcrumbs{margin:50px auto 0;}
	footer .ftMenuOuter{margin: 20px auto;}
	footer #ftMenu{width:900px;}
	footer #ftMenu>li{width:146px;}
	footer #ftMenu>li:nth-child(5){width:296px;}
	footer #ftMenu > li:nth-child(n+6){margin-top:16px;}
	
	
	/************************************
	titleBlock
	*************************************/
	#titleBlock{padding:80px 0 40px;}
	#titleBlock.logoBefore h2 span{margin:0 -200px;}
}
@media screen and (min-width:769px) and (max-width:1080px){
	/************************************
	header
	*************************************/
	header h1{
		box-sizing:content-box;
		padding:14px 15px;
	}
	header h1 a{
		background:url(/common/img/logo-white.svg) no-repeat left top;
		background-size: contain;
	}
	header h1 img{opacity: 0;}
	header h1 a{margin: 0 auto;}
	header .navigations{
		display:block;
		width: 100%;
		height: 0;
		padding: 0;
		overflow:hidden;
		transition: all 0.4s;
		-webkit-overflow-scrolling: touch;
	}
	header .navigationsInner{
		position: relative;
		width:100%;
		height: 100%;
		padding: 0 5vw;
		overflow-y:auto;
	}
	header .navigations li a span.enName{
		display:inline-block;
		font-size: 1.5rem;
	}
	header .navigations li a span.jpName{
		display:inline-block;
		margin-left: 16px;
		font-size: 1.1rem;
	}
	header #mainNavi,
	header #langNav{
		display: block;
		width: 100%;
		padding:0;
		max-width:initial;
	}
	header #mainNavi li{margin: 0;}
	header #mainNavi .subMenu{
		display: block;
		width: 100%;
		padding: 0;
	}
	header #gNavBtn{
		position: absolute;
		top: 0;
		left: 0;
		width: 28px;
		height: 22px;
		padding: 16px;
		display: block;
		box-sizing:content-box;
	}
	header #gNavBtn a{
		display: block;
		width: 100%;
		height: 100%;
		position: relative;
		transition: all .4s;
	}
	header #gNavBtn a:before,
	header #gNavBtn a span,
	header #gNavBtn a:after{
		content: "";
		display: block;
		width: 100%;
		height:4px;
		border-radius:4px;
		background:#fff;
		position: absolute;
		left: 0;
		transition: all .4s;
	}
	header #gNavBtn a:before{top: 0;}
	header #gNavBtn a span{
		top: 50%;
		margin-top: -2px;
	}
	header #gNavBtn a:after{bottom: 0;}
	header #contactSpBtn{
		position: absolute;
		top:9px;
		right:10px;
		display: inline-block;
		vertical-align: middle;
		box-sizing:content-box;
	}
	header #contactSpBtn a{
		display: inline-block;
		padding: 3px 0;
		text-align: center;
		border-radius: 4px;
		line-height: 1.0;
		background: #007bff;
	}
	header #contactSpBtn a:before{
		content: "";
		display: block;
		margin: 0 auto;
		width: 24px;
		height: 24px;
		background: url(/common/img/mail-icon-white.svg) no-repeat center center;
		background-size: contain;
	}
	header #contactSpBtn a span{
		display: block;
		margin-top: -2px;
		font-size: 10px;
		text-align: center;
		transform-origin: center bottom;
		transform: scale(0.7);
		letter-spacing: 0;
		color: #fff;
	}
	header #myroomSpBtn{
		position: absolute;
		top:9px;
		right:60px;
		display: inline-block;
		vertical-align: middle;
		box-sizing:content-box;
	}
	header #myroomSpBtn a{
		display: inline-block;
		padding: 3px 0;
		text-align: center;
		border-radius: 4px;
		line-height: 1.0;
		background:#fff;
		color:#2d2726;
	}
	header #myroomSpBtn a:before{
		content: "";
		display: block;
		margin: 0 auto;
		width: 24px;
		height: 24px;
		background: url(/common/img/mypage-icon-brown.svg) no-repeat center center;
		background-size: contain;
	}
	header #myroomSpBtn a span{
		display: block;
		margin-top: -2px;
		font-size: 10px;
		text-align: center;
		transform-origin: center bottom;
		transform: scale(0.7);
		letter-spacing: 0;
		color:#2d2726;
	}
	header #mainNavi{margin:20px 0 120px;}
	header #mainNavi > li{
		display: block;
		text-align: left;
		padding: 24px 24px 24px 8px;
	}
	header #mainNavi > li.contactBtn{display: none;}
	header #mainNavi .parents{padding-right: 0;}
	header #mainNavi .parents>a{pointer-events: none;}
	header #mainNavi li+li{border-top: 2px solid #184b68;}
	header #mainNavi li a{
		position: relative;
		display: block;
		color: #fff;
		font-size: 1.5rem;
	}
	header #mainNavi li.contactBtn a{
		display: inline-block;
		padding: 16px;
		text-align: center;
	}
	header #mainNavi li a:after{
		content: "";
		display: block;
		position: absolute;
		top: 50%;
		right: -8px;
		width: 8px;
		height: 13px;
		margin-top: -6px;
		background:url(/common/img/pink-arrow-next.svg) no-repeat center center;
		background-size:contain;
	}
	header #mainNavi li.parents > a{
		padding-bottom: 10px;
		color: #b8bdc5;
	}
	header #mainNavi li.parents > a:after{content: none;}
	header #mainNavi .subMenu > li{
		display: block;
		text-align: left;
		padding: 24px 24px 24px 36px;
	}
	header #mainNavi .subMenu > li:last-child{padding-bottom: 0;}
	header #langNav{
		padding-bottom:50px;
		text-align: left;
	}
	header #langNav li{text-align:left;}
	.navOpen header{background:#104462;}
	.navOpen header .navigations{height:calc(100vh - 54px);}
	.navOpen header .navigations .ps .ps__rail-y:hover{background: rgba(255,255,255,0.2);}
	.navOpen header .navigations .ps__thumb-y{background:rgba(255,255,255,0.8);}
	.navOpen header #gNavBtn a:before{
		-webkit-transform: translateY(9px) rotate(-45deg);
		transform: translateY(9px) rotate(-45deg);
	}
	.navOpen header #gNavBtn a span{opacity: 0;}
	.navOpen header #gNavBtn a:after{
		-webkit-transform: translateY(-9px) rotate(45deg);
		transform: translateY(-9px) rotate(45deg);
	}

	/************************************
	footer
	*************************************/
	#ftBanner ul{max-width: 336px;}
	footer .breadcrumbs{margin:4vw auto 0;}
	footer .ftMenuOuter{margin:2vw auto 4vw;}
	footer #ftMenu > li{width:32%;}
	footer #ftMenu > li:nth-child(5){width:64%;}
	footer #ftMenu > li:nth-child(n+4){margin-top:3vw;}
	
	
	/************************************
	titleBlock
	*************************************/
	#titleBlock{
		padding-top:calc(40px + 4vw);
		padding-bottom:5vw;
	}
	#titleBlock.logoBefore h2 span{margin:0 -16vw;}
	#titleBlock.subBefore p{width:60vw;}
}
@media screen and (max-width:768px){
	.navOpen #mainWrap{overflow-y: hidden;}

	/************************************
	header
	*************************************/
	header h1{
		box-sizing:content-box;
		padding:14px 15px;
	}
	header h1 a{
		background:url(/common/img/logo-white.svg) no-repeat left top;
		background-size: contain;
	}
	header h1 img{opacity: 0;}
	header h1 a{margin: 0 auto;}
	header .navigations{
		display:block;
		width: 100%;
		height: 0;
		padding: 0;
		overflow:hidden;
		transition: all 0.4s;
		-webkit-overflow-scrolling: touch;
	}
	header .navigationsInner{
		position: relative;
		width:100%;
		height: 100%;
		padding: 0 5vw;
		overflow-y:auto;
	}
	header .navigations li a span.enName{
		display:inline-block;
		font-size: 1.5rem;
	}
	header .navigations li a span.jpName{
		display:inline-block;
		margin-left: 16px;
		font-size: 1.1rem;
	}
	header #mainNavi,
	header #langNav{
		display: block;
		width: 100%;
		padding: 0;
		max-width:initial;
	}
	header #mainNavi li{margin: 0;}
	header #mainNavi .subMenu{
		display: block;
		width: 100%;
		padding: 0;
	}
	header #gNavBtn{
		position: absolute;
		top: 0;
		left: 0;
		width: 28px;
		height: 22px;
		padding: 16px;
		display: block;
		box-sizing:content-box;
	}
	header #gNavBtn a{
		display: block;
		width: 100%;
		height: 100%;
		position: relative;
		transition: all .4s;
	}
	header #gNavBtn a:before,
	header #gNavBtn a span,
	header #gNavBtn a:after{
		content: "";
		display: block;
		width: 100%;
		height:4px;
		border-radius:4px;
		background:#fff;
		position: absolute;
		left: 0;
		transition: all .4s;
	}
	header #gNavBtn a:before{top: 0;}
	header #gNavBtn a span{
		top: 50%;
		margin-top: -2px;
	}
	header #gNavBtn a:after{bottom: 0;}
	header #contactSpBtn{
		position: absolute;
		top:9px;
		right:10px;
		display: inline-block;
		vertical-align: middle;
		box-sizing:content-box;
	}
	header #contactSpBtn a{
		display: inline-block;
		padding: 3px 0;
		text-align: center;
		border-radius: 4px;
		line-height: 1.0;
		background: #007bff;
	}
	header #contactSpBtn a:before{
		content: "";
		display: block;
		margin: 0 auto;
		width: 24px;
		height: 24px;
		background: url(/common/img/mail-icon-white.svg) no-repeat center center;
		background-size: contain;
	}
	header #contactSpBtn a span{
		display: block;
		margin-top: -2px;
		font-size: 10px;
		text-align: center;
		transform-origin: center bottom;
		transform: scale(0.7);
		letter-spacing: 0;
		color: #fff;
	}
	header #myroomSpBtn{
		position: absolute;
		top:9px;
		right:60px;
		display: inline-block;
		vertical-align: middle;
		box-sizing:content-box;
	}
	header #myroomSpBtn a{
		display: inline-block;
		padding: 3px 0;
		text-align: center;
		border-radius: 4px;
		line-height: 1.0;
		background:#fff;
		color:#2d2726;
		text-decoration: none;
	}
	header #myroomSpBtn a:before{
		content: "";
		display: block;
		margin: 0 auto;
		width: 24px;
		height: 24px;
		background: url(/common/img/mypage-icon-brown.svg) no-repeat center center;
		background-size: contain;
	}
	header #myroomSpBtn a span{
		display: block;
		margin-top: -2px;
		font-size: 10px;
		text-align: center;
		transform-origin: center bottom;
		transform: scale(0.7);
		letter-spacing: 0;
		color:#2d2726;
	}
	header #mainNavi{margin:20px 0 120px;}
	header #mainNavi > li{
		display: block;
		text-align: left;
		padding: 24px 24px 24px 8px;
	}
	header #mainNavi > li.contactBtn,
	header #mainNavi > li.myroomBtn{display: none;}
	header #mainNavi .parents{padding-right: 0;}
	header #mainNavi .parents>a{pointer-events: none;}
	header #mainNavi li+li{border-top: 2px solid #184b68;}
	header #mainNavi li a{
		position: relative;
		display: block;
		color: #fff;
		font-size: 1.5rem;
	}
	header #mainNavi li.contactBtn a{
		display: inline-block;
		padding: 16px;
		text-align: center;
	}
	header #mainNavi li a:after{
		content: "";
		display: block;
		position: absolute;
		top: 50%;
		right: -8px;
		width: 8px;
		height: 13px;
		margin-top: -6px;
		background:url(/common/img/pink-arrow-next.svg) no-repeat center center;
		background-size:contain;
	}
	header #mainNavi li.parents > a{
		padding-bottom: 10px;
		color: #b8bdc5;
	}
	header #mainNavi li.parents > a:after{content: none;}
	header #mainNavi .subMenu > li{
		display: block;
		text-align: left;
		padding: 24px 24px 24px 36px;
	}
	header #mainNavi .subMenu > li:last-child{padding-bottom: 0;}
	header #langNav{
		padding-bottom:50px;
		text-align: left;
	}
	header #langNav li{text-align:left;}
	.navOpen header{background:#104462;}
	.navOpen header .navigations{height:calc(100vh - 54px);}
	.navOpen header .navigations .ps .ps__rail-y:hover{background: rgba(255,255,255,0.2);}
	.navOpen header .navigations .ps__thumb-y{background:rgba(255,255,255,0.8);}
	.navOpen header #gNavBtn a:before{
		-webkit-transform: translateY(9px) rotate(-45deg);
		transform: translateY(9px) rotate(-45deg);
	}
	.navOpen header #gNavBtn a span{opacity: 0;}
	.navOpen header #gNavBtn a:after{
		-webkit-transform: translateY(-9px) rotate(45deg);
		transform: translateY(-9px) rotate(45deg);
	}


	/************************************
	footer
	*************************************/
	#ftBanner{padding:7vw 0;}
	#ftBanner ul{max-width: 336px;}
	footer .breadcrumbs{margin:6vw auto 0;}
	footer #ftMenu{
		margin:4vw auto 0;
		text-align: left;
	}
	footer #ftMenu{
		display:block;
		width: 100%;
	}
	footer #ftMenu li{
		width: 100%;
		text-align:left;
		cursor: pointer;
	}
	footer #ftMenu > li{
		position: relative;
		padding:1vw 2vw;
	}
	footer #ftMenu > li+li{border-top:1px solid #ababab;}
	footer #ftMenu > li.location:before,
	footer #ftMenu > li.location:after{
		display: block;
		position:absolute;
		background: #fff;
		content: "";
		transition: all 0.8s;
		transform-origin: center center;
	}
	footer #ftMenu > li.location:before{
		width:1px;
		height:9px;
		top: 12px;
		right: calc(2vw + 4px);
	}
	footer #ftMenu > li.location:after{
		width:9px;
		height: 1px;
		top: 16px;
		right: 2vw;
	}
	footer #ftMenu > li.location.active:before,
	footer #ftMenu > li.location.active:after{transform:rotate(45deg);}
	footer #ftMenu .subFtMenu,
	footer #ftMenu .subFtMenu *{
		max-height: 0;
		overflow: hidden;
		transition: all 0.8s;
	}
	footer #ftMenu .subFtMenu{margin:0 0 0 2vw;}
	footer #ftMenu .subFtMenu>li{
		margin-top: 0;
		height: 0;
	}
	footer #ftMenu > li.location.active .subFtMenu{padding-bottom: 2vw;}
	footer #ftMenu > li.location.active .subFtMenu,
	footer #ftMenu > li.location.active .subFtMenu *{max-height: 100%;}
	footer #ftMenu > li.location.active .subFtMenu>li{
		margin-top:6px;
		height: 18px;
	}
	footer #ftMenu > li .jpName{
		display: inline-block;
		margin-left: 12px;
		font-size: 1.2rem;
		color: #efefef;
	}
	footer #btmNavi{width:100%;}
	footer #btmNavi li{line-height: 1.8;}
	footer .copyrights{line-height: 1.2;}
	
	
	/************************************
	titleBlock
	*************************************/
	#titleBlock{
		padding-top:calc(40px + 6vw);
		padding-bottom:10.4vw;
	}
	#titleBlock.logoBefore h2{
		width:208px;
		font-size: 1.9rem;
	}
	#titleBlock.logoBefore h2:before{margin:-6px auto 20px;}
	#titleBlock.subBefore h2 .title1{font-size:1.6rem;}
	#titleBlock.subBefore h2 .title2{
		margin:8px auto 0;
		font-size:3.2rem;
	}
	#titleBlock.subBefore h2:after{
		width:62px;
		height:4px;
	}
	#titleBlock.subBefore p{
		width: 80vw;
		font-size: 1.4rem;
	}
}
header #mainNavi .subMenu.subMenu-service{
	display: flex;
}
header #mainNavi .subMenu.subMenu-service li{
	width: calc((100% - 30px) / 4);
}
	
#locationNavi a[target="_blank"] .jpName::after, 
#mainNavi a[target="_blank"] .jpName::after {
    display: inline-block;
    margin-left: 5px;
    content: "\f08e";
    font-family: FontAwesome;
}
@media screen and (min-width: 1200px){
	header #mainNavi li.parents .subMenu{
		padding-left:calc(50% - 594px);
		padding-right:calc(50% - 594px);
	}
}
