@charset "UTF-8";
/* auther: cee; */

.EnableJS body:not(#sitetop) header {
width: 100%;
transform: translate(0,-64px);
transition: transform .3s linear;
}
.EnableJS body:not(#sitetop) header.On,
.EnableJS header.burgerHeader.On {
transform: translate(0,0);
transition: transform .3s linear;
}
.DisabledJS body:not(#sitetop) header::before {
width: 100%;
height: 64px;
content: '';
background: url(/jpn/images/common/logo_s.png) no-repeat center center;
background-size: auto 44px;
display: block;
}
#nav_menu {display: none;}
header,
#verticalheader {
color: #fff;
z-index: 900;
position: fixed;
right: 0;
top: 0;
}
header a:hover,
#verticalheader a:hover {color: #E4FF00;}
header h1,
#verticalheader h1 {
position: relative;
z-index: 2;
}
header h1 a,
#verticalheader h1 a {
background-size: contain;
background-repeat: no-repeat;
background-position: center center;
display: block;
}
header ul:nth-of-type(1) li:hover,
#verticalheader ul:nth-of-type(1) li:hover {
box-shadow: 1px -3px 20px 10px rgba(17,135,210,.2) inset;
border-left: 1px solid transparent;
}
#verticalheader ul:nth-of-type(1) li:hover {background: rgba(92,187,220,1);}
header ul:nth-of-type(1) a,
#verticalheader ul:nth-of-type(1) a {
font-family: 'Noto Sans JP', sans-serif;
font-size: 11px;
font-weight: 400;
line-height: 1.7em;
text-align: center;
text-shadow: 1px 1px 1px rgba(0,0,0,.2);
word-break: keep-all;
display: block;
}
@media all and (-ms-high-contrast: none) {
	#verticalheader ul:nth-of-type(1) a {font-family: 'メイリオ', 'Meiryo', 'MS PGothic', 'Hiragino Kaku Gothic ProN', sans-serif;}
}
header ul:nth-of-type(1) span,
#verticalheader ul:nth-of-type(1) span {
font-family: 'Roboto', sans-serif;
font-size: 15px;
font-weight: 700;
line-height: 1.25em;
text-transform: uppercase;
display: block;
}
header ul:nth-of-type(2),
#verticalheader ul:nth-of-type(2) {
position: absolute;
right: 20px;
}
header ul:nth-of-type(2) li,
#verticalheader ul:nth-of-type(2) li {float: left;}
header ul:nth-of-type(2) a,
#verticalheader ul:nth-of-type(2) a {display: block;}
header ul:nth-of-type(2) a:hover,
#verticalheader ul:nth-of-type(2) a:hover {opacity: .8;}
header ul:nth-of-type(2) li:nth-of-type(1) a,
#verticalheader ul:nth-of-type(2) li:nth-of-type(1) a {
background: url(/jpn/images/common/logo_facebook.png) no-repeat center center;
background-size: contain;
}
header ul:nth-of-type(2) li:nth-of-type(2) a,
#verticalheader ul:nth-of-type(2) li:nth-of-type(2) a {
/* background: url(/jpn/images/common/logo_twitter_fff.png) no-repeat center center; */
background: url(/jpn/images/common/logo-x-white.png) no-repeat center center;
background-size: contain;
}
header ul:nth-of-type(2) li:nth-of-type(3) a,
#verticalheader ul:nth-of-type(2) li:nth-of-type(3) a {
background: url(/jpn/images/common/logo_youtube.png) no-repeat center center;
background-size: contain;
}
header ul:nth-of-type(2) li:nth-of-type(4) a,
#verticalheader ul:nth-of-type(2) li:nth-of-type(4) a {
background: url(/jpn/images/common/logo_instagram.png) no-repeat center center;
background-size: contain;
}

header {
width: 100%;
height: 64px;
left: 0;
}
header h1 {float: left;}
header h1 a {
width: 90px;
height: 44px;
margin: 10px 10px 10px 20px;
background-image: url(/jpn/images/common/logo_s.png);
}
#verticalheader .box,
header.burgerHeader .box {
margin: 0 0 50px 0;
padding: 2px 0 6px;
background: linear-gradient(0deg,rgba(73,190,226,0.85),rgba(44,177,231,0.85));
position: relative;
z-index: 1;
}
#verticalheader .box::before,
#verticalheader .box::after,
header.burgerHeader .box::before,
header.burgerHeader .box::after {
content: "";
z-index: -1;
position: absolute;
}
#verticalheader .box::before,
header.burgerHeader .box::before {
width: calc(100% - 50px);
height: 50px;
background: rgba(73,190,226,0.85);
left: 50px;
bottom: -50px;
}
#verticalheader .box::after,
header.burgerHeader .box::after {
visibility: visible;
border: 25px solid transparent;
border-top: 25px solid rgba(73,190,226,0.85);
border-right: 25px solid rgba(73,190,226,0.85);
left: 0;
bottom: -50px;
}
#verticalheader ul:nth-of-type(1),
header.burgerHeader ul:nth-of-type(1) {
margin: 13px 0 17px 35px;
box-shadow: 1px 1px 5px 2px rgba(0,0,0,.1);
border-radius: 10px 0 0 10px / 10px 0 0 10px;
position: relative;
}
#verticalheader ul:nth-of-type(1)::before,
header.burgerHeader ul:nth-of-type(1)::before {
width: calc(100% - 16px);
height: 100%;
padding: 15px;
content: "";
border: 1px solid rgba(255, 255, 255,.2);
border-right: 0;
border-radius: 17px 0 0 17px / 17px 0 0 17px;
box-shadow: 1px -3px 15px 1px rgba(0,0,0,.2) inset;
display: block;
z-index: -1;
position: absolute;
left: -15px;
right: 0;
top: -15px;
bottom: -15px;
}
#verticalheader ul:nth-of-type(1) li,
header.burgerHeader ul:nth-of-type(1) li {
background: rgba(92, 187, 220,.6);
border-left: 1px solid rgba(255,255,255,.3);
border-bottom: 1px solid rgba(255,255,255,.3);
}
#verticalheader ul:nth-of-type(1) li:first-child,
header.burgerHeader ul:nth-of-type(1) li:first-child {
border-top: 1px solid rgba(255,255,255,.3);
border-radius: 10px 0 0 0 / 10px 0 0 0;
}
#verticalheader ul:nth-of-type(1) li:last-child,
header.burgerHeader ul:nth-of-type(1) li:last-child {
border-bottom: none;
border-radius: 0 0 0 10px / 0 0 0 10px;
}
#verticalheader ul:nth-of-type(1) li:hover,
header.burgerHeader ul:nth-of-type(1) li:hover {
box-shadow: 1px -3px 20px 10px rgba(17,135,210,.2) inset;
background: rgba(92,187,220,1);
border-left: 1px solid transparent;
}
#verticalheader ul:nth-of-type(1) li:first-child:hover,
header.burgerHeader ul:nth-of-type(1) li:first-child:hover {border-top: 1px solid transparent;}
#verticalheader ul:nth-of-type(1) a,
header.burgerHeader ul:nth-of-type(1) a {padding: 12px 0 11px;}
header ul:nth-of-type(2) a {height: 20px;}
header ul:nth-of-type(2) li:nth-of-type(1) a {width: 20px;}
header ul:nth-of-type(2) li:nth-of-type(2) a {width: 24px;}
header ul:nth-of-type(2) li:nth-of-type(3) a {width: 20px;}
header ul:nth-of-type(2) li:nth-of-type(4) a {width: 24px;}

@media screen and (min-width:995px) {
	header {background: linear-gradient(0deg,rgba(73,190,226,0.85),rgba(44,177,231,0.85));}
	header .box {padding: 0;}
	header .box::before,
	header .box::after {display: none;}
	header ul:nth-of-type(1) {
	margin: 0 138px 0 130px;
	box-shadow: none;
	border-radius: none;
	}
	header ul:nth-of-type(1)::before {display: none;}
	header ul:nth-of-type(1) li {
	width: calc((100% / 7) - 1px);
	background: transparent;
	border: none;
	float: left;
	position: relative;
	}
	header ul:nth-of-type(1) li:hover,
	header ul:nth-of-type(1) li:first-child:hover {border: none;}
	header ul:nth-of-type(1) li::before,
	header ul:nth-of-type(1) li::after {
	width: 0;
	height: 44px;
	margin: auto 0;
	content: "";
	visibility: visible;
	background: rgba(255,255,255,.3);
	display: block;
	position: absolute;
	left: -1px;
	top: 10px;
	bottom: 10px;
	}
	header ul:nth-of-type(1) li::before {width: 1px;}
	header ul:nth-of-type(1) li:last-child::after {
	width: 1px;
	left: auto;
	right: 0;
	}
	header ul:nth-of-type(1) li:first-child,
	header ul:nth-of-type(1) li:last-child {
	border-top: none;
	border-radius: 0;
	}
	header ul:nth-of-type(1) a {
	height: 64px;
	padding: 15px 0;
	box-sizing: border-box;
	}
	header ul:nth-of-type(1) span {letter-spacing: 0;}
	header ul:nth-of-type(2) {
	width: 108px;
	margin: 0;
	padding: 21px 0;
	top: 0;
	bottom: auto;
	}
	header ul:nth-of-type(2) a {margin: 0 2px;}
}
@media print {
	header {position: absolute;}
}
@media screen and (max-width:995px), print {
	header {background: rgba(44,177,231,.85);}
	header h1 a {margin-left: 10px;}
	header menu {
	height: 0;
	overflow: hidden;
	clear: both;
	}
	header #nav_menu:checked ~ menu {height: auto;}
	header menu::after {
	height: 0;
	content: '.';
	visibility: hidden;
	display: block;
	clear: both;
	}
	header .box {
	transform: translate(0,-120%);
	transition: all .3s ease 0s;
	}
	header #nav_menu:checked ~ menu .box {
	transform: translate(0,0);
	}
	header label {
	height: 64px;
	padding: 21px 20px;
	color: #fff;
	cursor: pointer;
	position: fixed;
	right: 0;
	top: 0;
	z-index: 1000;
	}
	header label:hover::before {
	width: 15px;
	transform-origin: left top;
	transform: rotate(45deg) translate(5px,-1px);
	top: 23px;
	}
	header #nav_menu:checked ~ label:hover {opacity: 1;}
	header #nav_menu:checked ~ label {opacity: .7;}
	header label span {
	height: 24px;
	width: 24px;
	position: relative;
	display: block;
	}
	header label::before,
	header label span::before,
	header label span::after {
	height: 4px;
	width: 24px;
	content: "";
	background: rgba(255,255,255,1);
	display: block;
	visibility: visible;
	opacity: 1;
	position: absolute;
	transform: none;
	}
	header label::before {top: 21px;}
	header label:hover span::before {
	width: 15px;
	transform-origin: right top;
	transform: rotate(-45deg) translate(8px,-1px);
	top: 11px;
	}
	header #nav_menu:checked ~ label::before {
	width: 15px;
	transform-origin: left top;
	transform: rotate(-45deg) translate(5px,-1px);
	left: 19px;
	top: 40px;
	}
	header label span::before {top: 9px;}
	header #nav_menu:checked ~ label span::before {
	width: 15px;
	transform-origin: right top;
	transform: rotate(45deg) translate(8px,-1px);
	left: 2px;
	top: 10px;
	}
	header label span::after {top: 18px;}
	header label:hover span::after {
	opacity: 0;
	transform: translate(0,-24px);
	}
	header #nav_menu:checked ~ label span::after {
	opacity: 0;
	transform: translate(0,-24px);
	}
	header ul:nth-of-type(1) li {
	width: 50%;
	height: 60px;
	float: left;
	}
	header ul:nth-of-type(1) li:nth-of-type(2) {border-top: 1px solid rgba(255,255,255,.3);}
	header ul:nth-of-type(1) li:nth-of-type(7) {width: 100%;}
	header ul:nth-of-type(1) li:nth-of-type(7) span::after {content: '・Recruit'}
	header ul:nth-of-type(2) {
	width: 126px;
	right: 5px;
	bottom: -31px;
	}
	header ul:nth-of-type(2) a {margin: 0 0px;}
	header ul:nth-of-type(2) li:nth-of-type(3) a {
		margin-left: 4px;
		margin-right: 6px;
	}
	header ul:nth-of-type(2) li:nth-of-type(2) a {
		margin-left: 6px;
	}
}
