@charset "UTF-8";

#header_wrap{
	background-color:rgba(137,137,137,1.0);
}

.page_tit{
	margin: 0 auto;
	padding: 0 0 0 0;
	position:relative;
	background-color:rgba(137,137,137,1.0);
	min-width: 1170px;
}

h2.page_tit{
	margin: 0 auto;
	padding: 0 0 40px;
	position: relative;
	text-align: center;
}
h2.page_tit strong{
	margin: 0 0;
	padding: 0 0 0 ;
	position: relative;

font-family: Lato;
font-weight: 300;
font-size: 30px;
letter-spacing: 0.25em;
line-height: 30px;
text-align: center;
color: #fff;
}

h2.page_tit small{
	margin: 0 0 0;
	padding: 0 0 0;
	position: relative;

font-family: "Noto Sans JP";
font-weight: 500;
font-size: 20px;
letter-spacing: 0.1em;
line-height: 20px;
text-align: center;
color: #fff;
display:block;
margin-top:20px;
}

.page_p{
	margin: 0 auto;
	padding: 0 0 0 0;
	position:relative;
	height: 600px;
background:  url(../../images/company/page_p.jpg?2) no-repeat center center;
background-size:cover;
}


.btn_style{
	margin: 0 0 0 0;
	padding: 0 0 0 0;
	position:relative;
	text-align:center;
}

.btn_style a{
	margin: 0 auto;
	padding: 10px 0;
	position:relative;
	text-align:center;

font-family: Lato;
font-weight: bold;
font-size: 12px;
line-height: 1.5;
text-align: center;
color: #585858;
border: 1px solid rgba(88, 88, 88, 0.5);

transition-duration: .2s;
box-sizing: border-box;
background: url(../../images/base/plus.svg) no-repeat right 10px top 50%;
background-color: #fff;
}

.btn_style a:hover{
background: url(../../images/base/plus_on.svg) no-repeat right 10px top 50%;
background-color: #383837;
color:#fff;
text-decoration:none;
}




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

.area_inner{
	width: 1170px;
	margin: 0 auto;
	padding: 0 0;
	position:relative;
}

h2.h2_style{
	margin: 0 0 50px;
	padding: 0 0;
	position: relative;
text-align: left;
display: flex;
align-items:center;
justify-content:flex-start;
}
h2.h2_style strong{
	margin: 0 30px 0 0;
	padding: 0 0 0 ;
	position: relative;

font-family: Lato;
font-weight: 300;
font-size: 30px;
letter-spacing: 0.25em;
line-height: 30px;
text-align: left;
color: #585858;
}

h2.h2_style small{
	margin: 0 0 0;
	padding: 0 0 0;
	position: relative;

font-family: "Noto Sans JP";
font-weight: 500;
font-size: 18px;
letter-spacing: 0.02em;
line-height: 38px;
text-align: left;
color: #585858;
}

.message_area{
	min-width: 1170px;
	margin: 0 auto;
	padding: 100px 20px;
	position:relative;
	text-align:center;
	background-color:#e5e5e5;
}

.main_column{
	max-width: 1300px;
	margin: 0 auto;
	padding: 0 0 0 0;
	position:relative;
text-align: center;
display: flex;
align-items:flex-start;
justify-content:flex-start;
}

.main_txt{
	width: 790px;
	margin: 0 0;
	padding: 0 0 0 0;
	position:relative;
	text-align: left;
}

.main_txt h3{
	margin: 0 0;
	padding: 0 0 0 0;
	position:relative;
font-family: "Noto Sans JP";
font-weight: 600;
font-size: 25px;
letter-spacing: 0.03em;
line-height: 44px;
text-align: left;
color: #585858;

}

.main_p{
	width: auto;
	margin: 0 0;
	padding: 0 0 0 0;
	position:relative;
	text-align: left;
}

.main_p span{
	width: auto;
	margin: 10px 0 0 0;
	padding: 0 0 0 0;
	position:relative;
font-family: "Noto Sans JP";
font-weight: normal;
font-size: 18px;
letter-spacing: 0.03em;
line-height: 1.5;
text-align: left;
color: #585858;
display:block;
}
.main_p span b{
font-family: "Noto Sans JP";
font-weight: 500;
font-size: 18px;
letter-spacing: 0.07em;
line-height: 1.5;
text-align: center;
color: #585858;
}
.main_p span em{
font-family: "Noto Sans JP";
font-weight: 500;
font-size: 22px;
letter-spacing: 0.07em;
line-height: 1.5;
text-align: center;
color: #585858;
}



ul.message_list{
	max-width: 1300px;
	min-width: 1200px;
	margin: 0 auto;
	padding: 0 0 0 0;
	position:relative;
text-align: center;
}

ul.message_list li{
	margin: 0 auto 80px;
	padding: 0 0 0 0;
	position:relative;
text-align: center;
display: flex;
align-items:stretch;
justify-content:space-between;
}

ul.message_list li .message_txt{
	margin: 0 0;
	padding: 0;
	position:relative;
text-align:justify;
width: 650px;
}

ul.message_list li .message_num{
	margin: 0 0 20px;
	padding: 0 0 30px;
	position:relative;
font-family: Lato;
font-weight: 300;
font-size: 47px;
letter-spacing: 0.03em;
line-height: 50px;
text-align: left;
color: #585858;

}

ul.message_list li .message_num:before {
  position: absolute;
  bottom: 0px;
  left: 0px;
  width: 60px;
  height: 1px;
  content: '';
  background: #777;
}

ul.message_list li .message_txt h3{
	margin: 0 auto 20px;
	padding: 0 0 0 0;
	position:relative;
font-family: "Noto Sans JP";
font-weight: normal;
font-size: 23px;
letter-spacing: 0.03em;
line-height: 38px;
text-align: left;
color: #585858;

}

ul.message_list li .message_txt h3 small{
font-family: Lato;
font-weight: 300;
font-size: 14px;
letter-spacing: 0.1em;
line-height: 38px;
text-align: left;
color: #403a3a;
display:block;

}

ul.message_list li .message_txt p{
	margin: 0 auto;
	padding: 0 0 0 0;
	position:relative;
font-family: "Noto Sans JP";
font-weight: normal;
font-size: 15px;
line-height: 34px;
text-align: left;
color: #585858;
}

ul.message_list li h4{
	margin: 0 0 0;
	padding: 0 0 0 0;
	position:relative;
text-align: center;
width: 30%;
}

ul.message_list li .message_p{
	margin: 0 0 0;
	padding: 0 0 0 0;
	position:relative;
text-align:justify;
}


ul.message_list li:nth-child(1){
	margin: -80px auto 80px;
	padding: 0 0 0 0;
	position:relative;
align-items:flex-end;
}

ul.message_list li:nth-child(2){

}

ul.message_list li:nth-child(3){
	margin: -130px auto 80px;
	padding: 0 0 0 0;
	position:relative;
align-items:flex-end;
}

ul.message_list li:nth-child(3) p{
	margin: 0 auto 20px;
	padding: 0 0 0 0;
	white-space:nowrap;
}

ul.message_list li:nth-child(3) p em{
font-family: "Noto Sans JP";
font-weight: normal;
font-size: 18px;
letter-spacing: 0.03em;
line-height: 42px;
text-align: left;
color: #585858;

}

ul.message_list li:nth-child(3) p img.img_left{
margin: 10px 20px 0 0;
float:left;
}


ul.message_list li:nth-child(3) p span{
	margin:0 5px 0 0;
	padding: 5px 15px;
	position:relative;
font-family: "Noto Sans JP";
font-weight: 500;
font-size: 16px;
letter-spacing: 0.03em;
line-height: 34px;
text-align: left;
color: #585858;
background-color:#fff;
display:inline-block;

}


ul.message_list li:nth-child(2),
ul.message_list li:nth-child(4){
flex-direction:row-reverse;
}

ul.message_list li .message_txt p img.img_right{
	float:right;
	margin: 0 0 0 50px;
}


.outline_area{
	max-width: 1310px;
	min-width: 1170px;
	margin: 100px auto 30px;
	padding: 0 0 0 20px;
	position:relative;
	text-align:center;

display: flex;
align-items:flex-start;
justify-content:space-between;
}

.table_block{
	margin: 0 0;
	padding: 0 0;
	position:relative;
	text-align:left;
	width:68%;
display: flex;
align-items:stretch;
justify-content:space-between;
}

table.outline_table{
	margin: 0 0;
	padding: 0 0;
	position:relative;
	text-align:left;
	width:50%;
}

table.outline_table th{
	margin: 0 0;
	padding: 0 0 20px;
	position:relative;
font-family: "Noto Sans JP";
font-weight: normal;
font-size: 16px;
line-height: 24px;
text-align: left;
color: #585858;
}
table.outline_table td{
	margin: 0 0;
	padding: 0 0 20px;
	position:relative;
font-family: "Noto Sans JP";
font-weight: 300;
font-size: 14px;
line-height: 24px;
text-align: left;
color: #383837;
}



.staff_area{
	max-width: 1300px;
	min-width: 1170px;
	margin: 0 auto;
	padding: 0 0 0 20px;
	position:relative;
	text-align:center;

display: flex;
align-items:flex-start;
justify-content:space-between;
}

.staff_p{
	margin: 0 0;
	padding: 0 0;
	position:relative;
	text-align:justify;
	width:68%;
}

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

.btn_style.staff_btn{
	position:absolute;
	top:60px;
	left:20px;
}

.btn_style2{
	position:absolute;
	bottom:60px;
	left:20px;
}

.btn_style2 a{
	margin: 0 auto;
	padding: 10px 40px;
	position:relative;
	text-align:center;

font-family: "Noto Sans JP";
font-weight: 600;
font-size: 16px;
letter-spacing: 0.05em;
line-height: 20px;
text-align: center;
color: #fff;

border: 1px solid #9c9c9c;

transition-duration: .2s;
background-color: #9c9c9c;
}

.btn_style2 a:hover{
background-color: #fff;
color:#585858;
text-decoration:none;
}




.recruit_wrap{
	min-width: 1170px;
	margin: 0 auto;
	padding: 100px 20px;
	position:relative;
	text-align:center;
background-color: #9c9c9c;
}


.recruit_area{
	max-width: 1300px;
	min-width: 1170px;
	margin: 0 auto;
	padding: 0 0;
	position:relative;
	text-align:center;
display: flex;
align-items:flex-start;
justify-content:space-between;
}

.recruit_area h2.h2_style{

}
.recruit_area h2.h2_style strong{
color: #fff;
}

.recruit_area h2.h2_style small{
color: #fff;
}

.recruit_area p{
	position:absolute;
	top:70px;
	left:0;
font-family: "Noto Sans JP";
font-weight: normal;
font-size: 18px;
line-height: 34px;
text-align: left;
color: #fff;

}

.recruit_p{
	margin: 0 0;
	padding: 0 0;
	position:relative;
	text-align:justify;
	width:68%;
}

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


.btn_style3{
	position:absolute;
	bottom:0px;
	left:0;
}

.btn_style3 a{
	margin: 0 auto;
	padding: 10px 20px;
	position:relative;
	text-align:center;

font-family: "Noto Sans JP";
font-weight: 600;
font-size: 16px;
letter-spacing: 0.05em;
line-height: 20px;
text-align: center;
color: #585858;

border: 1px solid #585858;

transition-duration: .2s;
background-color: #fff;

}

.btn_style3 a small{
font-family: Lato;
font-weight: bold;
font-size: 13px;
letter-spacing: 0.05em;
line-height: 33px;
text-align: center;

padding-right:10px;
}

.btn_style3 a:hover{
background-color: #585858;
color:#fff;
text-decoration:none;
}



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

.access_area h2.h2_style{
	margin: 0 auto 50px;
	padding: 0 0;
	position: relative;
text-align: center;
display: flex;
align-items:center;
justify-content:center;
}

.map_block{
	margin: 0 0 30px;
	padding: 0 0;
	position:relative;
text-align: center;
}

.access_area p{
	margin: 0 0;
	padding: 0 0;
	position:relative;
font-family: "Noto Sans JP";
font-weight: normal;
font-size: 15px;
line-height: 34px;
text-align: center;
color: #585858;
}








@keyframes fadeIn01 {
    from {
        opacity: 0;
    }
    to {
        opacity: 1;
    }
}
.fadein01 {
    animation-name: fadeIn01;
    animation-fill-mode: backwards;
    animation-timing-function: ease-out;
}

@keyframes fadeInUp02 {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
.fadein_up02 {
    animation-name: fadeInUp02;
    animation-fill-mode: backwards;
    animation-timing-function: ease-out;
}

@keyframes fadeInRight02 {
    from {
        opacity: 0;
        transform: translateX(10px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}
.fadein_right02 {
    animation-name: fadeInRight02;
    animation-fill-mode: backwards;
    animation-timing-function: ease-out;
}







.kotei {
    animation-name: fadeIn01;
    animation-fill-mode: backwards;
    animation-timing-function: ease-out;
    animation: fadeIn 2s ease-in-out;
}


@keyframes fadeInUp01 {
    from {
        opacity: 0;
        transform: translateY(14px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
.h2_kv01 {
    animation-name: fadeInUp01;
    animation-duration: 0.3s; 
    animation-delay: 0.3s; 
    animation-fill-mode: backwards;
    animation-timing-function: ease-out;
}
.h2_kv02 {
    animation-name: fadeInUp01;
    animation-duration: 0.3s;
    animation-delay: 1.0s;
    animation-fill-mode: backwards;
    animation-timing-function: ease-out;
}

@keyframes fadeInRight01 {
    from {
        opacity: 0;
        transform: translateX(10px);
    }
    to {
        opacity: 1;
        transform: translateX(0);
    }
}
.h3_kv {
    animation-name: fadeInRight01;
    animation-duration: 0.3s;
    animation-delay: 1.5s;
    animation-fill-mode: backwards;
    animation-timing-function: ease-out;
}




