body {
	font-family: Roboto, "Droid Sans", "游ゴシック体", "Yu Gothic", "YuGothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif
}
.layout {
	width: calc(100% - 6px);
	margin: 0 auto;
	overflow: hidden
}
#wrap {
	border-top: 3px solid #003166
}
#hd {
	padding: 20px 5px
}
#hd h1 {
	width: calc(100% - 70px);
	height: 16vw;
	background: url(../images/logo.png) center center no-repeat;
	background-size: 100%
}
#hd h1 a {
	width: 100%;
	height: 100%;
	display: block
}
#hd h1 img {
	display: none
}
#hd h1.en {
	width: calc(100% - 70px);
	height: 16vw;
	background: url(../images/logo_en_sp.png) center center no-repeat;
	background-size: 100%
}
#hd h1.en a {
	width: 100%;
	height: 100%;
	display: block
}
#hd h1.en img {
	display: none
}
#hd .language {
	display: none
}
.nav_open {
	right: 0px !important
}
.nav {
	-webkit-transition: All 0.5s ease;
	transition: All 0.5s ease;
	position: fixed;
	top: 0px;
	right: -200px;
	height: calc(100% + 500px);
	padding-bottom: 500px;
	z-index: 100;
	width: 200px;
	overflow-x: none;
	overflow-y: auto;
	background: #222;
	color: #fff;
	box-shadow: inset 0 0 5px 5px #222
}
.nav ul {
	display: block;
	margin: 0;
	padding: 0
}
.nav ul li {
	display: block;
	margin: 0
}
.nav ul li a {
	font-size: 15px;
	color: #fff;
	font-weight: bold;
	display: block;
	padding: 18px 10px;
	text-decoration: none;
	border-bottom: 1px solid rgba(0,0,0,0.15);
	position: relative
}
.nav ul li a:hover {
	box-shadow: inset 0 0 10px 2px rgba(0,0,0,0.3)
}
.nav ul li a:after {
	content: "";
	border-bottom: 1px solid rgba(255,255,255,0.15);
	width: 100%;
	position: absolute;
	bottom: 0;
	left: 0
}
.nav ul li ul {
	display: block;
	margin: 0 0 0 15px;
	padding: 0
}
.nav ul li ul li {
	display: block;
	margin: 0
}
.nav ul li ul li a {
	font-size: 14px;
	color: #fff;
	display: block;
	padding: 14px 6px;
	text-decoration: none;
	border-bottom: 1px solid rgba(0,0,0,0.15)
}
.nav ul li ul li a:hover {
	box-shadow: inset 0 0 10px 2px rgba(0,0,0,0.3)
}
.nav ul li ul li a:after {
	content: "";
	border-bottom: 1px solid rgba(255,255,255,0.15);
	width: 100%;
	position: absolute;
	bottom: 0;
	left: 0
}
.menu-trigger {
	z-index: 1000;
	position: fixed !important;
	top: 25px;
	right: 15px;
	display: block;
	margin-top: -5px
}
.menu-trigger, .menu-trigger span {
	display: inline-block;
	-webkit-transition: all .4s;
	transition: all .4s;
	box-sizing: border-box
}
.menu-trigger {
	position: relative;
	width: 36px;
	height: 24px
}
.menu-trigger span {
	position: absolute;
	left: 0;
	width: 100%;
	height: 4px;
	background-color: #000;
	border-radius: 4px
}
.menu-trigger span:nth-of-type(1) {
	top: 0
}
.menu-trigger span:nth-of-type(2) {
	top: 10px
}
.menu-trigger span:nth-of-type(3) {
	bottom: 0
}
.menu-trigger::after {
	position: absolute;
	left: 0;
	bottom: -20px;
	content: 'MENU';
	display: block;
	width: 100%;
	color: #000;
	font-size: 10px;
	text-decoration: none;
	text-align: center;
	-webkit-transition: all .4s;
	transition: all .4s
}
.menu-trigger.active::after {
	content: 'CLOSE';
	bottom: -25px;
	color: #fff
}
.menu-trigger.active span:nth-of-type(1) {
	-webkit-transform: translateY(10px) rotate(-45deg);
	-ms-transform: translateY(10px) rotate(-45deg);
	transform: translateY(10px) rotate(-45deg);
	background: #fff
}
.menu-trigger.active span:nth-of-type(2) {
	opacity: 0;
	background: #fff
}
.menu-trigger.active span:nth-of-type(3) {
	-webkit-transform: translateY(-10px) rotate(45deg);
	-ms-transform: translateY(-10px) rotate(45deg);
	transform: translateY(-10px) rotate(45deg);
	background: #fff
}
#con {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap
}
#main {
	width: calc(100% - 10px);
	margin: 0 auto
}
#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.5em;
	margin: 0 0 25px 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.6em 0 0.5em 20px;
	margin: 24px 0 14px 0;
	border-bottom: 1px solid #666;
	position: relative
}
#main h2:after {
	content: "";
	position: absolute;
	bottom: -1px;
	left: 0;
	width: 30%;
	height: 2px;
	background: #003166
}
#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: calc(100% - 10px);
	margin: 0 auto
}
#side h2 {
	font-size: 1.1em;
	font-weight: normal;
	color: #fff;
	text-align: center;
	padding: 14px 5px;
	margin: 0 0 6px 0;
	background: #003166
}
#side #sidenav {
	display: none
}
#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: 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 {
	border: 1px solid #003166;
	margin-top: 20px
}
#side #contact p {
	padding: 5px 10px
}
#side #contact a.form {
	display: block;
	margin: 0 10px 10px 10px;
	padding: 14px;
	background: #003166;
	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 {
	display: none
}
.ft_language ul {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex
}
.ft_language ul li {
	width: calc(100% / 2)
}
.ft_language ul li a {
	font-size: 0.8em;
	color: #fff;
	background: #333;
	padding: 14px;
	display: block;
	text-decoration: none;
	text-align: center;
	border-top: 1px solid rgba(255,255,255,0.6);
	border-left: 1px solid rgba(255,255,255,0.6)
}
.ft_language ul li:first-child a {
	border-left: none
}
#ft {
	padding-top: 15px;
	padding-bottom: 15px;
	text-align: center;
	color: #fff;
	background: #003166
}
#i_img {
	box-shadow: 0 10px 10px rgba(0,0,0,0.05);
	margin-bottom: 20px
}
.i_news {
	height: 30vh;
	overflow: auto
}
.i_news table {
	width: 100%
}
.i_news table tr {
	border-bottom: 1px dotted #cccccc;
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: flex;
	-webkit-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap
}
.i_news table td {
	vertical-align: top;
	font-size: 0.9em;
	padding: 10px 10px 0 10px
}
.i_news table td:first-child {
	background: url(../images/news_icon.png) 10px 17px no-repeat;
	padding-left: 30px
}
.i_news table td:last-child {
	display: block;
	width: 100%;
	padding: 0 10px 10px 30px
}
.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 18px no-repeat;
	padding: 10px 0 0 20px
}
.whatsnew .wn-item .wn-article {
	padding: 0 0 10px 20px;
	display: block;
	width: 100%;
	border-bottom: 1px dotted #cccccc
}
.whatsnew .wn-item .wn-article:after {
	content: "を更新しました。"
}
#page-top {
	margin-top: 20px;
	width: 100%;
	text-align: center;
	font-size: 0.9em;
	background: #333;
	text-decoration: none;
	color: #ffffff;
	padding: 14px;
	text-align: center;
	display: block
}
.waku{
	padding: 10px 5px;
	margin: 10px 0;
	border: #B1B1B1 1px solid;
}