@charset "UTF-8";

/*under_header*/
.under_header{
    background: url(../img/reform/mv.jpg) center / cover no-repeat;
}


/* reform_box01
***************************************************************/
.reform_four{
	flex-wrap: wrap;
	gap: 40px 4%;
}
.reform_four > div{
	width: 48%;	
    background: var(--lg01);
    color: var(--white);
    border-radius: 50px;
	display: flex;
	align-items: center;
	padding: clamp(25px, 3.2vw, 45px) clamp(25px, 3.2vw, 50px);
}
.reform_four--number{
	display: flex;
	flex-direction: column;
	align-items: center;
	font-weight: 700;

	.txt_small{
		font-size: clamp(18px, 2.2vw, 24px);
	}
	.txt_big{
		font-size: clamp(44px, 5.2vw, 60px);
	}
}
.reform_four--txt{
	display: flex;
	flex-direction: column;
	font-weight: 700;

	border-left: 4px solid var(--white);
	padding-left: 6%;
	margin-left: 6%;

	> span + span{
	 	margin-top: 10px;
	}

	.txt_small{
 		font-size: clamp(16px, 1.8vw, 18px);
 		line-height: 1.45;
		font-weight: 400;
	}
	.txt_middle1{
		font-size: clamp(30px, 3.5vw, 48px);
		white-space: nowrap;
	}
	.txt_middle2{
  		font-size: clamp(24px, 2.4vw, 36px);
	}
	.txt_big{
		font-size: clamp(44px, 5.2vw, 60px);
	}
}


/*--------------------PC--------------------*/
@media all and (min-width:768px) {}

/*--------------------SP--------------------*/
@media all and (max-width:767px) {
	.reform_four > div {
	    max-width: 395px;
	    width: 100%;
	    padding: clamp(25px, 3.2vw, 45px) clamp(25px, 6vw, 50px);
	    margin-left: auto;
	    margin-right: auto;
	}
	.reform_four > div + div{
		margin-top: 20px;
	}

}


/* reform_box02
***************************************************************/
.reform_box02 .block_ttl_sub{
	display: block;
	font-size: 50%;
}
.reform_box02 .flex_box{
	justify-content: space-between;
	flex-wrap: wrap;
	padding: clamp(40px, 5.2vw, 65px) 3.8%;
	font-weight: 700;
}
.reform_box02 .flex_box:not(:first-of-type){
	margin-top: 40px;
}

.reform_box02--num{
	width: 100%;
}
.case_num{
	font-size: 16px;
}
.reform_box02--ttl{
	font-size: clamp(18px, 2.2vw, 24px);
	line-height: 1.45;
	margin-top: 0.2em;
}
.reform_box02--txt1{
	font-size: clamp(14px, 1.9vw, 16px);
	line-height: 1.5;
	font-weight: 400;
	margin-top: 0.7em;
}
.blue_arrow{
	display: block;
	width: 4.5%;
	margin-top: 26%;
}

.reform_box02--img {
	position: relative;
}
.period{
	width: clamp(100px, 10.6vw, 120px);
    height: clamp(100px, 10.6vw, 120px);
    border-radius: 50%;
    background: var(--lg01);
    font-size: 16px;
    font-weight: 400;
    line-height: 1.2;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--white);
    position: absolute;
    top: -15%;
    right: 0;
}
.period span{
  	font-size: clamp(28px, 3.1vw, 32px);
	font-weight: 700;
	display: contents;
}

/*--------------------PC--------------------*/
@media all and (min-width:768px) {
	.reform_box02--sub{
		width: 33.5%;
		display: flex;
		flex-direction: column;
	}
	.before--img{
		margin-top: auto;
	}
	.after--img{
		width: 58.4%;
	}

	
	
	.reform_box02--txt2{
	  	font-size: clamp(28px, 3.6vw, 36px);
		position: absolute;
		top: -1.2em;
		left: 0;
	}

}

/*--------------------SP--------------------*/
@media all and (max-width:767px) {
	.reform_box02 .flex_box{
		padding: 35px 6% 40px;
	}
	.before--img{
		width: 70%;
		margin-top: 30px;
	}
	.reform_box02--txt2{
		font-size: 28px;
		margin-bottom: 0.5em;
	}

	.blue_arrow{
	    width: 9%;
	    max-width: 28px;
	    transform: rotate(90deg);
	    margin: 10px 0 0 32%;
	}
	.period {
	    width: clamp(90px, 15.5vw, 120px);
	    height: clamp(90px, 15.5vw, 120px);
	  	font-size: clamp(14px, 3.7vw, 16px);
	    top: 0;
	}


}

/* reform_box03
***************************************************************/
.reform_box03 > .block_txt{
	text-align: center;
}

.reform_box03--ttl {
    width: 100%;
    height: 36px;
    font-size: 16px;
    font-weight: 700;
    color: var(--white);
    text-align: center;
    background-color: var(--blue);
    display: flex;
    align-items: center;
    justify-content: center;
	margin-top: 40px;
}

.reform_box03--sub{
	margin-top: 40px;

	> div{
		justify-content: space-between;
		position: relative;
	}
	> div + div{
		margin-top: 60px;
	}

	.box03_sub--arrow{
		width: 18px;
		position: absolute;
		bottom: 0;
		left: 4%;
	}

}

.box03_sub--txt1{
	width: 11.5%;
  	font-size: clamp(28px, 3.6vw, 36px);
	font-weight: 700;
}
.box03_sub--txt2{
	width: 53.8%;
	dt{
		font-size: clamp(18px, 2.2vw, 24px);
		font-weight: 700;
	}
	dd{
		border-top: 2px solid var(--blue);
		margin-top: 1em;
		padding-top: 1em;
	}
}
.box03_sub--img{
	width: 25%;
}



/*--------------------PC--------------------*/
@media all and (min-width:768px) {}

/*--------------------SP--------------------*/
@media all and (max-width:767px) {
	.reform_box03--sub{
		margin-top: 20px;

		> div + div{
			margin-top: 30px;
		}

	}
	.box03_sub--txt1{
		width: 100%;
	}
	.box03_sub--txt2,
	.box03_sub--img{
		width: 100%;
		margin-top: 20px;
	}
}


/* aaa
***************************************************************/

/*--------------------PC--------------------*/
@media all and (min-width:768px) {}

/*--------------------SP--------------------*/
@media all and (max-width:767px) {}