@charset "utf-8";
/* CSS Document */

/* PRINT ===================================================== */

@media print {
  *html body {
    zoom: 64%;
  }
}


/* RESET ===================================================== */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	vertical-align: baseline;
}
ol, ul {
	list-style: none;
}


a {
    color:  #235BA0;
}
a:hover {
    color: #336052;
    text-decoration: none;
}


/* RESET ===================================================== */

.clearfix:after{
  content: ".";
  display: block;
  height: 0;
  font-size:0;
  clear: both;
  visibility:hidden;
}

.clearfix{display: inline-block;}

/* Hides from IE Mac \*/
* html .clearfix {height: 1%;}
.clearfix{display:block;}
/* End Hack */

.clear {
	clear: both;
}

/* =================================================== */

body {
	background: #FAF4E4 url(../images/bg_body.jpg) center top no-repeat;
	color: #000;
	font-size: 75%;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", verdana, "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
}


/* container box */
#container {
	margin: 0 auto;
}



/* Block Skip */
div#blockskip { z-index: 9999; overflow: visible; margin: 0; padding: 0; width: 100%; }
div#blockskip a {
	overflow: hidden;
	display: block;
	background: #333;
	margin: 0;
	padding: 0;
	width: 100%;
	height: 0;
	color: #ffffff;
	text-align: center;
	text-decoration: none;
	font-size: 0.1em;
	line-height: 0;
	cursor: default;
}
div#blockskip a:hover { text-decoration: underline; color:#fff; }
div#blockskip a.show {
	height:1em;
	margin-top: -3px;
	padding: 5px 0;
	color: #ffffff;
	font-size: 100%;
	line-height: 1;
	cursor: pointer;
}

/* HEADER =================================================== */

#header {
	width: 980px;
	margin: 0 auto;
	padding: 15px 0 0;
}
#logo {	float: left;}

/* navi area */
#navi_area {
	float: right;
	min-width: 528px;
	_width: 560px;
	margin-bottom: 13px;
	padding: 5px;
	background: url(../images/bg_filter.png) left top repeat;
}
	/* IE7 hack */
	*+html #navi_area {
		width: 560px
	}

#navi_area #nav_link {
	float: right;
	margin-right: 8px;
	padding: 7px 8px 7px 0;
	background: url(../images/dot_line.png) right center no-repeat;
}
#navi_area #nav_link li {
	float: left;
	margin-right: 10px;
	padding: 3px 0 3px 24px;
	border-left: 1px dotted #336600;
	border-left: expression((this.parentNode.firstChild ==this)?'none':'1px dotted #336600');
	background: url(../images/icon_arrow01.png) 8px center no-repeat;
	white-space: nowrap;
}
#navi_area #nav_link li:first-child {
	border-left: none;
}
#navi_area #nav_link li a {
	color: #333;
}
#navi_area #search {
	float: right;
	width: 320px;
	margin-bottom: 5px;
}
#search dt {
	float: left;
	width: 76px;
	margin-right: 6px;
	_margin-right: 3px;
	padding: 8px 0 5px;
}
#search dd {float: left; padding: 3px 0 0;_padding: 2px 0 0;}
#search input {
	margin: 0;
	padding: 0;
}
#search .keyword {
	width: 177px;
	padding: 5px 2px 2px;
	_padding: 3px 2px 2px;
	background: url(../images/search_bg.png) left 3px no-repeat;
}
#search .keyword input {
	width: 175px;
	height: 22px;
	padding: 0;
	border: none;
	vertical-align:middle;
}
	/* IE7 hack */
	*+html #search .keyword input {
		width: 175px;
		height: 22px;
		line-height: 22px;
	}
	/* IE6 hack */
	#search .keyword input {
		_width: 175px;
		_height: 22px;
		_border-width: 0;
		_zoom: 1;
	}
#search .button {
	width: 56px;
	height: 26px;
}
#search .button input {
	height: 26px;
	border: 0;
	vertical-align: middle;
}


/* useful_area */
#useful_area {
	float: right;
	width: 521px;
}
/* color_change */
#color_change {
	float: left;
	width: 203px;
	_width: 208px;
	margin-right: 10px;
	_margin-right: 5px;
}
	/* IE7 hack */
	*+html #color_change {
		width: 208px;
	}
#color_change p {
	float: left !important;
}
#color_change ul {
	float: left;
}
#color_change ul li {
	float: left;
	margin-left: 2px;
	_margin-left: 1px;
}

/* txt_size */
#txt_size {
	float: left;
	width: 174px;
}
#txt_size dt {
	margin-right: 5px;
}
#txt_size dt,
#txt_size dd {float: left;}
#txt_size ul {
	overflow: hidden;
}
#txt_size li {
	float: left;
	cursor: pointer;
}
#txt_size li a {
	display: block;
	overflow: hidden;
	width: 51px;
	height: 28px;
	text-indent: -9999px;
}
#txt_size .normal a {
	background-image: url(../images/btn_txt_size.png);
	background-repeat: no-repeat;
	background-position: 0 0;
}
#txt_size .normal a:hover {
	background-position: 0 -30px;
}
#txt_size .big a {
	background-image: url(../images/btn_txt_size.png);
	background-repeat: no-repeat;
	background-position: -51px 0;
}
#txt_size .big a:hover {
	background-position: -51px -30px;
}


/* reading */
#reading {
	float: right;
}


/* GLOBAL NAVI =================================================== */
#gnav {
	width: 984px;
	height: 63px;
	margin: 0 auto 12px;
	zoom: 1;
	position:relative;
	z-index: 999;
}
#gnav li {
	position: relative;
	float: left;
	width: 140px;
	height: 63px;
}
#gnav li#home,
#gnav li#last {
	width: 142px;
}
#gnav li .sub {
	display: none;
	position: absolute;
	top: 63px;
	left: 0;
	width: 255px;
	padding: 10px;
	border: 2px solid #18763B;
	border-radius: 6px;
	background: #fff;
	z-index: 999;
}
#gnav li#last .sub {
	position: absolute;
	top: 63px;
	left: -139px;
}
#gnav li .sub li {
	display: inline-block;
	_display: inline;
	width: auto;
	height: auto;
	margin-right: 10px;
	line-height: 1.4em;
	zoom: 1;
}
	/* IE7 hack */
	*+html #gnav li .sub li {
		display: inline;
	}
#gnav li .sub li:first-child {
	border-top: none;
}
#gnav li .sub li a {
	display: inline-block;
	_display: inline;
	height: auto;
	padding: 5px 0 5px 16px;
	background: url(../images/icon_arrow01.png) 0px 7px no-repeat;
	_white-space: nowrap;
	zoom: 1;
}
	/* IE7 hack */
	*+html #gnav li .sub li a {
		display: inline;
		white-space: nowrap;
	}
#gnav li .sub li a:hover {
  background: #F3F3F3 url(../images/icon_arrow02.png) 0px 7px no-repeat;
}



#keyvisual {
	width: 984px;
	margin: 0 auto 15px;
}

/* CONTENTS =================================================== */
#wrapper {
	clear: both;
	width: 980px;
	margin: 0 auto;
	padding: 0 0 50px;
}

/* crumb =================================================== */
#crumb {
	overflow: hidden;
	margin-bottom: 10px;
	padding: 5px 0 6px;
	background: url(../images/bg_filter.png) left top repeat;
	zoom: 1;
}
#crumb li {
	float: left;
	margin-right: 5px;
	padding: 3px 0 3px 10px;
	background: url(../images/icon_crumb.gif) left center no-repeat;
}
#crumb li.home {
	clear: both;
	padding-left: 24px;
	background: url(../images/icon_home.png) 8px center no-repeat;
}
#crumb li a {
	margin-right: 4px;
}

/* FOOTER =================================================== */

#footer {
	clear: both;
	zoom: 1;
}
#footer a {
	color: #1A5597;
}
#footer .inner {
	width: 980px;
	margin: 0 auto;
}
#footer #fnav {
	overflow: hidden;
	padding: 0 0 6px;
	background: url(../images/footer_bg.png) left bottom repeat-x;
}
#footer #fnav ul {
	float: left;
	margin: 30px 0 0 -8px;
}
#footer #fnav li {
	display: inline;
	margin-right: 8px;
	padding: 0 0 0 24px;
	border-left: 1px dotted #336600;
	background: url(../images/icon_arrow01.png) 8px center no-repeat;
}
#footer #fnav li:first-child {
	border-left: none;
}
#footer #fnav #pagetop {
	float: right;
}


#footer #info {
	padding: 15px 0;
	background: #fff;
	font-size: 120%;
}
#footer #info #name {
	margin-bottom: 5px;
	font-size: 150%;
	font-weight: bold;
}
#footer #info table {
	margin-bottom: 5px;
}
#footer #info table caption {
	display: none;
}
#footer table th {
	text-align: left;
	white-space: nowrap;
}
#footer table th,
#footer table td {
	padding: 3px 8px 0 0;
	vertical-align: top;
}
#copyright {
	padding: 8px;
	background: url(../images/copyright_bg.jpg) left top repeat-x;
	color: #fff;
	text-align: center;
}

#xp1 {
	float: right;
}
