@charset "UTF-8";
/* CSS Document */
html{
	font-size: 62.5%;/*16px x 62.5%=10px*/
}
body{
	color: #222;
	font-family: 'Open Sans' ,'Noto Sans JP', sans-serif;
	font-size: 1.6rem;
	line-height: 1.85;
	font-feature-settings: "palt";
	letter-spacing: 0.025em;
	-webkit-font-smoothing:antialiased;
	-moz-osx-font-smoothing:grayscale;
}
img{
	max-width: 100%;
	height: auto;
}
h1{
	font-size: 8.0rem;
	font-weight: bold;
	font-style: italic;
	color: #024eb6;
	text-transform: uppercase;
}
.contents_text{
	padding: 60px 0;
    width: 780px;
    margin: 0 auto;
}
.contents_list{
	display: flex;
    justify-content: space-around;
    align-items: flex-start;
}
.btn{
	color: #FFF;
	border: #fff 1px solid;
	font-style: italic;
	text-transform: uppercase;
	padding: 20px 80px;
	background-color: #024eb6;
}
.btn:hover{
	color: #024eb6;
	border: #024eb6 1px solid;
	background: #fff;
}
.text_center{
	text-align: center;
}
._pc{
	display: block;
}
._sp{
	display: none;
}
.contents_title{
	display: flex;
    justify-content: center;
    align-items: center;
	padding-bottom: 60px;
}
.contents_inner{
	margin: 0 auto;
    padding-top: 60px;
    padding-bottom: 110px;
    background-color: #f7f7f7;
}
.bgc{
	background-color: #f7f7f7;
}
.bgc_f{
	background-color: #fff;
}
.contents{
	width: 50%;
	margin: 0 auto;
}
/******************

header

******************/
.header{
	color: #fff;
	background-color: #024eb6;
    height: 80px;
    width: 100%;
    display: flex;
	justify-content: space-between;
    align-items: center;
    padding-left: 20px;
	box-sizing: border-box;
}
.top_logo{
	margin-right: auto;
}
.top_logo img{
	width: 50%;
}
.nav_e{
	text-transform: uppercase;
	font-size: 1.0rem;
}
nav ul{
	display: flex;
	align-items: center;
	text-align: center;
}
nav ul li{
	margin-left: 50px;
}
nav ul li a{
	color: #fff;
}
nav li.current a{
	color: #63b5ff;
	font-weight: bold;
}

@media screen and (min-width:769px) and (max-width:1140px){
	nav ul li{
		margin-left: 30px;
	}
}
@media screen and (min-width:769px){
	.h_contact_btn a{
		display: block;
		color: #fff;
		background-color: #0b80e6;
		padding: 15px 30px;
		border: 1px solid #0b80e6;
	}
	.h_contact_btn a:hover{
		color: #0b80e6;
		background-color: #fff;
		border: #0b80e6 solid 1px;
	}
	.nav-item-animated a{
		display: block;
		padding: 0 0 5px;
		position: relative;
		text-decoration: none;
	}
	.nav-item-animated a::before,
	.nav-item-animated a::after {
	  border-bottom: solid 3px #fff;
	  bottom: 0;
	  content: "";
	  display: block;
	  position: absolute;
	  transition: all .3s ease;
	  -webkit-transition: all .3s ease;
	  width: 0;
	}
	.nav-item-animated a::before {
	  left: 50%;
	}
	.nav-item-animated a::after {
	  right: 50%;
	}
	.nav-item-animated a:hover::before,
	.nav-item-animated a:hover::after {
	  width: 50%;
	}
}
/******************

title

******************/
.title h1{
  line-height: 5rem;
}
.h1_sub{
	font-size: 3rem;
	font-style: normal;
}
.catch{
	display: flex;
    align-items: baseline;
    justify-content: space-between;
}
.kv{
	width: 80%;
}
.kv img{
	width: 100%;
}
.title_contents{
	margin-left: -270px;
    margin-right: 100px;
    text-align: center;
}
.pankuzu{
	max-width: 1000px;
    margin: 0 auto;
}
.p-subpage-top-area__breadcrumb-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    height: 100%;
    font-size: small;
    color: #222;
}
.p-subpage-top-area__breadcrumb-item:not(:last-child), .p-subpage-top-area__breadcrumb-item--top-page:not(:last-child) {
    position: relative;
    margin-right: 1.5em;
}
.p-subpage-top-area__breadcrumb-item:not(:last-child)::after, .p-subpage-top-area__breadcrumb-item--top-page:not(:last-child)::after {
    display: block;
    position: absolute;
    width: 1.5em;
    height: 1.5em;
    top: 0;
    left: 100%;
    content: '>';
    text-align: center;
}
.p-subpage-top-area__breadcrumb-item--top-page {
    padding-left: 1.5em;
}
.p-subpage-top-area__breadcrumb-item:not(:last-child)>a, .p-subpage-top-area__breadcrumb-item--top-page:not(:last-child)>a {
    -webkit-transition: opacity .2s;
    transition: opacity .2s;
}
.p-subpage-top-area__breadcrumb-item:not(:last-child), .p-subpage-top-area__breadcrumb-item--top-page:not(:last-child) {
    position: relative;
    margin-right: 1.5em;
}
.p-subpage-top-area__breadcrumb-item--top-page {
    padding-left: 1.5em;
}
.pankuzu ul li:last-child{
	margin-left: 5px;
}
.pankuzu ul li a{
	color: #024eb6;
}
/******************

reqruit

******************/
.reqruit{
    margin: 0 auto;
    padding-top: 110px;
}
.reqruit_title{
	color: #fff;
	background-image: url("../image/reqruit_bg02.png");
	background-size: cover;
	background-repeat: no-repeat;
	padding: 60px 0 110px;
}
.reqruit_title dl{
	max-width: 800px;
    margin: 0 auto;
}
.reqruit_title dt{
	font-size: 4.0rem;
	font-weight: bold;
	padding-bottom: 50px;
}
.reqruit_contents{
	padding: 60px 0 110px;
    background-color: #f7f7f7;
}
.p-definition-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
	max-width: 780px;
    margin: 0 auto;
}
.p-definition-list__list {
    width: 100%;
}
.p-definition-list__item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
	padding: 15px 20px;
}
.p-definition-list__term{
	width: 30%;
	color: #024eb6;
    font-weight: bold;
}
.p-definition-list__desc {
    width: 100%;
}
/******************

contact

******************/
.contact{
	color: #024eb6;
	padding: 90px 0 0;
	margin-bottom: 100px;
}
.contact_title{
	font-size: 3.0rem;
	font-weight: bold;
	padding-bottom: 60px;
}
.contact_text{
	font-weight: bold;
	padding-bottom: 50px;
}
.contact_item{
	display: flex;
	justify-content: center;
}
.tel{
	font-size: 3.0rem;
	font-weight: bold;
}
.tel_border{
	border: 1px solid;
	margin: 0 70px;
}
.c_contact_btn{
	font-style: normal;
	padding: 15px 45px;
}
.page_top{
	position: fixed;
    display: block;
    bottom: 0;
	right: 0px;
    color: #fff;
    background-color: #024eb6;
    padding: 10px;
}
.fa-angle-up{
	color: #fff;
}
/******************

footer

******************/

.footer{
	color: #fff;
	background-color: #203c7d;
}
.footer_inner{
	max-width: 1080px;
    margin: 0 auto;
    display: flex;
    padding: 60px 40px 40px;
	justify-content: space-between;
}
.f_logo{
	padding-bottom: 25px;
}
.f_logo img{
	width: 50%;
}
.f_contents_2{
	display: inline-block;
    text-align: end;
    align-self: flex-end;
}
.f_contents_2_items{
	display: flex;
    align-items: flex-end;
}
.f_contents_2_items a{
	display: flex;
    align-items: center;
    color: #fff;
}
.f_contents_2_items a:last-child{
	padding-left: 20px;
}
.f_contents_2_items a i{
	padding-right: 5px;
}
.f_contents_2_items p{
	font-size: 1.1rem;
}
.footer small{
	font-size: 1.0rem;
}
@media screen and (max-width:768px){
	body{
		font-size: 1.4rem;
	}
	h1{
		font-size: 4.0rem;
		line-height: 2.5rem;
	}
	.h1_sub{
		font-size: 1.4rem;
	}
	h3{
		font-size: 2.4rem;
		line-height: 20px;
	}
	.h3_sub{
		font-size: 1.2rem;
		font-style: normal;
	}
	.contents_text{
		padding: 30px 0;
		width: 100%;
	}
	.btn{
		padding: 20px 80px;
	}
	._pc{
		display: none;
	}
	._sp{
		display: block;
	}
	.contents_title{
		padding-bottom: 18px;
		justify-content: flex-start;
	}
	.contents_inner{
		max-width: 100%;
		padding: 30px 20px 50px;
	}
	.contents{
		width: 100%;
		margin: 0 auto;
	}
/******************

header

******************/
	.header{
		padding-left: 0;
    	position: fixed;
		z-index: 100;
		background-color: #fff;
	}
	.top_logo{
		margin-right: 0;
		width: 100%;
		padding: 20px;
	}
	.top_logo img{
		width: 25%;
	}
	.drawer-toggle{
		position: fixed;
		top: 25px;
		right: 20px;
		z-index: 1000000;
		cursor: pointer;
		width: 30px;
		height: 34px;
	}
	.sp-btn--open span:nth-of-type(1) {
		top: 0;
	}
	.sp-btn--open span {
		display: inline-block;
		-webkit-transition: all .25s;
		-moz-transition: all .25s;
		-ms-transition: all .25s;
		-o-transition: all .25s;
		transition: all .25s;
		position: absolute;
		left: 0;
		width: 100%;
		height: 1px;
		background-color: #024eb6;
	}
	.sp-btn--open span:nth-of-type(2) {
		top: 7px;
	}
	.sp-btn--open span:nth-of-type(3) {
		top: 15px;
	}
	.sp-btn--open span:nth-of-type(4) {
		bottom: 0;
		font-size: 1.0rem;
		color: #024eb6;
		height: auto;
		background: none;
		text-align: center;
		letter-spacing: 0.05rem;
		white-space: nowrap;
	}
	.sp-btn--open.active{
		top: 30px;
	}
	.sp-btn--open.active span:nth-of-type(1){
		-webkit-transform: rotate(-45deg);
    	transform: rotate(-45deg);
		top:10px;
	}
	.sp-btn--open.active span:nth-of-type(2){
		opacity: 0;
	}
	.sp-btn--open.active span:nth-of-type(3){
		-webkit-transform: rotate(45deg);
    	transform: rotate(45deg);
		top:10px;
	}
	.sp-btn--open.active span:nth-of-type(4){
		top:25px;
	}
	.gnav{
		display: none;
		width: 100vw;
		height: 100vh;
		background-color: #024eb6;
		position: fixed;
		top: 80px;
		}
	.gnav ul{
		flex-wrap: wrap;
		text-align: left;
		}
	.gnav ul li{
		box-sizing: border-box;
		margin: 0 auto;
    	width: 50%;
		padding: 20px 0;
		border-bottom: 0.9px #e9e9e9 solid;
	}
	.gnav ul li:first-child{
		width: 100%;
		text-align: center;
	}
	.gnav ul li:nth-child(2n){
		border-right: 0.9px #e9e9e9 solid;
		padding-left: 5px;
	}
	.gnav ul li a{
		padding-left: 10px;
	}
	.gnav_nopadding{
		padding-left: 0;
	}
	.h_contact_btn{
		padding: 0;
		background-color: #024eb6;
	}
/******************

title

******************/
	.title{
		padding-top: 80px;
	}
	.title h1{
		line-height: 2.5rem;
	}
	.catch{
		display: block;
	}
	.kv{
		width: 100%;
	}
	.kv img{
		height: 200px;
    	object-fit: cover;
	}
	.title_contents{
		margin: 0 auto;
		padding-top: 30px;
		padding-bottom: 18px;
	}
	.pankuzu ul li:first-child {
		margin-left: 0;
	}
/******************

requit

******************/
	.reqruit{
		padding: 50px 0;
    	box-sizing: border-box;
	}
	.reqruit_title{
		padding: 30px 20px;
	}
	.reqruit_title dt{
		font-size: 1.6rem;
    	padding-bottom: 25px;
	}
	.reqruit_title dd{
		font-size: 1.4rem;
	}
	.p-definition-list__item{
		display: block;
    	padding: 10px;
	}
	.p-definition-list__term{
		width: 100%;
	}

/******************

contact

******************/
	.contact{
		padding: 50px 0 0;
	}
	.contact_title{
		font-size: 2.3rem;
    	padding-bottom: 30px;
	}
	.contact_text{
		font-size: 1.1rem;
    	padding-bottom: 30px;
	}
	.contact_item{
		display: block;
	}
	.tel{
		font-size: 2.3rem;
    	padding-bottom: 30px;
	}
	.c_contact_btn{
		padding: 15px 45px;
	}
	.fa-angle-up{
		display: none;
	}
	.page_top{
		padding: 10px 20px;
	}
/******************

footer

******************/
	.footer{
		font-size: 1.1rem;
	}
	.footer_inner{
		max-width: 100%;
		display: block;
		padding: 30px 20px;
		text-align: center;
	}
	.f_logo{
		padding-bottom: 30px;
	}
	.f_logo img{
		width: 28%;
	}
	.footer_tel{
		font-size: 1.7rem;
	}
	.f_contents_2{
		text-align: center;
    	padding: 30px 0;
	}
	.f_contents_2_items{
		padding-bottom: 40px;
	}
}
@media (max-width: 1040px) and (min-width: 769px){
	.top_logo{
		width: 180px;
	}
	
}

a{
	color: #FFFFFF;
	}





































