/* Caption 
------------------------------------------------------------------------- */
#caption {
	margin: 0px auto 0px auto;
}

#caption dl {
	font-size: 0px;
	text-align: center;
	line-height: 100%;
	margin: 0px 0px 10px 0px;
	padding: 0px 0px 2px 0px;
}

#caption dl dt {
	width: 100%;
	margin: 0px 0px 18px 0px;
}

#caption dl dt img {
	width: 100%;
	vertical-align: top;
}

#caption dl dd {
	display: inline-block;
	width: calc(50% - 28px);
	margin: 2px 12px 12px 12px;
}

#caption dl dd a {
	position: relative;
	display: block;
	text-align: center;
	vertical-align: middle;
	font-weight: bold;
	color: #333333;
}

@media (min-width: 320px) {
	#caption dl dd a {
		font-size: 12px;
	}
}

@media (min-width: 414px) {
	#caption dl dd a {
		font-size: 16px;
	}
}

@media (min-width: 800px) {
	#caption dl dd a {
		font-size: 18px;
	}
}

#caption dl dd img {
	width: 100%;
}

#caption dl dd:hover img {
	opacity: 0.7;
}

#caption dl dd b {
	position: absolute;
	width: 80%;
	padding: 1px 10px 2px 10px;
	background-color: rgba(255, 255, 255, 0.8);
	top:50%;
	left: 50%;
	transform: translate(-50%,-50%);
	line-height: 170%;
}


/* Support 
------------------------------------------------------------------------- */
#support {
	margin: 10px 0px 10px 0px;
}

#support ul {
	text-align: center;
}

#support ul li {
	display: inline-block;
	margin: 6px 0px 6px 0px;
}

/* Information 
------------------------------------------------------------------------- */
#information {
	margin: 30px 0px 60px 0px;
}

#information h2 {
	margin: 0px auto 20px auto;
	padding: 10px 0px 10px 0px;
	font-size: 20px;
	color: #ffffff;
	width: 90%;
	background-color: #007558;
	font-weight: normal;
	text-align: center;
}

#information h3 {
	margin: 30px auto 20px auto;
	font-size: 14px;
	colorr: #333333;
	border-bottom: 1px solid #333333;
	text-align: center;
	padding: 0px 0px 8px 0px;
}

#information #official {
	width: 90%;
	margin: 0px auto 0px auto;
}

#information #official li {
	border-bottom: 1px solid #dddddd;
}

#information #official li a {
	display: block;
	color: #000066;
	text-decoration: none;
	padding: 0px 0px 10px 0px;
}

#information #official li h4 {
	color: #333333;
	line-height: 18px;
	vertical-align: middle;
	margin: 0px 0px 6px 0px;
}

#information #official li h4 b {
	display: inline-block;
	padding: 0px 6px 1px 6px;
	margin: 0px 10px 0px 0px;
	font-weight: bold;
	font-size: 11px;
	background-color: #ff3333;
	color: #ffffff;
	line-height: 18px;
	vertical-align: top;
	border-radius: 4px;
}

#information #official li a:hover {
	text-decoration: underline;
}

#information #official > a {
	display: block;
	width: 60%;
	color: #333333;
	margin: 16px auto 0px auto;
	padding: 10px 10px 10px 10px;
	border: 1px solid #dddddd;
	text-align: center;
	background-color: #eeeeee;
}

#information #event {
	width: 90%;
	margin: 30px auto 0px auto;
}

#information #event p {
	padding: 6px 10px 6px 10px;
}
