@charset "UTF-8";

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

	共通コンテンツ部

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

body{
	position: relative;
	color: #333333;
	font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", sans-serif;
	line-height: 1.6;
	word-wrap: break-word;
	font-size: 16px;
}

.mincho{
	font-family: A1 Mincho,Times New Roman, "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "メイリオ", Meiryo, serif;
}

.en{
	font-family: 'Roboto', sans-serif;
}

a:hover,
a:hover img{
	opacity: 0.8;
}

a img,
a:hover img{
   -webkit-transition: all 0.2s linear;
   -webkit-transition: -webkit-all 0.2s linear;
   -moz-transition: all 0.2s linear;
   -o-transition: all 0.2s linear;
   -ms-transition: all 0.2s linear;
   transition: all 0.2s linear;
}

.fade image,
.fade{
   -webkit-transition: all 0.2s linear;
   -webkit-transition: -webkit-all 0.2s linear;
   -moz-transition: all 0.2s linear;
   -o-transition: all 0.2s linear;
   -ms-transition: all 0.2s linear;
   transition: all 0.2s linear;
}

a{
	color: #A26363;
	text-decoration: none;
}

a:hover{
	text-decoration: none;

   -webkit-transition: all 0.2s linear;
   -webkit-transition: -webkit-all 0.2s linear;
   -moz-transition: all 0.2s linear;
   -o-transition: all 0.2s linear;
   -ms-transition: all 0.2s linear;
   transition: all 0.2s linear;
}

.pc-on{ display: block; }
.sp-on{ display: none; }

.fit{
	width: 100%;
	height: auto;
}

::selection {
    background: #acacac;
    color: #fff;
}

//Firefox
::-moz-selection {
    background: #acacac;
    color: #fff;
}


.wrapper{
	width: 1170px;
	margin: 0 auto;
	position: relative;
	box-sizing: border-box;
}


/******************** header ********************/

header{

}

header #head01{
	width: 1170px;
	margin: 0 auto;
	position: fixed;
	top: 0;
	left: 50%;
	transform: translate(-50%, 0);
	background: #2086D1;
	border-radius: 0 0 14px 14px;
	display: table;
	padding: 17px 0 19px;
	z-index: 50;
   -webkit-transition: all 0.6s linear;
   -webkit-transition: -webkit-all 0.6s linear;
   -moz-transition: all 0.6s linear;
   -o-transition: all 0.6s linear;
   -ms-transition: all 0.6s linear;
   transition: all 0.6s linear;
}

header #head01.active{
	width: 100%;
	border-radius: 0;
	padding: 8px 0 8px;
	padding-left: 4%;
	padding-right: 4%;
	box-sizing: border-box;
}

header #head01 nav,
header #head01 .head_logo{
	display: table-cell;
	vertical-align: middle;
}

header #head01 .head_logo{
	padding: 0 0 0 40px;
}

header #head01 nav{
	
}

header #head01 nav > ul{
	float: right
}

header #head01 nav > ul > li{
	float: left;
	width: 140px;
	position: relative;
}

header #head01 nav > ul > li.contact{
	width: 200px;
}

header #head01 nav > ul > li > a{
	display: block;
	line-height: 40px;
	font-size: 16px;
	color: #fff;
	text-align: center;
	letter-spacing: 3px;
	border-left: 1px solid #84DEF8;
}

header #head01 nav > ul > li.contact > a{
	background: url(/wp_common/images/common/icon_contact01.png) no-repeat 41px 50%;
	padding-left: 35px;
}

header #head01 nav > ul > li > ul{
	position: absolute;
	width: 840px;
	top: 40px;
	left: -120px;
	overflow: hidden;
	height: 0;
	opacity: 0;
   -webkit-transition: all 0.2s linear;
   -webkit-transition: -webkit-all 0.2s linear;
   -moz-transition: all 0.2s linear;
   -o-transition: all 0.2s linear;
   -ms-transition: all 0.2s linear;
   transition: all 0.2s linear;
}

header #head01 nav > ul > li:hover > ul{
	height: auto;
	opacity: 1;
   -webkit-transition: all 0.2s linear;
   -webkit-transition: -webkit-all 0.2s linear;
   -moz-transition: all 0.2s linear;
   -o-transition: all 0.2s linear;
   -ms-transition: all 0.2s linear;
   transition: all 0.2s linear;
}

header #head01 nav > ul > li > ul > li{
	float: left;
	width: 140px;
	overflow: hidden;
}

header #head01 nav > ul > li > ul > li:first-child{
	border-radius: 0 0 0 8px;
}

header #head01 nav > ul > li > ul > li:last-child{
	border-radius: 0 0 8px 0;
}

header #head01 nav > ul > li > ul > li a{
	display: block;
	background: #fff;
	padding: 10px;
	font-size: 11px;
	color: #1C659C;
	text-align: center;
	line-height: 1.2;
}

header #head01 nav > ul > li:hover > ul > li a{
	opacity: 1;
}

header #head01 nav > ul > li > ul > li a:hover{
	background: #2086D1;
	color: #fff;
	opacity: 1;
}

header #head01 nav > ul > li > ul > li a .image{
	display: block;
	margin: 0 0 8px;
}



header #head02{
	width: 1170px;
	margin: 0 auto;
	position: fixed;
	top: 58px;
	left: 50%;
	transform: translate(-50%, 0);
	background: #1C659C;
	border-radius: 0 0 14px 14px;
	display: table;
	padding: 30px 0 10px;
	z-index: 30;
   -webkit-transition: all 0.6s linear;
   -webkit-transition: -webkit-all 0.6s linear;
   -moz-transition: all 0.6s linear;
   -o-transition: all 0.6s linear;
   -ms-transition: all 0.6s linear;
   transition: all 0.6s linear;
}

header #head02.active{
	width: 100%;
	border-radius: 0;
	top: 45px;
	padding-left: 4%;
	padding-right: 4%;
	box-sizing: border-box;
}

header #head02 .sys_link02,
header #head02 .sys_link,
header #head02 .description{
	display: table-cell;
	vertical-align: middle;
}

header #head02 .description{
	padding-left: 40px;
	font-size: 14px;
	color: #fff;
	line-height: 1;
}

header #head02 .sys_link02,
header #head02 .sys_link{
	width: 213px;
	padding-left: 0px;
}

header #head02 .sys_link02 a,
header #head02 .sys_link a{
	width: 204px;
	display: block;
	line-height: 39px;
	font-size: 14px;
	color: #005da1;
	font-weight: bold;
	text-align: center;
	background: rgba(255,255,255,0.9);
	border-radius: 8px;
	box-sizing: border-box;
}


#loader-bg {
	display: none;
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;
	background: #fff;
	z-index: 999;
}
#loader {
	display: none;
	position: fixed;
	top: 50%;
	left: 50%;
	width: 180px;
	height: 180px;
	margin-top: -100px;
	margin-left: -100px;
	text-align: center;
	color: #fff;
	z-index: 2;
}


/******************** footer ********************/

/***** リンクエリア *****/

#link_area{
	width: 1117px;
	margin: 0 auto;
	padding: 40px 0 0;
	border-top: 1px solid #1464A3;
	display: table;
}

#link_area #catalog_area,
#link_area #banner_area{
	display: table-cell;
	vertical-align: middle;
	text-align: center;
}

#link_area #banner_area ul li{
	/*float: left;*/
	display: inline-block;
	margin: 0 8px;
}

#link_area #catalog_area{
	width: 360px;
}

#link_area #catalog_area a{
	display: block;
	box-shadow:0px 2px 5px 2px #cececc;
	color: #5e5c52;
	padding: 20px 23px;
}

#link_area #catalog_area a .title{
	display: block;
	font-size: 24px;
	font-weight: bold;
	line-height: 1;
	margin: 0 0 18px;
}

#link_area #catalog_area a .catalog_wrapp{
	display: flex;
	flex-direction: row-reverse;
	align-items: center;
}

#link_area #catalog_area a .catalog_wrapp .image{
	width: 96px;
}

#link_area #catalog_area a .catalog_wrapp .text{
	width: 218px;
	box-sizing: border-box;
	padding-right: 14px;
	font-size: 15px;
}

#page-top{
	position: fixed;
	bottom: 90px;
	right: 30px;
	text-align: center;
	z-index: 90;
}

footer{
	background: #005DA3;
}

footer .footer_link{
	width: 1170px;
	margin: 0 auto;
	padding: 26px 0 40px;
	line-height: 1;
}

footer .footer_link ul{
	float: right;
}

footer .footer_link ul li{
	float: left;
	margin-right: 15px;
}

footer .footer_link ul li:last-child{
	margin-right: 0;
}

footer .footer_link ul li a{
	display: block;
	line-height: 15px;
	font-size: 14px;
	color: #fff;
	text-decoration: none;
	background: url(/wp_common/images/common/icon_arrow01.png) no-repeat 0 0;
	padding-left: 17px;
}


footer .copyright{
	background: #001554;
}

footer .copyright .footer_wrapper{
	width: 1170px;
	margin: 0 auto;
	padding: 45px 0 55px;
	display: table;
}

footer .copyright .footer_wrapper .footer_logo02,
footer .copyright .footer_wrapper .text,
footer .copyright .footer_wrapper .footer_logo01{
	display: table-cell;
	vertical-align: middle;
}

footer .copyright .footer_wrapper .footer_logo01{
	width: 344px;
}

footer .copyright .footer_wrapper .text{
	width: auto;
	font-size: 12px;
	color: #fff;
	padding: 7px 0 0;
}

footer .copyright .footer_wrapper .footer_logo02{
	width: 213px;
}

footer .copyright .sp_copy{
	display: none;
}



/******************** contents ********************/

main{
	padding: 117px 0 58px;
	background-image: url(/wp_common/images/common/page_bg01.jpg);
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: 100%;
}

main.top{
	padding: 0 0 58px;
}

main.recruit{
	background-image: none;
}

#breadcrumbs{
	width: 1170px;
	margin: 0 auto 50px;
}

#breadcrumbs span,
#breadcrumbs a{
	font-size: 12px;
	color: #000;
}


#page{
	width: 1117px;
	margin: 0 auto;
	padding: 30px 0 65px;
	position: relative;
	z-index: 10;
}

h2{
	font-size: 22px;
	font-weight: bold;
	margin: 0 0 12px;
}


.date .category-box a{
	background: #ccc;
}

.date .category-box a.news{
	background: #ff0000;
}

.date .category-box a.news{
	background: #669900;
}

.date .category-box a.out{
	background: #FF3333;
}

.date .category-box a.specification{
	background: #FF9900;
}

.date .category-box a.other{
	background: #2086D1;
}



/******************** 404 ********************/

#notfound_wrapp{
	width: 800px;
	margin: 0 auto;
	padding: 60px 0 160px;
	text-align: center;
}

#notfound_wrapp .image{
	margin: 0 0 60px;
}

#notfound_wrapp h2{
	margin: 0 0 40px;
}


/********************************************************************************
	リキッド用 CSS
********************************************************************************/

@media screen and (max-width:1117px){

#page {
    width: 100%;
}

}


/********************************************************************************
	スマートフォン用 CSS
********************************************************************************/

@media screen and (max-width:767px){

html { font-size: 62.5%; }
body {
	font-size: 1.4rem;
	-webkit-text-size-adjust:100%;
}

.sp-on{ display: block !important; }
.pc-on{ display: none !important; }


.wrapper{
	width: auto;
	margin: 0 auto;
}


/******************** header ********************/

header #head01{
	width: auto;
	background: transparent;
	border-radius: 0;
	display: block;
	padding: 0;
	z-index: 110;
	left: 0;
	transform: translate(0, 0);
}

header #head01 nav,
header #head01 .head_logo{
	display: block;
}

header #head01 .head_logo{
	padding: 0;
	width: 210px;
	position: fixed;
	top: 16px;
	left: 14px;
}

header #head01 nav{
	
}

header #head01 nav > ul > li > ul > li a{
	display: table;
}

.mean-container .mean-nav ul li span.image{
	display: inline-block;
	vertical-align: middle;
	margin: 0;
	float: none;
	width: 20%;
	border-top: none;
}

.mean-container .mean-nav ul li span.text{
	display: inline-block;
	vertical-align: middle;
	margin: 0;
	float: none;
	width: auto;
	border-top: none;
}



header #head02{
	display: none;
}

.mean-container .mean-nav ul li.contact a{
	background: url(/wp_common/images/common/icon_contact01.png) no-repeat 16px 50% #2086D1;
	color: #fff;
	padding-left: 48px;
}

.mean-container .mean-nav ul li.cart a{
	/*background: url(/wp_common/images/common/icon_cart01.png) no-repeat 14px 50% #E4F1F7;
	background-size: 23px;*/
	background: #E4F1F7;
	color: #005CA2;
	/*padding-left: 48px;*/
}




/******************** footer ********************/

/***** リンクエリア *****/

#link_area{
	width: auto;
	margin: 0 6%;
	padding: 20px 0 0;
	display: block;
}

#link_area #catalog_area,
#link_area #banner_area{
	display: block;
}

#link_area #banner_area ul li{
	float: left;
	display: block;
	width: 48%;
	margin: 0 0 15px;
}

#link_area #banner_area ul li:nth-child(even){
	float: right;
}


#link_area #catalog_area{
	width: 70%;
	margin: 15px auto 0;
}

#link_area #catalog_area a{
	padding: 14px;
}

#link_area #catalog_area a .title{
	display: block;
	font-size: 1.5rem;
	margin: 0 0 8px;
}

#link_area #catalog_area a .catalog_wrapp{
	display: flex;
	flex-direction: row-reverse;
	align-items: center;
}

#link_area #catalog_area a .catalog_wrapp .image{
	width: 25%;
}

#link_area #catalog_area a .catalog_wrapp .text{
	width: 75%;
	padding-right: 12px;
	font-size: 1.2rem;
	line-height: 1.4;
}


#page-top{
	bottom: 50px;
	right: 10px;
	width: 40px;
}


footer .footer_link{
	width: auto;
	margin: 0 auto;
	padding: 0px 0;
}

footer .footer_link ul{
	float: none;
}

footer .footer_link ul li{
	float: none;
	margin-right: 0;
	border-bottom: 1px solid #006FBF;
}

footer .footer_link ul li:last-child{
	border-bottom: none;
}

footer .footer_link ul li a{
	line-height: 1;
	font-size: 1.3rem;
	background: url(/wp_common/images/common/icon_arrow01.png) no-repeat 10px 50%;
	padding: 13px 0 13px 27px;
}


footer .copyright .footer_wrapper{
	width: auto;
	margin: 0 auto;
	padding: 20px 6% 10px;
	display: block;
}

footer .copyright .footer_wrapper .footer_logo02,
footer .copyright .footer_wrapper .text,
footer .copyright .footer_wrapper .footer_logo01{
	display: block;
}

footer .copyright .footer_wrapper .footer_logo01{
	width: 58%;
	float: left;
}

footer .copyright .footer_wrapper .text{
	display: none;
}

footer .copyright .footer_wrapper .footer_logo02{
	width: 30%;
	float: right;
}

footer .copyright .sp_copy{
	display: block;
	font-size: 0.8vw;
	color: #fff;
	text-align: center;
}



/******************** contents ********************/

main{
	padding: 15px 0 40px;
	background-position: 0 55px;
}

main.top{
	padding: 55px 0 40px;
}

#breadcrumbs{
	width: auto;
	margin: 0 0 34px;
}

#breadcrumbs span,
#breadcrumbs a{
	font-size: 1.1rem;
}


#page{
	width: auto;
	padding: 50px 6% 30px;
}

h2{
	font-size: 1.8rem;
	margin: 0 0 8px;
	text-align: center;
}



/******************** 404 ********************/

#notfound_wrapp{
	width: auto;
	padding: 40px 0 60px;
}

#notfound_wrapp .image{
	width: 60%;
	margin: 0 auto 40px;
}

#notfound_wrapp h2{
	margin: 0 0 20px;
}

#notfound_wrapp h2 span{
	display: block;
	margin: 8px 0 0;
}



}
