@charset "utf-8";

/* ----- */
/* サービス */
/* ----- */

/* -------------------------------------------------- */
/* PC */
/* -------------------------------------------------- */
.subMvBg {
	background-image: url("../../img/service/mv_service_pc.jpg");
}

.serviceSilverWrap {
	margin-bottom: 105px;
}

/* 作業スライダー（slider-pro） */
#serviceWorkSliderInner .sp-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#serviceWorkSliderInner .sp-thumbnail-image {
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: block;
}

#serviceWorkSliderInner .sp-bottom-thumbnails {
    margin-top: 15px;
}
#serviceWorkSliderInner .sp-bottom-thumbnails .sp-thumbnail-container {
	margin-left: 3.375px;
	margin-right: 3.375px;
}

#serviceWorkSliderInner .sp-arrow {
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background-color: #333333;
}

#serviceWorkSliderInner .sp-previous-arrow:before,
#serviceWorkSliderInner .sp-previous-arrow:after,
#serviceWorkSliderInner .sp-next-arrow:before,
#serviceWorkSliderInner .sp-next-arrow:after {
	width: 1.5px;
    height: 20%;
}

#serviceWorkSliderInner .sp-next-arrow:before,
#serviceWorkSliderInner .sp-previous-arrow::before {
	top: 31%;
}
#serviceWorkSliderInner .sp-previous-arrow:before {
	left: 45%;
	-webkit-transform: skew(135deg, 0deg);
	-ms-transform: skew(135deg, 0deg);
	transform: skew(135deg, 0deg);
}
#serviceWorkSliderInner .sp-next-arrow:before{
	right: 45%;
 	-webkit-transform: skew(45deg, 0deg);
    -ms-transform: skew(45deg, 0deg);
    transform: skew(45deg, 0deg);
}

#serviceWorkSliderInner .sp-previous-arrow:after {
	left: 45%;
	-webkit-transform: skew(-135deg, 0deg);
	-ms-transform: skew(-135deg, 0deg);
	transform: skew(-135deg, 0deg);
}
#serviceWorkSliderInner .sp-next-arrow:after {
	right: 45%;
    -webkit-transform: skew(-45deg, 0deg);
    -ms-transform: skew(-45deg, 0deg);
    transform: skew(-45deg, 0deg);
}


/* ----- */
/* ご利用の流れ */
/* ----- */
.serviceFlowList {
	position: relative;
	margin-bottom: 60px;
}

.serviceFlowList::before {
	content: "";
	position: absolute;
	left: 19%;
	top: 0;
	bottom: 0;
	width: 7.5px;
	background-color: #2E9D61;
	z-index: -1;
}

.serviceFlowItem {
	position: relative;
	z-index: 1;
	margin-bottom: 24px;  
}

.serviceFlowItem:last-child {
	margin-bottom: 0;
}

.serviceFlowItemInner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	border: 2.25px solid #016B3A;
	border-radius: 7.5px;;
    padding: 1.5%;
    background: #fff;
    min-height: 83.25px;
}

.serviceFlowSide {
	position: relative;
	z-index: 1;
	-webkit-box-flex: 0;
	    -ms-flex: 0 0 36%;
	        flex: 0 0 36%;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
	border-right: 0.75px solid #707070;
}


.serviceFlowNum {
	font-size: clamp(3.75rem, 4.9575vw, 6.45rem);
	font-weight: 700;
	color: #2E9D61;
    margin-right: 0.25em;
    line-height: 1;
}
.serviceFlowTitWrap {
    letter-spacing: 0.05em;
    font-weight: bold;
}

.serviceFlowTit {
	font-size: clamp(1.5rem, 1.61475vw, 2.1rem);
	color: #016B3A;     
}

.serviceFlowSub {
	font-size: clamp(1.2rem, 1.1535vw, 1.5rem);
}

.serviceFlowBody {
	-webkit-box-flex: 1;
	    -ms-flex: 1;
	        flex: 1;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	    -ms-flex-align: center;
	        align-items: center;
}

.serviceFlowText {
	font-size: clamp(1.2rem, 1.038vw, 1.4rem);
	line-height: 1.3;
    letter-spacing: 0.1em;
    padding: 0.5em 0 0.5em 1em;
}

/* 確認事項 */
.serviceCheckHead {
	position: relative;
	display: inline-block;
	min-width: 8.947em;
    border-radius: 7.5px 7.5px 0px 0px;
	padding: 0.35em 1em;
	font-size: clamp(1.4rem, 1.725vw, 2.6rem);
	font-weight: 700;
	line-height: 1.2;
    letter-spacing: 0.05em;
	color: #ffffff;
	background-color: #2E9D61;
    text-align: center;
}

.serviceCheckHead::before {
	content: "";
	display: inline-block;
	width: 1.1em;
	height: 1.1em;
	margin-right: 0.3em;
	background: url("../../img/common/icon_checkbox_white.svg") no-repeat center / contain;
	vertical-align: bottom;
}

.serviceCheckContent {
	padding: 33.75px 6.6% 31.5px;
	background-color: #F8F8F8;
    border-radius: 0px 7.5px 7.5px 7.5px;
}

.serviceCheckList {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	gap: 30px 3.5%;
}

.serviceCheckItem {
	-webkit-box-flex: 1;
	    -ms-flex: 1;
	        flex: 1;
}

.serviceCheckCaption {
    letter-spacing: 0.05em;
	margin-bottom: 0.75em;
	font-size: clamp(1.3rem, 1.3845vw, 1.8rem);
	font-weight: bold;
	line-height: 1;
	color: #2E9D61;
    text-align: center;
}

.serviceCheckCaption::before {
	content: "";
    display: inline-block;
	width: 1.3em;
	height: 1em;
    margin-right: 0.2em;
	background: url("../../img/common/icon_checkbox.svg") no-repeat center / contain;
    vertical-align: bottom;
}

.serviceCheckImgWrap img {
	width: 100%;
}

.serviceCheckText {
	margin-top: 0.7em;
	font-size: clamp(1.15rem, 1.03875vw, 1.35rem);
	line-height: 1.22;
	letter-spacing: 0.06em;
}




/* -------------------------------------------------- */
/* PC only (1025px〜) */
/* -------------------------------------------------- */
@media screen and (min-width: 1025px) {
	#service {
		margin-bottom: 105px;
	}


	#serviceFlow {
		margin-bottom: 97.5px;
	}

}


/* -------------------------------------------------- */
/* TAB(調整) */
/* -------------------------------------------------- */
@media screen and (min-width: 768px) and (max-width: 1024px) {

	.subMvBg {
		background-image: url("../../img/service/mv_service_tab.jpg");
	}

	.serviceSilverWrap {
		margin-bottom: 60px;
	}

}
/* -------------------------------------------------- */
/* TAB&SP */
/* -------------------------------------------------- */
@media screen and (max-width: 1024px) {
	.serviceFlowItemInner {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		    -ms-flex-direction: column;
		        flex-direction: column;
        padding: 4%;
	}

    .serviceFlowText {
        padding: 1em 0 0;
    }

	.serviceFlowText .brPc {
		display: none;
	}

	.serviceFlowSide {
		-webkit-box-flex: 0;
		    -ms-flex: none;
		        flex: none;
		border-right: none;
		border-bottom: 0.75px solid #dddddd;
	}

	.serviceFlowItem:nth-of-type(n+3) .serviceFlowSide {
		padding-bottom: 0.5em;
	}

    .serviceFlowList::before {
        left: 50%;
    }

	.serviceFlowItem {
		margin-bottom: 15px;
	}

    .serviceCheckContent {
        padding: 5% 3%;
    }

}


/* -------------------------------------------------- */
/* SP(調整) */
/* -------------------------------------------------- */
@media screen and (max-width: 767px) {

	.subMvBg {
		background-image: url("../../img/service/mv_service_sp.jpg");
	}

    .serviceCheckList {
        flex-direction: column;
    }

	.serviceSilverWrap {
		margin-bottom: 30px;
	}


}
