@charset "utf-8";
.product_grid {
		max-width: 1100px;
		margin: 0 auto;
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
		padding: 0 40px;
}
.product_grid_item {
		width: 520px;
		font-size: 16px;
		margin: 0 0 120px;
		position: relative;
}
.swiper-container.gallery_thumb {
		margin-left: 8px;
		margin-right: 0;
}
@media(min-width: 961px) {
		.products_detail_col {
				display: flex;
		}
}
.gallery_main {
		width: 440px;
		margin: 0 !important
}
.gallery_main .swiper-container {
		height: auto !important
}
.gallery_main .swiper-slide {
		transition: opacity 0.8s;
		height: auto !important
}
.gallery_main img {
		border-radius: 10px;
}
.gallery_thumb .swiper-wrapper {
		padding-right: 6px;
		box-sizing: border-box;
}
@media(min-width: 961px) {
		.gallery_thumb .swiper-wrapper {
				width: 72px;
				display: block;
		}
}
.gallery_thumb .swiper-slide {
		height: auto !important;
		position: relative;
}
.gallery_thumb .swiper-slide:last-child {
		margin-bottom: 0 !important;
}
.gallery_thumb .swiper-slide::before {
		content: '';
		display: block;
		position: absolute;
		top: 0;
		right: -6px;
		width: 2px;
		height: 100%;
		background: none;
		transform-origin: center top;
		transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
		transform: scaleY(0);
}
.gallery_thumb .swiper-slide.swiper-slide-thumb-active::before {
		background: #E48A89;
		transform: scaleY(1);
}
.bottom .gallery_thumb .swiper-slide.swiper-slide-thumb-active::before {
		background: #5AAAAB;
}
.gallery_thumb .swiper-wrapper img {
		width: 100%;
		height: auto;
		cursor: pointer;
}
.gallery_thumb img {
		border-radius: 4px;
}
.products_detail_col {
		margin-bottom: 40px;
}
.product_item_name {
		font-size: 24px;
		font-family: 'Roboto', "Noto Sans JP", serif;
		font-weight: 500;
		line-height: 1.4;
		padding-bottom: 10px;
		border-bottom: 1px solid #A9AAAC;
		margin: 0 0 15px;
}
.product_item_name + p {
		line-height: 1.6;
		text-align: justify;
}
.product_item_bottom {
		display: flex;
		justify-content: space-between;
		align-items: center;
		margin-top: 30px;
}
.product_item_code {
		font-size: 14px;
		margin: 0 0 4px;
		line-height: 1;
}
.hinban {
		display: inline-block;
		position: relative;
		margin-right: 15px;
		transform: translateY(0.5px)
}
.hinban::after {
		content: '';
		display: block;
		position: absolute;
		top: 0;
		right: -8px;
		width: 1px;
		height: 13px;
		background: #4c4949;
		opacity: 0.9
}
.product_item_price {
		font-size: 20px;
}
.buy_btn {
		width: 190px;
}
.buy_btn a {
		display: flex;
		justify-content: center;
		align-items: center;
		text-decoration: none;
		background: #E48A89;
		border: 1px solid #E48A89;
		color: #fff;
		height: 48px;
		border-radius: 60px;
		transition: background 0.4s;
}
.bottom .buy_btn a {
		background: #5AAAAB;
		border: 1px solid #5AAAAB;
}
@media (hover: hover) {
		.buy_btn a:hover {
				background: #fff;
				color: #E48A89;
		}
		.bottom .buy_btn a:hover {
				background: #fff;
				color: #5AAAAB;
		}
}
@media(max-width: 1200px) {
		.product_grid_item {
				width: calc(50% - 15px);
				margin: 0 0 120px;
		}
		.gallery_main {
				width: calc(100% - 60px);
		}
		.swiper-container.gallery_thumb {
				margin-left: auto;
				margin-right: 0;
		}
		.gallery_thumb, .gallery_thumb .swiper-wrapper {
				width: 50px;
				height: auto
		}
		.gallery_thumb .swiper-slide {
				height: auto !important
		}
		.gallery_thumb .swiper-wrapper {
				height: 348px;
		}
		.product_item_name {
				font-size: 20px;
		}
		.buy_btn {
				width: 160px;
		}
}
@media(max-width: 960px) {
		.gallery_main {
				width: 100%;
				margin: 0 0 10px !important;
		}
		.swiper-container.gallery_thumb {
				margin: 0
		}
		.gallery_thumb {
				width: 100%;
		}
		.gallery_thumb .swiper-wrapper {
				width: 100%;
				height: auto !important;
				padding: 0 0 8px;
		}
		.gallery_thumb .swiper-slide::before {
				top: inherit;
				right: inherit;
				left: 0;
				bottom: -7px;
				width: 100%;
				height: 2px;
				transform-origin: left center;
				transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
				transform: scaleX(0);
		}
		.gallery_thumb .swiper-slide.swiper-slide-thumb-active::before {
				transform: scaleX(1);
		}
		.product_item_price {
				font-size: 18px;
		}
		.product_item_bottom {
				display: block;
		}
		.buy_btn {
				width: 190px;
				margin: 20px auto 0;
		}
		.buy_btn a {
				height: 48px
		}
		.product_item_name + p {
				min-height: 18em;
		}
}
@media(max-width: 767px) {
		.product_grid {
				display: block;
				padding: 0 20px;
		}
		.product_grid_item {
				width: 100%;
				margin: 0 auto 80px;
				max-width: 400px;
		}
		.products_detail_col {
				margin-bottom: 25px;
		}
		.product_item_name {
				font-size: 18px;
		}
		.product_item_name + p {
				font-size: 14px;
				margin-bottom: 30px;
				min-height: inherit;
		}
		.heightLine-1 {
				height: auto !important
		}
		.gallery_main img {
				border-radius: 8px;
		}
		.gallery_thumb img {
				border-radius: 4px;
		}
}