@charset "utf-8";
@font-face {
  font-family: "YuGothic M";
  src: local("Yu Gothic Medium"),
       local("Yu Gothic");
  font-weight: 500;
}

html{height: 100%;}
body {
	color:#fff;
	text-align:justify;
	font-size:16px;
	line-height:2em;
	text-shadow:1px 1px 0 #000, -1px -1px 0 #000,
              -1px 1px 0 #000, 1px -1px 0 #000,
              0px 1px 0 #000,  0-1px 0 #000,
              -1px 0 0 #000, 1px 0 0 #000;
	background: url(../img/top/ct_bg2.jpg) center center no-repeat;
	background-size: cover;
	background-attachment: fixed;
	overflow-x:initial;
}

a{
	color: #3bc1e3;
	text-decoration: none !important;
}

/* テキストアインチエイリアス　どこかにいれる？
    -webkit-transform: rotate(0.028deg);
    -moz-transform: rotate(0.028deg);
    -ms-transform: rotate(0.028deg);
    -o-transform: rotate(0.028deg);
    transform: rotate(0.028deg);
文字ボケ効果
	text-shadow:rgba(10, 189, 240, 0.298039) 2px 2px 0px, rgba(254, 1, 1, 0.298039) -2px -2px 0px;
*/

/* PC用のスタイル記述 */
#wrapper {
	width:100%;
	min-width: 960px;


}
#header {
	background:url(../img/common/top_bg.jpg) center top no-repeat;
	background-size: auto;

}
#header .header_bx{
	width:960px;
	height:749px;
	margin:0 auto;
}
#header h1 {
	color:#FFFFFF;
	text-indent:100%;
	white-space:nowrap;
	overflow:hidden;
}

.sub_logo{
	position: fixed;
	top:10px;
	left:0;
	z-index:100;
}

nav#global {
	width:100%;
	height:66px;
background:url(../img/common/navi_bg.png) top center no-repeat;
	z-index:99;
}



nav#global .navi_box{
	width:100%;
	height:97px;
	background:url(../img/common/navi_bg.png) top center no-repeat;
	z-index:9999;
}
nav#global .nav_menu{
	width:100%;
	height:97px;
	z-index:9999;
}
/* 下層のメニュー用
nav#global .navigation_menu{
    position: fixed;
    top: 0;
    left: 0;
    Width: 100%;
	z-index:9999;
}
*/
nav#global .navigation_menu.fixed{
    position: fixed;
    top: 0;
    left: 0;
    Width: 100%;
	z-index:9999;
}
nav#global ul{
	width:760px;
	margin:0 auto;
	padding: 8px 0 0 0;
	display: flex;
	align-items: center;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	-webkit-flex-wrap:wrap;
	-ms-flex-wrap:wrap;
	flex-wrap:wrap;
	
}
nav#global ul li{
	width:150px;
}
nav#global ul li a{
	color: #fff;
	text-decoration: none;
	font-weight: bold;
	display: inline-block;
	z-index:9999;
}


#nav_toggle{
	display: none;
}

.line_box{
	width:450px;
	height: 330px;
	padding:8px;
	background: url(../img/top/box_l.png) top left no-repeat,url(../img/top/box_r.png) top right no-repeat,url(../img/top/box_top.png) top center no-repeat,url(../img/top/box_bottom.png) bottom center no-repeat;
	background-size:contain,contain,100%,100%;
	background-color:rgba(0,0,0,0.6);
}

.mask{
	background: rgba(0,0,0,0.6);
}
.sub_box{
	width:760px;
	margin:0 auto;
	padding:20px 5px;
}
.lp_box{
	width:760px;
	margin:0 auto;
	padding:0 0 15px 0;
}
.contents0{
	width:100%;

}
.contents1{
	width:100%;

}
.contents2{
	width:100%;

}
.contents3{
	width:100%;
	background: url(../img/top/ct_bg3.jpg) top center no-repeat;
	background-position: center 97px;
	background-size: cover;
}
.contents4{
	width:100%;
	background: url(../img/top/ct_bg4.jpg) top center no-repeat;
	background-position: center 97px;
	background-size: cover;
}
.contents5{
	width:100%;
	background: url(../img/top/ct_bg5.jpg) top center no-repeat;
	background-position: center 97px;
	background-size: cover;
}

.contents1,.contents2,.contents3,.contents4,.contents5 {
	margin-top:-97px;
	padding-top:97px;
}

h2.ct1{
	background: url(../img/top/h2_1.png) top center no-repeat;
	height:80px;
	text-indent:100%;
	white-space:nowrap;
	overflow:hidden;
}
h2.ct2{
	background: url(../img/top/h2_2.png) top center no-repeat;
	height:80px;
	text-indent:100%;
	white-space:nowrap;
	overflow:hidden;
}
h2.ct3{
	background: url(../img/top/h2_3.png) top center no-repeat;
	height:80px;
	text-indent:100%;
	white-space:nowrap;
	overflow:hidden;
}
h2.ct4{
	background: url(../img/top/h2_4.png) top center no-repeat;
	height:80px;
	text-indent:100%;
	white-space:nowrap;
	overflow:hidden;
}
h2.ct5{
	background: url(../img/top/h2_5.png) top center no-repeat;
	height:80px;
	text-indent:100%;
	white-space:nowrap;
	overflow:hidden;
}

.main {
	width:960px;
	margin:0 auto;
	text-align: center;
}
	.txt_ct{
		width:750px;
		margin:0 auto;
	}
.flex {
	min-width:960px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	-webkit-flex-wrap:wrap;
	-ms-flex-wrap:wrap;
	flex-wrap:wrap;
}
.flex_box{
	width: 480px;
	padding:0 15px
}
.flex_box3{
	width: 320px;
	padding:0 15px
}
.notices_box{
	height: 330px;
}


.fc_line{
	min-width:960px;
	width:100%;
	border-top:2px solid #1a1e73;
	border-bottom:2px solid #1a1e73;
}

.fc_box{
	border-top:2px solid #23a5c6;
	border-bottom:2px solid #23a5c6;

}
.fc_contents{
	width:960px;
	margin:0 auto;

	padding:10px 20px;
	text-align: center;
}
.fc_contents .flex{
	min-width:940px;
	width:100%;
	margin:0 auto;
	display: flex;
	align-items: center;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
	-webkit-flex-wrap:wrap;
	-ms-flex-wrap:wrap;
	flex-wrap:wrap;
}
.fc_contents .flex .flex_box_a{
	flex-basis: 300px;
	text-align: center;
}
.fc_contents .flex .flex_box_b{
	flex-basis: 320px;
	text-align: left;
	line-height: 1.5em;
	font-size:84%;
}
.fc_contents .flex .flex_box_c{
	flex-basis: 320px;
	text-align: center;
}
.fc_contents .flex .flex_box_c img{
	width:50%;
	margin:10px;
}
#footer {
	background-color: #07081f;
	padding:15px 0; 
	width:100%;
	margin:0 auto;
	line-height: 1.1em;
	font-size:84%;
	text-align: center;
}
#footer p{
	
}

#footer ul{
	padding:10px 0;
}
#footer ul li{
	display: inline;
	margin:5px;
}
.ct_end{
	background: url(../img/top/bg_end.png) top center no-repeat;
	width:100%;
	height:10px;
	margin-top:20px;
}
/*sliderバグ対応*/
.bxslider li {
  display: none;
}
.bx-viewport .bxslider li {
  display: block !important;
}
.pc { display: block !important; }
.sp { display: none !important; }

@media screen and (max-width: 750px) {
	
/* スマートフォン用のスタイル記述 */
.pc { display: none !important; }
.sp { display: block !important; }

	
#wrapper {
	width:100%;
	font-size:14px;
	line-height:1.5em;
	min-width: initial;
	background:none
}

body::before {
  content:"";
  display:block;
  position:fixed;
  top:0;
  left:0;
  z-index:-1;
  width:100%;
  height:100vh;
  background:url(../img/top/ct_bg2.jpg) center/cover no-repeat; /*fixedをトル！*/
  -webkit-background-size:cover;/*Android4*/
  }
	
#header {
	width:100%;
	background:initial;
}
#header .header_bx{
	background: url(../img/common/top_bg_sp.png) center top no-repeat;
	background-size: contain;
	width:100%;
	height: 0;
    /* 表示画像の高さ ÷ 表示画像の幅 × 100 */
    padding-top: 98.53%;
	}
#header h1 {
	color:#FFFFFF;
}
	nav#global {
		display:none;
		position: absolute;
		top:0;
		width: 100% !important;
		left: 0;
		height:100vh;
		z-index:9988;
		background:initial;
		
	}
nav#global .navi_box{
	width:100%;
	height:auto;
		height: auto;
  min-height: 100%;
		background-position: center center;
		background:rgba(0,0,0,0.8);
		background-size:cover;
	
}
	
	nav#global ul{
		display: block;
		width: 90%;
		height: auto;
		position: absolute;
		top: 50px;
		right: 0px;
		bottom: 0px;
		left: 0px;
		margin: auto;
		align-items: center;
	}
	nav#global ul li{
		width:80%;
		margin: 0 auto;
		text-align: center;
		background:none;
		color:#fff;
	}
	nav#global ul li:last-child{
		border: none;
	}
	nav#global ul li a{
		display: block; 
		color: #006598;
		position: relative;
		z-index:9999;
	}
	/*開閉ボタン*/
	#nav_toggle{
		display: block;
		width: 40px;
		height: 40px;
		position: fixed;
		top: 10px;
		right:10px;
		z-index: 10000;
	}
	#nav_toggle div {
		position: relative;
	}
	#nav_toggle span{
		display: block;
		height: 3px;
		background: #fff;
		position:absolute;
		width: 100%;
		left: 0;
		-webkit-transition: 0.5s ease-in-out;
		-moz-transition: 0.5s ease-in-out;
		transition: 0.5s ease-in-out;	
	}
	#nav_toggle span:nth-child(1){
		top:0px;
	}
	#nav_toggle span:nth-child(2){
		top:12px;
	}
	#nav_toggle span:nth-child(3){
		top:24px;
	}
	
	/*開閉ボタンopen時*/
	.open #nav_toggle span:nth-child(1) {
			top: 12px;
		   -webkit-transform: rotate(135deg);
			-moz-transform: rotate(135deg);
			transform: rotate(135deg);
		}
		.open #nav_toggle span:nth-child(2) {
			width: 0;
			left: 50%;
		}
		.open #nav_toggle span:nth-child(3) {
			top: 12px;
			-webkit-transform: rotate(-135deg);
			-moz-transform: rotate(-135deg);
			transform: rotate(-135deg);
		}
.sub_box{
	width:100%;
}
.lp_box{
	width:100%;
	padding:0;
}
.main {
	width:100%;
}
	.main_ct{
		margin:0 15px;
		padding:20px 0;
	}
	.txt_ct{
		width:100%;
	}
	.spimg{
		width:70%;
		}
	.slideicon{
		width:50%;
		
	}

.contents1,.contents2,.contents3,.contents4,.contents5 {
	margin-top:0px;
	padding-top:0px;
	background-position: top center;
}
	
h2.ct1,h2.ct2,h2.ct3,h2.ct4,h2.ct5,h2.ct6{
	background-size: 400%;
	height:60px;
}
.ct_end{
	background-size: 300%;
	height:0;
	padding-top:1%;
}

video {
    width: 100%;
    height: auto;
  }
	
.flex {
	min-width: initial;
	}
.flex_box{
	width: 100%;
	min-width: initial;
	padding:0;
}
.flex_box3{
	width: 50%;
	padding:0 10px;
}
.flex_box3:nth-child(3){
	width: 100%;
	padding:0 10px;
}
.flex_box3 img{
    width: 100%;
    }
.flex_box3:nth-child(3) img{
	width: 50%;
}
    
.fc_line{
	min-width: initial;
	}
.fc_contents{
		width:100%;
	}
	.flex_box_b{
		margin:0 0 20px 0;
	}
.fc_contents .flex{
	width:100%;
	min-width: initial;
	}
.fc_contents .flex .flex_box_a{
	width:100%;
	text-align: center;
	flex-basis: 100%;
}
.fc_contents .flex .flex_box_b{
	width:100%;
	text-align: center;
	line-height: 1.5em;
	font-size:84%;
	flex-basis: 100%;
}
.fc_contents .flex .flex_box_c{
	width:100%;
	text-align: center;
	flex-basis: 100%;
}
.fc_contents .flex .flex_box_c img{
	margin:5px 10px;
}


.line_box{
	width:100%;
	height: auto;
	padding:15px;
	background:url(../img/top/box_top.png) top center no-repeat,url(../img/top/box_bottom.png) bottom center no-repeat,url(../img/top/box_top.png) top center no-repeat,url(../img/top/box_bottom.png) bottom center no-repeat;
	background-size:contain;
	background-color:rgba(0,0,0,0.6);
}



	
#footer {
	width:100%;
	line-height: 1.1em;
	font-size:84%;
	padding: 15px;
}
#footer ul{
}
#footer ul li{
	display: block;
	margin:5px;
}
	
}





.video{
  position:relative;
  width:100%;
  padding-top:56.25%;
}
.video iframe{
  position:absolute;
  top:0;
  right:0;
  width:100%;
  height:100%;
}

