@charset 'UTF-8';

/*----------------------------------------

	+ products
		- form
		- accordion
		- product_count
		- product_list

-----------------------------------------*/

/*----------------------------------------
	common
	見出し調整
-----------------------------------------*/

@media screen and (max-width: 768px) {
	.heading_02 {
		margin-bottom: 9.73vw;
	}
}

/*----------------------------------------
	form (絞り込みエリア)
-----------------------------------------*/

.bg_basicblue {
	padding-bottom: 61.5px;
}

/* プルダウン */
form>div:first-of-type {
	display: grid;
	gap: 3.125%;
	grid-template-columns: repeat(2, 1fr);
	margin-top: 48px;
}

form legend {
	color: var(--color_white);
	letter-spacing: 0.03em;
}

form fieldset>div {
	position: relative;
	margin-top: 9px;
}

form fieldset>div::after {
	content: '';
	display: block;
	position: absolute;
	top: 50%;
	right: 15px;
	transform: translateY(-50%);
	width: 24px;
	height: 24px;
	background-image: url(../../img/c_ic_arw_btm_basicblue.svg);
	background-position: center;
	background-size: 24px 24px;
	background-repeat: no-repeat;
	background-color: var(--color_white);
	pointer-events: none;
}

form select {
	width: 100%;
	height: 52px;
	padding: 0 15px;
	background: var(--color_white);
	letter-spacing: 0.04em;
	cursor: pointer;
}

form option {
	border: initial;
}

/* ボタン */
form>div:last-of-type {
	margin-top: 40px;
}

form>div:last-of-type button {
	margin: auto;
	position: relative;
	z-index: 2;
}

@media screen and (max-width: 768px) {
	.bg_basicblue {
		padding-bottom: 10.95vw;
	}

	.bg_basicblue .inner_box:nth-of-type(2) {
		width: 84.615%;
	}

	form>div:first-of-type {
		gap: 6vw;
		grid-template-columns: 1fr;
		margin-top: 4vw;
	}

	form fieldset>div {
		margin-top: 2.3vw;
	}

	form fieldset>div::after {
		right: 3.84vw;
		width: 6.15vw;
		height: 6.15vw;
		background-size: 6.15vw 6.15vw;
	}

	form select {
		height: 12.3vw;
		padding: 0 3.84vw;
	}

	form>div:last-of-type {
		margin-top: 7vw;
	}
}

/*----------------------------------------
	accordion
-----------------------------------------*/

/* 位置をヘッダーに合わせる調整 */
@media screen and (min-width: 619px) and (max-width: 768px) {
	.accordion {
		overflow: hidden;
		z-index: 5;
		position: sticky;
		top: 84px;
		left: 0;
		height: 17.43vw;
		padding: 0;
		transition: height var(--transition05secEaseout);
	}
}

@media screen and (max-width: 620px) {
	.accordion {
		overflow: hidden;
		z-index: 5;
		position: sticky;
		top: 13.82vw;
		left: 0;
		height: 17.43vw;
		padding: 0;
		transition: height var(--transition05secEaseout);
	}
}

@media screen and (max-width: 768px) {
	.accordion {
		background-position: right -34vw bottom !important;
		transition: height var(--transition05secEaseout);
	}

	.accordion.active {
		overflow-y: scroll;
		background-position: right 0 bottom !important;
		height: 72vw;
		transition: height var(--transition05secEaseout);
	}

	/* 部品を絞り込む (開閉ボタン) */
	.accordion .heading_04 {
		display: flex;
		align-items: center;
		z-index: 1;
		position: relative;
		width: 100%;
		height: 17.43vw;
		padding: 0 5.12vw;
		background-color: var(--color_basicblue);
		cursor: pointer;
	}

	/* プラスアイコン */
	.accordion .heading_04::after {
		content: '';
		position: absolute;
		top: 50%;
		right: 5.12vw;
		transform: translateY(-50%);
		width: 6.15vw;
		height: 6.15vw;
		background-image: url(../../img/c_ic_plus_white.svg);
		background-position: center;
		background-size: 6.15vw 6.15vw;
		background-repeat: no-repeat;
		transition: opacity var(--transition02secEaseout);
	}

	.accordion.active .heading_04::after {
		/*opacity: 0;*/
		background-image: url(../../img/c_ic_minus_white.svg);
	}
}

/*----------------------------------------
	product_list (絞り込み結果)
-----------------------------------------*/

/* 件数 */
.product_count {
	margin-top: 60px;
}

.product_count p {
	letter-spacing: 0.03em;
	text-align: right;
}

/* 記事一覧 */
.product_list {
	display: grid;
	gap: 100px 3.125%;
	grid-template-columns: repeat(3, 1fr);
	overflow: hidden;
	margin-top: 20px;
	padding: 50px 0;
	border-bottom: 1px solid var(--color_silver);
}

/* 0件の時余白を消す */
.product_list:empty {
	padding: 0;
}

.product_list .item {
	position: relative;
}

.product_list .item::before {
	content: '';
	position: absolute;
	top: -50px;
	left: 0;
	width: 1056px;
	height: 1px;
	background: var(--color_silver);
}

.product_list .item a {
	display: flex;
	flex-direction: column;
}

.product_list .item figure {
	overflow: hidden;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	aspect-ratio: 1.49 / 1;
	border: 1px solid var(--color_silver);
}

.product_list .item img {
	width: 100%;
	height: 100%;
	object-fit: contain;
	transform: scale(1.05);
	transition: transform var(--transition03secEaseinout);
}

/* hover */
@media (hover: hover) {
	.product_list .item a:hover img {
		transform: scale(1.15);
	}
}

.product_list .item p {
	margin-top: 16px;
	letter-spacing: 0.03em;
}

.product_list .item div {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-top: 20px;
}

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

	/* 件数 */
	.product_count {
		margin-top: 9.23vw;
	}

	/* 記事一覧 */
	.product_list {
		gap: 7.9vw;
		grid-template-columns: 1fr;
		margin-top: 3.07vw;
		padding: 8.2vw 0;
		border-top: 1px solid var(--color_silver);
	}

	.product_list:empty {
		border-top: initial;
	}

	.product_list>:only-child {
		max-width: initial;
	}

	.product_list .item::before {
		display: none;
	}

	.product_list .item a {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		grid-template-areas: 'img name'
			'img tag';
		column-gap: 4.1vw;
	}

	.product_list .item figure {
		grid-area: img;
	}

	.product_list .item p {
		grid-area: name;
		margin-top: 0;
	}

	.product_list .item div {
		gap: 1.28vw;
		grid-area: tag;
		margin-top: 3.33vw;
	}
}