* {
	padding: 0;
	margin: 0;
}

body {
	background: #fafdfe;
}

p, h1, h2, h3 {
	padding: 0;
}

/*	Main lay-out elements:
----------------------------------*/

#container {
	background-repeat: no-repeat;
	background-position: top left;
	width: 721px;
	position: absolute;
	left: 292px;
	top: 0;
	z-index: 10;
}

#wrapper {
	width: 1014px;
	margin: 0 auto;
	position: relative;
}

#header {
	height: 238px;
}

#logo a {
	display: block;
	text-decoration: none;
	width: 292px;
	height: 205px;
	background-image: url(/images/logo.png);
}

#logo span, #english-link a span {
	visibility: hidden;
}

#english-link {
	position: absolute;
	top: 12px;
	right: 35px;
	z-index: 100;
	background-image: url(/images/english.png);
	background-repeat: no-repeat;
	background-position: top right;
}
#english-link a, #english-link a:hover {
	text-decoration: none;
	background: transparent;
	display: block;
	height: 40px;
	width: 50px;
}

#sidebar {
	width: 292px;
	background-image: url(/images/sidebar_background.png);
	background-repeat: repeat-y;
	position: absolute;
	z-index: 20;
	font-size: 11px;
	line-height: 14px;
}
#sidebar #extra {
	background-image: url(/images/sidebar_bottom.png);
	background-repeat: no-repeat;
	background-position: bottom;
	padding: 5px 22px 75px 75px;
}

#sidebar h2, #sidebar p, #related h2, #related p {
	padding: 2px 0 6px 0;
}

#sidebar h2, #related h2 {
	font-size: 14px;
	font-weight: bold;
}

#events h2, #publications h2 {
	padding-top: 12px;
}


body #container, body #related, body #nav ul {
	background-image: url(/images/header_young_faces.jpg);
}

body.calendar #container, body.calendar #related, body.calendar #nav ul {
	background-image: url(/images/header_calendar.jpg);
}

body.blueprint #container, body.blueprint #related, body.blueprint #nav ul {
	background-image: url(/images/header_blueprint.jpg);
}

body.conference_room #container, body.conference_room #related, body.conference_room #nav ul {
	background-image: url(/images/header_conference_room.jpg);
}

body.street #container, body.street #related, body.street #nav ul {
	background-image: url(/images/header_street.jpg);
}


/*	Navigation:
----------------------------------*/

#nav {
	list-style: none;
	width: 200px;
	height: 110px;
	padding: 55px 0 73px 28px;
	position: absolute;
}

#nav ul {
	position: absolute;
	z-index: 20;
	top: 42px;
	left: 200px;
	list-style: none;
	width: 400px;
	height: 140px;
	background-position: -200px -42px;
	padding: 0;
}

#nav li {
	padding: 0;
}

#nav .current ul {
	z-index: 10;
}

#nav ul a, #nav .expanded ul a {
	background: transparent;
	display: block;
	padding: 0 0 0 30px;
	width: 400px;
	font-size: 13px;
	font-size: 12px;
	font-weight: normal;
	line-height: 22px;
	line-height: 16px;
	color: #a9dcf0;
	text-decoration: underline;
}
#nav ul a, #nav .expanded ul a, #nav ul li {
	height: 20px;
}

#nav ul a:hover {
	color: #fff;
}

#nav ul .current a, #nav ul .current a:hover {
	color: #fff;
	text-decoration: none;
}

#nav a {
	font-size: 14px;
	font-weight: bold;
	line-height: 22px;
	color: #089bd5;
	text-decoration: none;
	display: block;
	width: 172px;
	height: 22px;
	background: #fff;
}

#nav .expanded a, #nav a:hover {
	color: #005678;
}

#nav .expanded a {
	background: transparent;
}


/*	Page:
----------------------------------*/

#title {
	height: 48px;
	padding-right: 54px;
	padding-left: 28px;
	position: relative;
}
#breadcrumbs {
	position: absolute;
	top: -12px;
	left: 30px;
	margin: 0;
	padding: 0;
}
#title, #title a {
	color: #fff;
}
#title h1 {
	margin: 10px 0 0 0;
	font-weight: normal;
	line-height: 30px;
	vertical-align: top;
}

#page {
	padding-left: 61px;
	padding-top: 10px;
	padding-right: 20px;
	padding-right: 252px;
	width: 442px;
	
/*	IE6width: 754px;*/
	background-image: url(/images/page_background.png);
	background-repeat: repeat-y;
}

#page, #footer {
	margin-left: -33px;
}


/*	Page content:
----------------------------------*/

ul, ol {
	padding: 4px 0 6px 24px;
}
li {
	padding: 2px 0;
}

#page ul p, #page ol p {
	padding: 0 0 4px 0;
}

#page .credits {
	border-bottom: 1px solid #BDDDF1;
	padding-bottom: 6px;
	margin-bottom: 6px;
}
#page .credits p {
	color: #0083B7;
	padding: 1px 0;
}

/*	Related:
----------------------------------*/


#related {
	position: absolute;
	top: 286px;
	left: 490px;
	background-repeat: no-repeat;
	background-position: -490px -287px;
	min-height: 236px;
	width: 172px;
	color: #fff;
	padding: 15px 10px 0 15px;
	font-size: 11px;
	line-height: 14px;
}

#related a {
	color: #fff;
}

#related a:hover {
	color: #089bd5;
	background: #fff;
}

/*	Footer:
----------------------------------*/

#footer {
	clear: both;
	height: 81px;
	padding: 20px 0 0 61px;
	background: url(/images/footer.png);
	width: 693px;
	color: #0083B7;
	font-size: 0.8em;
	background-repeat: no-repeat;
}

/*	Notices & Errors:
----------------------------------*/


#page .flashmessage {
	padding: 8px;
}

p.error {
	border: 1px solid #f60;
	color: #f60;
	background-color: #FFF1DB;
}

form table p.error {
	border: 0;
}

.error, .error_message {
	color:#900;
	font-weight: bold;
}

.error_message {
	clear: both;
}

.error em {
	font-size: 18px;
	color: #003d4c;
}

div.error {
  padding: 2px;
  border: #f60 solid 2px;
}

.notice, .message {
	color: #02a74c;
	border: 1px solid #01c20a;
	font-size: 14px;
	background-color: #e6f9e7;
	padding: 0.5em;
	margin: 1em 0;
	display:block;
}


/*	Forms:
----------------------------------*/

form table p.error {
	border: 0;
}

#page form table {
	border-collapse: collapse;
	width: 420px;
}

form table td, form table th {
	border: 1px solid #e4f4fa;
	border-width: 1px 0 0 0;
}
#page form table th {
	width: 120px;
}
#page form table td {
	width: 400px;
}
form .textfield {
	width: 100%;
}

.error, .error_message {
	color:#900;
	font-weight: bold;
}

.error_message {
	clear: both;
}

.error em {
	font-size: 18px;
	color: #003d4c;
}

label.has_errors {
	color: #f60;
}
span.required {
	font-weight: bold;
}
div.field_with_errors {
	border: 2px solid #f60;
	background: #FFF1DB;
	margin: 0;
	padding: 0;
	background-image: url(/images/error_icon.gif) baseline right;
}

.error, .error_message {
	color:#f60;
	font-weight: bold;
}

.field_with_errors #review_body, .field_with_errors #review_author_name {
	width: 99.5%;
	margin: 0;
}

form td.error_message {
	width: 40px;
	padding: 0;
	background-image: url(/images/error_icon.gif);
	background-repeat: no-repeat;
	background-position: 5px center;
}
table .error_message {
	border: 0;
	margin: 0;
	padding: 0;
	width: 20px;
	height: 20px;
	text-indent: -2000px;
	background-position: center left;
}
