@charset "utf-8";

/* === Index ==========

1. Common
2. Header
3. Contents
	3-0. Common
	3-1. First Message
	3-2. Skill up & Training
4. Order
5. Footer

=================== */



/* ====================

	1. Common

==================== */

.innerBox {
	width: 980px;
	margin: 0 auto;
}
@media screen and (max-width: 667px) {
	.innerBox, .pageStyle main > section { width: 94%; }
}

h1, h2, h3, h4, h5, h6, p, li, th, td, dt, dd {
	font-family: "Hiragino Kaku Gothic ProN", Meiryo, "Hiragino Sans", "sans-serif";
}

p, li, th, td, dt, dd {
	color: #444;
	font-size: 1.6rem;
}
@media screen and (max-width: 667px) {
	p, li, th, td, dt, dd { font-size: 1.4rem; }
}

li {
	list-style: none;
	line-height: 1.5;
}

p { line-height: 1.7; }

a { text-decoration: none; }

.f16 { font-size: 1.6rem; }

.red { color: #e94f55; }

.sp { display: none; }
@media screen and (max-width: 667px) {
	.sp { display: block; }
	
	img {
		width: 100%;
		height: auto;
	}
}



/* ====================

	2. Header

==================== */

header {
	padding: 2rem 0 10rem;
	background: url("../images/recruit/header_bg_pc.png") top center no-repeat;
}
@media screen and (max-width: 667px) {
	header {
		padding: 2rem 0 0;
		background: url("../images/recruit/header_bg_sp.jpg") top center no-repeat;
		background-size: 100%;
	}
	
	header .innerBox { width: 100%; }
}

h1 { line-height: 0; }
@media screen and (max-width: 667px) {
	h1 {
		width: 80%;
		margin: 0 auto 3rem;
	}
}

.mainImg { margin: -2.5rem auto 7rem; }
@media screen and (max-width: 667px) {
	.mainImg {
		margin: 0 auto;
		padding: 0 0 0 3%;
	}
}

.staff {
	width: 740px;
	margin: 0 auto;
	padding: 8rem 0 8.6rem;;
	text-align: center;
	background: url("../images/recruit/order_bg_pc.png") center top no-repeat;
}
@media screen and (max-width: 667px) {
	.staff {
		width: 94%;
		padding: 4rem 0;
		background: url("../images/recruit/order_bg_sp.png") center top no-repeat;
		background-size: 100%;
	}
}

.staff h2 {
	margin-bottom: 3rem;
	line-height: 0;
}
@media screen and (max-width: 667px) {
	.staff h2 { margin-bottom: 0; }
}

.staff h2 span {
	display: block;
	margin-bottom: 0.8rem;
}
@media screen and (max-width: 667px) {
	.staff h2 span { margin-bottom: 0.5rem; }
}


/* ====================

	3. Contents

==================== */

/* --- 3-0. Common --- */
.yelCirc, .yelBg, .greeting, .requirements {
	padding: 8rem 0 7rem;
}
@media screen and (max-width: 667px) {
	.yelCirc, .yelBg, .greeting, .requirements {
		padding: 4rem 0;
	}
}

.greeting h2, .requirements h2 {
	margin-bottom: 6rem;
	font-size: 4rem;
	font-weight: normal;
	text-align: center;
	position: relative;
}
@media screen and (max-width: 667px) {
	.greeting h2, .requirements h2 {
		font-size: 2.8rem;
	}
}

.greeting h2:before, .requirements h2:before {
	content: '';
	position: absolute;
	bottom: -15px;
	display: inline-block;
	width: 40px;
	height: 3px;
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
	border-radius: 2px;
}




/* --- 3-1. First Message --- */
.firstMes {
	display: flex;
	flex-wrap: wrap;
	flex-direction: row-reverse;
	justify-content: space-between;
	align-items: center;
}
@media screen and (max-width: 667px) {
	.firstMes { flex-direction: column; }
}

.firstMes div { width: 520px; }
@media screen and (max-width: 667px) {
	.firstMes div {
		width: 100%;
		margin-bottom: 3rem;
	}
}

.firstMes h2 {
	width: 100%;
	margin-bottom: 4rem;
	color: #67483b;
	font-size: 2.8rem;
	text-align: center;
	line-height: 1.3;
}
@media screen and (max-width: 667px) {
	.firstMes h2 {
		margin-bottom: 3rem;
		font-size: 2.4rem;
	}
}

.firstMes h2 span { display: block; }

.firstMes p { margin-bottom: 2.8rem; }


/* --- 3-2. Skill up & Circumstance --- */
.grnBg {
	padding: 18rem 0 9rem;
	background: url("../images/recruit/bg_grnleaf_pc.png") top center no-repeat;
}

.skill, .circ, .voice {
	display: flex;
	position: relative;
	padding-top: 4rem;
}

.skill, .voice { flex-direction: row; }
.circ { flex-direction: row-reverse; }
.skill, .circ { margin-bottom: 6rem; }
@media screen and (max-width: 667px) {
	.skill, .circ { margin-bottom: 4rem; }
	.skill, .circ, .voice { flex-direction: column; }
}

.skill div, .circ div, .voice div {
	width: 560px;
	padding: 6rem;
	background-color: #fff;
}
@media screen and (max-width: 667px) {
	.skill div, .circ div, .voice div {
		width: 100%;
		padding: 10% 5%;
	}
}

.circ div { margin-left: -40px; }
@media screen and (max-width: 667px) {
	.circ div { margin-left: 0; }
}

.voice div {
	padding-bottom: 14rem;
	background: url("../../images/recruit/voice_txt_bg.png") center bottom no-repeat;
	background-color: #fff;
}

.skill:before { content: url("../images/recruit/skillup_txt.png"); }
.voice:before { content: url("../../images/recruit/voice_txt.png"); }

.skill:before, .voice:before {
	position: absolute;
	top: 20px;
	left: 60px;
	z-index: 100;	
}

.circ:before {
	content: url("../images/recruit/circ_txt.png");
	position: absolute;
	top: 20px;
	left: 480px;
	z-index: 100;
}
@media screen and (max-width: 667px) {
	.skill:before { content: url("../images/recruit/skillup_txt_sp.png"); }
	.circ:before { content: url("../images/recruit/circ_txt_sp.png"); }
	.voice:before { content: url("../images/recruit/voice_txt_sp.png"); }
	
	.skill:before, .circ:before, .voice:before {
		top: 30px;
		left: 5%;
	}
}

.skill h2, .circ h2, .voice h2 {
	position: relative;
	margin-bottom: 3rem;
	padding-bottom: 3rem;
	font-size: 2.8rem;
	font-weight: normal;
	line-height: 1.3;
}
@media screen and (max-width: 667px) {
	.skill h2, .circ h2, .voice h2 { font-size: 2.4rem; }
}

.skill h2:after, .circ h2:after, .voice h2:after {
	position: absolute;
	content: " ";
	display: block;
	bottom: -3px;
	width: 8%;
}

.skill h2:after, .voice h2:after { border-bottom: solid 3px #84c24c; }
.circ h2:after { border-bottom: solid 3px #ffc23c; }

.skill figure, .voice figure { margin: -40px 0 0 -40px; }
.circ figure {
	margin: -40px 0 0 0;
	z-index: 100;
}
@media screen and (max-width: 667px) {
	.skill figure, .circ figure, .voice figure { margin: 0; }
}

.skill p, .circ p, .voice p { margin-bottom: 1rem; }
.skill p:last-child, .circ p:last-child, .voice p:last-child { margin-bottom: 0; }



/* --- 3-3. Greeting --- */
.greeting {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	background: url("../../images/recruit/greeting_bg.png") center top no-repeat;
}
@media screen and (max-width: 667px) {
	.greeting { background-size: 100%; }
}

.greeting h2 { width: 100%; }

.greeting h2:before { background-color: #f5c51d; }

.greeting div { width: 600px; }
@media screen and (max-width: 667px) {
	.greeting div { width: 100%; }
}

.greeting p { margin-bottom: 3rem; }
.greeting p:last-child { margin-bottom: 0; }

.greeting figure { margin-right: 2rem; }
.greeting figure img { box-shadow: 20px 20px 0px 0px #fffae4; }
@media screen and (max-width: 667px) {
	.greeting figure {
		width: 80%;
		margin: 2rem auto;
	}
}


/* --- 3-4. Requirements --- */
.requirements { background: url("../images/recruit/bg_yel_stripe.png") repeat; }

.requirements h2:before { background-color: #f5c51d; }

.requirements h3 {
	width: 980px;
	margin: 0 auto 4rem;
	color: #67483b;
	font-size: 2.4rem;
	font-weight: normal;
	text-align: center;
}
@media screen and (max-width: 667px) {
	.requirements h3 { width: 100%; }
}

.requirements h3 span {
	padding: 1rem 3rem;
	background-color: rgb(233 79 85 / 0.2);
	border-radius: 30px;
}

.requirements a {
	color: #e94f55;
	border-bottom: 1px solid #e94f55;
}

#timetable {
	margin: 0 auto;
	background-color: #fff;
	border-top: 1px solid #ddd;
	border-left: 1px solid #ddd;
}

#timetable th, #timetable td {
	font-size: 1.6rem;
	padding: 1rem;
	border-right: 1px solid #ddd;
	border-bottom: 1px solid #ddd;
}

#timetable th {
	color: #895d4c;
	background-color: rgb(190 153 121 / 0.1);
}

.closed {
	width: 345px;
	margin: 0 auto 6rem;
	font-size: 1.2rem;
}

.requirements > dl {
	margin: 0 auto 8rem;
	padding: 6rem;
	background-color: #fff;
}
@media screen and (max-width: 667px) {
	.requirements > dl {
		margin: 0 auto 4rem;
		padding: 5%;
	}
}

.mrg-btm1 { margin-bottom: 1rem!important; }

.requirements > dl > dt {
	float: left;
	width: 150px;
	padding: 1.5rem 0;
	color: #895d4c;
	font-weight: bold;
	line-height: 1.7;
}
@media screen and (max-width: 667px) {
	.requirements > dl > dt {
		float: none;
		width: 100%;
		padding: 1.5rem 0 1rem;
	}
	.requirements > dl > dt:first-child { border-top: 1px dashed #ddd; }
}

.requirements > dl > dd {
	padding: 1.5rem 0 1.5rem 15rem;
	line-height: 1.7;
	border-top: 1px dashed #ddd;
}
@media screen and (max-width: 667px) {
	.requirements > dl > dd {
		padding: 0 0 1.5rem;
		border-top: none;
		border-bottom: 1px dashed #ddd;
	}
}

.requirements > dl > dd:last-child { border-bottom: 1px dashed #ddd; }

.requirements dd dt {
	margin-top: 1rem;
	color: #895d4c;
	font-weight: bold;
	line-height: 1.7;
}

.requirements li {
	margin-left: 1em;
	list-style: disc;
}



/* ====================

	4. Order

==================== */

.btn {
	width: 800px;
	margin: 0 auto;
}
@media screen and (max-width: 667px) {
	.btn { width: 90%; }
}

.btn a {
	display: block;
	padding: 2rem 0;
	color: #fff;
	font-size: 3.2rem;
	font-weight: bold;
	text-align: center;
	border-radius: 50px;
	background: linear-gradient(90deg, #fd8e2c 0%, #ffe933 100%);
}
@media screen and (max-width: 667px) {
	.btn a { font-size: 2.4rem; }
}

.btn a:hover { background: linear-gradient(90deg, #ffe933 0%, #fd8e2c 100%); }



/* ====================

	5. Footer

==================== */

footer { padding: 8rem 0 0; }
@media screen and (max-width: 667px) {
	footer { padding: 4rem 0 0; }
}

footer .innerBox {
	display: flex;
	justify-content: space-between;
	padding-bottom: 8rem;
	background: url("../images/footer_bg_pc.png") center bottom no-repeat;
}
@media screen and (max-width: 667px) {
	footer .innerBox {
		flex-direction: column;
		margin-bottom: 4rem;
	}

	footer .innerBox div:first-child { margin-bottom: 3rem;}

	.map {
		position: relative;
		width: 100%;
		height: 0;
		padding-top: 75%;
	}

	.map iframe {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
	}
}

.footerInfo {
	padding: 4rem 0;
	background-color: #895d4c;
}

.footerInfo ul {
	display: flex;
	justify-content: center;
}
@media screen and (max-width: 667px) {
	.footerInfo ul {
		width: 94%;
		flex-wrap: wrap;
		justify-content: flex-start;
		margin: 0 auto;
	}
	
	.footerInfo li {
		width: 50%;
		margin: 0 0 1rem;
		text-align: center;
	}
}

.footerInfo li,.footerInfo a, .footerInfo p {
	color: #fff;
	font-size: 1.4rem;
}

.footerInfo li { padding-right: 1em; }
@media screen and (max-width: 667px) {
	.footerInfo li { padding-right: 0; }
}

.footerInfo li:after {
	content: "／";
	padding-left: 1em;
}
@media screen and (max-width: 667px) {
	.footerInfo li:after {
		content: "";
		padding-left: 0;
	}
}

.footerInfo li:last-child { padding-right: 0; }

.footerInfo li:last-child:after {
	content: "";
	padding-left: 0;
}

.footerInfo p { text-align: center; }






