@charset "utf-8";

/* reset
------------------------------------------------ */
body,div,pre,p,a,img,form,fieldset,input,textarea,select,option,
dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,table,th,td,embed,object,
figure,figcaption {
	margin: 0;
	padding: 0;
}
html { height: 100%; font-size: 62.5%; }
body {
	width: 100%;
	background: white;
	-webkit-text-size-adjust: 100%;
	font-family: "Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ＭＳ Ｐゴシック", "MS P Gothic", "メイリオ", "Meiryo", Osaka, sans-serif;
	font-size: 1rem;
	line-height: 1.6;
	color: #000;

}
.f_gothic { font-family: "Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ＭＳ Ｐゴシック", "MS P Gothic", "メイリオ", "Meiryo", Osaka, sans-serif; }

ul,ol { list-style: none; }
img { border: none; vertical-align: top; }
a:link { text-decoration: none; color: #000; }
a:visited { text-decoration: none; color: #000; }
a:hover,
input[type=submit]:hover { text-decoration: none; opacity: .6; filter: alpha(opacity=60); }

.mb_17{
	margin-bottom: 17px;
}

/* clearfix
------------------------------------------------ */
.clearfix {
	clear: both;
}
.clearfix:before,.clearfix:after {
	content: " ";
	display: table;
}
.clearfix:after { clear: both; }

/* container
------------------------------------------------ */
.container {
	margin: 0 auto;
	max-width: 980px !important;
}

/* header
------------------------------------------------ */
#header {
	top: 0;
	left: 0;
	right: 0;
	margin: 0 auto;
	position: fixed;
	z-index: 99;
}
#header,
#header * {
	transition: ease .3s;
	-webkit-transition: ease .3s;
	-moz-transition: ease .3s;
	-ms-transition: ease .3s;
	-o-transition: ease .3s;
}
#header .container { position: relative; width: auto; max-width: 1200px !important; }
#header .navbar { min-height: 65px; border: none; }
#header .navbar-header { width: 10%; }
#header .navbar-collapse { position: absolute; top: 17px; right: 0; padding: 0; width: 100%; }
#header .navbar-nav { position: relative; float: none; margin: 0; }
#header .navbar-nav .u-pcNone { display: none;}
#header .navbar-nav { display: flex; flex-wrap: wrap; justify-content: flex-end; }
#header .navbar-nav > li { float: none; display: inline-block; text-align: center; }
#header .navbar-nav > li > a { display: block; padding: 0 20px; line-height: 48px; }
#header .navbar-nav > li > a:hover { opacity: 1; filter: alpha(opacity=100); }
#header .navbar-nav > li.has-megamenu { position: static; }

#header .navbar-nav > li .megamenu {
	background: rgb(21, 90, 160);
	position: absolute;
	top: 50px;
	left: 0;
	padding: 20px 20px 20px 30px;
	height: 375px;
	width: 100%;
	transition: all .3s;
}

#header .navbar-nav > li .megamenu h3 {
	color: #fff;
	font-family: Helvetica, Arial, Verdana;
	font-size: 58px;
	font-size: 5.8rem;
	font-weight: bold;
	margin: 50px 0;
}

#header .navbar-nav > li .megamenu a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 20px;
}

#header .navbar-nav > li p span:nth-of-type(1) {
	color: #fff;
	font-size: 20px;
	font-size: 2rem;
	font-weight: bold;
}

#header .navbar-nav > li p span:nth-of-type(2) {
	color: #fff;
	font-size: 13px;
	font-size: 1.3rem;
	font-weight: bold;
	border: 1px solid #fff;
	border-radius: 17px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	height: 34px;
	width: 120px;
}

#header .navbar-nav > li p:hover span:nth-of-type(2) {
	background: #fff;
	color: rgb(21, 90, 160);
}

#header .navbar-nav > li .megamenu .image {
	float: right;
	display: flex;
	justify-content: center;
	overflow: hidden;
	height: 335px;
}

#header .navbar-nav > li > a > strong {
	display: block;
	/* font-family: Helvetica, Arial, Verdana; */
	font-size: 13px;
	font-size: 1.3rem;
	font-weight: bold;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #0f4391;
}

#header .navbar-nav > li > a > span {
	display: none;
	font-size: 13px;
	font-size: 1.3rem;
	font-weight: bold;
	align-items: center;
	justify-content: center;
	color: #fff;
}

#header .navbar-nav > li > a img {
	margin-left: 10px;
}

@media (min-width: 768px){
	#header .navbar-nav > li > a:hover strong { display: none; }
	#header .navbar-nav > li > a:hover span { display: flex; }
	#header .navbar-nav > li .megamenu {
		opacity: 0;
		visibility: hidden;
	}
	#header .navbar-nav > li:hover .megamenu {
		opacity: 1;
		visibility: visible;
	}
}

#header .contact{
	display: none;
}

#header .contact a{
	border: 1px solid #0f4391;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 17px;
	margin-top: 8px;
	margin-right: 15px;
	height: 34px;
	width: 108px;
}

#header .navbar-toggle {
		background-color: #0f4391 !important;
		border: none;
		border-radius: 0;
		margin: 0;
		padding: 18px 15px;
}
#header .navbar-toggle .icon-bar {
	background-color: #fff !important;
}
#header .navbar-toggle:not(.collapsed) .icon-bar.top {
	position: relative;
	top: 6px;
	transform: rotate(45deg);
}
#header .navbar-toggle:not(.collapsed) .icon-bar.mid {
	opacity: 0;
}
#header .navbar-toggle:not(.collapsed) .icon-bar.btm {
	position: relative;
	top: -6px;
	transform: rotate(-45deg);
}
#header .navbar-toggle .icon-bar {
	background-color: #fff !important;
}
#header .navbar-collapse{
	border: none;
}

#header .navbar-default { 
	background-color: white !important;
		border: none !important; 
		margin: 0;
}

#tagline {
	padding: 4px 0;
	text-align: right;
	font-size: 10px;
	font-size: 1rem;
	line-height: 1;
}

#logo { position: absolute; top: 15px; left: 20px; width: 67px; z-index: 3; }
#logo a { display: block; padding: 0; width: 100%; }
#logo a img { height: 108px; }
.fix_header #logo img { height: 80px; }

@media (min-width: 768px) and (max-width: 1000px) {
	#logo { width: 6.7vw; }
	#header .navbar-nav > li > a { padding: 0 2vw; }
}

@media (max-width: 767px){
	#header .navbar { min-height: 50px; }
	#logo { top: 5px; left: 15px; width: 28px; }
	#logo a img { height: 40px; }
	.fix_header #logo img { height: 40px; }
}

/* contents
------------------------------------------------ */
#contents {
}

/* footer
------------------------------------------------ */
#footer {
	font-size:15px;
	font-size:1.5rem;
	color:rgb(21, 90, 160);
	font-weight: bold;
	padding-top:30px;
}

	#pagetop {
		position: fixed;
		bottom: 60px;
		right: 20px;
		width: 54px;
	}

		#pagetop a { display: block; }
		#pagetop img { width: 100%; }

	#footer #pre_footer{
		background: white;
		text-align: center;
		margin: 0 auto;
		padding: 60px 0px 20px;
	}
	#footer #pre_footer ul {
		display: flex;
		flex-wrap: wrap;
		margin: 2px auto;
		line-height: 1.4;
		padding-left: 0;
		text-align: center;
	}

		#footer #pre_footer li {
			display: inline-block;
			width: 12%;
			vertical-align: top;
		}

			#footer #pre_footer li a { color: #0f4391; }
			#footer #pre_footer li a:hover { opacity: 1; filter: alpha(opacity=100); }
		
				#footer #pre_footer li strong {
					display: block;
/*					font-family: Helvetica, Arial, Verdana;
*/					font-size: 12px;
					font-size: 1.2rem;
					font-weight: bold;
				}
	
				#footer #pre_footer li span {
					display: none;
					font-size: 12px;
					font-size: 1.2rem;
				}
				@media (min-width: 768px){
					#footer #pre_footer li a:hover strong { display: none; }
					#footer #pre_footer li a:hover span { display: block; }
				}

	#bottom_footer{
		background: rgb(21, 90, 160);
		/*max-width: 1050px;*/
		margin: 0 auto;
		color:white;
		padding: 8px 0px;
	}

		#bottom_footer ul{
			margin: 2px auto;
	        line-height: 1.4;
	        padding-left: 0;
	        margin-top: 12px;
		}

		#bottom_footer li {
			display: inline-block;
			margin-right: 20px;
			vertical-align: top;
			list-style-type: none;
			line-height: 1;
			color: #fff;
		}
		#bottom_footer li:nth-of-type(1) { width: 140px; }
		#bottom_footer li:nth-of-type(2) { width: 100px; }

			#bottom_footer li a { display: inline-block; position: relative; padding-left: 14px; vertical-align: top; color: #fff; }
			#bottom_footer li a::before { content: ''; position: absolute; top: 50%; left: 0; transform: translateY(-50%); width: 0; height: 0; border: 6px solid transparent; border-right: none; border-left: 12px solid #fff; }
			#bottom_footer li a:hover { opacity: 1; filter: alpha(opacity=100); }
	
				#bottom_footer li strong,
				#bottom_footer li span {
					padding-left: .4em;
				}
	
				#bottom_footer li strong {
					display: inline-block;
					vertical-align: middle;
/*					font-family: Helvetica, Arial, Verdana;
*/					font-size: 12px;
					font-size: 1.2rem;
					font-weight: bold;
				}
	
				#bottom_footer li span {
					display: none;
					vertical-align: middle;
					font-size: 10px;
					font-size: 1rem;
				}

			@media (min-width: 768px){
				#bottom_footer li a:hover strong { display: none; }
				#bottom_footer li a:hover span { display: inline-block; }
			}

		#bottom_footer li:last-child {
			margin-right: 0;
			height: 12px;
			float:right;
		}
		#bottom_footer li img{
			height: 10px;
		}

/* lg screen*/
@media (min-width: 1200px){
   

	#bs-example-navbar-collapse-1{
		background: transparent !important;
	}
}
/* md screen*/
@media (max-width: 1199px) and (min-width: 992px){
  	
	#bs-example-navbar-collapse-1{
		background: transparent;
	}
}
/* sm screen*/
@media (max-width: 991px) and (min-width: 768px){
}
/* xs screen*/
@media (max-width: 767px){
	#bs-example-navbar-collapse-1{ position: relative; background:#0f4391; z-index: 999; }
	#tagline { display: none; }
	#header .navbar-header { width: auto; }
	#header .navbar-collapse { top: 50px; float: none; padding-right: 15px; padding-left: 15px; width: auto; }
	#header .contact{ display: block; float: right; }
	#header .navbar-nav { margin: 0; padding-top: 30px; width: 100%; height: calc(100dvh - 50px); }

			#header .navbar-nav .u-pcNone {
				display: inline-block;
			}

			#header .navbar-nav .u-spNone {
				display: none !important;
			}
	
			#header .navbar-nav li { width: 100%; text-align: left; border-bottom: 1px solid #fff; }
				#header .navbar-nav li a { padding: 10px 4%; line-height: 1.6; }
				#header .navbar-nav > li > a > strong {
					color: #fff;
					justify-content: space-between;
				}
	
			#header .navbar-nav .close-button {
				color: #fff;
				font-size: 18px;
				font-size: 1.8rem;
				height: 120px;
				width: 100%;
			}

				#header .navbar-nav > li .megamenu {
					background: none;
					position: relative;
					top: auto;
					left: auto;
					padding: 0;
					height: auto;
					width: 100%;
				}
		
					#header .navbar-nav > li .megamenu div {
						padding-right: 0;
					}
		
					#header .navbar-nav > li .megamenu h3 {
						display: none;
					}
		
					#header .navbar-nav > li .megamenu a {
						display: flex;
						align-items: center;
						justify-content: space-between;
						margin-top: 0;
					}
		
					#header .navbar-nav > li p:nth-of-type(n+2) {
						border-top: 1px solid #fff;
					}
		
					#header .navbar-nav > li p span:nth-of-type(1) {
						color: #fff;
						font-size: 13px;
						font-size: 1.3rem;
						font-weight: bold;
					}
		
					#header .navbar-nav > li p span:nth-of-type(2) {
						color: #fff;
						font-size: 13px;
						font-size: 1.3rem;
						font-weight: 300;
						border: none;
						border-radius: 0;
						height: auto;
						width: auto;
					}
		
					#header .navbar-nav > li .megamenu .image {
						display: none;
					}

	.navbar-brand{
		padding: 5px 0 5px 15px;
	}
		/* .navbar-brand img { height: 100% !important; } */


	#pagetop { bottom: 66px; width: 32px; }

	#footer {}
	#footer #pre_footer {}
	#footer #pre_footer li { width: 25%; }

	#bottom_footer {}
	#bottom_footer ul { margin-top: 6px; }
	#bottom_footer ul li:nth-of-type(1),
	#bottom_footer ul li:nth-of-type(2) { margin: 0 0 16px; width: 50%; }

}



.m_t_30{
	margin-top: 30px;
}
.t_c{
	text-align: center;
}
.blue{
	color: rgb(21, 90, 160);
}
.f_20{
	font-size: 20px;
	font-size: 2rem;
}