@charset "UTF-8";
/* CSS Document */
body.responsive{
	min-width: inherit;
}
.contents {
	background-color: #fff;
	position: relative;
}
.contents a:link, a:visited {
	text-decoration: none;
}
/* ------------------------------------------------------------
 * header */
.header {
	height: 0px;
	position: relative;
	z-index: 3;
}
.header__inner {
	padding: 16px 0 15px 0;
	background-color: #000;
}
.header__inner > .inner {
	width: 960px;
	margin: 0 auto;
}
.header__logo {
	float: left;
	margin-left: 1px;
}
.header__logo--company {
	float: right;
	margin-top: 8px;
}

/* header__nav */
.header__nav {
	width: 100%;
	position: absolute;
}
.header__nav__inner {
	position: relative;
	background-color: transparent;
}
.header__nav .inner {
	max-width: 960px;
	margin: 0 auto;
}
.header__nav__menu {
	position: relative;
	height: 27px;
}
.header__nav__menu:after {
	content: "";
	position: absolute;
	top: 50%;
	right: 0;
	display: block;
	width: 1px;
	height: 22px;
	margin-top: -11px;
	background-color:transparent;
}
.header__nav__menu > li {
	position: relative;
	float: left;
	width: 137px;
	height: 27px;
	text-align: center;
	font-size: 12px;
	line-height: 27px;
	margin-top: 25px;
}

.header__nav__menu > li:nth-child(1) {
	width: 27%;
	text-align: left;
	background-image: url(../../image/line_w.png);
	background-repeat: no-repeat;
	background-position: right;
}
.header__nav .header__nav__menu > li:first-child > a,
.header__nav .header__nav__menu > li:first-child > span {
	overflow: hidden;
	background: url(../../image/logo_03.png) no-repeat left 50%;
	text-indent: -9999px;
	display: inline-block;
}
@media screen and (max-width: 768px) {
.header__nav .header__nav__menu > li:first-child > a
{
	background: none;
	text-indent: 0;
}
}
.header__nav__menu > li:nth-child(2),
.header__nav__menu > li:nth-child(3),
.header__nav__menu > li:nth-child(4),
.header__nav__menu > li:nth-child(5){
	width: 9%;
}
.header__nav__menu > li:nth-child(2) a,
.header__nav__menu > li:nth-child(3) a,
.header__nav__menu > li:nth-child(4) a,
.header__nav__menu > li:nth-child(5) a {
	background-image: url(../../image/line_w.png);
	background-repeat: no-repeat;
	background-position: right;
}
.header__nav__menu > li:nth-child(6) {
	width: 19%;
	text-align: right;
}
.header__nav__menu > li:nth-child(7) {
	width: 13%;
	text-align: right;
}
.header__nav__menu > li:nth-child(6) a,
.header__nav__menu > li:nth-child(7) a{
	max-width:120px;
	display: inline-block;
	background-color: #FFFFFF;
	text-align: center;
}
.header__nav__menu > li:nth-child(6) a{
	color: #3256b3;
	margin-right: 10px;
	border: 1px solid #3256b3;
}
.header__nav__menu > li:nth-child(7) a{
	background-color: #06196e;
	color: #fff;
	border: 1px solid #06196e;
}
.header__nav__menu > li:before,
.header__nav__menu > li:before {
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	display: block;
	width: 1px;
	height: 18px;
	margin-top: -11px;
	background-color:transparent;
}
.header__nav__menu > li > a,
.header__nav__menu > li > span {
	display: block;
	width: 100%;
	height: 27px;
}
.header__nav__menu > li > a {
	color: #fff;
	text-decoration: none;
}
.header__nav__menu > li > a:hover {
	opacity: 1;
	background-color: #CCCCCC
}
.header__nav__menu > .is-current > a,
.header__nav__menu > .is-current > span {
	color: #fff;
	font-weight: bold;
}
.header__nav__menu > .is-current > a:after,
.header__nav__menu > .is-current > span:after {
	content: "";
	position: absolute;
	bottom: 1px;
	left: 0;
	display: block;
	width: 137px;
	height: 4px;
	background-color: transparent;
}
#global-nav .header__nav__menu > .is-on > a,
#global-nav .header__nav__menu > .is-on > span {
	background-color: #ccc;
}
.header__nav__menu > .is-on > a:hover {
	opacity: 1;
}
.header__nav__menu > .is-current.is-on > a,
.header__nav__menu > .is-current.is-on > span {
	color: #000;
	font-weight: normal;
}
.header__nav__menu > .is-current.is-on > a:after,
.header__nav__menu > .is-current.is-on > span:after {
	display: none;
}
@media screen and (max-width: 768px) {
#global-nav	.header__nav__menu > li > a:hover {
	opacity: 1;
	background-color: #CCCCCC
}
}
/* header__nav--child */
.header__nav--child {
	position: absolute;
	top: 50px;
	left: 0;
	z-index: 99;
	display: none;
	width: 100%;
	padding-top: 10px;
	background-color: #cccccc;
}
@media screen and (max-width: 768px) {
.header__nav--child {
	top: -200%;
}
}
.header__nav--child__inner {
	width: 960px;
	margin: 0 auto;
	border-top: 1px solid #fff;
	padding: 5px 0 25px;
}
.header__nav--child__inner:first-child {
	border-top: none;
}
.header__nav--child__inner.is-brd {
	border-top: none;
	border-bottom: 1px solid #8f8f8f;
	padding-bottom: 15px;
}
.header__nav__menu--child {
	margin-left: 0px;
}
.header__nav__menu--child > li {
	float: left;
	width: 300px;
	margin: 12px 0 0 20px;
	font-size: 13px;
}
.header__nav__menu--child > li:first-child {
	font-weight: bold;
}
.header__nav__menu--child > li > a {
	padding: 0 0 0 14px;
	background: url(../image/arw_gray_01.png) no-repeat 0 50%;
	color: #000;
	font-weight: normal;
	text-decoration: none;
	display:block;
}
.header__nav__menu--child > li > a:hover {
	opacity: 0.5;
}
/* header__nav fixed */
 .header__nav.fixed{
	position: fixed;
	top: 0;
	z-index:0;
	padding-bottom: 10px;
	background: #fff;
	shadow: 0px 1px 10px #ccc; 
	-moz-box-shadow: 0px 1px 10px #ccc;
	-webkit-box-shadow: 0px 1px 10px #ccc;
}
.header__nav.fixed a{
	color: #333;
}
.header__nav.fixed .header__nav__menu > li:first-child > a,
.header__nav.fixed .header__nav__menu > li:first-child > span {
    overflow: hidden;
    background: url(../image/logo_02.png) no-repeat left 50%;
    text-indent: -9999px;
}
/* header */

/* main */
.main_img{
	position:fixed;
	top: 0;
	width:100%;
	overflow: hidden;
	text-align: center;
	vertical-align: middle;
}
.main_img img{
	width: 100%;
	min-height: 630px;
	position: relative;
}
@media screen and (max-width: 768px) {
.main_img img{
	margin-left: -30%;
	width: 1040px;
	height: 630px;
}
}
.main_copy{
	width:100%;
	margin: 130px auto 40px;
	color: #FFFFFF;
	text-align: center;
}
.main_copy .style01{
	font-size: 1.214em;
}
.copy_wrap{
	position: absolute;
	z-index: 1;
	width: 100%;
	top: 0;
}
@media screen and (min-width: 768px) {
.main_copy {
	width: 440px;
	font-size: 1.143em;
	line-height: 1.7;
}
.copy_wrap{
	top: 10%;
}
}
@media screen and (min-width: 1300px) {
.copy_wrap{
	top: 18%;
}
}
.home__mv {
	position: relative;
	width: 100%;
	height: auto;
}
.home__mv img.space {
    width: 100%;
    min-height: 630px;
}
/* main */

/*banner*/
.ban{
	height: 160px;
	background-color:rgba(34,92,172,0.57);
	margin-bottom: 70px;
	position: relative;
}
.ban_inner{
	width: 90%;
	height: 88px;
	margin:auto;
	padding-top: 36px;
	position: relative;
}
.swiper-container {
	z-index: 0;
	height: 88px;
}
.swiper-slide {
	-webkit-flex-shrink: 0;
	-ms-flex: 0 0 auto;
	flex-shrink: 0;
	width: 100%;
	height: 88px;
	position: relative;
	text-align: center;
}
.swiper-slide img {
	height: 88px;
}
.swiper-button-next, .swiper-button-prev {
	width: 15px;
	height: 30px;
	margin-top: -15px;
	-moz-background-size: 15px 30px;
	-webkit-background-size: 15px 30px;
	background-size: 15px 30px;
}
.swiper-button-prev {
	left: 20px;
	z-index: 0;
}
.swiper-button-next {
	right: 20px;
	z-index: 0;
}
.w_980{
	width: 96%;
	height: 100%;
	position: relative;
	margin: 0 auto;
}
@media screen and (min-width: 768px) {
.w_980{
	max-width: 980px;
	margin: 0 auto;
}
.ban_inner{
	max-width: 860px;
	width: auto;
}
.swiper-container img{
		width: auto;
		height: 100%;
	}
}
/*banner*/

/*news*/
.news_box{
	position: relative;
	width:100%;
	text-align: center;
	background-color: #bdbebf;
	padding: 15px 0 10px;
	clear: both;
}
.news_box p.news{
	color: #FFFFFF;
	width:80px;
	text-align: left;
	display: inline-block;
	vertical-align: top;
	margin-bottom: 10px;
}
.news_box ul{
	display: inline-block;
	text-align: left;
	position: relative;
	text-indent: -6.5em;
	padding-left: 6.5em;
	max-width: 570px;
}
.news_box ul li{
	margin-bottom: 10px;
}
.news_box ul li:last-child{
	margin-bottom: 0px;
}
.contents .news_box a{
	color: #000000;
	text-decoration: underline;
}
.news_box a:hover{
	color: #5185c5;
}
@media screen and (max-width: 768px) {
.news_box ul{
	clear: both;
	width: 60%;
	margin: 0 auto;
	float: none;
}
.news_box p.news{
	text-align: center;

}
}

.news_box span.date{
	color: #FFFFFF;
	width:100px;
	text-align: right;
}
/*news*/

/*contents*/
/*title*/
h1 img{
	width: 234px;
	margin-top: 30px;
	margin-bottom: 30px;
}
h2{
	text-align: center;
}
h2 span {
	color: #5185c5;
	font-size: 1.643em;
	background-image: url(../../image/under_line.jpg);
	padding-bottom:9px;
	background-repeat: no-repeat;
	background-position: center bottom;
	display: inline-block;
	border: none;
}
.toiawase h2 span {
	color: #5185c5;
	font-size: 1.643em;
	padding-bottom:9px;
	background-image: none;
	background-repeat: no-repeat;
	background-position: center bottom;
	display: inline-block;
	border: none;
	margin-top: 40px;
}
.toiawase p {
	color: #595757;
	font-size: 1.071em;
}
.tit_style{
	color: #5185c5;
}
.tit_style p span{
	font-size:0.857em;
	margin: 11px auto 13px;
	display: block;
}
/*title*/

.ta_l{
	text-align: left;
}
.responsive .sec--02 {
	margin-top: 45px;
}

/*ditail*/
.ditail{
	background-color: #7dcde9;
	min-height: 320px;
	margin-top: 35px;
	padding-bottom:50px;
}
.ditail .inner {
	background-image: url(../../image/arrow_w.png);
	background-repeat: no-repeat;
	background-position: 50% -1px;
	background-size: 40px 20px;
}
.ditail h3{
	font-size: 1.071em;
	font-weight: bold;
	margin-bottom: 15px;
}
.ditail ul {
	width: 100%;
	padding-top:25px;
}
.ditail ul li {
	display: block;

}
@media screen and (min-width: 768px) {
.ditail{
	background-image: url(../../image/second_img.jpg);
	background-size: 130%;
	background-size: auto;
	background-position: center;
	background-repeat: no-repeat;
	padding-bottom: 0px;
}
.ditail ul {
	width: 700px;
}
.ditail ul li {
	display: inline-block;
	width: 240px;
	font-size: 0.857em;
}
.ditail ul li:nth-child(3){
	width: 210px;
}
.ditail div{
	width: 960px;
}
}

.ditail .btn a {
	display: block;
	padding: 10px 0;
	background-color: #fff;
	font-weight: bold;
	color: #5185c5;
	margin: 40px auto 10px;
	width:100%;
	max-width: 215px;
	text-align: center;
	font-size: 0.964em;
	text-decoration: none;
}
/*ditail*/


/*solution*/
.solution li {
	width: calc(100% - 20px);
	text-align: center;
	margin-bottom: 20px;
	padding: 10px;
	color: #595757;
	position: relative;
	display: inline-block;
	border: 2px solid #ccc;
	text-decoration: none;
	outline: none;
	transition: all .3s;
/*  visibility: hidden;*/
}
.solution li h3{
	font-size: 1.571em;
	font-weight: bold;
	color: #5185c5;
}
.solution li h3 + h4{
	margin-bottom: 10px;
}
.solution li h3 + p{
	margin-top: 10px;
}
.solution li h4{
	font-weight: bold;
	font-size: 1.143em;
}
.solution img{
	width: 130px;
}
@media screen and (min-width: 768px) {
.solution li{
	float: left;
	width:calc(49% - 4px);
	min-height: 198px;
	margin-bottom: 20px;
	padding: 25px 0 0;
}
.solution li p{
	font-size: 1.071em;
}
.solution a:nth-of-type(2n+1) li{
	margin-right: 1%;
}
.solution a:nth-of-type(2n) li{
	margin-left: 1%;
}
}

.solution li::before,
.solution li::after,
.solution li span::before,
.solution li span::after {
  position: absolute;
  z-index: 2;
  content: '';
  width: 0;
  height: 0;
  border: 1px solid transparent;
  transition: all .3s;
}
.solution li::before {
  top: -2px;
  left: -2px;
  border-left-color: #ccc;
}
.solution li::after {
  bottom: -2px;
  right: -2px;
  border-right-color: #ccc;
}
.solution li span::before {
  bottom: -2px;
  left: -2px;
  border-bottom-color: #ccc;
}
.solution li span::after {
  top: -2px;
  right: -2px;
  border-top-color: #ccc;
}
/*.solution li:hover {
  color: #00a6e4;
}*/
.solution li:hover::before,
.solution li:hover::after {
  height: 100%;
  visibility: visible;
	border-color: #00a6e4;
}
.solution li:hover span::before,
.solution li:hover span::after {
  width: 100%;
  visibility: visible;
	border-color: #00a6e4;
}
/*ボタン*/
.btn a {
	display: block;
	padding: 25px 0;
	background-color: #375e9c;
	font-weight: bold;
	color: #FFFFFF;
	margin: 30px auto 80px;
	width:100%;
	max-width: 380px;
	text-align: center;
	font-size: 1.143em;
	text-decoration: none;
	clear: both;
}
@media screen and (min-width: 768px) {
.btn a {
	width:370px;
}
}
/*ボタン*/
/*solution*/


/*sp_nav*/
/* Toggle Button */
#nav-toggle {
	display: none;
	position: absolute;
	z-index: 10;
	right: 13px;
	top: 14px;
	width: 34px;
	height: 36px;
	cursor: pointer;
}
#nav-toggle div {
	position: relative;
}
#nav-toggle span {
	display: block;
	position: absolute;
	left: 0;
	height: 4px;
	width: 100%;
	background: #0069ab;
	-webkit-transition: .35s ease-in-out;
	-moz-transition: .35s ease-in-out;
	transition: .35s ease-in-out;
}
#nav-toggle span:nth-child(1) {
	top: 0;
}
#nav-toggle span:nth-child(2) {
	top: 11px;
}
#nav-toggle span:nth-child(3) {
	top: 22px;
}
#mobile-head {
	display: none;
	}
@media screen and (max-width: 768px) {
.header__nav__menu{
	height: auto;
}
#top-head {
	top: 0;
	position: fixed;
	margin-top: 0;
	width: 100%;
}
#top-head.fixed {
	padding-top: 0;
	background: transparent;
}
#mobile-head {
	display: block;
	position: relative;
	z-index: 999;
	width: 100%;
	height: 56px;
	background: #fff;
	shadow: 0px 1px 10px #ccc;
	-moz-box-shadow: 0px 1px 10px #ccc;
	-webkit-box-shadow: 0px 1px 10px #ccc;
}
#mobile-head p.logo{
	width: 92px;
}
.fixed .logo,
.logo {
	position: absolute;
	left: 13px;
	top: 13px;
	color: #fff;
	font-size: 1.625em;
}
#global-nav {
	position: absolute;
	top: -500px;
	width: calc(100%);
	padding: 10px 0;
	background: #333;
	text-align: left;
	-webkit-transition: .5s ease-in-out;
	-moz-transition: .5s ease-in-out;
	transition: .5s ease-in-out;
}
.header__nav .inner {
	height: auto;
	width: 96%;
}
ul.header__nav__menu > li {
	position: static;
	right: 0;
	bottom: 0;
	font-size: 0.875em;
	list-style: none;
}
.header__nav__menu > li {
	position: static;
	float: none;
	margin-top: 0px;
	padding: 10px 0;
}
.header__nav__menu > li:nth-child(1),
.header__nav__menu > li:nth-child(2),
.header__nav__menu > li:nth-child(3),
.header__nav__menu > li:nth-child(4),
.header__nav__menu > li:nth-child(5),
.header__nav__menu > li:nth-child(6),
.header__nav__menu > li:nth-child(7){
	width: 100%;
	border: none;
}
.header__nav.fixed .header__nav__menu > li:first-child > a,
.header__nav.fixed .header__nav__menu > li:first-child > span {
	background: none;
	text-indent:0;
}
.header__nav__menu > li:nth-child(6) a {
	color: #FFFFFF;
	margin: 0px;
	border: none;
}
.header__nav__menu > li:nth-child(6) a,
.header__nav__menu > li:nth-child(7) a {
	max-width: 100%;
	display: block;
	background-color: transparent;
	text-align: center;
}
.header__nav__menu > li:nth-child(1),
.header__nav__menu > li:nth-child(2) a,
.header__nav__menu > li:nth-child(3) a,
.header__nav__menu > li:nth-child(4) a,
.header__nav__menu > li:nth-child(5) a {
	background: none;
}
.header__nav--child {
	display: none;
}
.header__nav--child__inner {
	width:100%;
}
.header__nav__menu--child > li {
	float: none;
	width: 100%;
	margin: 12px 0 0 0px;
	font-size: 13px;
}
	
#global-nav ul li a,
.fixed #global-nav ul li a {
	display: block;
	color: #fff;
	text-align: center;
	font-size: 1.143em;
}
.fixed #global-nav ul li a:hover {
	background-color:rgba(204,204,204,1.00);
	opacity: 1;
	}
#global-nav ul.header__nav__menu--child li a,
.fixed #global-nav ul.header__nav__menu--child li a {
	color: #000;
	}
#nav-toggle {
		display: block;
	}
	/* #nav-toggle 切り替えアニメーション */
	.open #nav-toggle span:nth-child(1) {
		top: 11px;
		-webkit-transform: rotate(315deg);
		-moz-transform: rotate(315deg);
		transform: rotate(315deg);
	}
	.open #nav-toggle span:nth-child(2) {
		width: 0;
		left: 50%;
	}
	.open #nav-toggle span:nth-child(3) {
		top: 11px;
		-webkit-transform: rotate(-315deg);
		-moz-transform: rotate(-315deg);
		transform: rotate(-315deg);
	}
	/* #global-nav スライドアニメーション */
	.open #global-nav {
		/* #global-nav top + #mobile-head height */
		-moz-transform: translateY(556px);
		-webkit-transform: translateY(556px);
		transform: translateY(556px);
	}
}
/*sp_nav*/
.link_wrap{
	display: table;
	width: 100%;
}
.responsive .sec--02.link_wrap .col01{
	width: 100%;
	vertical-align: middle;
	position: relative;
	max-height: 285px;
	overflow: hidden;
}
.responsive .sec--02.link_wrap a .col01 img{
-moz-transition: -moz-transform 0.5s linear;
-webkit-transition: -webkit-transform 0.5s linear;
-o-transition: -o-transform 0.5s linear;
-ms-transition: -ms-transform 0.5s linear;
transition: transform 0.5s linear;
	max-width:inherit;
	width: 100%;
}
.responsive .sec--02.link_wrap a:hover .col01 img{
 -webkit-transform: scale(1.2);
-moz-transform: scale(1.2);
-o-transform: scale(1.2);
-ms-transform: scale(1.2);
transform: scale(1.2);
}
.responsive .sec--02.link_wrap a:hover .col01 div{
	opacity: 0.5;
}
 
@media screen and (min-width: 768px) {
.link_wrap{
	min-width: 960px;
}
.responsive .sec--02.link_wrap .col01{
	width: calc(100% / 3);
	float: left;
	vertical-align: middle;
	text-align: center;
	position: relative;
}
}
.link_wrap .btn{
	position: absolute;
	z-index: 9999;
	width: 270px;
	top: calc(50% - 30px);
	left: calc(50% - 135px);
	display: block;
	margin: auto auto;
	padding: 20px 0;
	background-color: #fff;
	font-weight: bold;
	color: #3eaae1;
	text-align: center;
	font-size: 1.429em;
	text-decoration: none;
	letter-spacing: 0.1em;
}
footer{
	position: relative;
	z-index: 1;
}