
* {
	font-family: -apple-system, BlinkMacSystemFont, meiryo, arial, sans-serif;
	font-size: 14px;
	margin: 0px;
	padding: 0px;
}

.clearfix:after {
	content: " ";
	display: block;
	clear: both;
}

body {
	text-align: center;
	background: #FFFFFF;
	position: relative;
}

header {
	background-image: url(/img/hbg.png);
	background-repeat: repeat-x;
	background-size: 40px 130px;
	width: 100%;
	height: 130px;
}

h1 a {
	display: block;
	margin: 0px auto;
	background-image: url(/img/h1.png);
	background-size: 800px 80px;
	width: 800px;
	height: 80px;
	text-indent: -9999px;
}

nav {
	width: 840px;
	height: calc(50px - 5px - 5px);
	margin: 0px auto;
	padding: 5px 0px;
}

nav ul,
nav li {
	margin: 0px;
	padding: 0px;
	display: block;
}

nav li a {
	width: 140px;
	height: 40px;
	text-indent: -9999px;
	float: left;
	background-image: url(/img/gmenu.png);
	background-size: 840px 80px;
}

nav li:nth-of-type(1) { display: none; }

nav li:nth-of-type(2) a { 		background-position:    0px 0px; }
nav li:nth-of-type(3) a { 		background-position: -140px 0px; }
nav li:nth-of-type(4) a { 		background-position: -280px 0px; }
nav li:nth-of-type(5) a { 		background-position: -420px 0px; }
nav li:nth-of-type(6) a { 		background-position: -560px 0px; }
nav li:nth-of-type(7) a { 		background-position: -700px 0px; }


nav li:nth-of-type(2) a:hover { background-position:    0px -40px; }
nav li:nth-of-type(3) a:hover { background-position: -140px -40px; }
nav li:nth-of-type(4) a:hover { background-position: -280px -40px; }
nav li:nth-of-type(5) a:hover { background-position: -420px -40px; }
nav li:nth-of-type(6) a:hover { background-position: -560px -40px; }
nav li:nth-of-type(7) a:hover { background-position: -700px -40px; }

/* ************************************************************************************* */

footer {
	clear: both;
	margin: 20px 0px 0px 0px;
	padding: 0px;
	width: 100%;
	background: #1E1E28;
}

footer,
footer a {
	color: #FFFFFF;
}

footer ul,
footer ol {
	list-style-type: none;
}

footer ul {
	width: 800px;
	height: 150px;
	margin: 0px auto;
}

footer ul li:nth-of-type(1) {
	width: 50%;
	height: 150px;
	float: left;
	background-image: url(/img/flogo.png);
	background-repeat: no-repeat;
	background-size: 245px 32px;
	background-position: center;
	text-indent: -9999px;
}

footer ul li:nth-of-type(2) {
	width: 50%;
	float: right;
	text-align: center;
	margin-top: calc((150px - 2rem) / 2);
}

footer hr {
	height: 3px;
	border: none;
	border-top: 3px solid #FFFFFF;
}


footer ol {
	width: 800px;
	height: 36px;
	margin: 0px auto;
}

footer ol li {
	line-height: 36px;
	display: block;
}

footer ol li a { text-decoration: none; }
footer ol li a:hover { color: #828278; }

footer ol li:nth-of-type(1) { float: left; padding-right: 30px; }
footer ol li:nth-of-type(2) { float: left; padding-right: 30px; }
footer ol li:nth-of-type(3) { float: left; }
footer ol li:nth-of-type(4) { float: right; }

footer ol li span {
	display: inline;
}

/* ************************************************************************************* */

h2 { 
	height: 60px;
	line-height: 60px;
	background: #1E489D;
	color: #FFFFFF;
	font-size: 150%;
	text-align: center;
	font-weight: normal;
	letter-spacing: 0.3em;
}

h3 { 
	width: 100%;
	margin: 20px auto 0px auto;
	border-bottom: 2px solid #1E489D;
}

h3 span {
	display: block;
	width: 600px;
	margin: 0px auto;
	text-align: left;
	font-size: 120%;
	color: #1E489D;
}

article {
	width: 600px;
	margin: 10px auto 20px auto;
	text-align: left;
}

blockquote {
	background: #F6F7F7;
	padding-bottom: 10px;
}

blockquote p,
blockquote div {
	width: 800px;
	margin: 0px auto;
	padding: 5px 0px;
	text-align: left;
}
