@charset "utf-8";
/* CSS Document */

/*###########################
 position:fixed用設定
###########################*/
#container {
	overflow-y:hidden;
	overflow-x:auto;
  min-height: 100vh;
  position: relative;
  padding-bottom: 207px;
  box-sizing: border-box;
}

.pcOnly{
	display: block;
}
.spOnly{
	display: none;
}
.pcOnly_inb{
	display: inline-block;
}


body {font:12px/1.4 "メイリオ",Meiryo,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","ＭＳ Ｐゴシック",Osaka, Helvetica, Arial, sans-serif;
	-webkit-text-size-adjust: 100%;
}

@media screen and (max-width: 960px){
	img{
		max-width: 100%;
		height: auto;
	}
}
@media screen and (max-width: 767px) {
  #container{
    padding-bottom: 65%;
  }
	body.menuOpen{
		overflow: hidden;
	}
	.pcOnly,.pcOnly_inb{
		display: none;
	}
	.spOnly{
		display: block;
	}
}

/* header
-------------------------------------------------------------------------*/
#header .spHeaderCont,
#header .spHeaderNavi{
	display: none;
}
#header .headerCont{
	height: 119px;
	box-sizing: border-box;
	border-top: #e30934 3px solid;
	border-bottom: #d2d2d2 1px solid;
	background: #ffffff;
	padding: 13px 0 0 0;
}
#header .headerInner{
	max-width: 1000px;
	margin: 0 auto;
}
#header .naviMenuListWrap{
	position: relative;
}
#header .naviMenuListWrap .closeBtn{
	width: 50px;
	height: 50px;
	background: #e30934;
	position: absolute;
	top: -40px;
	right: -50px;
	cursor: pointer;
}
#header .naviMenuListWrap .closeBtn span::before,
#header .naviMenuListWrap .closeBtn span::after {
	display: block;
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 65%;
	height: 1px;
	margin-left: -33%;
	background: #ffffff;
}
#header .naviMenuListWrap .closeBtn span::before {
	transform: rotate(-45deg);
}
#header .naviMenuListWrap .closeBtn span::after {
	transform: rotate(45deg);
}
#header .headerBlock{
	margin-bottom: 13px;
	padding: 0 9px;
}
#header .headerBlock::after{
	content: "";
  display: block;
  clear: both;
}
#header .headerLogo{
	display: flex;
	align-items: center;
	float: left;
}
#header .headerLogo .logo{
	width: 173px;
}
#header .headerLogo .logo img{
	width: 100%;
}
#header .headerLogo .text{
  font-family: 'YuGothic', 'Yu Gothic', 'Noto Serif JP', serif;
	color: #e30934;
	font-weight: bold;
	font-size: 0.93rem;
	margin-left: 0.5em;
}
#header .headerBtn{
	display: flex;
	align-items: center;
	float: right;
}
#header .headerBtn .text{
	margin-right: 4px;
	font-size: 0.8125rem;
}
#header .headerBtn .btn{
	border-radius: 3px;
	background: #e30934;
	text-align: center;
}
#header .headerBtn .btn._o{
	background: #ff9b25;
    margin-left: 5px;
    min-height: 50px;
    display: flex;
    align-items: center;
}
#header .headerBtn .btn._o02{
	background: #fffbe9;
    margin-left: 5px;
    min-height: 50px;
    display: flex;
    align-items: center;
  border:1px solid #ed7100;

}
#header .headerBtn .btn .link{
	display: block;
	color: #ffffff;
	padding: 8px 15px;
	font-size: 12px;
}

#header .headerBtn .btn .link:hover{
	text-decoration: none;
}
#header .headerBtn ._o02 .link{
	color: #ed7100!important;

}

#header .headerBtn ._o02 .link:hover{
	text-decoration: none;
}
#spNaviBtn{
	display: none;
}
#header .headerNaviList{
	display: flex;
	justify-content: center;
}
#header .headerNaviList .list{
	width: 25%;
	text-align: center;
	border-bottom: #ffffff 5px solid;
	transition: all 0.2s ease;
}
#header .headerNaviList .list .linkWrap{
	border-right: #c9c9c9 1px solid;
}
#header .headerNaviList .linkWrap:first-child{
	border-left: #c9c9c9 1px solid;
}
#header .headerNaviList .list:hover{
	border-bottom: #e30934 5px solid;
}
#header .headerNaviList .link{
	display: block;
	color: #333333;
	font-size: 0.9375rem;
	font-weight: bold;
	padding: 7.5px 0;
	cursor: pointer;
}
#header .headerNaviList .link:hover{
	text-decoration: none;
}
#header .headerNaviMenu{
	display: none;
	position: absolute;
	top: 119px;
	left: 0;
	width: 100%;
	z-index: 1000;
	background: #faf2d2;
	padding: 40px 0 60px;
}
#header .naviMenuList{
	display: flex;
	flex-wrap: wrap;
}
#header .naviMenuList .item{
	width: 48%;
	padding-bottom: 15px;
	border-bottom: #d0cbb8 1px solid;
	margin-top: 35px;
	text-align: left;
}
#header .naviMenuList .item:nth-child(-n+2){
	margin-top: 0;
}
#header .naviMenuList .item:nth-child(even){
	margin-left: 4%;
}
#header .naviMenuList .link{
	display: inline-block;
	position: relative;
	font-size: 0.9375rem;
	color: #333333;
	padding: 0 2em;
}
#header .naviMenuList .link:hover{
	text-decoration: none;
}
#header .naviMenuList .link::after{
	content: "";
	position: absolute;
  width: 19px;
  height: 5px;
	right: 0;
	top: 30%;
  border-bottom: 1px solid #e30934;
  border-right: 1px solid #e30934;
  transform: skew(45deg);
}
@media screen and  (max-width: 960px) and (min-width: 768px) {
clearfix{
 padding: 0 8px;
}
}
@media screen and (max-width: 1050px) {
	#header .naviMenuListWrap .closeBtn{
		right: 0;
	}
}
@media screen and (max-width: 999px) {
	#header .headerLogo .text,
	#header .headerBtn .text {
    font-size: 1.2vw;
	}
	#header .headerBtn .btn .link,
	#header .headerNaviList .link{
    font-size: 1.45vw;
	}
}
@media screen and (max-width: 776px){
#header .headerLogo .text, #header .headerBtn .text {
    font-size: 1.2vw;
	}
}
@media screen and (min-width: 768px) {
	#header .headerNavi{
		display: block !important;
	}
}
@media screen and (max-width: 767px) {
	#header .spHeaderCont{
		display: block;
		width: 100%;
		top: 0;
		box-sizing: border-box;
		z-index: 12000;
		background: #ffffff;
		border-top: #e30934 3px solid;
    border-bottom: #d2d2d2 1px solid;
	}
	#header .spHeaderCont img{
		width: 100%;
	}
	#header .spHeaderInner{
		height: 60px;
		display: flex;
		align-items: center;
		justify-content: space-between;
    padding: 4%;
    box-sizing: border-box;
	}
	#header .spHeaderCont .logo{
		width: 36%;
	}
	#header .spHeaderCont .text{
		color: #e30934;
		font-size: 0.8125rem;
		font-weight: bold;
		margin-right: 20%;
	}
	#header .headerCont{
		height: auto;
		padding: 0;
		border: none;
	}
	#header .headerInner{
		max-width: none;
		width: 100%;
	}
	#header .headerBlock{
		position: fixed;
		box-sizing: border-box;
		width: 100%;
		height: 70px;
		bottom: 0;
		z-index: 10000;
		background: #ffffff;
		margin-bottom: 0;
		padding: 12px 3.3%;
		border-top: #c9c9c9 1px solid;
	}
	#header .headerLogo{
		display: none;
	}
	#header .headerBtn{
		float: none;
	}
	#header .headerBtn .text{
		display: none;
	}
	#spNaviBtn{
		display: block;
		position: relative;
		top: 0;
		right: 0;
		width: 45px;
		height: 45px;
		z-index: 31;
		border-radius: 3px;
		background: #e6e6e6;
		margin-left: auto;
		cursor: pointer;
	}
	#spNaviBtn .lines {
    position: absolute;
    width: 22px;
    height: 22px;
    top: 7px;
    left: 12px;
	}
	#spNaviBtn .lines span {
	position: absolute;
	left: 0;
	width: 100%;
	height: 2px;
	background-color: #333333;
	border-radius: 4px;
	transition: transform 0.2s;
	}
	#spNaviBtn .lines span:nth-of-type(1) {
	top: 2px;
	}
	#spNaviBtn .lines span:nth-of-type(2) {
		top: 9px;
	}
	#spNaviBtn .lines span:nth-of-type(3) {
		bottom: 4px;
	}
	.menuOpen #spNaviBtn .lines span:nth-of-type(1) {
		-webkit-transform: translateY(7px) rotate(-45deg);
		transform: translateY(7px) rotate(-45deg);
	}
	.menuOpen #spNaviBtn .lines span:nth-of-type(2) {
		opacity: 0;
	}
	.menuOpen #spNaviBtn .lines span:nth-of-type(3) {
		-webkit-transform: translateY(-7px) rotate(45deg);
		transform: translateY(-7px) rotate(45deg);
	}
	#spNaviBtn .iconText{
		position: absolute;
		bottom: 4px;
		right: 0;
		left: 0;
		margin: auto;
		font-size: 0.5rem;
		font-weight: bold;
		text-align: center;
		line-height: 1;
	}
	#spHeader{
		display: block;
	}
	#header .headerNavi{
		display: none;
		width: 100%;
		height: calc(100% - 70px);
		position: fixed;
		top: 0;
		background: #faf2d2;
		z-index: 999;
		overflow-y: auto;
	}
	#header .naviMenuListWrap .closeBtn{
		display: none;
	}
	#header .headerNaviList{
		flex-direction: column;
	}
	#header .headerNaviList .list{
		width: 100%;
		border: none;
		border-bottom: #cccccc 1px solid;
		text-align: left;
		padding-bottom: 0;
	}
	#header .headerNaviList .list:first-child{
		border-bottom: none;
	}
	#header .headerNaviList .list:nth-child(2){
		border-top: #cccccc 1px solid;
	}
	#header .headerNaviList .list:hover{
		border-bottom: #cccccc 1px solid;
	}
	#header .headerNaviList .list:first-child:hover{
		border-bottom: none;
	}
	#header .headerNaviList .list .linkWrap{
		border: none;
	}
	#header .headerNaviList .link{
		padding: 20px 4%;
		font-size: 0.875rem;
		position: relative;
	}
	#header .headerNaviList span.link::before,
  #header .headerNaviList span.link::after {
		content: '';
		display: block;
		width: 18px;
		height: 2px;
		border-radius: 5px;
		background: #e30934;
		position: absolute;
		right: 4%;
		top: 27px;
	}
	#header .headerNaviList span.link::after {
		transform: rotate(90deg);
	}
	#header .headerNaviList span.link.open::after {
		transform: rotate(0);
	}
	#header .headerNaviMenu{
		position: static;
		display: none;
		background: #ffffff;
		padding: 0 !important;
	}
	#header .naviMenuList{
		flex-direction: column;
	}
	#header .naviMenuList .item{
		width: 100%;
		border-bottom: #cccccc 1px solid;
		margin-top: 0;
		padding: 0;
		box-sizing: border-box;
	}
	#header .naviMenuList .item:first-child{
		border-top: #cccccc 1px solid;
	}
	#header .naviMenuList .item:last-child{
		border-bottom: none;
	}
	#header .naviMenuList .item:nth-child(even){
		margin-left: 0;
	}
	#header .naviMenuList .link::after{
		content: none;
	}
	#header .naviMenuList .link{
		display: block;
		padding: 20px 4%;
		font-size: 0.875rem;
	}
	#header .headerBtn .btn{
	 width: 39.2%;
    
	}
	#header .headerBtn .btn._o{
		/* ボタン2つ時 margin-left: 4.3%;*/
		margin-left: 2%;   
        width: 21%;  
	}
	#header .headerBtn .btn._o02{
		margin-left: 2%;
		margin-right: 2%; 
        width: 21%;  
	}  
	#header .headerBtn .btn._col1 {
    width: 84%;
		margin-right: 10px;
	}
	#header .headerBtn .btn .link{
		font-size: 0.75rem;
		padding: 6px 7%;
	}
	#header .spHeaderNavi{
		display: block;
		padding: 25px 4%;
	}
	#header .spHeaderNavi li{
		margin-bottom: 15px;
	}
	#header .spHeaderNavi li:last-child{
		margin-bottom: 0;
	}
	#header .spHeaderNavi .link{
		display: inline-block;
		font-size: 0.875rem;
		color: #333333;
		background: url(/recruit/res/image/icon_window.png) no-repeat 0 4px;
		background-position: right;
		padding-right: 6%;
	}
	#header .menuLogo{
		width: 50.4%;
		margin-top: 25px;
	}
}
@media screen and (max-width: 375px) {
	#header .spHeaderCont .text {
	font-size: 3.5vw;
}
	#header .headerBtn .btn .link {
		font-size: 3.2vw;
	}
}

/* page top
-------------------------------------------------------------------------*/
#pageTop {
	padding-top:35px;
}
.pageTop {margin-bottom:80px;}

.pageTop a,
#pageTop a {
	float:right;
	display:block;
	width:89px;
	height:23px;
	text-indent:-9999px;
	background:url(../image/btn_pagetop.gif) no-repeat;
}


/* footer
-------------------------------------------------------------------------*/
#footer{
  position: absolute;
  width: 100%;
  bottom: 0;
}
#footer .footerLinkArea{
	background: #faf2d2;
	padding: 45px 0 35px;
	text-align: center;
}
#footer .footerLinkList .list{
	display: inline-block;
	line-height: 1;
}
/*-------------------
SP420px以下時のfooter design
-------------------*/
@media screen and (max-width: 420px) {
	#footer .footerLinkList .list:nth-child(3n){
	margin-top: 4%;
	}
}
#footer .footerLinkList .list:nth-child(2){
	padding: 0 1.5em;
	margin: 0 1.5em;
	border-right: #a9a490 2px solid;
	border-left: #a9a490 2px solid;
}
#footer .footerLinkList .link{
	color: #333333;
	font-size: 0.875rem;
	padding-right:19px;
	background:url("/recruit/res/image/icon_window.png") no-repeat 0 4px;
	background-position: right;
}
/*-------------------
IE
-------------------*/
@media all and (-ms-high-contrast: none) {
	#footer .footerLinkList .link{
	padding-top: 4%;
	}
	
	#footer .footerLinkList .link_last{
		padding-top: 6%;
	}
}
#footer .footerLinkList .link:hover{
	text-decoration: none;
}
#footer .footerLinkArea .logo{
	width: 242px;
	margin: 25px auto 0;
}
#footer .footerLinkArea .logo img{
	width: 100%;
}
#footer .copyright{
	background: #e30934;
	color: #ffffff;
	text-align: center;
	font-size: 0.875rem;
	line-height: 1;
	padding: 10px;
}
/*-------------------
IE
-------------------*/
@media all and (-ms-high-contrast: none) {
	#footer .copyright{
		padding: 10px;
		padding-bottom: 8px;
	}
}
@media screen and (max-width: 767px) {
	#footer{
		padding-bottom: 65px;
	}
	#footer .footerLinkArea{
		padding: 20px 5.3%;
	}
	#footer .footerLinkList .link{
		font-size: 0.8125rem;
	}
	#footer .footerLinkList .list:nth-child(2){
		border-right: #a9a490 1px solid;
    border-left: #a9a490 1px solid;
		padding: 0 1em;
    margin: 0 1em;
	}
	#footer .copyright{
		font-size: 0.6875rem;
		padding: 2% 0 3%;
	}
}
@media screen and (max-width: 375px){
	#footer .footerLinkList .link {
		font-size: 3.5vw;
	}
	#footer .footerLinkArea .logo{
		width: 57%;
	}
}
