@charset "utf-8";

/* 基本スタイル---------------- */
html {
	overflow-y: scroll;
}
body {
	margin: 0;
	color: #000;
	background: #fff;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS P Gothic", sans-serif;
	text-align: center;
}
div, ul, ol, li, dl, dt, dd, form, input, textarea {
	margin: 0;
	padding: 0;
}
h1 {
	margin: 5px;
	text-align: left;
	font-size: 100%;
	font-weight: normal;
	color: #333;
}
h2, h3, h4, h5 {
	margin: 0;
	padding: 0;
	font-size: 100%;
}
img {
	border: 0;
}
p {
	margin: 0 0 20px 0;
	line-height: 160%;
}
a:link {
	color: #00f;
	text-decoration: underline;
}
a:visited {
	color: #60f;
	text-decoration: underline;
}
a:hover {
	color: #00f;
	text-decoration: none;
}
ul {
	list-style: none;
}
li {
	line-height: 100%;
}
input, textarea {
	margin: 0 0 3px 0;
	padding: 5px;
	border: 1px solid #999;
}
label {
	cursor: pointer;
}


/* 基本レイアウト---------------- */
#wrapper {
	width: 960px;
	margin: 0 auto;
	text-align: left;
}
#container {
	clear: both;
	width: 960px;
}
#main01 {
	margin-bottom: 20px;
	padding: 20px;
	border: 2px solid #8ED22E;
}
#main02 {
	margin-bottom: 20px;
	padding: 20px;
	border: 2px solid #c00;
}
#pankuzu {
	padding: 10px 0 20px 5px;
}
#pankuzu ul li {
	display: inline;
	margin-right: 10px;
	padding-left: 15px;
	background: url(../img/icon01.gif) no-repeat left center;
}
#main {
	width: 650px;
	float: left;
}
#side {
	width: 270px;
	float: right;
}



/* ヘッダー---------------- */
#header {
	width: 960px;
	height: 130px;
}
#header-logo {
	width: 710px;
	float: left;
}
#header2 {
	width: 200px;
	float: right;
}
#tsize {
	margin: 10px 0 0 0;
	padding: 0;
	list-style: none;
}
#tsize li {
	margin: 0 0 0 5px;
	padding: 0;
	float: left;
}
#tsize0 {
	width: 90px;
	height: 30px;
}

#navi {
	clear: both;
	width: 960px;
	height: 65px;
	margin: 0;
	padding: 0;
	list-style: none;
}
#navi li {
	float: left;
	margin: 0;
	padding: 0;
}
#navi01 a, #navi02 a, #navi03 a, #navi04 a, #navi05 a, #navi06 a {
	display: block;
	width: 160px;
	height: 65px;
	text-indent: -9999em;
	background: url(../img/navi1.gif) no-repeat;
	overflow: hidden;
}
#navi01 a {
	background-position: 0 0;
}
#navi01 a:hover {
	background-position: 0 -65px;
}
#navi01-on a {
	display: block;
	width: 160px;
	height: 65px;
	text-indent: -9999em;
	background: url(../img/navi1.gif) no-repeat;
	overflow: hidden;
	background-position: 0 -65px;
}
#navi02 a {
	background-position: -160px 0;
}
#navi02 a:hover {
	background-position: -160px -65px;
}
#navi02-on a {
	display: block;
	width: 160px;
	height: 65px;
	text-indent: -9999em;
	background: url(../img/navi1.gif) no-repeat;
	overflow: hidden;
	background-position: -160px -65px;
}
#navi03 a {
	background-position: -320px 0;
}
#navi03 a:hover {
	background-position: -320px -65px;
}
#navi03-on a {
	display: block;
	width: 160px;
	height: 65px;
	text-indent: -9999em;
	background: url(../img/navi1.gif) no-repeat;
	overflow: hidden;
	background-position: -320px -65px;
}
#navi04 a {
	background-position: -480px 0;
}
#navi04 a:hover {
	background-position: -480px -65px;
}
#navi04-on a {
	display: block;
	width: 160px;
	height: 65px;
	text-indent: -9999em;
	background: url(../img/navi1.gif) no-repeat;
	overflow: hidden;
	background-position: -480px -65px;
}
#navi05 a {
	background-position: -640px 0;
}
#navi05 a:hover {
	background-position: -640px -65px;
}
#navi05-on a {
	display: block;
	width: 160px;
	height: 65px;
	text-indent: -9999em;
	background: url(../img/navi1.gif) no-repeat;
	overflow: hidden;
	background-position: -640px -65px;
}
#navi06 a {
	background-position: -800px 0;
}
#navi06 a:hover {
	background-position: -800px -65px;
}
#navi06-on a {
	display: block;
	width: 160px;
	height: 65px;
	text-indent: -9999em;
	background: url(../img/navi1.gif) no-repeat;
	overflow: hidden;
	background-position: -800px -65px;
}



/* フッター---------------- */
.pagetop {
	margin-bottom: 20px;
	padding: 5px;
	text-align: right;
	font-size: 90%;
}
#footer {
	clear: both;
	width: 960px;
	margin-bottom: 5px;
}
#copy {
	text-align: center;
	padding: 20px;
	font-size: 90%;
	background: #8ED22E;
}


/* トップページ---------------- */
#top-img {
	margin-bottom: 20px;
}
#top-info {
	overflow: auto;
	margin: 0 0 0px 0;
	padding: 10px 15px;
	list-style: none;
	/*background: url(../img/bg01.jpg) repeat-x;*/
}
#top-info li {
	margin: 0;
	padding: 0 0 3px 18px;
	background: url(../img/icon01.gif) no-repeat;
	background-position: 0 0.5em;
	border-bottom: 1px dotted #ccc;
	line-height: 190%;
}
.new1 {
	padding-left: 5px;
	color: #f00;
}
.top-bn1 {
	margin-bottom: 15px;
}
.top-bn1 a:hover {
	opacity: 0.7;
	transition: 0.2s;
}



/* サイドメニュー---------------- */
.side01 {
	margin-bottom: 20px;
	padding: 10px 15px;
	background: url(../img/bg01.jpg) repeat-x;
	text-align: center;
}
.side02 {
	padding: 10px;
	border: 2px solid #8ED22E;
}
.side03 {
	padding: 10px;
	border: 2px solid #c00;
}



/* 下層ページ---------------- */
.content01 {
	padding: 0 10px 0 10px;
}
.content01 h4 {
	margin-bottom: 5px;
}
.content01 p {
	margin: 0 0 15px 20px;
}
.tab01 {
	width: 100%;
	margin-bottom: 5px;
	border-collapse: collapse;
}
.tab01 th {
	padding: 5px;
	text-align: center;
	color: #fff;
	background: #06c;
	border: 1px solid #ccc;
}
.tab01 td {
	padding: 5px;
	text-align: center;
	border: 1px solid #ccc;
}
.tab01 .td01 {
	background: #eee;
}
.tab02 {
	width: 100%;
	margin-bottom: 20px;
	border-collapse: separate;
}
.tab02 th {
	padding: 5px;
	text-align: left;
}
.tab02 td {
	padding: 5px;
}
.tab03 {
	width: 100%;
	margin-bottom: 20px;
	border-collapse: collapse;
}
.tab03 th {
	width: 11em;
	padding: 5px;
	text-align: center;
	font-weight: normal;
	border: 1px solid #ccc;
}
.tab03 td {
	padding: 5px;
	border: 1px solid #ccc;
}
.submit-b {
	margin-bottom: 20px;
	text-align: center;
}
.submit-b input {
	width: 16em;
	margin: 0 auto;
	color: #fff;
	font-size: 100%;
	font-weight: bold;
	text-shadow: 1px 1px 3px #060;
	text-align: center;
	display: block;
	text-decoration: none;
	border: 1px solid #060;
	padding: 15px 0;
	border-radius: 5px;
	background: #339900;
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#339900', endColorstr='#006600'); /* for IE */
	background: -webkit-gradient(linear, left top, left bottom, from(#339900), to(#006600)); /* for webkit browsers */
	background: -moz-linear-gradient(top,  #339900,  #006600); /* for firefox 3.6+ */
	box-shadow: 1px 2px 2px rgba(0,0,0,0.3), 0px 1px 0px rgba(255,255,255,0.5) inset, 0px -1px 0px rgba(255,255,255,0.2) inset;
	cursor: pointer;
}
.submit-b input:hover {
	background: #f60;
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff6600', endColorstr='#ff3300'); /* for IE */
	background: -webkit-gradient(linear, left top, left bottom, from(#ff6600), to(#ff3300)); /* for webkit browsers */
	background: -moz-linear-gradient(top,  #ff6600,  #ff3300); /* for firefox 3.6+ */
}
.error_coution {
	color: #f00;
	font-weight: bold;
}




/* 共通スタイル---------------- */
.clear1 {
	clear: both;
}
.clearfix:after {  
	content: ".";   
	display: block;   
	height: 0;   
	clear: both;   
	visibility: hidden;  
}
.right01 {
	float: right;
}
.h-img1 {
	margin: 0;
}
.h-img2 {
	margin-bottom: 10px;
}
.h-img3 {
	margin-bottom: 15px;
}
.h-img1 a:hover, .h-img2 a:hover, .h-img3 a:hover {
	opacity: 0.7;
	transition: 0.2s;
}
.h3-1 {
	margin-bottom: 20px;
	padding-left: 8px;
	font-size: 130%;
	border-left: 7px solid #8ED22E;
}
.h3-2 {
	padding: 6px;
	text-align: center;
	font-size: 110%;
	color: #000;
	background: #8ED22E;
}
.h3-3 {
	margin-bottom: 20px;
	padding-left: 8px;
	font-size: 130%;
	border-left: 7px solid #c00;
}
.h3-4 {
	padding: 6px;
	text-align: center;
	font-size: 110%;
	color: #fff;
	background: #c00;
}
.p01 {
	margin-bottom: 20px;
}
.p02 {
	margin-bottom: 20px;
	font-size: 90%;
}

.p03 {
	margin-bottom: 10px;
	font-size: 90%;
}
.col01 {
	width: 700px;
	float: left;
}
.col02 {
	width: 240px;
	float: right;
}
.col03 {
	width: 400px;
	float: left;
}
.col04 {
	width: 500px;
	float: right;
}
.col05 {
	width: 500px;
	float: left;
}
.col06 {
	width: 400px;
	float: right;
}
.col07 {
	width: 650px;
	float: left;
}
.col08 {
	width: 325px;
	float: left;
	margin-bottom: 5px;
}
.waku01 {
	margin-bottom: 20px;
	padding: 10px;
	background: #eee;
	border: 1px dotted #8ED22E;
}
.waku01 p {
	margin-bottom: 0;
}
.sage01 {
	margin-left: 1em;
	text-indent: -1em;
}
.line01 {
	text-decoration: underline;
}

.center1 {
	text-align: center;
}
.ul01 {
	margin: 0;
	list-style: none;
}
.ul01 li {
	margin-bottom: 5px;
	padding-left: 20px;
	line-height: 150%;
	background: url(../img/icon01.gif) no-repeat;
	background-position: left center;
}
.ul02 {
	margin-bottom: 30px;
}
.ul02 li {
	float: left;
	margin: 0 20px 5px 0;
	padding-left: 18px;
	line-height: 150%;
	background: url(../img/icon02.gif) no-repeat;
	background-position: left center;
}
.ul03 {
	margin: 0 0 20px 0;
	list-style: none;
}
.ul03 li {
	margin-bottom: 5px;
	padding-left: 20px;
	line-height: 150%;
	background: url(../img/icon02.gif) no-repeat;
	background-position: left center;
}
.dl01 {
	margin: 0 0 10px 20px;
}
.dl01 dt {
	width: 4em;
}
.dl01 dd {
	margin: -1.5em 0 0.5em 4em;
}
.dl02 {
	margin: -15px 0 20px 20px;
}
.dl02 dt {
	width: 5em;
}
.dl02 dd {
	margin: -1.5em 0 0.5em 6em;
}
.txt01 {
	color: #f00;
}
.space01 {
	margin-bottom: 20px;
}
.img01 {
	vertical-align: -0.2em;
}

.ul04 {
	margin: 0 0 20px;
	list-style: none;
}.ul04 li{
	margin-bottom: 5px;
}
.ul04 li a{
	margin-bottom: 5px;
	padding-left: 25px;
	line-height: 150%;
	background: url(../img/icon-pdf.gif) no-repeat;
	background-position: left center;
}

.ul-1em {
	margin-left:20px;
	margin-bottom:20px;
	list-style: none;
}.ul-1em li{
	margin-left:1em;
	text-indent:-1em;
	line-height: 150%;
}
.ul-1em2 {
	margin-left:20px;
	margin-bottom:0;
	list-style: none;
}.ul-1em2 li{
	margin-left:1em;
	text-indent:-1em;
	line-height: 150%;
}
.ul-1em3 {
	margin-bottom:0;
	list-style: none;
}.ul-1em3 li{
	margin-left:1em;
	text-indent:-1em;
	line-height: 150%;
}
.flex{
	display:flex;
}
.flex > div{
	margin-right:1em;
	flex:1;
}
.flex > div:last-child{
	margin-right:0em;
}
.flex2{
	display:flex;
	align-items:center;
}
.flex2 > div{
	margin-right:1em;
	flex:1;
}
.flex2 > .left{
	text-align:left;
}
.flex2 > .right{
	text-align:right;
}
.flex2 > div:last-child{
	margin-right:0em;
}
.navy{
color:#0033CC;
}
.red{
color:#FF0000;
}

@media print {
#pagetop,
#footer,
#add,
#footer2,
#copy,
#counter {
	display: none;
}
}


.news-link{
	text-align:right;
	margin:0px 0 30px;
	padding-right:15px;
	background:url(../img/icon01.gif) top 0.35em right no-repeat;
}

.sponsor-title{
	text-align:center;
	font-size:1.6em;
	margin-bottom:40px;
	font-weight:bold;
}
.sponsor-note{
	text-align:right;
	margin-bottom:0px;
	font-size:12px;
}
.sponsor-thx{
	text-align:left;
	font-size:1em;
	font-weight:bold;
}
.sponsor-01{
	display:flex;
	flex-direction:column;
	margin:0 auto 50px;
	width:100%;
}
.sponsor-01 li{
	text-align:justify;
	text-align-last: justify;
	text-justify: inter-ideograph;
	width:55%;
	margin:0 auto 0;
	font-size:24px;
	line-height:1.5;
	font-weight:bold;
	margin-bottom:0.3em;
}
.sponsor-02{
	margin:0 auto 30px;
	width:100%;
	text-align:center;
	display:flex;
	justify-content:space-around;
}
.sponsor-02{
	flex:1;
}
.sponsor-02 li{
	text-align:left;
	font-size:22px;
	line-height:1.5;
	font-weight:bold;
	margin-bottom:0.3em;
}
.sponsor-03{
	display:flex;
	
	justify-content: space-around;
	flex-wrap:wrap;
	font-size:20px;
	letter-spacing: -2px;
	margin:0 auto 30px;
	width:100%;
}
.sponsor-03 li{
	text-align:left;
	width:48%;
	line-height:1.3;
	font-weight:bold;
	margin-bottom:0.3em;
}
.sponsor-03 li:nth-child(3n-1){
	width:48%;
}
.sponsor-04{
	display:flex;
	justify-content: space-around;
	flex-wrap:wrap;
	letter-spacing: -2px;
	font-size:18px;
	margin:0 auto 30px;
	width:100%;
}
.sponsor-04 li{
	text-align:left;
	width:48%;
	line-height:1.5;
	margin-bottom:0.3em;
}
.sponsor-04 li:nth-child(3n-1){
	width:48%;
}
.sponsor-05{
	display:flex;
	justify-content: space-between;
	flex-wrap:wrap;
	letter-spacing: -1.5px;
	font-size:16px;
	margin:0 auto 30px;
	width:100%;
}
.sponsor-05 li{
	text-align:left;
	width:30%;
	line-height:1.5;
	margin-bottom:0.3em;
}
.sponsor-05 li:nth-child(3n+1){
	width:38%;
}
.sponsor-06{
	display:flex;
	justify-content: space-between;
	flex-wrap:wrap;
	letter-spacing: -1px;
	font-size:14px;
	margin:0 auto 0px;
	width:100%;
}
.sponsor-06 li{
	text-align:left;
	width:30%;
	line-height:1.5;
	margin-bottom:0.3em;
}
.sponsor-06 li:nth-child(3n-1){
	width:38%;
}