* {
	box-sizing: border-box;
}

html {
	visibility: hidden;
	animation: loading 0.5s ease-in-out 0.5s forwards;
}

body {
	font-family: "Prompt", "Noto Sans JP", sans-serif;
}

img {
	display: block;
	width: 100%;
	height: auto;
}

picture {
	display: block;
	width: 100%;
	height: auto;
}

a {
	display: inline-block;
	transition-duration: 0.7s;
}

a:hover {
	opacity: 0.7;
}

.faq-fv {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 320px;
	background-image: url("../../img/faq-fv.webp");
	background-position: center;
	background-size: cover;
}

.faq-fv__title {
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-top: 40px;
	color: #ffffff;
}

.faq-fv__title-en {
	font-size: 50px;
	line-height: 1.6;
	text-align: center;
	text-transform: uppercase;
}

.faq-fv__title-jp {
	font-size: 18px;
}

.faq__content {
	padding: 90px 0;
}

.faq__section {
	margin-bottom: 80px;
}

.faq__hdl {
	display: flex;
	position: relative;
	flex-direction: column;
	width: 100%;
	margin-bottom: 40px;
}

.faq__hdl-en {
	-moz-column-gap: 24px;
	display: flex;
	column-gap: 24px;
	align-items: center;
	margin-bottom: 16px;
	font-weight: bold;
	font-size: 18px;
	text-transform: uppercase;
}

.faq__hdl-en:after {
	display: block;
	flex-grow: 1;
	height: 2px;
	background-color: #212121;
	content: "";
}

.faq__hdl.--recruit .faq__hdl-en {
	color: #ffd800;
}

.faq__hdl.--work .faq__hdl-en {
	color: #802eff;
}

.faq__hdl.--welfare .faq__hdl-en {
	color: #ff8045;
}

.faq__hdl-jp {
	padding-bottom: 16px;
	border-bottom: 2px solid #212121;
	color: #212121;
	font-weight: bold;
	font-size: 36px;
	text-align: center;
}

.faq__block {
	margin-bottom: 40px;
}

.faq__block:last-of-type {
	margin-bottom: 0;
}

.faq__question {
	display: flex;
	position: relative;
	align-items: center;
	width: 100%;
	height: 55px;
	background-color: #d0d0d0;
	font-size: 21px;
	cursor: pointer;
	transition-duration: 0.5s;
}

.faq__question:hover {
	opacity: 0.7;
}

.faq__question-q {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 55px;
	height: 55px;
	margin-right: 20px;
	color: #212121;
	font-weight: bold;
	font-size: 25px;
}

.faq__list.--recruit .faq__question-q {
	background-color: #ffd800;
}

.faq__list.--work .faq__question-q {
	background-color: #802eff;
}

.faq__list.--welfare .faq__question-q {
	background-color: #ff8045;
}

.faq__question-icon {
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	position: absolute;
	top: 52%;
	right: 2%;
	width: 12px;
	height: 12px;
	transform: translate(-50%, -50%);
}

.faq__question-icon-img {
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
	transition-duration: 0.5s;
}

.faq__question-icon-img.--active {
	opacity: 1;
}

.faq__answer {
	width: calc(100% - 55px);
	max-height: 0;
	margin-right: 0;
	margin-left: auto;
	overflow: hidden;
	transition: max-height 0.5s ease-out;
	transition-duration: 0.5s;
}

.faq__answer-text {
	padding: 10px 20px;
	color: #212121;
	font-weight: bold;
	font-size: 18px;
	line-height: 1.666;
}

.faq__answer-text a {
	text-decoration: underline;
}

.faq__list.--recruit .faq__answer {
	background-color: #ffd800;
}

.faq__list.--work .faq__answer {
	background-color: #802eff;
}

.faq__list.--work .faq__answer-text {
	color: #ffffff;
}

.faq__list.--welfare .faq__answer {
	background-color: #ff8045;
}

@media screen and (max-width: 1200px) {

.faq-fv {
	height: 22.2222222222vw;
}

.faq-fv__title {
	margin-top: 2.7777777778vw;
}

.faq-fv__title-en {
	font-size: 3.4722222222vw;
}

.faq-fv__title-jp {
	font-size: 1.25vw;
}

.faq__content {
	padding: 6.25vw 0;
}

.faq__section {
	margin-bottom: 5.5555555556vw;
}

.faq__hdl {
	margin-bottom: 2.7777777778vw;
}

.faq__hdl-en {
	-moz-column-gap: 1.6666666667vw;
	column-gap: 1.6666666667vw;
	margin-bottom: 1.1111111111vw;
	font-size: 1.25vw;
}

.faq__hdl-en:after {
	height: 0.1388888889vw;
}

.faq__hdl-jp {
	padding-bottom: 1.1111111111vw;
	border-bottom: 0.1388888889vw solid #212121;
	font-size: 2.5vw;
}

.faq__block {
	margin-bottom: 2.7777777778vw;
}

.faq__block:last-of-type {
	margin-bottom: 0;
}

.faq__question {
	height: 3.8194444444vw;
	font-size: 1.4583333333vw;
}

.faq__question-q {
	width: 3.8194444444vw;
	height: 3.8194444444vw;
	margin-right: 1.3888888889vw;
	font-size: 1.7361111111vw;
}

.faq__question-icon {
	width: 0.8333333333vw;
	height: 0.8333333333vw;
}

.faq__answer {
	width: calc(100% - 3.8194444444vw);
}

.faq__answer-text {
	padding: 0.6944444444vw 1.3888888889vw;
	font-size: 1.25vw;
}

}

@media screen and (max-width: 767px) {

.faq-fv {
	height: 74.6666666667vw;
	background-image: url("../../img/sp-faq-fv.webp");
}

.faq-fv__title {
	margin-top: 5.3333333333vw;
}

.faq-fv__title-en {
	margin-bottom: 2.1333333333vw;
	font-size: 13.3333333333vw;
	line-height: 1.1;
}

.faq-fv__title-jp {
	font-size: 4.8vw;
}

.faq__content {
	padding: 18.6666666667vw 0 16vw 0;
}

.faq__section {
	margin-bottom: 18.6666666667vw;
}

.faq__section:last-of-type {
	margin-bottom: 0;
}

.faq__hdl {
	margin-bottom: 8vw;
}

.faq__hdl-en {
	-moz-column-gap: 4.2666666667vw;
	column-gap: 4.2666666667vw;
	margin-bottom: 1.6vw;
	font-size: 4.2666666667vw;
}

.faq__hdl-en:after {
	height: 0.2666666667vw;
}

.faq__hdl-jp {
	padding-bottom: 4.2666666667vw;
	border-bottom: 0.2666666667vw solid #212121;
	font-size: 6.6666666667vw;
}

.faq__block {
	margin-bottom: 8vw;
}

.faq__block:last-of-type {
	margin-bottom: 0;
}

.faq__question {
	height: 18.6666666667vw;
	padding: 0 4vw 0 13.3333333333vw;
	padding-left: 13.3333333333vw;
	font-size: 4.2666666667vw;
	line-height: 1.5;
}

.faq__question-q {
	position: absolute;
	top: 0;
	left: 0;
	width: 9.3333333333vw;
	height: 9.3333333333vw;
	margin-right: 4vw;
	font-size: 5.3333333333vw;
}

.faq__question-icon {
	top: 75%;
	right: auto;
	left: 5.6%;
	width: 3.2vw;
	height: 3.2vw;
}

.faq__answer {
	width: 100%;
}

.faq__answer-text {
	padding: 3.2vw 4vw;
	font-size: 3.7333333333vw;
}

}

@keyframes loading {

0% {
	visibility: hidden;
}

100% {
	visibility: visible;
}

}

