@charset "Shift_JIS";

/*--------------------------------------------------------
  共通レイアウトパーツ設定
--------------------------------------------------------*/

body{
	background-image : url(../o8b.gif);
  background-position: center;
  background-repeat: repeat;
	background-size: 11px;
	background-color: #fff;
}

/* box-sizeing */
*, *::before, *::after{
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
 }

#hpb-inner::after{
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}


/* ヘッダー内パーツ */
#hpb-header::after{
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}

#hpb-headerLogo{
	margin-top: 10px;
	text-align: left;
	display: block;
	text-decoration: none;
}
#hpb-headerLogo h1{
	font-size: 28px;
	color: #000;
	margin: 0;
	padding: 0;
}

#hpb-headerLogo p{
	margin: 0;
	padding: 0;
	color: #666;
	font-size: 12px;
}


/* フッター内パーツ */
#hpb-footer{
	background-color: #20bc71;
}

#hpb-footerMain{
	padding-top: 18px;
	padding-bottom: 18px;
}

/* コピーライト文字設定 */
#hpb-footerMain p{
	text-align: center;
	margin: 0;
	color: #fff;
}



/*--------------------------------------------------------
  ナビゲーションデザイン設定
--------------------------------------------------------*/

#hpb-nav-list a{
	display: block;
	text-decoration: none;
	border-bottom: 1px solid #c5d9ba;
	padding: 16px 36px 16px 18px;
	color: #000;
	font-size: 14px;
	font-weight: normal;
	text-align: left;
	background-image: url(../img/gnav_imte_01.png);
	background-repeat: no-repeat;
	background-position: center right 12px;
	background-size: 8px auto;
}

#hpb-nav-list li{
	list-style-type: none;
	padding: 0;
	margin: 0;
}

#hpb-nav-list a:hover{
	background-color: #d2f4e0;
}



/*--------------------------------------------------------
  基本パーツデザイン設定
--------------------------------------------------------*/

/* リンク文字色 */
a:link{
	color: #000;
	text-decoration: underline;
}
a:visited{
	color: #000;
	text-decoration: underline;
}
a:hover{
	color: #666;
	text-decoration: none;
}
a:active{
	color: #666;
	text-decoration: none;
}

/* ヘッダースキップの非表示 */
#hpb-skip{
	height: 1px;
	margin: 0;
	padding: 0;
	overflow: hidden;
	text-indent: -9999px;
}

p{
	margin-top: 0.5em;
	margin-bottom: 2em;
	padding-right: 20px;
	padding-left: 0.1em;
	line-height: 1.4;
	text-align: left;
}

p.large{
	font-weight: bold;
	color: #548a04;
	font-size: 1.2em;
}
p.indent{
	padding-left: 25px;
}

.left{
	float: left;
}

img.left{
	margin-left: 14px;
}

.right{
	float: right;
}

img.right{
	margin-right: 24px;
}

hr{
	width: 100%;
	height: 1px;
	margin-top: 10px;
	margin-right: 24px;
	margin-bottom: 20px;
	margin-left: auto;
	padding-top: 0;
	padding-right: 0;
	padding-bottom: 0;
	padding-left: 0;
	clear: both;
	border-top-width: 1px;
	border-top-style: none;
	border-right-width: 1px;
	border-right-style: none;
	border-left-width: 1px;
	border-left-style: none;
	color: #ffffff;
	border-bottom-width: 1px;
	border-bottom-style: none;
}

.hpb-layoutset-02 h2{
	padding-left: 33px;
	padding-top: 0px;
	padding-bottom: 0px;
  text-align: left;
	line-height: 78px;
  color: #fff;
  font-weight: normal;
	font-size: 1.6em;
	letter-spacing: 0.1em;
}

h2 span.en{
	display: none;
}

#hpb-wrapper h3{
	color: #75b400;
	font-size: 1.6em;
	font-weight: normal;
	letter-spacing: 0.1em;
	padding: 10px 10px 0px 10px;
}

h3.hpb-c-index{
	height: 1px;
	margin: 0;
	padding: 0;
	overflow: hidden;
	text-indent: -9999px;
	background: none;
}

h4{
	margin-top: 0;
	margin-right: 24px;
	margin-bottom: 1em;
	margin-left: 0;
	padding-top: 5px;
	padding-right: 10px;
	padding-bottom: 5px;
	padding-left: 10px;
	text-align: left;
	font-size: 1.1em;
	line-height: 1.2;
	color: #0d6138;
	font-weight: bold;
}

h5{
	margin-top: 0;
	margin-bottom: 10px;
	margin-left: 14px;
	margin-right: 14px;
	padding-top: 0;
	padding-right: 10px;
	padding-bottom: 5px;
	padding-left: 0px;
	text-align: left;
	font-size: 1.1em;
	line-height: 1.2;
	border-bottom-width: 2px;
	border-bottom-style: dotted;
	border-bottom-color: #3cc482;
}

table{
	margin-top: 5px;
	margin-right: auto;
	margin-bottom: 5px;
	margin-left: 10px;
	border-collapse: collapse;
	border-top-width: 1px;
	border-top-style: solid;
	border-top-color: #cccccc;
	border-left-width: 1px;
	border-left-style: solid;
	border-left-color: #cccccc;
	width: 90%;
}

table th{
	padding-top: 8px;
	padding-right: 15px;
	padding-bottom: 8px;
	padding-left: 8px;
	text-align: left;
	background-color: #e9faf2;
	border-right-width: 1px;
	border-right-style: solid;
	border-right-color: #cccccc;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #cccccc;
}

table td{
	padding-top: 8px;
	padding-right: 15px;
	padding-bottom: 8px;
	padding-left: 8px;
	text-align: left;
	border-right-width: 1px;
	border-right-style: solid;
	border-right-color: #cccccc;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #cccccc;
}

/* フォームパーツ設定 */
input.button{
	margin-top: 15px;
	margin-right: auto;
	margin-bottom: 15px;
	margin-left: auto;
	padding: 10px;
}

textarea{
	width: 400px;
	height: 200px;
}

input.l{
	width: 400px;
}
input.m{
	width: 250px;
}
input.s{
	width: 150px;
}
#contact form{
	text-align:center;
}
#contact form h3{
	text-align: left;
}
#contact form table{
	margin-left:auto;
}


/* メインコンテンツ内基本パーツ */
#hpb-main p{
	margin-left: 10px;
	margin-right: 10px;
}

#hpb-main ul{
	margin: 20px 0 20px 20px;
	padding: 0;
}

#hpb-main ol{
	margin: 20px 0 20px 20px;
	padding: 0;
}

#hpb-main ul li{
	text-align: left;
	line-height: 1.3;
	padding-left: 0;
	margin-bottom: 8px;
}

#hpb-main dl{
	margin-top: 0;
	margin-right: 15px;
	margin-bottom: 30px;
	margin-left: 10px;
	padding-top: 0;
	padding-right: 0;
	padding-bottom: 0;
	padding-left: 0;
}

#hpb-main dt{
	float: left;
	margin-top: 0;
	margin-right: 0;
	margin-bottom: 0;
	margin-left: 0;
	text-align: left;
	line-height: 16px;
	min-height: 16px;
	font-weight: normal;
	width: 140px !important;
	padding-top: 10px;
	padding-right: 0;
	padding-bottom: 10px;
	padding-left: 20px;
	background-image : url(../img/point_1F1.png);
	background-position: 5px 11px;
	background-repeat: no-repeat;
}

#hpb-main dd{
	margin-top: 0;
	margin-right: 0;
	margin-bottom: 0;
	margin-left: 0;
	padding-top: 10px;
	padding-right: 10px;
	padding-bottom: 10px;
	text-align: left;
	line-height: 16px;
	min-height: 16px;
	padding-left: 165px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #c8dcbd;
}


#hpb-main dl::after{
	content: ".";
	clear: both;
	height: 0;
	display: block;
	visibility: hidden;
}

#hpb-main img.left{
	margin-top: 5px;
	margin-right: 20px;
	margin-bottom: 10px;
	float: left;
}

#hpb-main img.right{
	margin-top: 5px;
	margin-bottom: 10px;
	margin-left: 20px;
	float: right;
}

#pagetop{
  position: absolute;
	bottom: 0;
	right: 20px;
  width: 100%;
  text-align: right;
}

/* ページの先頭へのリンク設定 */
#pagetop a{
  background-color: #20bc71;
	display: inline-block;
	padding: 10px 20px;
	border-top-left-radius: 8px;
	border-top-right-radius: 8px;
}

#pagetop a:link,
#pagetop a:visited{
	color: #fff;
	text-decoration: none;
}

/* サイドブロック内パーツ */
#banner ul{
	margin-top: 0;
	margin-right: 0;
	margin-bottom: 5px;
	margin-left: 0;
	padding-top: 0;
	padding-right: 0;
	padding-bottom: 0;
	padding-left: 0;
	list-style-type: none;
}

#banner li{
	padding-bottom: 4px;
}

#banner li a{
	display: block;
	width: 214px;
	height: 77px;
	text-indent: -9999px;
	overflow: hidden;
}

/* 製品一覧バナー */
#banner a#banner-service{
	background-image : url(banner_1F1_01.png);
	background-position: top left;
	background-repeat: no-repeat;
}

/* 採用情報バナー */
#banner a#banner-recruit{
	background-image : url(banner_1F1_02.png);
	background-position: top left;
	background-repeat: no-repeat;
}

/* アクセスバナー */
#banner a#banner-access{
	background-image : url(banner_1F1_03.png);
	background-position: top left;
	background-repeat: no-repeat;
}

#hpb-inner #companyinfo{
	background-color: #efefef;
	margin-bottom: 10px;
}

#hpb-inner #companyinfo h3{
	background-color: #20b971;
  color: #fff;
  padding: 8px 10px;
	margin: 0;
  font-size: 13px;
	font-weight: bold;
	text-align: center;
}

#hpb-inner #companyinfo-inner{
	padding: 14px 18px;
}

#hpb-inner #companyinfo p{
	margin: 0 0 8px 0;
	padding: 0;
	color: #000;
	font-size: 13px;
}

#hpb-inner h4{
	margin: 0 0 12px 0;
	padding: 0;
	color: #000;
	font-weight: bold;
	font-size: 15px;
}


/* アクセスページ デザイン定義 */
#access h3 + img{
	margin-left: 10px;
	margin-bottom: 10px;
}



/* =======================================================
  レスポンシブル設定
======================================================= */
@media screen and (max-width: 568px) {

	/*--------------------------------------------------------
	  共通レイアウトパーツ設定
	--------------------------------------------------------*/
	#hpb-container{
		width: 100%;
		margin-top: 0;
		background-image: none;
		background-color: #fff;
	}

	/* ヘッダー内パーツ */
	#hpb-header-inner{
		width: 100%;
		padding-bottom: 10px;
		height: 58px;
		border-bottom: none;
	}

	#hpb-headerLogo{
		padding-left: 14px;
	}

	#hpb-headerLogo h1{
		font-size: 22px;
	}

	#pagetop{
		text-align: center;
		left: 0;
	}

	/* フッター内パーツ */
	#hpb-footerMain{
		padding-top: 10px;
		padding-bottom: 10px;
	}

	/* コピーライト文字設定 */
	#hpb-footerMain p{
		padding-left: 5px;
		padding-right: 5px;
		word-break: break-all;
	}

	/*--------------------------------------------------------
	  基本パーツデザイン設定
	--------------------------------------------------------*/
	p{
		padding-right: 0;
		padding-left: 0;
	}

	img.left{
		margin-left: 10px;
		margin-right: 10px;
	}

	img.right{
		margin-left: 10px;
		margin-right: 10px;
	}

	.hpb-layoutset-02 h2{
		width: 96%;
		padding-left: 0;
		padding-top: 25px;
		line-height: 1.4;
		margin-top: 4px;
		margin-right: auto;
		margin-left: auto;
		word-break: break-all;
	}

	table{
		width: 96%;
		margin-right: auto;
		margin-left: auto;
	}

	/* フォームパーツ設定 */
	textarea{
		width: 96%;
	}

	input.l{
		width: 96%;
	}

	input.m{
		width: 60%;
	}

	input.s{
		width: 30%;
	}

	/* メインコンテンツ内基本パーツ */
	#hpb-main h3{
		background-size: contain;
	}

	#hpb-main ul li{
		padding-right: 0;
	}

	#hpb-main dt{
		float: none;
		line-height: 1.4;
		padding-bottom: 0;
	}

	#hpb-main dd{
		line-height: 1.4;
		padding-left: 20px;
		padding-right: 0;
	}

	#hpb-main img.left{
		margin-left: 10px;
		margin-right: 10px;
		float: none;
	}

	#hpb-main img.right{
		margin-left: 10px;
		margin-right: 10px;
		float: none;
	}

	/* サイドブロック内パーツ */
	#banner li a{
		max-width: 100%;
		margin-left: auto;
		margin-right: auto;
	}

	#banner a#banner-service,
	#banner a#banner-recruit,
	#banner a#banner-access{
		background-position: top center;
		background-size: contain;
	}

	#hpb-inner #companyinfo{
		margin-bottom: 0;
		margin-left: auto;
		margin-right:auto;
		width: 96%;
	}

	/* トップページ デザイン定義 */
	#toppage p.large{
		margin-left: 0;
		margin-right: 0;
	}

	/* アクセスページ デザイン定義 */
	#access h3 + img{
		margin-left: 10px;
		margin-right: 10px;
		max-width: 96%;
		height: auto;
	}

}
