@charset "utf-8";
/*------------------------------------------------------------
	recruit/interview/
------------------------------------------------------------*/
#main {
	overflow: hidden;
}
#main .headLine07 .large {
	text-shadow: 0.2rem 0.2rem 0 #000;
}
#main .voiceBox .voiceImg {
	width: 12.9rem;
}
#main .voiceBox .rBox {
	padding: 2.6rem 4.5rem;
	position: relative;
	background-color: #fff;
	border: 0.1rem solid #000;
	border-radius: 1rem;
}
#main .voiceBox .rBox p {
	line-height: 1.75;
	text-align: justify;
}
#main .voiceBox .rBox:after {
	position: absolute;
	left: 4.2rem;
	bottom: -1.2rem;
	width: 2.3rem;
	aspect-ratio: 46/28;
	background: url(../img/recruit/voice_bg01.png) no-repeat left top/100%;
	content: "";
}
#main .topVisual {
	padding: 3.3rem 0 9.3rem;
	position: relative;
	z-index: 1;
	align-items: flex-start;
	justify-content: flex-end;
}
#main .topVisual .sideImg {
	position: absolute;
	left: 0;
	top: 3.3rem;
	width: 9.1rem;
	height: calc(100% - 12.8rem);
	border-radius: 0 9.8rem 0 0;
	overflow: hidden;
}
#main .topVisual .sideImg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 16.5% top;
}
#main .topVisual .phoBox {
	width: calc(50% + 13.4rem);
	height: 80.7rem;
	border-radius: 12.4rem 0 0 0;
	overflow: hidden;
}
#main .topVisual .phoBox img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: right top;
}
#main .topVisual .txtBox {
	margin: 6.2rem -57.7rem 0 12rem;
	width: 100rem;
	position: relative;
	z-index: 1;
}
#main .topVisual .txtBox h2 {
	margin: 0 0 6.3rem;
	text-align: left;
}
#main .topVisual .txtBox h2 img {
	margin: 0 0 2.8rem -0.3rem;
	height: 5.82rem;
	display: block;
}
#main .topVisual .txtBox h2 .large {
	font-size: 7.5rem;
	line-height: 1.42;
	letter-spacing: 0.22em;
}
#main .topVisual .txtBox .subTtl {
	margin: 0 0 3.4rem 0.5rem;
	font-size: 1.3rem;
}
#main .topVisual .txtBox .subTtl .name {
	display: block;
	font-size: 1.2rem;
	letter-spacing: 0.05em;
}
#main .topVisual .txtBox .subTtl .name .large {
	margin-right: 1rem;
	font-size: 2.4rem;
	font-weight: 700;
	vertical-align: -0.5rem;
	letter-spacing: 0.08em;
}
#main .topVisual .txtBox .infoList {
	max-width: 30rem;
	margin-left: 1rem;
	position: relative;
	padding-left: 2.7rem;
	line-height: 1.6;
	letter-spacing: 0.04em;
}
#main .topVisual .txtBox .infoList:before,
#main .topVisual .txtBox .infoList:after {
	position: absolute;
	left: 0;
	top: 0.2rem;
	width: 0.5rem;
	height: calc(50% - 0.4rem);
	background: #00A23E;
	content: "";
}
#main .topVisual .txtBox .infoList:after {
	top: calc(50% - 0.4rem);
	background: #000;
}
#main .topVisual .txtBox .infoList li:not(:last-child) {
	margin-bottom: 1.3rem;
}
#main .topVisual .txtBox .infoList .ttl {
	display: flex;
	align-items: center;
	font-weight: 700;
}
#main .topVisual .txtBox .infoList .ttl:after {
	margin-left: 1rem;
	flex: 1;
	border-top: 1px solid #000;
	content: "";
}
#main .topVisual .txtBox .infoList .txt {
	margin-right: -1rem;
}
#main .topVisual .txtBox .voiceBox {
	position: absolute;
	left: 35.3rem;
	bottom: 5.6rem;
	align-items: flex-end;
}
#main .topVisual .txtBox .voiceBox .voiceImg {
	margin: 0 0.5rem -11rem 0;
}
#main .detailBox {
	padding: 13.5rem 0 23rem;
}
#main .detailBox .content {
	max-width: 135rem;
}
#main .detailBox .photo {
	border: 1px solid #000;
	border-radius: 1.2rem;
	overflow: hidden;
}
#main .detailBox .photo img {
	width: 100%;
}
#main .detailBox .bgBox {
	margin: 0 0 10.8rem 8.1%;
	max-width: 104.8rem;
	padding: 8.8rem 11% 11.7rem;
	position: relative;
	background-color: #00A23E;
	border: 1px solid #000;
	border-radius: 1.2rem;
}
#main .detailBox .bgBox .enTtl {
	position: absolute;
	left: 5.2rem;
	top: -3rem;
	letter-spacing: 0.04em;
}
#main .detailBox .bgBox .note {
	position: absolute;
	right: 7rem;
	top: -2.2rem;
	width: 20.6rem;
}
#main .detailBox .bgBox h3 {
	margin: 0 -1rem 2.8rem 0;
	text-align: left;
}
#main .detailBox .bgBox h3 .large {
	--start-color: #000;
	--end-color: #fff;
	font-size: 4.4rem;
	letter-spacing: 0.14em;
	text-shadow: 0.1rem 0.1rem 0 #000;
}
#main .detailBox .bgBox .txt {
	line-height: 2.5;
	text-align: justify;
}
#main .detailBox .bgBox .voiceBox {
	position: absolute;
	left: 5.8rem;
	bottom: -5.4rem;
}
#main .detailBox .bgBox .voiceBox .voiceImg {
	margin: 2rem 2.4rem 0 0;
	width: 10.4rem;
}
#main .detailBox .bgBox .voiceBox .rBox {
	padding: 2rem 4.2rem;
}
#main .detailBox .bgBox .voiceBox .rBox:after {
	left: -1.26rem;
	bottom: 3.4rem;
	width: 1.3rem;
	aspect-ratio: 26/44;
	background-image: url(../img/recruit/voice_bg02.png);
}
#main .detailBox .bgBox .voiceBox .rBox p {
	letter-spacing: 0.05em;
}
#main .detailBox .bgBox .photo {
	position: absolute;
	bottom: -23.8rem;
	right: -15.7rem;
	width: 60rem;
}
#main .detailBox .circle {
	width: 35.7rem;
	border: 1px solid #000;
	border-radius: 50%;
}
#main .detailBox .circle img {
	width: 100%;
}
#main .detailBox .staffBox {
	margin-bottom: -0.2rem;
	align-items: flex-start;
	position: relative;
	z-index: 1;
}
#main .detailBox .staffBox .txtBox {
	margin: 7.2rem 0 0 3rem;
	flex: 1;
	max-width: 81.5rem;
}
#main .detailBox .staffBox .txtBox h3 {
	margin: 0 -1.5rem 2.6rem 0;
	text-align: left;
}
#main .detailBox .staffBox .txtBox h3 img {
	display: block;
	margin-bottom: 3.5rem;
	width: 22.2rem;
}
#main .detailBox .staffBox .txtBox h3 .large {
	padding-left: 1.3rem;
	font-size: 4.4rem;
	letter-spacing: 0.13em;
	text-shadow: 0.1rem 0.1rem 0 #000;
}
#main .detailBox .staffBox .txtBox p {
	margin-left: 1.3rem;
	line-height: 2.5;
	letter-spacing: -0.01em;
	text-align: justify;
}
#main .phoInner {
	margin-bottom: 9.3rem;
	align-items: flex-end;
	position: relative;
}
#main .phoInner .photo {
	margin: 2rem 6.2rem 0 0;
	width: calc(50% + 4.3rem);
	border-radius: 0 1.2rem 1.2rem 0;
}
#main .phoInner .voiceTxt {
	padding: 2rem 4rem 2rem 4.5rem;
	position: absolute;
	z-index: 1;
	top: 14rem;
	left: calc(50% - 14rem);
	line-height: 1.75;
	text-align: justify;
	background-color: #00A23E;
	border: 0.1rem solid #000;
	border-radius: 1.2rem;
}
#main .phoInner .voiceTxt:after {
	position: absolute;
	left: -1.26rem;
	bottom: 4.7rem;
	width: 1.3rem;
	aspect-ratio: 26/44;
	background: url(../img/recruit/voice_bg04.png) no-repeat left top/100%;
	content: "";
}
#main .phoInner .rBox .pho {
	margin: 0 0 4.8rem 13rem;
	width: 29.6rem;
}
#main .phoInner .voiceBox .rBox {
	padding: 2rem 3rem 2rem 4.6rem;
}
#main .phoInner .voiceBox .rBox:after {
	left: auto;
	right: -1.26rem;
	bottom: 2.3rem;
	width: 1.3rem;
	aspect-ratio: 26/44;
	background-image: url(../img/recruit/voice_bg03.png);
}
#main .phoInner .voiceBox .voiceImg {
	width: 10.4rem;
	margin: 8.4rem 0 0 1.7rem;
}
#main .schedule {
	padding: 0 2rem;
}
#main .schedule .content {
	max-width: 120rem;
}
#main .schedule h3 {
	margin: 0 0 1.5rem;
	display: flex;
	align-items: center;
	justify-content: flex-end;
}
#main .schedule h3 .large {
	margin-bottom: -1rem;
	color: #00a23e;
	--start-color: #fff;
	--end-color: #00a23e;
	font-size: 4.6rem;
	line-height: 1.5;
	letter-spacing: 0.03em;
}
#main .schedule h3 .sml {
	position: relative;
	margin: 1.5rem 0 0 11rem;
	font-weight: 700;
	letter-spacing: 0.22em;
}
#main .schedule h3 .sml:before {
	position: absolute;
	left: -9.3rem;
	width: 8rem;
	top: 50%;
	height: 1px;
	background-color: #000;
	content: "";
}
#main .schedule .listBox {
	padding: 5rem 6.5rem 7.8rem 5.2rem;
	background-color: #fff;
	border-radius: 1.2rem;
	border: 1px solid #000;
}
#main .schedule .listBox .phoBox {
	margin-right: -0.2rem;
	width: 37.3rem;
}
#main .schedule .listBox .timeList {
	margin-top: 2.8rem;
	flex: 1;
}
#main .schedule .listBox .timeList li {
	position: relative;
	display: flex;
	align-items: flex-start;
}
#main .schedule .listBox .timeList li:not(:last-child) {
	margin-bottom: 1.5rem;
}
#main .schedule .listBox .timeList li:not(:last-child):before {
	position: absolute;
	left: 3.2rem;
	top: 7.5rem;
	width: 1px;
	height: calc(100% - 7.2rem);
	background-color: #000;
	content: "";
}
#main .schedule .listBox .timeList li:not(:last-child):after {
	position: absolute;
	left: 3.5rem;
	bottom: -0.8rem;
	width: 1px;
	height: 1rem;
	transform: rotate(35deg);
	background-color: #000;
	content: "";
}
#main .schedule .listBox .timeList .time {
	width: 6.8rem;
}
#main .schedule .listBox .timeList .rBox {
	margin: 0.2rem 0 0 2.3rem;
	padding: 2.8rem 4rem;
	flex: 1;
	border: 0.1rem solid #000;
	border-radius: 1rem;
	position: relative;
}
#main .schedule .listBox .timeList .rBox:after {
	position: absolute;
	left: -1.26rem;
	top: 52%;
	width: 1.3rem;
	aspect-ratio: 26/44;
	background: url(../img/recruit/voice_bg02.png) no-repeat left top/100%;
	content: "";
}
#main .schedule .listBox .timeList .rBox.height02:after {
	top: 50%;
	margin-top: -1.1rem;
}
#main .schedule .listBox .timeList .rBox p {
	line-height: 1.75;
	letter-spacing: 0.04em;
	text-align: justify;
}
#main .schedule .listBox .timeList .rBox .ttl {
	margin-bottom: 0.4rem;
	font-size: 2.4rem;
	line-height: 1.17;
	font-weight: 700;
	letter-spacing: 0.08em;
}
#main .schedule .listBox .timeList .rBox .ttl .large {
	margin-right: 1.2rem;
	color: #00A23E;
	font-size: 3rem;
	letter-spacing: 0.03em;
	vertical-align: -0.2rem;
}
@media all and (max-width: 1380px) {
	#main .topVisual .phoBox {
		flex: 1;
	}
	#main .detailBox .bgBox {
		margin-left: 0;
	}
	#main .detailBox .staffBox .txtBox h3 .large {
		font-size: 4rem;
	}
}
@media all and (min-width: 897px) {
	#main #interview2 .detailBox .bgBox .voiceBox {
		bottom: -7.3rem;
	}
	#main #interview2 .detailBox .bgBox .voiceBox .voiceImg {
		margin-top: 2.5rem;
	}
	#main #interview2 .detailBox .bgBox .photo {
		bottom: -25.5rem;
	}
	#main #interview2 .detailBox .staffBox {
		margin-bottom: 3.1rem;
	}
	#main #interview2 .phoInner .voiceTxt {
		top: 12rem;
  		left: calc(50% - 11rem);
	}
	#main #interview2 .phoInner .voiceTxt:after {
		bottom: auto;
		top: 5.5rem;
	}
	#main #interview3 .detailBox .bgBox .voiceBox {
		bottom: -11rem;
	}
	#main #interview3 .detailBox .bgBox .voiceBox .rBox:after {
		bottom: auto;
		top: 6.6rem;
	}
}
@media all and (max-width: 896px) {
	#main .voiceBox .voiceImg {
		width: 12rem;
	}
	#main .voiceBox .rBox {
		padding: 2rem 2.5rem;
		flex: 1;
	}
	#main .voiceBox .rBox p {
		line-height: 1.88;
	}
	#main .voiceBox .rBox:after {
		left: -1.27rem;
		bottom: auto;
		top: 2.2rem;
		width: 1.3rem;
		aspect-ratio: 26/44;
		background-image: url(../img/recruit/voice_bg05.png);
	}
	#main .topVisual {
		padding: 5.2rem 0 0 2.5rem;
		flex-direction: column-reverse;
	}
	#main .topVisual .sideImg {
		display: none;
	}
	#main .topVisual .tagImg {
		position: absolute;
		left: 1.6rem;
		top: 2.6rem;
		z-index: 1;
	}
	#main .topVisual .tagImg img {
		height: 6rem;
	}
	#main .topVisual .phoBox {
		width: 100%;
		height: auto;
		border-radius: 4.6rem 0 0 4.6rem;
	}
	#main .topVisual .txtBox {
		margin: -11.2rem 0 0;
		width: 100%;
	}
	#main .topVisual .txtBox h2 {
		margin: 0 0 1.3rem;
	}
	#main .topVisual .txtBox h2 .large {
		font-size: 4.3rem;
		line-height: 1.28;
		letter-spacing: 0.03em;
	}
	#main .topVisual .txtBox .subTtl {
		margin: 0 0 1.8rem;
		font-size: 1.7rem;
	}
	#main .topVisual .txtBox .subTtl .name {
		font-size: 1.9rem;
	}
	#main .topVisual .txtBox .subTtl .name .large {
		font-size: 2.75rem;
		vertical-align: -0.2rem;
	}
	#main .topVisual .txtBox .infoList {
		max-width: inherit;
		margin: 0 2.5rem 1.1rem 0;
		line-height: 1.56;
	}
	#main .topVisual .txtBox .infoList:before,
	#main .topVisual .txtBox .infoList:after {
		top: 0.3rem;
		height: calc(50% - 0.3rem);
	}
	#main .topVisual .txtBox .infoList:after {
		top: calc(50% - 0.1rem);
	}
	#main .topVisual .txtBox .infoList li:not(:last-child) {
		margin-bottom: 1.1rem;
	}
	#main .topVisual .txtBox .infoList .ttl {
		font-size: 1.8rem;
	}
	#main .topVisual .txtBox .infoList .ttl:after {
		margin-left: 1rem;
	}
	#main .topVisual .txtBox .voiceBox {
		margin-right: 2.5rem;
		position: static;
	}
	#main .topVisual .txtBox .voiceBox .voiceImg {
		margin: 0 1.9rem 2rem -0.8rem;
	}
	#main .topVisual .txtBox .voiceBox .rBox p {
		font-weight: 700;
		letter-spacing: -0.06em;
	}
	#main .detailBox {
		margin-top: -8.5rem;
		padding: 15rem 0 29.6rem;
	}
	#main .detailBox .photo {
		border-radius: 0.6rem;
	}
	#main .detailBox .bgBox {
		margin: 0 0 4rem;
		padding: 4.8rem 2.8rem 4rem;
		border-radius: 2rem;
	}
	#main .detailBox .bgBox .enTtl {
		margin-bottom: 1.2rem;
		position: static;
	}
	#main .detailBox .bgBox .note {
		right: 2.6rem;
		top: -2rem;
		width: 20.4rem;
	}
	#main .detailBox .bgBox h3 {
		margin: 0 -1rem 0.9rem 0;
	}
	#main .detailBox .bgBox h3 .large {
		font-size: 3.7rem;
		line-height: 0.96;
		letter-spacing: 0.02em;
		line-height: 1.09;
	}
	#main .detailBox .bgBox .txt {
		line-height: 1.88;
	}
	#main .detailBox .bgBox .voiceBox {
		margin: 1.6rem 0 2.8rem;
		position: static;
	}
	#main .detailBox .bgBox .voiceBox .voiceImg {
		margin: 5rem 1.4rem 0 0;
		width: 9.4rem;
	}
	#main .detailBox .bgBox .voiceBox .rBox {
		padding: 2.4rem 2.5rem;
	}
	#main .detailBox .bgBox .voiceBox .rBox:after {
		top: auto;
		bottom: 2.1rem;
	}
	#main .detailBox .bgBox .voiceBox .rBox p {
		letter-spacing: 0;
		line-height: 1.56;
	}
	#main .detailBox .bgBox .photo {
		margin: 0 -0.1rem;
		position: static;
		width: auto;
	}
	#main .detailBox .circle {
		width: 25.1rem;
	}
	#main .detailBox .staffBox {
		margin-bottom: 3.5rem;
		display: block;
	}
	#main .detailBox .staffBox .phoBox {
		margin-left: auto;
	}
	#main .detailBox .staffBox .txtBox {
		margin: -6.4rem 0 0;
		position: relative;
		z-index: 1;
	}
	#main .detailBox .staffBox .txtBox h3 {
		margin: 0 0 1.5rem;
	}
	#main .detailBox .staffBox .txtBox h3 img {
		margin-bottom: 1.9rem;
		width: 20.7rem;
	}
	#main .detailBox .staffBox .txtBox h3 .large {
		padding-left: 2.8rem;
		font-size: 3.7rem;
		line-height: 1.08;
		letter-spacing: 0.03em;
		display: block;
	}
	#main .detailBox .staffBox .txtBox p {
		margin: 0 2.5rem 0 2.9rem;
		line-height: 1.88;
		letter-spacing: 0.02em;
	}
	#main .phoInner {
		margin: 0 2.5rem 6.5rem 0;
		display: block;
	}
	#main .phoInner .photo {
		margin: 0 2.8rem 0 0;
		width: auto;
		border-radius: 0 0.6rem 0.6rem 0;
	}
	#main .phoInner .voiceTxt {
		padding: 2.3rem 2.5rem 2rem 2.6rem;
		top: 11rem;
		left: 48.2%;
		right: 0;
		line-height: 1.56;
		z-index: 1;
	}
	#main .phoInner .voiceTxt:after {
		bottom: auto;
		top: 2.5rem;
	}
	#main .phoInner > .rBox {
		margin: 1.4rem 0 0 2.5rem;
	}
	#main .phoInner .rBox .pho {
		margin: 0 0 3.5rem;
		width: 20.7rem;
	}
	#main .phoInner .voiceBox .rBox {
		padding: 2.3rem 3rem 2.3rem 2.5rem;
	}
	#main .phoInner .voiceBox .rBox:after {
		top: auto;
	}
	#main .phoInner .voiceBox .rBox p {
		line-height: 1.56;
	}
	#main .phoInner .voiceBox .voiceImg {
		width: 9.3rem;
		margin: 3rem 0.1rem 0 1rem;
	}
	#main .schedule {
		padding: 0;
	}
	#main .schedule .content {
		padding: 3.7rem 2.7rem 14.3rem;
		position: relative;
		background-color: #fff;
		border-radius: 2rem;
		border: 1px solid #000;
	}
	#main .schedule h3 {
		margin: 0 0 1.5rem;
		display: block;
	}
	#main .schedule h3 .large {
		margin: 0 -0.5rem 0.1rem 0;
		font-size: 2.9rem;
		display: block;
	}
	#main .schedule h3 .sml {
		margin: 1.5rem 0 0;
	}
	#main .schedule h3 .sml:before {
		display: none;
	}
	#main .schedule .listBox {
		padding: 0;
		background: none;
		border-radius: 0;
		border: none;
		display: block;
	}
	#main .schedule .listBox .phoBox {
		margin-right: 0;
		width: 21.4rem;
		position: absolute;
		left: -1.3rem;
		bottom: -27.2rem;
	}
	#main .schedule .listBox .phoBox02 {
		bottom: -31rem;
	}
	#main .schedule .listBox .timeList {
		margin-top: 0;
	}
	#main .schedule .listBox .timeList li:not(:last-child) {
		margin-bottom: 3.2rem;
	}
	#main .schedule .listBox .timeList li:not(:last-child):before {
		left: 2.9rem;
		height: calc(100% - 6rem);
	}
	#main .schedule .listBox .timeList li:not(:last-child):after {
		left: 3.2rem;
		bottom: -2.1rem;
		height: 0.8rem;
	}
	#main .schedule .listBox .timeList .time {
		margin: 0.1rem 0 0 0.1rem;
		width: 6.1rem;
	}
	#main .schedule .listBox .timeList .rBox {
		margin: 0 0 0 1.6rem;
		padding: 1.1rem 2.5rem 2rem;
		border-radius: 1rem;
	}
	#main .schedule .listBox .timeList .rBox:not(.height02):after {
		top: 6.5rem;
	}
	#main .schedule .listBox .timeList .rBox p {
		line-height: 1.56;
		letter-spacing: 0.03em;
	}
	#main .schedule .listBox .timeList .rBox .ttl {
		margin-bottom: 0.2rem;
		font-size: 1.9rem;
	}
	#main .schedule .listBox .timeList .rBox .ttl02 {
		margin-right: -1rem;
		letter-spacing: -0.1em;
	}
	#main .schedule .listBox .timeList .rBox .ttl .large {
		display: block;
		margin: 0 0 0.1rem;
		font-size: 2.4rem;
	}
	#main #interview2 .detailBox {
		padding-bottom: 35rem;
	}
	#main #interview2 .phoInner .voiceTxt {
		top: 16.5rem;
	}
	#main #interview3 .topVisual .txtBox .voiceBox .voiceImg {
		margin-bottom: 5rem;
	}
	#main #interview3 .detailBox {
		margin-top: -11.5rem;
		padding-top: 18rem;
	}
	#main #interview3 .phoInner .voiceTxt {
		top: 16.5rem;
	}
	#main #interview4 .detailBox .bgBox .voiceBox .rBox {
		padding: 2.4rem 2.2rem;
	}
	#main #interview4 .phoInner .voiceTxt {
		top: 13rem;
	}
	#main #interview4 .schedule .content {
		padding-bottom: 11rem;
	}
}