@charset "UTF-8";

img {
	image-rendering: -webkit-optimize-contrast;
}

#header h1 img{
	filter: invert(100%);
}

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

#kv_inner{
	margin: 0 0px ;
	padding: 0 0 0 0;
	height: 110px;
	min-width: auto;
	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: 20px;
letter-spacing: 0.1em;
line-height: 30px;
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: 16px;
letter-spacing: 0.08em;
line-height: 28px;
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: auto;
	margin: 0 auto 50px;
	padding: 0 0;
	position:relative;
	text-align:center;
}

.main_p img{
	width: 100%;
	height:auto;
}



.staff_area{
	min-width: auto;

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

ul.staff_list{
	max-width: auto;
	margin: 0 30px 50px;
	padding: 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 20px 0;
	padding: 0 0;
	position:relative;
	text-align:center;
	width:45%;
	letter-spacing:normal;
}

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


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

ul.staff_list li .staff_img img{
	height:210px;
	width: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: 16px;
line-height: 22px;
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: 10px;
letter-spacing: 0.05em;
line-height: 22px;
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: 22px;
text-align: center;
color: #585858;
}

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

font-weight: normal;
font-size: 12px;
line-height: 19px;
text-align: justify;
color: #585858;
}







/* popup */

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

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

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

}

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

.popup_close{
	position: absolute;
	top: 14px;
	right: 10px;
	z-index:1000;
}

.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 auto ;
	padding: 0 0 ;
	position: relative;
	text-align:justify;
	width:260px;
}

.popup_l .staff_img{
	margin: 0 auto 15px;
	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:auto;
}

dl.popup_txt{
	margin: 0 30px ;
	padding: 0 0 ;
	position: relative;
	text-align:justify;
}
dl.popup_txt dt{
	margin: 0 0 3px;
	padding: 0 0 ;
	position: relative;
font-weight: bold;
font-size: 13px;
line-height: 1.8;
text-align: justify;
color: rgba(56, 56, 55, 0.85);

}
dl.popup_txt dd{
	margin: 0 0 10px;
	padding: 0 0 ;
	position: relative;
font-weight: normal;
font-size: 13px;
line-height: 1.5;
text-align: justify;
color: rgba(56, 56, 55, 0.85);
}



.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: absolute;
  opacity: 0.4;
  margin: 0;
  top: 40%;

  padding: 0;
  width: 15px;
  height: 30px;
  -webkit-tap-highlight-color: transparent; }
  .gallery-arrow:active {
}

  .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;
	background-size:15px auto !important;
	width:15px;
	height:30px;
 }


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







.center{
	text-align:center;
}

.pc_only{
	display:none;
}

.img_pc {
	display:none;
}


ul.staff_list li .staff_img span.bg2,
ul.staff_list li .staff_img span.bg3 {
	display:none;
}


/* POPUP CLOSE ボタン
==================================================*/
.icon_close{
    display: block;
    width: 40px;/*枠の大きさ*/
    height: 40px;/*枠の大きさ*/
    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!;}




/* アニメーション 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%;
}

div.popup_l .staff_img span.bg1 {
    z-index: 1;
    opacity: 1;
    transition-property: opacity;
    transition-duration: 400ms;
    transition-timing-function: ease;
    transition-delay: 0ms;
}
div.popup_l .staff_img span.bg2 {
    z-index: 2;
    opacity: 0;
}
div.popup_l .staff_img span.bg3 {
    z-index: 3;
    opacity: 0;
}

div.popup_l .staff_img span img {
    display: block;
    height: 100%;
    width: auto;
    max-width: none;
    margin-left: 50%;
    transform: translateX(-50%);
}

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; /* 遅延を調整 */
}

/* slow クラス用のアニメーション適用 */
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; /* 遅延を調整 */
}

@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; }
}
