@charset "utf-8";
/*
Theme Name: NPS
Description: NPSテーマファイル
Version: 1.0
Author: MegumiM
Tags: 
*/



/*===============
base
=================*/
* { box-sizing: border-box; }
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,
form,input,p,th,td {
margin:0;
padding:0;
}  
img {
	border-top-style: none;
	border-right-style: none;
	border-bottom-style: none;
	border-left-style: none;
	font-size: 0%;
	line-height: 0%;
	vertical-align: bottom;
    width: 100%;
    height: auto;	
}



html {
	overflow-y: scroll;
	font-size: 62.5%;
	scroll-padding-top:120px;	
}
body{
	font-size:1.6rem; /* =16px */
    font-family:"Noto Sans JP",sans-serif;
	line-height: 1.8;
	color: #333333;
	margin: 0; padding: 0;
	overflow-x:hidden;
}
@media screen and (max-width: 768px) {
	body {
		font-size:1.4rem;/* 14px*/
		background-image:none;
	}
}
@media screen and (max-width: 640px) {
	html,
	body { overflow-x: hidden; max-width: 100%; }
	}

a:link,
a:visited,
a:active{
	color: #333;
	text-decoration: underline;
}

a:hover{
	text-decoration: underline;
}

/* 横幅が768px以上で、電話番号リンクは無効 */
@media (min-width: 768px) {
	a[href*="tel:"] {
	pointer-events: none;
	cursor: default;
	text-decoration: none;
	}
}


ul,ol{
list-style: none;
}

/*clearfix*/
.clearfix:after,
.recruit_p:after
{  
visibility:hidden;/*見えなくする*/ 
height:0;/*見えなくする*/
display: block;/*block要素にする*/
font-size: 0;  
content: " ";  
clear: both;  

}  
* html .clearfix             { zoom: 1; } /* IE6 */  
*:first-child+html .clearfix { zoom: 1; } /* IE7 */


.mb0 { margin-bottom: 0 !important; }
.mb10 { margin-bottom: 10px !important; }
.mb15 { margin-bottom: 15px !important; }
.mb20 { margin-bottom: 20px !important; }

.mt50 { margin-top: 50px !important; }
.mt60 { margin-top: 60px !important; }

.al_left { text-align: left; }
.al_right { text-align: right; }
.al_center { text-align: center; }

.t_red { color: #ff0000; }

.no_border_btm { border-bottom: none !important; } 


.pc {}
.sp { display: none !important; }




@media screen and (max-width: 640px) {
	.pc { display: none !important; }
	.sp { display: block !important; }
	.scroll_x {
	  overflow-y: hidden;
	  overflow-x: scroll;
	-webkit-overflow-scrolling: touch;	
	}
	.scroll_x::-webkit-scrollbar {
	  height: 10px;
	}	
}


/*ページネーション*/
div.pagination {
	clear:both;
	padding:20px 0;
	position:relative;
	font-size:11px;
	line-height:13px ;
	background:none;
	margin:10px 0 20px;
	vertical-align: middle;
}

div.pagination span, .pagination a {
	display:block;
	float:left ;
	margin: 2px 2px 2px 0 ;
	padding:6px 9px 5px 9px ;
	text-decoration:none;
	width:auto ;
	color:#fff ;
	background: #666 ;
}

div.pagination a:hover{
	color:#fff ;
	background: #fdcd1a;
}

div.pagination .current{
	padding:6px 9px 5px 9px ;
	background: #fdcd1a;
	color:#fff ;
}

/* reCAPTCHAマーク　非表示 */
.grecaptcha-badge { visibility: hidden; }



/*---------------------------------------------------------------------------
　header .inner
---------------------------------------------------------------------------*/
/*==============================
.inner
================================*/
/* header {
  top: 0;
  left: 0;
  z-index: 9999;
  width: 100%;
  height: 220px;
	background: #fff;
  transition: .3s;
} */
/* header */
header {
	background-color: #fff;
    width: 100%;
	margin: 0 auto;
    padding: 0;
    line-height: 1;
    position: absolute; z-index: 999;
}
header * {  }

header .inner {
	position: relative;
	width: 98%;
	max-width: 1400px;
	height: 100px;
	margin: 0 auto;
	padding: 30px 0 0;
}

header .inner .logo {
	display: inline-block;
	font-size: 30px; color: #000;
}
header .inner .logo img {
    max-width: 105px; height: auto;
}

header .inner h2 {
	color: #4d4d4d;
	font-size: 1.0rem; font-weight: normal; line-height: 1.4;
	margin: 0;
	text-align: left;
	width: 100%;
	position: absolute; left: 0; top: 10px;
}

header #mobile-head {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
}
/*
header .htel { position: relative; }
header .htel .num {
	font-size: 1.8em; font-weight: 600;
	color: #0071bb;
	margin: 0;
}
header .htel .num i {
	font-size: .75em;
}
header .htel .head_txt{
	font-size: .8em; color: #7d7d7d;
	position: absolute; right: 0; top: 0; transform: translateY(-125%);
	white-space: nowrap;
	line-height: 1.4;
}

@media screen and (max-width: 1080px) {
	header .inner h2 {
		font-size: .75em; line-height: 1.2;
		margin: .4em 1% -1.5em;
	}	
	header .inner h2 br {
		display: none;
	}	
}
*/
@media screen and (max-width: 640px) {
	header { min-width:auto; }
	header .inner { 
		height: 60px;
		margin: 0 auto 0;
	}
	header .inner .logo img {
		max-width: 150px; height: auto;
	}	
}


/*==============================
#global-nav
================================*/
#global-nav > ul {
	margin: 0;
    list-style: none;

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

#global-nav > ul > li {
    display: inline-block;
	/* width: calc(100% / 8); */
	text-align: center;
	box-sizing: border-box;
	font-size: 0.9375em;
	white-space: nowrap;
	position: relative;
	
}
/* #global-nav ul li::before {
	content: '';
	display: block;
	width: 1px;
	height: 150%;
	background: #999;
	position: absolute; left: -15px; top: -25%; 
}*/
#global-nav ul li a {
	width: 100%; height: 100%; display: block;
	transition:all .3s;
	padding: 0 10px;
	text-decoration: none;
	border-left: solid 1px #999;
	transition: .3s;
}
#global-nav ul li a:hover {
	color: #2566A7;
}
#global-nav ul li:nth-of-type(7) a {
	border-right: none;
}

#global-nav ul li a > img {
	width: 100%; height: auto; display: block;
	transition: 0.2s ;
}

#global-nav ul li a.contact {
	display: block;
	text-align: center;
	vertical-align: middle;
	text-decoration: none;
	width: auto;
	margin: auto;
	padding: 1rem 3rem;
	color: #000;
	border: 2px solid #000;
	transition: .3s;
}
#global-nav ul li a.contact:hover {
	color: #fff;
	background-image: linear-gradient(to left, #C9DDF0 0%, #5F9AD2 100%);
	border: 2px solid #eee;
}


#global-nav ul ul{
	display: block;
}


/*== 2・3階層目の共通設定 */

/*下の階層を持っているulの指定*/
#global-nav li.has-child ul{
    /*絶対配置で位置を指定*/
	position: absolute;
	left:0;
	top:30px;
	z-index: 4;
    /*形状を指定*/
	background:rgba(0,98,163,0.95);
    /*はじめは非表示*/
  visibility: hidden;
  opacity: 0;
    /*アニメーション設定*/
	transition: all .3s;
}
#global-nav li.has-child li a {
	display: block;
	text-decoration: none;
	color: #fff;
	padding:20px 35px;
	transition:all .3s;	
	/* border-bottom:solid 1px rgba(255,255,255,0.6); */
}
#global-nav li.has-child li a:hover {
	background:rgba(0,0,0,0.2);
}

#global-nav li.has-child li:last-child a {
	border-bottom:none;
}

/*hoverしたら表示*/
#global-nav li.has-child:hover > ul,
#global-nav li.has-child ul li:hover > ul,
#global-nav li.has-child:active > ul,
#global-nav li.has-child ul li:active > ul{
  visibility: visible;
  opacity: 1;
}




/*==============================
Fixed
================================*/

/* Fixed */
#top-head.fixed {
    margin-top: 0;
    top: 0;
    position: fixed;
    height: 100px;
    /* background: #fff;
    background: rgba(255,255,255,.95); */
    transition: top 0.65s ease-in;
    -webkit-transition: top 0.65s ease-in;
    -moz-transition: top 0.65s ease-in;
	 box-shadow: 0 10px 15px -10px;
}
#top-head.fixed .inner { height: 100px; }

#top-head.fixed .header_right {
	display: none;
}
#top-head.fixed .inner .logo {
}


/* Toggle Button */
#nav-toggle {
    display: none;
    position: absolute;
    right: 12px;
    top: 15px;
    width: 40px;
    height: 40px;
    cursor: pointer;
    z-index: 101;
    padding: 5px 5px 0;
    background: #000;
    border: solid 2px #000;
}
#nav-toggle div {
    position: relative;
}
#nav-toggle span {
    display: block;
    position: absolute;
    height: 3px;
    width: 100%;
    background: #fff;
	border-radius: 50vh;
    left: 0;
    -webkit-transition: .35s ease-in-out;
    -moz-transition: .35s ease-in-out;
    transition: .35s ease-in-out;
}
#nav-toggle span:nth-child(1) {
    top: 2px;
}
#nav-toggle span:nth-child(2) {
    top: 11px;
}
#nav-toggle span:nth-child(3) {
    top: 20px;
}
#nav-toggle span:nth-child(4) {
    top: 22px;
	font-size: 6.0px;
	text-align: center;
}

@media screen and (max-width: 1080px) {
    header,
    header .inner {
        width: 100%;
        padding: 0;
		height: 65px;
    }
header .inner h2 {
	position: absolute; left: 110px; top: 50%; transform: translateY(-50%);
	display: inline-block;
	width: auto;
}	
    #top-head {
        top: 0;
        position: fixed;
        margin-top: 0;
    }
    /* Fixed reset */
    #top-head.fixed {
        padding-top: 0;
		height: 65px;
    }
    #mobile-head {
        width: 100%;
        height: 70px;
        z-index: 999;
        position: relative;
    }
    #top-head.fixed .logo,
    #top-head .logo {
        position: absolute;
        left: 13px;
        top: 10px;
        width: 50%;
    }
	
	#top-head.fixed .inner { height: 60px; }
	#top-head.fixed .inner .logo {
	display: block;
	}
	#top-head .inner .logo img {
    width: auto; height: 50px;
	}
	#top-head .htel {
		display: none;
	}

    #global-nav {
        position: absolute;
        /* 開いてないときは画面外に配置 */
        right: -100vw; top: 65px;
        /* background: rgba(147,189,81,0.98); */
		background: rgba(29,82,134,0.95);
        width: 100vw; height: 100vh;
        text-align: center;
        padding: 1em 1em;
        -webkit-transition: .5s ease-in-out;
        -moz-transition: .5s ease-in-out;
        transition: .5s ease-in-out;
		display: block;
    }
    #global-nav ul {
        list-style: none;
        position: static;
        right: 0;
        bottom: 0;
        font-size: 14px;
    }
	
    #global-nav > ul > li {
        float: none;
        position: static;
		display: inline-block;
		width: 90%; max-width:none;
		height: auto;
		text-align: center;
		box-sizing: border-box;
		border-left: none; border-right: none !important;
		border-bottom: dotted 1px #fff;
		margin: 0 auto;
}
	    #global-nav > ul > li:last-of-type {
		border-bottom: none;
		margin: 10px auto;
}
	
    #top-head #global-nav ul li a,
    #top-head.fixed #global-nav ul li a {
		width: 100%;
		display: block;
		color: #fff;
		padding: 1em 20px;
		font-size: 14px;
		text-align: left;
		text-decoration: none;
		border-right: none !important;
		border-left: none !important;
    }
	#top-head #global-nav ul li a.contact {
		border-radius: 0;
		border: solid 2px #fff !important;
	}
    #nav-toggle {
        display: block;
    }
    /* #nav-toggle 切り替えアニメーション */
    .open #nav-toggle span:nth-child(1) {
        top: 12px;
        -webkit-transform: rotate(315deg);
        -moz-transform: rotate(315deg);
        transform: rotate(315deg);
    }
    .open #nav-toggle span:nth-child(2) {
        width: 0;
        left: 50%;
    }
    .open #nav-toggle span:nth-child(3) {
        top: 12px;
        -webkit-transform: rotate(-315deg);
        -moz-transform: rotate(-315deg);
        transform: rotate(-315deg);
    }
    /* #global-nav スライドアニメーション */
    .open #global-nav {
        /* #global-nav top + #mobile-head height */
        -moz-transform: translateX(-100vw);
        -webkit-transform: translateX(-100vw);
        transform: translateX(-100vw);
	}

}

/* .has-child ul　ドロップダウンメニュー */
@media screen and (max-width: 1080px) {

	#global-nav li.has-child ul {
		position: relative;
		left:0;
		top:0;
		width:100%;
		visibility:visible;/*JSで制御するため一旦表示*/
		opacity:1;/*JSで制御するため一旦表示*/
		display:block;/*JSで表示させるため非表示に*/
		transition:none;/*JSで制御するためCSSのアニメーションを切る*/
		background: rgba(0,0,0,0.5);
		display: flex;
		justify-content: flex-start;
		flex-wrap: wrap;		
	}		
	#global-nav ul {
		display: block;
		margin: 0;
	}
	#global-nav li.has-child ul li { 
		width: 100% !important;
		position: relative;
	}
		#global-nav li.has-child ul li::before { 
			content: "";
			width: 10px; height: 10px;
			display: inline-block;
			border-left: solid 2px #fff;
			border-bottom: solid 2px #fff; 
			position: absolute; left: 20px; top: 10px;
	}
	#global-nav li.has-child ul li a {
		padding: 1em 20px 1em 40px !important;
	}
	
}



/*---------------------------------------------------------------------------
　footer
---------------------------------------------------------------------------*/
/*==============================
footer .inner
================================*/
footer {
	background: #fff;
}
footer .footer__bnr_area {
	background: #2566A7/*#36395b*/;
	color: #fff;
}
footer .footer__bnr_area h3 {
	line-height: 1.4;
	text-align: center;
}
footer .footer__bnr_area h3 .jp {
	font-size: 1.8em;
	display: inline-block;
	position: relative;
}
footer .footer__bnr_area h3 .jp::before,
footer .footer__bnr_area h3 .jp::after {
	content: "";
	background-color: #fff;
	width: 80px; height: 1px;
	position: absolute; top: 50%;
}
footer .footer__bnr_area h3 .jp::before {
	left: 0; transform: translateX(-120%);
}
footer .footer__bnr_area h3 .jp::after {
	right: 0; transform: translateX(120%);
}
footer .footer__bnr_area .inner > p {
	text-align: center;
	margin: 30px auto;
}
ul.wrap_bnr { align-items: center; }
ul.wrap_bnr li {
	width: 50%;
}
ul.wrap_bnr li.tel {
	border-right: solid 1px #fff;
}
ul.wrap_bnr .tel a {
	color: #fff;
	text-decoration:none;
	text-align: center;
}
ul.wrap_bnr .tel a .num {
	font-size: 2.0em; font-weight: 600;
	margin: 0 0 10px;
}

ul.wrap_bnr li.contact {
	padding: 20px 40px;
}
ul.wrap_bnr li.contact a {
	background-color: #fff;
	font-size: 1.5em;
	width: 100%;
	padding: 20px;
	display: flex; justify-content: space-around; align-items: center;
	text-decoration: none;
}
ul.wrap_bnr li.contact .arrow{
	display: inline-block;
    line-height: 1;
    position: relative;
    width: 20px;
    height: 5px;
    border-right: 1px solid #000;
    border-bottom: 1px solid #000;
    transform: skew(45deg);	
}

@media screen and (max-width: 640px) {
	ul.wrap_bnr li {
		width: 100%;
	}
	ul.wrap_bnr li.tel {
		border-right: none;
	}	
}




footer .inner {
	width: 100%;
	max-width: 1100px;
	margin: 0 auto;
	padding: 3em 0;	
}

footer .inner .logo {
	display: block;
	text-align: center;
	margin: 0 auto 10px;
	width: 50%;
}
footer .inner .logo img {
    max-width: 125px; height: auto;
}
footer .tel,
footer .time {
	text-align: center;
}
footer .company_name {
	text-align: center;
	font-weight: bold;
}
footer .add {
	text-align: center;
	font-size: .8em;
}

footer .footer_content {
	background-color: #0071bb;
}
footer .footer_content .inner {
	width: 100%;
	max-width: 1400px;
	margin: 0 auto;
	padding: 3em 0;	
}

footer .sdgs {
	padding: 10px 0;
}
footer .sdgs img {
	width: auto; height: 24px;
}

.wrap_fnav {
	display:flex;
	justify-content:space-between;
	flex-wrap:wrap; align-items:start;
}
.fnav { 
	display: flex;
	justify-content: flex-start; flex-wrap:wrap; 
}
.fnav li { 
	list-style: none;
	display: inline-block;
	padding: 0 1em;
	border-left: solid 1px #999;
	margin: 5px 0;
		
}
.fnav li:last-of-type { 
	border-right: solid 1px #999;
}

.fnav li a {
	color: #000; text-decoration: none;
	font-size: .85em;
}

@media screen and (max-width: 640px) {
	footer .inner { 
		width: 95%; margin: 0 auto;
	}
	footer .inner .logo {
		width: 50%;
	}	
}






.copyright {
	color: #000;
	font-size: 80%;
	padding: 1em;
	text-align: center; }



@media screen and (max-width: 640px) {
	footer .wrap_info {
		justify-content: center;
		margin-top: 0;
	}	
	.wrap_fnav {
		justify-content:center;
	}	
	footer .fnav {
		display: none;
	}	
}


.fnav_sp {
    width: 100%;
    position: fixed;
    bottom: 0%;
    left: 0%;
    z-index: 9998;
	display: none;
	background: #59b0c0;
}
.fnav_sp ul {
	display: flex;
	justify-content: center;
}
.fnav_sp li {
    width: calc(100% / 1);
	max-width: 300px;
    margin: 0 auto;
}
@media screen and (max-width: 640px) {
	.fnav_sp {
		display: block;
	}
}
