@charset "utf-8";


/* =Reset default browser CSS.
Based on work by Eric Meyer: http://meyerweb.com/eric/tools/css/reset/index.html
-------------------------------------------------------------- */
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, font, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {border: 0;font-family: inherit;font-size: 100%;font-style: inherit;font-weight: inherit;margin: 0;outline: 0;padding: 0;vertical-align: baseline;}
:focus {outline: 0;}

ol, ul {list-style: none;}
table {border-collapse: separate;border-spacing: 0;}
caption, th, td {font-weight: normal;text-align: left;}
blockquote:before, blockquote:after,q:before, q:after {content: "";}
blockquote, q {quotes: "" "";}
a img{border: 0;}
figure{margin:0}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {display: block;}
/* -------------------------------------------------------------- */

html,body{
    width: 100%;

}
body{
	font-size: 17px;
	font-family: Century Gothic,CenturyGothic,AppleGothic,sans-serif;

	line-height: 180%;
	-webkit-text-size-adjust: 100%;

}



/* リンク設定
------------------------------------------------------------*/
a{
    color: #2A4D93;
    text-decoration: none;
}
a:hover{
	color: #9E1B1D;
}
a:hover img
{
	opacity: 0.7;
	filter: alpha(opacity=70);
	-ms-filter: "alpha( opacity=70 )";
	background: transparent;
	border-top-style: none;
	border-right-style: none;
	border-bottom-style: none;
	border-left-style: none;
}
a:active, a:focus{outline:0;}
p{
	margin-bottom: 40px;
}

/* 全体
------------------------------------------------------------*/

h1{
	padding: 3px 0;
	font-size: 10px;
	font-weight: normal;
	color: #8B8B8B;
	display: block;
}
img{

	}
/*************
/* ヘッダー
*************/
#header{
    width: 100%;
    margin-top: 12px;
}

* html #header{height:1%;}

#header .lang{　
    width: 0px;
    width: 80px;
    float: right;
    margin-right: 40px;
}
#header .lang ul li{
	width:40px;
    float: left;
  
}

/*************
メイン コンテンツ
*************/

section#stage1{
    width: 100%;
    position: relative;
    margin-bottom: 60px;
    z-index: 0;
	}
section#stage2,section#stage3{
    width: 100%;
    margin-bottom: 70px;
	}
#stage2 .inner,#stage3 .inner{
    width: 1100px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 50px;
	}	

#stage2 .txt{
    margin-bottom: 40px;
    margin-left: 30px;
}
#stage3 .txt2{
	margin-bottom: 40px;
	padding-left: 35px;
}
#stage3 .txt{
	margin-bottom: 40px;
	padding-left: 35px;
}
.indent_Box{
    margin-left: 30px;
}
h2{
    font-size: 49px;
    text-align: center;
    margin-bottom: 40px;
    font-family: Century Gothic,CenturyGothic,AppleGothic,sans-serif;
    line-height: 140%;
}
.latest{
    background-color: #FFFFFF;
    background-image: url(../common/h2.png);
    background-repeat: repeat-x;
    font-size: 28px;
    line-height: 48px;
    margin-bottom: 30px;
    padding-left: 20px;
}
.midashi_waku{   padding: 10px;
    border: 1px solid #666666;
    margin-bottom: 20px;
    -webkit-border-radius: 7px;
    -moz-border-radius: 7px;
    border-radius: 7px;
    /* box-shadow */
    box-shadow: 2px 2px 4px -1px #353535;
}
 h3{
    font-size: 32px;
    font-weight: bold;
    margin-bottom: 30px;
    display: block;

}
 h4{
    font-weight: bold;
    font-size: 23px;
    margin-bottom: 15px;

}

h5{
    font-weight: bold;
    font-size: 20px;
    list-style-position: outside;
    padding-left: 20px;
    margin-bottom: 25px;
}
ul.local2{
    margin-left: 60px;
    margin-bottom: 20px;
}
ul.local2 li{
    list-style-type: disc;
    list-style-position: outside;
    margin-left: 15px;
}
ul.local{
    width: 50%;
    float: left;
}
ul.local li{
    list-style-type: disc;
    list-style-position: inside;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
ol.local li{
    font-weight: bold;
    font-size: 23px;
    margin-bottom: 15px;
    list-style-type: decimal;
    margin-left: 15px;
}
#stage3 .inner2{
    width: 1100px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 50px;
}
#stage3 .q{
    padding: 10px;
    border: 1px solid #666666;
    margin-bottom: 20px;
    -webkit-border-radius: 7px;
    -moz-border-radius: 7px;
    border-radius: 7px;
    /* box-shadow */
    box-shadow: 2px 2px 4px -1px #353535;
}
#stage3 .q:before{
	content: "Q : ";
	font-size: 25px;
	font-weight: bold;
}
#stage3 .a{
    margin-bottom: 40px;
}
 .halfbox{
    padding: 20px;
    border-left-color: #A2A2A2;
    border-bottom-color: #A2A2A2;
    border-top-color: #A2A2A2;
    border-left-style: solid;
    border-bottom-style: solid;
    border-top-style: solid;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    background-color: #eee;
    margin-bottom: 40px;
    /* box-shadow */
    box-shadow: 9px 9px 6px -9px #A2A2A2;
    -webkit-box-shadow: 9px 9px 6px -9px #A2A2A2;
}
.halfbox .flow{
    border: 1px solid #B0B0B0;
    margin-bottom: 40px;
    -webkit-border-radius: 7px;
    -moz-border-radius: 7px;
    padding: 20px;
    border-radius: 7px;
    background-color: #FFFFFF;
    /* box-shadow */
    box-shadow: 9px 9px 6px -9px #A2A2A2;
    -webkit-box-shadow: 9px 9px 6px -9px #A2A2A2;
    list-style-image: none;
}
.halfbox .flow .ttl{
    background-color: #071446;
    color: #060606;
    font-size: 23px;
    padding: 7px;
    font-weight: bold;
    margin-bottom: 20px;
    -webkit-border-radius: 7px;
    -moz-border-radius: 7px;
    border-radius: 7px;
    background-image: -webkit-linear-gradient(270deg,rgba(255,255,255,1.00) 0%,rgba(219,219,219,1.00) 100%);
    background-image: -moz-linear-gradient(270deg,rgba(255,255,255,1.00) 0%,rgba(219,219,219,1.00) 100%);
    background-image: -o-linear-gradient(270deg,rgba(255,255,255,1.00) 0%,rgba(219,219,219,1.00) 100%);
    background-image: linear-gradient(180deg,rgba(255,255,255,1.00) 0%,rgba(219,219,219,1.00) 100%);
    border: 1px solid #BCBCBC;
}

.halfbox .img{
    margin-bottom: 30px;	
}
.bt a img{
    width: 180px;
    float: right;
    background-color: #EEEEEE!important;
}
 .halfbox2{
    padding: 20px;
    border-left-color: #A2A2A2;
    border-bottom-color: #A2A2A2;
    border-top-color: #A2A2A2;
    border-left-style: solid;
    border-bottom-style: solid;
    border-top-style: solid;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    background-color: #eee;
    margin-bottom: 40px;
/* box-shadow */
box-shadow:9px 10px 6px -7px #b0b0b0;
}
.halfbox2 .img{
    margin-bottom: 30px;	
}
 .halfbox3{
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    margin-bottom: 40px;

}
.halfbox3 .frame{
    border: 1px solid #E5E5E5;
    box-shadow: 1px 1px 6px -1px #ababab;
    -webkit-border-radius: 7px;
    -moz-border-radius: 7px;
    border-radius: 7px;
    padding: 30px;
    margin-bottom: 70px;
}
.halfbox3 h2{
    background-repeat: no-repeat;
    background-position: left center;
    padding-left: 30px;
    line-height: 50px;
    font-weight: normal;
    border-bottom: 1px solid #272727;
    border-left: 5px none #333333;
    background-image: url(../images/toph3.png);
    color: #FFFFFF;
    text-align: left;
    font-size: 30px;
	-webkit-border-radius: 7px;
-moz-border-radius: 7px;
border-radius: 7px;
}

.halfbox3 h3{
    background-repeat: no-repeat;
    background-position: left center;
    padding-left: 30px;
    line-height: 50px;
    font-weight: normal;
    border-bottom: 1px solid #272727;
    border-left: 5px none #333333;
}

 .halfbox3 .img{
    margin-bottom: 30px;	
}
 .halfbox4{
    padding: 20px;
    border-left-color: #A2A2A2;
    border-bottom-color: #A2A2A2;
    border-top-color: #A2A2A2;
    border-left-style: solid;
    border-bottom-style: solid;
    border-top-style: solid;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    background-color: #2E230C;
    color: #FFFFFF;
    margin-bottom: 40px;
/* box-shadow */
box-shadow:9px 10px 6px -7px #b0b0b0;
}
 .halfbox4 .img{
    margin-bottom: 30px;	
}
 .halfbox5{
    padding: 20px;
    border-left-color: #A2A2A2;
    border-bottom-color: #A2A2A2;
    border-top-color: #A2A2A2;
    border-left-style: solid;
    border-bottom-style: solid;
    border-top-style: solid;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    background-color: #000000;
    color: #FFFFFF;
    margin-bottom: 40px;
	 box-shadow:7px 5px 6px -7px #848484;
}
 .halfbox5 .img{
    margin-bottom: 30px;	
}
 .halfbox6{
    padding: 20px;
    border-left-color: #A2A2A2;
    border-bottom-color: #A2A2A2;
    border-top-color: #A2A2A2;
    border-left-style: solid;
    border-bottom-style: solid;
    border-top-style: solid;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    background-color: #625E55;
    color: #FFFFFF;
    margin-bottom: 40px;
/* box-shadow */
box-shadow:9px 10px 6px -7px #b0b0b0;
}
 .halfbox6 .img{
    margin-bottom: 30px;	
}

.triple_box{
    padding: 20px;
    width: 100%;
    border-left-color: #A2A2A2;
    border-bottom-color: #A2A2A2;
    border-top-color: #A2A2A2;
    border-left-style: solid;
    border-bottom-style: solid;
    border-top-style: solid;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    margin-bottom: 40px;
}
 .triple_box:last-child{
  
}
.indent{
    padding-left: 50px;
    margin-bottom: 30px;
}
.indent2{
    padding-left: 20px;
    margin-bottom: 30px;
}
.image_r{
    width: 400px;
    float: right;
}
.spmenu{
	display: none;
}
#a,#b,#c,#d,#e,#f{
    margin-top: -45px;
    padding-top: 45px;
}

.news{
    width: 1100px;
    margin-left: auto;
    margin-right: auto;
}
.news .inner{
    max-height: 350px;
    width: 1050px;
    padding-right: 50px;
    overflow-y: auto;
}
.news dl{}
.news dl dt{
    width: 120px;
    float: left;
}
.news dl dd{
    width: 900px;
    float: right;
}
.news dl dd p{
    margin-bottom: 20px;
}


/**************************
/* メイン画像（トップページ+サブページ）
**************************/
#mainBanner{
    margin-right: auto;
    margin-left: auto;
    padding: 0;
    width: 100%;
    position: relative;
    line-height: 0;
    text-align: center;
    z-index: 0!important;
}
#mainBanner .ttl{
    color: #000000;
    font-size: 60px;
    position: absolute;
    text-align: center;
    text-shadow: #fff 2px 1px 0;
    bottom: 60px;
    right: 80px;
}
#mainBanner img{
    width: 100%;
    height: auto;
    text-align: center;
}
#mainBanner_full{
	margin-right: auto;
	margin-left: auto;
	margin-bottom: 50px;
	padding: 0;
	width: 1020px;
	position: relative;
	line-height: 0;
}

#mainBanner_full img{
   max-width:100%;
   height:auto;
}

h2 > span {
	position: relative;
	display: block;
	top: -13px;
}

.form_style {
	padding: 7px;
	font-size: 15px;
	font-weight: bold;
	background-color: #FFF;
	border: 1px solid #C7C7C7;
	width: 280px;
	margin-bottom: 7px;
}
.form_style2 {
	padding: 7px;
	font-size: 15px;
	font-weight: bold;
	background-color: #FFF;
	border: 1px solid #C7C7C7;
	width: 150px;
	margin-bottom: 7px;
}
.form_style3 {
	padding: 7px;
	font-size: 18px;
		background-color: #FFF;
	border: 1px solid #C7C7C7;
	width: 70px;
	margin-bottom: 7px;
}
.form_bt{
    width: 100px;
    height: 50px;
    border: 2px solid #6C6C6C;
    -webkit-border-radius: 7px;
    -moz-border-radius: 7px;
    border-radius: 7px;
    font-size: 20px;
    font-weight: bold;
}	
.submit_bt{
	width: 100%;
	text-align: center;
	margin-bottom: 30px;


}	

/*************
　フッタ
*************/

#footer{
    width: 100%;
    background-color: #031A49;
    padding-top: 30px;
    padding-bottom: 30px;
    margin-bottom: -130px;
    color: #FFFFFF;
    clear: both;
}

 html #footer{height:1%;}



/*************
/* pagetop
*************/

.pagetop{
	width: 90%;
	text-align: right;
	position: fixed;
	bottom: 60px;
	padding-left: 5%;
	padding-right: 5%;

	}
.pagetop img {
	width: 50px;
	text-align: right;
	height: 50px;
}
/*************
/*contact
*************/
.contact_select{
    width: 400px;
    margin-bottom: 60px;
      margin-left: auto;
    margin-right: auto;
    font-size: 30px;
    font-weight: bold;
    text-align: left;
}
.contact_select li{
    padding: 10px;
    border: 1px solid #666666;
    margin-bottom: 20px;
    -webkit-border-radius: 7px;
    -moz-border-radius: 7px;
    border-radius: 7px;
    /* box-shadow */
    box-shadow: 2px 2px 4px -1px #353535;
    text-align: center;
}
.contact_select li a{
    list-style-type: none;
    color: #071C7E;
	
}
.contact_box{
    width: 1050px;
    display: block;
    margin-bottom: 60px;
    padding-top: 20px;
    padding-right: 15px;
    padding-left: 15px;
    padding-bottom: 15px;
    border: 2px solid #DCDCDC;
    -webkit-border-radius: 7px;
    -moz-border-radius: 7px;
    border-radius: 7px;
    margin-left: auto;
    margin-right: auto;
}		
.contact_box form {
}
.form_bt{
	background-image: url(images/bt_submit.png);
	width: 100px;
	height: 50px;
	border-width: 0px;
	border-style: none;
}
.form_ttl{
	width: 100%;
	text-align: left;
	margin-bottom: 30px;
	padding-bottom: 10px;
	border-bottom: 1px solid #01074E;
	float: right;
}	

.contact_box dl{
    margin-bottom: 10px;
    border-bottom: 1px dotted #D3D3D3;
    background-image: none;
    list-style-type: none!important;
    list-style-position: outside;
    padding: 15px;
    background-color: #EFEFEF;
	}
	
.contact_box dl dt{
    width: 250px;
    float: left;
    text-align: left;
    margin-right: 15px;
    padding-right: 0px;
    margin-top: 0px;
    background-image: none;
    list-style-position: inside;
    font-weight: bold; 
	}	
.contact_box dl dd{
    width: 740px;
    margin: 0;
    padding: 0;
    float: right;
    text-align: left;
	}		
.form_style {
	padding: 7px;
	font-size: 18px;
	background-color: #FFF;
	border: 1px solid #C7C7C7;
	width: 500px;
	margin-bottom: 7px;
}
.form_style2 {
	padding: 7px;
	font-size: 18px;
	background-color: #FFF;
	border: 1px solid #C7C7C7;
	width: 220px;
	margin-bottom: 7px;
}	
.submit_bt{
	width: 100%;
	text-align: center;
	margin-bottom: 30px;
}
.address_Box{
display: -webkit-flex;
    display: flex;
}
.address_Box .frame{
    padding: 20px;
    margin-left: 2px;
    margin-right: 2px;
     background-color: #EFEFEF;
    width: 33.3333%;
}
::placeholder {
  color: #ccc;
  font-size: 18px;
	font-weight: normal;
}

.career_box{
    width: 1050px;
    display: block;
    margin-bottom: 60px;
    padding-top: 20px;
    padding-right: 15px;
    padding-left: 15px;
    padding-bottom: 15px;
    border: 2px solid #DCDCDC;
    -webkit-border-radius: 7px;
    -moz-border-radius: 7px;
    border-radius: 7px;
    margin-left: auto;
    margin-right: auto;
}		
.career_box dl{
    margin-bottom: 10px;
    border-bottom: 1px dotted #D3D3D3;
    background-image: none;
    list-style-type: none!important;
    list-style-position: outside;
    padding: 15px;
    background-color: #EFEFEF;
	}
	
.career_box dl dt{
    width: 250px;
    float: left;
    text-align: left;
    margin-right: 15px;
    padding-right: 0px;
    margin-top: 0px;
    background-image: none;
    list-style-position: inside;
    font-weight: bold; 
	}	
.career_box dl dd{
    width: 740px;
    margin: 0;
    padding: 0;
    float: right;
    text-align: left;
	}		

/*************
テーブル
*************/
table.table{
border-collapse:collapse;
width:100%;
margin:10px auto;
}

table.table th,table.table td{
padding:5px;
border:1px solid #280b36;
}

table.table th{
text-align:right;
font-weight:bold;
letter-spacing:1px;
white-space:nowrap;
color:#fff;
background:#000;
border-left:#280b36 5px solid
}

table.table td{border-left:#280b36 3px double}


.fixed{
  position: fixed;
  top: 0px;
  left: 0px;
  z-index: 9999;
}

#container{
	margin-left: auto;
	margin-right: auto;
	margin-top: 20px;
	margin-bottom: 20px;
	display: flex; 
		}
nav{
    background-color: #00204E;
    width: 100%;
    padding-top: 5px;
    padding-bottom: 5px;
}
.nav {
    width: 1100px;
    margin: 0 auto;
    display: flex;
    padding-left: 30px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
.nav li {
 	position: relative;
    list-style: none;
    margin-right: 40px;
    text-align: center;
 }
.nav li a {
    display: block;
    text-align: center;
    color: #fff;
    font-size: 18px;
    line-height: 40px;
    transition: 0.5s;
    text-decoration: none;
    box-sizing: border-box;

}
.nav > li:hover > a {/*layer-1*/
    color: #FFd700;
}
.nav > li li:hover > a {/*layer-2*/
    color: #8F0000;
}
.nav li ul {
    left: 0px;
    position: absolute;
    z-index: 5000;
    width: 360px;
    top: 43px;
    height: 0;
    display: inline!important;
    padding-top: 0px;
}
.hs{
    line-height: 40px!important;
}
.nav li ul li {
    overflow: hidden;
    height: 0;
    with: auto;
    transition: 0.2s;
    padding-left: 10px;
    color: #000000;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    width: auto;
    margin-left: 0px;
    margin-right: 0px;
    display: block;
    background-repeat: no-repeat;
    background-image: url(../images/line.png);
    background-position: 0% bottom;
    background-color: rgba(255,255,255,0.85);
    margin-top: 1px;
}
.nav li ul li a {
    color: #000000;
    font-size: 14px;
    text-align: left;
    line-height: 120%;
    padding-top: 0px;
    padding-bottom: 5px;
    margin-bottom: 0px;
    height: 50px;
}
.nav li:hover > ul > li {
  overflow: visible;
	  height: 40px;
}
  .nav li ul li ul {
    top: 0;
    left: 0px;
    width: 0px;
  }
  .nav li ul li ul:before {/*layer-2▷*/
    position: absolute;
    content: "";
    top: 15px;
    left: 30px;
    border: 5px solid transparent;
    border-left: 5px solid #fff;
    z-index: 5000;
  }
  .nav li ul li ul li:hover > a {/*layer-3*/
    color: pink;

  }
  .nav li ul li ul.left {
    top: 0;
    left: -190px;
  }
  .nav li ul li ul.left:before,/*layer-2-left▷*/
  .nav li ul li ul li ul.left:before {/*layer-3-left▷*/
    position: absolute;
    content: "";
    top: 15px;
    left: 190px;
    border: 5px solid transparent;
    border-right: 5px solid #fff;
  }
  .nav li ul li ul.left li:hover > a {/*layer-2-left*/
    color: pink;

  }
  .nav li ul li ul li ul.left li:hover > a {/*layer-3-left*/
    color: purple;
  
  }
.active_bg{

    display: block;
}
#header .logo{
    width: 430px;
    float: left;
    margin-left: 30px;
    margin-bottom: 10px;
}
#header .contact .email img{
	width: 30px;
	height: 30px;
}
#header .contact .tel{
	float: left;
	width: 150px;
}
#header .contact .email{
	width: 30px;
	float: left;
	margin-left: 5px;
}
#header .address{
	float: right;
	width: 450px;
	margin-right: 30px;
	text-align: right;
	line-height: 130%;
	
}
#footer .inner{
    width: 1100px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 50px;
}
#footer .logo{
	width: 355px;
	float: left;
	margin-bottom: 10px;
	margin-top: 25px;
	margin-right: 20px;

}
#footer .contact{
	float: right;
	margin-bottom: 10px;
	font-size: 15px;
	margin-top: 20px;
	margin-left: auto;
	margin-right: auto;
}
#footer .contact a{
    color: #FFBD5E;
    text-align: center;
}
#footer .contact dl{}
#footer .contact dl dt{
    width: 210px;
    float: left;
    text-align: right;
    padding-right: 5px;
}
#footer .contact dl dd{
    width: 500px;
    float: right;
}
#footer .copyright{
    width: 100%;
    margin-bottom: 20px;
    text-align: center;
    clear: both;
    font-size: 15px;
	}
