/* Tag Base Styles */
* {
	margin: 0;
	padding: 0;
}

html, body, #wrap {
	height: 100%;
}

body > #wrap {
	height: auto;
	min-height: 100%;
}

div.round {
	padding: 15px;
	border-style: solid;
	-moz-border-radius: 20px;
	-webkit-border-radius: 20px;
}

#content {
	padding-top: 10px;
	padding-bottom: 50px;
}

a {
	text-decoration: none;
}

h1 {
	text-align: left;
	padding: 0;
}

h2 {
	margin-top: 5px;
}

h3 {
	margin-top: 15px;
	border-bottom-style: dotted;
	border-bottom-width: 1px;
}

img {
	border: 0;
}

/* Common Class Styles */
.container {
	margin: 0 auto;
	max-width: 50em;
}
.right {
	float: right;
}
.left {
	float: left;
}
.clear {
	clear: both;
	visibility: hidden;
	width: 0;
	height: 0;
}
.clear hr {
	display: none;
}
.error, .notice {
	padding: 5px;
	border-style: solid;
	border-width: 1px;
}
.validator {
	margin: 5px;
	padding: 3px;
	border-style: solid;
	border-width: 1px;
}

.hilite-top {
	border-style: none solid none solid;
	padding: 15px;
}
/*
.hilite-bottom {
	border-width: 1px;
	border-style: none solid solid solid;
	-moz-border-radius-bottomleft: 20px;
	-moz-border-radius-bottomright: 20px;
	-webkit-border-bottom-left-radius: 20px;
	-webkit-border-bottom-right-radius: 20px;
}
*/
/* Common ID Styles */
#header {
	min-width: 53em;
}

#header h1 a {
	float: left;
	padding-top: 20px;
	padding-left: 20px;
	padding-bottom: 20px;
}

#header ul {
	float: right;
	margin: 20px;
	padding: 0px;
}

#twitter {
--	margin-top: 30px;
	width: 36px;
	height: 36px;
}

#menu {
	border-style: solid;
	border-width: 1px;
}

#menu li {
	float: left;
	list-style-type: none;
}

#menu a {
	display: block;
	border-width: 1px;
	border-style: solid;
}

#content {
	margin: 0 auto;
	min-width: 50em;
}

#welcome, #articles {
	margin: 10px auto;
	max-width: 50em;
}

#footer {
	margin-top: -20px;
	height: 20px;
	position: relative;
	text-align: center;
}

/* Welcome */
#welcome-summary, #articles-snippets {
	border-width: 3px;
	border-style: solid;
}

#welcome-service {
	padding: 0 20px;
	min-height: 14em;
	max-height: 14em;
}

div.hilite {
	margin: 0 5px;
	float: left;
	max-width: 15.2em;
	min-height: 16em;
}

div.hilite a {
	min-height: 2em;
	max-height: 2em;
	border-style: solid;
	border-width: 1px 3px 3px 3px;
	-moz-border-radius-bottomleft: 20px;
	-moz-border-radius-bottomright: 20px;
	-webkit-border-bottom-left-radius: 20px;
	-webkit-border-bottom-right-radius: 20px;
	text-align: center;
	padding: 10px 5px 5px 5px;
	display: block;
}

/* Articles */
#articles-header .round {

}

div.article {
	margin-top: 15px;
}

#articles h2 {
	margin-bottom: 15px;
}

div.article-heading {
	border-bottom-style: dotted;
	border-bottom-width: 1px;
}

div.article-heading a {
	display: block;
}

div.article-heading .left {
	width: 80%;
}

div.article-controls a {
	display: inline;
}

div.article-heading {
	min-height: 20px;
}

#articles span.article-title {
	padding: 5px 5px 5px 10px;
}

#articles span.article-date {
	padding: 5px;
}

#articles span.article-body {
	padding: 10px;
}

.article-content {
	padding: 10px;
	-moz-border-radius-bottomleft: 10px;
	-moz-border-radius-bottomright: 10px;
	-webkit-border-bottom-left-radius: 10px;
	-webkit-border-bottom-right-radius: 10px;
}

.article code {
	display: block;
	border: 1px dashed;
	padding: 10px;
	margin-top: 10px;
	margin-bottom: 10px;
}

/* Products */
.round {
	border-style: solid;
	-moz-border-radius: 10px;
	-webkit-border-radius: 10px;
}

.round-left {
	border-style: solid none solid solid;
	-moz-border-radius-topleft: 10px;
	-moz-border-radius-bottomleft: 10px;
	-webkit-border-top-left-radius: 10px;
	-webkit-border-bottom-left-radius: 10px;
}

.round-right {
	border-style: solid solid solid none;
	-moz-border-radius-topright: 10px;
	-moz-border-radius-bottomright: 10px;
	-webkit-border-top-right-radius: 10px;
	-webkit-border-bottom-right-radius: 10px;
}

.round-top-right {
	border-style: solid solid solid none;
	-moz-border-radius-topright: 10px;
	-webkit-border-top-right-radius: 10px;
}

.round-bottom-right {
	-moz-border-radius-bottomright: 10px;
	-webkit-border-bottom-right-radius: 10px;
}

.product-content a, .product-purchase, .product .round-right {
	height: 100px;
}

.product a {
	display: block;
}

.product img {
	margin: 5px;
	width: 57px;
	height: 57px;
	float: left;
}

.product-content {
	float: left;
	width: 80%;
}

.product-abstract {
	padding: 5px;
}

.product-purchase {
	float: right;
	width: 20%;
}

.product .round-top-right, .product .round-bottom-right {
	height: 50px;
}

.product-free, .product-price {
	text-align: center;
	width: 100%;
}

.section-heading {
	margin-left: 10px;
}

.product-content a {
	border-style: solid;
	border-width: 1px;
}

.product .round-top-right {
	border-style: solid solid none none;
	border-width: 1px;
}

.product .round-bottom-right {
	border-style: none solid solid none;
	border-width: 1px;
}

.product .round-right {
	border-style: solid solid solid none;
	border-width: 1px;
}

.section {
	margin: 10px;
}

/*
#products {
	
}

#products a {
	display: block;
}

.product img, .product-content, .product-price {
	border: 1px solid;
}

div.product {
	margin-top: 10px;
}

.product img, .product-content {
	float:left;
}

.product-content {
	max-width: 20em;
}

.product img, .product-price {
	width: 100px;
	height: 100px;
}

.product-price {
	float: right;
	width: 100px;
}
*/

/* Services */
#services ul {
	margin-top: 15px;
	margin-left: 15px;
}

/* Contact Info */
table.contact {
	margin: 0 auto;
	padding: 30px;
}

table.contact th {
	text-align: center;
	border-bottom-style: solid;
	border-bottom-width: 1px;
}

table.contact td {
	text-align: left;
	vertical-align: top;
	padding: 15px 20px;
}

/* iPhone */
#iphone {
	padding: 10px;
}

#iphone div {
	margin-top: 10px;
}

#iphone a, #iphone a:hover {
	padding: 10px;
}

#iphone a {
	display: block;
}

#iphone a:hover {
	border-style: solid;
}

#iphone img {
	float: left;
	margin:15px;
}

/* Login */
#login form div {
	visibility: hidden;
}