/* ====================
content
==================== */
.content#home {
	width: 1300px;
	margin: 0 auto;
	position: relative;
}

/* ====================
lead
==================== */
.lead {
	background: url(../img/home/bg_lead_pc.gif) left top no-repeat;
	height: 560px;
}
.lead-title {
	padding-top: 94px;
	text-align: center;
}
.lead-text {
	font-size: 24px;
	font-weight: 500;
	line-height: 2.17;
	padding-top: 10px;
	text-align: center;
	letter-spacing: 0.04em;
	margin-left: 10px;
}

/* ====================
about
==================== */
.about {
	background: url(../img/home/bg_about_pc.gif) left top no-repeat;
	height: 1351px;
}
.about-image {
	text-align: center;
}
.about-image img {
	width: 640px;
}
.about-title-wrapper {
	padding-top: 36px;
}
.about-title {
	font-size: 52px;
	font-weight: 900;
	color: #ffffff;
	letter-spacing: 0.06em;
	text-align: center;
	line-height: 1;
}
.about-title span {
	position: relative;
}
.about-title span::before {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/home/bg_title.png) left top no-repeat;
	background-size: contain;
	width: 90px;
	height: 131px;
	top: -25px;
	left: -108px;
}
.about-title span::after {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/home/bg_title.png) left top no-repeat;
	background-size: contain;
	width: 90px;
	height: 131px;
	top: -25px;
	right: -100px;
}
.about-title-sub {
	font-size: 130px;
	font-family: "Open Sans", sans-serif;
	font-weight: 700;
	text-align: center;
	letter-spacing: 0.1em;
	color: #ffffff;
	line-height: 1;
	padding-top: 20px;
	margin-left: 4px;
}
.about-title-sub span {
	color: #fd319b;
}
.about-info {
	width: 1100px;
	background-color: #ffffff;
	border-radius: 20px;
	margin: 45px auto 0;
	padding-top: 50px;
	padding-bottom: 60px;
}
.about-info-text {
	font-size: 16px;
	font-weight: 500;
	line-height: 2.125;
	text-align: center;
	letter-spacing: 0.04em;
}
.about-btn-wrapper {
	padding-top: 30px;
	display: flex;
	justify-content: center;
}

/* ====================
interview
==================== */
.interview {
	background: url(../img/home/bg_interview_pc.gif) left top no-repeat;
	height: 1158px;
}
.interview-title-wrapper {
	padding-top: 98px;
}
.interview-title {
	font-size: 52px;
	font-weight: 900;
	color: #ffffff;
	letter-spacing: 0.06em;
	text-align: center;
	line-height: 1;
}
.interview-title span {
	position: relative;
}
.interview-title span::before {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/home/bg_title.png) left top no-repeat;
	background-size: contain;
	width: 90px;
	height: 131px;
	top: -25px;
	left: -108px;
}
.interview-title span::after {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/home/bg_title.png) left top no-repeat;
	background-size: contain;
	width: 90px;
	height: 131px;
	top: -25px;
	right: -108px;
}
.interview-title-sub {
	font-size: 130px;
	font-family: "Open Sans", sans-serif;
	font-weight: 700;
	text-align: center;
	letter-spacing: 0.09em;
	color: #ffffff;
	line-height: 1;
	padding-top: 20px;
}
.interview-title-sub span {
	color: #fd319b;
}
.interview-list-wrapper {
	width: 1100px;
	margin: 0 auto;
	padding-top: 43px;
}
.interview-list {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: center;
	gap: 39px 40px;
}
.interview-list-item {
	width: 340px;
	display: flex;
	flex-direction: column;
	position: relative;
	/*background-color: #ffffff;*/
	border-bottom-left-radius: 20px;
	border-bottom-right-radius: 20px;
	padding-bottom: 39px;
}
.interview-list-card a {
	display: flex;
	flex-direction: column;
}
.interview-list-card::before {
	position: absolute;
	content: "";
	display: block;
	width: 30px;
	height: 30px;
	background-color: #00b7ee;
	border-radius: 50%;
	bottom: 20px;
	right: 20px;
}
.interview-list-card::after {
	position: absolute;
	display: block;
	content: "";
	width: 6px;
	height: 6px;
	border-right: solid 2px #ffffff;
	border-bottom: solid 2px #ffffff;
	transform: rotate(-45deg);
	bottom: 31px;
	right: 32px;
}
.interview-list-card {
	position: relative;
	background-color: rgba( 255, 255, 255, 0.85 );
	left: 20px;
	bottom: 30px;
}
.interview-list-text {
	font-size: 18px;
	font-weight: 700;
	line-height: 1.78;
	padding: 12px 20px 0 20px;
	letter-spacing: 0.04em;
	flex-grow: 1;
}
.interview-list-jobname {
	font-size: 16px;
	font-weight: 500;
	line-height: 1;
	padding: 12px 20px 20px 20px;
	letter-spacing: 0.04em;
}


/* ====================
environment
==================== */
.environment {
	background: url(../img/home/bg_environment_pc.gif) left top no-repeat;
	height: 2621px;
}
.environment-title-wrapper {
	padding-top: 196px;
}
.environment-title {
	font-size: 52px;
	font-weight: 900;
	color: #ffffff;
	letter-spacing: 0.06em;
	text-align: center;
	line-height: 1;
}
.environment-title span {
	position: relative;
}
.environment-title span::before {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/home/bg_title.png) left top no-repeat;
	background-size: contain;
	width: 90px;
	height: 131px;
	top: -25px;
	left: -108px;
}
.environment-title span::after {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/home/bg_title.png) left top no-repeat;
	background-size: contain;
	width: 90px;
	height: 131px;
	top: -25px;
	right: -108px;
}
.environment-title-sub {
	font-size: 130px;
	font-family: "Open Sans", sans-serif;
	font-weight: 700;
	text-align: center;
	letter-spacing: 0.09em;
	color: #ffffff;
	line-height: 1;
	padding-top: 20px;
}
.environment-title-sub span {
	color: #fd319b;
}
.environment-info-wrapper {
	width: 1100px;
	margin: 0 auto;
	padding-top: 45px;
	display: flex;
	position: relative;
}
.environment-info-wrapper.info01 {
	flex-direction: row-reverse;
}
.environment-info-wrapper.info02 {
	flex-direction: row;
	padding-top: 60px;
}
.environment-info-wrapper.info03 {
	flex-direction: row-reverse;
	padding-top: 60px;
}
.environment-info-wrapper.info04 {
	flex-direction: row;
	padding-top: 122px;
}
.environment-info-wrapper.info01::before {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/home/image_environment_info01.png) left top no-repeat;
	background-size: contain;
	width: 597px;
	height: 340px;
	top: 77px;
	left: -46px;
}
.environment-info-wrapper.info02::before {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/home/image_environment_info02.png) left top no-repeat;
	background-size: contain;
	width: 476px;
	height: 337px;
	top: 92px;
	right: 24px;
}
.environment-info-wrapper.info03::before {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/home/image_environment_info03.png) left top no-repeat;
	background-size: contain;
	width: 555px;
	height: 425px;
	top: 60px;
	left: -12px;
}
.environment-info-wrapper.info04::before {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/home/image_environment_info04.png) left top no-repeat;
	background-size: contain;
	width: 601px;
	height: 400px;
	top: 122px;
	right: -32px;
}


.environment-info {
	width: 570px;
	background-color: #ffffff;
	border-radius: 20px;
	padding-bottom: 72px;
}
.info04 .environment-info {
	width: 1100px;
	padding-bottom: 90px;
}
.environment-info-title {
	font-size: 34px;
	font-weight: 900;
	line-height: 1;
	padding: 57px 40px 0;
	letter-spacing: 0.04em;
}
.info04 .environment-info-title {
	padding: 98px 50px 0;
}
.environment-info-text {
	font-size: 16px;
	line-height: 2.125;
	padding: 20px 40px 0;
	letter-spacing: 0.04em;
}
.info04 .environment-info-text {
	padding: 20px 50px 0;
}
.environment-btn-wrapper {
	padding: 30px 40px 0;
}
.info04 .environment-btn-wrapper {
	padding: 40px 50px 0;
}
.info03 .btn-info {
	width: 330px;
}
.environment-btn-info-wrapper {
	padding-top: 60px;
	display: flex;
	justify-content: center;
}


/* ====================
application
==================== */
.application {
	background: url(../img/home/bg_application_pc.gif) left top no-repeat;
	height: 735px;
}
.application-title-wrapper {
	padding-top: 88px;
}
.application-title {
	font-size: 52px;
	font-weight: 900;
	color: #ffffff;
	letter-spacing: 0.06em;
	text-align: center;
	line-height: 1;
}
.application-title span {
	position: relative;
}
.application-title span::before {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/home/bg_title.png) left top no-repeat;
	background-size: contain;
	width: 90px;
	height: 131px;
	top: -25px;
	left: -112px;
}
.application-title span::after {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/home/bg_title.png) left top no-repeat;
	background-size: contain;
	width: 90px;
	height: 131px;
	top: -25px;
	right: -121px;
}
.application-title-sub {
	font-size: 130px;
	font-family: "Open Sans", sans-serif;
	font-weight: 700;
	text-align: center;
	letter-spacing: 0.09em;
	color: #ffffff;
	line-height: 1;
	padding-top: 20px;
}
.application-title-sub span {
	color: #fd319b;
}
.application-info-wrapper {
	width: 1100px;
	margin: 0 auto;
	padding-top: 45px;
	display: flex;
	flex-direction: row;
	column-gap: 40px;
}
.application-info {
	width: 530px;
	background-color: #ffffff;
	border-radius: 20px;
	padding-bottom: 90px;
	text-align: center; // 2024.05.02
}
.application-info-title {
	font-size: 34px;
	font-weight: 900;
	line-height: 1;
	padding: 76px 50px 0;
	letter-spacing: 0.04em;
}
.application-btn-wrapper {
	padding: 50px 50px 0;
	display: inline-block;  // 2024.05.2
}
.application-btn-info-wrapper {
	padding-top: 60px;
	display: flex;
	justify-content: center;
}


/* ====================
faq
==================== */
.faq {
	background: url(../img/home/bg_faq_pc.gif) left top no-repeat;
	position: relative;
	padding-bottom: 200px;
}
.faq::before {
	position: absolute;
	display: block;
	content: "";
	background: linear-gradient(90deg, rgba(19,194,237,1) 0%, rgba(80,210,242,1) 100%);
	background-size: contain;
	width: 1300px;
	height: 100%;
	top: 0;
	left: 0;
	z-index: -1;
}
.faq::after {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/home/bg_faq_pc.png) left bottom no-repeat;
	background-size: contain;
	width: 132px;
	height: 64px;
	bottom: 60px;
	left: 0;
}
.faq-title-wrapper {
	padding-top: 195px;
}
.faq-title {
	font-size: 52px;
	font-weight: 900;
	color: #ffffff;
	letter-spacing: 0.06em;
	text-align: center;
	line-height: 1;
}
.faq-title span {
	position: relative;
}
.faq-title span::before {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/home/bg_title.png) left top no-repeat;
	background-size: contain;
	width: 90px;
	height: 131px;
	top: -25px;
	left: -95px;
}
.faq-title span::after {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/home/bg_title.png) left top no-repeat;
	background-size: contain;
	width: 90px;
	height: 131px;
	top: -25px;
	right: -115px;
}
.faq-title-sub {
	font-size: 130px;
	font-family: "Open Sans", sans-serif;
	font-weight: 700;
	text-align: center;
	letter-spacing: 0.09em;
	color: #ffffff;
	line-height: 1;
	padding-top: 20px;
}
.faq-title-sub span {
	color: #fd319b;
}
.faq-list {
	width: 1100px;
	margin: 0 auto;
	padding-top: 46px;
	position: relative;
}
.faq-list::before {
	position: absolute;
	display: block;
	content: "";
	background: url(../img/home/img_faq.png) right top no-repeat;
	background-size: contain;
	width: 239px;
	height: 352px;
	top: -305px;
	right: -35px;
}
.faq-list-item {
	border-top: 1px solid #ffffff;
}
.faq-list-item:last-child {
	border-bottom: 1px solid #ffffff;
}
.question {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: baseline;
	padding: 26px 28px 34px;
	position: relative;
	cursor: pointer;
}
.question::after {
	position: absolute;
	display: block;
	content: "";
	width: 8px;
	height: 8px;
	border-right: solid 3px #ffffff;
	border-bottom: solid 3px #ffffff;
	transform: rotate(45deg);
	top: calc(50% - -3px);
	right: 22px;
}
.question.open::after {
	position: absolute;
	display: block;
	content: "";
	width: 8px;
	height: 8px;
	border-right: solid 3px #ffffff;
	border-bottom: solid 3px #ffffff;
	transform: rotate(-135deg);
	top: calc(50% - 2px);
	right: 22px;
}
.question-number {
	width: 73px;
	font-size: 40px;
	font-family: "Open Sans", sans-serif;
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1;
	color: #ffffff;
}
.quetion-list {
	font-size: 26px;
	font-weight: 500;
	letter-spacing: 0.04em;
	line-height: 1;
	color: #ffffff;
}
.answer {
	padding: 22px 28px 28px;
	line-height: 1;
	border-top: 1px solid #ffffff;
	background-color: #a4eaff;
	display: none;
}
.answer-wrapper {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	align-items: baseline;
}
.answer-number {
	width: 73px;
	font-size: 40px;
	font-family: "Open Sans", sans-serif;
	font-weight: 700;
	letter-spacing: 0.04em;
	color: #2dc4f1;
}
.answer-list {
	font-size: 16px;
	font-weight: 500;
	letter-spacing: 0.04em;
	line-height: 2.125;
}