@charset "utf-8";



.col_w{
	color: #fff;
}

.bg-w{
	background-color: #fff;
}

.nav-other{
	position: fixed;
	right: 2rem;
	bottom: 2rem;
	z-index: 100;
}


/* ---------------------------------------
* common
------------------------------------------ */

main{
	position: relative;
}

.btn.sp{
	display: none;
}

.col-w{
	color: #fff;
}

.access a{
	display: block;
	text-decoration: underline;
}

.mainTop{
	overflow: hidden;
}

.btn-404{
	margin: 0 auto;
}

.slideImg{
	display: inline-block;
	margin-right: 2.5vw;
}

.nav-other02{
	padding-left: 30px;
}

.nav-other02 li a{
	display: block;
	font-size: 12px;
	line-height: 100%;
	letter-spacing: normal;
	transition: all .3s;
	font-weight: 600;
}

.nav-other02 li a:hover{
	color: #005FFF;
}

.nav-other02 li.active a{
	color: #005FFF;

}

.nav-other02 li:not(:last-of-type){
	padding-right: 5px;
	margin-right: 5px;
	position: relative;
}

.nav-other02 li:not(:last-of-type)::after{
	content: "/";
	display: block;
	position: absolute;
	right: -2px;
	top: 50%;
	transform: translateY(-50%);
	color: #000000;
	font-size: 12px;
	font-weight: 600;
	line-height: 100%;
	letter-spacing: normal;
}

svg{
	width: 100%;
	height: 100%;
}

.bg{
	background-repeat: no-repeat;
	background-size: cover;
}

:root {
	--primary: #0200F5;
	--bg01: #F7F7F7;
	--bg02: #0D0D0D;
}

.footer_small p{
	font-size: 14px;
	line-height: 160%;
	letter-spacing: normal;
	color: #999999;
}

/* --------------------------------
* Top ページ
----------------------------------- */

.video{
	width: 100%;
	padding-top: 60%;
	position: relative;
}

.video video{
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}

.sec01{
	position: relative;
}

.sec01bg{
	position: absolute;
	left: 0;
	bottom: 0;
	z-index: -1;
}

.sec01-l{
	width: 50%;
}

.sec01-l .ttl1_main{
	padding-top: 40px;
}

.sec01-r{
	padding-top: 60px;
	width: 43.75%;
}

.sec01Txt{
	padding-left: 60px;
}

.sec01Txt p{
	line-height: 240%;
	font-weight: 600;
}

.sec01Txt p:not(:last-of-type){
	padding-bottom: 30px;
}

.sec02{
	background-color: var(--bg02);
}

.sec02TtlWrap>p{
	padding-top: 20px;
	font-weight: 600;
	line-height: 160%;
	letter-spacing: normal;
	font-size: 24px;
}

.sec02-listItem{
	width: 660px!important;
	background-color: #fff;
	border: solid 4px #fff;
	border-radius: 40px 40px 40px 10px;
}

.sec02-listTxt,.sec02-listImg{
	width: 50%;
}

.sec02-listTxt{
	padding: 0 20px;
}

.sec02-listTxt h3{
	padding-top: 28px;
	position: relative;
}

.sec02-listTxt h3::before{
	content: "";
	display: block;
	width: 24px;
	height: 8px;
	background-color: var(--primary);
	position: absolute;
	left: 0;
	top: 0;
}

.sec02-listTxt h3 p:not(:last-of-type){
	margin-bottom: 10px;
}

.sec02-listTxt h3 span{
	display: inline-block;
	background-color: var(--bg02);
	color: #fff;
	font-weight: 600;
	padding: 2px 10px;
	font-size: 18px;
	line-height: 160%;
	letter-spacing: normal;
}

.sec02-listTxt>p{
	padding-top: 30px;
	font-size: 14px;
	letter-spacing: normal;
	color: #707070;
	font-weight: 600;
}

.sec02-listImg img{
	border-radius: 0 40px 40px 0;
}

.sec03-list,.sec04-list{
	column-gap: 30px;
}

.sec03-listItem,.sec04-listItem{
	width: calc((100% - (30px * 2)) / 3);
}

.sec03-listTxt{
	padding-top: 20px;
}

.sec03-listTtl p,.sec04-listTtl p{
	display: inline-block;
	background-color: var(--bg02);
	border: solid 1px #fff;
	color: #fff;
	font-weight: 700;
	padding: 4px 10px;
	margin-bottom: 10px;
	line-height: 160%;
	letter-spacing: normal;
	font-size: 12px;
}

.sec03-listTtl h4{
	font-size: 24px;
	letter-spacing: normal;
	line-height: 160%;
	font-weight: 600;
}

.sec03-listTxt>p{
	padding-top: 20px;
	letter-spacing: normal;
}

.aboutBanner{
	position: relative;
	overflow: hidden;
	background-color: var(--primary);
}

.aboutBannerBg{
	position: absolute;
	left: 0;
	bottom: 0;
}

.aboutBanner .inner{
	position: relative;
	z-index: 2;
}

.bannerTtl p{
	font-weight: 600;
	font-size: 24px;
	line-height: 160%;
	letter-spacing: normal;
	padding-bottom: 10px;
}

.bannerImg{
	padding-top: 130px;
	width: 58.3%;
	margin: 0 auto;
}

.sec04-listItem{
	background-color: #fff;
	border-radius: 40px 40px 40px 10px;
}

.sec04-listImg img{
	border-radius: 40px 40px 0 0 ;
}

.sec04-listTxt{
	padding: 20px 20px 30px;
}

.sec04-listTtl h4{
	font-size: 18px;
	line-height: 160%;
	letter-spacing: normal;
	font-weight: 600;
}

.sec04-listTxt>p{
	letter-spacing: normal;
	padding-top: 20px;
}

.sec05{
	overflow: hidden;
	background-color: #fff;
}

.sec05Tag-list{
	column-gap: 18px;
}

.sec05Tag-listItem{
	width: calc((100% - ( 18px * 3)) / 4);
	background-color: var(--primary);
	color: #fff;
	padding: 14px 0;
	border-radius: 20px 20px 20px 5px;
	font-size: 18px;
	line-height: 160%;
	letter-spacing: normal;
	font-weight: 600;
	border: solid 1px #707070;
}

.loop{
	width: calc(1560px * 3);
}

.loopImg{
	width: 1520px;
}

.sec050ther{
	background-color: var(--bg01);
	border: solid 1px #CFCFCF;
	padding: 40px 0;
	border-radius: 10px;
}

.sec050ther h4{
	font-size: 24px;
	line-height: 160%;
	letter-spacing: normal;
	font-weight: 600;
}

.sec050ther p{
	padding: 10px 0;
}

.sec050ther-list{
	justify-content: center;
	column-gap: 20px;
}

.sec050ther-listItem{
	padding-left: 34px;
	position: relative;
	line-height: 160%;
	letter-spacing: normal;
	font-weight: 600;
	color: var(--primary);
}

.sec050ther-listItem::before{
	content: "";
	display: block;
	width: 24px;
	height: 24px;
	background-image: url(../img/top/check.svg);
	position: absolute;
	left: 0;
	top: 0;
}

.sec06{
	background-color: var(--bg02);
}

.faq-defList{
	padding-bottom: 40px;
	margin-bottom: 40px;
	border-bottom: solid 1px #E9E8E4;
}

.faq-defList:last-of-type{
	margin-bottom: 0;
}

.faq-defTtl{
	font-size: 20px;
	line-height: 160%;
	letter-spacing: normal;
	padding-bottom: 20px;
}

.faq--defDesc a{
	text-decoration: underline;
}

@media screen and (max-width:768px) {

	/* ---------------------------------------
	* common
	------------------------------------------ */

	.btn.sp{
		display: flex;
	}

	.btn.pc{
		display: none;
	}

	.btn{
		margin: 0 auto;
	}

	.nav-other02{
		padding-right: 10px;
	}

	.nav-other02 li a{
		display: block;
		font-size: 12px;
	}


	.footer_small p{
		font-size: 12px;
		padding-top: 4px;
	}

	/* --------------------------------
	* Top ページ
	----------------------------------- */

	.video{
		width: 100%;
		padding-top: 80%;
		position: relative;
	}

	.sec01{
		padding-bottom: 30px;
	}

	.sec01bg{
		position: absolute;
		left: 0;
		bottom: 0;
		z-index: -1;
	}

	.sec01-l{
		width: 100%;
	}

	.sec01-l .ttl1_main{
		padding-top: 20px;
		font-size: 28px;
	}

	.sec01-r{
		padding-top: 30px;
		width: 100%;
	}

	.sec01Txt{
		padding-left: 0;
	}

	.sec01Txt p{
		line-height: 200%;
	}

	.sec01Txt p:not(:last-of-type){
		padding-bottom: 20px;
	}

	.sec01Img{
		padding-top: 60px;
	}


	.sec02TtlWrap>p{
		padding-top: 20px;
		font-size: 16px;
	}

	.sec02-listItem{
		display: flex;
		flex-direction: column-reverse;
		width: 90%!important;
		border-radius: 40px 40px 40px 10px;
	}

	.sec02-listTxt,.sec02-listImg{
		width: 100%;
	}

	.sec02-listTxt{
		padding: 20px 20px 30px;
	}

	.sec02-listTxt h3{
		padding-top: 24px;
	}

	.sec02-listTxt h3::before{
		width: 20px;
		height: 6px;
	}

	.sec02-listTxt h3 p:not(:last-of-type){
		margin-bottom: 4px;
	}

	.sec02-listTxt h3 span{
		padding: 2px 10px;
		font-size: 18px;
	}

	.sec02-listTxt>p{
		padding-top: 20px;
	}

	.sec02-listImg img{
		border-radius: 40px 40px 0 0;
	}

	.sec03-listItem,.sec04-listItem{
		width: 100%;
	}

	.sec03-listItem:not(:last-of-type),.sec04-listItem:not(:last-of-type){
		margin-bottom: 40px;
	}

	.sec03-listTxt{
		padding-top: 20px;
	}

	.sec03-listTtl h4{
		font-size: 20px;
	}

	.aboutBanner{
		overflow: hidden;
	}

	.aboutBannerBg {
		position: absolute;
		left: -20%;
		bottom: 0;
		width: 150%;
	}

	.bannerTtl p{
		font-size: 16px;
		padding-bottom: 4px;
	}

	.bannerImg{
		padding-top: 80px;
		width: 70%;
	}

	.sec05Txt .ttl2_main{
		font-size: 18px;
		text-align: center;
	}

	.sec05Tag-list{
		column-gap: 10px;
		row-gap: 10px;
		flex-wrap: wrap;
	}

	.sec05Tag-listItem{
		width: calc((100% - ( 10px * 1)) / 2);
		padding: 12px 0;
		font-size: 14px;
	}

	.loop{
		width: calc(1040px * 3);
	}

	.loopImg{
		width: 1020px;
	}

	.sec050ther{
		padding: 40px 20px;
	}

	.sec050ther h4{
		font-size: 20px;
	}

	.faq-defList{
		padding-bottom: 30px;
		margin-bottom: 30px;
	}

	.faq-defTtl{
		font-size: 18px;
		padding-bottom: 14px;
	}


}

.cvArea{
	background-color: #fff;
	position: relative;
}

.cvBg{
	position: absolute;
	left: 0;
	bottom: 0;
}

.cvArea .inner{
	position: relative;
	z-index: 2;
}

.cv-list{
	column-gap: 30px;
}

.cv-listItem{
	width: calc((100% - (30px * 1)) / 2);
}

.cv-listItem a{
	display: block;
	padding: 40px;
	border-radius: 20px 20px 20px 5px;
	color: #fff;
	background-color: var(--bg02);
}

.cv-listItem02 a{
	background-color: var(--primary);
}

.cv-listTtl{
	padding-bottom: 20px;
	margin-bottom: 20px;
	border-bottom: solid 1px rgba(255,255,255,.1);
}

.cv-listTtl p{
	line-height: 100%;
	letter-spacing: normal;
	font-weight: 700;
	padding-bottom: 10px;
}

.cv-listTtl h3{
	font-size: 20px;
	line-height: 160%;
	letter-spacing: normal;
	font-weight: 600;
}

.cvBtn{
	justify-content: flex-end;
}

.cvBtn p{
	line-height: 100%;
	font-weight: 600;
	padding: 7px 0;
	position: relative;
}

.cvBtn p::after{
	content: "";
	width: 100%;
	height: 1px;
	background-color: #fff;
	position: absolute;
	left: 0;
	bottom: 0;
	opacity: 0;
	transition: all .3s;
}

.cv-listItem a:hover .cvBtn p::after{
	opacity: 1;
}

.cvArrow{

	width: 30px;
	height: 30px;
	margin-left: 20px;
}

@media screen and (max-width:768px) {

	.cvBg{
		display: none;
	}

	.cv-listItem{
		width: 100%;
	}

	.cv-listItem:not(:last-of-type){
		margin-bottom: 20px;
	}

	.cv-listItem a{
		padding: 40px 40px 30px;
	}


	.cv-listTtl h3{
		font-size: 20px;
		line-height: 160%;
		letter-spacing: normal;
		font-weight: 600;
	}


}

.middlecv{
	padding: 40px 20px;
	background-color: var(--primary);
	border-radius: 20px;
	margin-bottom: 40px;
}

.middlecv p{
	font-weight:600;
	font-size: 20px;
	line-height: 160%;
}

@media screen and (max-width:768px) {
	.middlecv{
		padding: 30px 20px;
	}

	.middlecv p{
		font-size: 18px;
	}

}
