@import url("colorbox.css"); 

/* general CSS */
*
{
	margin: 0px 0px 0px 0px;
	padding: 0px 0px 0px 0px;	
	border: 0;
}

html, body
{
	font-family: Arial, Helvetica, sans-serif;
	font-size: 62.5%;
	height: 100%;
}

body 
{ 
	font-size: 1.25em;
	color: #000000;
	background-color: #D9D9D9;
	background-image: url('../images/bg.png');
	background-position: top center;
	background-repeat: repeat-y;
}

hr
{
	color: #EBEFEE;
	background-color: #EBEFEE;
	height: 1px;
	margin: 0 0 15px;
}

a
{
	color: #00AFE4;
	text-decoration: none;
}

a:hover
{
	text-decoration: underline;
}

#wrapper
{
	position: relative;
	width: 965px;
	margin: 0 auto;
	height:auto !important;
	height:100%;
	min-height:100%;
}

.clr
{
	clear: both;
	width: 0px;
	height: 0px;
}

/* CSS for header */
#logo
{
	float: left;
	width: 351px;
	height: 94px;
	margin: 0px 0px 40px 0px;
}

#header
{
	background-image: url('../images/bg_header.png');
	background-position: top left;
	background-repeat: repeat-x;
	background-color: #FFFFFF;
} 

#header_img, #header_img_slideshow, #header_img_empty
{
	position: relative;
	z-index: 1;
}

#header_img_empty
{
	height: 6px;
	background-color: #00AEE6;
}

#message_bar
{
	position: relative;
	background-color: #EBEFEE;
	border: 1px solid #DAE0E0;
	margin: 1px 1px 1px 1px;	
	font-weight: bold;
	overflow: hidden;
	height: 14px;
	padding: 2px 5px 2px 5px;
}

#message_bar #message
{
	position: relative;
	right: 0px;
}

/* CSS for search form */
#search
{
	display: block;
	float: right;
	width: 219px;
	background-image: url('../images/bg_search.png');
	background-position: bottom left;
	background-repeat: no-repeat;
	margin: 20px 25px 0px 0px;
}

#search legend
{
	color: #FFFFFF;
	margin: 0px 0px 5px 0px;
}

#search #product_search_terms
{
	display: block;
	width: 160px;
	float: left;
	border: 0;
	margin: 4px 0px 0px 5px;
}

#search #button_search
{
	display: block;
	float: right;
	height: 26px;
	width: 44px;
	border: 0;
	margin: 0px 5px 0px 0px;
}

/* CSS for navigation menu */
#menu
{
	display: block;
	position: absolute;
	top: 95px;
	left: 50%;
	width: 965px;
	height: 40px;
	list-style-type: none;
	padding: 5px 0px 0px 0px;
	margin: 0px 0px 0px -482px;
	z-index: 2;
} 

#menu li
{
	float: left;
	margin: 0px 0px 0px 10px;
}

#menu li a
{
	display: block;
	color: #FFFFFF;
	font-size: 14px;
	text-decoration: none;
	padding: 5px 10px 13px 10px;
}

#menu li:hover a
{
	color: #FFD0D0;
	background-image: url('../images/bg_menu_link.png');
	background-position: top left;
	background-repeat: repeat-x;
}

#menu li .submenu
{
	display: none;
}

#menu li:hover .submenu
{
	position: absolute;
	display: block;
	width: 359px;
	height: auto;
	top: 38px;
	list-style-type: none;
	z-index: 2;
	margin: 0px 0px 0px -10px;
}

#menu li .submenu .submenu_header, #menu li .submenu .submenu_footer, #menu li .submenu .submenu_body
{
	display: block;
	width: 359px;
	height: 9px;
	float: none;
	background-image: url('../images/submenu_header.png');
	background-position: top left;
	background-repeat: no-repeat;
}

#menu li .submenu .submenu_footer
{
	background-image: url('../images/submenu_footer.png');
}

#menu li .submenu .submenu_body
{
	width: 329px;
	height: auto;
	background-image: url('../images/bg_submenu.png');
	background-position: top left;
	background-repeat: repeat-y;
	padding: 0px 15px 0px 15px;	
	overflow: hidden;
}

#menu li .submenu .submenu_body a
{
	display: block;
	float: left;
	width: 144px;
	color: #FFFFFF;
	font-size: 12px;
	padding: 5px 10px 5px 10px;
	background: none;
}

#menu li .submenu .submenu_body a:hover
{
	color: #FFD0D0;	
	background-image: url('../images/bg_submenu_link.png');
	background-position: top left;
	background-repeat: repeat-x;
}

/* CSS for content */
#content
{
	background-color: #FFFFFF;	
	background-image: url('../images/bg_content_right.png');
	background-position: top right;
	background-repeat: repeat-y;
	padding: 0px 0px 79px 0px;
}

#content_left
{
	float: left;
	width: 648px;
	padding: 15px 15px 15px 15px;
}

#content_left h1
{
	color: #00AFE4;
	font-weight: normal;
	font-size: 125%;
	margin: 0px 0px 15px 0px;
}

#content_left p
{
	margin: 0px 0px 15px 0px;
}

#content_left ul
{
	margin: 0px 0px 15px 40px;
}

#content_left ol
{
	margin: 0px 0px 15px 40px;
}

#sidebar
{
	float: right;
	width: 287px;
}

#sidebar h2
{
	background-image: url('../images/bg_h2.png');
	background-position: top left;
	background-repeat: no-repeat;
	padding: 6px 15px 20px 15px;
	font-size: 14px;
	text-transform: uppercase;
	border-top: 1px solid #CCCCCC;
}

#sidebar h2 span
{
	color: #00AFE4;
}

#sidebar .sidebar_content
{
	padding: 5px 15px 5px 15px;
}

/* CSS for products */
#nav
{
	display: block;
	border: 1px solid #CECECE;
	background-color: #F0F0F0;
	padding: 10px 10px 10px 10px;	
	overflow: hidden;
	margin: 0px 0px 20px 0px;
}

#nav h3, #product_search legend
{
	display: block;
	font-weight: bold;
	font-size: 1em;
	margin: 0px 0px 0px 0px;
	text-transform: uppercase;
}

#nav #product_nav
{
	display: block;
	list-style-type: none;	
	overflow: hidden;
	line-height: 0.8em;
	margin: 10px 0px 10px 0px;
}

#product_nav li
{
	display: block;
	float: left;
	border-right: 1px solid #000000;
	padding: 0px 5px 0px 5px;
}

#product_nav li.last
{
	border-right: 0;
}

#product_search
{
	display: block;
}

#product_search label
{
	display: none;
}

#product_search input, #product_search select
{
	display: block;
	float: left;
	width: 237px;
	border: 1px solid #CECECE;
	padding: 2px 5px 2px 5px;
	margin: 0px 5px 0px 0px;
}

#product_search select
{
	width: auto;
	padding: 1px 0px 1px 0px;
}

#product_search .button
{
	width: 100px;
	border: 1px solid #000000;
	background-color: #D4D0C8;
}

.page_nav
{
	margin: 0 auto;
	text-align: center;
	margin-top: 10px;
	margin-bottom: 10px;
	padding: 5px 0px 0px 0px;
	border-top: 1px solid #CECECE;
}

#results_info
{
	margin: 10px 0px 10px 0px;
	padding: 0px 0px 5px 0px;
	overflow: hidden;
	border-bottom: 1px solid #CECECE;
}

#results_info h3
{
	float: left;
	display: block;
	font-weight: bold;
	font-size: 1em;
	margin: 0px 20px 0px 0px;
	text-transform: uppercase;
}

#results_info #page_info
{
	float: left;
	margin: 0px 10px 0px 0px;
}

#results_info #results_filter
{
	width: 150px;
	float: right;
}

#results_info #results_filter label, #results_info #results_filter select
{
	float: left;
	border: 1px solid #CCCCCC;
}

#results_info #results_filter label
{
	width: 100px;
	border: 0;
	font-weight: bold;
	padding: 2px 0px 1px 0px;
}

#results_info #results_filter select
{
	width: 50px;
	padding: 0px 0px 0px 0px;
}

#products
{
	width: 648px;
	border-collapse:collapse;
}

#products img
{
	width: 50px;
	border: 1px solid #CECECE;
}

#products a
{
	font-weight: bold;
}

#products td
{
	width: 173px;
	height: 50px;
	padding: 5px 5px 5px 5px;
	vertical-align: middle;
}

#products td.image
{
	width: 60px;
}

#products td.cas
{
	width: 125px;
	font-size: smaller;
}

#products td.links
{
	width: 270px;
	font-size: smaller;	
	text-align: right;
}

#clear_search
{
	display: block;
	width: 237px;
	text-align: right;
	font-size: x-small;
	margin: 3px 0px 0px 0px;
}	

/* CSS for product page */
#product
{
	overflow: hidden;
}

#product_image
{
	display: block;
	margin: 0 auto;
	margin-top: 20px;
	margin-bottom: 20px;
}

#product h2
{
	color: #00AFE4;
	font-weight: normal;
	font-size: 115%;
}

#product h3
{
	font-weight: bold;
	font-size: 100%;
}

#product h4
{
	font-style: italic;
	font-size: 100%;
}

#product #read_more
{
	display: box;
	float: right;
	font-size: x-small;
	margin: 15px 0px 15px 0px;
}

#product #full_text
{
	display: none;
}

#product #product_info
{
	width: 648px;
	border-collapse:collapse;
	margin: 0 auto;
	margin-bottom: 15px;
}

#product #product_info .uneven th, #product #product_info .uneven td, #product #product_info .even th, #product #product_info .even td
{
	width: 314px;
	text-align: left;
	background-color: #CCCCCC;
	padding: 5px 5px 5px 5px;
}

#product #product_info .even th, #product #product_info .even td
{
	background-color: #F5F5F5;
}

.contact_link
{
	display: table;
	margin: 0 auto;
	margin-bottom: 15px;
}

.contact_link a
{
	display: table-cell;
	font-size: 12px;
	height: 42px;
	background-image: url('../images/bg_contact.png');	
	background-position: top left;
	background-repeat: repeat-x;
	color: #FFFFFF;
	text-transform: uppercase;
	vertical-align: middle;
	font-weight: bold;
}

.contact_link_left, .contact_link_right
{
	display: table-cell;
	width: 19px;
	height: 42px;
}

/* CSS for contact */
#contact
{
	width: 505px;
	margin: 0px 0px 20px 0px;
	overflow: hidden;
}

#contact legend
{
	display: none;
}

#contact label, #contact input, #contact select, #contact textarea
{
	float: left;
	width: 288px;
	border: 1px solid #CCCCCC;
	padding: 2px 5px 2px 5px;
	margin: 0px 0px 2px 0px;
}

#contact label
{
	width: 190px;
	border: 0;
	padding: 3px 5px 2px 5px;
	font-weight: bold;
}

#contact select
{
	width: auto;
	padding: 0px 0px 0px 5px;
}

#contact textarea
{
	height: 125px;
}

#contact label span, .red
{
	color: #FF0000;
	font-weight: bold;
}

#contact br
{
	clear: both;
}

#contact .button
{
	width: 150px;
	margin: 15px 0px 0px 350px;
	border: 1px solid #000000;
	background-color: #D4D0C8;
}

#contact .instruction
{
	display: none;
	position: absolute;
	width: 140px;
	border: 1px solid #CCCCCC;
	background-color: #F0F0EE;
	padding: 5px 5px 5px 5px;
	margin: -20px 0px 0px 505px;
	z-index: 2;
}

#contact #comments_instruction
{
	margin: -133px 0px 0px 505px;
}

#contact #referral_explanation1, #contact #referral_explanation2, #contact #referral_explanation3
{
	display: none;
}

#contact .error
{
	background-color: #FFDFDF;
	padding: 5px 0px 5px 0px;
	margin: 0px 0px 5px 0px;
	border: 1px solid #FF0000;
	overflow: hidden;
}

#contact .error label, #contact .error input, #contact .error select, #contact .error textarea
{
	margin: 0px 0px 0px 0px;
	border: 1px solid #FF0000;	
}

#contact .error label
{
	border: 0;
	color: #FF0000;
}

strong.product
{
	color: #FF0000;
}

/* CSS for directions */
#google
{
	float: right;
	text-align: left;
	margin: 0px 0px 0px 10px;
}

#google #map
{
	width: 350px;
	height: 350px;
	margin: 0px 0px 5px 0px;
}

/* CSS for payment */
#payment
{
	width: 454px;
	margin: 0 auto;
	margin-top: 40px;
	margin-bottom: 100px;
	overflow: hidden;
	text-align: center;
}

#payment legend
{
	display: none;
}

#payment fieldset
{
	float: left;
	width: 342px;
	margin: 0px 5px 0px 5px;
}

#payment #invoice_price
{
	width: 82px;
}

#payment label, #payment input
{
	display: block;
	width: 330px;
	border: 1px solid #CCCCCC;
	padding: 2px 5px 2px 5px;
	margin: 0 auto;
	margin-top: 2px;
	margin-bottom: 2px;
	text-align: left;
	text-align: center;
}

#payment label
{
	border: 0;	
}

#payment #ItemCost, #payment #invoice_price label
{
	width: 70px;
}

#payment .button
{
	display: inline;
	width: 120px;
	margin: 15px 5px 0px 5px;
	border: 1px solid #000000;
	background-color: #D4D0C8;
}

#eprocess_logo
{
	display: block;
	margin: 0 auto;
	margin-bottom: 20px;
}

#payment_success, #payment_failure, #send_success
{
	display: block;
	padding: 35px 20px 35px 20px;
	text-align: center;
	background-color: #E1FFDF;
	border: 1px solid #00FF00;
	color: #00FF00;
	font-weight: bold;
	background-image: url('../images/payment_success.png');	
	background-position: left center;
	background-repeat: no-repeat;
}

#payment_failure
{
	background-color: #FFDFDF;
	border: 1px solid #FF0000;
	color: #FF0000;
	background-image: url('../images/payment_failure.png');	
}

/* CSS for youtube */
.youtube_entry, .youtube_entry_last
{
	padding: 10px 0px 10px 0px;
	background-image: url('../images/bg_sidebar_entry.png');
	background-position: bottom left;
	background-repeat: repeat-x;
	text-align: center;
	font-size: x-small;	
}

#player
{
	padding: 10px 10px 10px 10px;
	background-image: none;
	background-color: #FFFFFF;
}

.youtube_entry_last
{
	background-image: none;
}

.youtube_entry img, .youtube_entry_last img
{
	display: block;
	border: 0;
	margin: 0 auto;
	margin-bottom: 5px;
}

/* CSS for blog */
.blog_entry, .blog_entry_last
{
	padding: 10px 0px 10px 0px;
	background-image: url('../images/bg_sidebar_entry.png');
	background-position: bottom left;
	background-repeat: repeat-x;
}

.blog_entry h3, .blog_entry_last h3
{
	color: #00AFE4;
	font-weight: normal;
	font-size: 110%;
	margin: 0px 0px 5px 0px;
}

.blog_entry p, .blog_entry_last p
{
	text-align: center;
}

.blog_entry .blog_link, .blog_entry_last .blog_link
{
	display: block;
	text-align: right;
	margin: 5px 0px 0px 0px;
}

.blog_entry_last
{
	background-image: none;
}

/* CSS for sitemap */
#sitemap li
{
	margin: 0px 0px 0px 0px;
}

#sitemap ul
{
	margin: 0px 0px 10px 15px;
}

/* CSS for footer */
#footer
{
	position: absolute;
	bottom: 0;
	width: 938px;
	height: 54px;
	padding: 14px 14px 14px 14px;
	margin: 0px 0px 0px -1px;
	background-image: url('../images/bg_footer.png');
	background-position: top left;
	background-repeat: repeat-x;	
	background-color: #242424;	
	text-align: center;
	color: #93989B;
	z-index: 1;
}

#footer a
{
	color: #FFFFFF;
}

#footer p
{
	margin: 10px 0px 0px 0px;
}

/* CSS for sectionbar */
.sectionbar
{
	background-image: url('../images/grey-h2.png');
	background-position: top left;
	background-repeat: no-repeat;
	padding-bottom: 20px;
	font-size: 14px;
	text-transform: uppercase;
	text-align:center;
	border-top: 1px solid #CCCCCC;
}