@charset"utf-8";

/*base--------------------------------*/

*{
	font-family: 'Noto Sans JP', sans-serif, 'Meiryo', 'メイリオ', 'ヒラギノ 角ゴPro W3', 'Hiragino Kaku Gothic Pro', 'MS PGothic', 'ＭＳ Ｐゴシック';
	font-size: 100%;
	}
.container figcaption {
	font-size: 0.75em;
}

html, body {
	height: 100%;
	overflow: visible;
}

body{
	width: 100%;
	margin: 0;
	padding: 0;
	overflow-x: hidden;
	overflow-y: scroll;
}

/* よく登場する要素のリセット */

h1, h2, h3, h4, h5, h6, p, address,
ul, ol, li, dl, dt, dd,
table, caption, th, td, img, form, div {
	margin: 0;
	padding: 0;
	border: none;
	font-style: normal;
	font-weight: normal;
	font-size: 100%;
	text-align: left;
	list-style-type: none;
	font-family: 'Noto Sans JP', sans-serif, 'Meiryo', 'メイリオ', 'ヒラギノ 角ゴPro W3', 'Hiragino Kaku Gothic Pro', 'MS PGothic', 'ＭＳ Ｐゴシック';
	color: #000;
}

/* テキストエリア内文字サイズのブラウザ間での差異をなくす */
textarea { font-size: 100%; }

/* 画像の下にできる隙間をなくす */
img {
	vertical-align: bottom;
}

.cf:after {
	content: ".";	/* 新しい要素を作る */
	display: block;	/* ブロックレベル要素に */
	clear: both;
	height: 0;
	visibility: hidden;
}

.cf {
	min-height: 1px;
}

* html .cf {
	height: 1px;
	/*\*//*/
	height: auto;
	overflow: hidden;
	/**/
}

ruby rt {
	font-size: 50%;
}
@-moz-document url-prefix() {
	ruby rt {
		font-size: 50%;
	}
}



/*common--------------------------------*/

#wrap {
	overflow: hidden;
}

.top#wrap {
	opacity: 0;
}

.lower#wrap {
	opacity: 1;
}

.container {
	width: 90vw;
	max-width: 1000px;
	margin: 0 auto;
}

.plain_txt {
	font-size: 16px;
	line-height: 2em;
	padding-bottom: 1.5em;
}

a:link,
a:visited,
a:active {
	color: #333;
	text-decoration: none;
}

a:focus {
	outline:none;
	text-decoration: none;
}

a.underline {
	text-decoration: underline;
}

a.disabled {
    pointer-events: none;
}

.pc {
	display: block;
}

.sp {
	display: none;
}

.red {
	color: #cc0000;
}

.hover {
	-webkit-transition: .5s ease-out;
	transition: .5s ease-out;
}

.hover:hover {
	opacity:0.6;
	zoom:1;
	-webkit-transition: .5s ease-out;
	transition: .5s ease-out;
}

.fit {
	width: 100%;
}

.zoom {
	transition: 0.3s ease;
}

.zoom:hover {
	transform: scale(1.03);
	transition: 0.3s ease;
}

.fade_up{
    animation-name:fadeUpAnime;
    animation-duration:1.5s;
    animation-fill-mode:forwards;
    opacity:0;
}
@keyframes fadeUpAnime{
    0% {
      opacity: 0;
      transform: translateY(40px);
    }
    50% {
      opacity: 0;
      transform: translateY(40px);
    }
    100% {
      opacity: 1;
      transform: translateY(0);
    }
}

.sec_ttl {
	padding-bottom: 60px;
}

.sec_ttl b {
	display: block;
    font-family: 'Oswald', sans-serif;
	font-size: 72px;
	font-weight: 300;
	color: #317bbe;
	text-align: center;
	letter-spacing: .18em;
}

.sec_ttl span {
	display: block;
	font-size: 16px;
	font-weight: 700;
	color: #666;
	text-align: center;
	line-height: 1em;

}

.btn_container a {
	display: block;
	width: 500px;
	height: 100px;
	margin: 0 auto;
	border: 3px solid #fff;
	box-sizing: border-box;
	font-size: 24px;
	font-weight: 700;
	color: #fff;
	text-align: center;
	line-height: 94px;
	position: relative;
	-webkit-transition: .5s ease-out;
	transition: .5s ease-out;
}

.nav_list_container + .btn_list_container .btn_list_item +  .btn_list_item {
	padding-top: 20px;
}

.nav_list_container + .btn_list_container .btn_list_item a {
	display: block;
	width: 450px;
	height: 100px;
	border: 3px solid #fff;
	box-sizing: border-box;
	position: relative;
	-webkit-transition: .5s ease-out;
	transition: .5s ease-out;
}

.nav_list_container + .btn_list_container .btn_list_item:first-child a {
	background-color: #317bbe;
}

.nav_list_container + .btn_list_container .btn_list_item:last-child a {
	background-color: #8ad1f4;
}

.nav_list_container + .btn_list_container .btn_list_item a span {
	display: block;
	font-size: 16px;
	font-weight: 500;
	color: #fff;
	text-align: center;
	line-height: 1em;
	padding: 15px 0 10px;
}

.nav_list_container + .btn_list_container .btn_list_item a b {
	display: block;
	font-size: 30px;
	font-weight: 700;
	color: #fff;
	line-height: 1em;
	text-align: center;
}

.btn_container a::after,
.nav_list_container + .btn_list_container .btn_list_item a::after {
	content: '';
	display: block;
	width: 40px;
	height: 40px;
	border-right: 3px solid #fff;
	border-bottom: 3px solid #fff;
	position: absolute;
	bottom: 5px;
	right: 5px;
	-webkit-transition: .5s ease-out;
	transition: .5s ease-out;
}

.btn_container a:hover,
.nav_list_container + .btn_list_container .btn_list_item:first-child a:hover {
	background-color: #fff;
	color: #317bbe;
	border-color: #317bbe;
	-webkit-transition: .5s ease-out;
	transition: .5s ease-out;
}

.nav_list_container + .btn_list_container .btn_list_item:first-child a:hover span,
.nav_list_container + .btn_list_container .btn_list_item:first-child a:hover b {
	color: #317bbe;
}

.btn_container a:hover::after,
.nav_list_container + .btn_list_container .btn_list_item:first-child a:hover::after {
	border-color: #317bbe;
}

.nav_list_container + .btn_list_container .btn_list_item:last-child a:hover {
	background-color: #fff;
	color: #8ad1f4;
	border-color: #8ad1f4;
	-webkit-transition: .5s ease-out;
	transition: .5s ease-out;
}

.nav_list_container + .btn_list_container .btn_list_item:last-child a:hover span,
.nav_list_container + .btn_list_container .btn_list_item:last-child a:hover b {
	color: #8ad1f4;
}

.nav_list_container + .btn_list_container .btn_list_item:last-child a:hover::after {
	border-color: #8ad1f4;
}


/*----------------------------------------*/

/*loading*/

/*----------------------------------------*/

.loading {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
    background-color: #fff;
	text-align: center;
}

.load-spinner {
	display: inline-block;
	width: 50px;
	height: 50px;
	border: 2px solid rgba(138,209,244,1);
	border-top-color: rgba(49,123,190,1);
	border-radius: 50%;
	position: fixed;
	top: 50%;
	left: 50%;
	margin: -25px 0 0 -25px;
	animation: spin 1.2s linear 0s infinite;}
	@keyframes spin { 0% {transform: rotate(0deg);}100% {transform: rotate(360deg);}
}

.loading_news {
    position: relative;
    height: 50px;
    padding-top: 0;
    display: none;
}

.lower + .loading {
	display: none;
}

.loading_sort {
    position: relative;
    height: 100px;
    padding-top: 200px;
    display: none;
}



/*--------------------------------------*/

/*header*/

/*--------------------------------------*/

header {
	width: 100%;
	height: 80px;
	background-color: #fff;
	display: flex;
	justify-content: space-between;
	box-shadow: 0 5px 10px rgba(0,0,0,.1);
	position: fixed;
	top: 0;
	left: 0;
	z-index: 9999999;
}

header .logo_container {
	width: 210px;
	padding: 20px 15px 0;
	background-color: #fff;
}

header .gnav_container {
	background-color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
}

header .gnav_container .btn_wrap {
	display: flex;
	align-items: center;
	justify-content: center;
}

header .gnav_container .btn_wrap .sns_list_container {
	display: flex;
	align-items: center;
	justify-content: center;
}

header .gnav_container .btn_wrap .sns_list_item {
	width: 60px;
	height: 100%;
}

header .ico_inst {
	width: 33px;
}

header .ico_fb {
	width: 34px;
}

header .ico_tw {
	width: 37px;
}

header .gnav_container .btn_wrap .btn_list_container {
	display: flex;
}

header .gnav_container .btn_wrap .btn_list_item {
	padding-left: 2px;
}

header .gnav_container .btn_wrap .btn_list_item a {
	display: inline-block;
	width: 120px;
	height: 80px;
    font-family: 'Oswald', sans-serif;
	font-size: 18px;
	font-weight: 400;
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
}

header .gnav_container .btn_wrap .btn_list_item:first-child a {
	background-color: #8ad1f4;
}

header .gnav_container .btn_wrap .btn_list_item:last-child a {
	background-color: #317bbe;
}



/*menu_trigger--------------------------------*/

.menu_trigger {
	width: 110px;
	height: 80px;
	background-color: #fff;
	display: block;
	z-index: 9999999;
	cursor: pointer;
	-webkit-transition: .2s ease-out;
	transition: .2s ease-out;
	position: relative;
}

.menu_trigger,
.menu_trigger span {
	display: inline-block;
	transition: all .4s;
	box-sizing: border-box;
}

.menu_trigger span {
	position: absolute;
	left: 30px;
	width: 50px;
	height: 5px;
	background-color: #666;
	z-index: 4;
}

.menu_trigger span:nth-of-type(1) {
	top: 26px;
}

.menu_trigger span:nth-of-type(2) {
	top: 46px;
}

.menu_trigger.active {
	border: none;
}

.menu_trigger.active span:nth-of-type(1) {
	-webkit-transform: translateY(9px) rotate(-45deg);
	transform: translateY(9px) rotate(-45deg);
}

.menu_trigger.active span:nth-of-type(2) {
	-webkit-transform: translateY(-9px) rotate(45deg);
	transform: translateY(-9px) rotate(45deg);
}



/*menu_target--------------------------------*/

.menu_target {
	height: 100%;
	padding: 140px 26px 0;
	box-sizing: border-box;
	background-color: #317bbe;
	position: fixed;
	top: 0;
	right: -800px;
	z-index: -1;
}

.menu_target .nav_list_item {
	padding-bottom: 30px;
}

.menu_target .nav_list_item a {
	font-size: 22px;
	font-weight: 500;
	color: #fff;
}

.menu_target .nav_list_container + .btn_list_container {
	padding-top: 30px;
}

.menu_target .nav_list_container + .btn_list_container .btn_list_item a {
	width: 300px;
	height: 70px;
}

.menu_target .nav_list_container + .btn_list_container .btn_list_item a span {
	font-size: 14px;
	padding: 10px 0 5px;
}

.menu_target .nav_list_container + .btn_list_container .btn_list_item a b {
	font-size: 22px;
}

.menu_target .nav_list_container + .btn_list_container .btn_list_item a::after {
	width: 20px;
	height: 20px;
}

.menu_target .sns_list_container {
	display: flex;
	justify-content: center;
	align-items: center;
	padding-top: 60px;
}

.menu_target .sns_list_item {
	padding: 0 20px;
}



/*--------------------------------------*/

/*mv*/

/*--------------------------------------*/

.mv_wrap {
	width: 100%;
	height: calc(100vh - 50px);
	background: url('../img/mv_obj.jpg') center center no-repeat;
	background-size: cover;
	position: relative;
}

.catch_wrap {
	position: absolute;
	top: 55%;
	left: 4vw;
}

.catch_ttl {
	font-size: 60px;
	font-weight: 900;
	color: #fff;
	text-shadow: 3px 3px 6px rgba(0,0,0,.7);
}

.catch_lead {
	display: block;
	font-size: 27px;
	font-weight: 500;
	color: #fff;
	text-shadow: 2px 2px 4px rgba(0,0,0,.7);
	padding-top: 15px;
}

.mv_wrap .news_container {
	width: 90vw;
	max-width: 1000px;
	height: 60px;
	background-color: #317bbe;
	display: flex;
	justify-content: space-between;
	position: absolute;
	bottom: -30px;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
}

.mv_wrap .news_ttl {
	width: 120px;
	height: 50px;
	margin: 5px 0;
	border-right: 1px solid #8ad1f4;
    font-family: 'Oswald', sans-serif;
	font-size: 27px;
	font-weight: 300;
	color: #fff;
	text-align: center;
	line-height: 50px;
}

.mv_wrap .news_txt {
	width: calc(100% - 240px);
	padding-left: 30px;
	box-sizing: border-box;
	font-size: 16px;
	font-weight: 400;
	color: #fff;
	line-height: 60px;
}

.mv_wrap .news_txt a {
    color: #fff;
}

.mv_wrap .news_txt b {
	padding-left: 2em;
	font-weight: normal;
}

.mv_wrap .btn_container a {
	width: 120px;
	height: 60px;
    font-family: 'Oswald', sans-serif;
	font-size: 18px;
	font-weight: 300;
	color: #8ad1f4;
	text-align: center;
	line-height: 60px;
	border: none;
}

.mv_wrap .btn_container a::after {
	display: none;
}

.mv_wrap .btn_container a::before {
	content: '';
	display: block;
	width: 8px;
	height: 8px;
	border-top: 1px solid #8ad1f4;
	border-right: 1px solid #8ad1f4;
	position: absolute;
	top: 50%;
	right: 15px;
	-webkit-transform: translateY(-50%) rotate(45deg);
	transform: translateY(-50%) rotate(45deg);
}



/*--------------------------------------*/

/*sec01*/

/*--------------------------------------*/

.top .sec01 {
	width: 100%;
	height: 100vh;
	display: flex;
	justify-content: center;
	align-items: center;
}

.about_wrap {
	width: 90vw;
	max-width: 1200px;
	margin: 0 auto;
}

.about_container {
	width: 100%;
	display: flex;
	justify-content: space-between;
}

.about_container .img_container {
	width: 373px;
}

.about_container .txt_container {
	width: 720px;
	padding-left: 20px;
}

.about_container .about_ttl b {
	font-size: 70px;
	font-weight: 700;
}

.about_container .about_ttl span {
	font-size: 34px;
	font-weight: 400;
	padding-left: 20px;
}

.about_container .about_lead {
	border-bottom: 2px solid #317bbe;
	padding-bottom: 15px;
	margin-bottom: 20px;
}

.about_container .about_lead b {
	font-size: 36px;
	font-weight: 700;
}

.about_container .about_lead span {
	font-size: 20px;
	font-weight: 500;
	letter-spacing: .05em;
	padding-left: 20px;
}

.about_container .about_txt {
	font-size: 18px;
	font-weight: 400;
	line-height: 1.5em;
	letter-spacing: .08em;
	text-align: justify;
	padding: 0 .5em 1.5em;
}



/*--------------------------------------*/

/*sec02*/

/*--------------------------------------*/

.top .sec02 {
	padding: 80px 0;
} 

.sec02 .bnr_list_container {
	max-width: 100%;
	display: flex;
	justify-content: space-between;
	padding-bottom: 90px;
}

.sec02 .bnr_list_item a {
	display: block;
	width: 29vw;
	max-width: 320px;
	height: 180px;
	border: 2px solid #317bbe;
	box-sizing: border-box;
	overflow: hidden;
}

.sec02 .bnr_list_item:first-child a {
	background: url('../img/business_obj01.png') 90% 8px no-repeat;
	background-size: 188px auto;
}

.sec02 .bnr_list_item:nth-child(2) a {
	background: url('../img/business_obj02.png') right 3px no-repeat;
	background-size: 240px auto;
}

.sec02 .bnr_list_item:last-child a {
	background: url('../img/business_obj03.png') 95% 8px no-repeat;
	background-size: 188px auto;
}

.sec02 .business_bnr_ttl {
	font-size: 24px;
	font-weight: 900;
	line-height: 180px;
	letter-spacing: .08em;
	padding-left: 20px;
	text-shadow: 1px 1px 0 #FFF, -1px -1px 0 #FFF,
	-1px 1px 0 #FFF, 1px -1px 0 #FFF,
	0px 1px 0 #FFF, 0 -1px 0 #FFF,
	-1px 0 0 #FFF, 1px 0 0 #FFF;
}

.sec02 .business_lead {
	font-size: 24px;
	font-weight: 700;
	color: #317bbe;
	text-align: center;
	line-height: 2em;
	letter-spacing: .1em;
	padding-bottom: 90px;
}

.sec02 .business_list_item {
	width: 100%;
	height: 500px;
	display: flex;
}

.sec02 .business_list_item:nth-child(odd) {
	flex-direction: row-reverse;
}

.sec02 .business_list_item .img_container {
	width: 50%;
	height: 100%;
	position: relative
}

.sec02 .business_list_item:first-child .img_container {
	background: url('../img/business_obj04.jpg') center center no-repeat;
	background-size: cover;
}

.sec02 .business_list_item:nth-child(2) .img_container {
	background: url('../img/business_obj05.jpg') center center no-repeat;
	background-size: cover;
}

.sec02 .business_list_item:last-child .img_container {
	background: url('../img/business_obj06.jpg') center center no-repeat;
	background-size: cover;
}

.sec02 .business_list_item:nth-child(2) .img_container::after {
	content: '';
	display: block;
	width: 100%;
	height: 100%;
	background-color: rgba(55,129,192,.3);
	position: absolute;
	top: 0;
	left: 0;
}

.sec02 .business_list_item .txt_container {
	width: 50%;
	height: 100%;
	padding: 0 10px;
	box-sizing: border-box;
	display: flex;
	align-items: center;
	justify-content: center;
}

.sec02 .business_list_item:nth-child(odd) .txt_container {
	background-color: #317bbe;
}

.sec02 .business_list_item .business_list_ttl {
	position: relative;
	padding-bottom: 25px;
	margin-bottom: 30px;
}

.sec02 .business_list_item .business_list_ttl b {
	font-size: 36px;
	color: #317bbe;
	letter-spacing: .1em;
}

.sec02 .business_list_item .business_list_ttl span {
	display: block;
    font-family: 'Oswald', sans-serif;
	font-size: 16px;
	color: #317bbe;
	letter-spacing: .18em;
	text-indent: .2em;
}

.sec02 .business_list_item .business_list_ttl::after {
	content: '';
	display: block;
	width: 60px;
	height: 2px;
	background-color: #317bbe;
	position: absolute;
	bottom: 0;
	left: .2em;
}

.sec02 .business_list_item .business_list_txt {
	width: 100%;
	max-width: 530px;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.88em;
}

.sec02 .business_list_item:nth-child(odd) .business_list_ttl b,
.sec02 .business_list_item:nth-child(odd) .business_list_ttl span,
.sec02 .business_list_item:nth-child(odd) .business_list_txt {
	color: #fff;
}

.sec02 .business_list_item:nth-child(odd) .business_list_ttl::after {
	background-color: #fff;
}



/*--------------------------------------*/

/*sec03*/

/*--------------------------------------*/

.top .sec03 {
	padding: 80px 0;
}

.outline_list_container {
	width: 90vw;
	max-width: 1000px;
	margin: 0 auto;
}

.outline_list_container dt {
	font-size: 20px;
	font-weight: 700;
	color: #666;
	padding-left: 30px;
	position: relative;
	z-index: 2;
}

.outline_list_container dd {
	width: 100%;
	box-sizing: border-box;
	padding: 30px 30px 30px 110px;
	margin: -12px 0 20px;
	background-color: #efefef;
	font-size: 20px;
	font-weight: 400;
	color: #666;
	position: relative;
	z-index: 1;
}

.outline_list_container dd:after {
	content: '';
	display: block;
	border-top: 10px solid transparent;
	border-right: 10px solid #fff;
	border-bottom: 10px solid #fff;
	border-left: 10px solid transparent;
	position: absolute;
	bottom: 0;
	right: 0;
}

.outline_list_container dd .address_list_item {
	display: flex;
}

.outline_list_container dd .address_list_item + .address_list_item {
	padding-top: 1em;
}

.outline_list_container dd .address_list_item span {
	width: 7em;
	font-size: 20px;
	font-weight: 400;
	color: #666;
}

.outline_list_container dd .address_list_item b {
	width: calc(100% - 7em);
	font-size: 20px;
	font-weight: 400;
	color: #666;
}

.outline_list_container dd .outline_txt {
	font-size: 20px;
	font-weight: 400;
	color: #666;
	line-height: 2em;
}



/*--------------------------------------*/

/*sec04*/

/*--------------------------------------*/

.top .sec04 {
	padding: 80px 0 180px;
}

.sec04 .contact_list_container {
	width: 96vw;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
}

.sec04 .contact_list_item a {
	display: block;
	width: 47vw;
	background-color: #317bbe;
	position: relative;
}

.sec04 .contact_list_item a .img_container {
	width: 100%;
	height: 20vw;
}

.sec04 .contact_list_item a .img_container .contact_list_obj {
	display: block;
	width: 100%;
	height: 100%;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
}

.sec04 .contact_list_item:last-child a .img_container .contact_list_obj {
	background-position: center 85%;
}

.sec04 .contact_list_item a .txt_container {
	padding: 15px;
}

.sec04 .contact_list_item a .txt_container span {
	font-size: 24px;
	font-weight: 500;
	color: #fff;
}

.sec04 .contact_list_item a .txt_container b {
	display: block;
	font-size: 36px;
	font-weight: 700;
	color: #fff;
}

.sec04 .contact_list_item a .txt_container::after {
	content: '';
	display: block;
	width: 40px;
	height: 40px;
	border-right: 5px solid #fff;
	border-bottom: 5px solid #fff;
	position: absolute;
	bottom: 5px;
	right: 7px;
}



/*--------------------------------------*/

/*sec05*/

/*--------------------------------------*/

.top .sec05 {
	width: 100%;
	height: 100vh;
	background: url('../img/joblist_obj.jpg') center center no-repeat;
	background-size: cover;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
}

.top .sec05::after {
	content: '';
	display: block;
	width: 100%;
	height: 100%;
	background-color: rgba(55,129,192,.8);
	position: absolute;
	top: 0;
	left: 0;
	z-index: 0;
}

.top .sec05 .jablist_container {
	position: relative;
	z-index: 2;
}

.top .sec05 .jablist_container .sec_ttl b,
.top .sec05 .jablist_container .sec_ttl span {
	color: #fff;
}

.top .sec05 .jablist_container .jobinfo_lead {
	font-size: 24px;
	font-weight: 700;
	color: #fff;
	line-height: 2em;
	text-align: center;
	letter-spacing: .1em;
	padding-bottom: 80px;
}



/*--------------------------------------*/

/*footer*/

/*--------------------------------------*/

footer {
	background-color: #222;
	padding: 80px 0;
}

footer .sns_list_container {
	display: flex;
	justify-content: center;
	align-items: center;
	padding-bottom: 80px;
}

footer .sns_list_item {
	width: 80px;
	text-align: center;
}

footer .sns_list_item .ico_inst {
	width: 48px;
}

footer .sns_list_item .ico_fb {
	width: 50px;
}

footer .sns_list_item .ico_tw {
	width: 55px;
}

.footer_container {
	width: 90vw;
	max-width: 1000px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
}

.footer_container .logo_container {
	width: 269px;
	padding-bottom: 80px;
}

.footer_container nav {
	width: 90vw;
	max-width: 830px;
	display: flex;
	justify-content: space-between;
}

.footer_container .nav_list_container {
	width: 300px;
	padding-left: 80px;
}

.footer_container .nav_list_item {
	padding: 10px 0 20px;
}

.footer_container .nav_list_item a {
	font-size: 18px;
	font-weight: 500;
	color: #fff;
}

.footer_container .btn_list_container {
	padding-bottom: 80px;
}

footer .copy {
	text-align: center;
}

footer .copy small {
	font-size: 14px;
	font-weight: 500;
	color: #fff;
}



/*--------------------------------------*/

/*lower*/

/*--------------------------------------*/

.lower article {
	padding-top: 160px;
}



/*--------------------------------------*/

/*contact*/

/*--------------------------------------*/

.formContainer {
	width: 1000px;
	margin: 0 auto 30px;
	border-collapse: collapse;
	border-spacing: 0;
	border-top: 3px solid #317bbe;
	border-bottom: 3px solid #317bbe;
}

.confirm_container + .formContainer {
	margin-top: 20px;
}

.formContainer th {
	width: 32%;
	border-bottom: 1px solid #eee;
	padding: 30px 0 30px 30px;
	box-sizing: border-box;
	font-weight: 500;
	color: #666;
}

.formContainer td {
	width: 68%;
	border-bottom: 1px solid #eee;
	padding: 30px;
	box-sizing: border-box;
}

.formContainer tr:last-child th,
.formContainer tr:last-child td {
	border-bottom: none;
}

.formContainer td .error {
    color: #cc0000;
    font-size: 14px;
}

.req {
	background-color: #cc0000;
	color: #fff;
	font-size: 12px;
	padding: 0 5px 2px;
	margin-left: 10px;
}

.input {
	height: 30px;
	padding: 10px;
	border: 2px solid #ccc;
}

.input:focus {
	outline: 3px solid #317bbe;
	border: 2px solid #fff;
}

.input-l {
	width: calc(100% - 20px);
}

.input-s {
	width: 40%;
}

textarea {
	width: calc(100% - 20px);
	height: 140px;
	padding: 10px;
	border: 2px solid #ccc;
}

textarea:focus {
	outline: none;
}

.formError {
	z-index: -1;
}

.submit {
	padding: 20px 0 160px;
}

#submit,
#btnTop {
	display: block;
	width: 500px;
	height: 100px;
	margin: 0 auto;
	background-color: #317bbe;
	border: 3px solid #317bbe;
	font-size: 24px;
	color: #fff;
	line-height: 94px;
	cursor: pointer;
	-webkit-transition: .5s ease-out;
	-moz-transition: .5s ease-out;
	-ms-transition: .5s ease-out;
	transition: .5s ease-out;
}

#submit:hover,
#btnTop:hover {
	background-color: #fff;
	color: #317bbe;
	-webkit-transition: .5s ease-out;
	-moz-transition: .5s ease-out;
	-ms-transition: .5s ease-out;
	transition: .5s ease-out;
}

#submit.disabled {
	background-color: #ccc;
	border: 3px solid #ccc;
	color: #fff;
	cursor: default;
	pointer-events: none;
}

#btnTop {
	margin: 100px 0 160px;
}

#btnBack {
	display: block;
	width: 500px;
	height: 100px;
	margin: 0 auto;
	background-color: #ccc;
	border: 3px solid #ccc;
	font-size: 24px;
	color: #fff;
	line-height: 94px;
	cursor: pointer;
	-webkit-transition: .5s ease-out;
	-moz-transition: .5s ease-out;
	-ms-transition: .5s ease-out;
	transition: .5s ease-out;
}

#btnBack:hover {
	background-color: #fff;
	color: #ccc;
	-webkit-transition: .5s ease-out;
	-moz-transition: .5s ease-out;
	-ms-transition: .5s ease-out;
	transition: .5s ease-out;
}

.formErrorContent {
	display: inline-block!important;
	background-color: #fff!important;
	color: #cc0000!important;
	font-size: 14px!important;
	font-weight: normal!important;
}

.confirm h2 {
	text-align: center;
	font-size: 24px;
	padding: 2em 0 1em;
}

.confirm p {
	text-align: center;
}

.confirm_ttl {
    font-size: 24px;
    text-align: center;
    padding-bottom: 20px;
}

.confirm_container .plain_txt {
    text-align: center;
}

.contact .btn_container {
	margin: 80px 0 160px;
}

.contact .btn_container a {
	display: block;
	width: 500px;
	height: 100px;
	margin: 0 auto;
	background-color: #317bbe;
	border: 3px solid #317bbe;
	box-sizing: border-box;
	font-size: 24px;
	font-weight: 700;
	color: #fff;
	text-align: center;
	line-height: 94px;
	position: relative;
	-webkit-transition: .5s ease-out;
	transition: .5s ease-out;
}
.contact .btn_container a:hover {
	background-color: #fff;
	color: #317bbe;
	-webkit-transition: .5s ease-out;
	-moz-transition: .5s ease-out;
	-ms-transition: .5s ease-out;
	transition: .5s ease-out;
}

.date_list_container {
	display: flex;
}

.date_list_item {
	width: 150px;
	position: relative;
}

.date_list_item .formError {
	position: absolute!important;
	top: 94%!important;
	left: -100%!important;
}

.sex .date_list_item .formError {
	top: 0!important;
	left: -50%!important;
}

.select {
	width: 100px;
	height: 50px;
	border: 2px solid #ccc;
}

.privacy_ttl {
	width: 90vw;
	max-width: 1000px;
	margin: 0 auto;
	padding-bottom: 10px;
	font-size: 18px;
	font-weight: bold;
}

.privacy_wrap {
	width: 90vw;
	max-width: 1000px;
	height: 300px;
	margin: 0 auto;
	border: 2px solid #ccc;
	padding: 10px;
	box-sizing: border-box;
}

.privacy_container {
	width: 100%;
	height: 100%;
	padding: 10px;
	box-sizing: border-box;
	overflow-y: auto;
}

.privacy_txt {
	font-size: 14px;
	font-weight: 400;
	line-height: 1.6em;
	padding-bottom: 1em;
}

dl.privacy_list_container dt {
	font-size: 16px;
	font-weight: 500;
	border-bottom: 1px solid #317bbe;
	padding-bottom: .5em;
	margin-bottom: .5em;
}

dl.privacy_list_container dd {
	font-size: 14px;
	font-weight: 400;
	line-height: 1.6em;
	padding-bottom: 1.5em;
}

ul.privacy_list_container {
	padding-bottom: .5em;
}

.privacy_list_item {
	font-size: 14px;
	font-weight: 400;
	line-height: 1.6em;
	padding: 0 0 .3em 2.5em;
	text-indent: -2.5em;
}

.agree_container {
  text-align: center;
  padding: 20px 0 30px;
}

.agree_container label {
  font-size: 16px;
  font-weight: 500;
  line-height: 20px;
  letter-spacing: .1em;
}

.checkbox {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  cursor: pointer;
  padding-left: 45px;
  vertical-align: middle;
  position: relative;
}

.checkbox::before,
.checkbox::after {
  content: "";
  display: block; 
  position: absolute;
}

.checkbox::before {
  background-color: #fff;
  border-radius: 0%;
  border: 2px solid #ccc;
  width: 20px;
  height: 20px;
  transform: translateY(-50%);
  top: 50%;
  left: 0;
}

.checkbox::after {
  border-bottom: 5px solid #317bbe;
  border-left: 5px solid #317bbe;
  opacity: 0;
  height: 9px;
  width: 16px;
  transform: rotate(-45deg);
  top: -10px;
  left: 4px;
}

.checkbox:checked::after {
  opacity: 1;
}





@media screen and (max-width: 1120px) {
	.sec02 .business_bnr_ttl {
		font-size: 2.14vw;
		padding-left: 1.79vw;
	}

	.top .sec05 .jablist_container .jobinfo_lead .sp {
		display: block;
	}

	.footer_container .logo_container {
		margin: 0 auto;
	}

	.footer_container {
		flex-wrap: wrap;
	}

}




@media screen and (max-width: 880px) {
	.sec02 .business_list_item .business_list_ttl b {
		font-size: 4vw;
	}

	.sec02 .business_list_item .business_list_ttl span {
		font-size: 1.78vw;
	}

	.sec04 .contact_list_item a .txt_container span {
		font-size: 2.67vw;
	}
	
	.sec04 .contact_list_item a .txt_container b {
		font-size: 4vw;
	}
}