@charset "utf-8";

/* benefit
-------------------------------------------------------------------------------*/

div#footer {
	padding-top: 14.5em;
}

h2 {
	margin: 0;
}

h2 + p {
	border-left: #000 .2em dotted;
	border-right: #000 .2em dotted;
	padding: .3em 4.4em .7em;
	margin: 2.4em 0 5.9em;
}

h2 + p span {
	line-height: 2.19;
	font-size: 16px;
	font-weight: bold;
}

h2 + p strong {
	display: block;
	font-size: 12px;
	margin-top: 1.17em;
}

h3 {
	font-size: 10px;
	color: #fb8b3c;
	padding-bottom: .8em;
	margin-bottom: 2.5em;
	border-bottom: #000 .2em dotted;
}

h3 span {
	font-size: 25px;
	line-height: 2;
}

#primary h4 {
	border: none;
	font-size: 18px;
	margin-bottom: .5em;
}

#primary table + h4 {
	margin-top: 2.3em;
}

#primary h4:before {
	content: none;
}

#primary > div {
	margin-top: 8.5em;
}

#primary > div a {
	text-decoration: underline;
}

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

#primary > dl a {
	text-decoration: underline;
}

#primary > dl + dl {
	margin-top: 7.4em;
}

#primary > dl dd:first-child {
	width: 48em;
	float: right;
}

#primary > dl.rev dd:first-child {
	float: left;
}

#primary > dl dd:first-child img {
	margin-bottom: 2.1em;
}

#primary > dl dd:first-child li {
	font-size: 12px;
	padding-left: 1em;
	text-indent: -1em;
}

#primary > dl dt {
	color: #fb8b3c;
	font-weight: bold;
	margin: 0 53em 0 0;
}

#primary > dl.rev dt {
	margin: 0 0 0 53em;
}

#primary > dl dt small {
	font-size: 10px;
	display: block;
	border-bottom: #000 .2em dotted;
	margin: -.4em 0 1em 0;
	padding: 0 0 1em .7em;
}

#primary > dl dt small span {
	font-size: 16px;
	line-height: 2em;
}

#primary > dl dt strong {
	font-size: 30px;
	line-height] 1.67;
	padding-left: .2em;
}

#primary > dl dt + dd {
	margin: 1.4em 53em 0 0;
	padding: .9em 0 .8em .4em;
	border-top: #000 .2em dotted;
	border-bottom: #000 .2em dotted;
}

#primary > dl.rev dt + dd {
	margin: 1.4em 0 0 53em;
}

#primary > dl dt + dd ul {
	font-size: 0;
	font-weight: bold;
}

#primary > dl dt + dd ul:before {
	content: "対象商品";
	font-size: 12px;
	color: #fff;
	width: 6.25em;
	line-height: 2.5em;
	display: inline-block;
	vertical-align: middle;
	background: #b2b2b2;
	text-align: center;
	border-radius: .33em;
	margin-right: 1em;
}

#primary > dl dt + dd li {
	display: inline-block;
	vertical-align: middle;
	font-size: 12px;
}

#primary > dl dt + dd li + li {
	margin-left: 1.5em;
}

#primary > dl dt + dd li:before {
	content: "●";
	padding-left: .1em;
	font-weight: normal;
}

#primary > dl dt + dd + dd {
	font-size: 14px;
	padding: 2em 0 0 .36em;
}

#primary > dl.rev dt + dd + dd {
	padding: 2em 0 0 38.2em;
}

/* icon
-------------------------------------------------------------------------------*/

p[class^="type"] {
	font-size: 10px;
	width: 17.1em;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	border-radius: .4em;
	position: relative;
	z-index: 1;
	background: #fff;
}

body > p[class^="type"].fl {
	position: absolute;
	border: #e6e6e6 .3em solid;
}

p[class^="type"]:before,
i[class^="icon"] {
	font-family: techoicons;
	color: #fff;
	font-size: 18px;
	width: 1.17em;
	height: 1.17em;
	line-height: 1.17;
	overflow: hidden;
	border-radius: .28em;
	text-align: center;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	font-weight: normal;
	margin: 0 auto;
	cursor: default;
}

p[class^="type"]:before {
	position: absolute;
	top: -.28em;
	left: -.28em;
	z-index: 2;
}

p[class^="type"].fl:before {
	top: -.39em;
	left: -.39em;
}

p.typeA:before,
#primary i.icon-typeA {
	content: "\e801";
	background: #ff3155;
}

p.typeB:before,
#primary i.icon-typeB {
	content: "\e802";
	background: #fb8b0a;
}

p.typeC:before,
#primary i.icon-typeC {
	content: "\e803";
	background: #a3d500;
}

p.typeD:before,
#primary i.icon-typeD {
	content: "\e804";
	background: #66dafc;
}

p.typeZ {
	border: #e6e6e6 .3em solid;
	height: 11.4em;
	text-align: center;
	color: #8c8c8c;
}

p.typeZ:before {
	content: "\e805";
	color: #8c8c8c;
	background: #fff;
	border: #e6e6e6 .17em solid;
	width: 1.28em;
	height: 1.28em;
	line-height: .88;
	top: -.39em;
	left: -.39em;
}

p.typeZ:after {
	content: "";
	font-size: 10px;
	height: 10.8em;
	display: inline-block;
	vertical-align: middle;
}

p.typeZ span {
	display: inline-block!important;
	vertical-align: middle;
}

p[class^="type"] img {
	border-radius: .4em;
	display: block;
	position: relative;
	z-index: -1;
}

p[class^="type"].fl img {
	border-radius: 0;
}

p[class^="type"] span {
	font-size: 12px;
	display: block;
}

p[class^="type"] img + span {
	margin-top: .5em;
}

p[class^="type"].fl img + span {
	margin: .5em 0 .5em .5em;
	letter-spacing: 0;
}

i.icon-typeZ {
	color: #8c8c8c;
}

/* benefit
-------------------------------------------------------------------------------*/

div#benefit h3 + p {
	font-size: 14px;
}

div#benefit h3 + p strong {
	font-size: 12px;
	margin-top: 1em;
	display: block;
}

div#benefit h3 + p strong + strong {
	margin-top: 0;
}

div#benefit ul {
	margin: 3.5em 0 3.7em;
}

div#benefit li {
	float: left;
}

div#benefit li + li {
	margin-left: 2.5em;
}

div#benefit table {
	table-layout: fixed;
}

div#benefit table th,
div#benefit table td {
	border: #cbcbcb 1px solid;
	padding: 1em 0;
}

div#benefit table th {
	background: #cbcbcb;
	border-left: #fff 1px solid;
	border-right: #fff 1px solid;
	color: #fff;
	text-align: center;
	font-weight: bold;
}

div#benefit table th span,
div#benefit table td span {
	font-size: 16px;
}

div#benefit table td span {
	padding-left: .825em;
	display: block;
}

div#benefit th:first-child {
	border-left: #cbcbcb 1px solid;
	width: 20em;
}

div#benefit th:first-child + th {
	width: 37.9em;
}

div#benefit th:first-child + th + th {
	width: 18.8em;
}

div#benefit th:last-child {
	border-right: #cbcbcb 1px solid;
	width: 18.8em!important;
}

.ie div#benefit th.last-child {
	border-right: #cbcbcb 1px solid;
	width: 18.8em!important;
}

div#benefit td:last-child {
	padding: 1.3em 0!important;
	font-size: 10px;
}

.ie div#benefit td.last-child {
	padding: 1.3em 0!important;
	font-size: 10px;
}

div#benefit td.active {
	background: #f2f2f2;
}

div#benefit table#hontai th:first-child {
	width: 76.9em;
}

div#benefit table#weeks th:first-child + th {
	width: 56.8em;
}

#benefit i {
	font-style: normal;
	text-align: center;
	display: block;
	font-size: 16px;
}

/* specific
-------------------------------------------------------------------------------*/

div#specific table {
	table-layout: fixed;
	width: 96em;
}

div#specific table th,
div#specific table td {
	border: #cbcbcb 1px solid;
}

div#specific table th {
	background: #cbcbcb;
	border-top: #fff 1px solid;
	border-bottom: #fff 1px solid;
	color: #fff;
	padding: 1em 0;
	font-weight: bold;
	width: 20em;
}

div#specific table td {
	padding: .625em 0;
}

div#specific table tr:first-child th {
	border-top: #cbcbcb 1px solid;
}

div#specific table tr:last-child th {
	border-bottom: #cbcbcb 1px solid;
}

.ie div#specific table tr.last-child th {
	border-bottom: #cbcbcb 1px solid;
}

div#specific table th span,
div#specific table td {
	font-size: 16px;
}

div#specific table th span {
	padding-left: .825em;
}

div#specific table td {
	padding-left: .825em;
}

div#specific li {
	padding-left: 1em;
	text-indent: -1em;
}

div#specific li:before {
	content: "・";
}

/* demerit
-------------------------------------------------------------------------------*/

#demerit dl {
	float: left;
	width: 50%;
}

#demerit dl + dl {
	float: right;
}

#demerit dl + dl + dl {
	margin-top: 4em;
}

#demerit dl + dl + dl + dl {
	float: left;
}

#demerit dt {
	font-size: 14px;
	font-weight: bold;
	margin-bottom: .5em;
}

#demerit dt:first-child {
	font-size: 16px;
	margin-bottom: 1em;
}

#demerit dd + dt {
	margin-top: 1em;
}

#demerit dd {
	font-size: 14px;
}