/*---------------------------------
	margin start
---------------------------------*/
.margin--bottom0{
	margin-bottom: 0 !important;
}

.margin--bottomHalf{
	margin-bottom: 0.5rem !important;
}

.margin--bottom1{
	margin-bottom: 1rem !important;
}

.margin--bottom2{
	margin-bottom: 2rem !important;
}

.margin--bottom3{
	margin-bottom: 3rem !important;
}

.margin--bottom4{
	margin-bottom: 4rem !important;
}

.margin--bottom5{
	margin-bottom: 5rem !important;
}

.margin--bottom10{
	margin-bottom: 10rem !important;
}

@media(min-width: 1025px){
	.margin--pcBottom0{
		margin-bottom: 0 !important;
	}

	.margin--pcBottom1{
		margin-bottom: 1rem !important;
	}

	.margin--pcBottom2{
		margin-bottom: 2rem !important;
	}

	.margin--pcBottom3{
		margin-bottom: 3rem !important;
	}

	.margin--pcBottom4{
		margin-bottom: 4rem !important;
	}

	.margin--pcBottom5{
		margin-bottom: 5rem !important;
	}
}

@media(max-width: 1024px){
	.margin--tbBottom0{
		margin-bottom: 0 !important;
	}

	.margin--tbBottom1{
		margin-bottom: 1rem !important;
	}

	.margin--tbBottom2{
		margin-bottom: 2rem !important;
	}

	.margin--tbBottom3{
		margin-bottom: 3rem !important;
	}

	.margin--tbBottom4{
		margin-bottom: 4rem !important;
	}

	.margin--tbBottom5{
		margin-bottom: 5rem !important;
	}
}

@media(max-width: 600px){
	.margin--spBottom0{
		margin-bottom: 0 !important;
	}

	.margin--spBottom1{
		margin-bottom: 1rem !important;
	}

	.margin--spBottom2{
		margin-bottom: 2rem !important;
	}

	.margin--spBottom3{
		margin-bottom: 3rem !important;
	}

	.margin--spBottom4{
		margin-bottom: 4rem !important;
	}

	.margin--spBottom5{
		margin-bottom: 5rem !important;
	}
}

.margin--top0{
	margin-top: 0 !important;
}

.margin--top1{
	margin-top: 1rem !important;
}

.margin--top2{
	margin-top: 2rem !important;
}

.margin--top3{
	margin-top: 3rem !important;
}

.margin--top4{
	margin-top: 4rem !important;
}

.margin--top5{
	margin-top: 5rem !important;
}

@media(min-width: 1025px){
	.margin--pcTop0{
		margin-top: 0 !important;
	}

	.margin--pcTop1{
		margin-top: 1rem !important;
	}

	.margin--pcTop2{
		margin-top: 2rem !important;
	}

	.margin--pcTop3{
		margin-top: 3rem !important;
	}

	.margin--pcTop4{
		margin-top: 4rem !important;
	}

	.margin--pcTop5{
		margin-top: 5rem !important;
	}
}

@media(max-width: 1024px) and (min-width: 601px){
	.margin--tbTop0{
		margin-top: 0 !important;
	}

	.margin--tbTop1{
		margin-top: 1rem !important;
	}

	.margin--tbTop2{
		margin-top: 2rem !important;
	}

	.margin--tbTop3{
		margin-top: 3rem !important;
	}

	.margin--tbTop4{
		margin-top: 4rem !important;
	}

	.margin--tbTop5{
		margin-top: 5rem !important;
	}
}

@media(max-width: 600px){
	.margin--spTop0{
		margin-top: 0 !important;
	}

	.margin--spTop1{
		margin-top: 1rem !important;
	}

	.margin--spTop2{
		margin-top: 2rem !important;
	}

	.margin--spTop3{
		margin-top: 3rem !important;
	}

	.margin--spTop4{
		margin-top: 4rem !important;
	}

	.margin--spTop5{
		margin-top: 5rem !important;
	}
}

/*---------------------------------
	margin end
---------------------------------*/

/*---------------------------------
	responsive start
---------------------------------*/
@media(min-width: 1025px){
	.responsive--pcHidden{
		display: none;
	}
}

@media(max-width: 1024px) and (min-width: 601px){
	.responsive--tbHidden{
		display: none;
	}
}

@media(max-width: 600px){
	.responsive--spHidden{
		display: none;
	}
}

/*---------------------------------
	responsive end
---------------------------------*/

/*---------------------------------
	nColumsContents start
---------------------------------*/
.nColumsContents{
	--gapX: 2em;
	--gapY: 3em;
	--col: 2;
	list-style: none;
	display: flex;
	align-items: flex-start;
	justify-content: flex-start;
	flex-wrap: wrap;
	gap: var(--gapY) var(--gapX);
	padding: 0;
	margin: 0;
}

.nColumsContents_item{
	width: calc((100% - var(--gapX) * (var(--col) - 1) - 1px) / var(--col));
}

@media(min-width: 1025px){
	.nColumsContents--pcCol4{
		--col: 4;
	}
	
	.nColumsContents--pcCol3{
		--col: 3;
	}
	
	.nColumsContents--pcCol2{
		--col: 2;
	}
	
	.nColumsContents--pcCol1{
		--col: 1;
	}
}

@media(max-width: 1024px) and (min-width: 601px){
	.nColumsContents{
		--col: 2;
	}
	
	.nColumsContents--tbCol4{
		--col: 4;
	}
	
	.nColumsContents--tbCol3{
		--col: 3;
	}
	
	.nColumsContents--tbCol2{
		--col: 2;
	}
	
	.nColumsContents--tbCol1{
		--col: 1;
	}
}

@media(max-width: 600px){
	.nColumsContents{
		--col: 1;
	}
	
	.nColumsContents--spCol4{
		--col: 4;
	}
	
	.nColumsContents--spCol3{
		--col: 3;
	}
	
	.nColumsContents--spCol2{
		--col: 2;
	}
	
	.nColumsContents--spCol1{
		--col: 1;
	}
}

.nColumsContents_itemLink,
.nColumsContents_itemLink:hover{
	display: block;
	text-decoration: none;
	color: inherit;
}

/*---------------------------------
	nColumsContents end
---------------------------------*/

/*---------------------------------
	flow start
---------------------------------*/
.flowBlock{
	display: block;
	margin-inline: auto;
	max-width: 960px;
}

.flowBlockItem{
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	justify-content: space-between;
	margin: 0 auto 1.5em;
}

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

.flowBlockItem_left{
	width: 5em;
	position: relative;
	z-index: 2;
}

.flowBlockItem_no{
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background-color: var(--mainColor01_hex);
	width: 100%;
	height: 5em;
	padding-bottom: .25em;
}

.flowBlockItem_no--sub{
	color: #FFF;
	font-size: 112.5%;
	line-height: 1;
}

.flowBlockItem_no--main{
	color: #FFF;
	font-weight: var(--fontWeightBold);
	font-size: 175%;
	line-height: 1;
}

.flowBlockItem_arrow{
	display: block;
	width: 1.75em;
	margin: 0.5em auto 0;
}

.flowBlockItem_right{
	display: block;
	width: calc(100% - 5em - 1em);
	margin: 1em 0 0;
	padding: 1.25em 2em 1.5em 1em;
	position: relative;
	z-index: 1;
}

.flowBlockItem_right:before{
	content: "";
	display: block;
	width: calc(100% + 2em);
	height: 100%;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
	background-color:var(--subColor02_hex);
}

.flowBlockItem_text{
	display: block;
	width: 100%;
	margin: 0 auto;
	position: relative;
	z-index: 2;
}

.flowBlockItem_title{
	font-size: 112.5%;
	font-weight: bold;
	display: block;
	width: 100%;
	margin: 0 auto 0.5em;
}


@media(max-width: 750px){

	.flowBlock{
		width: 100%;
	}

	.flowBlockItem_left{
		width: 20%;
	}

	.flowBlockItem_no--sub{
		font-size: 100%;
	}

	.flowBlockItem_no--main{
		font-size: 150%;
	}

	.flowBlockItem_arrow{
		width: 1.75em;
		margin: 1em auto 0;
	}

	.flowBlockItem_right{
		width: 80%;
		padding: 1.25em 2em 1.5em 1.5em;
	}

	.flowBlockItem_right:before{
		width: calc(100% + 3.5em);
	}

}

/*---------------------------------
	flow end
---------------------------------*/
