@charset "UTF-8";

/*products
----------------------------------------*/
.products_lists {
	margin-top: 75px;
	margin-bottom: 60px;
	color: #333;
}
.products_lists li {
	text-align: center;
	font-size: 1.5rem;
	background: #ebebeb;
	padding: 19px 10px 21px 0;
	letter-spacing: 1.5px;
	cursor: pointer;
	-webkit-transition: all 300ms;
	transition: all 300ms;
}
.products_lists a {
	display: block;
	margin: 0 auto;
	-webkit-transition: all 300ms;
	transition: all 300ms;
}
.products_lists li span {
	display: block;
	font-size: 2.43rem;
	letter-spacing: 4.6px;
	max-width: 900px;
	width: 100%;
	margin: 0 auto 11px;
	padding-left: 3px;
}
.products_lists li:nth-of-type(2n+1) {
	background: #f9f9f9;
}
.products_lists a:hover {
	opacity: .6;
}

/* Other Types */
.type_block {
	border-bottom: 1px solid #333;
	background: #fafafa;
}
.type_block > * {
	float: left;
	width: 58%;
	margin: 0 0 0 2%;
	padding: 1em 0 2em 1.5em;
	*display: inline;
	*zoom: 1;
}
.type_block > *:nth-child(2n+1) {
	margin-left: 0;
	clear: both;
}
.type_block figure {
	width: 40%;
	margin: 0 auto;
}
.type_block figure img {
	display: block;
	margin: 0 auto;
	padding: 0;
}
.type_block figcaption {
	text-align: center;
	margin: 0 auto;
}
@media only screen and (max-width: 736px) {
	.type_block > *,
	.type_block figure {
		float: none;
		width: 100%;
	}
}
.products_img {
	width: 88%;
	max-width: 880px;
	margin: 85px auto 57px;
	text-align: center;
	color: #333;
}
.products_img figcaption {
	font-size: 2.7rem;
	letter-spacing: 6px;
	margin-top: 23px;
	padding-left: 6px;
	line-height: 1.2;
}
.products_img figcaption span {
	font-size: 1.6rem;
	letter-spacing: 1.5px;
}
.col2_block.plus > div + div::before {
	content: "+";
	font-size: 5rem;
	position: absolute;
	left: 0;
	top: 0;
	margin-top: 6%;
	margin-left: -.5em;
}
.col3_block.plus > div + div::before {
	content: "+";
	font-size: 7rem;
	position: absolute;
	left: 0;
	top: 0;
	margin-top: 19%;
	margin-left: -.54em;
}
.col2_block.combination div {
	padding: 0 20px 20px;
}
.col2_block.combination::before {
	content: "";
	position: absolute;
	top: 0;
	bottom: 30px;
	left: 50%;
	display: block;
	border-left: solid 1px #333;
}
.col2_block.combination + .combination {
	border-top: solid 1px #333;
}
.txt_label {
	display: inline-block;
	background: #ddd;
	line-height: 1.6;
	padding: 0 5px;
	font-size: 1.4rem;
}
.ttl_h2_line {
	border-bottom: 1px solid #333;
	text-align: center;
	color: #333;
	font-weight: 500;
	line-height: 1.6;
	font-size: 2.2rem;
	padding:64px 0 12px 3px;
	letter-spacing: 0.1em;
	margin-bottom: 12px;
}
.ttl_h2_line2 {
	text-align: center;
	border-bottom: solid 1px #333;
	color: #333;
	font-size: 2.7rem;
	font-weight: 500;
	letter-spacing: 2px;
	padding:64px 0 16px;
}
.ttl_h4_specificuse {
	background: #e5e5e5;
	text-align: center;
	padding: 7px;
	font-weight: 500;
	font-size: 1.6rem;
	margin-bottom: 10px;
}
.ttl_h5_specificuse {
	margin: 10px 0;
	font-size: 1.6rem;
	font-weight: 500;
}
.ttl_page.sub + section > .txtarea .col3_block .txt {
	line-height: 1.6;
}
.img_specificuse {
	width: 55%;
	padding: 20px 0;
	text-align: center;
}
@media only screen and (max-width: 736px) {
	.products_lists {
		margin-top: 35px;
		margin-bottom: 0;
	}
	.products_lists li {
		font-size: 1.4rem;
		padding: 19px 30px 21px;
		letter-spacing: 1px;
	}
	.products_lists li span {
		font-size: 2rem;
		letter-spacing: 1px;
		margin-left: 0;
		margin-bottom: 5px;
		position: static;
	}
	.products_img {
		margin: 40px 5.333% 30px;
		width: auto;
		max-width: none;
	}
	.products_img figcaption {
		font-size: 2rem;
		letter-spacing: 4px;
		margin-top: 10px;
		padding-left: 4px;
	}
	.products_list dd ul li a:hover,
	.products_list dt a:hover,
	.products_banner a:hover,
	.products_list dt:hover {
		opacity: 1;
	}
	.ttl_h2_line {
		padding:12px 0 12px 3px;
	}
	.ttl_h2_line2 {
		padding:16px 0 16px;
	}
	.col2_block.plus > div + div {
    	margin-top: 4em;
	}
	.col2_block.plus > div + div::before {
		left: 50%;
		top: 0;
		margin-top: -1.3em;
		margin-left: -.3em;
		z-index: 10;
	}
	.col3_block.plus > div + div {
    	margin-top: 4em;
	}
	.col3_block.plus > div + div::before {
		font-size: 5rem;
		left: 50%;
		top: 0;
		margin-top: -1.3em;
		margin-left: -.3em;
		z-index: 10;
	}
	.col2_block.combination div {
		padding: 15px 0;
	}
	.col2_block.combination > div + div {
		border-top: solid 1px #333;
	}
	.col2_block.combination::before {
    	display: none;
	}
	.col2_block.combination + .combination {
		border-top: solid 1px #333;
	}
	.img_specificuse {
		width: auto;
		padding: 20px 0;
		text-align: center;
	}
}

dl.example_list dt {
	position: static;
	background: none;
	color: #000;
	font-weight: bold;
	text-align: left;
	letter-spacing: 0.1em;
	padding: 0;
	width: auto;
}
dl.example_list dd {
	margin-bottom: 1.8rem;
	padding: 0;
}

.txtarea .indent_list li a {
	color: #009fe6;
}
