@charset "utf-8";

/*--------------------------------------------------------
  共通レイアウトパーツ設定
--------------------------------------------------------*/

body{
	background-image : url(../images/bg.gif);
    background-position: top left;
    background-repeat: repeat;
		background-color: #fff;
		-webkit-text-size-adjust: 100%;
}
#container{
}

#inner::after{
	content: ".";  
	display: block;  
	clear: both;
	height: 0;
	visibility: hidden;
}

/* ヘッダー内パーツ */


#header::after{
	content: ".";  
	display: block;  
	clear: both;
	height: 0;
	visibility: hidden;
}

#headerLogo{
	margin-top: 7px;
	padding-top: 23px;
	text-align: left;
}




/* フッター内パーツ */

#footer{
	background-color: #0059a0;
}

#footerMain{
	padding-top: 18px;
	padding-bottom: 18px;
}
#footerMain p{
    /* コピーライト文字設定 */
    text-align: center;
	margin: 0;
	color: #fff;
	font-size: 92.9%;
}


/*--------------------------------------------------------
  ナビゲーションデザイン設定
--------------------------------------------------------*/

#navi li a{
    /* ナビゲーション文字設定 */
    font-weight: bold;
}

#navi li a:link{
		color: #fff;
    text-decoration: none;
}
/* ナビゲーション文字色設定 */
#navi li a:visited{
		color: #fff;
		text-decoration: none;
}
#navi li a:hover{
    color: #fff;
    text-decoration: none;
}
#navi li a:active{
    color: #fff;
    text-decoration: none;
}

/*--------------------------------------------------------
  基本パーツデザイン設定
--------------------------------------------------------*/

/* リンク文字色 */
a:link{
    color: #1f9958;
    text-decoration: underline;
}
a:visited{
    color: #1f9958;
    text-decoration: underline;
}
a:hover{
    color: #1f9958;
    text-decoration: none;
}
a:active{
    color: #1f9958;
    text-decoration: none;
}


.bold {
	font-weight: bold;
}
.kasen {
    text-decoration: underline;
} 
.torikeshi {
    text-decoration: line-through;
}
.italic{
    font-style: italic;
}

.red {
	color: #F91F00;
}
.txt-right {
	text-align: right;
}
.txt-center {
    text-align: center;
}


.font-12px{
    font-size: 0.857em !important;
}
.font-13px{
    font-size: 0.929em !important;
}
.font-15px{
    font-size: 1.071em !important;
}
.font-16px{
    font-size: 1.143em !important;
}
.font-17px{
    font-size: 1.214em !important;
}
.font-18px{
    font-size: 1.286em !important;
}
.font-19px{
    font-size: 1.357em !important;
}
.font-20px{
    font-size: 1.429em !important;
}



.m-t_0 {
	margin-top: 0px !important;
}
.m-t_5 {
	margin-top: 5px !important;
}
.m-t_10 {
	margin-top: 10px !important;
}
.m-t_15 {
	margin-top: 15px !important;
}
.m-t_20 {
	margin-top: 20px !important;
}
.m-t_30 {
	margin-top: 30px !important;
}
.m-t_40{
	margin-top: 40px !important;
}
.m-t_50{
	margin-top: 50px !important;
}

.p-t_0 {
	padding-top: 0px !important;
}
.p-t_5 {
	padding-top: 5px !important;
}
.p-t_10 {
	padding-top: 10px !important;
}
.p-t_15 {
	padding-top: 15px !important;
}
.p-t_20 {
	padding-top: 20px !important;
}
.p-t_30{
	padding-top: 30px !important;
}
.p-t_40{
	padding-top: 40px !important;
}
.p-t_50{
	padding-top: 50px !important;
}


.m-l_0 {
	margin-left: 0px !important;
}
.m-l_5 {
	margin-left: 5px !important;
}
.m-l_10 {
	margin-left: 10px !important;
}
.m-l_15 {
	margin-left: 15px !important;
}
.m-l_20{
	margin-left: 20px !important;
}
.m-l_30{
	margin-left: 30px !important;
}
.m-l_40{
	margin-left: 40px !important;
}
.m-l_50{
	margin-left: 50px !important;
}

.p-l_0 {
	padding-left: 0px !important;
}
.p-l_5 {
	padding-left: 5px !important;
}
.p-l_10 {
	padding-left: 10px !important;
}
.p-l_15 {
	padding-left: 15px !important;
}
.p-l_20{
	padding-left: 20px !important;
}
.p-l_30{
	padding-left: 30px !important;
}
.p-l_40{
	padding-left: 40px !important;
}
.p-l_50{
	padding-left: 50px !important;
}

.m-b_0 {
	margin-bottom: 0px !important;
}
.m-b_5 {
	margin-bottom: 5px !important;
}
.m-b_10 {
	margin-bottom: 10px !important;
}
.m-b_15 {
	margin-bottom: 15px !important;
}
.m-b_20{
	margin-bottom: 20px !important;
}
.m-b_30{
	margin-bottom: 30px !important;
}
.m-b_40{
	margin-bottom: 40px !important;
}
.m-b_50{
	margin-bottom: 50px !important;
}

.p-b_0 {
	padding-bottom: 0px !important;
}
.p-b_5 {
	padding-bottom: 5px !important;
}
.p-b_10 {
	padding-bottom: 10px !important;
}
.p-b_15 {
	padding-bottom: 15px !important;
}
.p-b_20{
	padding-bottom: 20px !important;
}
.p-b_30{
	padding-bottom: 30px !important;
}
.p-b_40{
	padding-bottom: 40px !important;
}
.p-b_50{
	padding-bottom: 50px !important;
}

.m-r_0{
	margin-right: 0px !important;
}
.m-r_10{
	margin-right: 10px !important;
}
.m-r_20{
	margin-right: 20px !important;
}
.m-r_30{
	margin-right: 30px !important;
}
.m-r_40{
	margin-right: 40px !important;
}
.m-r_50{
	margin-right: 50px !important;
}

.p-r_0{
	padding-right: 0px !important;
}
.p-r_10{
	padding-right: 10px !important;
}
.p-r_20{
	padding-right: 20px !important;
}
.p-r_30{
	padding-right: 30px !important;
}
.p-r_40{
	padding-right: 40px !important;
}
.p-r_50{
	padding-right: 50px !important;
}



.w-10pc {
    width: 10% !important;
}
.w-15pc {
    width: 15% !important;
}
.w-20pc {
    width: 20% !important;
}
.w-30pc {
    width: 30% !important;
}
.w-40pc {
    width: 40% !important;
}
.w-50pc {
    width: 50% !important;
}
.w-60pc {
    width: 60% !important;
}
.w-70pc {
    width: 70% !important;
}
.w-80pc {
    width: 80% !important;
}
.w-90pc {
    width: 90% !important;
}
.w-100pc {
    width: 100% !important;
}


br.br01{
	display: block;
}

p{
    margin-top: 0.5em;
    margin-bottom: 1em;
    padding-right: 20px;
    padding-left: 0.1em;
    line-height: 1.538;
    text-align: left;
}

p.indent{
    padding-left: 25px;
}

.left{
    float: left;
}

img.left{
}

.right{
    float: right;
}

img.right{
}

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;
}

.c-page h2{
	padding-left: 33px;
	padding-top: 0px;
	padding-bottom: 0px;
	padding-right: 15px;
	text-align: left;
	line-height: 1;
	color: #fff;
	font-size: 2.000em;
	letter-spacing: 0.1em;
	font-weight:bold;
}

h2 span.en{
    display: none;
}

#wrapper h3{
	color: #333333;
	font-size: 1.286em;
	font-weight: bold;
	padding: 7px 10px 7px 10px;
	margin: 25px 0 15px 0;
	background-color: #c2e4ff;
	line-height: 1.2;
	border-left: 7px solid #0059a0;
	clear:both;
}
h3.c-index{
    height: 1px;
    margin: 0;
    padding: 0;
    overflow: hidden;
    text-indent: -9999px;
    background: none;
}

#wrapper h4{
		margin-top: 15px;
		margin-bottom: 10px;
		padding: 5px 10px 5px 10px;
		text-align: left;
		font-size: 1.071em;
		line-height: 1.2;
		border-bottom: 1px solid #0059a0;
		border-left: 7px solid #0059a0;
		color: #333333;
}
#wrapper h5{
    margin-top: 15px;
    margin-bottom: 1em;
    padding-top: 5px;
    padding-right: 10px;
    padding-bottom: 5px;
		padding-left: 5px;
    text-align: left;
    font-size: 1.000em;
    line-height: 1.2;
    color: #0059a0;
    font-weight: bold;
		border-bottom: 2px dotted #0059a0;
}
#wrapper h6{
    font-size: 1em;
    line-height: 1.2;
    margin-top: 15px;
    margin-bottom: 1em;
    padding-top: 5px;
    padding-right: 10px;
    padding-bottom: 5px;
		padding-left: 15px;
    text-align: left;
    font-weight: bold;
		color: #333333;
		position: relative;	
}
#wrapper h6:before {
        background: #0059a0;
        content: "";
        height: 8px;
        width: 8px;
        left: 2px;
        position: absolute;
        top: 7px;
}

table{
		margin-top: 0.5em;
		margin-bottom: 2em;
		border-collapse: collapse;
		border: 1px solid #cccccc;;
		width: 100%;
}

table th{
	padding-top: 8px;
	padding-right: 15px;
	padding-bottom: 8px;
	padding-left: 8px;
	text-align: left;
	font-weight: normal;
	background-color: #d4f6f2;
	border: 1px solid #cccccc;
	;
}

table td{
    padding-top: 8px;
    padding-right: 8px;
    padding-bottom: 8px;
    padding-left: 8px;
    text-align: left;
    border: 1px solid #cccccc;;
}




/* main */

#main p{
}

#main ul,
#main ol {
    margin-top: 0;
    margin-right: 10px;
    margin-bottom: 0;
    margin-left: 0;
    padding-top: 0;
    padding-right: 0;
    padding-bottom: 0;
    padding-left: 0;
    list-style-type: none;
}
#main ol {
    margin: 0 0 15px;
}

#main ol li {
    list-style-type: decimal;
	margin: 0px 0px 0px 20px;
	margin-bottom: 5px;
}

#main ul li{
	background-image: url(../images/blt_circle.gif);
	background-repeat: no-repeat;
	background-position: 3px 5px;
	padding: 0px 0px 0px 15px;
	margin-bottom: 5px;
}


#main img.left{
    margin-top: 5px;
    margin-right: 20px;
    margin-bottom: 15px;
    float: left;
}

#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: #0059a0;
	display: inline-block;
	padding: 10px 20px;
	border-top-left-radius: 4px;
	border-top-right-radius: 4px;
}
#pagetop a:link,
#pagetop a:visited{
	color: #fff;
	text-decoration: none;
}

/* banner */

#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 img:hover{
    opacity: 0.7;
}

#inner #companyinfo{
	margin-bottom: 10px;
	border: 1px solid #62a8df;
	border-radius: 4px;
	width: 209px;
	padding: 10px 0px;
}

#inner #companyinfo h3{
	padding-top: 7px;
	padding-bottom: 7px;
	margin: 0 10px 10px 10px;
	font-size: 1em;
	line-height: 1;
	text-align: center;
	background-color: #0059a0;
	color: #fff;
}

#inner #companyinfo p{
    margin: 0 10px 10px;
	 font-size: 92.9%;
	padding-right: 0;
}


/* home */

#toppage {
	margin-top: 20px;
}


#toppage-topics,
#toppage-news{
	border: 1px solid #62a8df;
	border-radius: 4px;
	margin: 0 0 25px 0;
	padding: 10px 12px 10px 12px;
}
#main #toppage-topics li{
	
}
#main #toppage-topics li:last-child{
	border: none;
}

#main #toppage-news dl{
	margin: 0 10px 0 10px;
	 padding: 0;
}
#main #toppage-news dt{
	float: left;
	width: 9.5em !important;
	margin: 0;
	text-align: left;
	line-height: 1.3;
    padding-top: 10px;
    padding-right: 0;
    padding-bottom: 10px;
    padding-left: 1.5em;
    background-image : url(../images/point01.png);
    background-position: 5px 11px;
    background-repeat: no-repeat;
}
#main #toppage-news dd{
	margin: 0;
	padding-left: 11em;
	padding-top: 10px;
	padding-right: 10px;
	padding-bottom: 10px;
	text-align: left;
	line-height: 1.3;
	border-bottom-width: 1px;
	border-bottom-style: dotted;
	border-bottom-color: #999999;
}

#main #toppage-news dd:last-child{
	border: none;
}




@media screen and (max-width: 960px) {

	/*--------------------------------------------------------
	  common
	--------------------------------------------------------*/
	
	br.br01{
		display: none;
	}

	
	#container{
		width: 100%;
		margin-top: 0;
		background-image: none;
		background-color: #fff;
	}

	/* header */
	#header{
		width: 100%;
		padding-bottom: 0px;
		height: auto;
		border-top: 15px solid  #0059a0;
	}
	#headerLogo{
		width: 96%;
		float: none;
		padding-left: 0;
		padding-top: 0;
		margin: 0 auto;
		height: auto;
		text-align: center;
	}
	#headerLogo img{
		max-width: 100%;
	}
	#headerLogo a{
		display: block;
		max-width: 100%;
		height: auto;
		padding-top:10px;
		padding-bottom:10px;
	}
	#pagetop{
		text-align: center;
		left: 0;
	}
	/* footer */
	#footerMain{
		padding-top: 10px;
		padding-bottom: 10px;
	}
	#footerMain p{
		padding-left: 5px;
		padding-right: 5px;
		/*word-break: break-all;*/
	}
	
	/* title */
	.c-page #page-title{
		background-size: auto 100%;
	}

	/*--------------------------------------------------------
	  navi
	--------------------------------------------------------*/
	#navi h3.c-index{
		width: 27px;
		height: 20px;
		background-image : url(../images/btn_menu.png);
		background-position: top left;
		background-repeat: no-repeat;
		margin-left: 10px;
		margin-top: 10px;
		margin-bottom: 10px;
		overflow: hidden;
		text-indent: -9999px;
		cursor: pointer;
	}

	/*--------------------------------------------------------
	  parts
	--------------------------------------------------------*/
	p{
		padding-right: 0;
		padding-left: 0;
	}
	img.left{
		margin-left: 10px;
		margin-right: 10px;
	}
	img.right{
		margin-left: 10px;
		margin-right: 10px;
	}
	.c-page h2{
		width: 96%;
		padding-left: 0;
		padding-top: 25px;
		line-height: 1.4;
		margin-top: 4px;
		margin-right: auto;
		margin-left: auto;
		margin-bottom: 0;
		word-break: break-all;
	}
	table{
		width: 100%;
		margin-right: auto;
		margin-left: auto;
	}


	/* main */
	#main h3{
		background-size: contain;
	}
	#main ul li{
		padding-right: 0;
	}
	#main img.left{
		margin-left: 10px;
		margin-right: 10px;
		float: none;
	}
	#main img.right{
		margin-left: 10px;
		margin-right: 10px;
		float: none;
	}

	/* banner */
	#banner ul {
		margin-left:auto;
		margin-right:auto;
		width: 652px;
	}

	#banner ul:after {
    content: ".";
    clear: both;
    height: 0;
    display: block;
    visibility: hidden;
	}
	#banner ul li {
		float: left;
		margin-right:5px;
	}
	#banner ul li:last-child {
		margin-right:0px;
	}
	#banner ul li:nth-child(3n) {
		margin-right:0px;
	}


	#inner #companyinfo{
		margin-top: 10px;
		margin-bottom: 10px;
		margin-left: auto;
		margin-right:auto;
		width: 96%;
	}

	/* home */
	#main #toppage-news dt{
		float: none;
		line-height: 1.4;
		padding-bottom: 0;
	}
	#main #toppage-news dd{
	padding-top: 5px;
	padding-right: 0;
	padding-left: 20px;
	border: none;
	border-bottom-width: 1px;
	border-bottom-style: dotted;
	border-bottom-color: #999999;
	line-height: 1.4;
	}
	#main #toppage-news dt:first-child + dd{
	border-bottom-width: 1px;
	border-bottom-style: dotted;
	border-bottom-color: #999999;
	}
	#main #toppage-news dd:last-child{
		border: none;
	}

}


@media screen and (max-width: 680px) {
	/*--------------------------------------------------------
	  parts
	--------------------------------------------------------*/
	
	/* banner */
	#banner ul {
		width: 433px;
	}
	#banner ul li:nth-child(3n) {
		margin-right:5px;
	}

	#banner ul li:last-child {
		margin-right: 5px;
	}
	#banner ul li:nth-child(even){ 
		margin-right: 0px;
	}
	


}
@media screen and (max-width: 451px) {
	/*--------------------------------------------------------
	  parts
	--------------------------------------------------------*/
	
	/* banner */
	#banner ul {
		width: 214px;
	}
	#banner ul li {
		margin-right:0px;
	}
	#banner ul li:nth-child(3n) {
		margin-right:0px;
	}

	#banner ul li:last-child {
		margin-right: 0px;
	}
	
	


}


@media screen and (max-width: 370px) {
	/*--------------------------------------------------------
	  common
	--------------------------------------------------------*/
	/* title */
	.c-page #page-title{
		background-size: cover;
	}
	




}
