@charset "utf-8";

a:link {
	color: #658D07;
	text-decoration: none;
}

a:visited {
	color: #A4AF08;
}

a:hover {
	color: #CC8E00;
	text-decoration: underline;
}

a:active {
	color: #FC6;
}

#contents {
	color: #494949;
}

#contents h1 {
	color: #658D07;
	font-size: 125%;
	border: 1px solid #658D07;
	padding: 7px 10px;
	margin-bottom: 25px;
}

#contents h2 {
	color: #658D07;
	font-size: 100%;
	border-bottom: 2px solid #658D07;
	padding-bottom: 5px;
	margin-bottom: 15px;
}

#contents h3 {
	color: #666;
	font-size: 90%;
	border-bottom: 1px solid #CCC;
	padding-bottom: 5px;
	margin-bottom: 8px;
}

#contents h3.shikaku {
	color:#666;
	margin-bottom:10px;
	background:url(images/news_arrow.gif) no-repeat left 4px;
	padding-left:20px;
	line-height:150%;
}

#contents h4 {
	color: #333;
	font-size: 90%;
	margin-bottom: 12px;
	padding: 2px 10px;
	display: inline-block;
	background: #EEE;
	border-radius: 5px;

}

#contents h5 {
	color: #658D07;
	font-size: 90%;
	border-bottom: 1px dotted #CCC;
	padding-bottom: 5px;
	margin-bottom: 15px;
	font-weight: normal;
}

#contents h6 {
	color: #658D07;
	font-size: 90%;
	border-bottom: 2px solid #658D07;
	padding-bottom: 5px;
	margin-bottom: 15px;
}

#contents p {
	font-size: 90%;
	line-height: 150%;
	margin: 0 0 20px 0;
}

#contents ul {
	margin: 0 0 20px 10px;
}

#contents ul li {
	background: url(images/liStandard.gif) no-repeat left 10px;
	padding-left: 15px;
}

#contents ol {
	margin: 0 0 20px 10px;
}

#contents ol li {
	list-style-type: decimal;
	margin-left: 0.5em;
}

#contents ol.alpha li {
	list-style-type: lower-alpha;
}

#contents li {
	margin: 0 auto 5px;
	line-height: 150%;
	font-size: 90%;
}

#contents ul li ul {
	margin: 10px 0 0 0;
	font-size: 110%;
}

#contents ul li ul li {
	background: url(images/liTriangle.gif) no-repeat left 6px;
}

#contents ol li ul {
	margin: 10px 0;
	font-size: 100%;
}

#contents ol li ul li {
	list-style-type: none;
	background: url(images/liTriangle.gif) no-repeat left 6px;
}

#contents dl {
	margin-left: 20px;
	font-size: 90%;
}

#contents dt {
	font-weight: bold;
}

#contents dd {
	margin: 10px 0 20px 1em;
	line-height: 150%;
}

hr {
	border: dotted #999;
	border-width: 1px 0px 0px 0px;
	height: 1px;
	overflow: hidden;
	margin: 8px 0 16px;
	clear: both;
}

#contents table {
	margin: 0 0 20px 0;
	border-collapse: collapse;
	border: none;
	line-height: 150%;
	empty-cells: show;
	font-size: 90%;
}

#contents caption {
	font-size: 85%;
	color: #494949;
	text-align: left;
	margin-bottom: 5px;
}

#contents td,
#contents th {
	border: 3px solid #FFF;
	padding: 5px 10px;
	vertical-align: top;
	line-height: 150%;
	background: #F8F8F8;
}

#contents th {
	color: #777;
	text-align: left;
	white-space: nowrap;
	background: #F3F4E8;
}

#contents td p {
	margin: 0;
	padding: 0;
	font-size: 100%;
}

#contents td ul {
	margin: 0;
	padding: 0;
	font-size: 110%;
}

#contents td ol {
	margin: 0 0 0 15px;
	padding: 0;
	font-size: 110%;
}

#contents th.thCenter {
	text-align: center;
}

#contents th.thRignt {
	text-align: right;
}

#contents table td.vMiddle {
	vertical-align: middle;
}

#contents blockquote {
	color: #333;
	margin: 10px 20px;
	line-height: 150%;
	font-size: 90%;
	font-style: italic;
}

.otoiawase {
	border: 2px solid #E8EAE5;
	padding-bottom: 10px;
	margin-bottom: 10px;
	margin-top: 50px;
}

#contents .otoiawase h2 {
	background: #EEF3F9;
	font-size: 94%;
	padding: 5px 10px;
	margin-left: 0;
	margin-bottom: 5px;
	border-bottom: none;
	border-left: none;
}

#contents .otoiawase p {
	margin: 0 10px 0 20px;
	font-size: 90%;
}

#contents .otoiawase p img {
	vertical-align: middle;
}

#contents ul li ol li {
	list-style-type: decimal;
	list-style-image: none;
	background: none;
	padding: 0;
	margin: 10px 0;
}

.columnL {
	float: left;
	width: 320px;
	padding-right: 10px;
}

.columnR {
	float: right;
	width: 320px;
	padding-left: 10px;
}

#wide .columnL,
#englishWide .columnL {
	float: left;
	width: 370px;
	padding-right: 10px;
}

#wide .columnR,
#englishWide .columnR {
	float: right;
	width: 370px;
	padding-left: 10px;
}

#contents ul.pubMenu li {
	float: left;
	width: 300px;
}

#contents ul.pubMenuImg li {
	float: left;
	width: 315px;
	background: none;
	padding-left: 0;
	display: block;
	margin-right: 20px;
	margin-bottom: 20px;
}

#contents ul.pubMenuImg li img {
	float: left;
	margin: 0 20px 0 0;
	box-shadow: 2px 2px 5px 2px rgba(0, 0, 0, 0.1);
}

.photoAreaL {
	float: left;
	margin: 0 20px 30px;
}

.photoAreaR {
	float: right;
	margin: 0 20px 30px;
}

#contents .photoAreaL p,
#contents .photoAreaR p {
	margin: 0;
	padding: 5px;
	background: #EEE;
	font-size: 80%;
	line-height: 150%;
}

#contents p.marginZero {
	margin: 0;
	padding: 1px;
}

#contents p.marginZero img {
	border: 4px solid #FFF;
}

.imgLeft,
#contents p.imgLeft {
	float: left;
	margin-right: 25px;
	margin-bottom: 15px;
}

.imgRight,
#contents p.imgRight {
	float: right;
	margin-left: 25px;
	margin-bottom: 15px;
}

.shadow {
	box-shadow: 2px 2px 5px 2px rgba(0, 0, 0, 0.1);
}

.dottedLine {
	border: dotted 2px #999;
	padding: 10px 30px;
}

.kakomiDouble {
	margin: 0 20px;
	border: 3px #CCC double;
	padding-top: 15px;
}

.kakomiDouble2 {
	margin: 0 20px 10px 20px;
	border: 3px #CCC double;
	padding-top: 15px;
}

.kakomiSingle {
	margin: 0 20px 20px 20px;
	border: 1px #CCC solid;
	padding: 0 10px;
}

.kakomi {
	margin: 0 20px;
	padding: 15px 30px 10px;
	border: 1px solid #CCC;
	background: #F8F8F8;
}

.kakomiIndent {
	margin: 0 20px;
	padding: 0 30px;
}


.relative {
	position: relative;
}

.toAppli {
	position: absolute;
	top: 11px;
	right: 30px;
}

.overflow {
	overflow: hidden;
}





/**********************************
Additional Styles
**********************************/
#contents ul.prevNext {
	list-style-image: none;
	margin: 0 0 10px;
	padding: 0;
	line-height: 30px;
}

#contents ul.prevNext li.prevPage {
	float: left;
}

#contents ul.prevNext li.nextPage {
	float: right;
}

.getAcro {
	background-color: #FEFEFE;
	border: 1px solid #EEE;
	margin: 20px auto;
}

.getAcro img {
	float: left;
	margin: 10px 15px;
}

#topContents .getAcro p.acrobat,
#contents .getAcro p.acrobat {
	font-size: 80%;
	margin-bottom: 0;
	margin-left: 120px;
	padding: 10px;
	text-indent: 0;
	color: #494949;
}

#topContents .getAcro {
	width: 500px;
}




#contents #cse table,
#contents #cse th,
#contents #cse td {
	border: none;
	margin: 0;
	padding: 0;
}

.gsc-cursor-box {
	text-align: center;
}

.gsc-wrapper {
	margin-top: 30px;
}

.gsc-input input.gsc-input {
	height: 22px;
	padding: 1px 2px;
}



.gsc-clear-button div.gsc-clear-button {
	margin-left: 0;
	height: 26px;
	line-height: 26px;
}

form.gsc-search-box table.gsc-search-box td.gsc-input {
	padding-right: 8px;
}

#contents .gsc-control-cse table,
#contents .gsc-control-cse th,
#contents .gsc-control-cse td {
	border: none;
	margin: 0;
}

#contents .gsc-result-info {
	text-align: left;
}

#contents .gsc-cursor-box {
	text-align: center;
	margin-top: 40px;
	margin-bottom: 60px;
}

#contents .gsc-control-cse td {
	background: none;
}


#contents table.tablesorter tr.even td {
	background: #FDFEFD;
}

#contents table.tablesorter th {
	cursor: pointer;
}

#contents table.tablesorter thead tr .header {
	background-image: url("images/bg.gif");
	background-position: right center;
	background-repeat: no-repeat;
	cursor: pointer;
}

#contents table.tablesorter thead tr .headerSortUp {
	background-image: url("images/asc.gif");
}

#contents table.tablesorter thead tr .headerSortDown {
	background-image: url("images/desc.gif");
}

#contents table.tablesorter thead tr .headerSortDown,
#contents table.tablesorter thead tr .headerSortUp {
	background-color: #EFF2CD;
}

.readmore {
	text-align: right;
}

.readmore a {
	background: url(images/toIchiran.png) no-repeat left center;
	padding-left: 20px;
}

#topicsPage img {
	float: left;
	margin-right: 20px;
	margin-bottom: 5px;
	border: 1px solid #EEE;
	-webkit-box-shadow: 2px 2px 5px 2px rgba(0, 0, 0, 0.1);
	box-shadow: 2px 2px 5px 2px rgba(0, 0, 0, 0.1);
}

#contents #acMenu dl {
	margin: 0;
}

#contents #acMenu dt {
	display: block;
	width: 660px;
	cursor: pointer;
	padding: 10px;
	background: #F4F4F4;
	border-bottom: 4px solid #FFF;
}

#contents #acMenu dd {
	width: 660px;
	padding: 10px;
	margin: 0 0 40px;
}

#contents #acMenu dl span {
	display: table-cell;
	padding-right: 20px;
}



#contents #topicsArea h3 {
	color: #494949;
	margin-bottom: 10px;
	font-size: 90%;
	background: url(images/news_arrow.gif) no-repeat left 4px;
	padding-left: 20px;
	line-height: 150%;
	border: none;
}

#contents #topicsArea p {
	font-size: 90%;
	margin: 0 0 15px;
	line-height: 150%;
	color: #494949;
	border-bottom: 1px dotted #999;
	padding-bottom: 20px;
	padding-left: 20px;
}


#contents table.faqTable {
	width: 100%;
	margin-bottom: 20px;
}

#contents table.faqTable,
#contents .faqTable th,
#contents .faqTable td {
	border: none;
}

#contents .faqTable th,
#contents .faqTable td {
	padding: 5px;
	background: #FFF;
}

#contents .faqTable .question {
	background: #F4F4F4;
	font-weight: bold;
}

#contents .faqTable th {
	width: 30px;
}




/*    I do not use too much    */

.textBlueBold {
	color: #4d66cc;
	font-weight: bold;
}

.textPurple {
	color: #6A5ACD;
}

.textGreen {
	color: #20B2AA;
}

.textGray {
	color: #999;
}

.backYellow {
	background: #FFFFF1
}

.backGreen {
	background: #EEFFF7
}

.backBlue {
	background: #E6F7FF
}

.backPink {
	background: #FFEEFF
}

.backPurple {
	background: #EEEEFF
}

.backGray {
	background: #F0F0F0;
}

.backOrange {
	background: #FFF3E8;
}


.anchor {
	position: absolute;
	top: 11px;
	right: 15px;
	display: flex;
}

a.down {
	background: url(images/iconDown.png) no-repeat left center;
	padding-left: 20px;
	color: #fd7142;
	font-size: 85%;
	font-weight: bold;
	margin-left: 2em;
}

a.next {
	background: url(images/iconNext.png) no-repeat left center;
	padding-left: 20px;
	color: #fd7142;
	font-size: 85%;
	font-weight: bold;
	margin-left: 2em;
}

#contents ul.horMenu {
	display: flex;
	margin: 0 auto 20px;
	justify-content: center;
}

#contents ul.horMenu li {
	background: url(images/iconDown.png) no-repeat left center;
	padding-left: 20px;
}

.accordion {
	cursor: pointer;
	position: relative;
}

.accordion:after {
	content: '';
	display: block;
	width: 6px;
	height: 6px;
	border-top: 2px solid #CCC;
	border-right: 2px solid #CCC;
	transform: rotate(135deg);
	position: absolute;
	top: calc(50% - 6px);
	right: 10px;
}

.accordion.open:after {
	transform: rotate(-45deg);
	top: calc(50% - 3px);
}

.flex3 {
	display: flex;
	justify-content: space-between;
	margin: 20px 0 30px;
}

#contents h3.shikaku {
	color: #494949;
	margin-bottom: 10px;
	font-size: 90%;
	background: url(images/news_arrow.gif) no-repeat left 4px;
	padding-left: 20px;
	line-height: 150%;
	border-bottom: none;
}


@media screen and (max-width:599px) {
	#topContents .getAcro {
		margin: 30px 20px 10px;
		width: calc(100% - 40px);
	}

	form.gsc-search-box table.gsc-search-box td.gsc-input {
		padding-right: 0;
	}

	.gsc-search-button-v2 {
		width: 39px !important;
		height: 39px !important;
	}

	.columnL,
	.columnR {
		float: none;
		padding: 0;
		width: 100%;
	}

	#contents .columnL ul {
		margin: 0 0 0 10px;
	}

	#contents table {
		width: 100%;
	}

	#contents th {
		white-space: wrap;
	}

	.anchor {
		display: none;
	}
}