@charset "UTF-8";

/*------------------------------------------------------------------------------
reset.css 2014.03.18
-------------------------------------------------------------------------------*/
html { overflow-y: scroll; }
article, aside, canvas, details, figcaption, figure, header, footer, hgroup, menu, nav, section, summary { display: block; }
body, div, dl, dt, dd, ul, ol, li, pre, code, form, fieldset, legend, input, textarea, p, blockquote, th, td { margin: 0; padding: 0; }
address, caption, cite, code, dfn, em, strong, th, var { font-style: normal; }
img, abbr, acronym, fieldset, a img { border: none; }
q:before, q:after { content: ''; }
object, embed { vertical-align: top; }
table { border-collapse: collapse; border-spacing: 0; }
h1, h2, h3, h4, h5, h6 { font-weight: bold; font-size: 100%; margin: 0; padding: 0; }
a { outline: none; cursor: pointer; }
ul,ol { list-style-type: none; }
sup { vertical-align:text-top; }
sub { vertical-align:text-bottom; }
input[type=checkbox], input[type=radio], input[type=submit], button, label { cursor: pointer; }
.clearfix:after{ content : ''; font-size: 0; height : 0px; display : block; clear : both; visibility : hidden; }
* html .clearfix, *:first-child+html .clearfix{ zoom: 1; }

/*------------------------------------------------------------------------------
基本スタイル系
-------------------------------------------------------------------------------*/
ul { list-style-type: none; }
ol { list-style-type: decimal; }
ol, ul, dl { margin-bottom: 1em; }
img { vertical-align: bottom; }
p { line-height: 1.8; margin-bottom: 1em; }
/*a { text-decoration: none; }*/
a:link { color: #036EB8; text-decoration: underline; }
a:visited { color: #606; text-decoration: underline; }
a:hover { color: #F60; text-decoration: underline; }
a:active { color: #C00; text-decoration: underline; }
a:hover img { opacity: 0.8; filter: alpha(opacity=80); }

/*--------------------------------------------------------
	レイアウト設定
--------------------------------------------------------*/
body{
	margin: 0;
	padding: 0;
	font-size: 0.8em;
	font-family: 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ' ,Meiryo, 'ＭＳ Ｐゴシック', 'Osaka' ,sans-serif;
	color: #000000; /* 標準文字色 */
	min-width: 900px;
}

/* リンク文字色 */
a:link{
		color: #FF6600;
		text-decoration: underline;
}
a:visited{
		color: #FF6600;
		text-decoration: underline;
}
a:hover{
		color: #4FB5E6;
		text-decoration: none;
}
a:active{
		color: #4FB5E6;
		text-decoration: none;
}

#hpb-skip{
		/* ヘッダースキップの非表示 */
		height: 1px;
		margin: 0;
		padding: 0;
		overflow: hidden;
		text-indent: -9999px;
}


#hpb-container-head{
	border-top: 3px solid #C17A01;
	background-color: #FFF;
	position: relative;
}

#hpb-header{
		width: 900px;
		margin: 0 auto;
		height: 75px;
}

#hpb-headerMain{
	margin: 25px 0 0 0;
	float: right;
	font-size: 10px;
	width: 470px;
}

#hpb-headerLogo{
	float: left;
	margin: 15px 0 0 10px;
	padding: 0;
}

#hpb-headerMain .description{
	text-align: right;
}

#hpb-headerMain .link-en{
	margin-left: 15px;
}
#hpb-headerMain a.link-en img{
	border: 1px solid #999;
}
#hpb-headerMain a.link-en:hover img{
	border: 1px solid #FF0004;
}

.hpb-inner{
		width: 900px;
		margin: 0 auto;
		/*position: relative;*/
		clear: both;
}

#hpb-nav{
	border-top: 1px solid #F8E4C0; 
	background: url(../img/bg_9A_01.png) repeat-x left top;
}

#hpb-nav > ul{
	width: 900px;
	height: 39px;
	/*overflow: hidden;*/
	margin: 0 auto;
	border-left: 1px solid #ddd;
}

#hpb-nav ul::after{
		content: ".";
		display: block;
		height: 0;
		clear: both;
		visibility: hidden;
}

#hpb-nav > ul > li{
		float: left;
		font-size: 13px;
		line-height: 38px;
		height: 39px;
		border-right: 1px solid #ddd;
		position: relative;
}

#hpb-nav > ul > li > a{
		display: block;
	  text-align: center;
		min-width: 120px;
		height: 39px;
		overflow: hidden;
		padding-left: 20px;
		padding-right: 20px;
		font-weight: bold;
}

#hpb-nav a:link{
		color: #000000;
		text-decoration: none;
}
#hpb-nav a:visited{
		color: #000000;
		text-decoration: none;
		background-image : url(../img/menuBg_9A_01.png);
		background-position: top right;
		background-repeat: no-repeat;
}
#hpb-nav a:hover{
		color: #444;
		text-decoration: none;
		background-image : url(../img/menuBg_9A_01_on.png);
		background-position: right top;
		background-repeat: no-repeat;
}
#hpb-nav a:active{
		color: #444;
		text-decoration: none;
		background-image : url(../img/menuBg_9A_01_on.png);
		background-position: right top;
		background-repeat: no-repeat;
}

/* 第2階層 */
#hpb-nav > ul > li > ul{
	display: none;
	position: absolute;
	top: 39px;
	left: 0;
	margin-bottom: 0;
	background-color: #FFF;
	z-index: 99
}

#hpb-nav li ul li a{
	background-image: none;
	border-bottom: solid 1px #ccc;
	display: block;
	padding: 10px;
	line-height: 1.2;
}
#hpb-nav li ul li a:hover{
	background-image: none;
	background-color: #FCCDAE;
}

#hpb-nav h3.hpb-c-index{
		height: 1px;
		margin: 0;
		padding: 0;
		overflow: hidden;
		text-indent: -9999px;
		background: none;
}


/* メインコンテンツ内基本パーツ */
#hpb-main{
		width: 650px;
		float: right;
		padding-top: 20px;
}

#hpb-title{
		margin-bottom: 20px;
		padding: 15px;
		overflow: hidden;
		background: url(../img/top_title_9A_02.png) no-repeat left top;
		background-size: cover;
}

#hpb-title h1{
	line-height: 1.4;
	font-size: 1.2em;
}

#hpb-title h1 span.ja{
		font-size: 1.15em;
		color: #ffffff;
}

#hpb-title h1 span.en{
		font-size: 0.8em;
		color: #FFAA00;
		padding: 0 8px;
}

.content{
	margin-bottom: 40px;
}

#hpb-main h2{
	font-size: 1.2em;
	border-top: 1px solid #CCC;
	border-bottom: 2px solid #CCC;
	padding: 5px;
	margin: 30px 0 10px;
}
#hpb-main h2.first{
	margin-top: 0;
}

#hpb-main h3{
		margin: 20px 0 10px;
		padding-top: 3px;
		padding-left: 1px;
		border-bottom: 2px solid #FFAA00;
		font-size: 1.1em;
}

h3.hpb-c-index{
		height: 1px;
		margin: 0;
		padding: 0;
		overflow: hidden;
		text-indent: -9999px;
		background: none;
}

#hpb-main h4{
		margin: 20px 0 10px;
		font-size: 1.05em;
}

#hpb-main h5{
	margin: 20px 0 10px;
}

#hpb-main table{
		margin-top: 5px;
		margin-right: auto;
		margin-bottom: 5px;
		margin-left: 0;
		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: 100%;
}

#hpb-main table th{
		padding-top: 5px;
		padding-right: 15px;
		padding-bottom: 5px;
		padding-left: 8px;
		text-align: left;
		background-color: #F3F3F3;
		border-right-width: 1px;
		border-right-style: solid;
		border-right-color: #cccccc;
		border-bottom-width: 1px;
		border-bottom-style: solid;
		border-bottom-color: #cccccc;
}

#hpb-main table td{
		padding-top: 5px;
		padding-right: 15px;
		padding-bottom: 5px;
		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;
}


#hpb-main ul,
#hpb-main ol{
	margin-bottom: 20px;
}

#hpb-main ul{
	list-style: disc;
	margin-left: 25px;
}

#hpb-main ol{
	list-style: decimal;
	margin-left: 30px;
}

#hpb-main dl{
	margin-bottom: 30px;
}


#hpb-main dt{
		float: left;
		margin-top: 0;
		margin-right: 0;
		margin-bottom: 0;
		margin-left: 0;
		text-align: left;
		line-height: 1.4;
		min-height: 16px;
		font-weight: bold;
		width: 170px;
		padding-top: 5px;
		padding-right: 0;
		padding-bottom: 2px;
		padding-left: 15px;
}

#hpb-main dd{
		margin-top: 0;
		margin-right: 0;
		margin-bottom: 0;
		margin-left: 0;
		padding-top: 5px;
		padding-right: 0;
		padding-bottom: 2px;
		text-align: left;
		line-height: 1.4;
		min-height: 16px;
		padding-left: 185px;
		border-bottom-width: 1px;
		border-bottom-style: dotted;
		border-bottom-color: #ddd;
}

#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;
}


#hpb-aside{
		width: 200px;
		float: left;
		padding: 10px;
		margin: 10px 0;
		background-color: #f4f4f4;
}

#hpb-aside .side-box{
/*	margin-bottom: 10px;*/
	padding: 8px;
	border: 1px solid #ccc;
	background-color: #fff;
	overflow: hidden;
	margin-bottom: 15px;
}
#hpb-aside .side-box a{
	text-decoration: none;
	color: #333;
}
#hpb-aside .side-box p,
#hpb-aside .side-box h3{
	margin: 4px;
	line-height: 1.2;
	font-size: 0.9em;
	overflow: hidden;
}
#hpb-aside .side-box h3{
	cursor: pointer;
}
#hpb-aside .side-box img{
	float: left;
	margin-right: 5px;
}
#hpb-aside .side-box ul{
	margin: 0 0 0 20px;
}
#hpb-aside .side-box ul li{
	list-style: square;
	font-size: 0.9em;
}
#hpb-aside .side-box ul li a:link{
	color: #333;
	text-decoration: none;
}
#hpb-aside .side-box ul li a:hover{
	color: #FF6600;
	text-decoration: underline;
}

.banner ul{
		margin: 0;
		padding: 0;
		list-style-type: none;
}

/*
.banner li{
		padding-bottom: 10px;
}
*/


#pagetop{
		margin: 10px auto;
		text-align: right;
		clear: both;
}

#pagetop a{
		/* ページの先頭へのリンク設定 */
		display: block;
		margin-left: auto;
		width: 125px;
		height: 21px;
		overflow: hidden;
		background-image : url(../img/returnTop_9A.png);
		background-position: top left;
		background-repeat: no-repeat;
		text-align: left;
		text-indent: -9999px;
}

#hpb-footer{
		padding-top: 10px;
		clear: both;
		background: url(../img/fbg_9A.png) repeat-x left top;
}

#hpb-footerMain{
		width: 900px;
		margin: 0 auto;
		padding-top: 10px;
}

.footer-nav li{
	display: inline-block;
}

.footer-nav li a{
	text-decoration: none;
	padding: 0 10px 0 5px;
	background: url(../img/separator.png) scroll no-repeat center right;
}

#hpb-footerMain p{
		/* コピーライト文字設定 */
		color: #8A8A8A;
		font-size: 0.8em;
		text-align: right;
}


#hpb-main .sitemap{
	margin-left: 10px;
}
#hpb-main .sitemap ul{
	margin: 10px 0 5px 20px;
}
#hpb-main .sitemap li{
	list-style-position: inside;
	list-style-type: circle;
}
#hpb-main .sitemap > li{
	padding: 10px 15px 10px 25px;
	border-bottom: 1px dotted #DDD;
	list-style-type: disc;
}


/* =======================================================
	レスポンシブ設定
======================================================= */
@media screen and (max-width: 568px) {

	body{
		min-width: 0;
		font-size: 1.0em;
	}

	/*--------------------------------------------------------
		レイアウト設定
	--------------------------------------------------------*/
	#hpb-container{
		background-image : none;
	}

	#hpb-header{
		width: 100%;
		margin-bottom: 0;
		height: auto;
		padding-bottom: 10px;
		display: flex;
		justify-content: space-between;
		align-items: center;
	}

	.hpb-inner{
		width: 100%;
	}

	#hpb-header img,
	.hpb-top-image img{
		max-width: 100%;
		height: auto;
	}

	#hpb-headerLogo,
	#hpb-headerMain{
		float: none;
		margin: 0;
		width: 100%;
	}

	#hpb-headerLogo,
	#hpb-headerMain p{
		padding: 5px 10px;
		margin: 0;
	}

	#hpb-main{
		width: 96%;
		float: none;
		padding-top: 1px;
		padding-bottom: 20px;
		margin-right: auto;
		margin-left: auto;
	}
	

	#hpb-aside{
		width: 96%;
		float: none;
		margin-top: 0;
		padding-bottom: 20px;
		margin-right: auto;
		margin-left: auto;
	}

	#hpb-aside .side-box p,
	#hpb-aside .side-box h3,
	#hpb-aside .side-box ul li{
		font-size: medium;
	}

	.banner li img {
		max-width: 98%;
		height: auto;
	}

	#hpb-footer{
		width: 100%;
		height: auto;
		padding-top: 0;
		border-top-color: #dddddd;
		border-top-width: 1px;
		border-top-style: solid;
	}

	#hpb-footerMain{
		width: 100%;
		padding: 0;
	}


	#hpb-nav{
		width: 100%;
		height: auto;
		background-color: #fdfdfd;
		border-top: 1px solid #dddddd;
		border-bottom: 1px solid #dddddd;
	}

	/* ナビゲーション */

	#hpb-nav h3.hpb-c-index{
		height: 20px;
		background-image : url(../img/btn_menu.png);
		background-position: top left;
		background-repeat: no-repeat;
		margin-left: 10px;
		margin-top: 10px;
		margin-bottom: 10px;
		overflow: hidden;
		text-indent: 35px;
		cursor: pointer;
	}

	#hpb-nav ul{
		margin-left: 0;
		width: auto;
		height: auto;
	}

	#hpb-nav ul.toggled-on{
		display: block;
	}

	#hpb-nav > ul > li ,
	#hpb-nav li{
		float: none;
		display: block;
		line-height: 1.4;
		height: auto;
		border-top-color: #dddddd;
		border-top-width: 1px;
		border-top-style: solid;
	}

	#hpb-nav > ul > li > a ,
	#hpb-nav li a{
		height: auto;
		padding-left: 10px;
		padding-right: 10px;
		padding-top: 13px;
		padding-bottom: 13px;
	}

	#hpb-nav a:link{
		background-image : none;
	}
	#hpb-nav a:visited{
		background-image : none;
	}
	#hpb-nav a:hover{
		background-image : none;
		background-color: #efefef;
	}
	#hpb-nav a:active{
		background-image : none;
		background-color: #efefef;
	}

	/* 第2階層 */
	#hpb-nav > ul > li > ul{
		position: static;
		display: list-item;
		text-align: center;
	}

	#hpb-nav li ul li a{
		background-image: none;
		border-bottom: none;
	}

	#hpb-main dt{
			float: none;
			width: auto;
			padding: 5px 0px 2px 5px;
	}

	#hpb-main dd{
			padding-left: 18px;
	}

	iframe{
		width: 100%;
		height: auto;
	}

}


/* フォームパーツ設定 */
input.button{
		margin-top: 10px;
		margin-bottom: 15px;
}

textarea{
		width: 400px;
		height: 200px;
}

input.l{
		width: 400px;
}
input.m{
		width: 250px;
}
input
{
}
input.s{
		width: 50px;
}

p.large{
		color: #FF6600;
		font-weight: bold;
}
p.indent{
		padding-left: 25px;
}

.left{
		float: left;
}
.right{
		float: right;
		margin-left: 10px;
}

.right img {
	display: block;
	margin: 0 auto 10px;
}

.right small{
	display: block;
	margin-bottom : 10px;
}

@media screen and (min-width: 569px) {
	.column {
		width: 49%;
	}
	.column-left {
		float: left;
	}
	.column-right{
		float: right;
	}
}
#hpb-main .column{
	border: 1px solid #D3D3D3;
	padding: 10px 10px 3px;
	box-sizing: border-box;
	margin-bottom: 20px;
}
#hpb-main .column h3{
	margin-top: 0;
}

.text-center{
	text-align: center;
}
.text-right{
	text-align: right;
}

hr{
	width: 100%;
	height: 1px;
	margin: 40px auto 30px;
	padding: 0px;
	clear: both;
	border-top: 1px solid #CCC;
	border-bottom: 1px solid #EFEFEF;
}

a.btn{
	border-radius: 6px;
	display: inline-block;
	padding-bottom: .5em;
	padding-left: 1em;
	padding-right: 1em;
	padding-top: .5em;
	background: #FF6600 url(../img/top_title_9A_02.png) no-repeat left top;
	color: #FFF;
	font-size: 1.05em;
	cursor: pointer;
	text-decoration: none;
	text-align: center;
	white-space: nowrap;
}
a.btn:hover{
	background-image: none;
}

iframe{
	border: none;
}

.info-tel{
	font-size: 1.6em;
	font-weight: bold;
}