@CHARSET "UTF-8";
/* ページ全体のレイアウト */
* {
	font-family: 'メイリオ','Hiragino Kaku Gothic Pro',sans-serif;
}
body {
	font-size: 14px;
	line-height: 18px;
	color: #666;
	background-color: #fafafa;
	word-wrap:break-word;
}
#globalheader {
	position: fixed;
	width: 100%;
	top: 0px;
	height: 50px;
	overflow: hidden;
	z-index: 1;
	background-color: rgba(250, 250, 250, 0.9);
}
#globalheader h1 {
/*	font-family: "Helvetica Neue",Helvetica, Arial, 'Hiragino Kaku Gothic Pro',Meiryo,'メイリオ', sans-serif; */
	position: absolute;
	left: 50%;
	margin-left: -400px;
	line-height: 40px;
	padding: 3px 10px 7px;
	font-size: 36px;
	
}
#globalheader h1 a {
	color: #277899;
	text-decoration: none;
}
#globalheader nav {
	position: absolute;
	left: 50%;
	margin-right: -400px;
}
#globalheader ul {
	overflow: hidden;
	width: 400px;
}
#globalheader li {
	float: left;
	text-align: center;
	line-height: 50px;
	font-size: 15px;
	width: 30%;
	margin-right: 5%;
}
#globalheader li:last-of-type {
	margin-right: 0px;
}
#globalheader li a {
	color: #999;
	text-decoration: none;
	padding: 0px 0px;
	display: block;
}
#globalheader li a:hover {
	color: #277899;
}
#flashMessage {
	position: fixed;
	top: 50px;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	width: 100%;
	height: 50px;
	padding: 0px 20px;
	line-height: 50px;
	font-size: 18px;
	background-color: rgba(39, 120, 153, 0.9);
	color: #fff;
	z-index: 1;
}
article {
	/*
	width: 800px;
	margin: 0px auto;
	*/
}
.sectionBlock {
	position: relative;
	padding: 100px 0px;
}
.sectionBlock section, .sectionBlock header {
	width: 800px;
	margin: 0px auto;
	padding: 0px 0px 20px;
	overflow: hidden;
}
.sectionBlock section h1 {
	line-height: 20px;
	margin: 0px 10px 20px;
	padding: 10px 0px;
	padding-left: 4px;
	font-size: 16px;
	border-bottom: solid 2px;
}
.sectionBlock section h2 {
	line-height: 16px;
	margin: 10px 10px 0px;
	padding: 10px 0px 0px
	padding-left: 4px;
	font-size: 14px;
}
.sectionBlock section p {
	margin: 0px 10px;
	padding: 10px 0px;
}

.sectionBlock header h1 {
	margin: 0px 10px;
	padding: 20px 0px;
	font-size: 32px;
	line-height: 40px;
	border-bottom: solid 2px;
}
.sectionBlock header p {
	margin: 0px 10px;
	padding: 20px 0px;
}
.sectionBlock:nth-of-type(odd) {
	background-color: #3498db;
	color: #fff;
}
.sectionBlock:nth-of-type(even) {
	background-color: #fafafa;
	color: #666;
}
.sectionBlock:nth-of-type(even) section h1, .sectionBlock:nth-of-type(even) header h1{
	color: #277899;
	border-color: #3498db;
}
.sectionBlock:nth-of-type(odd) section h1, .sectionBlock:nth-of-type(odd) header h1 {
	color: #fff;
	border-bottom-color: #fff;
}
.sectionBlock:nth-of-type(even) section h2, .sectionBlock:nth-of-type(even) header h2{
	color: #277899;
}
.sectionBlock:nth-of-type(odd) section h2, .sectionBlock:nth-of-type(odd) header h2 {
	color: #fff;
}

/*
.sectionBlock:not(:last-child):after {
	position: absolute;
	content: " ";
	bottom: 40px;
	left: 50%;
	width: 0px;
	height: 0px;
	border-style: solid;
	border-width: 10px 16px;
	margin-left: -16px;
	border-color: rgba(250, 250, 250, 0);
	border-top-color: #eee;
}
*/
footer {
	position: fixed;
	bottom: 0px;
	width: 100%;
	height: 40px;
	margin: 0px auto;
	padding: 0px;
	overflow: hidden;
	z-index: 1;
	line-height: 40px;
	background-color: rgba(250, 250, 250, 0.9);
}
footer small {
	font-size: 12px;
	position: absolute;
	right: 50%;
	bottom: 0px;
	bottom: 0px;
	margin-right: -400px;
	padding-right: 10px;
}
#sectionNavigator {
	padding-left: 10px;
	position: absolute;
	left: 50%;
	margin-left: -400px;
	overflow: hidden;
}
#sectionNavigator span {
	display: block;
	float: left;
}
#sectionNavigator span i {
	content: " ";
	display: block;
	width: 12px;
	height: 12px;
	margin: 14px;
	background-color: #ccc;
	border-radius: 6px;
}
#sectionNavigator span i.selected {
	background-color: #277899;
}

/* テーブルのレイアウト */
table.TappyTable {
	margin: 10px auto 10px;
	padding: 0px;
}
.TappyTable th {
	min-width: 28px;
	height: 28px;
	text-align: center;
	vertical-align: middle;
}
.TappyTable td {
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	width: 50px;
	min-width: 50px;
	height: 50px;
	line-height: 48px;
	border: solid 2px #fafafa;
	cursor: pointer;
	vertical-align: top;
	text-align: center;
	font-size: 14px;
	background-color: #ddd;
	color: #fff;
	font-weight: bold;
}
.RenderVerticalPressed td {
	height: 32px;
	line-height: 30px;
}

/* フォームのレイアウト */
input, textarea, .button, .buttonWhite {
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	width: 98%;
	margin: 4px 1%;
	padding: 0px 4px;
	border: none;
	font-size: 16px;
	background-color: #fff;
	display: block;
	text-decoration: none;
	border-radius: 2px;
}
.button[type='submit'] {
	text-align: center;
	line-height: 28px;
	margin: 0px auto;
	border: solid 2px #277899;
	background-color: #3889aa;
	color: #fff;
	font-weight: bold;
	cursor: pointer;
	border-radius: 2px;
}
.button[type='submit']:hover {
	background-color: #499abb;
}
input[type='submit'], .buttonWhite[type='submit'] {
	text-align: center;
	line-height: 24px;
	border: solid 2px #eee;
	background-color: #fafafa;
	color: #277899;
	height: 28px;
	font-weight: bold;
	cursor: pointer;
	border-radius: 2px;
}
input[type='submit']:hover, .buttonWhite[type='submit']:hover {
	background-color: #eee;
}
input[type='text'], input[type='password'], textarea {
	height: 28px;
	line-height: 28px;
	border: solid 2px #eee;
	font-size: 16px;
	background-color: #fff;
	color: #666;
}
input[type='text']:focus, input[type='password']:focus {
	border-color: #ccc;
}
input[type='checkbox'], input[type='radio'] {
	width: 20px;
}
select {
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	width: 100%;
	height: 28px;
	line-height: 32px;
	margin: 4px 0px;
	padding: 0px 4px;
	font-size: 16px;
	background-color: #fff;
	color: #666;
	border: solid 2px #eee;
}
textarea {
	height: 96px;
}
.sectionBlock:nth-of-type(odd) input, .sectionBlock:nth-of-type(odd) textarea, .sectionBlock:nth-of-type(odd) .buttonWhite {
	border-color: #fafafa;
}
/* for Layout */

div.flexible {
	width: 800px;
	margin: 0px auto;
	overflow: hidden;
}
div.flexible > * {
	display: block;
	width: 50%;
	overflow: hidden;
	float: left;
}
.flexible > *.wide {
	width: 67%;
}
.flexible > *.narrow {
	width: 33%;
}

table {
	display: inline-table;
}

/* Utilitys */

#scrollViewer {
	position: relative;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	width: 100%;
	padding: 0px 10px 20px;
	text-align: center;
	overflow : hidden;
}

/* マルチメディア対応 */

@media screen and (max-width : 800px){

	#globalheader h1 {
		left: 0px;
		margin: 0px;
	}
	#globalheader nav {
		right: 0px;
		margin: 0px;
	}
	#globalheader nav > ul {
		width: auto;
	}
	#sectionNavigator {
		left: 0px;
		margin: auto;
	}
	
	footer > small {
		right: 0px;
		margin: auto;
	}
	.sectionBlock section, .sectionBlock header {
		width: 100%;
	}
	div.flexible {
		width: 100%;
	}
}
@media screen and (max-width : 480px){
	#globalheader h1 {
		font-size: 24px;
	}
	#globalheader nav a {
		font-size: 12px;
		font-weight: normal;
	}
	#globalheader nav > ul {
		width: auto;
	}
	#sectionNavigator span i {
		width: 12px;
		height: 12px;
		margin: 14px 8px;
		border-radius: 6px;
	}
	footer > small {
		font-size: 10px;
	}
	.sectionBlock {
		padding: 55px 0px;
	}
	.sectionBlock h1 {
		margin: 5px 0px;
	}
	.sectionBlock header h1{
		font-size: 20px;
		line-height: 24px;
		margin: 5px;
		padding: 5px;
	}
	.sectionBlock header p {
		font-size: 14px;
		line-height: 16px;
	}
	.sectionBlock section h1{
		font-size: 15px;
		line-height: 18px;
		margin: 5px;
		padding: 5px;
	}
	.sectionBlock section p {
		margin: 0px 5px;
		padding: 5px 0px;
		font-size: 14px;
		line-height: 16px;
	}
	div.flexible > * {
		width: 100%;
		float: none;
	}
	div.flexible > *.wide {
		width: 100%;
	}
	div.flexible > *.narrow {
		width: 100%;
	}
	.TappyTable table {
		margin: 0px;
	}
	.TappyTable th {
		min-width: 20px;
		height: 20px;
		font-size: 10px;
	}
	.TappyTable td {
		box-sizing: border-box;
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		width: 40px;
		min-width: 40px;
		height: 40px;
		line-height: 38px;
		font-size: 12px;
	}
	.RenderVerticalPressed td {
		height: 24px;
		line-height: 22px;
	}
	#scrollViewer {
		margin: 0px;
		padding-bottom: 5px;
	}
}