/* =========================
* Main Firefly styles that replace "main.css" from Substruct. 
* 
* The first half are the Substruct styles with changes mixed in
* The last 1/4 are pure custom styles for Firefly
*
*/


/* Reset all margins and padding to ensure x-browser compatibility */
* {
	padding: 0px;
	margin: 0px;
}
body, html {
	margin: 0px;
	padding: 0px;
	width: 100%;
}
body {
	background-color: #fff;
}
body, table, div, td, input, textarea, option, select {
	font-family: 'Trebuchet MS', sans-serif;
	font-weight: normal;
	font-size: 10pt;
	line-height: 1.4em;
	color: #483324;
}

a.action:link, a.action:visited, a.action.bad:link, a.action.bad:visited {
	background-color: #049abe;
	color: #fff !important;
	font-weight:normal;
	font-size: 98%;
	padding: 4px;
	text-decoration:none !important;
}
a.action.bad:link, a.action.bad:visited {
	background-color: #770000;
	font-weight: bold;
}
a.normal { font-weight: normal; }
a.redlink, a.red:link, a.red:visited {
	color: #804D68;
}
form {
}
img {
	display:inline;
}
img.floater {
	margin:20px;
	border:1px dotted #C2B2FB !important;
	border:1px solid #9C8FCA;
}
img.floater2 {
	margin-right:10px;
	margin-bottom:10px;
}
p {
	padding-top: 5px;
	padding-bottom: 10px;
	line-height: 1.5em;
}
td {
	vertical-align: top;
}
label {
	clear:both;
	font-weight:bold;
	color: #666666;
	display:block;
	padding-bottom: 5px;
}
input {
}
option {
	padding: 0 0 2px 4px;
	line-height: 2em;
}
select {
	border: 1px solid #000;
	height: 2em;
	line-height: 2em;
	padding-top: 2px;
}
input[type=hidden] {
	display:none;
}
ul, ol {
	padding-left:30px;
}
ul {
	list-style-type:disc;
}
ul li {
	padding: 2px 0px;
	list-style-type: square;
}
ul.navigation {
	margin: 0px;
	padding-left:0px;
	padding: 0px;
	display: inline;
}
ul.navigation li {
	margin:0px;
	list-style: none;
	display:block;
	float:left;
	padding: 0px 5px;
}
ul.navigation li.active {
	font-weight: bold;
	font-style: italic;
}

/* Secondary actions: orders ready to ship, on hold etc */

ul.navigation.secondary {
	float:right;
	margin-top: -30px;
	margin-right: 0px;
}
ul.sortable {
	margin-left: 0px !important;
	padding-left: 0px !important;
}

ul.sortable li {
	cursor: pointer;
	cursor: hand;
	list-style-type: none;
	border-bottom: 1px dotted #ccc;
	margin-bottom: 5px;
	margin-left: 0px !important;
}

ul.sortable li p {
	margin-bottom: 5px;
}

.navigation a, .navigation a:link, .navigation a:visited {
}
.navigation.secondary a, .navigation.secondary a:link, .navigation.secondary a:visited {
	color: #5272E0;
}
.navigation.tertiary a, .navigation.tertiary a:link, .navigation.tertiary a:visited {
	color: #000;
	padding: 4px;
}
.navigation.tertiary li {
	background-color: #ccc;
	padding-left: 4px;
	padding-right: 4px;
}
.navigation.tertiary li.active {
	background-color: #fff;
	border: 1px solid #ccc;
	border-bottom: 0px;
}
#subnav {
	border-bottom: 1px solid #ccc !important;
	border-bottom: 0px;
	height: 18px;
}

img {	border: 0px; }

h1 {
	color: #3b3b3b;
	font-weight: normal;
	margin-bottom: .5em;
}
h1 .info {
	font-size: 102%;
	font-style: normal;
	color: #B8B3AD;
}

h1.border {
	border-bottom: 1px dotted #806a53;
}

h1 a {
	color: #f86d0a;
	font-weight: normal;
	text-decoration: none;
}

h1.important {
	font-size: 180%;
	font-style: italic;
	line-height: 1.1em;
}

h1:first-child, h1.first {
	margin-top: 0px;
}

h2, h3, h4 {
	margin-top: 10px;
	margin-bottom: 10px;
	padding-bottom:0px;
}

h2 {
	color: #5e5e5e;
	font-weight: normal;
}
h3 {
	margin-top: 0px;
	color: #840018;
	font-weight: normal;
}
h4 {
	margin: 0px;
	padding: 0px;
	color: #8a8075;
	font-weight: normal;
}

div.line {
	border-bottom: 1px dotted #B5B5B5;
	padding:0px;
	margin-top: 10px;
	margin-bottom: 20px;
	height: 1px;
	overflow:hidden;
	clear:both;
}


div.indent {
	padding:0px;
	margin:0px;
	margin-top:-10px;
	padding-left:20px;
}

div.padLeft {
	padding-left:10px;
}

/* div.price {
	background-color: #6ABE32;
	color: #fff;
	font-size: 198%;
	padding: 5px 10px;
	text-align: center;
	font-style: italic;
	-moz-border-radius: 10px;
} */

.info {
	font-size: 92%;
	font-style: italic;
	color: #666666;
	line-height: 1em;
}





/* BUTTONS */
/* This is used on anchors as well as button objects, so some css trickery is needed */
.buttonX, .buttonWarning {
	background-color: #046c82;
	background-image: url(/plugin_assets/substruct/images/public-ui/buttons/bg.gif) !important;
	background-repeat: repeat-x;
	border: 2px solid #000;
	font-size: 102%;
	font-weight: bold !important;
	color: #eeeeee !important;
	color: #eeeeee;
	text-decoration: none !important;
	text-decoration: none;
	line-height: 20px;
	padding: 5px;
	cursor: pointer;
	cursor: hand;
	text-align: center;
	display:block;
}

#right a.button, a.button {
	text-decoration: none;
	color: #eeeeee;
	font-weight: bold;
}

.buttonWarning {
	background-color: #FF0000;
	border-color:#B00000;
	color:#eeeeee;
}

/* end buttons */

*.small {
	padding: 1px;
	font-size: 90%;
}

/* BEGIN TABLE LIST CSS */

div.listContainer {
	height:300px;
	width: 100%;
	border: 1px solid #666666;
	background-color: #fff;
	overflow: auto;
}


.list {
	width: 100%;
}
/* don't put a border around tables contained by a div */
div.listContainer .list {
	width: 100%;
}

.list td {
	padding: 2px 6px;
}

.cart_item td {
	margin-bottom: 20px !important;
	border-bottom: 1px dotted #ccc !important;

}

.list tr, tr.cart_item {
	padding: 30px !important;
}

.list tr.odd td {
	background-color: #fff;
}

.list tr.even td, .even {
	background-color: #ECEEF2;
}
.numeric, .list .numeric {
	text-align: left;
}

/* .list th, .list tr.header td, .list td.header {
	font-weight: bold;
	background-color: #777777;
	background-image:url(/plugin_assets/substruct/images/table_header_bg.png);
	color: #eeeeee;
	border-bottom: 1px solid #666666;
	border-right: 1px solid #666666;
	text-transform:capitalize;
	padding: 4px;
	text-align: left;
} */

.list tr.footer td {
	font-weight:normal;
	font-style:italic;
	color: #333333;
	background-color: #cccccc;
	border-top: 1px solid #191465;
	text-transform:capitalize;
}

.list td.borderTop {
	border-top:1px solid #999999;
}

/* END TABLE LIST CSS */

*.hover {
	cursor: pointer;
	cursor: hand;
}
.hlt, tr.hlt td, tr.selected td {
	background-color: #fff !important;
	font-style:italic;
}

.notes {
	padding: 10px;
	background-color: #eeeeee;
	border: 1px solid #999999;
	margin-bottom: 10px;
	width: 400px;
}

.notesEdit {
	padding: 10px;
	width: 400px;
}

.clear {
	clear: both;
	height: 5px;
	overflow: hidden;
}

div.float, div.floatHalf {
	float:left;
	margin-right:10px;
}
div.floatHalf {
	width:45%;
}

/* MAIN TRI FLOATS */

div.floatTri {
	float: left;
	width: 31%;
	margin-right: 20px;
	background-image: url(/plugin_assets/substruct/images/public-ui/column-fade-middle.gif);
	background-repeat: repeat-x;
}
div.floatTri h2 {
	text-align: center;
	margin-bottom: 10px;
}

div.floatTri h4 {
	margin-left: 20px;
}

div.floatTri p {
	margin-top: 0px;
	margin-left: 20px;
	margin-right: 20px;
}
div.floatTri form {
	margin-left: 20px;
	margin-right: 20px;
}

.floatTri .left {
	float: left;
	background-image: url(/plugin_assets/substruct/images/public-ui/column-fade-left.gif);
	background-repeat: no-repeat;
	width: 10px;
	height: 150px;
}
.floatTri .right {
	float: right;
	background-image: url(/plugin_assets/substruct/images/public-ui/column-fade-right.gif);
	background-repeat: no-repeat;
	width: 10px;
	height: 150px;
}
.floatTri .middle {
	padding-top: 20px;
}

/* /MAIN TRI FLOATS */


.content_pad {
	padding: 20px;
	padding-top: 0px;
}

.fieldWithErrors input, .fieldWithErrors * option, .fieldWithErrors * {
  background-color: #dddddd;
}

.formError {
	color: red;
	font-style: italic;
	padding-bottom: 5px;
	padding-left: 10px;
}

#ErrorExplanation {
  width: 400px;
  border: 2px solid red;
  padding: 7px;
  padding-bottom: 12px;
  margin-bottom: 20px;
  background-color: #f0f0f0;
}

#ErrorExplanation h2 {
  text-align: left;
  font-weight: bold;
  padding: 5px 5px 5px 15px;
  font-size: 98%;
  margin: -7px;
  background-color: #c00;
  color: #fff;
}

#ErrorExplanation p {
  color: #333;
  margin-bottom: 0;
  padding: 5px;
}

#ErrorExplanation ul li {
  font-size: 98%;
  list-style: square;
}

.inline {
	display:inline;
	clear:none;
	margin-bottom:0px;
}

div.error {
	margin:10px;
	background-color:#FFFF99;
	border:1px solid #804D68;
	font-weight: bold;
	padding: 20px;
	text-align:center;
	color: #804D68;
}
input.error {
	background-color: #FFD3E3;
}
.textInput {
	color: #333;
	line-height: 1em !important;
}

.textInput, .textArea {
	border: 1px solid #7d6a55;
	padding: 2px;
}
.textInput.big {
	border: 2px solid #7d6a55;
	height: 25px;
	color: #8a8075;
	font-size: 110%;
	line-height: 28px;
	padding-top: 7px;
	background-image: url(/plugin_assets/substruct/images/public-ui/input-bg.gif);
	background-repeat: repeat-x;
}


/* CLASSES */
.minor_callout {
	margin-bottom: 20px;
}
.minor_callout p {
}
.main_block {
	margin-bottom: 20px;
	margin-left: 10px;
	margin-right: 10px;
}
.form_block {
	margin: 10px 0px 20px 0px;
	padding: 20px;
	background-image: url(/plugin_assets/substruct/images/public-ui/column-fade-middle.gif);
	background-repeat: repeat-x;
	border-top: 2px solid #ccc;
}
.form_block h2 {
	margin-bottom: 10px;
}
.blog_entry {
	padding: 10px;
}
.blog_entry.even {
	background-color: transparent;
	background-image: url(/plugin_assets/substruct/images/public-ui/column-fade-middle.gif);
}

/* PAGINATION ============================================= */
div.pagination {
	background-color: #EDEDED;
	/*border-top: 2px solid #C5BEBE;*/
	padding: 10px;
	font-size: 105%;
	text-align: right;
	margin: 20px 0px;
}
div.pagination a {
	text-decoration: none;
}
div.pagination a, div.pagination span {
	padding: 5px;
	font-weight: bold;
}
div.p * {
	font-size: 105%;
}

#flash {
	margin: 20px;
	padding: 10px;
	z-index: 100;
	background-color: #B2DF83;
	border: 4px solid #6AC034;
	color: #293F1B;
}
#flash h2 {
	background-color: #6AC034;
	padding: 5px;
	color: #fff;
}
#flash div, #flash .action {
	font-size: 105%;;
	line-height: 1.3em;
}


#container {
	/* Uses negative margin for very compatible centering */
	position: relative;
	left: 50%;
}

#toplinks {
	float: right;
}

#toplinks li {
	margin-left: 15px;
	line-height: 30px;
	float: right;
}

#searchbox {
	float:right;
	clear:right;
	margin-right: 10px;
	margin-top: 10px;
	width: 500px;
}

#searchbox .textInput {
	width: 250px;
}

/* Div that comes before the content */
#preContent {
	height: 83px;
	background-image: ;
	background-repeat: no-repeat;
}

#footer { 
	margin-top: 10px;
}

#footer li {
}

#big_product_image {
	float: left;
	margin: 20px;
	margin-left: 0px;
	margin-top: 0px;
	width: 200px;
	overflow: hidden;
}

#bLeftCol, #bMiddleCol, #bRightCol {
	padding:15px;
	padding-top:20px;
	float:left;
}
#bLeftCol {
	width: 219px !important;
}
#bMiddleCol {
	width: 260px !important;
}
#bRightCol {
	width: 228px !important;
	width:210px;
	overflow:visible !important;
	overflow:hidden;
}

/* Left content container */
#left {
	float:left;
	width: 630px !important;
	width: 610px;
	margin-left: 10px;
	padding-right: 20px;
	margin-right: 20px;
	min-height: 200px;
	margin-bottom: 20px;
}

/* Right content */
#right {
	float:left;
	width: 280px;
	padding-bottom: 20px;
}


#right .textInput {
	font-size: 108%;
	line-height: 108%;
	padding-top: 5px !important;
	padding-top: 10px;
	height: 20px;
}

#right h2 {
	color: #5e5e5e;
}
#right h3 {
	color: #8a8075;
	text-align: center;
}

#left, #right, #fullContent {
}

#fullContent {
	width: auto;
	margin: 0px 10px;
}

#customer_msg {
	position: absolute;
	margin-left: 390px;
	margin-top: 53px;
	background-color: #eee;
	width: 200px;
	padding: 0px 5px;
	height: 40px;
	overflow: hidden;
	color: #999;
}


/* MAIN NAVIGATION BAR */

ul#main_navigation { 
	height: 114px;
	overflow: hidden;
	float: left;
}

#main_navigation li { margin: 0; padding: 0;}

#main_navigation li a:link, #main_navigation li a:visited {
	display: block;
	height: 114px;
	width: 190px;
	text-align: center;
}

#main_navigation li.active { text-transform: uppercase; }

ul#subnavigation {
	height: 40px;
	background-color: #d0c8c8;
	margin-left: 10px;
	margin-right: 10px;
}

#subnavigation li {
	height: 40px;
	margin-left: 15px;
}

#subnavigation li a {
	color: #5e5e5e;
	font-weight: normal;
	font-size: 108%;
	line-height: 45px;
	display: block;
}

#subnavigation li.active {
	font-size: 100%;
	margin-right: 0px;
}

#subnavigation li.active a{
	font-style: italic;
	font-weight: normal;
	padding-right: 15px;
	padding-left: 5px;
}


/* END NAVIGATION */


#submittingText {
	display: none;
	font-weight: bold;
	font-size: 104%;
	color: green;
	padding: 10px;
}


/* HOME PAGE */

#main_callout {
	width: 690px;
	height: 310px;
	float: left;
}
#minor_callouts {
	width: 240px;
	float: right;
}

h1#new_sale_header {
	width: 120px;
	height: 180px;
	padding-top: 20px;
	text-align:center; 
	background-image: url(/plugin_assets/substruct/images/public-ui/new-sale-header-bg.gif);
	background-repeat: no-repeat;
	float: left;
	margin: 0px;
	margin-right: 20px;
	color: #f86d0a;
}

/* 
* ===================================
* ======== FIREFLY CUSTOM STLES =====
* ===================================
*/


/* COLORS & TYPOGRAPHY */

a:link, a:visited { text-decoration: none; }

a:hover { text-decoration: underline; }

a img { border: 0 }

.blue, a:link, a:visited, .highlight { color: #174977; }

.soft_black { color: #1A1A1A; }

.grey, body, p, .grey a:link, .grey a:visited { color: #686065; }

.lightgrey { #E7E7E7; }

#masthead, #main_navigation, #content_body { border-color: #E7E7E7; }

.red { color: #9E3847; }

.green, #cart a:link, #cart a:visited, a.green, a.green:visited { color: #AFC20C; }

.upcase { text-transform: uppercase; }

.lowcase { text-transform: lowercase; }

body { font-size: .7em; }

.small { font-size: 80%; }

.medium { font-size: 110%; }

.big { font-size: 124%; }

.normal { font-style: normal; font-weight: normal; }

.textright { text-align: right !important; }

.textleft { text-align: left !important; }

.push_right { float: right; text-align: right; }

.valign, .valign * {
	vertical-align: middle;
}


/* STRUCTURE */

#container {
	width: 768px;
	margin: 10px 0 0 -384px;
}

#masthead, #masthead .replaceable_image, #main_navigation {
	width: 762px;
}

#masthead {
	height: 180px;
	padding-top: 1px;
	position: relative;
}

#home_page #masthead {
	height: 302px;
}

#masthead h1, #masthead h2 { padding: 30px; } /* While image loads */

#masthead, #main_navigation, #content_body { 
	border-width: 2px;
	border-style: solid;
}

#masthead, #main_navigation { border-bottom: 0; }

#content_body, #main_navigation { border-top: 0; }


#content_body { 
	padding: 40px 40px;
	width: 682px;
	clear: both;
}

.block { display: block }

.clear { clear: both; }

/* IMAGES */

#masthead .replaceable_image {
	position: absolute;
	top: 0; left: 0;
	height: 180px;
	background: #ccc url(/images/firefly_banner.png) no-repeat;
}

#home_page #masthead .replaceable_image {
	height: 302px;
	background: #ccc url(/images/firefly_banner-full.png) no-repeat;
}


#main_navigation {
	background: url(/images/firefly_navigation.png) no-repeat 0 -114px;
}

#main_navigation li a:link, #main_navigation li a:visited { 
	text-indent: -99999px;
	background-image: url(/images/firefly_navigation.png);
	background-repeat: none;
}

li#about a:link, li#about a:visited {
	background-position: 0px 0px;
}

li#about a:hover, li#about.active a {
	background-position: 0px -114px
}

li#faq a:link, li#faq a:visited {
	background-position: -190px 0px;
}

li#faq a:hover, li#faq.active a {
	background-position: -190px -114px
}

li#store a:link, li#store a:visited {
	background-position: -380px 0px;
}

li#store a:hover, li#store.active a {
	background-position: -380px -114px
}

li#news a:link, li#news a:visited {
	background-position: -570px 0px;
}

li#news a:hover, li#news.active a {
	background-position: -570px -114px
}

#toplinks #contact { 
	padding-left: 35px;
	background: #fff url(/images/three_squares_icon.png) no-repeat left center;
}

#toplinks #cart { 
	padding-left: 25px;
	background: #fff url(/images/shopping_cart_icon.png) no-repeat left center;
}

#sidebar {
	float: right;
	text-align: right;
	margin: 0 20px 0 0;
	padding: 0;
	text-transform: uppercase;
}

#sidebar h3  { 
	font-weight: bold; 
	width: 160px;
	overflow: hidden;
}

.narrow_column { 
	float: right;
	width: 450px;
}


/* PRODUCT LIST ITEM */

#store_intro { 
	padding-top: 0; 
	padding-bottom: 30px;
}

#store_intro, #product_list .product {
	border-bottom: 1px dotted #333;
	padding: 0 0 40px 0;
	margin-bottom: 10px;
}

ul#product_list li, ul#sidebar li {
	list-style-type: none;
	margin:0; padding:0; 
}

#product_list ul li {
 	list-style-type: square;
	margin: 5px 20px;
}

table.product_meta {
	width: 100%;
	margin: 10px 0;
}


table.product_meta td {
	vertical-align: middle;
	line-height: 100%;
	color: #000;
}

.money { font-weight: bold; }

.button {
	padding: 5px;
	cursor: pointer;
	cursor: hand;
	display:block;
}

.add_to_cart, .checkout, .continue_shopping, .update_cart, .remove_from_cart {
	border: 0px;
	overflow: hidden;
}

.add_to_cart {
	background: url(/images/add_to_cart_button.png) no-repeat !important;
	width: 112px;
	height: 29px;
	text-indent: -9999em;
}

.checkout {
	background: url(/images/checkout_button.png) no-repeat !important;
	width: 92px;
	height: 27px;
	text-indent: -9999em;
}

.continue_shopping {
	background: url(/images/continue_shopping_button.png) no-repeat !important;
	width: 156px;
	height: 31px;
	text-indent: -9999em;
	margin-top: -2px; /* TEMP */
}

.update_cart {
	background: url(/images/update_cart_button.png) no-repeat !important;
	width: 120px;
	height: 29px;
	text-indent: -9999em;
}

.remove_from_cart {
	padding: 6px 0 6px 30px;
	background: url(/images/remove_from_cart_button.gif) no-repeat left center;
	text-indent: -9999em;
}

.product {
}

.product_image img {
	width: 450px;
	height: 130px;
}

.product_title {
	font-size: 140%;
	font-weight: bold;
}
td.money {
	width: 280px;
 	text-align: left;
}

td.quantity {
	width: 100px;
	text-align: right;
}

td.add_to_cart {
	width: 120px;
	text-align: right;
}

.add_to_cart input { 
	margin-left: 8px;
}

.product_desc {
	clear: both;
}
.product .icon {
	margin-left: 20px;
	z-index:300;
}

/* FAQ */

#faq_page p { 
  padding-top: 0; 
  margin-top: 0;
  margin-bottom: 10px;
}

