/* GENERAL ELEMENTS */
body {
	background-color: #fff;
	color: #333;
	font-family: "Lucida Grande", Trebutchet, Verdana, san-serif;
	font-size: 1em;
	margin: 25px 50px 0 50px;
	padding: 0;
}

a:link, a:visited {
	color: #036;
	text-decoration: underline;
}

a:hover {
	color: #39f;
	text-decoration: none;
}

h1 {
	font-size: 1.5em;
	color: #333;
	margin: 0 0 15px 0;
	padding: 0 0 15px 0;
	border-bottom: 3px solid #f1f1f1;
}

h2 {
	font-size: 1.2em;
	color: #333;
	margin: 0 0 15px 0;
}

/* COLORS */
.red   { color: #900; }
.blue  { color: #036; }
.green { color: #690; }
.grey  { color: #333; }
.lightgrey { color: #ccc; }

/* HEADER */
#KMHeader {
	margin-bottom: 25px;
	position: relative;
}

#KMHeader #KMHeaderInfo {
	position: absolute;
	top: 10px;
	right: 0;
	margin: 0;
	padding: 0;
	list-style-type: none;
}

.KMHeaderInfoContainer {
	float: left;
	padding: 0 20px 0 20px;
}

.KMHeaderInfoName {
	font-family: Georgia, serif;
	font-size: 0.8em;
	color: #999;
	text-transform: uppercase;
	letter-spacing: 0.25em;
}

.KMHeaderInfoValue {
	font-family: Georgia, serif;
	font-size: 1.5em;
	color: #690;
}

.KMHeaderInfoContainer a {
	font-family: Georgia, serif;
	font-size: 1.5em;
	text-decoration: none;
}

.KMHeaderInfoContainer a:link, a:visited {
	color: #333;
}

.KMHeaderInfoContainer a:hover {
	color: #690;
}


/* MENUBAR */
#KMMenuBar {
	margin-bottom: 35px;
	height: 64px;
	background-image: url("/img/menubar_bkgrnd.png");
	background-repeat: repeat-x;
	min-width: 1060px;
}

#KMMenuBar ul {
	list-style-type: none;
	margin: 0;
	padding: 0;
}

#KMMenuBar li {
	float: left;
	border-right: 1px solid #fff;
}

#KMMenuBar a {
	display: block;
	font-family: Georgia, serif;
	font-size: 1.2em;
	letter-spacing: 0.05em;
	width: 175px;
	height: 60px;
	margin: 0;
	padding: 0;
	text-decoration: none;
}

#KMMenuBar a:link, #KMMenuBar a:visited {
	background-color: #caeeff;
	border-top: 3px solid #036;
	color: #036;
}

#KMMenuBar a:hover {
	background-color: #D0E8AE;
	border-top: 3px solid #690;
	color: #360;
}

#KMMenuBar a.current:link, #KMMenuBar a.current:visited {
	background-color: #D0E8AE;
	border-top: 3px solid #690;
	color: #360;
}

.KMMenuBarText {
	padding: 20px 15px 0 60px;
}

#KMMenuBarHome { 
	background-image: url("/img/icons/32/home.png"); 
	background-repeat: no-repeat; 
	background-position: 15px 15px; 
	border-bottom: 1px solid #ccc;
}

#KMMenuBarChores { 
	background-image: url("/img/icons/32/clean.png"); 
	background-repeat: no-repeat; 
	background-position: 15px 15px; 
	border-bottom: 1px solid #ccc;
}

#KMMenuBarWishlist { 
	background-image: url("/img/icons/32/clipboard.png"); 
	background-repeat: no-repeat; 
	background-position: 15px 15px; 
	border-bottom: 1px solid #ccc;
}

#KMMenuBarPurchases { 
	background-image: url("/img/icons/32/moneybag.png"); 
	background-repeat: no-repeat; 
	background-position: 15px 15px; 
	border-bottom: 1px solid #ccc;
}

#KMMenuBarAccount { 
	background-image: url("/img/icons/32/star.png"); 
	background-repeat: no-repeat; 
	background-position: 15px 15px; 
	border-bottom: 1px solid #ccc;
}

#KMMenuBarKids { 
	background-image: url("/img/icons/32/heart.png"); 
	background-repeat: no-repeat; 
	background-position: 15px 15px; 
	border-bottom: 1px solid #ccc;
}

#KMMenuBarLogout { 
	background-image: url("/img/icons/32/lock.png"); 
	background-repeat: no-repeat; 
	background-position: 15px 15px; 
	border-top: 3px solid #036;
	border-bottom: 1px solid #ccc;
}

/* CONTENT */
#KMContent {
	margin-bottom: 50px;
}

/* LEFT COLUMN */
.KMLeftColumn {
	margin-right: 430px;
}

/* RIGHT COLUMN */
.KMRightColumn {
	position: absolute;
	top: 123px;
	right: 50px;
	width: 350px;
	padding: 20px;
}

/* FOOTER */
#KMFooter {
	background-color: #f1f1f1;
	border-top: 3px solid #ccc;
	padding: 20px;
	margin-top: 50px;
}

#KMFooter ul {
	margin: 0;
	padding: 0;
	list-style-type: none;
}

#KMFooter ul li {
	display: inline;
	padding-right: 25px;
}

#KMFooter ul li a {
	font-size: 1em;
	text-decoration: none;
}

#KMFooter ul li a:link, #KMFooter ul li a:visited {
	color: #036;
}

.KMFooter ul li a:hover {
	color: #39f;
}

/* ICONS */
.KMIcon {
	margin-right: 10px;
	vertical-align: bottom;
}

/* FORMS */
form {
	margin: 0 0 15px 0;
	padding: 0;
}

label {
	color: #036;
	display: block;
	margin-bottom: 5px;
}

form .KMFormElement {
	margin-bottom: 20px;
}

form input[type="text"], form input[type="password"], form select, form textarea
{
	font-family: "Lucida Grande", Trebutchet, Verdana, san-serif;
	font-size: 1em;
	background-color: #f1f1f1;
	color: #666;
    font-size: 100%;
	padding: 7px;
	margin-right: 5px;
    border: solid 2px #ccc;
    width: 250px;
}

form input[type="text"]:focus, form input[type="password"]:focus, form select:focus, form textarea:focus
{
	background-color: #fff;
	font-family: "Lucida Grande", Trebutchet, Verdana, san-serif;
	font-size: 1em;
	color: #666;
	font-size: 100%;
    padding: 7px;
	margin-right: 5px;
    border: solid 2px #690;
    width: 250px;
    outline: none;
}

form textarea {
	width: 500px;
}

form textarea:focus {
	width: 500px
}

form select {
	width: 270px;
}

form select:focus {
	width: 270px;
}

/* BUTTONS */
.KMButtons {
	margin-bottom: 70px;
}

.KMTabular .KMButtons {
	margin-bottom: 35px;
}

.KMButtons:focus { outline: none; }
.KMButtons:active { outline: none; }

.KMButtons a, .KMButtons button {
    display: block;
    float: left;
    margin: 0 7px 0 0;
    background-color: #f5f5f5;
    border: 2px solid #ccc;
    font-family: "Lucida Grande", Tahoma, Arial, Verdana, sans-serif;
    font-size: 100%;
    line-height: 130%;
    text-decoration: none;
    font-weight: bold;
    color: #369;
    cursor: pointer;
	outline: none;
    padding: 6px 10px 7px 7px; /* Links */
    white-space: nowrap;
}
.KMButtons button {
    width: auto;
    overflow: visible;
    padding: 5px 10px 4px 7px; /* IE6 */
}
.KMButtons button[type] {
    padding: 6px 10px 6px 7px; /* Firefox */
    line-height: 19px; /* Safari */
}
*:first-child+html button[type]{
    padding: 5px 10px 4px 7px; /* IE7 */
}
.KMButtons button img, .KMButtons a img {
    margin: 0 4px -3px 0 !important;
    padding: 0;
    border: none;
    width: 24px;
    height: 24px;
}

/* BUTTONS: STANDARD */
button:hover, .KMButtons a:hover {
    background-color: #caeeff;
    border: 2px solid #84C2FF;
    color: #369;
}
.KMButtons a:active {
    background-color: #6299c5;
    border: 2px solid #6299c5;
    color: #fff;
}

/* BUTTONS: POSITIVE */
button.positive, .KMButtons a.positive {
    color: #529214;
}
.KMButtons a.positive:hover, button.positive:hover {
    background-color: #E6EFC2;
    border: 2px solid #690;
    color: #529214;
}
.KMButtons a.positive:active {
    background-color: #529214;
    border: 2px solid #690;
    color: #fff;
}

.KMButtons a.positiveselected {
    background-color: #529214;
    border: 2px solid #690;
    color: #fff;
}

/* BUTTONS: NEGATIVE */
.KMButtons a.negative, button.negative {
    color: #d12f19;
}
.KMButtons a.negative:hover, button.negative:hover {
    background: #fbe3e4;
    border: 2px solid #fbc2c4;
    color: #d12f19;
}
.KMButtons a.negative:active {
    background-color: #d12f19;
    border: 1px solid #d12f19;
    color: #fff;
}

.KMButtons a.negativeselected {
    background-color: #d12f19;
    border: 1px solid #d12f19;
    color: #fff;
}

/* TABLES */
table.KMTabular {
	border: 2px solid #ccc;
	margin-bottom: 15px;
	border-collapse: collapse;
	color: #333;
	text-align: left;
	width: 100%;
}

table.KMTabular thead tr {
	border: 2px solid #ccc;
	background-color: #f1f1f1;
}

table.KMTabular thead th {
	padding: 15px;
	border-collapse: collapse;
}

table.KMTabular tbody tr {
	background-color: #fff;
}

table.KMTabular tbody tr:hover {
	background-color: #FCFFE7;
}

table.KMTabular td {
	border-bottom: 1px dotted #ccc;
	padding: 10px;
	border-collapse: collapse;
}

.KMTHHorizontal {
	color: #333;
	text-align: left;
	background-color: #f1f1f1;
	border-right: 1px dotted #ccc;
	border-bottom: 1px dotted #ccc;
	padding: 10px;
}

.KMTDHorizontal {
	color: #333;
	text-align: left;
	background-color: #fff;
	border-bottom: 1px dotted #ccc;
	padding: 10px;
}

.KMTabularIndex {
	border-spacing: none;
	padding: 0;
	margin:0;
}

.KMTabularIndex td {
	border-collapse: collapse;
	padding: 0;
	margin:0;
	border-spacing: none;
	vertical-align: top;
	border: 1px solid #fff;
}

/* Modal Box */
.KMModalBoxWrapper {
	display: none;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 10;
	padding: 5px;
	border: 1px solid #333;
	background-color: #fff;
	width: 850px;
}

.KMModalBoxSubWrapper {
	border: 1px solid #333;
}

#KMModalBoxClose {
	position: absolute;
	right: 20px;
	top: 20px;
}

#KMModalBoxOverlay {
	background-color: #000;
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	z-index: 5;
}

.KMModalBoxHeader {
	padding: 20px;
	background-color: #333;
}

.KMModalBoxHeader h1 {
	color: #fff;
}

.KMModalBoxContent {
	background-color: #fff;
	padding: 20px;
}

/* ERRORS */
.KMBlockError {
	background-color: #FBE3E4;
	border-top: 2px solid #FF9A9F;
	border-bottom: 2px solid #FF9A9F;
	color: #900;
	font-size: 1.1em;
	padding: 10px 20px 10px 20px;
	margin-bottom: 15px;
}

.KMInlineError {
	color: #900;
}

/* Confirmations */
.KMBlockConfirmation {
	background-color: #E6EFC2;
	border-top: 2px solid #690;
	border-bottom: 2px solid #690;
	color: #690;
	font-size: 1.1em;
	padding: 10px 20px 10px 20px;
	margin-bottom: 15px;
}

/* PAGINATION */
.paging div {
	display: inline;
}

/* ROUNDED BOX */
.KMRounded {
	-moz-border-radius: 1em;
	-webkit-border-radius: 1em;
	padding: 20px;
	background-color: #f1f1f1;
	border: 2px solid #ccc;
	margin-bottom: 20px;
}

/* OVERWRITING CAKE STUFF */
.error-message { color: #900; display: inline;}





/* Calendar: a Javascript class for Mootools that adds accessible and unobtrusive date pickers to your form elements <http://electricprism.com/aeron/calendar> */
/* Default CSS for Calendar (navigation: 1), Copyright (c) 2007 Aeron Glemann <http://electricprism.com/aeron> */









.hidden {
	opacity: 0;
	position: absolute;
}
.visible {
	opacity: 1;
}


input.calendar,
select.calendar {
	width: 99px;
}

button.calendar {
	background: url("../img/icons/32/calendar.png");
	background-repeat: no-repeat;
	background-position: top left;
	width: 32px;
	height: 32px;
	border: 0;
	cursor: pointer;
	margin: 0;
	padding: 0;
}
button.calendar:hover,
button.calendar.active {
	
}

div.calendar {
	background: #fff;;
	height: 195px;
	padding: 0 6px;
	text-align: center;
	width: 175px;
	border: 1px solid #ccc;
	font-size: 0.8em;
}	
	div.calendar * {
		margin: 0;
		padding: 0;
	}	
	div.calendar div {
		background: none !important;
		cursor: move;
		height: 185px;
		overflow: hidden;
		padding-top: 10px;
		position: relative;
		width: 175px;
	}	
	
	div.calendar caption {
		color: #333;
		padding: 12px 0 8px 0;
		text-align: center;
		width: 100%;
	}
	div.calendar caption a {
		cursor: pointer;
		display: block;
		height: 12px;
		overflow: hidden;
		position: absolute;
		text-indent: -100px;
		top: 17px;
		width: 11px;
	}
	div.calendar caption a.prev {
		background-image: url("../img/icons/24/left.png");
		background-repeat: no-repeat;
		background-position: top left;
		left: 0;
		width: 24px;
		height: 24px;
	}
	div.calendar caption a.next {
		background-image: url("../img/icons/24/right.png");
		background-repeat: no-repeat;
		background-position: top left;
		right: 0;
		width: 24px;
		height: 24px;
	}
	div.calendar caption a:hover {
		
	}
	div.calendar caption span {
		height: 25px;
		position: relative;
		text-align: center;
	}
	div.calendar caption span.month {
		padding-right: 8px;
	}
	div.calendar caption span.month:after {
		
	}

	div.calendar table {
		background: #FFF;
		border: 0;
		border-collapse: collapse;
		border-spacing: 0;
		cursor: default;
		margin: 0 auto;
		overflow: hidden;
		width: 175px;
	}
	div.calendar td,
	div.calendar th {
		border: 0;
		color: #0597DB;
		
		height: 21px;
		text-align: center;
		width: 21px;
	}
	div.calendar td {
		background: url(calendar-td.gif);
		background: #f1f1f1;
		color: #ccc;

	}
	div.calendar td.invalid {
		color: #999;
	}
	div.calendar td.valid {
		background: url(calendar-valid.gif);
		background: #caeeff;
		color: #0597DB;
		cursor: pointer;
	}
	div.calendar td.hilite {
		background: url(calendar-hilite.gif);
		background: #ffc;
	}
	div.calendar td.inactive {
		background: url(calendar-td.gif) 0 100%;
		color: #FFF;
		background: #fff;
	}
	div.calendar td.active,
	div.calendar td.hover {
		background: url(calendar-valid.gif) 0 100%;
		background: #036;
		color: #FFF;
		cursor: pointer;
	}

