@charset "utf-8";

*{margin:0;padding:0;}

body{
font: 13px/1.6 "メイリオ","Meiryo",arial,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro",Osaka,"ＭＳ Ｐゴシック","MS PGothic",Sans-Serif;
color:#252525;
background: #ffffff url(images/bg.jpg) repeat-x top;
}

body#toppage {
background: url(images/bg_top.jpg) repeat-x top;
}

a{color:#51a4d4;text-decoration:none;}
a:hover{color:#3886b3;}
a:active, a:focus {outline: 0;}
img{border:0;}
.clear{clear:both;}


/*************
全体
*************/
#wrapper{
margin: 0 auto;
padding: 0 20px;
width: 910px;
}

/*************
/* ヘッダー
*************/
#header{
	zoom: 1;
}
#header:after {
	content: "";
	display: block;
	clear: both;
}

#header h1 {
color: #333;
padding: 10px 0;
font-size: 10px;
font-weight: normal;
}
#header p#logo {
	float:left;
}
#header div#header_contact {
	float:right;
}
#header div#header_contact p {
	float:left;
	margin:0 0 0 20px;
}
#header div#header_contact p a:hover {
	opacity: 0.6;
	filter: alpha(opacity=60);
	-ms-filter: "alpha( opacity=60 )";
}


/*************
/* トップナビゲーション
*************/
ul#topnav{
margin: 20px 0;
width: 910px;
height: 31px;
background:url(images/topnav.png) no-repeat 0 0;
}

ul#topnav li{
float:left;
list-style:none;
width:182px;
}

ul#topnav a{
text-indent: -9999px;
text-decoration: none;
display: block;
width: 182px;
height: 46px;
background:url(images/topnav.png) no-repeat;
}

ul#topnav li:first-child a {background-position:0 0;}
ul#topnav li:nth-child(2) a {background-position:-182px 0;}
ul#topnav li:nth-child(3) a {background-position:-364px 0;}
ul#topnav li:nth-child(4) a {background-position:-546px 0;}
ul#topnav li:nth-child(5) a {background-position:-728px 0;}

ul#topnav li:first-child a:hover, ul#topnav li:first-child.active a {background-position:0 -46px;}
ul#topnav li:nth-child(2) a:hover, ul#topnav li:nth-child(2).active a {background-position:-182px -46px;}
ul#topnav li:nth-child(3) a:hover, ul#topnav li:nth-child(3).active a {background-position:-364px -46px;}
ul#topnav li:nth-child(4) a:hover, ul#topnav li:nth-child(4).active a {background-position:-546px -46px;}
ul#topnav li:nth-child(5) a:hover, ul#topnav li:nth-child(5).active a {background-position:-728px -46px;}


/*************
メイン画像
*************/
#mainimage {
margin-top: 35px;
}

/*************
メイン（右側）コンテンツ
*************/
#main {
float: right;
width: 618px;
padding: 23px 0;
display: inline;
}

#main .bannerM a:hover{
	opacity: 0.6;
	filter: alpha(opacity=60);
	-ms-filter: "alpha( opacity=60 )";
}
#main .bannerM img{
padding-right: 10px;
padding-bottom: 15px;
}
#main .bannerM img.last{padding-right:0;}

#main h2{
margin-bottom: 10px;
padding: 1px 10px 0px 30px;
line-height: 40px;
font-size: 15px;
font-weight: normal;
color: #252525;
background: url(images/heading.png) no-repeat;
}

#main h3 {
font-size: 14px;
font-weight: normal;
line-height: 30px;
padding-left: 15px;
margin-top: 10px;
letter-spacing: 0.2em;
color: #51a4d4;
border-bottom: 1px solid #cccccc;
margin-bottom: 15px;
}
#main h4 {
font-size: 13px;
font-weight: normal;
padding-left: 10px;
margin-top: 10px;
border-left: 3px solid #cccccc;
margin-bottom: 10px;
}

/*更新プログラム(連動)フォーマット*/
#news01 {
	width: 100%;
	margin-bottom: 10px;
	/* CSS3 */
	zoom: 1;
}
#news01 dl {
	padding: 10px 5px;
	border-bottom: 1px dotted #CCC;
}
#news01 dl dt {
	float: left;
	width: 80px;
	font-size: 13px;
}
#news01 dl dd {
	padding: 0 0 0 90px;
}
#news01 dl dd p {
	font-size: 13px;
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
}


/* 画像を右に回りこみ */
#main p.withImage{
width: 598px;
margin: 20px 0 0 10px;
padding: 5px 0;
}

#main p.withImage img{
float: right;
margin-left: .5em;
}

#date {
text-align: right;
padding-right: 15px;
padding-top: 15px;
padding-bottom: 10px;
font-weight:bold;
color:#51a4d4;
}

#next {
text-align: center;
padding-top: 30px;
padding-bottom: 30px;
}

img.aligncenter {
    display: block;
    margin-left: auto;
    margin-right: auto;
}
img.alignright {
    padding: 4px;
    margin: 0 0 2px 7px;
    display: inline;
}
img.alignleft {
    padding: 4px;
    margin: 0 7px 2px 0;
    display: inline;
}
.alignright {
    float: right;
}
.alignleft {
    float: left;
}

/* フッター共通 */
.box{
float: left;
width: 195px;
margin: 0 16px 10px 0;
line-height: 1.2;
}

.box_img{
padding: 0px 0px 10px 0px;
}

.last{margin-right:0;}


/* ボタン */
p.button{
text-align: center;
padding: 10px 0;
}

p.button a{
display:block;
line-height: 32px;
background: #ffffff url(images/button.png) no-repeat;
margin: 0 -20px;
}

p.button a{color:#51a4d4;}
p.button a:hover{color:#fff;}

p.button a:hover{
cursor:pointer;
background-position: 0 -32px;
}

/* メインとフッターのリスト位置調節 */
#main ul, #footer ul{margin-left: 20px;}
#main li, #footer li{margin-bottom: 3px;}


/*************
サイド（左側）コンテンツ
*************/
#sidebar {
float: left;
width: 265px;
padding: 23px 0;
}
#sidebar div.frame {
	margin:0 0 20px;
	padding:15px;
	border:solid 1px #d1d1d1;
	border-radius:10px;
}




/*************
/* フッター
*************/
#footer{
clear:both;
padding: 30px 0 10px;
border-top: 1px solid #cccccc;
}

#footer .inner{
overflow: hidden;
}

* html #footer .inner{height:1%;}

#footer #footer_name{
float:left;
width: 292px;
}
#footer #footer_name p{
	line-height:1.2;
}
#footer #footer_name .name{
	font-size:22px;
	font-weight:bold;
}
#footer #footer_name .name span{
	font-size:18px;
}

address{
padding: 20px 0 10px;
text-align: center;
font-style:normal;
font-size: 12px;
clear:both;
display:block;
}

/*------------------------------------------------------------Block*/
/*Block02,03*/
.phbox div.tx {
	overflow: hidden;/* for modern browser */
	zoom: 1;/*ie6*/
	line-height: 1.5;
	padding: 0px;
}
.phbox img {
	margin-bottom: 10px;
}
/*Block04*/
.phlist {
	float: left;
	width: 190px;
}
/*Block07*/
.table01 {
	border-collapse: collapse;
	width: 100%;
}
.table01 tr th, .table01 tr td {
	border: #666 1px dotted;
	padding: 10px 15px;
}
/*Block08*/
.table02 {
	border-collapse: collapse;
	width: 48%;
}
.table02 tr th, .table02 tr td {
	border: #666 1px dotted;
	padding: 10px 15px;
}
/*Block09*/
.table03 {
	border-collapse: collapse;
	width: 55%;
}
.table03 tr th, .table03 tr td {
	border: #666 1px dotted;
	padding: 10px 15px;
}
/*Block10*/
.flowbox01 {
	float: left;
	width: 165px;
}
.fb01_arrow {
	background: url(images/flow_arrow01.png) no-repeat right 50%;
	padding-right: 50px;
}
/*Block11*/
.flowbox02 {
	clear: both;
}
.flowbox02 p {
	overflow: hidden;/* for modern browser */
	zoom: 1;/*ie6*/
	line-height: 1.5;
	padding: 0px;
}
.fb_arrow02 {
	background: url(images/flow_arrow02.png) no-repeat center bottom;
	padding-bottom: 50px;
}
/*Block12*/
.dl01 dl {
	padding: 5px 0px;
}
.dl01 dl dt {
	float: left;
	width: 100px;
	font-weight: bold;
	padding: 0px 0 0;
	color: #666;
}
.dl01 dl dd {
	padding: 0 0 0 120px;
}
.dl01 dl dd p {
	font-size: 12px;
}
/*Block07*/
.table04 {
	border-collapse: collapse;
	width: 100%;
}
.table04 tr th, .table04 tr td {
	border: #666 1px dotted;
	padding: 10px 15px;
	text-align: center;
}

/*------------------------------------------------------------Decoration*/
/*Line*/
hr.line_01 {
	height: 1px;
	clear: both;
	margin: 20px 0px;
	border-top: 1px dotted #CCC;
	border-right: 0 dotted #CCC;
	border-bottom: 0 dotted #CCC;
	border-left: 0 dotted #CCC;
}
/*------------------------------------------------------------Float*/
/*FloatLeft*/
.float_left {
	float: left;
}
/*FloatRight*/
.float_right {
	float: right;
}
/*ClearBoth*/
.clearboth {
	clear: both;
}
/*------------------------------------------------------------Margin*/
/*MarginTop*/
.margin_t05 {
	margin-top: 5px;
}
.margin_t10 {
	margin-top: 10px;
}
.margin_t20 {
	margin-top: 20px;
}
.margin_t30 {
	margin-top: 30px;
}
.margin_t40 {
	margin-top: 40px;
}
.margin_t50 {
	margin-top: 50px;
}
/*MarginBottom*/
.margin_b05 {
	margin-bottom: 5px;
}
.margin_b10 {
	margin-bottom: 10px;
}
.margin_b20 {
	margin-bottom: 20px;
}
.margin_b30 {
	margin-bottom: 30px;
}
.margin_b40 {
	margin-bottom: 40px;
}
.margin_b50 {
	margin-bottom: 50px;
}
/*MarginRight*/
.margin_r05 {
	margin-right: 5px;
}
.margin_r10 {
	margin-right: 10px;
}
.margin_r15 {
	margin-right: 15px;
}
.margin_r20 {
	margin-right: 20px;
}
/*MarginLeft*/
.margin_l05 {
	margin-left: 50px;
}
.margin_l10 {
	margin-left: 10px;
}
.margin_l15 {
	margin-left: 15px;
}
.margin_l20 {
	margin-left: 20px;
}
/*------------------------------------------------------------ClearFix*/
.clearfix {
	zoom: 1;
}
.clearfix:after {
	content: "";
	display: block;
	clear: both;
}


