:root {
	--bg-color: #F7F7F7;
	--bg-green: #005945;
	--txt-green: #1C4937;
}

body{
	background-color: #fff !important;
	
}

.font-ryumin{
	font-family: "a-otf-ryumin-pr6n", serif;
	font-weight: 300;
	font-style: normal;
}

/* layout */
.page__wrapper{
	width: 100%;
	max-width: 1070px;
	padding: 0 20px;
	margin: 40px auto 0;
}

.page__wrapper__820{
	width: 100%;
	max-width: 860px;
	padding: 0 20px;
	margin: auto;	
}
@media screen and (max-width: 430px){
	.page__wrapper__820{
		padding: 0;
	}
}
.page__lead{
	font-size: 16px;
	line-height: 1.5;
	margin-bottom: 60px;
	text-align: left;
}
.page__lead.oneLine{
	margin-bottom: 30px;
}
.page--h3{
	background-color: var(--bg-color);
	color: #000;
	font-size: 24px;
	padding: 15px 50px;
	line-height: 1;
	text-align: left;
	margin-bottom: 25px;
}

.page--h3.center{
	text-align: center;
}
.page-mb-15{
	margin-bottom: 15px;
}
.page-mb-25{
	margin-bottom: 25px;
}
.page-mb-40{
	margin-bottom: 40px;
}
@media screen and (max-width: 830px){
	.page--h3{
		font-size: 18px;
		padding-left: 25px;
		padding-right: 25px;
	}
	.page__lead{
		font-size: 14px;
		margin-bottom: 40px;
	}
	.page__lead.oneLine{
		margin-bottom: 25px;
	}
	.tb_hide{
		display: none !important;
	}
}

.page--h3__step span:first-child{
	color: #D84673;
	padding-right: 35px;
	position: relative;
	font-size: 20px;
}
.page--h3__step span:first-child::after{
	content: "";
	height: 28px;
	width: 0.5px;
	background-color: #505050;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
}
.page--h3__step span+span{
	padding-left: 15px;
}
@media screen and (max-width: 830px){
	.page--h3.page--h3__step{
		padding-left: 20px;
		padding-right: 20px;
	}
	.page--h3__step span:first-child{
		padding-right: 20px;
		font-size: 16px;
	}
	.page--h3__step span:first-child::after{
		height: 26px;
	}
	.page--h3__step span+span{
		padding-left: 5px;
	}
}


@media screen and (min-width: 1021px){
	.fullWrapper{
		padding-left: 80px;
		padding-right: 80px;
	}
}


@media screen and (max-width: 1020px) and (min-width: 831px) {
	.fullWrapper{
		padding-left: 40px;
		padding-right: 40px;
	}
}
@media screen and (min-width: 831px){
	.pc_hide{
		display: none !important;
	}
}
@media screen and (max-width: 830px){
	
	.fullWrapper{
		padding-left: 20px;
		padding-right: 20px;
	}
}
@media screen and (min-width: 431px){
	.sp_show{
		display: none !important;
	}
}
@media screen and (max-width: 430px){
	.sp_hide{
		display: none !important;
	}
}
/* text style */
.page--text{
	font-size: 16px;
	line-height: 1.5;
	text-align: left;
}
@media screen and (max-width: 830px){
	.page--text{
		font-size: 14px;
	}
}
.textAlign--left{
	text-align: left;
}
.text--inlineLink{
	color: #000;
	transition: all 0.6s ease;
	text-decoration: none;
}
.text--inlineLink:hover{
	color: var(--bg-green);
	text-decoration: none;
}

.pageTitle--green{
	background-color: var(--bg-green);
	color: #fff;
	font-size: 28px;
	padding: 15px 50px;
	line-height: 1;
	text-align: left;
	margin-bottom: 25px;
}
@media screen and (max-width: 830px){
	.pageTitle--green{
		font-size: 22px;
		padding-left: 25px;
		padding-right: 25px;
	}
}
.btn--green{
	border: 1px solid var(--txt-green);
	color: var(--txt-green);
	text-align: center;
	max-width: 400px;
	margin-left: 0;
	display: block;
	line-height: 3;
	height: 45px;
	font-size: 14px;
}

.btn--inForm{
	border: 1px solid var(--txt-green);
	text-align: center;
	margin-left: 0;
	margin-bottom: 15px;
	display: block;
	width: 210px;
	padding: 14px 0;
	font-size: 0;
}
.btn--inForm span{
	font-size: 14px;
	color: var(--bg-green);
	line-height: 1;
}

.btn--inForm.mail span::before{
	content: "";
	display: inline-block;
	margin-right: 10px;
	background-image: url(../images/icon_mail.jpg);
	width: 19px;
	height: 15px;
	background-size: contain;
	vertical-align: top;
	background-repeat: no-repeat;
}
.btn--inForm.chat span::before{
	content: "";
	display: inline-block;
	margin-right: 10px;
	background-image: url(../images/icon_chat.jpg);
	width: 19px;
	height: 15px;
	background-size: contain;
	vertical-align: top;
	background-repeat: no-repeat;
}
@media screen and (max-width: 430px){
	.btn--inForm{
		width: 100%;
	}
}


a:hover, a:focus{
	text-decoration: none !important;
}


html{
	scroll-behavior: smooth;
}


.stepNav{
	padding: 15px 0;
	border-top: 0.5px solid #505050;
	border-bottom: 0.5px solid #505050;
	display: flex;
	flex-wrap: wrap;
	gap: 16px 0;
	margin-bottom: 50px;
}
@media screen and (max-width: 430px){
	.stepNav{
		margin-bottom: 30px;
	}
}
.stepNav__a{
	width: 33.3%;
	text-align: left;
	color: #000;
	text-decoration: none;
}
.stepNav__num{
	font-size: 16px;
    color: #D84673;
    margin-left: 24px;
    padding-right: 20px;
    position: relative;
    vertical-align: middle;
    line-height: 14px;
    display: inline-block;
}
.stepNav__num:after{
	content: "";
	height: 26px;
	width: 0.5px;
	background-color: #505050;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
}

.stepNav__name{
	vertical-align: middle;
	padding-left: 15px;
}
@media screen and (min-width: 431px){
	.stepNav__name{
		font-size: min(1.6vw, 16px);
	}
}

@media screen and (max-width: 768px) and (min-width: 431px){
	.stepNav__name{
		font-size: min(1.5vw, 15px);
	}
	.stepNav__num{
		margin-left: 0;
		padding-right: 5%;
		line-height: 12px;
	}
}
.stepNav__name::after{
	content: "";
	width: 10px;
	height: 6px;
	display: inline-block;
	background-image: url(../images/arr_bottom.png);
	background-repeat: no-repeat;
	background-size: cover;
	vertical-align: middle;
	margin-left: 15px;
}
@media screen and (max-width: 430px){
	.stepNav{
		display: block;
		padding: 20px 0;
	}
	.stepNav__a{
		width: 100%;
		display: block;
		position: relative;
		margin-top: 25px;
	}
	.stepNav__a:first-child{
		margin-top: 0;
	}
	.stepNav__num{
		margin-left: 0;
	}
	.stepNav__name::after{
		position: absolute;
		right: 0;
		top: 50%;
		transform: translateY(-50%);
	}
}
.baseMakeStep__mr10{
	margin-right: 10px;
}
.baseMakeStep__table a{
	color: #000;
	text-decoration: none;
}
.baseMakeStep__table{
	overflow-x: auto;
	margin-bottom: 80px;
}
.baseMakeStep__table__th {
	background-color: #fff !important;
}
.baseMakeStep__table__th .baseMakeStep__table__col{
	padding: 15px 10px;
}
.baseMakeStep__table__th .baseMakeStep__table__col{
	background-color: #F7EFD4;
}
.baseMakeStep__table__th .baseMakeStep__table__col.blank{
	background-color: #fff;
	padding: 0;
}
.baseMakeStep__table__th p{
	font-size: 16px;
	text-align: left;
	line-height: 1.5;
}
.baseMakeStep__table__row{
	display: flex;
	border-bottom: solid 1px #fff;
	min-width: 1030px;
}
.baseMakeStep__table__row:nth-of-type(2n){
	background-color: #FEFBF7;
}
.baseMakeStep__table__row:nth-of-type(2n+1){
	background-color: #FCF5E7;
}

.baseMakeStep__table__foundationImgs{
	display: flex;
	flex-wrap: wrap;
	width: 100%;
}
.baseMakeStep__table__foundationImgs a{
	padding-right: 2%;
}
.baseMakeStep__table__foundationImgs img{
	height: 65px;
	height: min(4.2vw, 66px);
	width: auto;
}
.baseMakeStep__table__col{
	border-right: solid 1px #fff;
	padding: 10px;
	display: flex;
    align-items: center;
}

.baseMakeStep__table__col:first-child{
	width: 23.3%;
	display: block;
}
.baseMakeStep__table__col.w19{
	width: 19.8%;
}
.baseMakeStep__table__col.w22{
	width: 21.6%;
}
.baseMakeStep__table__col.w29{
	width: 29%;
}
.baseMakeStep__table__col.w35{
	width: 35.6%;
}
.baseMakeStep__table__col.w39{
	width: 39%;
}
.baseMakeStep__table__col.w50{
	width: 50%;
}
.baseMakeStep__table__col.w78{
	width: 78.5%;
}
.baseMakeStep__table__main{
	padding: 16px 24px;
}
.baseMakeStep__table__img {
	margin-bottom: 10px;
	position: relative;
}
.baseMakeStep__table__img .icon_no1{
	position: absolute;
	z-index: 2;
	background-color: #D5B67C;
	color: #fff;
	text-align: center;
	line-height: 1;
	font-size: 12px;
	padding: 5px 7px;
	top: 0;
	left: 0;
}
.baseMakeStep__table__img .icon_no1::after{
	display: none !important;
}
.baseMakeStep__table__img img{
	width: 100%;
}
.baseMakeStep__table__p{
	font-size: 14px;
	text-align: left;
	line-height: 1.6;
}
.baseMakeStep__table__prdName{
	margin-bottom: 5px;
	font-size: 16px;
	text-align: left;
	line-height: 1.6;
}
.baseMakeStep__table__prices{
	text-align: left;
	font-size: 0;
}
.baseMakeStep__table__prices:nth-of-type(2){
	margin-bottom: 10px;
}
.baseMakeStep__table__price{
	font-size: 16px;
	text-align: left;
	margin-bottom: 10px;
}
.baseMakeStep__table__tax{
	font-size: 10px;
}
@media screen and (max-width: 1024px){
	.baseMakeStep__table__foundationImgs img{
		height: 80px;
	}
}


@media screen and (max-width: 430px){
	.baseMakeStep__table__row{
		min-width: 565px;
	}
	.baseMakeStep__table__col:first-child{
		width: 24%;
	}
	.baseMakeStep__table__col.w22{
		width: 17.6%;
	}
	.baseMakeStep__table__col.w35{
		width: 40%;
	}
	.baseMakeStep__table__th p{
		font-size: 14px;
	}
	.baseMakeStep__table__prdName{
		font-size: 14px;
	}
	.baseMakeStep__table__price{
		font-size: 14px;
	}
	.baseMakeStep__table__main{
		padding: 10px;
	}
	.baseMakeStep__table__img{
		max-width: 103px;
		margin-left: auto;
		margin-right: auto;
	}
	.baseMakeStep__table{
		margin-bottom: 60px;
		scrollbar-color: #505050 #CCCCCC;
		padding-bottom: 15px;
	}
	.baseMakeStep__table::-webkit-scrollbar {
		height: 5px;
		background-color: #CCCCCC; 
		border-radius: 10px;
	}
	.baseMakeStep__table::-webkit-scrollbar-thumb {
		background: #505050;
		height: 5px;
		border-radius: 10px;
	}
	.baseMakeStep__table__foundationImgs img{
		height: 47px;
	}
}
