@charset "utf-8";

#tab .panel_l ul.item{
	display: flex;
	flex-wrap: wrap;
	gap: 40px;
	width: 76%;
	margin: 0 auto;
}

#tab .panel_l ul.item > li{
	width: calc(100% / 2 - 40px * 1 / 2);
	border: 1px solid #333;
	box-shadow: 8px 8px 8px rgba(51,51,51,0.4);
	position: relative;
}
#tab .panel_l ul.item > li:hover{
	border-color: #00367d;
	box-shadow: 8px 8px 8px rgba(0, 54, 125, 0.4);
	transition: all .3s;
}

#tab .panel_l ul.item > li:hover .thum img{
	transform: scale(1.1);
	transition: all .3s;
}

#tab .panel_l ul.item > li a.link{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 2;
}

#tab .panel_l ul.item > li .item_head .thum{
	background-color: #f1f5fc;
	overflow: hidden;
	padding:8% 4% 4%;
}

#tab .panel_l ul.item > li .item_head .thum img{
    height: 250px;
    max-width: 340px;
    margin: 0 auto;
	display: block;
	object-fit: cover;
}

main .item_head{
	position: relative;
}

main .item_head .cate{
	position: absolute;
	font-size: 24px;
	top: 0;
	font-weight: 700;
	line-height:1;
	padding: 10px 80px 10px 10px;
	width: fit-content;
	background: linear-gradient(to right,#c08623,#d3b04e);
	clip-path: polygon(0 0, 100% 0%, 90% 100%, 0% 100%);
}
main .item_head .cate span.ja.noen{
	font-size:24px;
}
main .item_head .cate span.ja{
	font-size: 14px;
	margin: 6px 0 0 4px;
}

main .item_head .cate span.en{
	line-height:1;
}






main .item_body{
	padding: 4% 4% 8%;
}

#tab .panel_l .item_body h3{
	margin: 0 0 10px;
	line-height:1.4;
}

main .panel_r ul{
	display: flex;
	flex-wrap: wrap;
	gap: 60px 20px;
	margin: 0% auto 0;
	width: 74%;
}

main .panel_r ul li{
	width: calc(100% / 4 - 20px * 3 / 4);
	position: relative;
	display: flex;
	flex-direction: column;
}

main .panel_r ul li h3{
	font-size:20px;
}

main .panel_r ul li:hover h3{
	border-bottom: 2px solid #00367d;
	transition: all .3s;
}

main .item_body p{
	font-size:15px;
}

main .panel_r ul li .icon{
	width: 70%;
	margin: 0 auto 10px;
}

main .panel_r ul li h3{
	text-align: center;
	margin: 0 0 20px;
	padding: 0 0 10px;
	border-bottom: 2px solid transparent;

}

main .panel_r ul li .etc{
	background: url(../img/product/bodytype_bg.png) no-repeat center center / cover;
	padding:6%;
	position: relative;
	flex-grow: 1;
}

main .panel_r ul li .etc::after{
	content: 'etc';
	position: absolute;
	bottom: 10px;
	right: 10px;
}

main .panel_r ul li a{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 2;
}

main .product-type-list li:last-of-type .etc{
	visibility:hidden;
}

/*taxonomy common*/
#kaso_body.product_taxonomy #tab{
	padding: 4% 0;
}

#kaso_body.product_taxonomy main h2{
	width: 84%;
	font-size: 24px;
	margin: 0 auto 4%;
}

#kaso_body.product_taxonomy main h2 span{
	font-size: 34px;
}
#tab .panel_l ul{
	display:flex;
	gap:6px;
	flex-wrap:wrap;
	margin: 0 0 10px;
	position: relative;
	z-index: 3;

}

#kaso_body.product_taxonomy #tab ul.tag li{
	padding: 0;
}

#kaso_body.product_taxonomy #tab .panel_l ul.tag li a:hover{
	color: #fff;
	border-color: #00367d;
	background-color: #00367d;
	transition: all .3s;
}

#kaso_body.product_taxonomy #tab ul.tag li a{
	padding: 2px 10px;
	border:1px solid #333;
	font-size:12px;
}

#kaso_body.product_taxonomy #tab ul.tag li:nth-of-type(n + 8){
	display:none;
}


@media screen and (max-width: 1023px){
	main .item_head .cate span.en,
	main .item_head .cate span.ja.noen{
		font-size:18px;
	}

	main .item_head .cate span.ja{
		font-size:12px;
		margin: 10px 0 0 4px;
	}

}
@media screen and (min-width: 768px) and (max-width: 1279px) {

	#tab .panel_l ul.item{
		gap:40px 20px;
		width:90%;
	}
	main .item_head .cate{
		padding: 10px 30px 10px 20px;
		font-size:20px;
	}
	#tab .panel_l .item_body h3{
		font-size: 24px;
	}
	main .item_head .cate span.ja{
		font-size:12px;
	}

	#tab .panel_l .tg ul li a{
		font-size:12px;
	}
	main .panel_r ul li .etc h4{
		font-size:12px;
	}
	main .panel_r ul li .etc::after{
		font-size:10px;
	}
	main .panel_r ul li h3{
		margin:0 0 10px;
		font-size:20px;
	}

	#kaso_body.product_taxonomy main h2{
		font-size: 20px;
		margin: 0 auto 2%;
	}

	#kaso_body.product_taxonomy main h2 span{
		font-size: 28px;
	}
	#kaso_body.product_taxonomy #tab ul.tag li:nth-of-type(n + 6){
		display:none;
	}
	#tab .panel_l ul.item > li .item_head .thum img{
		    height: 200px;
    max-width: 300px;
	}

}

@media screen and (max-width: 767px){
	main h2{
		font-size: 16px;
	}

	main h3{
		font-size: 24px;
	}

	main p{
		font-size: 15px
	}

	main .panel_r ul{
		width: 100%;
		gap: 40px 10px;
		flex-wrap: wrap;
	}

	main .panel_r ul li{
		width: calc(100% / 3 - 10px * 2 / 3);
	}

	main .panel_r ul li h3{
		font-size: 18px;
		margin: 0 0 10px;
	}

	#tab .tab_panel.active{
		padding: 8% 0;
		display: flex !important;
		flex-direction: column;
	}

	main .panel_r ul li .etc h4{
		font-size: 12px;
	}
	main .panel_r ul li .icon{
		margin: 0 auto 6px;
	}

	main .panel_r ul li .etc::after{
		font-size: 12px;
		bottom: 4px;
	}

	#tab .panel_l ul.item{
		width: 100%;
		order: 1;
	}

	#tab .panel_l ul.tag li:nth-of-type(n + 4){
		display:none;
	}
	#kaso_body.product_taxonomy main h2{
		font-size: 18px;
		width: 94%;
		margin: 0 auto 8%;
	}

	#kaso_body.product_taxonomy main h2 span{
		font-size: 24px;
	}
	#kaso_body.product_taxonomy #tab ul.tag li:nth-of-type(n + 5){
		display:none;
	}
	#kaso_body.product_taxonomy #column ul.item{
		gap:20px;
	}
	#tab .panel_l ul.item{
		gap:20px 10px;
	}
	#tab .panel_l ul.item > li{
		width:calc(100% / 2 - 10px * 1 / 2);
	}
	#tab .panel_l ul.item > li .item_head .thum img{
		    height: 160px;
    max-width: 200px;
	}
		#tab .panel_l ul.item > li .item_head .thum{
padding: 12% 4% 4%;
	}

}

@media screen and (max-width: 520px){

	#tab .panel_l ul.item{
		flex-direction: column;
		width: 94%;
		margin: 0 auto;
	}

	#tab .panel_l ul.tag li{
		font-size: 10px;
		margin: 0 4px 4px 0;
	}

	#tab .panel_l ul.item > li{
		margin:0 auto;
		width:94%;
	}

	main .item_head .cate span.ja{
		margin: 6px 0 0 4px;
	}
	main .item_head .cate span.ja.noen{
		font-size:16px;
	}
	main .panel_r ul li{
		width: calc(100% / 2 - 10px * 1 / 2);
	}
	main .item_body p{
		font-size:14px;
	}

	#tab .panel_l ul.item > li .item_head .thum img{
		    height: 150px;
    max-width: 200px;
	}
	main .item_head .cate{
		padding: 6px 40px 6px 10px;
	}
	

}
