@charset "UTF-8";

img {
	image-rendering: -webkit-optimize-contrast;
}
#header_wrap {
	position: fixed;
	top: 0;
	z-index: 999;
	background:#fff;
	animation-duration: 0.0s;
	animation-timing-function: ease-out;
	height:90px;
}
#header_wrap.kotei {
	animation-duration: 0.0s;
}
#header h1 img{
	filter: invert(100%);
}
.kotei #header h1{
	margin-top: 15px;
}
.kotei ul.pc_nav{
	padding: 35px 0 0;
}
ul.pc_nav li a{
	color: #000;
}
ul.pc_nav li a span{
	color: #000;
}

ul.fix_nav li.sns_btn img{
	filter: invert(100%) !important;
}

#kv{
	margin: 140px auto 70px;
	padding: 0 0 0 0;
	position:relative;
	height: 160px;
	min-width: 1170px;
	background-color:rgba(0,0,0,0.05);
}

#kv_inner{
	margin: 0 0px ;
	padding: 0 0 0 0;
	height: 160px;
	min-width: 1170px;
	position:relative;
display: flex;
align-items:center;
justify-content:center;
}

h2.h2_tit{
	margin: 0 auto;
	padding: 0 0 0;
	position: relative;
	text-align:center;
font-family: Poppins;
font-weight: 600;
font-size: 36px;
letter-spacing: 0.1em;
line-height: 50px;
text-align: center;
color: #585858;
}

h2.h2_tit small{
	margin: 0 0 0;
	padding: 0 0 0;
	position: relative;
display:block;
font-weight: 600;
font-size: 22px;
letter-spacing: 0.04em;
line-height: 44px;
text-align: center;
color: #585858;

}




#document{
	width: 100%;
	margin: 0 auto;
	padding: 0 0 0;
	position: relative;
	text-align:center;
	overflow: hidden;
}

.main_p{
	min-width: 1170px;
	margin: 0 auto 100px;
	padding: 0 0;
	position:relative;
	text-align:center;
}





.staff_area{
	min-width: 1170px;

	margin: 0 auto 100px;
	padding: 0 0;
	position:relative;
	text-align:center;
}

ul.staff_list{
	max-width: 1320px;
	margin: 0 auto 50px;
	padding: 0 70px 0 0;
	position:relative;
	text-align:justify;
display: flex;
align-items:stretch;
justify-content:space-between;
flex-wrap:wrap;
}

ul.staff_list li{
	margin: 0 0 50px 0;
	padding: 0 0;
	position:relative;
	text-align:center;
	width:280px;
	letter-spacing:normal;
}

ul.staff_list li a{
	display:block;
	cursor: pointer;
}

ul.staff_list li a:hover{
	text-decoration:none;

}

ul.staff_list li .staff_img{
	margin: 0 auto 25px;
	padding: 0 0px;
	position:relative;
	display:block;
	text-align:center;
}

ul.staff_list li .staff_img img{
	width:210px;
	height:auto;
	vertical-align:top;
	transition-duration: .3s;
}

ul.staff_list li .staff_name{
	margin: 0 auto 15px;
	padding: 0 0;
	position:relative;
	display:block;
font-weight: bold;
font-size: 22px;
letter-spacing: 0.03em;
line-height: 34px;
text-align: center;
color: #585858;
}

ul.staff_list li .staff_name em{
	margin: 0 auto 0;
	padding: 0 0;
	position:relative;
	display:block;
font-family: Poppins;
font-weight: 600;
font-size: 14px;
letter-spacing: 0.05em;
line-height: 30px;
text-align: center;
color: #2b2e31;
}

ul.staff_list li .staff_name small{
	margin: 0 auto 0;
	padding: 0 0;
	position:relative;
	display:block;
font-weight: normal;
font-size: 13px;
letter-spacing: 0.03em;
line-height: 19px;
text-align: center;
color: #585858;
}

ul.staff_list li .staff_txt{
	margin: 0 30px 0;
	padding: 0 0;
	display:none;

font-weight: 500;
font-size: 13px;
letter-spacing: 0.03em;
line-height: 25px;
text-align: justify;
color: #585858;
}

ul.staff_list:after {
	content: "";
	display: block;
	width: 280px;
	height: 0;
}
ul.staff_list:before {
	content: "";
	display: block;
	width: 280px;
	height: 0;
	order: 1;
}






/* popup */

.mfp-bg {
background: #fff !important;
opacity: 0.8 !important;
}
.white-popup-block{padding:0 0;text-align:justify;max-width:960px;margin:0 auto;position:relative}
.mfp-hide{display:none!important}

.popup_block{
	box-sizing: border-box;
	margin: 20px auto;
	padding: 60px 0px;
	min-width: 960px;
	position:relative;
	text-align:center;

	background-color:#fff;
	border:2px solid #888;

display: flex;
align-items:stretch;
justify-content:space-between;
	min-height:270px !important;
}

.popup_block:after, .popup_block:before {
    content: "";
    clear: both;
    display: block;
}

.popup_close{
	position: absolute;
	top: 18px;
	right: 14px;
}

.popup_close a{
	display:block;
}

.mfp-close{
	display:none !important;
}

/* Dark overlay, start state */
.my-mfp-zoom-in.mfp-bg {
	opacity: 0;
	-webkit-transition: opacity 0.3s ease-out; 
	-moz-transition: opacity 0.3s ease-out; 
	-o-transition: opacity 0.3s ease-out; 
	transition: opacity 0.3s ease-out;
}
/* animate in */
.my-mfp-zoom-in.mfp-ready.mfp-bg {
	opacity: 0.8;
}
/* animate out */
.my-mfp-zoom-in.mfp-removing.mfp-bg {
	opacity: 0;
}

.popup_l{
	margin: 0 0 ;
	padding: 0 0 ;
	position: relative;
	text-align:justify;
	width:260px;
}

.popup_l .staff_img{
	margin: 0 auto 35px;
	padding: 0 0px;
	position:relative;
	display:block;
	text-align:center;
}

.popup_l .staff_img img{
	width:65%;
	height:auto;
	vertical-align:top;
}

.popup_l .staff_name{
	margin: 0 auto 15px;
	padding: 0 0;
	position:relative;
	display:block;
font-weight: bold;
font-size: 22px;
letter-spacing: 0.03em;
line-height: 34px;
text-align: center;
color: #585858;
}

.popup_l .staff_name em{
	margin: 0 auto 0;
	padding: 0 0;
	position:relative;
	display:block;
font-family: Poppins;
font-weight: 600;
font-size: 14px;
letter-spacing: 0.05em;
line-height: 30px;
text-align: center;
color: #2b2e31;
}

.popup_l .staff_name small{
	margin: 0 auto 0;
	padding: 0 0;
	position:relative;
	display:block;
font-weight: normal;
font-size: 13px;
letter-spacing: 0.03em;
line-height: 19px;
text-align: center;
color: #585858;
}


.popup_r{
	margin: 0 0 ;
	padding: 0 0 ;
	position: relative;
	text-align:justify;
	width:560px;
}

dl.popup_txt{
	margin: 0 0 ;
	padding: 0 0 ;
	position: relative;
	text-align:justify;
}
dl.popup_txt dt{
	margin: 0 0 6px;
	padding: 0 0 ;
	position: relative;
font-weight: bold;
font-size: 16px;
letter-spacing: 0.03em;
line-height: 34px;
text-align: justify;
color: #585858;
}
dl.popup_txt dd{
	margin: 0 0 16px;
	padding: 0 0 ;
	position: relative;
font-weight: normal;
font-size: 16px;
letter-spacing: 0.03em;
line-height: 34px;
text-align: justify;
color: #585858;
}



.gallery-arrow{
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none; }

button.gallery-arrow {
  overflow: visible;
  cursor: pointer;
  background: transparent;
  border: 0;
  -webkit-appearance: none;
  display: block;
  outline: none;
  padding: 0;
  z-index: 1046;
  box-shadow: none;
  touch-action: manipulation; }

.gallery-arrow {
  position: fixed;
  opacity: 0.5;
  margin: 0;
  top: 47%;

  padding: 0;
  width: 44px;
  height: 90px;
  -webkit-tap-highlight-color: transparent; }
  .gallery-arrow:active {
}
  .gallery-arrow:hover,
  .gallery-arrow:focus {
    opacity: 1; }

  .gallery-arrow:after {
    content: '';
    display: block;
    width: 0;
    height: 0;
    position: absolute;
    left: 0;
    top: 0;
 }
  .gallery-arrow:after {
 }

.gallery-arrow-left {
  left: 30px; }
  .gallery-arrow-left:after {
	background:url(../../images/staff/arr_l2.png)  no-repeat center center !important;
	width:44px;
	height:90px;
 }


.gallery-arrow-right {
  right: 30px; }
  .gallery-arrow-right:after {
	background:url(../../images/staff/arr_r2.png)  no-repeat center center !important;
	width:44px;
	height:90px;
 }

.center{
	text-align:center;
}

.sp_only{
	display:none;
}

.img_sp {
	display:none;
}

/* POPUP CLOSE ボタン
==================================================*/
.icon_close{
    display: block;
    width: 50px;/*枠の大きさ*/
    height: 50px;/*枠の大きさ*/
    position: relative;
}

.icon_close::before, .icon_close::after{
    content: "";
    display: block;
    width: 100%;/*バツ線の長さ*/
    height: 1px;/*バツ線の太さ*/
    background: #000;
    transform: rotate(45deg);
    transform-origin:0% 50%;
    position: absolute;
    top: calc(14% - 5px);
    left: 14%;
}

.icon_close::after{
    transform: rotate(-45deg);
    transform-origin:100% 50%;
    left: auto;
    right: 14%;
}
.mfp-close {visibility:hidden !important!;}


/* アニメーション 一覧用
==================================================*/

ul.staff_list li .staff_img {
	display: block;
	width: 210px;
	height: 370px;
	position: relative;
}
ul.staff_list li .staff_img span {
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
ul.staff_list li .staff_img span.bg2, .staff_img span.bg3 {
	z-index: -2;
	opacity: 0;
}
ul.staff_list li .staff_img span img {
	display: block;
	height: 100%;
	width: auto;
	max-width: none;
	margin-left: 50%;
	transform: translateX(-50%);
}
ul.staff_list li:hover .staff_img span.bg1 {
	transition: opacity 400ms ease;
	opacity: 0;
}
ul.staff_list li:hover .staff_img span.bg2 {
	animation: fadeOutBg2 400ms ease 400ms forwards, stayVisibleBg2 1ms ease-out 800ms forwards;
}
ul.staff_list li:hover .staff_img span.bg3 {
	transition: opacity 400ms ease 900ms;
	opacity: 1;
}

ul.staff_list li:hover .staff_img.slow span.bg1 {
	transition: opacity 600ms ease;
	opacity: 0;
}
ul.staff_list li:hover .staff_img.slow span.bg2 {
	animation: fadeOutBg2 600ms ease 600ms forwards, stayVisibleBg2 1ms ease-out 1200ms forwards;
}
ul.staff_list li:hover .staff_img.slow span.bg3 {
	transition: opacity 600ms ease 1300ms;
	opacity: 1;
}

@keyframes fadeOutBg2 {
	from { opacity: 0; }
	to { opacity: 1; }
}

@keyframes stayVisibleBg2 {
	from { opacity: 1; }
	to { opacity: 0; }
}
















/* アニメーション popup用
==================================================*/
div.popup_l .staff_img {
    display: block;
    width: 210px;
    height: 370px;
    position: relative;
}
div.popup_l .staff_img span {
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transition: opacity 400ms ease;
    opacity: 0;
}
div.popup_l .staff_img span.bg1 {
    z-index: 1;
    opacity: 1;
}
div.popup_l .staff_img span.bg2 {
    z-index: 2;
}
div.popup_l .staff_img span.bg3 {
    z-index: 3;
}
div.popup_l .staff_img.slow span {
    transition-duration: 500ms; /* スロークラス用の遷移時間変更 */
}
div.popup_l .staff_img span img {
    display: block;
    height: 100%;
    width: auto;
    max-width: none;
    margin-left: 50%;
    transform: translateX(-50%);
}

/* アニメーションの定義 */
@keyframes fadeOutBg1 {
    0% { opacity: 1; }
    100% { opacity: 0; }
}
@keyframes fadeInOutBg2 {
    0% { opacity: 0; }
    100% { opacity: 1; }
}
@keyframes stayVisibleBg2 {
    0% { opacity: 1; }
    100% { opacity: 0; }
}
@keyframes fadeInBg3 {
    0% { opacity: 0; }
    100% { opacity: 1; }
}

/* アニメーションの適用 */
div.popup_l.animate-once .staff_img span.bg1 {
    animation: fadeOutBg1 500ms ease 500ms forwards; /* 500msの遅延を追加 */
}
div.popup_l.animate-once .staff_img span.bg2 {
    animation: fadeInOutBg2 400ms ease 900ms forwards, stayVisibleBg2 1ms ease 1300ms forwards;
}
div.popup_l.animate-once .staff_img span.bg3 {
    animation: fadeInBg3 400ms ease 1500ms forwards;
}
div.popup_l.animate-once .staff_img.slow span.bg1 {
    animation: fadeOutBg1 700ms ease 500ms forwards; /* 500msの遅延を追加 */
}
div.popup_l.animate-once .staff_img.slow span.bg2 {
    animation: fadeInOutBg2 600ms ease 1100ms forwards, stayVisibleBg2 1ms ease 1700ms forwards;
}
div.popup_l.animate-once .staff_img.slow span.bg3 {
    animation: fadeInBg3 600ms ease 1900ms forwards;
}
