@charset "utf-8";

/* body
----------------------------------------------------------- */
body {
	color: #333333;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 75%;
	background: #ffffff;
	-webkit-text-size-adjust: 100%;
}


/* ヘッダ
----------------------------------------------------------- */
header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	min-width: 980px;
	height: 126px;
	border-bottom: 28px solid #005e9a;
	background: #fafafa;
	z-index: 200;
}

.header_inner {
	position: relative;
	width: 980px;
	margin: 0 auto;
}

.logo {
	height: 44px;
	padding: 20px 0 0;
}

.global_nav {
	overflow: hidden;
}

.global_nav li {
	float: left;
}

.global_nav a:hover img {
	filter: alpha(opacity=100);
	-moz-opacity: 1;
	opacity: 1;
}

.guide_nav {
	position: absolute;
	top: 20px;
	right: 371px;
	line-height: 25px;
}

.guide_nav li {
	float: right;
	margin: 0 0 0 25px;
}

.font_size {
	position: absolute;
	top: 20px;
	right: 218px;
}

.font_size dt {
	float: left;
	line-height: 25px;
	margin: 0 5px 0 0;
}

.font_size dd {
	float: left;
	line-height: 15px;
	padding: 5px;
	font-size: 91.7%;
	background: #e0e0e0;
}

.font_size dd li {
	float: left;
}

.font_size dd a {
	float: left;
	display: block;
	padding: 0 5px;
	text-decoration: none;
}

.font_size dd a:hover {
	text-decoration: underline;
}

.font_size .textresizer-active {
	color: #ffffff;
	background: #417a9f;
}

header #___gcse_0 {
	position: absolute;
	top: 20px;
	right: 0;
	overflow: hidden;
}

header .gsc-control-cse {
	padding: 0;
	border: none;
	background: none;
}

header form {
	width: 200px !important;
	height: 25px;
	margin: 0 !important;
	padding: 0 !important;
}

header form * {
	margin: 0 !important;
	padding: 0 !important;
	border: none !important;
}

header .gsc-search-button,
header .gsc-clear-button {
	width: 0 !important;
}

header .gsc-input-box {
	background: none !important;
}

header .gsst_b {
	position: absolute !important;
	top: 7px;
	right: 25px;
}

header input[type="text"] {
	width: 148px !important;
	height: 23px !important;
	line-height: 23px;
	padding: 0 45px 0 5px !important;
	border: 1px solid #e0e0e0 !important;
	color: #888888;
	font-size: 14px !important;
	background-color: #ffffff !important;
}

header input[type="image"] {
	position: absolute;
	top: 6px;
	right: 9px;
	border: none !important;
	background: none !important;
}


/* コンテナ
----------------------------------------------------------- */
#container {
	position: relative;
	width: 980px;
	line-height: 1.8;
	margin: 0 auto;
}


/* メイン
----------------------------------------------------------- */
#main {
	position: relative;
	float: right;
	width: 724px;
	margin: 0 0 80px;
	font-size: 116.7%;
	z-index: 100;
}


/* サイド
----------------------------------------------------------- */
#side {
	float: left;
	width: 216px;
	margin: 0 0 80px;
}

.side_nav {
	font-size: 116.7%;
	font-weight: bold;
}

.side_nav li {
	line-height: 1.5;
	border-bottom: 1px solid #ffffff;
}

.side_nav a {
	display: block;
	padding: 15px 10px 15px 30px;
	background: #ededed url(../images/icon_arrow_01.png) no-repeat 16px 50%;
}

.side_nav .current a {
	color: #ffffff;
	text-decoration: none;
	background: #005e9a url(../images/icon_arrow_02.png) no-repeat 16px 50%;
}

.side_nav span {
	display: block;
	background: url(../images/icon_external.png) no-repeat 100% 50%;
}

.side_nav .current li {
	border: none;
	border-top: 1px solid #ffffff;
}

.side_nav .current li a {
	padding: 10px 10px 10px 30px;
	border-left: 8px solid #cccccc;
	color: #333333;
	text-decoration: underline;
	background: #e0e0e0 url(../images/icon_arrow_01.png) no-repeat 16px 50%;
}

.side_nav .current li a:hover {
	text-decoration: none;
}

.side_nav .current .current a {
	border-left: 8px solid #005e9a;
	text-decoration: none;
	background: #a9c3d4 url(../images/icon_arrow_01.png) no-repeat 16px 50%;
}


/* フッタ
----------------------------------------------------------- */
footer {
	position: relative;
	clear: both;
	background: #f2f2f2;
}

.footer_inner {
	width: 960px;
	overflow: hidden;
	margin: 0 auto;
	padding: 15px 0 10px;
}

.footer_inner dl {
	overflow: hidden;
	padding: 0 0 15px;
}

.footer_inner dt {
	float: left;
}

.footer_inner dt img {
	margin: 0 0 7px;
}

.footer_inner dd {
	float: right;
	margin: 0 0 0 20px;
}

.footer_inner ul {
	clear: both;
	padding: 15px 0 0;
	border-top: 1px solid #ffffff;
	font-size: 108.3%;
}

.footer_inner li {
	float: left;
	width: 240px;
	margin: 0 0 10px;
}

.footer_inner li a {
	color: #404040;
	font-weight: bold;
	text-decoration: none;
}

.footer_inner li a:hover {
	text-decoration: underline;
}

footer .page_top {
	height: 40px;
	text-align: center;
	background: #dfdfdf;
}

footer .page_top a {
	display: block;
}

footer small {
	display: block;
	height: 35px;
	line-height: 35px;
	color: #ffffff;
	text-align: center;
	background: #125e99;
}