@charset "utf-8";


/* -------------------------------------------------------
contents
------------------------------------------------------- */
.contents,
.inner{
	margin: 0 auto;
	padding:0 40px;
	width: 100%;
	max-width: 1200px;
	text-align: left;
	position: relative;
}
@media screen and (max-width:767px){
	.contents,
	.inner{
		padding:0 20px;
		max-width:100%;
	}
}


/* -------------------------------------------------------
  top
------------------------------------------------------- */
/**/
.topImgCont01{
	width: 100%;
	height: 870px;
	position: relative;
	background: url(../img/top/mv01.png) no-repeat top center;
	background-size: cover;
}
.bgBl {
	background-color: #f1f8ff;
	padding-bottom: 60px;
}
/**/
.topImgCont02{
	width: 100%;
	position: relative;
	background: url(../img/top/sec_bg.png) no-repeat top center;
	background-size:100%;
	background-position: left bottom;

}
.topBgBl{
	background-color: #f1f8ff;
	padding:90px 0 100px;
}
.topBgBl.mt-{
	padding:200px 0 140px;
	margin-top: -110px;
}
.topBgBl > .inner > ul{
	display:flex;
	justify-content: space-between;
}
.topBgBl > .inner > ul li{
	width: 48%;
	box-shadow:1px 1px 2px 1px #ccc;
}

/*mv*/
.mvTop{
	width: 100%;
	max-width: 1200px;
  margin: 0 auto;
	position: relative;
	padding: 215px 0 205px;
	text-align: center;
}
.mvTop h2 {
  overflow: hidden;
  position: relative;
	font-size: 400%;
	text-align: left;
	color: #fff;
	font-weight: normal;
  line-height: 1.5;
	margin: 0 auto;
	letter-spacing: 0.1em;
	text-shadow: 3px 3px 7px rgba(0,0,0,0.3);
}
.mvTop h2 span{
  display: block;
  /* padding-left: 4em; */
}
/*secWt*/
.secWt{
	margin: 0 auto;
	padding: 60px 100px 65px;
	max-width: 1200px;
	position: relative;
	background-color: rgba(255,255,255,0.9);
  box-shadow: 1px 1px 1px 1px #ddd;
}

/*ttl*/
.ttlTopBl{
	text-align: center;
	display: block;
	font-size:228%;
	font-weight: normal;
	color:#053597;
	margin-bottom: 50px;
}
.secWt p {
	font-size: 25px;
	letter-spacing: 0.02em;
	color: #053597;
}

.br_1200 {
	display: block;
}

@media screen and (max-width:1200px){
	.secWt {
		margin:0 20px;
	}
	.mvTop {
		padding-left: 20px;
		padding-right: 20px;
	}
	.br_1200 {
		display: none;
	}
}

@media screen and (max-width:1024px){
	.topImgCont01{
		background: url(../img/top/mv01.png) no-repeat 75% top;
		background-size: cover;
		height: auto;
	}
	.ttl_bg {
		margin-bottom: 130px;
	}
	.bgBl {
		padding-bottom: 65px;
	}
	.topImgCont02{
		/* padding: 50px 0 60px; */
		padding-top: 20px;
	}
	.topBgBl{
		padding:110px 0 50px;
	}
	.mvTop{
		width: 100%;
		padding: 130px 20px;
	}
	.mvTop h2 {
		font-size: 250%;
		letter-spacing: 0em;
	}
	.secWt{
		margin:0 20px;
		padding:40px 20px;
		max-width:100%;
		top: 20px;
	}
	.ttlTopBl{
		font-size:227%;
		margin-bottom: 30px;
	}
	.pc {
		display: none;
	}
}
@media screen and (max-width:767px){
	.topImgCont01{
		background: url(../img/top/mv01.png) no-repeat 85% top;
		background-size: cover;
		padding-bottom: 0;
	}
	.topImgCont02{
		/* padding: 50px 0 40px; */
		background-size: 190%;
	}
	.topBgBl.mt-{
		padding:170px 0 60px;
		margin-top: -110px;
	}
	.topBgBl{
		padding: 80px 0 50px;
	}
  .mvTop{
		padding: 60px 15px 0;
    margin: 0 auto 40px;
	}
	.mvTop h2 {
		font-size: 160%;
    margin-left:auto;
		/* background: rgba(4, 58, 124, 0.6); */
    padding-top: 5px;
	}
  .mvTop h2 span{
    padding-left: 0;
  }
	.mvTop .copy{
		font-size:100%;
		margin-bottom: 20px;
	}
	.secWt{
		margin:0 10px;
		padding:30px 20px;
		max-width:100%;
	}
	/*ttl*/
	.ttlTopBl{
		font-size:178%;
		margin-bottom: 24px;
	}
	.secWt p {
		font-size: 16px;
	}
}
@media screen and (max-width:350px){
  .mvTop h2 {
		font-size: 130%;
	}
}

/*business*/
.cont {
	margin: 0 auto;
	padding: 40px 20px;
	max-width: 1200px;
}
.business {
	width: 100%;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	margin-bottom: 30px;
	padding-top: 20px;
}
.business > li {
	width: 100%;
	display: block;
	margin-bottom: 140px;
	line-height: 1;
}
.business > li:last-child {
	margin-bottom: 0;
}
.business > li > a {
  display: table;
  width: 100%;
  height: 100%;
  cursor: pointer;
	text-decoration: none;
	position: relative;
}
.business > li > a:hover .businessTxt  {
	background: rgba(255, 255, 255, 1);
}
.business > li > a:hover::after,
.business > li > a:hover .businessTxt p,
.business > li > a:hover .businessTtl::before,
.business > li > a:hover .businessTtl::after {
	opacity: 0.6;
}
.business > li > a::after {
	position: absolute;
	content:"\f105";
	right: 30px;
	top: 60%;
	color: #053597;
	font-size: 34px;
	font-family: "FontAwesome";
}
.businessImg {
	width: 50%;
	height: 338px;
	display: table-cell;
	-webkit-transition: -webkit-transform 0.3s;
	transition: transform 0.3s;
}
.business > li:first-child > a .businessImg {
	background: url(../img/top/sec_img01.png) no-repeat center center;
  background-size: cover;
}
.business > li:nth-child(2) > a .businessImg {
	background: url(../img/top/sec_img02.png) no-repeat center center;
  background-size: cover;
}
.business > li:nth-child(3) > a .businessImg {
	background: url(../img/top/sec_img03.png) no-repeat center center;
  background-size: cover;
}
.businessTxt {
  width: 50%;
  margin-left: 40%;
  line-height: 1;
  padding: 58px 10px 72px 30px;
  display: table-cell;
  vertical-align: middle;
	position: relative;
	top: 20px;
	padding:0.25em 1em;
	box-shadow: 4px 4px 5px 2px #ddd;
	background-color: #fff;
}
.txtFrameBl {
	padding: 20px;
  position: relative;
}
.txtFrameBl::before,
.txtFrameBl::after {
	content: '';
	width: 30px;
	height: 30px;
	position: absolute;
}

.txtFrameBl::before {
	border-left: solid 1px #5767bf;
	border-top: solid 1px #5767bf;
	top: 0;
	left: 10px;
}

.txtFrameBl::after {
	border-right: solid 1px #5767bf;
	border-bottom: solid 1px #5767bf;
	bottom: 0;
	right: 10px;
}

.businessTxt p {
	font-size: 100%;
	line-height: 1.7;
	padding: 20px;
	padding-right: 50px;
}
.businessTxt p.subTtl {
	font-size: 110%;
	font-weight: bold;
	position: relative;
}
 .businessTtl {
	 position: relative;
	 width: 80%;
	 margin-left: 20px;
 }
.businessTtl::before {
  border-bottom: solid 1px #053597;
  width: 50%;
  position: absolute;
	z-index: 1;
	bottom: 0;
	left: 0;
  content: "";
}
.businessTtl::after {
  border-bottom: solid 1px #c9ddfe;
  width: 100%;
  position: absolute;
	bottom: 0;
	left: 0;
  content: "";
}
@media screen and (max-width:1024px){
	.business > li > a::after {
		font-size: 32px;
	}
	.businessTxt p {
		font-size: 87%;
		padding-top: 10px;
		padding-right: 50px;
	}
	.businessTxt > p.subTtl {
		 margin-bottom: 15px;
		 padding-top: 20px;
		 padding-bottom: 5px;
 }
 .businessTxt > p.subTtl::after {
     bottom: -1px;
 }
}
@media screen and (max-width:767px) {
	.cont {
		width: 100%;
		padding: 0 20px 20px;
	}
	.business > li {
		margin-bottom: 50px;
	}
	.business > li:last-child {
		margin-bottom: 0;
	}
	.business > li > a {
    display: block;
  }
	.business > li > a::after {
    top: 75%;
    font-size: 30px;
	}
  .businessImg {
  	width: 100%;
    display: block;
		height: 200px;
   }
  .businessTxt {
	  width: 100%;
    display: block;
		top: 0px;
  }
  .businessTxt p {
	  font-size: 80%;
		padding-right: 20px;
  }
  .businessTxt {
	  margin-left: 0;
  }
	.txtFrameBl::before {
		top: 10px;
	}
	.txtFrameBl::after {
    bottom: 10px;
	}
}

/*reason*/
.reason{
	margin: 50px auto 0;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.reason li{
	width: 22.6%;
}
.reason li:nth-child(5){
	clear: both;
	width: 100%;
	margin-top: 24px;
}
@media screen and (max-width:767px){
	.reason{
		margin: 30px auto 0;
	}
	.reason li{
		width: 48%;
		margin-top: 14px;
	}
	.reason li:nth-child(5){
		margin-top: 14px;
	}
}


/*formLink*/
/* .formLink {
	margin: auto 0;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.formLink li{
	width: 31%;
	box-shadow:1px 1px 2px 1px #ccc;
} */

/*top3Link*/
/* .top3Link01{
	margin:90px auto 0;
	max-width: 1200px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.top3Link01 li{
	width: 31%;
	box-shadow:1px 1px 2px 1px #ccc;
} */
/**/
.top3Link02{
	margin:70px 30px 0;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.top3Link02 li{
	width: 31.5%;
	background: #fff;
	box-shadow:1px 1px 2px 1px #ccc;
	display: flex;
	justify-content: space-between;
	flex-wrap:nowrap;
	overflow: hidden;
}
.top3Link02 li a{
	display: table;
	width: 100%;
	height: 100%;
	cursor: pointer;
}
.top3Link02 li a .img{
	width: 45%;
	display: table-cell;
	-webkit-transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
}
.top3Link02 li:nth-child(1) a .img {
	background: url(../img/top/img_other01.jpg) no-repeat center center;
	background-size: cover;
}
.top3Link02 li:nth-child(2) a .img{
	background: url(../img/top/img_other02.jpg) no-repeat center center;
	background-size: cover;
}
.top3Link02 li:nth-child(3) a .img {
	background: url(../img/top/img_other03.jpg) no-repeat center center;
	background-size: cover;
}
.top3Link02 li a:hover .img{
    -webkit-transform: scale(1.1);
  transform: scale(1.1);
}
.top3Link02 li a .txt{
	width: 55%;
	margin-left: 40%;
	line-height: 1;
	padding: 58px 10px 72px 30px;
	display: table-cell;
	vertical-align: middle;
}
.top3Link02 li a .txt p{
	position: relative;
	display: inline-block;
	font-size: 118%;
	color: #000;
}
.top3Link02 li a .txt p span{
	display:block;
	color: #999;
	margin-bottom:8px;
	font-size: 54%;
}
.top3Link02 li a .txt p:after{
	content: "";
	width: 2em;
	height:3px;
	background-color: #000;
	position: absolute;
	left:0;
	bottom: -12px;
}

@media screen and (max-width:1024px){
	/* .top3Link01{
		margin:50px 20px 0;
		max-width:100%;
	} */
	.top3Link02{
		margin:40px 20px 0;
	}
	.top3Link02 li{
		width:48%;
		flex-wrap:wrap;
		margin-bottom: 20px;
	}
}
@media screen and (max-width:767px){
	/* .formLink li{
		width: 48%;
		margin-bottom: 15px;
	} */
	/* .top3Link01 li{
		width: 48%;
		margin-bottom: 15px;
	} */
	/* .top3Link01{
		margin: 50px 10px 0;
	} */
	.top3Link02{
		margin:30px 20px 0;
	}
	.top3Link02 li{
		width:100%;
		flex-wrap:wrap;
	}
	.top3Link02 li a .img{
		width:35%;
	}
	.top3Link02 li a .txt{
		width: 65%;
		padding: 22px 10px 36px 15px;
	}
	.top3Link02 li a .txt p{
		font-size: 108%;
	}
}
