@charset "utf-8";
/* CSS Document */
.main-wrap .cate_wrap .cate1{
	position: relative;
	overflow: hidden;
}
.main-wrap .cate_wrap .cate1 .imgbox{
	position: absolute;
	opacity: 0.2;
	width: 100%;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	z-index: 1;
}
.main-wrap .cate_wrap .cate1 h2,.main-wrap .cate_wrap .cate1 p{
	position: relative;
	z-index: 3;
}
.main-wrap .cate_wrap .cate1 h2{
	padding-top: 50px;
}
.main-wrap .cate_wrap .cate1 h2::after{
	content: "";
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 1px;
	height: 25px;
	background-color: #323942;
}

.main-wrap .cate_wrap .cate2{
	padding-right: 0;
}
.main-wrap .cate_wrap .cate2 .titlebox{
	transform: translateX(25%) translateY(8vw);
}
.main-wrap .cate_wrap .cate2 .titlebox h2{
	padding: 10px 0;
}
.main-wrap .cate_wrap .cate2 .titlebox p{
	color: #2E9568;
}
.main-wrap .cate_wrap .cate2 .contents{
	background-color: #E6EDE9;
	width: calc(100% - 105px);
	padding: 8vw;
	padding-right: 0;
}
.main-wrap .cate_wrap .cate2 .contents .box:not(:last-of-type){
	margin-bottom: 80px;
}
.main-wrap .cate_wrap .cate2 .contents .box .num{
	padding-left: 30px;
	position: relative;
}
.main-wrap .cate_wrap .cate2 .contents .box .num::after{
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 20px;
	height: 1px;
	background-color: #2E9568;
}
.main-wrap .cate_wrap .cate2 .contents .box .num span{
	font-family: "Zen Old Mincho","游明朝", "YuMincho", "ＭＳ Ｐ明朝", "MS PMincho","ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "Sawarabi Mincho", "serif";
	font-size: clamp(20px, 2.2vw,36px);
	font-weight: 700;
	padding-left: 5px;
}
/* ---------- IEのみ ---------- */
@media all and (-ms-high-contrast: none) {
}
/* ---------- 1280px ~ ---------- */
@media screen and (max-width: 1280px){

}
/* ---------- 1080px ~ ---------- */
@media screen and (max-width: 1080px){

}
/* ---------- 768px ~ ---------- */
@media screen and (max-width: 768px){

}
/* ---------- 576px ~ ---------- */
@media screen and (max-width: 576px){
	.main-wrap .cate_wrap .cate2{
		padding: 0;
	}
	.main-wrap .cate_wrap .cate2 .contents{
		width: 100%;
		padding: 50px 20px;
		padding-top: 30vw;
	}
	.main-wrap .cate_wrap .cate2 .contents .box:not(:last-of-type){
		margin-bottom: 50px;
	}
	.main-wrap .cate_wrap .cate2 .titlebox{
		transform: translateX(0) translateY(50%);
	}
	.main-wrap .cate_wrap .cate1 h2 br{
		display: none;
	}
}
/* ---------- 350px ~ ---------- */
@media screen and (max-width: 350px){
}

