@charset "utf-8";
/* CSS Document */

/* ---------- main ---------- */
.cate .box_wrap{
	padding-right: 40px;
	padding-left: 40px;
}
.cate_wrap .cate1{
	background-color: #BA1A23;
	color: #fff;
	border-bottom-left-radius: 60px;
}
.cate1 .txtbox2{
	padding-bottom: 100px;
}
.txt-line span{
	position: relative;
	padding-bottom: 10px;
	margin-bottom: 5px;
}
.txt-line span::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0px;
	height: 10px;
	background-image: radial-gradient(#fff 20%, transparent 21%);
	background-size: 8px 8px;
	background-repeat: repeat-x;
}

.cate1 .imgbox img{
	width: 50%;
	border-radius: 10px;
}
.cate1 .imgbox .txtitem{
	width: 50%;
}
.cate1 .imgbox .txtitem h2{
	width: 150px;
	background-color: #fff;
	color: #222222;
}
.cate2 .titlebox p{
	line-height: normal;
}
.cate2 .box_wrap{
	gap: 20px;
	flex-wrap: wrap;
}
.cate2 .box_wrap .box-item .imgbox{
	width: 50%;
}
.cate2 .box_wrap .box-item .imgbox img{
	border-radius: 10px;
}
.cate2 .box_wrap .box-item .txtbox{
	width: 50%;
	padding-left: 20px;
}
.cate2 .titlebox{
	flex-direction: column;
}


/* ---------- 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){
	.cate1 .txtbox2{
		padding-bottom: 50px
	}
	.cate1 .imgbox{
		flex-direction: column;
	}
	.cate1 .imgbox img{
		width: 80%;
	}
	.cate1 .imgbox h2{
		width: 80%;
		margin-top:20px;
	}
	.cate2 .box_wrap .box-item{
		flex-direction: column;
	}
	.cate2 .box_wrap .box-item .imgbox{
		width: 80%
	}
	.cate2 .box_wrap .box-item .txtbox{
		width: 80%;
		padding-top: 20px;
		padding-left: 0px;
	}
}
/* ---------- 350px ~ ---------- */
@media screen and (max-width: 350px){
}

