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

.cate_wrap .cate1 .contents{
	position: relative;
}
.cate_wrap .cate1 .imgbox{
	width: 30%;
}
body.on .cate_wrap .cate1 .imgbox{
	position: absolute;
	width: 30%;
}
body.on .cate_wrap .cate1 .imgbox.img1{
	right: 0;
	top: 0;
}
body.on .cate_wrap .cate1 .imgbox.img2{
	left: 0;
	bottom: 0;
}
body.on .cate_wrap .cate1 .imgbox.img1::after{
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: #050505;
	background: linear-gradient(60deg, rgba(5, 5, 5, 0.9) 1%, rgba(0, 0, 0, 0.2) 100%);
}
body.on .cate_wrap .cate1 .imgbox.img2::after{
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: #050505;
	background: linear-gradient(300deg, rgba(5, 5, 5, 0.9) 1%, rgba(0, 0, 0, 0.2) 100%);
}
body.on .cate_wrap .cate1 .imgbox.img1 img,body.on .cate_wrap .cate1 .imgbox.img2 img{
	opacity: 0.5;
}
.cate_wrap .cate1 .txtbox{
	position: relative;
	z-index: 2;
	padding: 10% 20px;
}

.cate_wrap .cate2 .contents > div{
	width: 50%;
}
.cate_wrap .cate2 .contents .leftbox{
	position: relative;
}
.cate_wrap .cate2 .contents .leftbox .boxwrap .box{
	position: relative;
	width: 60%;	
}
.cate_wrap .cate2 .contents .leftbox .boxwrap .box:nth-of-type(2){
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-60%);
}
.cate_wrap .cate2 .contents .leftbox .boxwrap .box:nth-of-type(3){
	transform: translateY(-20%);
}
.cate_wrap .cate2 .contents .leftbox .boxwrap .box .box_innner{
	position: relative;
	width: 100%;	
	aspect-ratio: 1 / 1;
	border-radius: 50%;
	background-color: rgba(123,153,217,0.20);
	border: 1px solid #FFFFFF;
	flex-direction: column;
	gap: 10px;
}
.cate_wrap .cate2 .contents .leftbox .boxwrap .box .num{
 color: #9F9F9F;
}
.cate_wrap .cate2 .contents .rightbox{
	padding-left: 10%;
}
/*
.cate_wrap .cate2 .contents .rightbox .boxwrap .box:not(:last-of-type){
	margin-bottom: 80px;
}
*/
.cate_wrap .cate2 .contents .rightbox .boxwrap .box .num{
	color: #696969;
}

/* 右側ボックス：基本は非表示 */
.cate_wrap .cate2 .contents .rightbox .boxwrap .box{
	display: none;
}
.cate_wrap .cate2 .contents .rightbox .boxwrap .box p,.cate_wrap .cate2 .contents .rightbox .boxwrap .box h3{
	opacity: 0;
	-ms-filter: blur(6px);
	filter: blur(6px);
}
/* 表示中 */
.cate_wrap .cate2 .contents .rightbox .boxwrap .box.is-active{
	display: block;
}
.cate_wrap .cate2 .contents .rightbox .boxwrap .box.is-active p,.cate_wrap .cate2 .contents .rightbox .boxwrap .box.is-active h3{
	animation-name: blurin;
	animation-duration: 1.2s;
	animation-timing-function: ease;
	animation-fill-mode: forwards;
}
body.gjs-dashed .cate_wrap .cate2 .contents .rightbox .boxwrap .box{
	display: block;
}
body.gjs-dashed .cate_wrap .cate2 .contents .rightbox .boxwrap .box p,body.gjs-dashed .cate_wrap .cate2 .contents .rightbox .boxwrap .box h3{
	opacity: 1;
	-ms-filter: blur(0px);
	filter: blur(0px);
}


.cate_wrap .cate3,.cate_wrap .cate4{background-color: #212121;}
.cate_wrap .cate3 > div,.cate_wrap .cate4 > div,.cate_wrap .cate5 > div{
	width: 50%;
}
.cate_wrap .cate3 .imgbox{
	position: relative;
}
.cate_wrap .cate3 .imgbox img:nth-of-type(1){
	width: 80%;
}
.cate_wrap .cate3 .imgbox img:nth-of-type(2){
	position: absolute;
	width: 40%;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
}
.cate_wrap .cate3 .txtbox{
	width: 50%;
	padding-left: 5%;
}
.cate_wrap .cate3 .txtbox .boxwrap .box:not(:last-of-type){
	margin-bottom: 50px;
}
.cate_wrap .cate3 .txtbox .boxwrap .box h3{
	margin-bottom: 15px;
}
.cate_wrap .cate3 .txtbox .boxwrap .box p{
	color: #E3E4E5;
	opacity: 0.8;
}

.cate_wrap .cate4,.cate_wrap .cate5{
	flex-direction: row-reverse;
}
.cate_wrap .cate4 .imgbox img:not(:last-of-type){
	margin-bottom: 10px;
}
.cate_wrap .cate4 .txtbox{
	padding-right: 5%;
}
.cate_wrap .cate4 .txtbox .boxwrap .box{
	justify-content: flex-start;
	align-items: stretch;
}
.cate_wrap .cate4 .txtbox .boxwrap .box:not(:last-of-type){
	margin-bottom: 20px;
}
.cate_wrap .cate4 .txtbox .boxwrap .box > div{
	padding: 5px 0;
}
.cate_wrap .cate4 .txtbox .boxwrap .box .leftbox{
	width: 75px;
	padding-right: 20px;
}
.cate_wrap .cate4 .txtbox .boxwrap .box .rightbox{
	width: calc(100% - 75px);
	padding-left: 20px;
	border-left: 1px solid #575A5D;
}

.cate_wrap .cate5{
	flex-direction: row-reverse;
}
.cate_wrap .cate5 .imgbox{
	position: relative;
}
body.on .cate_wrap .cate5 .imgbox::before{
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: 1;
	background: #1A1A1A;
	background: linear-gradient(180deg, rgba(26, 26, 26, 0) 1%, rgba(26, 26, 26, 0.05) 45%, rgba(26, 26, 26, 0.8) 70%, rgba(26, 26, 26, 1) 100%);
}
body.on .cate_wrap .cate5 .imgbox::after{
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	opacity: 0.2;
	z-index: 2;
	mix-blend-mode: overlay;
	background: #D03565;
	background: linear-gradient(105deg, rgba(208, 53, 101, 0) 1%, rgba(208, 53, 101, 0.05) 45%, rgba(208, 53, 101, 0.8) 70%, rgba(208, 53, 101, 1) 100%);
}
.cate_wrap .cate5 .txtbox{
	padding-right: 5%;
}

.cate_wrap .cate2 .contents .leftbox .boxwrap .box .box_innner{
  will-change: transform, opacity, filter;
  opacity: 0;
  filter: blur(20px);
}
body.gjs-dashed .cate_wrap .cate2 .contents .leftbox .boxwrap .box .box_innner{
  opacity: 1;
  filter: blur(0px);
}


/* ---------- IEのみ ---------- */
@media all and (-ms-high-contrast: none) {
}
/* ---------- 1280px ~ ---------- */
@media screen and (max-width: 1280px){
}
/* ---------- 1080px ~ ---------- */
@media screen and (max-width: 1080px){
	.cate_wrap .cate2 .contents > div{
		width: 80%;
	}
	.cate_wrap .cate2 .contents .rightbox{
		padding-left: 0;
	}
	.cate_wrap .cate2 .contents .rightbox .boxwrap .box{
		display: block;
	}
	.cate_wrap .cate2 .contents .rightbox .boxwrap .box:not(:last-of-type){
		margin-bottom: 80px;
	}
	.cate_wrap .cate2 .contents .rightbox .boxwrap .box p,.cate_wrap .cate2 .contents .rightbox .boxwrap .box h3{
		opacity: 1;
		-ms-filter: blur(0px);
		filter: blur(0px);
	}
}
/* ---------- 768px ~ ---------- */
@media screen and (max-width: 768px){
	.cate_wrap .cate3 .imgbox,.cate_wrap .cate4 .imgbox,.cate_wrap .cate5 .imgbox{
		width: 45%;
	}
	.cate_wrap .cate3 .txtbox,.cate_wrap .cate4 .txtbox,.cate_wrap .cate5 .txtbox{
		width: 55%;
	}
	.cate_wrap .cate3 .txtbox .boxwrap .box:not(:last-of-type){
		margin-bottom: 30px;
	}
	.cate_wrap .cate3 .txtbox .boxwrap .box h3{
		margin-bottom: 10px;
	}

}
/* ---------- 576px ~ ---------- */
@media screen and (max-width: 576px){
	body.on .cate_wrap .cate1 .imgbox{
		position: absolute;
		width: 50%;
	}
	.cate_wrap .cate2 .contents > div{
		width: 100%;
	}
	.cate_wrap .cate2 .contents .rightbox .boxwrap .box:not(:last-of-type){
		margin-bottom: 50px;
	}
	.cate_wrap .cate2 .contents .leftbox .boxwrap .box .default_title2{font-size: 16px;}
	.cate_wrap .cate3 .imgbox,.cate_wrap .cate4 .imgbox,.cate_wrap .cate5 .imgbox{
		width: 90%;
		margin: 0 auto 40px;
	}
	.cate_wrap .cate3 .txtbox,.cate_wrap .cate4 .txtbox,.cate_wrap .cate5 .txtbox{
		width: 100%;
	}
	.cate_wrap .cate3 .imgbox img:nth-of-type(1){
		width: 70%;
	}
	.cate_wrap .cate3 .imgbox img:nth-of-type(2){
		width: 50%;
	}
	.cate_wrap .cate4 .txtbox .boxwrap .box:not(:last-of-type){
		margin-bottom: 15px;
	}
	.cate_wrap .cate4 .txtbox .boxwrap .box > div{
		padding: 3px 0;
	}
	.cate_wrap .cate4 .txtbox .boxwrap .box .leftbox{
		width: 65px;
		padding-right: 15px;
	}
	.cate_wrap .cate4 .txtbox .boxwrap .box .rightbox{
		width: calc(100% - 65px);
		padding-left: 15px;
		border-left: 1px solid #575A5D;
	}
}
/* ---------- 350px ~ ---------- */
@media screen and (max-width: 350px){
}

