@charset "utf-8";

/* =====================================================================
	form.css
===================================================================== */

/* ----------------------------------------------------------------------
 * 全デバイス共通
 * ---------------------------------------------------------------------- */

/* common -------------------------------------------------- */
article {
	width: 100%;
	margin: 0 auto 40px auto;
}
h1 {
	width: 100%;
	margin: 0;
	font-size: 2rem;
	line-height: 1;
	font-weight: 900;
	padding: 1em 0;
	text-align: center;
}
form {
	margin: 40px auto 0 auto;
}
#newGraduate {
	background-color: #facb88;
}
#career {
	background-color: #a1c3d7;
}
#contact {
	background-color: #c8bb9b;
}

/* index -------------------------------------------------- */
/* #introduction */
#introduction {
	margin: 20px auto 40px auto;
}
#introduction p,
#introduction a {
	font-size: 2rem;
	font-weight: 500;
}
#contactTel,
#contactTelBody {
	display: flex;
	justify-content: center;
}
#contactTel {
	margin: 20px auto;
}
#contactTelTitle {
	height: 70px;
	background-color: #c8bb9b;
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	align-items: center;
}
#contactTelBody {
	border: 2px solid #c8bb9b;
	box-sizing: border-box;
	display: flex;
	justify-content: center;
	align-items: center;
}
/* #entryForm */
#entryForm {
	margin: 0 auto;
}
#entryForm dl {
	width: 100%;
	display: flex;
	font-size: 1.6rem;
	line-height: 1.5;
}
#entryForm dl dt {
	font-size: 2rem;
	font-weight: 900;
}
#entryForm dl dd {
	font-weight: 500;
	display: flex;
	align-items: flex-start;
	flex-wrap: wrap;
}
.formMustTrue,
.formMustFalse {
	color: #fff;
	font-size: 1.8rem;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 60px;
	height: 30px;
	white-space: nowrap;
}
.formMustTrue {
	background-color: #e60012;
}
.formMustFalse {
	background-color: #7a6a56;
}
.formCaution {
	color: #e60012;
	font-size: 1.6rem;
	font-weight: 900;
}

#entryForm input[type="text"],
#entryForm input[type="tel"],
#entryForm input[type="email"],
#entryForm textarea {
	border: 1px solid #b5b6b6;
	box-sizing: border-box;
	padding: 7px 20px;
	font-size: 1.6rem;
	line-height: 1.375;
	position: relative;
}
#entryForm textarea {
	top: 0;
	margin: 20px 0 0 0;
}

#entryForm input[type="checkbox"],
#entryForm input[type="radio"],
#entryForm select {
	all: revert;
	-webkit-appearance: auto;
	appearance: auto;
	box-sizing: border-box;
	vertical-align: middle;
	color: inherit;
	font: inherit;
	background: transparent;
	padding: 0;
	margin: 0;
	outline: 0;
	border-radius: 0;
	text-align: inherit;
	font-size: 1.4rem;
}
#entryForm select {
	padding: 7px 20px;
	border: 1px solid #b5b6b6;
	position: relative;
}
#entryForm input[type="radio"] {
	position: relative;
	top: -.1em;
	margin-right: 20px;
	accent-color: black;
}

.w100out {
	width: 100%;
}
.w3em {
	width: 3em;
}
.w4em {
	width: 4em;
}
.w5em {
	width: 5em;
}
.w6em {
	width: 6em;
}
.w7em {
	width: 7em;
}

#entryForm #dl__birth span:not(:first-of-type) {
	display: flex;
	align-items: center;
}
#entryForm #dl__birth span:last-of-type {
	margin-right: 0;
}
#entryForm #dl__address span:nth-of-type(2),
#entryForm #dl__address span:nth-of-type(3) {
	display: flex;
	align-items: center;
}
#entryForm #dl__address span:nth-of-type(2) input,
#entryForm #dl__address span:nth-of-type(3) select {
	margin-left: 10px;
}
#entryForm #dl__address span:last-of-type {
	margin-top: 20px;
	width: 100%;
	display: flex;
	flex-direction: column;
}
#entryForm #dl__address span:last-of-type input {
	margin-top: 20px;
}
#entryForm #dl__driver_licence label:not(:nth-of-type(1)) {
	margin-left: 20px;
}

#privacyPolicy {
	font-size: 1.6rem;
	font-weight: 500;
}
#privacyCheckFlag {
	font-size: 1.6rem;
	font-weight: 500;
	display: flex;
}
#entryForm #privacyCheckFlag input {
	position: relative;
	top: -.25em;
	margin-right: 20px;
}
#entryForm input.inputError {
	border: 1px solid #e60012;
}
.inputLengthInfo {
	margin: .25em 0 0 auto;
	font-size: 1.4rem;
}
.radioErrorMsg {
	color: #e60012;
	margin-left: 2em;
}

#indexErrorMsg {
	font-size: 2rem;
	font-weight: 500;
	text-align: center;
	line-height: 1.3;
	color: #e60012;
	display: none;
}


/* button -------------------------------------------------- */
#confirmBtn,
#returnBtn,
#completeBtn {
	font-size: 2rem;
	font-weight: 900;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 65px;
	box-sizing: border-box;
	text-align: center;
	border-radius: 2em;
}
#confirmBtn span,
#returnBtn span,
#completeBtn span {
	letter-spacing: .2em;
	text-indent: .2em;
}
#confirmBtn {
	margin: 40px auto 0 auto;
}
.newGraduate #confirmBtn {
	background-color: #facb88;
}
.career #confirmBtn {
	background-color: #a1c3d7;
}
.contact #confirmBtn {
	background-color: #c8bb9b;
}
#returnBtn {
	margin: 20px auto 0 auto;
	background-color: #727171;
	color: #fff;
}
#completeBtn {
	margin: 20px auto 0 auto;
}
.newGraduate #completeBtn {
	background-color: #facb88;
}
.career #completeBtn {
	background-color: #a1c3d7;
}
.contact #completeBtn {
	background-color: #c8bb9b;
}


/* confirm -------------------------------------------------- */
/* #confirmForm */
#confirmForm {
	margin: 0 auto;
}
#confirmForm dl {
	width: 100%;
	display: flex;
	font-size: 1.6rem;
}
#confirmForm dl dt {
	font-size: 2rem;
	font-weight: 900;
}
#confirmForm dl dd {
	font-weight: 500;
	display: flex;
	align-items: flex-start;
	flex-wrap: wrap;
	box-sizing: border-box;
	position: relative;
}
#confirmForm .formMustTrue,
#confirmForm .formMustFalse {
	margin: 0;
	position: absolute;
	left: 0;
}
#completeBox {
	margin: 40px auto 0 auto;
}
#returnBox p,
#completeBox p {
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.25;
	text-align: center;
}

/* complete -------------------------------------------------- */
h2 {
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1;
	text-align: center;
}
.sentMsg {
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.375;
}




/* --------------------------------------------------
 * 画面の横幅が960px以上（PC）
 * -------------------------------------------------- */
@media screen and (min-width: 960px){
	/* common -------------------------------------------------- */
	form {
		width: 920px;
	}
	a[href*="tel:"] {
		pointer-events: none;
		cursor: default;
		text-decoration: none;
	}

	/* index -------------------------------------------------- */
	/* #introduction */
	#introduction {
		width: 920px;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
	}
	#contactTelTitle {
		width: 200px;
	}
	#contactTelBody {
		height: 70px;
		padding: 0 30px;
		border-left: none;
	}
	#contactTelBody a {
		margin: 0 1em 0 0;
	}
	/* #entryForm */
	#entryForm {
		width: 920px;
	}
	#entryForm dl {
		margin: 40px 0;
	}
	#entryForm dl dt {
		width: 230px;
	}
	#entryForm dl dd {
		width: calc(100% - 230px);
	}
	.formMustTrue,
	.formMustFalse {
		margin: 0 30px 0 0;
	}
	.formCaution {
		width: calc(100% - 60px - 30px);
	}

	.w100 {
		width: calc(100% - 60px - 30px);
	}

	#entryForm #dl__recruitment_type label {
		margin-top: .5em;
		margin-left: 90px;
	}
	#entryForm #dl__recruitment_type label:not(:nth-of-type(1)) {
		margin-left: 20px;
	}
	#entryForm #dl__recruitment_type label:nth-of-type(2),
	#entryForm #dl__recruitment_type label:nth-of-type(4) {
		margin-right: 240px;
	}
	#entryForm #dl__recruitment_type label:nth-of-type(3) {
		margin-left: 90px;
	}
	#dl__recruitment_type .radioErrorMsg {
		margin-left: 90px;
		margin-top: .5em;
	}
	#entryForm #dl__sex_type label:not(:nth-of-type(1)) {
		margin-left: 20px;
	}
	#entryForm #dl__sex_type label:nth-of-type(3) {
		margin-left: 20px;
	}
	#entryForm #dl__birth span:not(:first-of-type) {
		margin-right: 1em;
	}
	#entryForm #dl__birth span:last-of-type {
		margin-left: 2em;
	}
	#entryForm #dl__birth span input,
	#entryForm #dl__birth span select {
		margin: 0 .25em 0 0;
	}
	#entryForm #dl__address span:nth-of-type(2) {
		margin-right: 10px;
	}
	#entryForm #dl__address span:last-of-type {
		margin-left: 90px;
	}

	#privacyPolicy {
		text-align: center;
		margin: 40px auto;
	}
	#privacyCheckFlag {
		margin: 40px auto;
		justify-content: center;
	}


	/* button -------------------------------------------------- */
	#confirmBtn,
	#returnBtn,
	#completeBtn {
		width: 350px;
	}


	/* confirm -------------------------------------------------- */
	/* #confirmForm */
	#confirmForm {
		width: 920px;
	}
	#confirmForm dl {
		line-height: 1.375;
		margin: 2.5em 0;
	}
	#confirmForm dl dt {
		width: 230px;
	}
	#confirmForm dl dd {
		width: calc(100% - 230px);
		padding: 0 0 0 90px;
	}
	#confirmForm .formMustTrue,
	#confirmForm .formMustFalse {
		top: 0;
	}
	#returnBox {
		margin: 80px auto 0 auto;
	}

	/* complete -------------------------------------------------- */
	h2 {
		margin: 40px auto;
	}
	.sentMsg {
		text-align: center;
	}
}


/* --------------------------------------------------
 * 画面の横幅が959pxまで（タブレット端末横）
 * -------------------------------------------------- */
@media screen and (max-width: 959px){
	/* common -------------------------------------------------- */
	form {
		width: 88%;
	}

	/* index -------------------------------------------------- */
	/* #introduction */
	#introduction {
		width: 88%;
	}
	#introduction p {
		line-height: 1.3;
	}
	#contactTel {
		width: 280px;
		flex-direction: column;
	}
	#contactTelTitle {
		width: 100%;
	}
	#contactTelBody {
		height: auto;
		padding: 20px 0;
		border-top: none;
		flex-direction: column;
	}
	#contactTelBody a {
		margin: 0 0 1em 0;
	}
	#contactTelBody p {
		line-height: 1;
		text-align: center;
	}
	/* #entryForm */
	#entryForm {
		width: 88%;
		margin-top: 25px;
	}
	#entryForm dl {
		flex-direction: column;
		margin: 25px 0 20px 0;
	}
	#entryForm dl dt {
		width: 100%;
		line-height: 1;
		box-sizing: border-box;
		padding: 0 0 0 80px;
	}
	#entryForm dl dd {
		width: 100%;
		position: relative;
		margin: 20px 0 0 0;
	}
	.formMustTrue,
	.formMustFalse {
		margin: 0;
		position: absolute;
		top: -45px;
		left: 0;
	}
	.formCaution {
		width: calc(100% - 42px - 30px);
	}

	.w100 {
		width: 100%;
	}

	#entryForm #dl__recruitment_type dd {
		flex-direction: column;
	}
	#entryForm #dl__recruitment_type label {
		margin-top: 20px;
		margin-left: 0;
	}
	#entryForm #dl__recruitment_type label:not(:nth-of-type(1)) {
		margin-left: 0;
	}
	#dl__recruitment_type .radioErrorMsg {
		margin-top: 20px;
		margin-left: 0;
	}
	#entryForm #dl__sex_type dd {
		flex-direction: column;
	}
	#entryForm #dl__sex_type label:not(:nth-of-type(1)) {
		margin-top: 20px;
		margin-left: 0;
	}
	#dl__sex_type .radioErrorMsg {
		margin-top: 20px;
		margin-left: 0;
	}
	#entryForm #dl__birth span:not(:first-of-type) {
		margin-right: 10px;
	}
	#entryForm #dl__birth span:nth-of-type(2) {
		margin-right: calc(100% - 100px);
		margin-bottom: 20px;
	}
	#entryForm #dl__birth span:nth-of-type(4) {
		margin-right: calc(100% - 220px);
		margin-bottom: 20px;
	}
	#entryForm #dl__birth span:last-of-type {
		margin-left: 0;
	}
	#entryForm #dl__birth span input,
	#entryForm #dl__birth span select {
		margin: 0 10px 0 0;
	}
	#entryForm #dl__address span:nth-of-type(2) {
		margin-right: calc(100% - 150px);
		margin-bottom: 20px;
	}
	#entryForm #dl__address span:last-of-type {
		margin-left: 0;
	}
	#entryForm #dl__driver_licence label:not(:nth-of-type(1)) {
		margin-right: calc(100% - 160px);
	}
	#dl__driver_licence .radioErrorMsg {
		margin-top: 20px;
		margin-left: 0;
	}

	#privacyPolicy {
		text-align: left;
		margin: 20px auto;
	}
	#privacyCheckFlag {
		margin: 20px auto 40px auto;
		justify-content: flex-start;
	}


	/* button -------------------------------------------------- */
	#confirmBtn,
	#returnBtn,
	#completeBtn {
		width: 280px;
	}


	/* confirm -------------------------------------------------- */
	/* #confirmForm */
	#confirmForm {
		width: 88%;
		margin-top: 25px;
	}
	#confirmForm dl {
		flex-direction: column;
		line-height: 1.5;
		margin: 20px 0;
	}
	#confirmForm dl dt {
		width: 100%;
		line-height: 1;
		box-sizing: border-box;
		padding: 0 0 0 80px;
	}
	#confirmForm dl dd {
		width: 100%;
		padding: 0;
		margin: 20px 0 0 0;
	}
	#confirmForm .formMustTrue,
	#confirmForm .formMustFalse {
		top: -45px;
	}
	#returnBox {
		margin: 40px auto 0 auto;
	}

	/* complete -------------------------------------------------- */
	h2 {
		margin: 20px auto;
		width: 88%;
	}
	.sentMsg {
		text-align: left;
		margin: 0 auto;
		width: 88%;
	}
}