
/* Department thumbnails */

.Departments, .Products
{
	clear: both; 
	margin: 0 -15px;
}

.NodeThumbnail
{
    box-sizing: border-box;
    width: 33.3333%;
    min-height: 290px;
    float: left;
    text-align: center;
    -moz-border-radius: 4px;
    -webkit-border-radius: 4px;
    border-radius: 4px;
    padding: 15px;
}

.FeaturedProducts .NodeThumbnail
{
    width: 25%;
}

.NodeThumbnail .Inner
{
    background: #F7F8F8;
    padding: 15px 0;
}

.NodeThumbnail:hover
{
    border-color: #82aa32;
}

.NodeThumbnail .Image
{
    text-align: center;
    margin: 0 0 15px;
    box-sizing: border-box;
    padding-bottom: 70%;
    position: relative;
}

.NodeThumbnail .Image img
{
	max-width: 100%;
	max-height: 100%;
	width: auto !important;
	height: auto !important;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
}

.NodeThumbnail .Name a
{
    padding: 15px;
    display: block;
    text-decoration: none;
    font-weight: 400;
    font-size: 16px;
    text-shadow: none;
    color: #89ab2d;
    box-sizing: border-box;
}

.NodeThumbnail .Price
{
    text-align:left;
    padding: 7.5px 15px;
    font-size: 15px;
    font-weight: 400;
}

/*** Dep't overrides ***/

.Departments .NodeThumbnail .Name
{
    padding: 0 5px;
}

/* Product thumbnails */


/* Product table */

table.Products,
table.Invoices
{
	width: 100%;
	border-collapse: collapse;
	margin-bottom: 8px;
	margin-top: 0;
	padding: 0;
}

table.Products th, table.Invoices th,
table.Products td, table.Invoices td
{
	border-top: none;	
	border-bottom: 1px solid #b3b3b3;	
	padding-top: 5px;
	padding-bottom: 5px;
}

table.Products th, table.Invoices th
{
   padding-bottom: 10px;
}

table.Products img
{
	vertical-align: middle;
}

table.Products td.Buttons
{
	white-space:nowrap;
	text-align: right;
	padding-left: 0;
	padding-right: 0;
}

table.Products td.Name
{
	font-weight: bold;
}

table.Products tr.Line td
{
	padding-top: 8px;
}

table.Products td .Customisation input
{
    width:100%;
}

input.Quantity
{
	width: 30px;
	text-align:center;
}

.ProductDetails .Description
{
    width: 45%;
    float: left;
    box-sizing: border-box;
    padding: 0 15px 0 0;
}

.ProductDetails .Buy
{
    width: 55%;
    float: left;
    box-sizing: border-box;
    padding: 0 0 0 15px;
}

.ListPrice
{
    line-height: 32px;
    font-weight: 300;
}

.ProductDetails .ProductShortDesc
{
    font-size: 16px;
    margin: 28px 0 24px;
}

.ProductDetails .Buy table.PriceBreaks
{
    border-collapse:collapse;
}

.ProductDetails .Buy table.PriceBreaks td,
.ProductDetails .Buy table.PriceBreaks th
{
    border:1px solid #333333;
    padding:4px 16px 4px 4px;
}

.ProductDetails .Buy fieldset p
{
    margin:0 0 10px;
}

.ProductDetails .Buy fieldset div
{
    margin: 5px 0 20px;
    padding: 15px;
    background: #f3f3f3;
}

.ProductDetails .Buy fieldset div label
{
    position: static;
    text-align: left;
    width: 100%;
    padding: 0;
    margin: 0 0 6px;
}

.ProductDetails .Buy fieldset div select
{
    max-width:100%;
    min-width:25%;
}

.ProductDetails .Buy fieldset div .Icon
{
    font-size:13px;
}

.ProductDetails .Buy fieldset div .Icon.InStock
{
    color:Green;
}

.ProductDetails .Buy fieldset div .Icon.OutOfStock
{
    color:red;
}

.ProductDetails .QTYXSell,
.ProductDetails .QTYXSell .QTYXSellProd
{
    margin: 0;
    padding: 0;
}

.ProductDetails .QTYXSell .QTYXSellProd label
{
	padding: 0 0 0 25px;
	width: auto;
	display: block;
	font-size: 13px;
}

.ProductDetails .Buy fieldset div.AdditionalItemPromoBox
{
    display: none;
    padding: 0;
    margin: 10px 0;
}

.ProductDetails .Buy fieldset div.AdditionalItemPromoBox input.Text
{    width: 65%;    box-sizing: border-box;
}

.ProductDetails .QTYXSell .prodQTYXSellCheckbox
{
    vertical-align: top;
    position: absolute;
    top: 0;
    left: 0;
}

.ProductDetails fieldset div.Next
{
    padding: 0 !important;
    background: none;
}

.Content .Image
{
	float: right;
	padding: 0 0 10px 10px;
}

.ProductDetails .Image
{
	text-align: center;
}

.ProductDetails .Image img
{
    max-width: 100%;
    width: auto !important;
    height: auto !important;
    max-height: 100%;
}

.ProductDetails .Image
{
    position: relative;
    padding-bottom: 120%;
}

.ProductDetails .Image img
{
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
}

.ProductDetails .Enlarge
{
	text-align: center;
	display:block;
	margin: 10px 0 0;
}

.ProductDetails .Image img
{
	vertical-align: top;
}

.ProductDetails .ThumbImages
{
    margin: 20px 0;
    overflow: auto;
    border-left: 1px solid #e9e9e9;
    border-top: 1px solid #e9e9e9;
}

.ProductDetails .ThumbImages .Thumbs
{
	float:left;
	width: 25%;
	box-sizing: border-box;
	padding: 0 15px;
    border: 1px solid #e9e9e9;
    border-width: 0px 1px 1px 0;
}

.ProductDetails .ThumbImages .Thumbs .Inner
{
    padding-bottom: 100%;
    position: relative;
}

.ProductDetails .ThumbImages .Thumbs a
{
}

.ProductDetails .ThumbImages .Thumbs img
{
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	margin: auto;
	
	height: auto !important;
	width: auto !important;
	max-width: 100% !important;
	max-height: 100% !important;
}


.OutOfStock 
{
	color: Red;
}

.InStock
{
	color: Green;
	font-weight: bold;
}

.Stock
{
    font-size: 12px;
    padding-right: 5px;
    display: inline-block;
    white-space: nowrap;
    font-weight: 400;
    line-height: 24px;
}

.Stock img
{
    vertical-align: bottom;
}

/***** Bundle Product Table *****/

.BundleBuyBox
{
    border:1px solid #333333;
    padding:10px;
}

table.BundleOptions
{
}

table.BundleOptions td
{
    padding:4px 20px 4px 0;
    vertical-align:top;
}

table.BundleOptions td label
{
    display:block;
    font-weight:bold;
    margin-bottom:10px;
}

table.BundleOptions tr.BundleBuyQuantity td
{
    padding:14px 20px 4px 0;
}

table.BundleOptions tr.BundleBuyQuantity td label
{
    display:inline-block;
    margin-right:5px;
}

table.BundleOptions td select
{
    max-width:100%;
    min-width:25%;
}

table.BundleOptions td span.Options
{
    display:block;
}

.BundleBuyBox .BuyBox
{
}

.BundleBuyBox fieldset
{
    border:none !important;
    padding:0 !important;
}

.BundleBuyBox fieldset legend
{
    display:none;
}

.BundleBuyBox fieldset div label
{
    display:inline-block;
    width:10px;
}





/*** Product Page tabs ***/

#ProductInformation table
{
    max-width:100%;
    min-width:50%;
    margin:10px 0 4px;
    padding:0;
    border-collapse:collapse;
}

#ProductInformation table.InfoTab > tbody > tr > td
{
    margin:0;
    padding:0;
}

#ProductInformation table.InfoTab > tbody > tr > td > span
{
    background-color: #4A7CC7;
    border: medium none;
    color: #3F4F4F;
    cursor: pointer;
    display: block;
    margin: 0 4px 0 0;
    padding: 15px 25px;
    color: #fff;
    text-align: center;
}

#ProductInformation table tr td
{
    border-bottom: none;
    border-top: 1px solid #b3b3b3;
}

#ProductInformation table tr td:first-child span
{
    margin:0;
}

#ProductInformation table.InfoTab > tbody > tr > td.active > span
{
    background-color:#2e5590;
}

#ProductInformation .CrossSell table .TableSubHeading th
{
    background: #82AA32;
    color: #fff;
    border-top: none;
}

#ProductInformation .CrossSell table thead:first-child
{
	display: none;
}

#ProductInformation .CrossSell table .TableSubHeading td
{
    color: #82AA32;
    font-weight: bold;
    border-top: none;
}

#ProductInformation .CrossSell table .TableSubHeading th:first-child,
#ProductInformation .CrossSell table .TableSubHeading td:first-child
{
    padding-left: 5px;
}

#ProductInformation .TabContent
{
    display: none;
    height: 100%;
    overflow: auto;
    margin-bottom: 4px;
    box-shadow: 0px 0px 20px -5px #333;
    padding: 25px;
}

#ProductInformation .TabContent .NodeThumbnail
{
    width:156px;
}

#ProductInformation .TabContent.Downloads ul
{
    list-style:none;
    margin:0;
    padding:0;
}

#ProductInformation .TabContent.Downloads ul a
{
    text-decoration:none;
}

#ProductInformation .TabContent.Downloads ul a:hover
{
    text-decoration:underline;
}

#ProductInformation .TabContent.Downloads ul a i
{
    font-size:14px;
}
#ProductInformation .TabContent.Downloads ul a:hover i
{
    text-decoration:none;
}

#ProductInformation .TabContent p
{
    margin:8px 0;
}

.Reviews
{
}

.Reviews .Review .Rating
{
    margin-left:10px;
}

.Reviews .Review .Rating .Icon
{
    font-size:16px;
}

.Reviews .Review .Rating .Full
{
    color:#D4AF37;   
}

/*** Feature Filter ***/

.FeatureFilter
{
    padding:10px 0;
    height:100%;
    overflow:auto;
}

.FeatureFilter h2
{
    border-bottom: 1px solid #CCCCCC;
    font-size: 15px;
    margin-bottom: 5px;
    padding-bottom: 5px;
}

.FeatureFilter h3
{
    font-size:12px;
    padding:0 0 5px;
    margin:0 0 4px;
}

.FeatureFilter ul
{
    padding:0 10px;
}

.FeatureFilter ul, .FeatureFilter ul li
{
    list-style:none;
    margin:0;
}

.FeatureFilter ul li
{
    padding:0;
    clear:both;
}

.FeatureFilter ul.Feature
{
    margin-bottom:5px;
    padding:0;
}

.FeatureFilter ul.Feature li, .FeatureFilter li.BooleanFeature
{
    float:left;
    width:115px;
    padding:2px 0 6px 30px;
    position:relative;
    clear:none;
}

.FeatureFilter li.BooleanFeature
{
    clear:both;
}


.FeatureFilter ul.Feature li input, .FeatureFilter li.BooleanFeature input
{
    position:absolute;
    left:8px;
    top:0;
}

.FeatureFilter ul.Feature li label, .FeatureFilter li.BooleanFeature label
{
    display:block;
}


/*** Exploded View ***/

.ExplodedViewImageThumbs
{
    overflow: auto;
    margin: 15px 0 0;
}

.ExplodedViewImageThumbs .Thumb
{
    float: left;
    margin: 0 15px 0 0;
}

.ExplodedViewSearchContainer
{
    margin-top: 15px;
}

table.ExplodedViewProductsList
{
    
}

table.ExplodedViewProductsList td,
table.ExplodedViewProductsList thead th
{
    padding-right: 10px;
}

table.ExplodedViewProductsList td
{
    border-bottom: none;
}

table.ExplodedViewProductsList tr.NoBorder td,
table.ExplodedViewProductsList tr:first-child td,
table.ExplodedViewProductsList thead th
{
    border-top: none;
}

/*** Product Page ***/

.ProductDetails .ProductSparesInfoBox
{
    margin: 54px 0 10px;
    font-weight: 400;
    position: relative;
    box-shadow: 0 0 15px -5px #000;
    padding: 10px;
}

.ProductDetails .ProductSparesInfoBox:before
{
    content: "Description";
    display: block;
    display: inline-block;
    background: #2e5590;
    color: #fff;
    cursor: pointer;
    padding: 0 7.5px;
    text-align: center;
    min-width: 50%;
    width: auto;
    margin: 0 0 5px;
    position: absolute;
    bottom: 100%;
    height: 34px;
    line-height: 34px;
    left: 0;
}

.ProductDetails .ProductSparesInfoBox a
{
    font-weight: 600;
}

/*** Lightbox fiddles ***/

#lightbox-nav-btnNext
{
    background-image: url(images/lightbox-next.png) !important;
    background-color: transparent !important;
    background-repeat: no-repeat !important;
    background-position: center right !important;
}

#lightbox-nav-btnPrev
{
    background-image: url(images/lightbox-prev.png) !important;
    background-color: transparent !important;
    background-repeat: no-repeat !important;
    background-position: center left !important;
}


.DueInDate
{
    margin: 4px 0 0 !important;
}


td.DiscountPercentage span
{
    display: none;
}

td.ListPrice .VatLabel
{
	display: none;
}

/** product promo box **/

.ProductPromoBox h5
{
    margin-top: 0;
    margin-bottom: 12px;
}

.ProductPromoBox div
{
    padding: 4px 0 !important;
    margin-bottom: 0 !important;
}

.ProductPromoBox a
{
    text-decoration:none;
}

.ListPriceVatLabel
{
    display: inline !important;
}


td > .ListPriceVatLabel
{
    display: none !important;
}

.ProductDetails .Buy fieldset .MainQtyBox 
{
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: nowrap;
}

.ProductDetails .Buy fieldset .MainQtyBox > div
{
    margin: 0;
    padding: 0;
}

.ProductDetails .Buy fieldset .MainQtyBox .InnerLeft
{white-space: nowrap;padding: 0 15px 0 0;}

.ProductDetails .Buy fieldset .MainQtyBox .InnerRight
{padding: 0 0 0 15px;font-size: 85%;color: #000;}