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


.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_left .staff_img {
    display: block;
    width: 210px;
    height: 370px;
    position: relative;
}
div.popup_left .staff_img span {
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transition: opacity 400ms ease;
    opacity: 0;
}
div.popup_left .staff_img span.bg1 {
    z-index: 1;
    opacity: 1;
}
div.popup_left .staff_img span.bg2 {
    z-index: 2;
}
div.popup_left .staff_img span.bg3 {
    z-index: 3;
}
div.popup_left .staff_img.slow span {
    transition-duration: 500ms; /* スロークラス用の遷移時間変更 */
}
div.popup_left .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_left.animate-once .staff_img span.bg1 {
    animation: fadeOutBg1 500ms ease 500ms forwards; /* 500msの遅延を追加 */
}
div.popup_left.animate-once .staff_img span.bg2 {
    animation: fadeInOutBg2 400ms ease 900ms forwards, stayVisibleBg2 1ms ease 1300ms forwards;
}
div.popup_left.animate-once .staff_img span.bg3 {
    animation: fadeInBg3 400ms ease 1500ms forwards;
}
div.popup_left.animate-once .staff_img.slow span.bg1 {
    animation: fadeOutBg1 700ms ease 500ms forwards; /* 500msの遅延を追加 */
}
div.popup_left.animate-once .staff_img.slow span.bg2 {
    animation: fadeInOutBg2 600ms ease 1100ms forwards, stayVisibleBg2 1ms ease 1700ms forwards;
}
div.popup_left.animate-once .staff_img.slow span.bg3 {
    animation: fadeInBg3 600ms ease 1900ms forwards;
}




/* ポップアップ */

.mfp-bg {
/*background: #fff !important;
opacity: 0.8 !important;*/
}

.white-popup-block{padding:0 0;text-align:justify;max-width:1110px;margin:0 auto;position:relative}
.mfp-hide{display:none!important}

.mfp-container {
    padding: 20px !important;
}

.popup_block{
	margin: 0 auto;
	padding: 50px 0;
	position: relative;
	background:#fff;
	border:0px solid #fff;
	text-align:center;
}

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

.popup_left{
	margin: 0 0 0 ;
	padding: 0 0 ;
	position:relative;
	letter-spacing:normal;
	text-align:left;
	display:inline-block;
	vertical-align:top;
	width:540px;
}

.popup_right{
	margin: 0 0 0 50px;
	padding: 0 0 ;
	position:relative;
	letter-spacing:normal;
	text-align:left;
	display:inline-block;
	vertical-align:top;
	width:370px;
}

.pop_img{
	margin: 0 0 50px 0;
	padding: 0 0 0;
	position: relative;
	text-align:left;
	display:inline-block;
	vertical-align:top;
	width:240px;
}

.pop_img img{
	width:238px;
	height:247px;
	object-fit: cover;
}

.pop_info{
	margin: 10px 0 50px 30px;
	padding: 0 0 0;
	position: relative;
	text-align:left;
	display:inline-block;
	vertical-align:top;
	width:260px;
}


.pop_name{
	margin: 0 0 0 0;
	padding: 0 0 40px;
	position: relative;
	text-align:left;

	font-size: 14px;
	font-weight:normal;
	line-height: 1.8;
	letter-spacing:0px;
	color:#444;
}

.pop_name strong{
	margin: 0 0 0;
	padding: 0 0;
	text-align:left;
	font-size: 20px;
	font-weight:bold;

	letter-spacing:0px;
	color:#444;
}

.pop_name small{
	font-weight:bold;
	letter-spacing:1px;
	font-family: 'Roboto', sans-serif;
}

.pop_data{
	margin: 0 0 0 0;
	padding: 0 0 0;
	position: relative;
	text-align:justify;

	font-size: 13px;
	font-weight:normal;
	line-height: 2.0;
	letter-spacing:0px;
	color:#444;
}

.pop_data strong{
	font-weight:bold;
	font-family: 'Roboto', sans-serif;;
}



.pop_midashi {
	position: relative;
	margin: 0 0 20px;
	padding: 0 0;
	text-align: left;
}

.pop_midashi:before {
	position: absolute;
	top: calc(50% - 1px);
	left: 0;
	width: 100%;
	height: 1px;
	content: '';
	background: #000;
}

.pop_midashi span {
	position: relative;
	padding: 0 20px 0 0;
	background: #fff;

	text-align:left;
	font-size: 17px;
	line-height: 1.8;
	font-weight:bold;
	color:#000;
	letter-spacing:0px;
}

ul.pop_img_list{
	margin: 0 0 0 -50px;
	padding: 0 0 0;
	position: relative;
	text-align:left;
}

ul.pop_img_list li{
	margin: 0 0 50px 50px;
	padding: 0 0 0;
	position: relative;
	text-align:left;
	font-size: 14px;
	line-height: 1.8;
	font-weight:normal;
	color:#444;
	letter-spacing:0px;
	
	display:inline-block;
	vertical-align:top;
	width:240px;
}

ul.pop_img_list li img{
	margin-bottom:10px;
	width:238px;
	height:158px;
	object-fit: cover;
}





.pop_tit{
	margin: 0 0 20px 0;
	padding: 0 0 0;
	position: relative;
	text-align:left;
	
	font-size: 15px;
	font-weight:bold;
	line-height: 1.8;
	letter-spacing:2px;
	color:#444;
	font-family: 'Roboto', sans-serif;
}

.pop_txt{
	margin: 0 0 0 0;
	padding: 0 0px 50px;
	position: relative;
	text-align:justify;
	font-size: 14px;
	line-height: 2.0;
	font-weight:normal;
	color:#444;
	letter-spacing:0px;
}



ul.pop_blog_list{
	margin: 0;
	padding: 0 0 0;
	position: relative;
	text-align:left;
}

ul.pop_blog_list li{
	margin: 0 0 10px;
	padding: 0 0 10px;
	position: relative;
	text-align:left;
	font-size: 14px;
	line-height: 1.5;
	font-weight:normal;
	color:#444;
	letter-spacing:0px;
	width:auto;
	border-bottom: 1px dashed #444;
}
/*
ul.pop_blog_list li:before {
	position: absolute;
	top: calc(100% - 1px);
	left: 0;
	width: 60px;
	height: 1px;
	content: '';
	background: #000;
}
*/
ul.pop_blog_list li a{
	display:flex;
}


ul.pop_blog_list li a strong{
	font-family: 'Roboto', sans-serif;
	font-weight:bold;
	letter-spacing:1px;
	vertical-align:top;
	width:110px;
}
ul.pop_blog_list li a span.tit {
	vertical-align:top;
	width:260px;
}
ul.pop_blog_list li a span.tit span.new{
	font-family: 'Roboto', sans-serif;
	font-weight:normal;
	color:red;
	padding-left:0.6em;
}

ul.pop_blog_list li a:hover{
	background-color:#f6f6f6;
	text-decoration:none;
}

.btn_more{
	margin: 0 auto;
	padding: 0 0 0;
	position: relative;
	text-align:right;
}

.btn_more a{
	margin: 0 0;
	padding: 20px 0;
	position: relative;
	text-align:center;
	font-size: 12px;
	line-height: 1.5;
	font-weight:normal;
	color:#444;
	letter-spacing:0px;
	display:block;
	width: 60px;
	font-family: 'Roboto', sans-serif;
	float:right;
	border:0;
}

.btn_more a:before {
	position: absolute;
	top: calc(100% - 1px);
	right: 0;
	width: 60px;
	height: 1px;
	content: '';
	background: #000;
}

.btn_more a:hover{
	background-color:#f6f6f6;
	border:0;
	color: inherit;
}


.btn_np{
	position: absolute;
	right:290px;
	bottom:28px;

	font-size: 12px;
	line-height: 1.5;
	font-weight:normal;
	color:#444;
	letter-spacing:1px;
	display:inline-block;
	font-family: 'Roboto', sans-serif;
}

.btn_np a{
	margin: 0 0;
	padding: 20px 10px;
	position: relative;

	font-size: 12px;
	line-height: 1.5;
	font-weight:normal;
	color:#444;
	letter-spacing:1px;
	display:inline-block;
	font-family: 'Roboto', sans-serif;
}

.close_btn{
	position: absolute;
	right:30px;
	top:30px;

}

.close_btn img{
	width:130px;
	height:auto;
}

.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.7;
}
/* animate out */
.my-mfp-zoom-in.mfp-removing.mfp-bg {
	opacity: 0;
}






