/* product type listing styles (/gear/) */

.productTypeSummary {
	clear: both;
}
.productTypeSummary td {
	padding-bottom: 1em;
}
.productTypeSummary .imageThumb {
	float: left;
	border: 0px;
	margin: .3em 15px 1em 0;
}
.productTypeSummary h2 {
	margin: 0px;
	padding: 0px;
	font-size: 1.4em;
}
.productTypeSummary h2 a {
	text-decoration: none;
	color: #444;
}
.productTypeSummary p {
	font-size: .9em;
}


/* category list on gear index and top-level producttype pages */

.categoryList {
	display: block;
	text-align: center;
	margin-bottom: 1em;
}
a.categoryList {
	position: relative;
	text-align: center;
	display: block;
	text-decoration: none;
	min-height: 280px;
	padding-top: 1em;
}
	a.categoryList::after {
		content: '';
		position: absolute;
		top: 0;
		right: 10px;
		left: 10px;
		bottom: 0;
		background-color: rgba(0, 0, 0, 0.05);
		border-radius: 20px;
	}
	a.categoryList:hover::after {
		background-color: rgba(0, 119, 255, 0.15);
	}
a.categoryList h2, a.categoryList h3 {
	text-decoration: none;
	color: #666;
	font-weight: normal;
	margin-left: 5px;
	margin-right: 5px;
}
a.categoryList:hover h2, a.categoryList:hover h3 {
	color: #009;
}
.categoryList div.categoryImage {
	height: 150px;
}
.categoryList img {
	max-width: calc(100% - 20px);
	max-height: 150px;
}



/* product list (pl) styles */

p#plSiblings {
	margin: 0px;
	padding: 0px;
	font-size: .9em;
	line-height: 1.3em; 
}

div#plTopPageBar {
	clear: both;
	width: 100%;
	color: #666;
	font-family: Arial,Helvetica,sans-serif;
	margin: 0px;
	padding: 0px;
	text-align: right;
}

div#plSortBar {
	clear: both;
	width: 100%;
	color: #444;
	background-color: #ccc;
	border-top: 1px solid #444;
	border-bottom: 1px solid #444;
	font-family: Arial,Helvetica,sans-serif;
	font-weight: bold;
	margin: .2em 0em .5em 0em;
	padding: .1em 0px;
}
	div#plSortBar a {
		color: #00c;
		font-weight: normal;
		text-decoration: none;
	}
	div#plSortBar img {
		border: 0px;
		vertical-align: middle;
	}

	div#plSDetails {
		float: left;
		width: 50%;
		padding-left: 5%;
	}
	/* IE 5 box model hack */
	div#plSDetails {
		width: 55%;
		padding-left: 5%;
		voice-family: "\"}\""; 
		voice-family:inherit;
		width: 50%;
		padding-left: 5%;
	}
	/* be nice to Opera hack */
	html>body div#plSDetails {
		width: 50%;
		padding-left: 5%;
	}
	
	
	div#plSRating {
		float: left;
		width: 25%;
		text-align: center;
	}
	div#plSPrice {
		float: left;
		width: 18%;
		text-align: center;
	}


/* product list list layout (old) */
div#productList {
/*
	position: relative;
*/
}
div#productList .adContainer {
	clear: both;
	width: 100%;
	margin: 0 auto;
	padding: 0;
	z-index: 0;
}
div#productList .adContainer>div>div {
	padding: 3em 0;
}


div.plProductSummary {
	position: relative;
	width: 100%;
	border-bottom: 1px dashed #ddd;
	padding: 2em 0px;
	background-color: #fff;
}
div.plPThumb {
	position: relative;
	float: left;
	width: 22%;
	margin: 0px;
	padding: 0px;
	border: 0px;
}
div.plPThumb a {
	position: relative;
	display: block;
	left: 50%;
	width: 70px;
	height: 70px;
	margin-left: -35px;
	border: 0px;
	overflow: hidden;
}
div.plPDetails {
	position: relative;
	float: left;
	width: 33%;
	padding: 1.2em 0em;
}
div.plPDetails h3 {
	position: relative;
	margin: 0px;
	padding: 0px;
	line-height: 1.1em;
	font-size: 1.1em;
	font-style: normal;
}
div.plPDetails h3 a {
	text-decoration: none;
}
div.plPDetails h3 a:hover {
	text-decoration: underline;
}
div.plPDetails small {
	display: block;
	margin-top: .3em;
	font-size: .9em;
	color: #999;
	line-height: 1.2em;
}
div.plPRating {
	position: relative;
	float: left;
	width: 25%;
	padding: 1.2em 0em;
	text-align: center;
}
div.plPPrice {
	position: relative;
	float: left;
	width: 18%;
	padding: 1.2em 0em;
	text-align: center;
}

/*
product list grid layout
*/
a.plProductSummaryGrid {
	display: block;
	position: relative;
	width: 50%;
	float: left;
	border: 1px solid #fff;
	padding: 10px 11px;
	height: 350px;
	text-decoration: none;
	color: #000;
	border-radius: 10px;
	overflow: hidden;
}
	a.plProductSummaryGrid:hover {
		border: 1px solid #ddd;
	}
	a.plProductSummaryGrid div.plPThumb {
		position: relative;
		float: none;
		width: 100%;
		height: 150px;
		margin: 0 auto;
	}
	a.plProductSummaryGrid div.plPDetails {
		float: none;
		width: auto;
		padding: 0;
		margin-top: .5em;
	}
		a.plProductSummaryGrid div.plPDetails b {
			line-height: 1.1em;
			font-size: 1.1em;
		}
		a.plProductSummaryGrid div.plPDetails h3 a {
			text-decoration: none;
		}
		a.plProductSummaryGrid div.plPDetails h3 a:hover {
			text-decoration: underline;
		}
		a.plProductSummaryGrid div.plPDetails small {
			display: block;
			margin-top: .3em;
			font-size: .9em;
			color: #999;
			line-height: 1.2em;
		}
	a.plProductSummaryGrid div.plPRating {
		float: none;
		width: auto;
		padding: 0;
		text-align: left;
		line-height: 1.6em;
		margin: .5em 0;
	}
		a.plProductSummaryGrid div.plPRating img {
			vertical-align: top;
		}
	a.plProductSummaryGrid div.plPPrice {
		float: none;
		width: auto;
		margin-top: .5em;
		padding: 0;
		text-align: left;
	}

@media (min-width: 420px) {
	a.plProductSummaryGrid {
		width: 33%;
	}
}

/*
product list grid layout within a similar products list
*/
#similar-products a.plProductSummaryGrid {
	width: 124px;
	height: 220px;
	font-size: .9em;
	overflow-y: hidden;
}
#similar-products a.plProductSummaryGrid div.plPThumb {
	width: 119px;
	height: 119px;
}


/* similar products lists */
ul.similarProducts {
	display: block;
	list-style: none;
}
ul.similarProducts li {
	display: block;
	list-style: none;
	clear: both;
	margin: 30px 0;
}
ul.similarProducts li a {
	display: block;
	height: 45px;
	padding-top: 20px;
}
ul.similarProducts li a .productThumb {
	display: block;
	position: relative;
	width: 70px;
	height: 70px;
	margin: -20px 30px 0 0;
	float: left;
}

/* style the "More Products" link appearing under similar products list */
div.moreSimilarProducts {
	padding: 2em 22%;
	border-bottom: 1px dashed #ddd;
}
div.moreSimilarProducts h3 {
	position: relative;
	margin: 0px;
	padding: 0px;
	line-height: 1.1em;
	font-size: 1.1em;
	font-style: normal;
}
div.moreSimilarProducts h3 a {
	text-decoration: none;
}
div.moreSimilarProducts h3 a:hover {
	text-decoration: underline;
}


/* product page styles */
div.reviewOuterContainer {
	clear: both;
	position: relative;
    padding: 3em 0;
    border-bottom: 1px solid #eee;
}
div.reviewOuterContainer:first-child, div.reviewSorter+div.reviewOuterContainer {
	padding-top: 0;
}
div.reviewOuterContainer.hidden {
	display: none;
}
div.reviewSummary {
	clear: right;
}
div.reviewSummary h3 {
	margin: 0;
	padding: 0;
}
div.reviewSummary img.rating {
	display: inline;
	width: 97px;
	height: 18px;
	margin: 0 .5em 0 0;
	vertical-align: text-bottom;
}


/* Where To Buy link styles */

.wtbList {
	clear: both;
	position: relative;
	margin: 0 0 2em 0;
}
	/* add margin when the list is shown within a Fancybox */
	.fancybox-inner .wtbList {
		margin-right: 20px;
	}
	
.wtbSorter {
	font-size: 0.9375rem;
}
.wtbSortLink {
	color: #00c;
	text-decoration: underline;
	cursor: pointer;
}
.wtbSortLink.selected {
	font-weight: bold;
	color: #000;
	text-decoration: none;
	cursor: default;
}
.wtbSponsoredNote {
	clear: both;
	float: right;
 	text-align: right;
 	color: #999;
 	font-size: 1em;
 	font-variant: small-caps;
	margin-top: -.25em;
 }
.wtbSponsoredNote::after {
	content: 'sponsored';
}
.column2of8 h2+.wtbSponsoredNote {
	margin-top: -3.5em;
}
.wtbHeaderBar {
	font-size: 1em;
	font-weight: bold;
	color: #444;
	background-color: #eee;
	border-top: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
	margin-top: .5em;
}
.wtbHeaderBar .wtbRetailerProductPrice {
	color: inherit;
	font-size: inherit;
}
.wtbRetailers {
	clear: both;
	margin-top: .5em;
	border-top: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
	min-height: 174px;
	max-height: 470px;
	overflow-y: auto;
	background-color: #eee;
	font-size: .9em;
}
.wtbHeaderBar .wtbRetailerProductPrice {
	color: inherit;
	font-size: inherit;
}
.wtbRetailer {
	position: relative;
	display: block;
	clear: both;
	border-bottom: 1px dashed #ddd;
	padding: 0px;
	background-color: #fff;
	width: 100%;
	text-decoration: none;
}
.wtbRetailer:hover::after {
    content: '';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,127,255,0.065);
    pointer-events: none;
}
.wtbRetailer:last-child {
	border-bottom: none;
}
.wtbRetailer .obviousButton:hover {
	text-decoration: underline;
}
.wtbRetailer a {
	text-decoration: none;
}
.wtbRetailerName {
	display: inline-block;
	vertical-align: middle;
	width: 36%;
	margin: 0px;
	padding: .5em 0px;
	border: 0px;
	text-align: center;
}
.wtbRetailerName img {
	margin: 0px;
	padding: 0px;
}
.wtbRetailerProductPrice {
	display: inline-block;
	vertical-align: middle;
	width: 25%;
	padding: 1em 0;
	text-align: center;
	color: #000;
	font-size: .9em;
}
	.wtbRetailerProductPrice span.wtbRetailerProductVariant {
		font-weight: bold;
		color: #666;
	}
		.wtbRetailerProductPrice span.wtbRetailerProductVariant:hover {
			text-decoration: underline;
		}
	.wtbRetailerProductPrice b {
		font-size: 1.3em;
		font-weight: bold;
		color: #c00;
	}
		.wtbRetailerProductPrice b:hover {
			text-decoration: underline;
		}
.wtbRetailerProductBuy {
	display: inline-block;
	vertical-align: middle;
	width: 36%;
	padding: 0;
	text-align: center;
	font-size: 1em;
}
	.wtbRetailerProductBuy small {
		font-size: .8em;
		margin-bottom: -1.6em;
		color: #999;
	}
		.wtbRetailerProductBuy small:hover {
			text-decoration: underline;
		}
	.wtbRetailerProductBuy .obviousButton {
		white-space: nowrap;
	}

/* allow too-long button labels ("Check Availability") to overflow to the left on small screens*/
@media(max-width: 419px) {
	.wtbRetailerProductBuy .obviousButton {
		float: right;
	}
}

.wtbRetailLocation {
/*	border-bottom: 1px dashed #ddd;*/
	padding: 0px;
	background-color: #eee;
	background-image: url('/images/gear/buy_local_bg.jpg');
	width: 100%;
	font-size: .9em;
	line-height: 1.2em;
	margin-bottom: .5em;
}
.wtbRetailLocation td {
	padding: 0 1.3em;
	width: 50%;
}
.wtbFootnote {
	font-size: .9em;
	line-height: 1.3em;
	color: #999;
	margin-top: .5em;
}
.wtbFootnote a {
	text-decoration: none;
	color: #66f;
}
.wtbFootnote a:hover {
	text-decoration: underline;
	color: #00c;
}

div.wtbRewardsIntro {
	display: none;
	font-size: .9em;
	color: #666;
	line-height: 1.3em;
	margin: .5em 0;
}


/* Rewards / cash back styles */
.cashbackAmount {
		color: #007f00;
	}
	.wtbRetailerProductPrice .cashbackAmount:hover {
		text-decoration: underline;
	}

/* product images */
.imageThumb {
	display: block;
	margin: 0;
	padding: 0;
	width: 70px;
	height: 70px;
	position: relative;
	overflow: hidden;
}

.imageGallery {
	position: relative;
	clear: both;
	margin: 0 auto 4em auto;
	border: 0;
	padding: 0;
	max-width: 700px;
}
	.imageGallery img {
		border: 0;
	}
	.imageGallery .imageFull {
		position: relative;
		display: block;
		margin: 0;
		overflow: hidden;
		z-index: 0;
		cursor: pointer;
		cursor: zoom-in;
		max-height: 70vh;
		height: 1000px; /* Safari 16.3 needs an absolute height to properly scale images (even if overridden by max-height it still needs a value here) */
	}
	.imageGallery .imageFull::before {
		content: "";
		padding-top: 80%;
		display: block;
	}
		.imageGallery .imageFull img {
			max-height: 100%;
			max-width: 100%;
			top: 0px;
			bottom: 0px;
			left: 0px;
			right: 0px;
			margin: auto;
			position: absolute;
			z-index: 0; 
		}
		.imageGallery .thumbList {
			display: block;
			margin: 0;
			padding: 0;
			position: relative;
			list-style-type: none;
			white-space: nowrap;
			min-width: 100%;
			text-align: center;
			overflow-x: auto;
			overflow-y: hidden;
			scrollbar-width: none;
		}
		.imageGallery .thumbList::-webkit-scrollbar {
			display: none;
		}
		.imageGallery .thumbList li {
			display: inline-block;
			vertical-align: top;
			width: 40px;
			height: 40px;
			margin: 4px 0 0 0;
			padding: 2px;
			border: 1px solid #fff;
			position: relative;
		}
		.imageGallery .thumbList li:hover {
			border: 1px solid #e5e5e5;
			cursor: pointer;
		}
		.imageGallery .thumbList li.selected {
			border: 1px solid #ccc;
			cursor: zoom-in;
		}
		.imageGallery .imageThumb {
			display: block;
			margin: 0;
			padding: 0;
			width: 40px;
			height: 40px;
			position: relative;
		}
		.imageGallery .imageThumb noscript img {
			width: auto;
			height: auto;
			max-width: 100%;
			max-height: 100%;
			display: block;
			margin: auto;
			border: 0px;
			position: absolute;
			top: 0;
			bottom: 0;
			left: 0;
			right: 0;
			
		}
		.imageGallery .imageThumb > img {
			border: 0px;
			position: absolute;
			top: 0;
			bottom: 0;
			left: 0;
			right: 0;
			margin: auto;
			max-width: 100%;
			max-height: 100%;
		}


/* review styles */
div.review img {
	max-width: 100%;
	max-height: 595px;
	width: auto;
	height: auto;
	border: 0;
	display: block;
	margin: 2em auto;
}
div.review figure img {
	margin: 0 auto;
}
div.review img.rating {
	display: inline;
	width: 97px;
	height: 18px;
	margin: 0 .5em 0 0;
	vertical-align: text-bottom;
}

div.review iframe {
	max-width: 100%;
	display: block;
	margin: 5px auto;
}
div.review blockquote {
	width: 84%;
	margin: .5em 3% .75em 3%;
	padding: .5em 3%;
	font-style: italic;
	border: 1px solid #ccc;
	font-size: .9em;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
}
div.review  blockquote blockquote {
	font-size: 1em;
	margin: 0px 1em 0px 1em;
}
.dtreviewed {
	font-size: .9em;
	color: #999;
	float: right;
}


/* inheritance styles */
.inherited_from {
  color: #999;
  font-style: italic;
  font-size: .9em;
}
h3 .inherited_from {
  font-weight: normal;
  font-size: .72em;
}


/* styles for products specs */
div.specsTableWrapper {
	overflow-x: scroll;
}
table.specsTable, table.specsTable td, table.specsTable th
{
	border-color: #ddd;
	border-style: solid;
	border-left: 1px solid #eee;
}
table.specsTable
{
	width: 100%;
	border-width: 0;
	border-spacing: 0;
	border-collapse: collapse;
	border-bottom: 1px solid #ddd;
	margin: 1.5em 0 2.5em 0;
}
table.specsTable th, table.specsTable td
{
	margin: 0;
	padding: 4px 1em;
	border-width: 1px 0 0 1px;
	text-align: left;
}
table.specsTable th
{
	font-size: .9em;
	border-top-width: 0;
}
table.specsTable th.label, table.specsTable td.label
{
	width: 20%;
	border-left: none;
	white-space: nowrap;
}
table.specsTable th.label
{
	text-align: left;
	background-color: #def;
}
table.specsTable tr:first-child th.label
{
	text-align: center;
	font-size: 1em;
}
table.specsTable td.label
{
	font-weight: bold;
	color: #333;
}
table.specsTable td.hasColspan
{
	text-align: left;
}
table.specsTable tr.shaded {
}


div.whereToBuy {
	margin: 0;
	padding: 5px;
	line-height: 1.2em;
	background-color: #fff;
	-moz-border-radius: 5px;
	-webkit-border-radius: 5px;
}
div.whereToBuy p.retailerName {
	font-size: 1em;
	color: #444;
	font-weight: bold;
	margin: 0;
	padding: 0;
}
div.whereToBuy p.retailerItem {
 padding-left: .75em;
 margin: 1em 0 1.5em 0;
}
div.whereToBuy p.retailerItem b {
	color: #c00;
}
div.whereToBuy p.buttonContainer {
	text-align: center;
	font-size: 1em;
	padding: 0;
	margin: 5px 0 0 0;
}
div.whereToBuy p.buttonContainer a.button {
	display: block;
	padding: 5px;
	border: 1px solid #999;
	background-color: #fc0;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
}

h2.yellowline {
	clear: both;
	border-top: 1px solid #fc0;
	padding-top: .3em;
	margin-top: 1em;
}

#productPriceSummary:empty {
	display: none;
}
#productPriceSummary {
	background-color: #def;
	padding: 5px;
	border: 1px solid #66c;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
	margin: 15px 0 20px 0;
}
#productPriceSummary div.pricing {
	color: #999;
	margin-bottom: 0;
}
#productPriceSummary div.pricing b {
	color: #c00;
	font-size: 1.5em;
}
#productPriceSummary a {
	text-decoration: none;
}
#productPriceSummary a:hover {
	text-decoration: underline;
}
#productPriceSummary h3 {
	margin: 0 0 .5em 0;
}
#productPriceSummary h4 {
	font-size: 1.3em;
	font-weight: normal;
	font-style: normal;
	color: #666;
	margin: 0;
}
#productPriceSummary div.whereToBuy{
	font-size: .9em;
}
#productPriceSummary.fixed {
	position: fixed;
	top: 0px;
	z-index: 999;
}



div.ratingSummary {
	padding: 5px;
	margin: 0 0 .5em 0;
	border: 1px solid #ccc;
	background-color: #eee;
	-webkit-border-radius: 5px;
	-moz-border-radius: 5px;
	border-radius: 5px;
}
div.ratingSummary a {
	text-decoration: none;
}
div.ratingSummary a:hover {
	text-decoration: underline;
}

#moreReviewsLink {
	background-color: #def;
	border: 1px solid #00c;
	border-radius: 10px;
	padding: 10px 0;
	text-align: center;
	font-weight: bold;
	color: #00c;
	cursor: pointer;
}
#moreReviewsLink:hover {
	text-decoration: underline;
}

.reviewSorter {
	clear: both;
	margin: 0;
	padding: 0;
	font-size: .8em;
	color: #999;
	text-align: right;
}
.reviewSortLink {
	color: #99f;
	text-decoration: underline;
	cursor: pointer;
}
.reviewSortLink.selected {
	font-weight: bold;
	color: #99f;
	text-decoration: none;
	cursor: default;
}


.producttypeSummaryThumbContainer {
	position: relative;
	display: inline-block;
	width: 150px;
	height: 150px;
}

.productListSummary {
	width: 40%;
	font-size: .9em;
	background-color: #def;
	padding: 10px 15px;
	border-radius: 10px;
	margin: 0 auto 2em auto;
}

@media (max-width: 700px) {
	.productListSummary {
		width: 80%;
	}
}

#productTests {
	border: 2px solid #ccc;
	border-radius: 10px;
	padding: 10px;
	margin-bottom: 3em;
}
#productTests img {
	display: block;
	margin: 5px auto;
	max-width: 100% !important;
}


div.column3of8.lastcolumn #overview {
	padding-left: 1em;
	border-left: 1px solid #eee;
}