@charset "utf-8";
html{
	width:100%;
/*	font-family: "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;*/
	font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
	background-color: #fff;
}

body{
	width:100%;
	color:#666;
}
em{
	font-style:normal;
	font-weight:bold;
}
.sp{display:block;}
.pc{display:none;}
a:link,
a:visited{
	color:#666;
	text-decoration:underline;
	}
a:active,
a:hover{
	color:#666;
	text-decoration:underline;
	}
img {
	border:0;
	vertical-align:top;
	max-width: 100%;
	height: auto;
	width :auto;　
}
.w1000{
	max-width:1000px;
	margin-left:auto;
	margin-right:auto;
}
.w90{
	width:90%;
	margin-left:auto;
	margin-right:auto;
}
@media screen and (min-width:768px) {
	.sp{display:none;}
	.pc{display:block;}
	a{
		transition-duration:0.3s;
		}
	a:hover{
		opacity: 0.7;
		}
}/* base */





/*header
----------------------------------------------------------- */
header{
	width: 100%;
	height: 60px;
	top: 0;
	right: 0;
	position:fixed;
	z-index: 100;
	background-color:#fff;
	display:flex;
	justify-content: center;
	align-items: center;
}
main{
	margin-top:60px;
}
/*ハンバーガーボタン*/	
#hBtnMenu{
	position:fixed;
	top:0;
	left:0;
	width:60px;
	height:60px;
	padding-top:10px;
	text-align:center;
	z-index:2;
	background-color: #00538c;
}
#hBtnMenu span {
	position: absolute;
	top: 0;
	left: 15px;
	display: block;
	width: 30px; /* 横幅 */
	height: 2px; /* 1本辺りの高さ */
	background: #fff; /* 線の色 */
	transition: all 0.3s ease-out;
  }
#hBtnMenu .hbBar01 { top: 18px; }
#hBtnMenu .hbBar02 { top: 30px; }
#hBtnMenu .hbBar03 { top: 42px; }
#hBtnMenu.open span{
	background: #fff; /* 線の色 */
	}
/* 最上部の線のスタイル ---------------------- */
#hBtnMenu.open .hbBar01 {
  top: 30px; /* 上から2番目の線の位置に変更 */
  transform: rotate(45deg);
}
/* 上から2番目の線のスタイル ---------------------- */
#hBtnMenu.open .hbBar02 {
  opacity: 0; /* 不透明度を下げて線を消す */
}
/* 最下部の線のスタイル ---------------------- */
#hBtnMenu.open .hbBar03 {
  top: 30px; /* 上から2番目の線の位置に変更 */
  transform: rotate(135deg);
}
@media(min-width:768px){
	header{
		height: 100px;
	}
	main{
		margin-top:100px;
	}
	#hBtnMenu{
		width:100px;
		height:100px;
		padding-top:10px;
	}
	#hBtnMenu span {
		position: absolute;
		top: 0;
		left: 25px;
		width: 50px; /* 横幅 */
		height: 6px; /* 1本辺りの高さ */
	  }
	#hBtnMenu .hbBar01 { top: 27px; }
	#hBtnMenu .hbBar02 { top: 47px; }
	#hBtnMenu .hbBar03 { top: 67px; }
	#hBtnMenu.open .hbBar01 {
	  top: 47px; /* 上から2番目の線の位置に変更 */
	}
	#hBtnMenu.open .hbBar03 {
	  top: 47px; /* 上から2番目の線の位置に変更 */
	}
}
/*gnav*/
#gNav{
	position:absolute;
	display:none;
	width:100%;
	top:0;
	left:0;
	background:#fff;
	z-index:1;
	text-align:center;
	padding: 30px 0 30px;
}
#gNav h1 figure{
	width:50%;
	max-width:300px;
}
#gNav figure{
	width: 100px;
	margin: 0 auto 20px;
}
#gNav a{
	display:block;
	color: #333 !important;
	text-align:center;
	text-decoration:none;
	padding:20px 0;
	line-height:1.5;
	font-size: 1.6rem;
	font-weight: normal;
}
.hLogo02{
	width:40%;
	max-width:200px;
	margin:10px auto 10px;
}




/*footer
----------------------------------------------------------- */
footer{
	padding:60px 0 20px;
	background-color: #f1f1f1;
}
.fLogo{
	width:90%;
	max-width:400px;
	margin:0 auto 20px;
}
.fConBtn{
	width:100%;
	max-width:400px;
	line-height:80px;
	margin:0 auto 20px;
	color:#fff !important;
	text-decoration: none !important; 
	background-color: #00538c;
	font-size:clamp(1.6rem,2vw,2rem);
	display:flex;
	justify-content: center;
	align-items: center;
}
.fConBtn i{
	font-size:clamp(2rem,3vw,3rem);
	margin-right:10px;
}
.fConBtn.line{
	background-color: #00C300;
}
.fConBtn.line img{
	width:30px;
	margin-right:10px;
}






/*section
----------------------------------------------------------- */
.sec8{padding-top:8rem;padding-bottom:8rem;}
.sec8t{padding-top:8rem;}
.sec8b{padding-bottom:8rem;}
.sec10{padding-top:10rem;padding-bottom:10rem;}
.sec10t{padding-top:10rem;}
.sec10b{padding-bottom:10rem;}
.sec12{padding-top:12rem;padding-bottom:12rem;}
.sec12t{padding-top:12rem;}
.sec12b{padding-bottom:12rem;}

/**/
.lh25{line-height: 2.5;}



/*title
----------------------------------------------------------- */
.pageTtl01{
	height:200px;
	color:#fff;
	background-size:cover;
	background-position: center center;
	display:flex;
	justify-content: center;
	align-items: center;
}
.pageTtl01 .cTtl01{
	margin-bottom:0;
}
@media (min-width:768px) {
	.pageTtl01{
		height:400px;
	}
}
/**/
.cTtl01{
	margin-bottom: 40px;
	font-weight: normal;
}
.cTtl01 .en{
	font-size: 4rem;
	font-size:clamp(2.5rem,4vw,4rem);
	font-family:"Times" , sans-serif;
	letter-spacing: 0.2em;
}
.cTtl01 .jp{
	font-size: 1.8rem;
	font-size:clamp(1.4rem,1.8vw,1.8rem);
}
.cTtl02{
	font-size: 2.5rem;
	font-size:clamp(1.8rem,2.5vw,2.5rem);
	font-weight: normal;
}
/**/


/*bg
----------------------------------------------------------- */
.cBg01{
	background-color: #213b5e;
}
.cBg02{
	background-color: #1a2f4b;
}

/*btn
----------------------------------------------------------- */


.cBtn01{
	width:100%;
	max-width:400px;
	padding:25px 20px;
	margin:0 auto 30px;
	color:#fff !important;
	text-decoration: none !important; 
	background-color: #00538c;
	font-size:clamp(1.6rem,2vw,2rem);
	display:flex;
	justify-content: center;
	align-items: center;
	text-align: center;
}