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

.cate_wrap .cate1{
	align-items: flex-start;
}
.cate_wrap .cate1 .imgwrap,.cate_wrap .cate1 .txtbox{
	margin-top: 10%;
}
.cate_wrap .cate1 .imgwrap{
	width: 40%;
	align-items: flex-start;
	justify-content: flex-start;
}
.cate_wrap .cate1 .imgwrap .img1{
	width: 30%;
	margin-right: -30px;
}
.cate_wrap .cate1 .imgwrap .img2{
	position: relative;
	z-index: 2;
	width: 70%;
	margin-top: 20%;
}
.cate_wrap .cate1 .txtbox{
	width: 45%;
	padding: 20px 50px;
}
.cate_wrap .cate1 .txtbox > .flex{
	flex-direction: column;
	align-items: flex-start;
}

.cate_wrap .cate1 .img3{
	width: 15%;
}

.cate_wrap .cate3 .webgene-blog{
	display:-webkit-box;
    display:-moz-box;
    display:-ms-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:-ms-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
    justify-content: flex-start;
    align-items: flex-start;
	flex-direction: row;
	gap: 40px;
}
.cate_wrap .cate3 .webgene-blog .webgene-item{
	width: calc(100% / 3 - 80px / 3);
}
.cate_wrap .cate3 .webgene-blog .webgene-item a .imgbox{
	position: relative;
	aspect-ratio: 1 / 1;
	overflow: hidden;
}
.cate_wrap .cate3 .webgene-blog .webgene-item a .imgbox > div{
	position: absolute;
	width: 100%;
	height: 100%;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	transition: ease 1.0s;
}
.cate_wrap .cate3 .webgene-blog .webgene-item a:hover .imgbox > div{
	transform: translate(-50%,-50%) scale(1.1);
}

/* ---------- IEのみ ---------- */
@media all and (-ms-high-contrast: none) {
}
/* ---------- 1280px ~ ---------- */
@media screen and (max-width: 1280px){
	.cate_wrap .cate3 .webgene-blog{
		gap: 30px;
	}
	.cate_wrap .cate3 .webgene-blog .webgene-item{
		width: calc(100% / 3 - 60px / 3);
	}
}
/* ---------- 1080px ~ ---------- */
@media screen and (max-width: 1080px){
	.cate_wrap .cate1 .txtbox{
		padding-left: 20px;
		padding-right: 20px;
	}
}
/* ---------- 768px ~ ---------- */
@media screen and (max-width: 768px){
	.cate_wrap .cate1 .imgwrap{
		width: 35%;
	}
	.cate_wrap .cate1 .imgwrap .img1{
		width: 40%;
		margin-right: -30px;
	}
	.cate_wrap .cate1 .imgwrap .img2{
		position: relative;
		z-index: 2;
		width: 60%;
		margin-top: 20%;
	}
	.cate_wrap .cate1 .txtbox{
		width: 50%;
		padding-left: 10px;
		padding-right: 10px;
	}
	.cate_wrap .cate3 .webgene-blog{
		gap: 20px;
	}
	.cate_wrap .cate3 .webgene-blog .webgene-item{
		width: calc(100% / 3 - 40px / 3);
	}
  .boxlayout1 .box .txtbox {
    padding: 3%;
}
}
/* ---------- 576px ~ ---------- */
@media screen and (max-width: 576px){
	.cate_wrap .cate1 .imgwrap{
		width: 100%;
		justify-content: center;
	}
	.cate_wrap .cate1 .imgwrap .img1{
		width: 40%;
		margin-right: -30px;
	}
	.cate_wrap .cate1 .imgwrap .img2{
		position: relative;
		z-index: 2;
		width: 50%;
		margin-top: 20%;
	}
	.cate_wrap .cate1 .txtbox{
		width: 100%;
		padding-left: 20px;
		padding-right: 20px;
	}
	.cate_wrap .cate1 .img3{
		width: 40%;
		margin-left: 60%;
	}
	.cate_wrap .cate3 .webgene-blog{
		gap: 40px;
	}
	.cate_wrap .cate3 .webgene-blog .webgene-item{
		width: 100%;
	}
}

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

