@charset "utf-8";

#mainv{
	background: url(../img/about/mainv.jpg) no-repeat center center/cover;
	color: #fff;
	height: 410px;
}
#mainv h2{
	width: 410px;
	height: 410px;
	background-color: rgba(0,0,0,0.8);
	font-size: 50px;
	padding: 100px 0 0 50px;
	font-weight: 400;
	line-height: 1.5;
}
#mainv h2 span{
	font-size: 16px;
	display: block;
	line-height: 1.5;
	font-weight: 400;
	padding-top: 20px;
}
/*----------------------------------------------*/
#sec1{
	background: #f0f0f0;
	padding: 85px;
}
#sec1 h2{
	font-size: 53px;
	text-align: center;
	padding-bottom: 55px;
	font-weight: 500;
	letter-spacing: -2px;
	line-height: 1.5;
}
#sec1 p{
	font-size: 18px;
	letter-spacing: -1px;
}
.sec1_box{
	background: #fff;
	border: 5px solid #03295D;
	padding: 25px 70px;
}
.sec1_box h3{
	font-size: 24px;
	padding-bottom: 10px;
	font-weight: 500;
}
/*----------------------------------------------*/
#sec2{
	background: #fff;
	padding: 50px 0 120px;
	text-align: center;
}
#sec2 h2{
	font-size: 53px;
	font-weight: 500;
	line-height: 1.6;
}
#sec2 .flex{
	padding-top: 40px;
}
.div1 {
	width:360px;
	height: 360px;
	position: relative;
	cursor:pointer;    /* マウスカーソルを指先表示にする */
}
.sec2_01{
	background: url(../img/home/sec2_img01.jpg) no-repeat;
}
.sec2_02{
	background: url(../img/home/sec2_img02.jpg) no-repeat;
}
.sec2_03{
	background: url(../img/home/sec2_img03.jpg) no-repeat;
}

.div1 a{
	color: #fff;
	font-size: 25px;
	line-height: 1.3;
	background: url(../img/home/sec2_btn.png) no-repeat;
	display: block;
	width: 277px;
	height: 90px;
	position: absolute;
	z-index: 5;
	bottom: -45px;
	left: 35px;
	padding-top: 12px;
	letter-spacing: -1px;
}
.div1 a:hover{
	opacity: 1;
}
.div1:hover .div2 {
	opacity: 1;     /* div1 の div にマウスがくると div2 を表示 */
	cursor:default;    /* 親の div のマウスカーソルが指先表示になっているのでデフォルトに戻す */
}
.div2 {
	opacity: 0;     /* 最初は非表示にする。 */
	width:360px;
	height: 360px;
	background: url(../img/home/sec2_hover.png) no-repeat;
	padding-top: 60px;
	color: #fff;

	transition: all 300ms ease;
	-webkit-transition: all 300ms ease;
	-moz-transition: all 300ms ease;
}
.fs150{
	font-size: 150px;
	line-height: 1.0;
}
.fs37{
	font-size: 37px;
}
/*-------------------------------------------------*/
#sec3{
	background: #E3EAF4;
	padding-bottom: 50px;
}
#sec3 h2{
	background: url(../img/about/sec3_h2_bg.jpg) no-repeat center center/cover;
	color: #fff;
	text-align: center;
	font-size: 44px;
	font-weight: 400;
	padding: 85px 0 95px;
	letter-spacing: -2px;
}
#sec3 h2 span{
	border-bottom: 3px solid #fff;
}
#sec3 .w1100{
	padding: 65px 15px 45px;
}
#sec3 .lh20{
	letter-spacing: -1px;
}
#sec3 table{
	width: 100%;
	margin: 30px 0;
	font-size: 18px;
}
#sec3 th,#sec3 td{
	border-left: 1px solid #ededed;
	padding: 15px;
}
#sec3 th:first-child,#sec3 td:first-child{
	border-left: none;
}
#sec3 th{
	background: #03295D;
	color: #fff;
	width: 33.33%;
	text-align: center;
}
#sec3 td{
	background: #fff;
	border-bottom: 1px solid #FAF2E9;
}
#sec3 h3{
	text-align: center;
	color: #03295D;
	font-size: 24px;
	font-weight: 400;
	letter-spacing: 0;
}
#sec3 h3 span{
	font-size: 37px;
	font-weight: 500;
}
.sec3_box{
	background: url(../img/about/sec3_bg.png) no-repeat center center;
	position: relative;
	height: 615px;
}
.sec3_box p{
	background: #FFDD00;
	border-radius: 50%;
	font-size: 15px;
	text-align: center;
	letter-spacing: 0;
	position: absolute;
	letter-spacing: -0.03em;
}
.sec3_box p span{
	font-size: 18px;
	font-style: italic;
	font-weight: 600;
    margin: 0 5px 0 0;
}
.sec3_01{
	/*width: 290px;
	height: 290px;*/
	width: 310px;
	height: 310px;
	padding: 55px 25px;
	top: 40px;
	/*left: 320px;*/
	left: 300px;
}
.sec3_02{
	/*width: 282px;
	height: 282px;*/
	width: 302px;
	height: 302px;
	padding: 80px 25px;
	top: 140px;
	right: 145px;
}
.sec3_03{
	/*width: 253px;
	height: 253px;*/
	width: 273px;
	height: 273px;
	padding: 75px 20px;
	bottom: 0;
	/*left: 450px;*/
	left: 410px;
}
#sec4{
	background: #f1f1f1;
}
#sec4 h2{
	background: url(../img/about/sec4_h2_bg.jpg) no-repeat center center/cover;
	color: #fff;
	text-align: center;
	font-size: 44px;
	font-weight: 400;
	padding: 85px 0 95px;
	letter-spacing: -2px;
}
#sec4 h2 span{
	border-bottom: 3px solid #fff;
}
#sec4 .w1100{
	padding: 65px 0 65px;
}
#sec4 .lh20{
	letter-spacing: -1px;
}
#sec4 .tac{
	padding: 10px 0 15px;
}
/*-------------------------------------------------*/
#sec5{
	background: #fff;
	padding-bottom: 50px;
}
#sec5 h2{
	background: url(../img/about/sec5_h2_bg.jpg) no-repeat center center/cover;
	color: #fff;
	text-align: center;
	font-size: 44px;
	font-weight: 400;
	padding: 85px 0 95px;
	letter-spacing: -2px;
}
#sec5 h2 span{
	border-bottom: 3px solid #fff;
}
#sec5 .w1100{
	padding: 65px 0 45px;
}
#sec5 .lh20{
	letter-spacing: -1px;
}
#sec5 .flex > div{
	text-align: center;
}
.sec5_01{
	width: 267px;
}
.sec5_02{
	width: 335px;
}
.sec5_03{
	width: 300px;
}
#sec5 .flex h3{
	font-size: 24px;
	font-weight: 500;
	font-style: italic;
	letter-spacing: -0.03em;
	line-height: 1.7;
	padding: 10px 0 15px;
}
#sec5 .flex h3 span{
	font-size: 19px;
	letter-spacing: -0.1em;
}
.sec5_t01{
	font-size: 14px;
	padding-top: 15px;
	letter-spacing: -0.03em;
	line-height: 1.6;
	width: 260px;
	margin: 0 auto;
	color: #666;
}
#sec5 .btn01 a{
	margin-bottom: 30px;
}
@media screen and (max-width:1100px) {
.div1 {
	width:32%;
	height: 360px;
}
.div1 a{
	left: 5%;
}
.div2 {
	width:100%;
}
/*----------------------------------------------*/
.sec3_01{
	top: 40px;
	left: 220px;
}
.sec3_02{
	top: 140px;
	right: 145px;
}
.sec3_03{
	bottom: 35px;
	left: 300px;
}
/*--------------------------------------------*/
#sec4 .w1100{
	padding: 65px 15px 65px;
}
/*------------------------------------------*/
#sec5 .w1100{
	padding: 65px 15px 45px;
}
.sec5_01,.sec5_02,.sec5_03{
	width: 32%;
}
.sec5_t01{
	width: 90%;
}
/*----------------------------------------*/
#sec6 .w1100{
	width: 100%;
}

}

/*---------------------------------------------------------
	スマホ
---------------------------------------------------------*/
@media screen and (max-width: 680px) ,screen and (max-width: 737px) and (orientation: landscape) {
#mainv{
	height: 250px;
}
#mainv h2{
	width: 100%;
	height: auto;
	font-size: 25px;
	padding: 20px;
}
	#mainv h2 br{
		display: none;
	}
#mainv h2 span{
	font-size: 15px;
	padding-top: 10px;
}
/*----------------------------------------------*/
#sec1{
	padding: 40px 0;
}
#sec1 h2{
	font-size: 25px;
	text-align: left;
	padding-bottom: 25px;
	letter-spacing: -1px;
}
#sec1 p{
	font-size: 15px;
	letter-spacing: 0;
}
.sec1_box{
	border: 3px solid #03295D;
	padding: 20px;
}
.sec1_box h3{
	font-size: 18px;
}
/*----------------------------------------------*/
#sec2{
	padding: 30px 0 40px;
}
#sec2 h2{
	font-size: 25px;
	margin-bottom: 10px;
}
#sec2 .flex{
	padding-top: 25px;
}
.div1 {
	width:100%;
	height: auto;
}
.sec2_01,.sec2_02,.sec2_03{
	background:none;
}
.div1 a{
	font-size: 20px;
	display: block;
	position: static;
	padding-top: 16px;
	letter-spacing: 0;
	margin: 0 auto 15px;
}

.div1:hover .div2 {
	display:none; 
}
.div2 {
	display:none; 
}
/*-------------------------------------------------*/
#sec3{
	padding-bottom: 30px;
}
#sec3 h2{
	font-size: 25px;
	padding: 30px 0 40px;
	letter-spacing: -1px;
}
#sec3 h2 span{
	border-bottom: 2px solid #fff;
}
#sec3 .w1100{
	padding: 30px 4%;
}
#sec3 table{
	margin: 30px 0;
	font-size: 13px;
}
#sec3 th,#sec3 td{
	vertical-align: middle;
	padding: 12px;
}
#sec3 h3{
	font-size: 20px;
	margin-bottom: 30px;
}
#sec3 h3 span{
	font-size: 28px;
	display: block;
}
.sec3_box{
	background: none;
	height: auto;
}
.sec3_box p{
	font-size: 14px;
	position: static;
	letter-spacing: 0;
	margin: 0 auto 10px;
}
.sec3_box p span{
	font-size: 18px;
	font-style: italic;
	font-weight: 600;
    margin: 0 5px 0 0;
}
.sec3_01,.sec3_02,.sec3_03{
	width: 290px;
	height: 200px;
	padding: 30px 25px;
}
	.sec3_02{
		padding-top: 45px;
	}
		.sec3_03{
		padding-top: 55px;
	}
/*-----------------------------------------------*/
#sec4 h2{
	font-size: 25px;
	padding: 30px 0 40px;
	letter-spacing: -1px;
}
#sec4 h2 span{
	border-bottom: 2px solid #fff;
}
#sec4 .w1100{
	padding: 30px 4%;
}
#sec4 .tac{
	text-align: left;
}
/*-------------------------------------------------*/
#sec5{
	padding-bottom: 30px;
}
#sec5 h2{
	font-size: 25px;
	padding: 30px 0 40px;
	letter-spacing: -1px;
}
#sec5 h2 span{
	border-bottom: 2px solid #fff;
}
#sec5 .w1100{
	padding: 30px 4%;
}
.sec5_01,.sec5_02,.sec5_03{
	width: 100%;
}
.sec5_img{
	width: 200px;
	margin: auto;
	padding-right: 20px;
}
#sec5 .flex h3{
	font-size: 20px;
	letter-spacing: 0;
	line-height: 1.4;
	padding: 10px 0;
}
#sec5 .flex h3 span{
	font-size: 17px;
}
.sec5_t01{
	padding-top: 5px;
	margin: 0 auto 30px;
}
#sec5 .btn01 a{
	margin-bottom: 20px;
}

}
