/* @group reset css */
body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, p, blockquote, address, th, td { margin : 0; padding :0; }

h2, h3, h4, h5, h6 { font-size : 100%; font-weight : normal; }

ol, ul { list-style-type : none; }

table { border-collapse : collapse; border-spacing : 0; }

caption, th { text-align : left; }

fieldset, img { border : 0; }

dt, address, caption, cite, code, dfn, th, var { font-style : normal; font-weight : normal; }

q:before, q:after { content :''; }

:focus {
	outline: 0;
}
/* @end */
/* @group layout */

body {  
	font-family: "Helvetica Neue", "Lucida Grande", Helvetica, Arial, Verdana, sans-serif; 
	font-size: 85%;
	text-align: center;
	color: #222;
}

#wrapper {
	position : relative;
	background-color: #fff;
  border: 10px solid #fff;
	margin: 10px auto;
	width: 950px;
	text-align: left;
}

#column1 {
  float: left;
  width: 350px;
	margin-left: 0;
	display: inline;          /* IE BUG FIX */
}

#column2 {
	float: right;
	width: 520px;
	margin-right: 10px;
}

#columnwrap {
  margin-left: 305px;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  padding-top: 10px;
}

#column4 {
  float: left;
  width: 300px;
	margin-left: 0;
	display: inline;          /* IE BUG FIX */
}

#column5 {
	float: right;
	width: 300px;
	margin-right: 10px;
}

#column6 {
  float: left;
  width: 520px;
	margin-left: 0;
	display: inline;          /* IE BUG FIX */
}

#column7 {
	float: right;
	width: 350px;
	margin-right: 10px;
}

#footer {
  clear: both;
  padding-top: 10px;
}

/* @end */
/* @group typography */

a {
  text-decoration: none;
  color: #36C;
}

a:hover {
  text-decoration: underline;
}

h1,h2,h3,h4,h5,h6 { font-weight: normal; }

h1 { font-size: 2.8em; line-height: 1; margin-bottom: 1em; }
h2 { font-size: 1.8em; font-variant: small-caps; margin-bottom: 0.75em; color: #333; }
h3 { clear:both; font-family: Georgia, "Times New Roman", Times, Serif; font-size: 1.3em; color: #999; line-height: 1.5; margin-bottom: 1em; border-top: 1px solid #ccc; padding-top: 4px; }
h4 { font-size: 1.3em; font-weight: bold; line-height: 1.25; margin-bottom: 0; }
h5 { font-size: 1em; font-weight: bold; margin-bottom: 0.5em; }
h6 { font-size: 1em; font-weight: bold; }

p           { margin: 0 0 1.5em; line-height: 1.4; }
p.last      { margin-bottom: 0; }
p img       { float: left; margin: 1.5em 1.5em 1.5em 0; padding: 0; }
p img.top   { margin-top: 0; } /* Use this if the image is at the top of the <p>. */
p.info      { clear: both; color: #bbb; font-style: italic; text-align: center;}
p.list      { line-height: 2em; margin: 0; }
img         { margin: 0 0 1.5em; }

input, textarea { font-size: 1.2em; }

ul, ol      { margin:0 1.5em 1.5em 1.5em; }
ul          { list-style-type: circle; }
ol          { list-style-type: decimal; }
dl          { margin: 0 0 1.5em 0; }
dl dt       { font-weight: bold; }
dd          { margin-left: 1.5em;}

span.date   { color: #999; font-weight: normal; }
span.small  { font-size: 0.9em; color: #999; }
#column2 div.error   { color: #c00; }

/* @end */
/* @group forms */

div.form-row {
	margin: 10px 0;
	clear: both;
}

div.form-row label {
	display: block;
	margin: 2px 0;
	color: #333;
	font-size: 11px;
	font-weight: bold;
}

div.form-row input, div.form-row textarea, div.form-row select {
	background-color: #fafafa;
}

div.form-row input:focus, div.form-row textarea:focus {
	border: 1px solid #36C;
} 

div.form-row input, div.form-row textarea {
	border: 1px solid #ccc;
	border-top: 1px solid #999;
	border-left: 1px solid #999;
}

div.form-row input[type="checkbox"] + label
{
  display: inline;
  float: none;
}

div.option {
  margin: 5px;
}

/* @end */
/* @group header */

#header {
  height: 140px;
}

#header h1 {
	height: 95px;
	background: transparent url(../images/logo.gif) no-repeat;
}

#header h1 a {
	display: block;
	height: 95px;
	width: 150px;
	text-indent: -9999px;
}

/* @end */
/* @group menu */

#nav {
  position: absolute;
  top: 15px;
  right: 0;
}

#nav, #nav ul { /* all lists */
	padding: 0;
	margin: 0;
	list-style: none;
	line-height: 1;
}

#nav a {
	display: block;
	font-size: 1.2em;
	letter-spacing: 1px;
	color: #999;
	padding-bottom: 2px;
	text-decoration: none;
}

#nav ul li a {
  font-size: 0.9em;
}

#nav li { 
	float: left;
	margin-right: 24px;
	padding-right: 24px; 
	border-right: 1px solid #666;
}

#nav li li {
  float: none;
  margin-bottom: 4px;
	border-right: 0;
}

#nav li.last {
  margin-right: 10px;
  border-right: 0;
	padding-right: 0;
}

#nav li a:hover, #nav li li a:hover {
  color: #36C;
}

/*  Attention : the current menu items are colored by css inserted in the header by the frontendController  */

#nav li ul {
	position: absolute;
	padding-top: 5px;
	left: -999em; 
}

#nav li:hover ul, #nav li.sfhover ul, #nav li.current ul { /* lists nested under hovered list items */
	left: auto;
}

/* @end */
/* @group accordion + lightbox + books */

div.accordion h3 {
  margin-bottom: 6px;
  cursor: pointer;
}

div.accordion div.element {
  margin-bottom: 6px;
}

div.element img {
  float: right;
  margin-left: 5px;
}

a.map img {
  float: right;
  margin-left: 5px;
  border: 1px solid #999;
}

div.thumbs {
  margin-top: 3.5em;
}

div.thumb {
  height: 150px;
  width: 150px;
  display: inline;
  float: left;
  margin: 7px 0 28px 22px;
}

div.book {
  display: inline;
  float: left;
  text-align: center;
  margin: 0 0 35px 48px;
}

div.book a {
  display: block;
  height: 125px;
  width: 120px;
}

div.book span {
  display: block;
  width: 120px;
  height: 2em;
  text-align: center;
  font-size: 0.9em;
  color: #999;
  font-style: italic;
}

div.legend   { float: right; margin-right: 10px;}

/* @end */
/* @group footer */

#footer {
  margin: 0;
  text-align: center;
  font-family: Georgia, "Times New Roman", Times, Serif;
  font-size: 0.9em;
  color: #999;
}

/* @end */
