@charset "UTF-8";

@media screen and (min-width: 769px){
	#header{
		position: sticky;
	}
}

.key-visual .bg{
	position: absolute;
	left: 0;
	top: 0;
	width: 0;
	height: 100%;
	/*background-image: url(../images/people-detail-key-visual.jpg);*/
	background-size: cover;
	background-position: left top;
	transition: .8s all ease;
	transform-origin: left top;
}
.key-visual .bg.is-active{
	width: 100%;
}
.key-visual .bg.is-active{
	width: 100%;
}
.key-visual .catch-copy{
	font-size: 2.8rem;
	font-weight: 600;
	line-height: 1.7857;
	color: #000;
}
.key-visual .catch-copy.text-white,
.key-visual .catch-copy.text-white *{
	color: #fff !important;
}
.key-visual .catch-copy span{
	display: block;
	width: fit-content;
	clip-path: inset(0 100% 0 0);
	background: none !important;
	font-weight: 600;
	transition: .8s all ease;
	transition-delay: 1.2s;
}
.key-visual .catch-copy.is-active span{
	clip-path: inset(0 0 0 0);
}
.key-visual .profile{
	width: 44rem;
	height: 10rem;
	background: url(../images/people-detail-bg.jpg) no-repeat;
	background-position: center center;
	background-size: cover;
	position: absolute;
	left: 0;
	bottom: -5rem;
	padding-inline: 3.6rem;
	font-size: 1.5rem;
	flex-direction: row-reverse;
	justify-content: space-between;
	align-items: center;
	transition: .8s all ease;
	transition-delay: 1.2s;
	clip-path: inset(0 100% 0 0);
}

.key-visual .profile.is-active{
	clip-path: inset(0 0 0 0);
}
.profile dt{
	font-size: 4rem;
}
.profile dd{
	align-items: center;
	font-weight: 400;
}
.profile dd .flex{
	align-items: center;
}
.profile dd .flex:after{
	content: "";
	display: block;
	width: 0;
	height: 3.2rem;
	border-left: 1px solid #fff;
	margin-inline: 2rem 1.2rem;
}
/* +++#interview+++ */
#interview{
	padding-top: 11.5rem;
	padding-bottom: 9rem;
}
.interview-box{
	max-width: 65rem;
	padding-block: 5.5rem 4rem;
}
.interview-box:not(:last-of-type){
	border-bottom: 1px solid rgba(255,255,255,.5);
}
.interview-head{
	align-items: center;
	margin-bottom: 3.6rem;
}
.q-number{
	color: #00763f;
	font-size: 9.5rem;
	line-height: 1;
	width: 11rem;
	padding-right: 2rem;
	text-align: center;
}
.q-number:before{
	content: attr(data-en);
	display: block;
	font-family: "M PLUS 2", YuGothic, 游ゴシック, メイリオ, Meiryo, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", sans-serif;
	font-size: 1.5rem;
	margin-bottom: 1rem;
	font-weight: 700;
	text-align: center;
}
.interview-head h2{
	font-size: 3.6rem;
	font-weight: 600;
	padding-top: 1.5rem;
	width: calc(100% - 11rem);
	line-height: 1.25;
}
.interview-body{
	font-weight: 400;
	font-size: 1.8rem;
	line-height: 2;
}

/* +++.pic-area+++ */
.pic-area{
	width: 100%;
	margin-block: 7rem 5rem;
}
.pic-area .pic{
	position: relative;
	width: 50%;
	aspect-ratio: 1 / 1;
	overflow: hidden;
}
.pic-area .pic:after{
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	background: url(../images/people-detail-mask01.jpg) no-repeat;
	background-size: cover;
	background-position: top right;
}
.pic-area .pic:nth-of-type(1):after{
	top: 0;
	transition: .8s all ease;
	transition-delay: 1.1s;
}
.pic-area .pic:nth-of-type(2):after{
	bottom: 0;
	transition: .8s all ease;
	transition-delay: 1.1s;
}
.pic-area .pic.is-active:nth-of-type(1):after,
.pic-area .pic.is-active:nth-of-type(2):after{
	height: 0;
}

/* +++#schedule+++ */
#schedule{
	background: url(../images/people-detail-bg01.jpg) no-repeat;
	background-position: center top;
	background-size: cover;
	padding-bottom: 10rem;
}
#schedule:before{
	content: "";
	display: block;
	width: 100%;
	height: 10rem;
	background: #000;
	position: absolute;
	left: 0;
	top: 0;
	position: absolute;
	z-index: 1;
}
#schedule .inner{
	z-index: 2;
	max-width: 106.6rem;
	justify-content: space-between;
}
.schedule-pic .pic{
	aspect-ratio: 450 / 650;
	overflow: hidden;
}
.schedule-pic .pic img{
	object-fit: cover;
}
.schedule-pic{
	position: sticky;
	left: 0;
	top: 15rem;
	width: 42.2138%;
}
.schedule-pic .pic02{
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	transition: .4s all ease;
}
.schedule-pic.is-active .pic02{
	opacity: 1;
}
#schedule .text{
	width: 49.2495%;
	padding-top: 6rem;
}
#schedule h2{
	color: #00763f;	
	font-size: 2.1rem;
	font-weight: 900;
	margin-bottom: 7rem;
}
#schedule h2:before{
	font-family: "Anton", sans-serif;
	font-weight: 400;
	content: attr(data-en);
	display: block;
	line-height: 1;
	margin-bottom: 1.8rem;
	font-size: 7.5rem;
}
#schedule ol{
	color: #000;
	position: relative;
}
#schedule ol:before{
	content: "";
	display: block;
	position: absolute;
	left: 5.8rem;
	top: .8rem;
	bottom: .8rem;
	margin: auto;
	width: 1px;
	background: #000;
}
#schedule li{
	position: relative;
	display: flex;
	align-items: center;
	font-weight: 400;
}
#schedule li .label{
	width: 5.8rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-size: 2rem;
	line-height: 1;
	margin-right: 1.6rem;
}
#schedule li .label:after{
	content: "";
	display: block;
	width: .7rem;
	height: .7rem;
	border-radius: 50%;
	background: #000;
	transform: translateX(.35rem);
}
/*
#schedule li:nth-of-type(1){
	margin-bottom: 2.4rem;
}
#schedule li:nth-of-type(2){
	margin-bottom: 4rem;
}
#schedule li:nth-of-type(3){
	margin-bottom: 10.9rem;
}
#schedule li:nth-of-type(4),
#schedule li:nth-of-type(7){
	margin-bottom: 4.8rem;
}
#schedule li:nth-of-type(5),
#schedule li:nth-of-type(6){
	margin-bottom: 10.6rem;
}
*/

#schedule li:not(:last-of-type){
	margin-bottom: 4rem;
}
.holiday-box{
	padding: 4rem 4.8rem;
	position: relative;
	background: rgba(255,255,255,.6);
	color: #000;
	margin: 15rem auto 0;
	font-weight: 400;
}
.holiday-text{
/*
	width: 60rem;
*/
	width: 61.855%;
}
.holiday-box.picture-none .holiday-text{
	width: 100%;
}
.holiday-text p{
	font-size: 1.5rem;
	word-break: break-all;
	line-height: 2;
}
.holiday-text h3{
	font-size: 2.1rem;
	font-weight: 900;
	margin-bottom: 2.4rem;
}
.holiday-box .pic{
/*
	width: 31rem;
*/
	width: 31.958%;
	position: absolute;
	right: 4.8rem;
	bottom: 4rem;
	aspect-ratio: 310 / 190;
	min-height: 100%;
	overflow: hidden;
}
.holiday-box .pic img{
	object-fit: cover;
}

/* +++#sec01+++ */
#sec01{
	padding-top: 9rem;
}
#sec01 h2{
	font-weight: 900;
	text-align: center;
	font-size: 2.1rem;
	margin-bottom: 8rem;
}
#sec01 h2:before{
	content: attr(data-en);
	display: block;
	font-family: "Anton", sans-serif;
	font-weight: 400;
	font-size: 5rem;
	line-height: 1;
	margin-bottom: 2rem;
}
.people-list{
	justify-content: space-between;
	align-items: stretch;
}
.people-list .people{
	padding-inline: 1.830vw;
}
.people-list .pic{
	overflow: hidden;
	aspect-ratio: 270 / 335;
}
.people-list .pic img{
	transition: .3s all ease;
	object-fit: cover;
}
.people-list a:hover .pic img{
	transform: scale(1.05);
}
.message{
	margin: 2.5rem 0 2rem;
	font-size: 2.1rem;
	font-weight: 600;
	line-height: 1.7142;
}
.people-list a{
	border-bottom: 5px solid #00763f;
	padding-bottom: 2rem;
	display: block;
}
.people-list dl{
	flex-direction: row-reverse;
	justify-content: space-between;
	align-items: flex-end;
	font-size: 1.4rem;
	font-weight: 500;
}
.people-list dt{
	font-size: 4rem;
}

.button-area{
	padding-right: 8.5rem;
	justify-content: space-between;
	align-items: center;
	margin: 9rem auto 0;
	max-width: 106.6rem;
}
.slick-arrow{
	width: 4rem;
	height: 4rem;
	background-repeat: no-repeat;
	background-position: center;
	background-size: 2rem auto;
	border: 1px solid #00763f;
	background-color: #00763f;
	cursor: pointer;
	margin-right: 2rem;
}
.prev-arrow{
	background-image: url(../images/prev-arrow-b.svg);
}
:hover.prev-arrow{
	background-image: url(../images/prev-arrow-g.svg);
	background-color: transparent;
}
.next-arrow{
	background-image: url(../images/next-arrow-b.svg);
}
:hover.next-arrow{
	background-image: url(../images/next-arrow-g.svg);
	background-color: transparent;
}
.back-button{
	font-size: 2rem;
	display: flex;
	align-items: center;
}
.back-button:before{
	content: "";
	display: block;
	width: 2.5rem;
	height: 2.5rem;
	background: url(../images/people-detail-icon01.svg) no-repeat;
	background-position: center;
	background-size: 100% auto;
	margin-right: 1.8rem;
}
#contact-area{
	padding-top: 5rem;
}


.is-few.slick-track{
	margin-left: 0;
}


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

	.key-visual .bg{
		background-image: url(../images/sp-people-detail-key-visual.jpg);
	}

	.key-visual .catch-copy{
		font-size: 3.6rem;
		line-height: 1.666666;
		margin-top: 28.6rem;
	}

	.key-visual .profile{
		width: 100%;
		height: 14rem;
		left: 0;
		right: 0;
		margin-inline: auto;
		bottom: -9.6rem;
		padding-inline: 3.2rem;
		font-size: 2.25rem;
	}

	.profile dt{
		font-size: 7rem;
	}
	.profile dd .flex:after{
		content: "";
		display: block;
		width: 0;
		height: 4.2rem;
		margin-inline: 3.2rem 2rem;
	}
/* +++#interview+++ */
	#interview{
		padding-top: 14.3rem;
		padding-bottom: 9.5rem;
	}
	.interview-box{
		max-width: 100%;
		padding-block: 10rem 7.5rem;
	}

	.interview-head{
		margin-bottom: 9rem;
	}
	.q-number{
		font-size: 13.8rem;
		width: 19.5rem;
		padding-right: 5.5rem;
		text-align: center;
	}
	.q-number:before{
		font-size: 2.2rem;
		margin-bottom: 2.4rem;
	}
	.interview-head h2{
		font-size: 5rem;
		padding-top: 3rem;
		width: calc(100% - 19.5rem);
	}
	.interview-body{
		font-size: 3rem;
	}

/* +++.pic-area+++ */
	.pic-area{
		display: block;
		margin-block: 18rem 4.5rem;
	}
	.pic-area .pic{
		width: 100%;
	}
	.pic-area .pic:nth-of-type(1):after{
		top: auto;
		bottom: 0;
		transition-delay: 0;
	}

/* +++#schedule+++ */
	#schedule .inner{
		display: block;
		z-index: 2;
		max-width: 100%;
	}
	.schedule-pic{
		position: relative;
		left: auto;
		top: auto;
		width: 100%;
	}
	#schedule:before{
		height: 5.3rem;
	}

	#schedule .text{
		width: 100%;
		padding-top: 0;
	}
	#schedule h2{	
		font-size: 3.6rem;
		margin-bottom: 11.4rem;
		text-align: center;
	}
	#schedule h2:before{
		margin-bottom: 3rem;
		font-size: 10.5rem;
	}
	#schedule ol{
		margin-top: 10.7rem;
		font-size: 3rem;
	}
	#schedule ol:before{
		left: 9.8rem;
		top: .8rem;
		bottom: .8rem;
	}

	#schedule li .label{
		width: 9.8rem;
		justify-content: flex-end;
		font-size: 3.2rem;
		line-height: 1;
		margin-right: 0;
		position: relative;
		padding-right: 2.4rem;
		margin-right: 2.7rem;
	}
	#schedule li .label:after{
		width: 2rem;
		height: 2rem;
		transform: translateX(0);
		position: absolute;
		right: -1rem;
		top: 0;
		bottom: 0;
		margin: auto;
	}
/*
	#schedule li:nth-of-type(1){
		margin-bottom: 4rem;
	}
	#schedule li:nth-of-type(2){
		margin-bottom: 9rem;
	}
	#schedule li:nth-of-type(3){
		margin-bottom: 21rem;
	}
	#schedule li:nth-of-type(4),
	#schedule li:nth-of-type(7){
		margin-bottom: 9.6rem;
	}
	#schedule li:nth-of-type(5),
	#schedule li:nth-of-type(6){
		margin-bottom: 21rem;
	}
*/
	#schedule li:not(:last-of-type){
		margin-bottom: 4.5rem;
	}
	.holiday-box{
		padding: 5.4rem 4.8rem;
		color: #000;
	}
	.holiday-text{
		width: 100%;
	}
	.holiday-text p{
		font-size: 3rem;
		line-height: 1.733333;
	}
	.holiday-text h3{
		font-size: 3.6rem;
		margin-bottom: 4.8rem;
	}
	.holiday-box .pic{
		width: 31rem;
		position: relative;
		right: auto;
		bottom: auto;
		margin-top: 4rem;
		width: 100%;
		min-height: auto;
	}

/* +++#sec01+++ */
	#sec01{
		padding-top: 15.3rem;
	}
	#sec01 h2{
		font-size: 3.6rem;
		margin-bottom: 15rem;
	}
	#sec01 h2:before{
		font-size: 7.5rem;
		margin-bottom: 3rem;
	}

	.people-list .people{
		padding-inline: 4rem;
	}

	.message{
		margin: 4.6rem 0 4rem;
		font-size: 3.6rem;
		line-height: 1.666666;
	}
	.people-list a{
		border-bottom: .8rem solid #00763f;
	}
	.people-list dl{
		font-size: 2.8rem;
	}
	.people-list dt{
		font-size: 7rem;
	}
	.people-list a .pic{
		aspect-ratio: 407 / 500;
	}
	.button-area{
		padding-right: 0;
		align-items: center;
		margin: 14.5rem auto 0;
		max-width: calc(100% - 9.6rem);
	}
	.slick-arrow{
		width: 8rem;
		height: 8rem;
		background-size: 4rem auto;
		margin-right: 4rem;
	}
	.back-button{
		font-size: 4rem;
	}
	.back-button:before{
		width: 5rem;
		height: 5rem;
		margin-right: 2.4rem;
	}
	#contact-area{
		padding-top: 15rem;
	}
}