@charset "UTF-8";
/*-----------------------------------

	mainvisual

-----------------------------------*/
#mainvisual {
	position: relative;
	width: 95%;
	margin: 75px auto 85px;
	border-radius: 30px;
	overflow: hidden;
}
#mainvisual .swiper .swiper-wrapper .swiper-slide {
	position: relative;
	z-index: 0;	
}
#mainvisual .swiper .swiper-wrapper .swiper-slide::before {
	content: "";
	width: 100%;
	height: 100%;
	background: rgba(29,109,90,0.25);
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}
#mainvisual .swiper .swiper-wrapper .swiper-slide img {
	width: 100%;
	/*height: 820px;*/
	object-fit: cover;
}
#mainvisual .swiper .swiper-wrapper .swiper-slide a.more {
	width: max-content;
	background: var(--mClr1) url(../img/common/icon_arrow_bwag.svg) no-repeat calc(100% - 7px) center/38px;
	color: #FFF;
	border-radius: calc(1px/0);
	font: 700 1.5rem/1 var(--fJa);
	letter-spacing: 0.03em;
	text-box: trim-both cap alphabetic;
	padding: 20px 75px 20px 45px;
	position: absolute;
	bottom: 20px;
	right: 20px;
	z-index: 5;
}
.swiper-pagination {
	width: auto !important;
    left: 50% !important;
    top: auto !important;
    bottom: 20px !important;
    transform: translateX(-50%) !important;
	display:flex;
}
.swiper-pagination-bullet {
	width: 35px !important;
    height: 3px !important;
    margin: 0 3px !important;
    background: #FFFFFF !important;
    border-radius: calc(1px/0) !important;
	opacity: 1 !important;
}
.swiper-pagination-bullet-active {
	background: #82FFD2 !important;
}
#mainvisual .mv_text {
	position: absolute;
	bottom: 50%;
	left: 8%;
	color: #FFF;
	z-index: 99;
	filter: drop-shadow(0px 0px 10px rgba(0,0,0,0.6));
}
#mainvisual .mv_text h1 {
	font: 700 5.8rem/1 var(--fJa);
}
#mainvisual .mv_text h1::after {
	content: "Recruit Information";
	font: 700 2.2rem/1 var(--fEn);
	text-transform: uppercase;
	display: block;
	margin-top: 20px;
}
@media screen and (max-width: 640px) {
	#mainvisual {
		width: 100%;
		border-radius: 0;
		margin: 0 auto 40px;
	}
	#mainvisual .swiper .swiper-wrapper .swiper-slide img {
		height: 670px !important;
	}
	#mainvisual .swiper .swiper-wrapper .swiper-slide a.more {
		font-size: 1.4rem;
		padding: 20px 60px 20px 30px;
		bottom: 40px;
	}
	#mainvisual .mv_text {
		left: 5%;
	}
	#mainvisual .mv_text h1 {
		font-size: 3.6rem;
	}
	#mainvisual .mv_text h1::after {
		font-size: 1.4rem;
		margin-top: 10px;
	}
}
/*-----------------------------------

	common

-----------------------------------*/
#contents h2 {
	font: 700 4.2rem/1.2 var(--fJa);
	letter-spacing: 0.03em;
	margin-bottom: 40px;
}
#contents h2::first-letter {
	color: var(--mClr1);
}
#contents h2::before {
	display: block;
	padding-left: 28px;
	margin-bottom: 20px;
	background: url(../img/common/h2_img.svg) no-repeat left center / 22px;
	font: 700 2.2rem/1.2 var(--fEn);
}
#contents a.link {
	padding: 20px 75px 20px 45px;
	border-radius: calc(1px/0);
	font: 700 1.5rem/1 var(--fJa);
	color: #FFF;
	width: max-content;
	text-box: trim-both cap alphabetic;
	background: #292929 url(../img/common/icon_arrow_bwag.svg) no-repeat calc(100% - 7px) center/38px;
}
#contents .cont {
	margin-bottom: 200px;
	position: relative;
}
#contents .cont::before {
	width: max-content;
	display: block;
	font: 700 14rem/1 var(--fEn);
	color: #EDF7F5;
	text-box: trim-both cap alphabetic;
	position: absolute;
	top: -70px;
}
#contents .cont.iLtR::before {
	left: 64.8%;
}
#contents .cont.iRtL::before {
	left: 2%;
}
#contents .cont .contents_inner {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	position: relative;
}
#contents .cont.iLtR .contents_inner {
	flex-direction: row-reverse;
}
#contents .cont .text {
	width: calc(52.5% + (50vw - 50%));
	background: #FFF;
	align-self: flex-end;
	position: relative;
	z-index: 5;
}
#contents .cont.iLtR .text {
	border-radius: 20px 0 0 20px;
	padding: 50px calc(50vw - 50%) 50px 60px;
	margin: 0 calc(50% - 50vw) -30px -14.17%;
}
#contents .cont.iRtL .text {
	border-radius: 0 20px 20px 0;
	padding: 50px 60px 50px calc(50vw - 50%);
	margin: 0 -14.17% -30px calc(50% - 50vw);
}
#contents .cont .text p {
	line-height: 2.85;
	white-space: pre-line;
}
#contents .cont .text a.link {
	margin-top: 40px;
}
#contents .cont .image {
	width: calc(61.67% + (50vw - 50%));
	overflow: hidden;
	align-self: flex-start;
	position: relative;
	z-index: 1;
}
#contents .cont.iLtR .image {
	border-radius: 0 20px 20px 0;
	margin: 0 auto 0 calc(50% - 50vw);
}
#contents .cont.iRtL .image {
	border-radius: 20px 0 0 20px;
	margin: 0 calc(50% - 50vw) 0 auto;
}
@media screen and (max-width: 1200px) {
	#contents .cont .text {
		width: calc(64.5% + (50vw - 50%));
	}
	#contents .cont.iLtR .text {
		margin: 0 calc(50% - 50vw) -30px -40%;
	}
	#contents .cont.iRtL .text {
		margin: 0 -40% -30px calc(50% - 50vw);
	}
	#contents .cont .image {
		width: calc(87.5% + (50vw - 50%));
	}
}
@media screen and (max-width: 840px) {
	#contents .cont::before {
		font-size: 11rem;
		top: auto;
		bottom: -80px;
		left: 0 !important;
	}
	#contents .cont .contents_inner {
		flex-direction: column;
	}
	#contents .cont.iLtR .contents_inner {
		flex-direction: column;
	}
	#contents .cont .text {
		width: calc(100% + (50vw - 50%));
		align-self: normal;
		order:2;
	}
	#contents .cont.iLtR .text {
		padding: 50px calc(50vw - 50%) 0 60px;
		margin: -50px calc(50% - 50vw) 0 auto;
	}
	#contents .cont.iRtL .text {
		padding: 50px 60px 0 calc(50vw - 50%);
		margin: -50px auto 0 calc(50% - 50vw);
	}
	#contents .cont .image {
		width: calc(100% + (50vw - 50%));
		align-self: normal;
		order:1;
	}
}
@media screen and (max-width: 640px) {
	#contents h2 {
		font-size: 3.2rem;
		letter-spacing: 0;
		margin-bottom: 25px;
	}
	#contents h2::before {
		padding-left: 24px;
		margin-bottom: 15px;
		background: url(../img/common/h2_img.svg) no-repeat left 2px/19px;
		font-size: 1.6rem;
	}
	#contents a.link {
		padding: 20px 60px 20px 30px;
		font-size: 1.4rem;
	}
	#contents .cont {
		margin-bottom: 100px;
	}
	#contents .cont::before {
		font-size: 5.6rem;
		bottom: -50px;
	}
	#contents .cont .text {
		border-radius: 10px 0 0 10px;
	}
	#contents .cont.iLtR .text {
		padding: 30px calc(50vw - 50%) 0 20px;
		margin: -30px calc(50% - 50vw) 0 auto;
	}
	#contents .cont.iRtL .text {
		padding: 30px 20px 0 calc(50vw - 50%);
		margin: -30px auto 0 calc(50% - 50vw);
	}
	#contents .cont .text p {
		line-height: 2.14;
	}
	#contents .cont .text a.link {
		margin-top: 20px;
	}
	#contents .cont.iLtR .image {
		border-radius: 0 10px 10px 0;
	}
	#contents .cont.iRtL .image {
		border-radius: 10px 0 0 10px;
	}
}
/*-----------------------------------

	news_block

-----------------------------------*/
#news_block {
	margin: 0 auto 160px;
}
#news_block .news_ttl {
	display: flex;
	align-items: center;
	justify-content: space-between;
}
#news_block .news_ttl h2::before {
	content: "News";
}
#news_block .news_ttl a.more {
	font: 700 1.5rem/28px var(--fJa);
	padding-right: 40px;
	background: url(../img/index/icon_arrow_newsmore.svg) no-repeat right center/28px;
}
#news_block .news_list {
	border-top: 1px solid #E6ECF2;
}
#news_block .news_list article {
	border-bottom: 1px solid #E6ECF2;
	padding: 30px;
}
#news_block .news_list article a {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 5px 25px;
	letter-spacing: -0.01em;
}
#news_block .news_list article a time {
	font: 500 1.2rem/1 var(--fEn);
	color: #979797;
}
#news_block .news_list article a p {
	line-height: 1.42;
}
#news_block .news_list article a .pdf {
	display: inline-block;
	width: 12px;
	height: 15px;
	background: url(../img/index/icon_pdf.svg) no-repeat center/contain;
	margin-left: 10px;
	vertical-align: middle;
}
@media screen and (max-width: 840px) {
	#news_block .news_list article a p {
		width: 100%;
	}
}
@media screen and (max-width: 640px) {
	#news_block {
		margin: 0 auto 80px;
	}
	#news_block .news_list article {
		padding: 20px 0;
	}
	#news_block .news_list article a {
		gap: 5px 15px;
	}
}
/*-----------------------------------

	manga_block

-----------------------------------*/
#manga_block::before {
	content: "Manga";
}
#manga_block h2::before {
	content: "Manga";
}
/*-----------------------------------

	about_block

-----------------------------------*/
#about_block::before {
	content: "About Sankosha";
}
#about_block h2::before {
	content: "About us";
}
/*-----------------------------------

	introduction_block

-----------------------------------*/
#introduction_block {
	margin-bottom: 100px !important;
}
#introduction_block::before {
	content: "Job introduction";
}
#introduction_block h2::before {
	content: "Job introduction";
}
@media screen and (max-width: 840px) {
	#introduction_block {
		margin-bottom: 200px !important;
	}
}
@media screen and (max-width: 640px) {
	#introduction_block {
		margin-bottom: 100px !important;
	}
}
/*-----------------------------------

	interview_block

-----------------------------------*/
#interview_block {
	margin-bottom: 200px;
}
#interview_block .ttlArea {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 70px;
}
#interview_block .ttlArea h2 {
	margin-bottom: 0 !important;
}
#interview_block .ttlArea h2::before {
	content: "Interview";
}
#interview_block .ttlArea p {
	width: 45%;
	white-space: pre-line;
	line-height: 2.14;
}
#interview_block .swiper {
	width: 100vw;
	margin: 0 calc(50% - 50vw);
}
#interview_block .swiper .swiper-slide {
	width: 320px;
}
#interview_block .swiper .swiper-slide a {
	position: relative;
	border-radius: 10px;
	overflow: hidden;
}
#interview_block .swiper .swiper-slide a::before {
	content: "Interview";
	font: 700 2rem/1 var(--fJa);
	letter-spacing: 0.05em;
	text-transform: uppercase;
	color: #FFF;
	writing-mode: vertical-rl;
	position: absolute;
	top: 15px;
	right: 15px;
	z-index: 5;
}
#interview_block .swiper .swiper-slide a::after {
	content: "";
	width: 100%;
	height: 45%;
	background: linear-gradient(0deg,rgba(0, 0, 0, 0.55) 0%, rgba(0, 0, 0, 0) 100%);
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 5;
}
#interview_block .swiper .swiper-slide a:hover {
	opacity: 1;
}
#interview_block .swiper .swiper-slide a img {
	transition: 0.3s;
}
#interview_block .swiper .swiper-slide a:hover img {
	transform: scale(1.2);
}
#interview_block .swiper .swiper-slide a .txt {
	color: #FFF;
	position: absolute;
	bottom: 15px;
	left: 15px;
	z-index: 10;
	filter: drop-shadow(0px 0px 4px #000000);
}
#interview_block .swiper .swiper-slide a .txt .post {
	display: block;
	font: 700 1.8rem/1 var(--fJa);
	line-height: 160%;
	margin-bottom: 10px;
}
#interview_block .swiper .swiper-slide a .txt .name {
	display: block;
	font: 700 3rem/1 var(--fJa);
}
@media screen and (max-width: 840px) {
	#interview_block {
		margin-bottom: 150px;
	}
	#interview_block .ttlArea {
		flex-wrap: wrap;
		gap: 20px;
	}
	#interview_block .ttlArea p {
		width: 100%;
	}
}
@media screen and (max-width: 640px) {
	#interview_block {
		margin-bottom: 80px;
	}
	#interview_block .ttlArea {
		margin-bottom: 30px;
		gap: 10px;
	}
	#interview_block .swiper .swiper-slide {
		width: 280px;
	}
	#interview_block .swiper .swiper-slide a {
		border-radius: 6px;
	}
	#interview_block .swiper .swiper-slide a::before {
		font: 700 1.8rem/1 var(--fJa);
	}
	#interview_block .swiper .swiper-slide a .txt .post {
		font-size: 1.5rem;
	}
	#interview_block .swiper .swiper-slide a .txt .name {
		font-size: 2.6rem;
	}
}
/*-----------------------------------

	benefits_block

-----------------------------------*/
#benefits_block::before {
	content: "Hr development";
}
#benefits_block h2::before {
	content: "Human Resources Development\A Employee Benefits";
	white-space: pre;
}