@-webkit-keyframes h1_rotate_01 {
0% {
-webkit-transform:rotate(0deg);
transform:rotate(0deg)
}
50% {
-webkit-transform:rotate(180deg);
transform:rotate(180deg)
}
100% {
-webkit-transform:rotate(360deg);
transform:rotate(360deg)
}
}
@keyframes h1_rotate_01 {
0% {
-webkit-transform:rotate(0deg);
transform:rotate(0deg)
}
50% {
-webkit-transform:rotate(180deg);
transform:rotate(180deg)
}
100% {
-webkit-transform:rotate(360deg);
transform:rotate(360deg)
}
}
@-webkit-keyframes h1_rotate_02 {
0% {
-webkit-transform:rotate(0deg);
transform:rotate(0deg)
}
50% {
-webkit-transform:rotate(-180deg);
transform:rotate(-180deg)
}
100% {
-webkit-transform:rotate(-360deg);
transform:rotate(-360deg)
}
}
@keyframes h1_rotate_02 {
0% {
-webkit-transform:rotate(0deg);
transform:rotate(0deg)
}
50% {
-webkit-transform:rotate(-180deg);
transform:rotate(-180deg)
}
100% {
-webkit-transform:rotate(-360deg);
transform:rotate(-360deg)
}
}
body {
	font-family: Roboto, "Droid Sans", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
	background: url(../images/body_bg_left.png) no-repeat top left, url(../images/body_bg_right.png) no-repeat bottom right;
	background-size: 50%;
	background-attachment: fixed
}
#wrap {
	border-top: 3px solid #003166;
	width: 100%;
	min-width: 960px
}
#hd {
	width: 960px;
	margin: 0 auto;
	overflow: hidden;
	padding: 30px 0;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-webkit-justify-content: space-between;
	-ms-flex-pack: justify;
	justify-content: space-between
}
#hd h1 {
	width: 250px
}
#hd h1 img {
	width: 100%
}
#hd h1.en {
	width: 250px
}
#hd h1.en img {
	width: 100%
}
#hd .language ul {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex
}
#hd .language ul li {
	margin-left: 5px
}
#hd .language ul li a {
	display: block;
	color: #333;
	padding: 2px 15px;
	text-decoration: none;
	-webkit-transition: All 0.5s ease;
	transition: All 0.5s ease;
	position: relative
}
#hd .language ul li a:before {
	z-index: -1;
	content: "";
	width: 30px;
	height: 30px;
	border: 1px solid #ddd;
	position: absolute;
	left: 0;
	left: 0;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
	background: rgba(0,45,104,0.05);
	-webkit-transition: All 0.5s ease;
	transition: All 0.5s ease
}
#hd .language ul li a:hover:before {
	z-index: -1;
	content: "";
	width: 30px;
	height: 30px;
	border: 1px solid #ddd;
	position: absolute;
	left: 0;
	left: 0;
	-webkit-transform: rotate(90deg);
	-ms-transform: rotate(90deg);
	transform: rotate(90deg);
	background: rgba(0,45,104,0.05)
}
#nav_bg {
	width: 100%;
	min-width: 960px
}
#nav_bg .nav {
	border-top: 1px solid #ddd;
	border-bottom: 1px solid #ddd;
	padding: 15px;
	width: 960px;
	margin: 0 auto;
	overflow: visible
}
#nav_bg .nav ul {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	width: 100%;
	z-index: 1000
}
#nav_bg .nav ul li {
	/*display: table-cell;*/
	width: calc(100% / 6);
	border-left: 1px solid #ddd;
	position: relative;

}
#nav_bg .nav ul li a {
	display: block;
	font-weight: bold;
	color: #666;
	text-align: center;
	text-decoration: none;
	padding: 12px 0 2px 0;
	position: relative
}
#nav_bg .nav ul li:after {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 5px 4px 0 4px;
	border-color: #666 transparent transparent transparent;
	position: absolute;
	left: calc(50% - 4px);
	top: 0;
	-webkit-transition: All 0.5s ease;
	transition: All 0.5s ease
}
#nav_bg .nav ul li:first-child {
	border-left: 1px solid rgba(242,242,242,0.3)
}
#nav_bg .nav ul li:hover a {
	color: #003166
}
#nav_bg .nav ul li:hover:after {
	top: 5px;
	border-color: #003166 transparent transparent transparent !important
}
#nav_bg .nav ul li.current-menu-item a, #nav_bg .nav ul li.current-menu-parent a {
	color: #003166
}
#nav_bg .nav ul li.current-menu-item:after, #nav_bg .nav ul li.current-menu-parent:after {
	top: 5px;
	border-color: #003166 transparent transparent transparent !important
}
#nav_bg .nav ul ul {
	display: none;
	width: 100%;
	position: absolute;
	top: 100%;
	left: 0
}
#nav_bg .nav ul ul li {
	display: block;
	width: 100%;
	border: none !important
}
#nav_bg .nav ul ul li a {
	background: rgba(0,0,0,0.7) !important;
	padding: 10px;
	text-decoration: none;
	color: #fff !important;
	display: block;
	border: none;
	border-bottom: 1px solid rgba(255,255,255,0.4)
}
#nav_bg .nav ul ul li.current-menu-item {
	background: rgba(0,0,0,0.5) !important
}
#nav_bg .nav ul ul li.current-menu-item a {
	color: #003166
}
#nav_bg .nav ul ul li ul {
	position: absolute;
	top: 0px;
	left: 100%
}
#nav_bg .nav ul ul li ul li {
	width: 100%
}
#nav_bg .nav ul ul li ul li a {
	border-left: 1px solid rgba(255,255,255,0.4)
}
.menu-trigger {
	display: none
}
#con {
	width: 100%;
	min-width: 960px;
	overflow: hidden;
	margin-top: 20px;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: center;
	-webkit-justify-content: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: start;
	-webkit-align-items: flex-start;
	-ms-flex-align: start;
	align-items: flex-start
}
#main {
	margin: 5px 0;
	width: 720px;
	padding: 15px;
	background: rgba(255,255,255,0.6);
	box-shadow: 0 0 5px rgba(0,0,0,0.2)
}
#main ol, #main ul {
	padding: 5px 0px 5px 25px
}
#main ul {
	list-style-type: disc
}
#main ol li, #main ul li {
	padding: 5px 0px
}
#main table {
	margin: 10px 0px
}
#main table th, #main table td {
	padding: 5px
}
#main img {
	max-width: 100%;
	height: auto
}
#main a img {
	display: inline-block;
	-webkit-transition: All 0.5s ease;
	transition: All 0.5s ease
}
#main a img:hover {
	opacity: 0.7
}
#main h1 {
	font-size: 1.7em;
	font-weight: bold;
	line-height: 1.4em;
	color: #003166;
	border-top: 2px solid #003166;
	padding: 0.1em;
	margin: 0 0 10px 0;
	position: relative
}
#main h1:before {
	z-index: 1;
	content: "";
	width: 35px;
	height: 35px;
	border: 1px solid #003166;
	opacity: 0.2;
	position: absolute;
	left: 5px;
	top: 5px;
	-webkit-animation: h1_rotate_01 30s linear 3s infinite normal;
	animation: h1_rotate_01 30s linear 3s infinite normal
}
#main h1:after {
	z-index: 1;
	content: "";
	width: 40px;
	height: 40px;
	border: 1px solid #003166;
	opacity: 0.2;
	position: absolute;
	left: 0;
	top: 0px;
	-webkit-animation: h1_rotate_02 25s linear 3s infinite normal;
	animation: h1_rotate_02 25s linear 3s infinite normal
}
#main h2 {
	font-size: 1.2em;
	font-weight: bold;
	padding: 0 0 0.5em 20px;
	margin: 20px 0 10px 0;
	border-bottom: 1px solid #666;
	position: relative
}
#main h2:after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 0;
	width: 30%;
	height: 1px;
	background: #003166
}
#main h2:before {
	z-index: -1;
	content: "";
	width: 30px;
	height: 30px;
	border: 1px solid #aaa;
	position: absolute;
	left: 0;
	top: 10px;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg);
	background: rgba(0,45,104,0.05)
}
#main h3 {
	font-size: 1.1em;
	font-weight: bold;
	padding: 1px 0 1px 10px;
	margin: 12px 0 8px 0;
	border-left: 4px solid #000000
}
#side {
	width: 220px;
	margin: 5px 0;
	padding: 5px;
	background: rgba(255,255,255,0.6);
	box-shadow: 0 0 5px rgba(0,0,0,0.2)
}





#side h2 {
	font-size: 1.1em;
	font-weight: normal;
	color: #000;
	text-align: left;
	padding: 5px;
	margin: 0 0 6px 0;
	border-bottom: 2px solid #003166
}
#side #sidenav {
	width: 100%
}
#side #sidenav a {
	width: 100%;
	padding: 8px 6px 8px 23px;
	display: block;
	text-decoration: none;
	background: url(../images/sidenav_icon.png) no-repeat 6px center;
	font-size: 12px;
	color: #000000;
	border-bottom: dotted 1px #cccccc;
	text-shadow: 2px 2px 2px rgba(0,0,0,0.1)
}
#side #bnr {
	margin-top: 20px;
	width: 100%
}
#side #bnr li {
	margin-bottom: 4px
}
#side #bnr li a {
	width: 100%;
	padding: 10px 10px 10px 30px;
	border-bottom: 1px solid #333;
	border-radius: 3px;
	display: block;
	text-decoration: none;
	background: url(../images/bnr_bg.png) no-repeat 8px center;
	font-size: 12px;
	color: #333;
	-webkit-transition: All 0.5s ease;
	transition: All 0.5s ease
}
#side #bnr li a:hover {
	opacity: 0.5
}
#side #contact p {
	padding: 5px 10px
}
#side #contact a.form {
	display: block;
	margin: 0 10px 10px 10px;
	padding: 2px;
	background: #333;
	color: #fff;
	text-align: center;
	text-decoration: none;
	border: 1px solid #003166;
	-webkit-transition: All 0.5s ease;
	transition: All 0.5s ease
}
#side #contact a.form:hover {
	background: #fff;
	color: #003166
}
#center {
	width: 20px
}
.ft_language {
	display: none
}
#ft {
	width: 100%;
	min-width: 960px;
	margin: 15px;
	text-align: center;
	color: #003166
}
#i_img {
	width: 960px;
	margin: 0 auto 20px;
	overflow: hidden
}
#i_img ul {
	box-shadow: 0 0 5px rgba(0,0,0,0.2)
}

#i_img_bg {
	width:100%;
}

.i_news {
	height: 250px;
	overflow: auto
}
.i_news table {
	width: 100%
}
.i_news table tr {
	border-bottom: 1px dotted #cccccc
}
.i_news table td {
	vertical-align: top;
	font-size: 0.9em;
	padding: 10px;
	display: block;
	width: 100%
}
.i_news table td:first-child {
	background: url(../images/news_icon.png) 5px 10px no-repeat;
	padding: 2px 0 0 20px
}
.i_news table td:last-child {
	white-space: normal;
	padding: 0 0 2px 20px
}
.whatsnew {
	border: none !important;
	font-size: 0.9em !important
}
.whatsnew .wn-head {
	display: none
}
.whatsnew .wn-item .wn-date {
	background: url(../images/news_icon.png) 5px 10px no-repeat;
	padding: 2px 0 0 20px
}
.whatsnew .wn-item .wn-article {
	padding: 0 0 2px 20px;
	display: block;
	width: 100%;
	border-bottom: 1px dotted #cccccc
}
.whatsnew .wn-item .wn-article:after {
	content: "を更新しました。"
}
#page-top {
	position: fixed;
	bottom: 20px;
	right: 20px;
	font-size: 0.9em;
	background: rgba(255,255,255,0.8);
	text-decoration: none;
	border: 1px solid #003166;
	color: #003166;
	padding: 10px;
	text-align: center;
	display: block;
	border-radius: 5px
}
.waku{
	padding: 10px 5px;
	margin: 10px 0;
	border: #B1B1B1 1px solid;
}