@charset "utf-8";

/**
 *
 *  ページ用CSS
 *　flow
 * 
 */

/*--------------------------------------------------------------------------
   Overwright
---------------------------------------------------------------------------*/
.page-ttl{
  background-image: url(../img/flow/img_kv_pc.jpg);
	background-position: center top;   
}


/*--------------------------------------------------------------------------
   Content
---------------------------------------------------------------------------*/
.flow-main._top-cont::before{
	height: calc(100% - 100px);
}


/* flow
-----------------------------------------------------------------*/
.flow-main{
	padding-bottom: 150px;
}
.flow-nav._upper{
	margin-bottom: 80px;
}
.flow-nav._bottom{
	margin-top: 100px;
}
.flow-nav ul{
	display: flex;
	justify-content: space-between;
}
.flow-nav ul li{
	position: relative;
	width: calc((100% - 299px)/14);
	min-height: 300px;
	border-radius: 5px;
	border: 1px solid var(--navy);
	background: var(--light);
}
.flow-nav ul li:nth-child(n+2)::before{
	position: absolute;
	left: -21px;
	top: 50%;
	transform: translateY(-50%);
	display: inline-block;
	content: "→";
	color: var(--blue);
}
.flow-nav ul a{
	position: relative;
	display: block;
	height: 100%;
	border-radius: 5px;
	overflow: hidden;
	transition: .3s;
}
.flow-nav ul a:hover{
	background-color: var(--blue);
}
.flow-nav ul a::after{
	position: absolute;
	left: 0;
	display: block;
	width: 100%;
	height: 23px;
	content: "";
	background: url(../img/flow/arw_list.svg) no-repeat center center var(--blue);
}
.flow-nav ul a:hover::after{
	background-image: url(../img/flow/arw_list_ov.svg);
}
.flow-nav._upper ul a{
	padding: 15px 10px 35px;
}
.flow-nav._upper ul a::after{
	bottom: 0;
}
.flow-nav._bottom ul a{
	padding: 35px 10px 15px;
}
.flow-nav._bottom ul a::after{
	top: 0;
	transform: rotate(180deg);
}
.flow-nav ul .step{
	margin-bottom: 15px;
	color: var(--blue);
	font-weight: 500;
	font-size: 2.4rem;
	line-height: 1;
	text-align: center;
	font-family: "EB Garamond", serif;
}
.flow-nav ul a:hover .step,
.flow-nav ul a:hover .ttl{
	color: var(--light);
}
.flow-nav ul .step small{
	display: block;
	margin-bottom: 3px;
	font-size: 1.4rem;
}
.flow-nav ul .ttl{
	display: flex;
	width: 100%;
	writing-mode: vertical-rl;
	align-items: center;
	font-size: 1.8rem;
}
.flow-list > div{
	position: relative;
	display: flex;
	align-items: flex-start;
	padding-bottom: 80px;
}
.flow-list > div:last-child{
	padding-bottom: 0;
}
.flow-list > div::before{
	position: absolute;
	left: 75px;
	top: 0;
	display: block;
	width: 2px;
	height: 100%;
	content: "";
	background: var(--navy);
	opacity: .2;
}
.flow-list > div:last-child::before{
	display: none;
}
.flow-list dt{
	position: relative;
	flex-shrink: 0;
	width: 150px;
	margin-right: 60px;
}
.flow-list dd .layout-box .txt-area{
	max-width: 660px;
	width: 61.92%;
}
.flow-list dd .layout-box .pic{
	max-width: 350px;
	width: 32.84%;
}
.flow-list dd h3{
	margin-bottom: 10px;
	color: var(--navy);
	font-size: 3.2rem;
	line-height: 1.6;
}
.flow-list dd .support{
	margin-top: 40px;
	padding: 30px 4%;
	border-radius: 10px;
	background: #FFF1CA;
}
.flow-list dd .support h4{
	display: flex;
}
.flow-list dd .support h4 .ico{
	margin-right: 5px;
}
.flow-list dd .support h4 .ttl{
	margin-bottom: 10px;
	font-size: 2.2rem;
	line-height: 1.4;
	color: #DF8A00;
}























/*--------------------------------------------------------------------------
   mobile
---------------------------------------------------------------------------*/
@media screen and (max-width: 768px) {


	.flow-main._top-cont::before{
		height: calc(100% - 140px);
	}
	

/* flow
-----------------------------------------------------------------*/
	.flow-main{
		padding-bottom: 60px;
	}
	.flow-nav._upper{
		margin-bottom: 40px;
	}
	.flow-nav._bottom{
		margin-top: 50px;
	}
	.flow-nav ul{
		display: block;
	}
	.flow-nav ul li{
		width: 100%;
		min-height: initial;
	}
	.flow-nav ul li:nth-child(n+2){
		margin-top: 18px;
	}
	.flow-nav ul li:nth-child(n+2)::before{
		left: 50%;
		top: -16px;
		transform: translateX(-50%);
		content: "↓";
		font-size: 1.1rem;
		line-height: 1;
	}
	.flow-nav ul a{
		display: flex;
		align-items: center;
	}
	.flow-nav ul a:hover{
		background-color: var(--light);
	}
	.flow-nav ul a::after{
		position: absolute;
		left: auto;
		right: 0;
		top: 0;
		width: 20px;
		height: 100%;
		content: "";
		background: url(../img/flow/arw_list_vertical.svg) no-repeat center center var(--blue);
	}
	.flow-nav ul a:hover::after{
		background-image: url(../img/flow/arw_list_vertical.svg);
	}
	.flow-nav._upper ul a{
		padding: 5px 25px 5px 10px;
	}
	.flow-nav._upper ul a::after{
		bottom: auto;
		top: 0;
	}
	.flow-nav._bottom ul a{
		padding: 5px 25px 5px 10px;
	}
	.flow-nav._bottom ul a::after{
		transform: rotate(180deg);
	}
	.flow-nav ul .step{
		margin: 0 10px 0 0;
		font-size: 1.8rem;
	}
	.flow-nav ul a:hover .step{
		color: var(--blue);
	}
	.flow-nav ul a:hover .ttl{
		color: var(--dark);
	}
	.flow-nav ul .step small{
		margin-bottom: 2px;
		font-size: 1.1rem;
	}
	.flow-nav ul .ttl{
		display: block;
		width: auto;
		writing-mode: horizontal-tb;
		font-size: 1.5rem;
	}
	.flow-list > div{
		padding-bottom: 40px;
	}
	.flow-list > div::before{
		left: 35px;
	}
	.flow-list > div:last-child::before{
		display: none;
	}
	.flow-list dt{
		position: relative;
		flex-shrink: 0;
		width: 70px;
		margin-right: 15px;
	}
	.flow-list dd .layout-box{
		display: block;
	}
	.flow-list dd .layout-box .txt-area{
		max-width: none;
		width: 100%;
	}
	.flow-list dd .layout-box .pic{
		max-width: none;
		width: 100%;
		margin-top: 15px;
	}
	.flow-list dd h3{
		margin-bottom: 5px;
		font-size: 1.8rem;
	}
	.flow-list dd .txt{
		font-size: 1.3rem;
		text-align: justify;
	}
	.flow-list dd .support{
		margin-top: 20px;
		padding: 15px;
	}
	.flow-list dd .support h4{
		align-items: center;
	}
	.flow-list dd .support h4 .ico{
		flex-shrink: 0;
		widtth: 18px;
		transform: translateY(-2px);
		margin-right: 5px;
	}
	.flow-list dd .support h4 .ttl{
		margin-bottom: 5px;
		font-size: 1.6rem;
	}
	.flow-list dd .support .txt{
		font-size: 1.2rem;
	}



}