/**********************
 *
 * All font sizing in ems.
 * Funny thing happens at 75% and lower. opera goes to a nice small size, but moz and ie pc
 * change almost not at all. seems 76% is as small as you can go and stay the same across browsers.
 * :(
 */

/***********************
 *
 * These setting 'level ' the playing field so that all browsers start with the same defaults
 */

/* Removes margin and padding from every element. */
* {
	margin:0; 
	padding:0
}

html {
	height:100%; 
	font-size:100.01%
}

/*
min-height:
	Sets the minimum page height to greater than the window height to force Netscape & 
	Firefox to display vertical scrollbars, thereby preventing content jumping on fixed width pages.
	IE doesn't understand min-height and totally ignores this setting.
font:
	Set font-size to a percentage preventing a Windows IE "extreme font re-sizing" bug.
	Set font-size slightly larger than 100% to repair Opera rounding errors.
	Set less than 101% to prevent Safari errors.
	The line-height setting gives nice, clear and easy-read spacing.
text-align: center
	Added to the body element to force IE to centre all content
*/
body { 
	text-align: left;
	min-height: 101%;
	font: 100.01% Arial, Verdana, Helvetica, sans-serif; 
	background: #FFFFFF;
	width: 100%; 
	margin: 0 auto;
	font-size: 0.71em;
	color: #333333;
}
table {
	border-spacing: 0;
	border-collapse: collapse;
}
table td {
	text-align: left;
	vertical-align: baseline;
}
/* moz 1.0/1.1/1.2.1, net 7.0/7.01 make this way too small, but i'm not going to go larger because
 monospace tends to run you into overflow pretty quick. prior moz and net are okay.
 */
pre {
	font-family: monospace;
	font-size: 1.0em;
}

strong, b {
	font-weight: bold;
}

/* general use */
@media screen {
	img.printOnly { display: none; }
	span.printOnly { display: none; }
	div.printOnly { display: none; }
	img.screenOnly { display: inline; }
	span.screenOnly { display: inline; }
	div.screenOnly { display: block; }
}
@media print {
	img.printOnly { display: inline; }
	span.printOnly { display: inline; }
	div.printOnly { display: block; }
	img.screenOnly { display: none; }
	span.screenOnly { display: none; }
	div.screenOnly { display: none; }
}

/* no borders for image links */
a img {
	border: 0;
}
.hideVisited a:visited,
.hideVisited a:active,
a.hideVisited:visited,
a.hideVisited:active {
	color: blue;
}

img.quickPick {
	width: 14px;
	height: 14px;
	position: relative; top: 6px;
}

/*******************
 *
 * Project specific common stuff starts here
 */

/*******************
 * header nav
 */
div.banner img.school {
	margin: 4px 0px 2px 3px;
	height: 39px;
}
div.banner h1 {
	margin: 0px 0px 4px 3px;
	padding: 0;
}
div.banner img.ptomgr {
	float: right;
	margin: 22px 25px 0px 0px;
}
div.header {
	background: #ECF2D9;
	border-top: 1px solid #D6D3CE;
	border-bottom: 1px solid #D6D3CE;
	padding: 0.1em 0.6em;
	color: #545454;
}
div.header a:link,
div.header a:visited {
	text-decoration: none;
	color: #545454;
}
div.header a:hover,
div.header a:active {
	color: #999999;
}
div.header div.nav {
	float: right;
	font-weight: bold;
}
table.level1Tab {
	width: 100%;
	color: white;
	background: #3380BD;
}
table.level1Tab td {
	white-space: nowrap;
	color: white;
	border: 1px solid #D6D3CE;
	border-top: 0;
}
table.level1Tab td.focus {
	background: #D6E7F7;
	border-bottom: 1px solid #D6E7F7;
	padding: 0.3em 1.5em;
	font-weight: bold;
	color: #3380BD;
}
table.level1Tab td.path {
	background: #D6E7F7;
	border-bottom: 1px solid #D6E7F7;
	font-weight: bold;
}
table.level1Tab td.path a:link,
table.level1Tab td.path a:visited,
table.level1Tab td.path a:hover,
table.level1Tab td.path a:active {
	text-decoration: none;
	display: block;
	padding: 0.3em 1.5em;
	color: #3380BD;
}
table.level1Tab td.off a:link,
table.level1Tab td.off a:visited,
table.level1Tab td.off a:hover,
table.level1Tab td.off a:active {
	text-decoration: none;
	display: block;
	padding: 0.3em 1.5em;
	font-weight: bold;
	color: white;
}
table.level1Tab td.path a:hover,
table.level1Tab td.path a:active,
table.level1Tab td.off a:hover,
table.level1Tab td.off a:active {
	background-color: #D6D3CE;
}
table.level1Tab td.about {
	width:90%;
	text-align: right;
	padding: 0.3em 1.5em;
}
table.level1Tab td.about a:link,
table.level1Tab td.about a:visited {
	font-weight: bold;
	color: white;
}
table.level1Tab td.about a:hover,
table.level1Tab td.about a:active {
	color: #D6D3CE;
}
table.level2Tab {
	width: 100%;
	background: #D6E7F7;
}
table.level2Tab td {
	white-space: nowrap;
	color: #545454;
	border-top: 1px solid #D6E7F7;
	border-bottom: 1px solid #D6D3CE;
}
table.level2Tab td.focus {
	background: white;
	border: 1px solid #D6D3CE;
	border-bottom: 1px solid white;
	padding: 0.3em 1.5em;
	font-weight: bold;
}
table.level2Tab td.path {
	background: white;
	border: 1px solid #D6D3CE;
	border-bottom: 1px solid white;
	font-weight: bold;
}
table.level2Tab td.path a:link,
table.level2Tab td.path a:visited,
table.level2Tab td.path a:hover,
table.level2Tab td.path a:active {
	text-decoration: none;
	display: block;
	padding: 0.3em 1.5em;
	color: #545454;
}
table.level2Tab td.off a:link,
table.level2Tab td.off a:visited,
table.level2Tab td.off a:hover,
table.level2Tab td.off a:active {
	text-decoration: none;
	display: block;
	padding: 0.3em 1.5em;
	font-weight: bold;
	color: #545454;
}
table.level2Tab td.path a:hover,
table.level2Tab td.path a:active,
table.level2Tab td.off a:hover,
table.level2Tab td.off a:active {
	background-color: #D6D3CE;
}
table.level2Tab td.about {
	width:90%;
	text-align: right;
	padding: 0.3em 1.5em;
}
/*******************
 * print header nav - only shown on the screen
 */
div.headerPrint {
	display: none;
}

/*******************
 *
 * mainPage layout
 */
table.mainPage {
	width: 100%;
}
table.mainPage td#leftPanel {
	width: 120px;
	vertical-align: top;
}
table.mainPage td#page {
	padding-left: 10px;
	padding-right: 10px;
	vertical-align: top;
}
table.mainPage td#rightPanel {
	width: 230px;
	vertical-align: top;
}

/*******************
 *
 * leftPanel design
 * only uses line elements of content
 */
table.mainPage td#leftPanel {
	font-size: 0.95em;
}
table.mainPage td#leftPanel p {
	margin-top: 1.2em;
	margin-bottom: 1.2em;
}
table.mainPage td#leftPanel div {
	border: 1px solid #D6D3CE;
	border-left: 0;
	padding-left: 8px;
	padding-right: 6px;
}
table.mainPage td#leftPanel div.nav {
	font-weight: bold;
}
table.mainPage td#leftPanel div.links {
	border-top: 1px solid #D6D3CE;
	background: #D6D3CE;
	font-weight: bold;
}
table.mainPage td#leftPanel div.adminNavHeader {
	padding-top: 0.4em;
	padding-bottom: 0.3em;
	font-weight: bold;
	background: #D6E7F7;
	text-align: center;
	color: #545454;
}
table.mainPage td#leftPanel div.adminNav {
	border-top: 1px solid #ECF2D9;
	color: #545454;
}
table.mainPage td#leftPanel div.editMode {
	border-top: 1px solid #ECF2D9;
	font-weight: bold;
	text-align: center;
	color: #545454;
}

/*******************
 *
 * rightPanel design
 * only uses line elements of content
 */
table.mainPage td#rightPanel {
	font-size: 0.95em;
	color: #545454;
	padding-right: 10px;
}
table.mainPage td#rightPanel p {
	margin-top: 0.8em;
	margin-bottom: 0.8em;
}
table.mainPage td#rightPanel input.button {
	text-align: center;
	font-weight: bold;
	font-size: 0.9em;
	color: #333333;
	padding: 0.05em 0.4em;
	margin: 1.0em 0em 1.0em 0em;
}
table.mainPage td#rightPanel div {
	border: 1px solid #D6D3CE;
	padding-left: 16px;
	padding-right: 20px;
}
table.mainPage td#rightPanel div.signIn {
	background: #D6E7F7;
	padding-left: 8px;
	padding-right: 8px;
	padding-bottom: 14px;
}
table.mainPage td#rightPanel div.signIn h1 {
	text-align: center;
	padding: 0.8em 0;
}
table.mainPage td#rightPanel div.body {
	background: white;
	border: 0;
}
table.mainPage td#rightPanel div.forms {
	background: white;
	border: 0;
	padding: 0;
}
table.mainPage td#rightPanel div.box {
	border-top: 1px solid white;
}

/*******************
 *
 * default design
 */
h1 {
	margin-top: 0.0em;
	margin-bottom: 0.5em;
	font-size: 1.12em;
	font-weight: bold;
	color: #545454;
}
h1 em {
	font-size: 1.25em;
	font-style: normal;
	color: #3380BD;
}
h2 {
	margin-top: 0.5em;
	font-size: 1.09em;
	font-weight: bold;
	color: #545454;
}
h3 {
	margin-top: 0.5em;
	font-size: 1.05em;
	font-weight: bold;
	color: #545454;
}
hr {
	color: black;
	background-color: black;
	height: 1px;
	width: 80%;
	margin: 0 auto;
}
p {
	margin-top: 0.4em;
	margin-bottom: 0.4em;
}
strong, b {
	font-weight: bold;
}
big {
	font-size: 1.2em;
}
small {
	font-size: 0.8em;
}
/* we need the clear because of the #^$@$&^% strange standards for CSS2 floating around boxes */
ul {
	margin-top: 0.4em;
	margin-bottom: 0.4em;
	clear: left;
}
ol {
	margin-top: 0.4em;
	margin-bottom: 0.4em;
	clear: left;
}
li {
	margin-left: 2.0em; 
}
ul li {
	margin-left: 1.4em; 
}
span.copyImage img {
	float: left;
	margin-right: 0.5em;
}
/* display tables design
 */
table.summary {
	color: #545454;
	font-weight: bold;
	font-size: 1.05em;
	text-align: center;
}
table.summary td {
	padding: 0.8em 3.0em;
	border: 1px solid #D6D3CE;
}
table.summary td.number {
	text-align: right;
}
table.summary td.line {
	text-align: left;
}

/*******************
 *
 * footer desgin
 */
div#footer {
	text-align: center;
	padding-top: 1.5em;
	padding-bottom: 0.5em;
}
div#footer hr {
	color: black;
	background-color: black;
	height: 1px;
	width: 50%;
	margin: 0 auto;
}

/**************************
 *
 * confirmaton
 * styles for the confirmation pages
 */
.confirmation {
	margin-top: 5em;
	margin-bottom: 5em;
	margin-left: 20%;
	margin-right: 20%;
	_margin-left: 14%;
	_margin-right: 14%;
}
.confirmation h1 {
	text-align: center;
	padding: 0.3em;
}
.confirmation h2 {
	text-align: center;
	padding: 0.3em;
}
