@charset "utf-8";
/* CSS Document */

/* ------------------------------------------------------------------------ */

/*mainVisual

/* ------------------------------------------------------------------------ */

.contact .mainVisual{
	background: url("/recruit/entry/img/img_mainvisual_contact.jpg") no-repeat center / cover;
}

/* ------------------------------------------------------------------------ */

/*section

/* ------------------------------------------------------------------------ */
select { 
	color: #232323; 
}
input[type="checkbox"]:after{
	top: 50%;
	transform: translate(0,-50%)rotate(-45deg);;
}
section .contents{
	padding: 0 40px;
}
.hd03{
	margin-top: 40px;
	font-weight: 400;
	font-size: 1.6rem;
	letter-spacing: 0.01em;
}
/* フォーム*/

.form_wrap{
	margin-top: 60px;
}
.formStyle01 th{
	color: #232323;
	width: 40%;
	padding: 40px 0;
}
.formStyle01 td{
	width: 60%;
}
.formStyle01 tr:first-child{
	border-top: 2px solid #ecf0f1;
}
.formStyle01 tr{
	border-bottom: 2px solid #ecf0f1;
	border-top: none;
	margin-bottom: 8px;
    display: flex;
}
.formStyle01 #address_err + .input_area .flex{
	margin: 0px 0 15px;
}
.form_wrap .formStyle01 input#position,.form_wrap .formStyle01 input#workplace,.form_wrap .formStyle01 input#name,.form_wrap .formStyle01 input#name2,.form_wrap .formStyle01 input#age,.form_wrap .formStyle01 input#address,.form_wrap .formStyle01 input#tel,.form_wrap .formStyle01 input#email,.form_wrap .formStyle01 input#email02{
	height: 50px;
	max-width: 100%!important;
	width: 100%;
	padding: 3px 10px;
}
.form_wrap .formStyle01 input#post{
    max-width: 315px;
    height: 50px;
}
.formStyle01 select{
	max-width: 315px;
	background-color: #f5f7f6;
	border-radius: 4px;
    border: none;
    padding: 3px;
    font-size: 16px;
    width: 100%;
    height: 50px;
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
}
.formStyle01 textarea{
	max-width: 100%;
	background-color: #f5f7f6;
	border-radius: 4px;
    border: none;
    padding: 3px 10px;
    font-size: 16px;
    width: 100%;
    height: 96px;
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
}
.formStyle01 #address_err + .input_area .flex{
	align-items: center;
}
.formStyle01 #address_err + .input_area .flex span{
	padding:0 12px;
}
.hissu{
	background-color: #1b325c;
    margin-left: 15px;
    padding: 2px 12px;
    border-radius: 0;
}

/* 送信ボタン */
.form_btn{
	position: relative;
    display: block;
    max-width: 300px;
    line-height: 60px;
    width: 100%;
    margin: 78px auto 0;
    font-size: 1.8rem;
    font-weight: 500;
    color: #fff;
	border-radius: 0;
	border:none;
    background-color: #1b325c;
    transition: all .3s;
    cursor: pointer;
}
.form_btn:before{
	content: "";
	background-image: url("../img/arrow.svg");
	background-repeat: no-repeat;
	border:none;
	width: 18px;
	height: 16px;
	transform: translateY(-50%) rotate(0) translate(0, 0);
}
.form_btn:hover{
	border:none;
	background-color: #1b325c;
	opacity: .7;
}
.form_btn:hover:before{
	border:none;
}
.form_btn[disabled] {
  background-color: #ccc;
  cursor: not-allowed;
}
.agree{
	margin-top: 45px;
}
.agree input[type="checkbox"]{
	padding-left: 20px;
	margin-left: 30px;
}
.agree label span{
	border-bottom: 1px solid #4ca9df;
	color:#4ca9df;
	font-weight: bold;
}
.agree label span a{
	color: #4ca9df;
}
.agree label span:hover{
	opacity: 0.7;
}
.agree label:hover{
	text-decoration: none;
}
.confirm .formStyle01 td{
	padding: 40px 0;
}


/* ------------------------------------------------------------------------ */

/*確認画面

/* ------------------------------------------------------------------------ */
.confirm .confirm_btn{
	display: flex;
	justify-content: center;
	gap:0 120px;
}
.confirm .confirm_btn{
	margin: 78px 0 0;
}
.confirm .confirm_btn .form_btn{
	margin: 0;
}

.confirm .confirm_btn .form_btn:first-child{
	border:1px solid #4ca9df;
	background-color: #fff;
	color: #4ca9df;
}
.confirm .confirm_btn .form_btn:first-child::before{
	content: "";
	border: none;
    width: 18px;
    height: 16px;
	background-image: url(../img/arrow_02.svg);
	background-repeat: no-repeat;
    transform: translateY(-50%) rotate(0) translate(0, 0);
	top: 50%;
	left: 25px;
}
.btn_wrap{
	display: flex;
	justify-content: center;
	margin-top: 24px;
}

.btn_wrap > li{
	width: 29%;
}

/* ------------------------------------------------------------------------ */

/*完了画面

/* ------------------------------------------------------------------------ */
.contents_finish{
	max-width: 880px;
	width: 100%;
	margin: 0 auto;
	padding: 48px 0;
	background-color: #edf3f4;
	margin-top: 38px;
}
.finish_ttl{
	font-size: 1.6rem;
	text-align: center;
}
.finish_txt{
	font-size: 1.6rem;
	margin-top: 20px;
	text-align: center;
	line-height:2;
}
.finish_tel{
	font-size: 1.6rem;
	margin-top: 23px;
	letter-spacing: 0.025em;
	color: #1b325c;
}
.finish_tel span{
	font-size: 2.0rem;
}
@media screen and (max-width: 880px){
	.contents_finish{
		max-width: 100%;
		width: auto;
		margin: 0 20px;
		padding: 48px 20px;
	}
	
}
@media screen and (max-width: 767px){
	.formStyle01 tr{
		display: block;
	}
	section .contents{
		padding: 0 20px;
		width: 100%;
	}
	.confirm .confirm_btn{
		display: block;
	}
	.confirm .confirm_btn .form_btn{
		margin: 40px auto;
	}
	.finish_ttl{
		font-size: 1.4rem;
		text-align: center;
	}
	.finish_txt{
		font-size: 1.4rem;
		margin-top: 20px;
		text-align: center;
		line-height:2;
	}
	.form_btn{
		margin: 40px auto 0;
	}
	.formStyle01 th{
		width: 100%;
		padding: 20px 0;
	}
	.confirm .formStyle01 td{
		padding: 20px 0;
	}
	
	.formStyle01 td{
		width: 100%;
	}
	.agree input[type="checkbox"]{
		margin-left: 0;
	}
}