@charset "UTF-8";

/*スタッフアーカイブ
------------------------------------*/

.staff .content_visual {
	background-image:url("../images/staff/bg_archive_staff.png");
}
.staff_list {
	position: relative;
}
.staff_list .title_line {
	position:absolute;
	top:30px;
	left: 0;
	width:calc(50% - 300px);
	height:43px;
	background: #2DAB53;
}
.staff_list .bg_title {
	position:absolute;
	top:30px;
	right:0;
	left:0;
	width:1200px;
	margin: 0 auto;
}
.staff_list .bg_title .title_wrap {
	position:relative;
	display: inline-block;
	background: #5CC97C;
background: linear-gradient(270deg,rgba(92, 201, 124, 1) 0%, rgba(45, 171, 83, 1) 100%);
	width:600px;
	border-radius: 0 20px 20px 0;
	padding-left: 20px;
}
.staff_list .content_wrap {
	display:flex;
}
.staff_list .bg_title .title_wrap p {
	color:#fff;
	font-size:24px;
	line-height: 43px;
	letter-spacing: 0.05em;
	width:100%;
	padding:0 0% 0 0;
	
}
.staff_list > .content_wrap {
	padding: 50px 0;
	background:#fff;
	margin-right: 20px;
	border-radius: 0 20px 20px 0;
	box-shadow: 0 3px 6px rgb(0,0,0,0.16);
}
.staff_list > .list_wrap .content_wrap {
	width: 100%;
	max-width: 1240px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	padding: 80px 20px 0;
}
.staff_list .content_wrap > div {
	width: 50%;
	margin-bottom:50px;
}
.staff_list .list_wrap .staff_wrap{
	display: flex;
	align-items:center;
}
.staff_list .staff_wrap .img_face {
	cursor: pointer;
	height: 307px;
	margin-inline: auto;
	position: relative;
	 width: 274px;
}
.staff_list .content_wrap .img_face img {
	height: auto;
	left: 0;
	position: absolute;
	width: 100%;
	border-radius: 20px;
}
.staff_list .content_wrap .img_face img:last-of-type {
	opacity: 0;
	transition: opacity .7s;
	pointer-events: none;
	position: absolute;
	z-index: 2;
}
.staff_list .content_wrap .img_face:hover img:last-of-type {
	opacity: 1;
	pointer-events: auto;
}
.staff_list .content_wrap .img_face:hover img {
	opacity: 1;
}
.staff_list .right_col {
	padding-left: 30px;
}
.staff_list .right_col .division {
	font-size: 12px;
	position:relative;
}
.staff_list .right_col .division::before {
	position:absolute;
	content: "";
	bottom: -10px;
	left:-50px;
	width: 220px;
	height: 2px;
	background: #5CC97C;
}
.staff_list .right_col .name {
	margin-top: 20px;
	letter-spacing: 0.1em;
	font-weight: 600;
}
.staff_list .right_col .btn_more {
	margin-top:50px;
	margin-left: 20px;
	position: relative;
	transition: 0.5s;
}
.staff_list .right_col .btn_more a {
	color:#179243;
}
.staff_list .right_col .btn_more::before {
	position: absolute;
    top: 0px;
    left: 102px;
    content: "";
    width: 25px;
    height: 25px;
    border: 1px solid #179243;
    border-radius: 50%;
    background: transparent;
    transition: 0.5s;
}
.staff_list .right_col .btn_more:hover::before {
	background:#179243;
}
.staff_list .right_col .btn_more::after {
	position: absolute;
    top: 10px;
    left: 110px;
    content: "";
    width: 6px;
    height: 6px;
    border-top: 2px solid #179243;
    border-right: 2px solid #179243;
    transform: rotate(45deg);
    transition: 0.5s;
}
.staff_list .right_col .btn_more:hover::after {
	border-top: 2px solid #fff;
    border-right: 2px solid #fff;
}
.staff_list .right_col .btn_more::before,
.staff_list .right_col .btn_more::after {
	pointer-events: none;
}

@media screen and (max-width: 1200px) {
	.content_wrap {
		overflow:hidden;
	}
	.staff_list .bg_title{
		width: 100%;
		max-width:1200px;
	}
	.staff_list .right_col {
		padding-left: 2rem;
	}
}
@media screen and (max-width: 1024px) {
	.staff_list .right_col {
		padding-left: 2rem;
	}
	.staff_list > .list_wrap .staff_wrap {
		padding-top: 3rem;
	}
}
@media screen and (max-width: 960px) {
	.staff_list .list_wrap .bg_wrap .staff_wrap{
		flex-flow:column;
		justify-content:flex-start;
	}
	.staff_list .right_col {
		padding-left:0;
		padding-top:1rem;
	}
	.staff_list .right_col .btn_more {
		margin: 20px 0 0;
	}
	.staff_list .staff_wrap .img_face {
		height: 274px;
	}
	.staff_list .right_col .division {
		height: auto;
	}
	.staff_list .right_col .division::before {
		width: 274px;
		left:50%;
		transform:translatex(-50%);
	}
}
@media screen and (max-width: 640px) {
	.staff_list > .list_wrap .content_wrap {
		flex-flow:column;
		align-items: center;
	}
	.staff_list .bg_title .title_wrap {
		width:99%;
	}
}
@media screen and (max-width: 560px) {
	.staff_list .bg_title .title_wrap p {
		font-size: 20px;
	}
	
}
@media screen and (max-width: 428px) {
	
}
@media screen and (max-width: 375px) {
	
}