html,body{
	width: 100%;
}
#wrapper{
	width: 100%;
}

/*
main-img
----------------------------------------*/

/* スマートフォン（ディスプレイ幅480px以下）より小さい画面 */
@media screen and (min-width: 780px) {
	#main-img .container {
	width: 970px;

}}
#main-img {
	height: 853px;
/*padding: 140px 0 0;
	padding: 15% 0 0;*/
	background: url(../img/top/bg_top6.jpg) no-repeat center center fixed;
	background-size: cover;
	text-align: left;
	letter-spacing: 0.1em;
}
#main-img .frame {
	width: 100%;
	margin: 0 auto;
	padding: 17% 0 0;
	position: relative;
	text-align: center;
}
#main-img .frame h1 {
	color: #fff;
  font-family: 'ＭＳ Ｐ明朝';
  font-size: 60px;
  line-height: 1.3;
  font-weight: 50;
 text-shadow: 0 0px 3px #000;
}
#main-img .frame h2.catch {
  margin: -6px 0 0 10px;
  font-size: 32px;
  font-weight: 600;
  letter-spacing: 0.3em;
  color: #fff;
  line-height: 1.8;
  text-shadow: 0 0px 3px #000;
}

#main-img .frame .btn {
	display: inline-block;
	width: 300px;
	height: 64px;
	text-align: center;
	text-decoration: none;
	line-height: 54px;
	outline: none;

}
#main-img .frame .btn::before,
#main-img .frame .btn::after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}
#main-img .frame .btn,
#main-img .frame .btn::before,
#main-img .frame .btn::after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all .25s;
	transition: all .25s;
}
#main-img .frame .btn {
	position: relative;
	margin-top: 15px;
	z-index: 2;
	background: none;
	border: 4px solid #fff;
	color: #fff;
	line-height: 60px;
	overflow: hidden;
	font-size: 18px;
	font-weight: 700;
	letter-spacing: 0.14em;
	display: inline-block;
	/*padding:0px 50px;*/
}
#main-img .frame a {
	text-align:center;
}
#main-img .frame .btn:hover {
	color: #36699E;
}
#main-img .frame .btn::after {
	top: 0;
	left:-100%;
	width: 100%;
	height: 100%;
}
#main-img .frame .btn:hover::after {
	/*top: 0;*/
	left: 0;
	background-color: #fff;
}
#main-img .scroll {
	position: absolute;
	bottom: 15px;
	left: 50%;
	margin-left: -28px;
}
#main-img .copy {
	position: absolute;
	top: 200px;
	right: 20px;
}



/*
content-sub-img
----------------------------------------*/
#content-sub-img {
	/*height: 853px;*/
	height: 30%;
	/*padding: 140px 0 0;*/
	/*padding: 15% 0 0;*/
	background: url(../img/top/bg_top3.jpg) no-repeat center center fixed;
	background-size: cover;
	text-align: left;
	letter-spacing: 0.1em;

}
#content-sub-img .frame {
	width: 100%;
	margin: 0 auto;
	padding: 3% 0 0;
	position: relative;
	text-align: center;
}

#margin20 {
	width: 1096px;
}
#content-sub-img .frame h1 {
	color: #fff;
  font-family: 'ＭＳ Ｐ明朝';
  font-size: 40px;
  line-height: 1.3;
  font-weight: 50;
  text-shadow: 0 0px 3px rgba(0,0,0,0.3);
}
#content-sub-img .frame h2.catch {
	color: #fff;
  font-family: 'ＭＳ Ｐ明朝';
  font-size: 40px;
  line-height: 1.3;
  font-weight: 50;
  text-shadow: 0 0px 3px rgba(0,0,0,0.3);
}
#content-sub-img .frame .btn {
	display: inline-block;
	width: 300px;
	height: 64px;
	text-align: center;
	text-decoration: none;
	line-height: 54px;
	outline: none;
}
#content-sub-img .frame .btn::before,
#content-sub-img .frame .btn::after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}
#content-sub-img .frame .btn,
#content-sub-img .frame .btn::before,
#content-sub-img .frame .btn::after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all .25s;
	transition: all .25s;
}
#content-sub-img .frame .btn {
	position: relative;
	margin-top: 15px;
	z-index: 2;
	background: none;
	border: 4px solid #fff;
	color: #fff;
	line-height: 60px;
	overflow: hidden;
	font-size: 18px;
	font-weight: 700;
	letter-spacing: 0.14em;
	display: inline-block;
	/*padding:0px 50px;*/
}
#content-sub-img .frame .btn:hover {
	color: #36699E;
}
#content-sub-img .frame .btn::after {
	top: 0;
	left:-100%;
	width: 100%;
	height: 100%;
}
#content-sub-img .frame .btn:hover::after {
	/*top: 0;*/
	left: 0;
	background-color: #fff;
}
#content-sub-img .scroll {
	position: absolute;
	bottom: 15px;
	left: 50%;
	margin-left: -28px;
}
#content-sub-img .copy {
	position: absolute;
	top: 200px;
	right: 20px;
}

/*
content
----------------------------------------*/
#content{
	  background: #fff;
}
/* news */
#content #news {
	width: 100%;
	display: table;
}
#content #news .left {
	width: 25%;
	background: #eee;
	display: table-cell;
	vertical-align: middle;
}
#content #news .right {
	width: 75%;
	padding: 46px 0 60px;
	display: table-cell;
}
#content #news .left h3 {
	width: 145px;
	margin: 0 auto;
	padding: 0;
	background: none;
	text-align: center;
	color: #000;
	font-size: 36px;
	font-weight: 900;
}
#content #news .left p {
	margin: 16px 0 24px;
	color: #666;
}
/*#content #news .left .btn {
	width: 125px;
	margin: 0 auto;
	padding: 0 20px 0 0;
	font-size: 13px;
}
#content #news .left .btn a {
	width: 125px;
	padding: 17px 20px 14px 0;
	background: #222 url(../img/top/icon_arrow_white.png) no-repeat 110px center;
	color: #fff;
	text-decoration: none;
	display: block;
}*/
#content #news .btn {
	display: inline-block;
	width: 200px;
	height: 44px;
	text-align: center;
	text-decoration: none;
	line-height: 44px;
	outline: none;
}
#content #news .btn::before,
#content #news .btn::after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}
#content #news .btn,
#content #news .btn::before,
#content #news .btn::after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all .3s;
	transition: all .3s;
}
#content #news .btn {
	position: relative;
	z-index: 2;
	background: #222;
	border: 4px solid #222;
	color: #eee;
	line-height: 40px;
	overflow: hidden;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.14em;
	display: inline-block;
}
#content #news .btn:hover {
	color: #222;
	background: #eee
}
#content #news .btn::after {
	top: 0;
	left:-100%;
	width: 100%;
	height: 100%;
}
#content #news .btn:hover::after {
	/*top: 0;*/
	left: 0;
	background-color: #eee;
}
#content #news .right article a {
	width: 735px;
	margin: 0 auto;
	padding: 14px 0;
	border-bottom: 1px solid #eee;
	color: #444;
	display: block;
	text-decoration: none;
	text-align: left;
}
#content #news .right article a:hover {
	color: #5992F8;
}
#content #news .right article a .top {
	margin: 0 0 14px;
}
#content #news .right article a .top .day {
	/*padding: 0 0 0 30px;*/
	/*background: url(../img/common/icon_arrow_blue.png) no-repeat left center;*/
	color: #bbb;
	font-size: 16px;
}
#content #news .right article a .top .day i{
	color:#649CE5;
	margin-right: 20px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all .1s;
	transition: all .1s;
}
#content #news .right article a:hover .top .day i{
	margin-right: 5px;
	margin-left: 15px;
}
#content #news .right article a:hover .top .day {
	/*background: url(../img/common/icon_arrow_blue.png) no-repeat 12px center;*/
}
#content #news .right article a .bottom .icon {
	width: 73px;
	padding: 9px 0 6px;
	color: #fff;
	display: table-cell;
	font-size: 11px;
	text-align: center;
}
#content #news .right article a .bottom .icon.blue {
	background: #0ca2e6;
}
#content #news .right article a .bottom .icon.green {
	background: #34b5be;
}
#content #news .right article a .bottom .icon.lightblue {
	background: #08c6e4;
}
#content #news .right article a .bottom .title {
	padding: 0 0 0 10px;
	font-weight: bold;
	display: table-cell;
	vertical-align: middle;
}

/* menu */
#content .menu .frame {
	width: 100%;
	height: 400px;
	overflow: hidden;
	/*display: table;*/
}
#content .menu .frame a {
	color: #fff;
	text-decoration: none;
	text-align: left;
}
#content .menu .frame a .inner {
	width: 100%;
	height: 100%;
	position: absolute;
	top: -50%;
	left: -50%;
	background: url("../img/video/video-bg.png") repeat;
	display: block;
	padding: 24% 0%;
	text-align: center;
}
#content .menu .frame a .inner h3 {
	padding: 0;
	background: none;
	font-size: 36px;
	color: #fff;
	letter-spacing: 0.025em;
	margin-bottom: 32px;
	font-weight: bold;
}
#content .menu .frame a .inner .title {
	margin: 16px 0 20px;
}
#content .menu .frame a .inner .tx {
	line-height: 1.9;
}
#content .menu .frame #about,
#content .menu .frame #service,
#content .menu .frame #recruit,
#content .menu .frame #access {
	/*width: 50%;
	display: table-cell;*/
}
#content .menu .frame .stage{
	width: 50%;
	float: left;
	top: 10%;
	position: relative;
	left: 0%;
}
#content .menu .frame .stage video{
	min-height: 100%;
	min-width: 100%;
	transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
}
#content .menu .frame .stage .sp-bg{
	height: 180px;
	background-size: cover;
	display: none;
}
#content .menu .frame .stage .sp-bg.about{
	background: url(../img/top/bg_about.png);
}
#content .menu .frame .stage .sp-bg.service{
	background: url(../img/top/bg_service.png);
}
#content .menu .frame .stage .sp-bg.recruit{
	background: url(../img/top/bg_recruit.png);
}
#content .menu .frame .stage .sp-bg.access{
	background: url(../img/top/bg_access.png);
}

/* スマートフォン（ディスプレイ幅480px以下）より小さい画面 */
@media screen and (max-width: 480px) {
#main-img {
	padding-top: 10px;
	/*margin-bottom: 1px;*/
	background-size: auto 100%;
	background: url(/img/top/bg_top3.jpg) no-repeat top center;
}
#main-img .frame {
	width: auto;
	margin: 0;
	padding: 0;
}
#main-img .frame h1 {
	  margin: 0;
  padding: 0 0 0 20px;
  font-size: 22px;
  text-align: center;
}
#main-img .frame h2.catch {
	margin: 0;
  padding: 10px;
  font-size: 24px;
  text-align: center;
  background:rgba(0,0,0,0.5);

}
#main-img .frame h2.catch img {
	width: 200px;
	height: 29px;
}
#main-img .frame .btn {
	width: 260px;
  /*margin: 10px 0 0 25px;
  display: block;*/
  line-height: 12px;
  font-size: 16px;
  height: 30px;
  border-width: 3px;
}
#main-img .frame .btn a {
	width: 263px;
	height: 55px;
}
#main-img .scroll{
	display: none;
}
#main-img .copy {
	display: none;
}

/*
content-sub-img
----------------------------------------*/
#content-sub-img {
	/*height: 853px;*/
	height: 20%;
	/*padding: 140px 0 0;*/
	/*padding: 15% 0 0;*/
	background: url(../img/top/bg_top3.jpg) no-repeat center center fixed;
	background-size: cover;
	text-align: left;
	letter-spacing: 0.1em;

}
#content-sub-img .frame {
	width: 100%;
	margin: 0 auto;
	padding: 3% 0 0;
	position: relative;
	text-align: center;
}

#margin20 {
	width: 1096px;
}
#content-sub-img .frame h1 {
	color: #fff;
  font-family: 'ＭＳ Ｐ明朝';
  font-size: 20px;
  line-height: 1.3;
  font-weight: 20;
  text-shadow: 0 0px 3px rgba(0,0,0,0.3);
}
#content-sub-img .frame h2.catch {
	color: #fff;
  font-family: 'ＭＳ Ｐ明朝';
  font-size: 30px;
  line-height: 1.3;
  font-weight: 20;
  text-shadow: 0 0px 3px rgba(0,0,0,0.3);
}
#content-sub-img .frame .btn {
	display: inline-block;
	width: 300px;
	height: 64px;
	text-align: center;
	text-decoration: none;
	line-height: 54px;
	outline: none;
}
#content-sub-img .frame .btn::before,
#content-sub-img .frame .btn::after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}
#content-sub-img .frame .btn,
#content-sub-img .frame .btn::before,
#content-sub-img .frame .btn::after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all .25s;
	transition: all .25s;
}
#content-sub-img .frame .btn {
	position: relative;
	margin-top: 15px;
	z-index: 2;
	background: none;
	border: 4px solid #fff;
	color: #fff;
	line-height: 60px;
	overflow: hidden;
	font-size: 18px;
	font-weight: 700;
	letter-spacing: 0.14em;
	display: inline-block;
	/*padding:0px 50px;*/
}
#content-sub-img .frame .btn:hover {
	color: #36699E;
}
#content-sub-img .frame .btn::after {
	top: 0;
	left:-100%;
	width: 100%;
	height: 100%;
}
#content-sub-img .frame .btn:hover::after {
	/*top: 0;*/
	left: 0;
	background-color: #fff;
}
#content-sub-img .scroll {
	position: absolute;
	bottom: 15px;
	left: 50%;
	margin-left: -28px;
}
#content-sub-img .copy {
	position: absolute;
	top: 200px;
	right: 20px;
}


/* news */
#content #news {
	width: 100%;
	display: block;
}
#content #news .left {
	width: 100%;
	height: 100px;
	display: block;
}
#content #news .right {
	width: 100%;
	padding: 0;
	display: block;
}
#content #news .left .title {
	margin: 32px 0 0 20px;
	float: left;
	text-align: left;
}
#content #news .left h3 {
	width: auto;
	margin: 0;
	padding: 0;
	background: none;
	text-align: left;
	font-size: 24px;
	margin-bottom: 2px;
}
#content #news .left h3 img {
	width: 72px;
	height: 19px;
}
#content #news .left p {
	margin: 0 0 24px;
	color: #666;
}
#content #news .left .btn {
	margin: 28px 20px 0 0;
	float: right;
	font-size: 12px;
	width: 160px;
}
#content #news .right article a {
	width: auto;
	margin: 0 15px;
	padding: 20px 0;
}
#content #news .right article a:hover {
	color: #5992F8;
}
#content #news .right article a .top {
	margin: 0 0 14px;
}
#content #news .right article a .top .day {
	color: #bbb;
	font-size: 16px;
}
#content #news .right article a .bottom .icon {
	width: 73px;
	height: 10px;
	padding: 8px 0 7px;
	color: #fff;
	float: left;
	display: table-cell;
	font-size: 11px;
	text-align: center;
}
#content #news .right article a .bottom .icon.blue {
	background: #0ca2e6;
}
#content #news .right article a .bottom .icon.green {
	background: #34b5be;
}
#content #news .right article a .bottom .icon.lightblue {
	background: #08c6e4;
}
#content #news .right article a .bottom .title {
	padding: 0 0 0 10px;
	font-weight: bold;
	display: table-cell;
	vertical-align: middle;
}

/* menu */
#content .menu .frame {
	width: 100%;
	display: block;
	height: 100%;
}
#content .menu .frame a .inner {
	/*width: 100%;
	height: 130px;
	margin: 0 0 0 -35px;
	padding: 0;
	background: url(../img/top/icon_arrow_white_big.png) no-repeat right center;*/
	padding: 20% 0%;
	top: 0;
	left: 0;
	  display: table;
}
#content .menu .frame a .inner div{
	display: table-cell;
}
#content .menu .frame a .inner h3 {
	/*padding: 45px 0 0 70px;
	background: none;*/
	    margin: 0px;
}
#content .menu .frame a .inner .title {
	/*margin: 12px 0 0;
	padding: 0 0 0 70px;*/
}
#content .menu .frame a .inner .tx {
	display: none;
}
#content .menu .frame .stage{
	width: 100%;
	top: 0;
	left: 0;
}
#content .menu .frame .stage video{
	width: 100%;
	transform: translate(0%, 0%);
	-webkit-transform: translate(0%, 0%);
	display: none;
}
#content .menu .frame .stage .sp-bg{
	display: block;
}
#content .menu .frame #about,
#content .menu .frame #service,
#content .menu .frame #recruit,
#content .menu .frame #access {
	width: 100%;
	display: block;
}
#content .menu .frame #about {
	background: url(../img/top/bg_about.png) no-repeat left top;
	background-size: cover;
}
#content .menu .frame #service {
	background: url(../img/top/bg_service.png) no-repeat left top;
	background-size: cover;
}
#content .menu .frame #recruit {
	background: url(../img/top/bg_recruit.png) no-repeat left top;
	background-size: cover;
}
#content .menu .frame #access {
	background: url(../img/top/bg_access.png) no-repeat left top;
	background-size: cover;
}
}

footer {
	position: static;
	bottom: inherit;
}
.box1{
	width:100%;
	color:#fff;
	font-size:22px;
	font-weight:bold;
	padding:60px;
}

@media screen and (max-width: 750px) {
	.box1{
	font-size:12px;
	padding:18px 0;
	text-align:center;
	height:53px;
 display: -webkit-flex;
 display: flex;
 -webkit-align-items: center; /* 縦方向中央揃え（Safari用） */
 align-items: center; /* 縦方向中央揃え */
 -webkit-justify-content: center; /* 横方向中央揃え（Safari用） */
 justify-content: center; /* 横方向中央揃え */
}
}
.box2{
	width:100%;
	color:#fff;
	font-size:22px;
	font-weight:bold;
	padding:60px;
}

@media screen and (max-width: 750px) {
	.box2{
	font-size:10px;
	padding:18px 0;
	text-align:center;
	height:53px;
 display: -webkit-flex;
 display: flex;
 -webkit-align-items: center; /* 縦方向中央揃え（Safari用） */
 align-items: center; /* 縦方向中央揃え */
 -webkit-justify-content: center; /* 横方向中央揃え（Safari用） */
 justify-content: center; /* 横方向中央揃え */
}
}

div#header01collapse.fix.header01-collapse .frame ul#moremenu {
background: #fff;
top: 70px;
opacity: .9;
}
div#header01collapse.fix .frame ul#moremenu li a:HOVER:AFTER{
background: #095DA6;
}
div#header01collapse.fix .frame ul#moremenu li a{
color: #095DA6;
}
div#header01collapse.fix .frame ul#moremenu {
background: rgba(255,255,255,.9);
top: 120px;
}