@charset "UTF-8";
/* ------------------------------------------------------------- */
/* StyleSection _ fv1  CSS                                       */
/* ------------------------------------------------------------- */
.fv1{
	position: relative;
	height: 800px;
	background: url("../img/fv_pc.webp") center no-repeat;
	background-size: cover;
	overflow: hidden;
}

.fv1 .txt1 {
	position: absolute;
	top: 10%;
	left: 50%;
	margin-left: -400px;
}

.fv1 img.txt2 {
  position: absolute;
  top: 65%;
  left: 3%;
}


/* ======== PC Setting ======== */
@media screen and (min-width: 1051px) {
	.fv_txt2{
		left: 50%;
		margin-left: -570px;
		/* 画像位置調整 PC */
		margin-top: 80px;
	}
}

/* ======== SMP Setting ======== */
@media screen and (max-width: 1050px) {
	.fv1{
		height: 168vw;
		background: url("../img/fv_sp.webp") center no-repeat;
	}
	.fv1 .txt1{
		margin-left: 0;
		top: 1%;
		left: 2%;
		width: 89.4vw;
	}
	
	.fv1 img.txt2 {
		position: absolute;
		top: 70%;
		left: 3%;
		width: 69.4vw;
	}

}



/* ------------------------------------------------------------- */
/* StyleSection _ fv2  CSS                                        */
/* ------------------------------------------------------------- */
.fv2{
	margin-top: 0;
	padding-bottom: 30px;
}
.fv2 .wrap{
/*
	padding: 0 0 40px;
*/
}
.fv2:before{
	top: 0;
	width: 100%;
	background-color: #fff;
	background-image:  url("../img/fv_2_bk_pc.webp");
	opacity: 0.3;

  background-repeat: no-repeat;
  background-size: cover;
}
.fv2 .ttl{
	letter-spacing: 0.03em;
	text-align: left;
	white-space: nowrap;
}
.fv_txt2{
	position: absolute;
	top: 830px;
}
.fv2blk{
	padding-top: 58px;
}
.fv2blk .ttl{
	margin-bottom: 40px;
}
.fv2li{
	display: inline-block;

}
.fv2li li{
	display: flex;
	line-height: 1;
	align-items: center;
	font-size: 2.1rem;
	padding-bottom: 13px;
}
.fv2li li p{
	position: relative;
}
.fv2li li p:before{
	content: "";
	display: block;
	position: absolute;
	width: calc(100% + 28px);
	height: 2px;
	bottom: -13px;
	left: -28px;
	background: #2a2a2a;

}
.fv2li li+li{
	margin-top: 28px;
}
.fv2li .ico_check_sq{
	width: 21px;
	margin-right: 9px;
}

.fv2_lead{
	margin-left: 400px;
	letter-spacing: 0.1em;
}
.fv2_lead .txt1{
	font-size: 2rem;
	line-height: 1;
	margin-bottom: 0.2em;
}
.fv2_lead .txt2{
	font-size: 3rem;
	line-height: 1.8;
}





/* ======== PC Setting ======== */
@media screen and (min-width: 1051px) {
	.fv2 .wrap{
		width: 850px;
	}
	
	/* 飛び出てくる人物画像 */
	.fv2_img{
		position: absolute;
		right: -5.5vw;
		top: 208px;
		width: 330px;
	}
	.fv2li li p{
		letter-spacing: 0.08em;
	}
}


/* ======== SMP Setting ======== */
@media screen and (max-width: 1050px) {
	.fv2{
		margin-top: 0;
	}
	.fv2 .wrap{
		padding: 0 0 14vw;
	}
	.fv2:before{
		top: 0;
		width: 100%;
		background-image:  url("../img/fv_2_bk_sp.webp");
		opacity: 0.3;
	  background-repeat: no-repeat;
	  background-size: cover;
	}
	.fv2 .ttl{
		line-height: 1.25;
	}
	.fv_txt2{
		top: -50vw;
		left: -5.8vw;
		width: 994.9vw;
	}
	.fv2blk{
		padding-top: 4.8vw;
	}
	.fv2blk .ttl{
		margin-bottom: 4.8vw;
	}
	.fv2li{
	}
	.fv2li li{
		font-size: 3.2vw;
		padding-bottom: 1.7vw;
	}
	.fv2li li p{
		font-size: 1.3em;
		letter-spacing: 0.01em;
	}
	.fv2li li p:before{
		width: calc(100% + 3.7vw);
		height: 1px;
		bottom: -1.7vw;
		left: -3.7vw;
	}
	.fv2li li+li{
		margin-top: 3.4vw;
	}
	.fv2li .ico_check_sq{
		width: 2.5vw;
		margin-right: 1.2vw;
	}
	
	/* SP 飛び出す画像設定 */
	.fv2_img{
		position: absolute;
		right: -5.5vw;
		top: 254px;
		width: 250px;
	}
	
	.fv2_lead{
		letter-spacing: 0.05em;
	}
	.fv2_lead .txt1{
		font-size: 3.4vw;
		margin-bottom: 0.5em;
	}
	.fv2_lead .txt2{
		font-size: 5vw;
		white-space: nowrap;
	}
	
}






/* ------------------------------------------------------------- */
/* StyleSection _ sec2  CSS                                      */
/* ------------------------------------------------------------- */
.sec2{
	padding: 80px 0 120px;
	background: url(../../top/img/sec2_bg_pc.webp) top center no-repeat;
	background-size: cover;
}
.sec2 .ttl{
	text-align: left;
	margin-bottom: 38px;
	letter-spacing: 0.05em;
}
.sec2li{
	margin-bottom: 24px;
	width: 610px;
}
.sec2li li{
	height: 58px;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	padding: 0 18px;
	background: rgba(42,42,42,0.8);
	font-size: 2.1rem;
	font-weight: 700;
	letter-spacing: 0.07em;
}
.sec2li li+li{margin-top: 11px;}

/* TOP Page で使用 */
.sec2li.icon p {
	margin-left: 10px;
}

/* 下記は未使用 */
.sec2li .ico{
	width: 40px;
	height: 1px;
	position: relative;
}
.sec2li .ico:before, .sec2li .ico:after{
	content: "";
	display: block;
	position: absolute;
	width: 30px;
	height: 3px;
	background: #fff;
	left: 0;
	top: -1px;
	transform-origin: center;
}
.sec2li .ico:before{
	transform: rotate(45deg);
}
.sec2li .ico:after{
	transform: rotate(-45deg);
}
/* ここまで 未使用 */


.sec2_lead{
	font-weight: 700;
	letter-spacing: 0.1em;
}
.sec2_lead .txt1{
	font-size: 2rem;
	line-height: 1;
	margin-bottom: 0.2em;
}
.sec2_lead .txt2{
	font-size: 3rem;
	line-height: 1.8;
}


@media screen and (min-width: 1051px) {
	.sec2 .wrap{
		width: 790px;
	}

}

@media screen and (max-width: 1050px) {
	.sec2{
		padding: 12vw 0 17.3vw;
		background: url(../../top/img/sec2_bg_sp.webp) top center no-repeat;
		background-size: cover;
	}
	
	.sec2 .icon img{
		width: 24px;
		margin-top: 2px;
	}

	.sec2 .ttl{
		margin-bottom: 2.6vw;
		line-height: 1.25;
	}
	.sec2li{
		margin-bottom: 5.3vw;
		width: 85.6vw;
	}

	.sec2li li{
		height: 8.8vw;
		padding: 0 2.4vw;
		font-size: 3.2vw;
		letter-spacing: 0.05em;
	}
	.sec2li li+li{margin-top: 1.3vw;}
	
	.sec2li .ico{
		width: 6.6vw;
		margin-top: 2px;
	}

	.sec2li .ico:before, .sec2li .ico:after{
		width: 4.6vw;
		height: 2px;
	}
	.sec2_lead{
		letter-spacing: 0.05em;
	}
	.sec2_lead .txt1{
		font-size: 3.4vw;
		margin-bottom: 0.5em;
	}
	.sec2_lead .txt2{
		font-size: 5vw;
		white-space: nowrap;
	}

}



