/* パンくずナビ */
.breadcrumb {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	width: 100%;
	max-width: 1160px;
	padding: 5px 10px;
	margin: 0 auto;
}
.breadcrumb li {
	margin-right: 3px;
}
.breadcrumb li:nth-child(n+2)::before {
	display: inline-block;
	content: "＞";
	margin-right: 3px;
}
.breadcrumb a {
	position: relative;
	transition: 200ms ease-out;
}
.breadcrumb a:hover {
	color: #09a;
}
.breadcrumb a::before {
	display: block;
	content: "";
	background-color: #09a;
	width: 0;
	height: 1px;
	position: absolute;
	bottom: 0;
	left: 0;
	transition: 200ms ease-out;
}
.breadcrumb a:hover::before {
	width: 100%;
}

/*-------------------------
home
---------------------------*/
/* product */
#homeProducts {
	width: 100%;
	max-width: 1160px;
	padding: 0 10px;
	margin: 0 auto;
}
#homeProducts > div > ul > li > a,#homeProducts img,#homeProducts span {
	display: block;
	width: 100%;
}
#homeProducts > div > ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	position: relative;
}
#homeProducts > div > ul > li {
	width: calc(calc(100% - 50px) / 6);
	margin-top: 10px;
}
.productsTop,
.productsTopS {
	text-align: center;
	font-weight: 700;
	position: relative;
	cursor: pointer;
}
.productsTop::after {
	display: block;
	content: "";
	background: url("../img/ico_tri.svg") center bottom / contain no-repeat;
	width: 18px;
	height: 20px;
	position: absolute;
	bottom: 0;
	left: 50%;
	z-index: 10;
	transition: 200ms ease-out;
	-webkit-transform-origin: bottom center;
	transform-origin: bottom center;
	-webkit-transform: translate(-50%, 100%) scale(1, 0);
	transform: translate(-50%, 100%) scale(1, 0);
}
.productsTop.productActive::after {
	-webkit-transform: translate(-50%, 100%) scale(1, 1);
	transform: translate(-50%, 100%) scale(1, 1);
}
.productsTop figure,
.productsTopS figure {
	background-color: #ebf4f4;
	padding: 10px 20px;
	margin-bottom: 5px;
	border: 1px solid #dbdbdb;
	position: relative;
}
.productsTopS figure {
	border-color: #dbdbdb;
}
.productsTop figure::after {
	display: block;
	content: "";
	background: url("../img/ico_arrow.svg") center / contain no-repeat;
	width: 20px;
	height: 20px;
	position: absolute;
	right: 10px;
	bottom: 4px;
	opacity: .6;
}
.productsUnder {
	display: none;
	background-color: #dbdbdb;
	width: 100%;
	padding: 10px;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 10;
	-webkit-transform: translateY(calc(100% + 19px));
	transform: translateY(calc(100% + 19px));
}
.productsUnder ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin: 0 0 -10px -10px;
}
.productsUnder li {
	width: 25%;
	padding: 0 0 10px 10px;
}
.productsUnder a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	background-color: #ebf4f4;
	height: 100%;
	font-size: 12px;
	font-weight: 700;
	padding: 5px;
	line-height: 1.1;
	transition: 200ms ease-out;
}
.productsUnder a:hover {
	background-color: #fff;
	color: #e60012;
}
.productsUnder figure {
	width: 70px;
	margin-right: 10px;
}
.productsUnder p {
	width: calc(100% - 80px);
}
.productsUnder figure img {
	transition: 200ms ease-out;
}
.productsUnder a:hover figure img {
	transform: scale(1.1);
}
.productsListButton {
	width: 100% !important;
	text-align: center;
	margin-top: 10px;
}
.productsListButton a {
	display: inline-block;
	min-width: 280px;
	padding: 10px 20px;
}
/* 表示コントロール */
#homeProducts > div {
	display: none;
}
#homeProducts > div:nth-child(1) {
	display: block;
}

@media screen and (max-width: 960px) {
	#homeProducts > div:nth-child(2) {
		display: block;
	}
	#homeProducts > div:nth-child(1) > ul > li:nth-child(n+4),
	#homeProducts > div:nth-child(2) > ul > li:nth-last-child(n+4) {
		display: none;
	}
	#homeProducts > div > ul > li {
		width: calc(calc(100% - 20px) / 3);
	}
	.productsUnder li {
		width: calc(100% / 3);
	}
}
@media screen and (max-width: 640px) {
	#homeProducts > div:nth-child(3) {
		display: block;
	}
	#homeProducts > div:nth-child(2) > ul > li:nth-last-child(n+4) {
		display: block;
	}
	#homeProducts > div:nth-child(1) > ul > li:nth-child(n+3),
	#homeProducts > div:nth-child(2) > ul > li:nth-child(n+5),
	#homeProducts > div:nth-child(2) > ul > li:nth-last-child(n+5),
	#homeProducts > div:nth-child(3) > ul > li:nth-last-child(n+3) {
		display: none;
	}
	#homeProducts > div > ul > li {
		width: calc(calc(100% - 10px) / 2);
	}
	.productsUnder li {
		width: 50%;
	}
	.productsUnder figure {
		width: 60px;
		margin-right: 5px;
	}
	.productsUnder p {
		width: calc(100% - 65px);
	}
}

/* contents */
#homeContents {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
}
#news {
	width: calc(63% - 40px);
}
#news li a {
	display: block;
	padding: 5px 0;
	transition: 200ms ease-out;
}
#news li a:hover {
	background-color: #eee;
}
#news dl,#news dt {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}
#news dt {
	width: 182px;
}
#news dt span {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	width: 60px;
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	line-height: 1;
	padding: 0 5px;
	margin-left: 10px;
}
.news-ir {
	background-color: #5d888f;
}
.news-product {
	background-color: #E26520;
}
.news-event {
	background-color: #784b7e;
}
#news dd {
	width: calc(100% - 182px);
	white-space: nowrap;
	text-overflow: ellipsis;
	overflow: hidden;
}
#pickup {
	width: 37%;
	margin-top: 50px;
}
#pickup li:nth-child(n+2) {
	margin-top: 10px;
}
#pickup a,#pickup img {
	display: block;
	width: 100%;
	transition: 200ms ease-out;
}
#pickup a:hover img {
	opacity: .6;
}
@media screen and (max-width: 640px) {
	#news dl {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
	}
	#news dt,#news dd {
		width: 100%;
	}
	#news dd {
		white-space: normal;
		text-overflow: ellipsis;
		padding-bottom: 5px;
		margin-top: 5px;
		border-bottom: 1px dotted #eee;
	}
	#news,#pickup {
		width: 100%;
	}
	#pickup {
		margin-top: 40px;
	}
}

/* siteInformation */
#siteInformation a {
	background-color: #f7f7f7;
	padding: 10px;
	border: 1px solid #f7f7f7;
	transition: 200ms ease-out;
}
#siteInformation a:hover {
	background-color: #fff;
}
#siteInformation figure {
	padding: 5px;
}
#siteInformation p {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	height: 2.6em;
	font-size: 12px;
	text-align: center;
	line-height: 1.3;
}

/*-------------------------
PRODUCTS
---------------------------*/
.productsNavi {
	background-color: #a0aab0;
	overflow-x: auto;
	overflow-y: hidden;
}
#productsContents .productsNavi {
	background: none;
}
.productsNavi ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	width: 100%;
	max-width: 1140px;
	margin: 0 auto;
}
.productsNavi li {
	width: calc(100% / 11);
	min-width: 100px;
	border-right: 1px solid #fff;
	border-left: 1px solid #fff;
}
.productsNavi-2 li {
	width: 50%;
}
.productsNavi-4 li {
	width: 25%;
}
.productsNavi-5 li {
	width: 20%;
}
.productsNavi-8 li {
	width: 12.5%;
}
.productsNavi li:nth-child(n+2) {
	border-left-width: 0;
}
.productsNavi a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	background-color: #a0aab0;
	height: 100%;
	min-height: 34px;
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	text-align: center;
	line-height: 1.1;
	letter-spacing: 0em;
	padding: 5px;
	position: relative;
	transition: 200ms ease-out;
}
.productsNavi a:hover,
.productsNavi .current a {
	background-color: #fff;
	color: #a0aab0;
}
.productsNavi .current a {
	cursor: default;
}
.productsNavi a::after {
	display: block;
	content: "";
	background-color: #e60012;
	width: 0;
	height: 2px;
	position: absolute;
	bottom: 0;
	left: 50%;
	transition: 200ms ease-out;
}
.productsNavi a:hover::after,
.productsNavi .current a::after {
	width: 100%;
	left: 0;
}

.products-list a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	background-color: #f6f6f6;
	height: 100%;
	padding: 10px;
	border: 1px solid #dbdbdb;
	transition: 200ms ease-out;
}
.products-list a:hover {
	background-color: #fff;
	color: #e60012;
}
.products-list figure {
	width: 70px;
	margin-right: 10px;
}
.products-list img {
	transition: 200ms ease-out;
}
.products-list a:hover img {
	-webkit-transform: scale(1.1);
	transform: scale(1.1);
}
.products-list p {
	width: calc(100% - 80px);
	font-weight: 700;
	line-height: 1.2;
}
@media screen and (max-width: 640px) {
	.products-list figure {
		width: 50px;
	}
	.products-list p {
		width: calc(100% - 60px);
		font-size: 12px;
	}
}

.products-etc-wrapper {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin: 0 0 -40px -20px;
}
.products-etc-wrapper > * {
	width: 50%;
	max-width: 430px;
	padding: 0 0 40px 20px;
}
.products-etc h3::after {
	background-color: #000;
}
.products-etc > div {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}
.products-etc > div p {
	width: calc(100% - 140px);
}
.products-etc > div figure {
	width: 100px;
	margin-left: 40px;
}
.products-etc > div img {
	display: block;
	width: 100%;
}
.products-etc .anchor-right {
	display: block;
	text-align: left;
}
@media screen and (max-width: 960px) {
	#productsContents .products-etc-wrapper > * {
		width: 100%;
		max-width: none;
	}
}
@media screen and (max-width: 640px) {
	.products-etc-wrapper > * {
		width: 100%;
		max-width: none;
	}
	.products-etc > div p {
		width: calc(100% - 100px);
	}
	.products-etc > div figure {
		width: 80px;
		margin-left: 20px;
	}
}

.products-bottom > div {
	margin: 0 0 -20px -20px;
}
.products-bottom > div > * {
	padding: 0 0 20px 20px;
}
.products-bottom > div > dl {
	width: 75%;
}
.products-bottom > div > div {
	width: 25%;
}
.products-bottom dt {
	background-color: #777;
	color: #fff;
	font-weight: 700;
	padding: 3px 10px;
	position: relative;
}
.products-bottom dt a {
	color: #fff;
}
.products-bottom dt::after {
	display: block;
	content: "";
	background-color: #e60012;
	width: 0;
	height: 2px;
	position: absolute;
	bottom: 0;
	left: 0;
	transition: 400ms ease-out;
}
.products-bottom dt:hover::after,
.products-bottom a:hover dt::after {
	width: 100%;
}
#productsContents .products-bottom dd {
	font-size: 12px;
}
.products-bottom li {
	width: calc(100% / 3);
	border-right: 1px solid #777;
	border-bottom: 1px solid #777;	
}
.products-bottom li:nth-child(3n+1) {
	border-left: 1px solid #777;
}
.products-bottom li a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	height: 100%;
	line-height: 1.4;
	padding: 5px 10px;
	transition: 200ms ease-out;
}
.products-bottom li a:hover {
	background-color: #f7f7f7;
	color: #e60012;
}
.products-bottom div div a:nth-child(n+2) {
	margin-top: 20px;
}
.products-bottom div div dl {
	position: relative;
}
.products-bottom div div dd {
	padding: 10px 100px 10px 10px;
	border: 1px solid #777;
	border-top-width: 0;
}
.products-bottom div div figure {
	width: 80px;
	position: absolute;
	top: 10px;
	right: 5px;
}
@media screen and (max-width: 960px) {
	.products-bottom > div > dl,
	.products-bottom > div > div {
		width: 100%;
	}
	.products-bottom > div > div {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}
	.products-bottom > div > div > * {
		width: calc(calc(100% - 20px) / 2);
	}
	.products-bottom div div a:nth-child(n+2) {
		margin-top: 0;
	}
}
@media screen and (max-width: 640px) {
	.products-bottom li {
		width: 100%;
	}
	.products-bottom li {
		border-left: 1px solid #777;
	}
	.products-bottom > div > div > * {
		width: 100%;
	}
	.products-bottom div div a:nth-child(n+2) {
		margin-top: 20px;
	}
}

.products-bottom .new-icon {
	display: inline-block;
	background-color: #e60012;
	color: #fff;
	font-size: 10px;
	font-weight: 700;
	padding: 0 5px;
	margin-right: 5px;
}

/* PRODUCTS DETAIL */
#productsWrapper {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}
#productsSearchArea {
	background-color: #f6f6f6;
	width: 200px;
	font-size: 12px;
}
#productsContents {
	width: calc(100% - 240px);
}
#productsSearchArea h2 {
	background-color: #768787;
	color: #fff;
	font-size: 18px;
	font-weight: 700;
	text-align: center;
	padding: 5px 10px;
}
#productsSearchArea > h2:nth-child(1) {
	cursor: pointer;
}
#productsSearchArea > section:nth-child(2) {
	display: none;
}
#productsSearchArea h3 {
	background-color: #a0aab0;
	color: #fff;
	font-size: 14px;
	font-weight: 700;
	text-align: center;
	padding: 2px 10px;
}
#productsSearchArea dl {
	padding: 10px;
	border-bottom: 1px solid #fff;
}
#productsSearchArea dt {
	font-weight: 700;
	padding-bottom: 3px;
}
#productsSearchArea ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}
#productsSearchArea li {
	width: 100%;
}
#productsSearchArea a {
	display: inline-block;
	position: relative;
	transition: 200ms ease-out;
}
#productsSearchArea a::after {
	display: block;
	content: "";
	background-color: #09a;
	width: 0;
	height: 1px;
	position: absolute;
	bottom: .3em;
	left: 0;
	transition: 200ms ease-out;
}
#productsSearchArea a:hover {
	color: #09a;
}
#productsSearchArea a:hover::after {
	width: 100%;
}
#productsSearchArea > * {
	display: none;
}
#productsSearchArea > *:nth-child(n+3) {
	display: block;
}
@media screen and (max-width: 800px) {
	#productsWrapper {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
	}
	#productsSearchArea {
		width: 100%;
	}
	#productsContents {
		width: 100%;
		margin-top: 60px;
	}
	#productsSearchArea li {
		width: calc(50% - 5px);
	}
	#productsSearchArea > * {
		display: block;
	}
	#productsSearchArea > *:nth-child(n+3) {
		display: none;
	}
}

.products-list-under > li > a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	min-height: calc(100% - 36px);
	border: 1px solid #dbdbdb;
	padding: 10px;
	transition: 200ms ease-out;
}
.products-list-under.products-photo-sensor > li > a {
	height: 100%;
}
.products-list-under > li > a:hover {
	background-color: #f6f6f6;
}
.products-list-under figure {
	width: 42%;
}
.products-list-under figure img {
	mix-blend-mode: darken;
	transition: 200ms ease-out;
}
.products-list-under a:hover figure img {
	-webkit-transform: scale(1.1);
	transform: scale(1.1);
}
.products-list-under dl {
	width: calc(58% - 10px);
	line-height: 1.4;
}
.products-list-under dt {
	color: #09a;
	font-weight: 700;
}
.products-list-under dt span {
	display: block;
	color: #000;
	font-size: 12px;
	font-weight: 400;
}
.products-list-under dt p {
	max-width: 50px;
	margin-bottom: 5px;
}
.products-list-under .light-logo {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	max-width: 105px;
	margin-bottom: 5px;
}
.products-list-under .light-logo p {
	width: calc(calc(100% - 5px) / 2);
	max-width: none;
	margin-bottom: 0;
}
.products-list-under dd {
	font-size: 12px;
	text-align: justify;
	padding-top: 5px;
	margin-top: 5px;
	border-top: 1px dotted #dbdbdb;
}
.products-list-under li ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	background-color: #f6f6f6;
	border: 1px solid #dbdbdb;
	border-top-width: 0;
	height: 36px;
}
.products-list-under li li {
	margin-left: 10px;
}
.products-list-under li li:first-child {
	margin-left: 5px;
}
.products-list-under li li a {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	height: 100%;
	color: #09a;
	font-size: 11px;
	font-weight: 700;
	line-height: 1;
	position: relative;
}
.products-list-under li li a::before {
	display: block;
	content: "\25B6\FE0E";
	transform: scale(0.5);
}
.products-list-under li li a::after {
	display: block;
	content: "";
	background-color: #09a;
	width: 0;
	height: 1px;
	position: absolute;
	bottom: -1px;
	left: 9px;
	transition: 200ms ease-out;
}
.products-list-under li li a:hover::after {
	width: calc(100% - 8px);
}
.new-item {
	position: relative;
}
.new-item::before {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	content: "NEW";
	background-color: #e60012;
	width: 30px;
	height: 30px;
	color: #fff;
	font-size: 10px;
	font-weight: 700;
	line-height: 1;
	border-radius: 50%;
	position: absolute;
	top: -8px;
	left: -8px;	
}

.lss-table {
	overflow-x: auto;
	overflow-y: hidden;
}
.lss-table table {
	width: 100%;
	min-width: 710px;
	font-size: 12px;
	line-height: 1.4;
	border-collapse: separate;
	position: relative;
}
.lss-table tr > * {
	padding: 5px;
}
.lss-table tr > th:nth-child(1) {
	position: sticky;
	left: 0;
	z-index: 5;
}
.lss-table th {
	background-color: #a0aab0;
	color: #fff;
	border-right: 1px solid #fff;
	border-bottom: 1px solid #fff;
}
.lss-table td {
	text-align: center;
	border-right: 1px solid #a0aab0;
	border-bottom: 1px solid #a0aab0;
}
.lss-table thead th:last-child {
	border-right-width: 0;	
}
.lss-table tbody th {
	min-width: 102px;
	text-align: left;
}
.lss-table tbody tr:last-child th {
	border-bottom-width: 0;
}
.products-aside::after {
	content: "※";
}