body {
	margin: 0;
	padding: 0;
	font-family: Verdana, sans-serif;
	/*font-size: small;*/
	text-align: center;
	line-height: 1.5em;
	color: #333;
	background: #333 url(../img/bg_tile_l.gif) repeat top left;
	background: #fff;
	font-size: 11px;

	}

/* ---[ links ]------------------------------- */

a:link {
	color: #40659B;
	}
a:visited {
	color: #8EA4C2;
	}
a:hover {
	color: #036;
	}
a.more {
	padding-right: 7px;
	background: url(../img/more-blue.gif) no-repeat 100% 5px;
	}

/* ---[ common elements ]--------------------- */

p {
	margin: 1em 0 1em;
	padding: 0;
	}
h1 {
	font-family:  Verdana, sans-serif;
	font-size: 150%;
	font-weight: normal;
	padding: 0;
	margin: 0;
	}
h2 {
	font-family:  Verdana, sans-serif;
	font-size: 150%;
	font-weight: normal;
	padding: 0;
	margin: 0 0 1em 0;
	}
h3 {
	margin: 1.5em 0 0 0;
	padding-bottom: 3px;
	font-family: Verdana, sans-serif;
	font-size: 120%;
	font-weight: normal;
	color: #7B9905;
	border-bottom: 1px solid #eee;
	}
h3 a:link, h3 a:visited {
	font-size: 110%;
	text-decoration: none;
	color: #40659B;
	}
h3 a:hover {
	color: #036;
	}
h4, h5 {
	margin: 1.5em 0 0 0;
	font-family:  Verdana, sans-serif;
	font-size: 110%;
	font-weight: normal;
	color: #333;
	}
h1 span, h2 span, h3 span {
	color: #999;
	}
blockquote {
	font-size: 88%;
	color: #777;
	padding-left: 23px;
	background: url(../images/quotemarks.gif) no-repeat 0 3px;
	}
blockquote.praise {
	padding: 0 0 10px 23px;
	border-bottom: 1px solid #eee;
	}
code {
	color: #7B9905;
	font-size: 110%;
	line-height: 1.2em;
	text-align: left;
	}
code strong {
	color: #4E6200;
	}
abbr, acronym, .popup {
	font-style: normal;
	border-bottom: 1px dotted;
	}
em {
	font-style: italic;
	}
strong {
	font-weight: bold;
	}
strike, del {
	text-decoration: line-through;
	}
ins {
	text-decoration: none;
	font-style: italic;
	}
address {
	margin: 0;
	padding: 0;
	font-style: normal;
	}

/* ---[ top ]------------------------------- */

#wrap {
	position: relative;
	margin: 0 auto;
	padding: 0;
	font-size: 95%;
	text-align: left;
  	width: 750px;
  	border-left: 1px solid #000;
  	border-right: 1px solid #000;
  	background: #fff;
	}
#logo {
	/* CIMI background: #3874BB url(../img/spring-head.gif) no-repeat top right;
	background-repeat: no-repeat;*/
	height: 85px;
	padding: 0;
	margin: 0;

	}
#left {
	position: absolute;
	top: 30px;
	left: 3px;
	margin:2px;
	width: 140px; 
	}
	
#middle {
	position: absolute;
	top: 3px;
	left: 150px;
	margin:2px;
	width: 444px;
	}
#right {
	position: absolute;
	top: 30px;
	right: 3px; 
	width: 156px; 
	}

/* navigation */

#nav {
	float: left;
	width: 750px;
	margin: 0;
	padding: 0;
	list-style: none;
	font-size: 82%;
	border-top: 1px solid #A2BD43;
	border-bottom: 3px solid #355A10;
	background: #538620 url(../img/nav-bg-green.gif) repeat-x top left;
	}
#nav li {
	float: left;
	margin: 0;
	padding: 0 1px 0 0;
	list-style: none;
	background: url(../img/nav-li-bg.gif) no-repeat top right;
	}
#nav a {
	float: left;
	padding: 7px 13px;
	text-decoration: none;
	color: #fff;
	}
#nav a img{
	float: left;
	text-decoration: none;
	color: #fff;
	}
#nav a:hover, #nav a.active {
	color: #fff;
	background: #538620;
	}
#nav a.active {
	font-weight: bold;
	background: #538620 url(../img/nav-on-bg.gif) repeat-x bottom left;
	}
li#t-home a {
	margin-left: 25px;
	background: url(../img/nav-li-bg.gif) no-repeat top left;
	}

/* switcher */

#theme {
	position: absolute;
	top: 94px;
	right: 5px;
	margin: 0;
	padding: 0;
	}
#theme a img {
	background: #CCE181;
	margin: 2px 5px 0 0;
	}
#theme a:hover img {
	background: #fff;
	}
#theme a img#theme-fixed {
	background: #fff;
	}
/*PrimaPagina*/
#PrimaPagina {
	/*clear:both;*/
	padding: 7px 10px 3px 0;
	text-align:right;
	font-size: 110%; 
	}
#PrimaPagina a {
	color: #7B9905;
	text-decoration:none;
}
#PrimaPagina a:hover {
	color:#336633;
	text-decoration:underline;
}
	
/* ---( title box )-------------------------------- */

#title {
	clear: left;
	padding: 10px 0 10px 0;}
	
#title h1 {
	margin: 0;
	padding: 5px 0 0 0;
	font-size: 110%; 
	font-weight: bold;
	color: #7B9905;
	line-height: 1.0em;
	}
#title h1 span {
	color: #666;
	}
#title h2 {
	font-family: Verdana, sans-serif;
	margin: 5px 0 0 0;
	padding: 0;
	font-size: 100%;
	line-height: 1.5em;
	}
#title  h3 {
	font-family: Trebuchet MS, Verdana, sans-serif;
	font-size: 200%;
	line-height: 1.1em;
	font-weight: normal;
	padding:  0 0 0 0;
margin: 10px 10px 0 0;
	}
#title h3 a {
	text-decoration: none;
	color: #40659B;
font-weight: Bold;
	}
#title a:visited {
	color: #40659B;
	}
#title a:hover {
	color: #036;
	}


/* ---[ main column ]----------------------------- */

#main-body {
	float: left;
	width: 439px;
	}
#content {
	margin: 15px 0;
	padding: 0 25px;
	background: #fff;
	}

/* figures */

#content img.thumb {	
	float: right;
	margin-left: 12px;
	margin-bottom: 6px;
	margin-top: .5em;
	border-color: #ccc;
	border-width: 1px;
	border-style: solid;
	padding: 5px;
	}
#content img.plain {
	border: none !important;
	}
#content a img.thumb:hover {
	border-color: #999;
	}
#content .figure {
	float: right;
	margin: .5em 0 6px 20px;
	font-size: 92%;
	color: #999;
	text-align: center;
	}
#content .figure dt img {
	margin: 0 0 1em 0;
	padding: 5px;
	border: 1px solid #ddd;
	}
#content .figure img.fig {	
	border-color: #ddd;
	border-width: 1px;
	border-style: solid;
	padding: 5px;
	}
#content img.alone {
	float: none;
	}

/* lists */

#content ul {
	list-style: none;
	margin: 1em 0 1em 0;
	padding-left: 24px;
	}
#content ul li {
	padding: 0 0 4px 13px;
	line-height: 1.4em;
	background: url(../img/arrows.gif) no-repeat 0 5px;
	}
#content dl dd {
	margin: 0;
	padding: 0 0 1em 0;
	font-size: 90%;
	line-height: 1.5em;
	}
#content dl dt {
	font-weight: bold;
	}
#content dl dt span {
	font-weight: normal;
	}
#quick-list dt {
	padding: 0 0 0 13px;
	background: url(../img/ext-link.gif) no-repeat 0 5px;
	}
#quick-list .date {
	color: #999;
	}

/* alert note */

#content .note {
	font-size: 90%;
	line-height: 1.6em;
	color: #777;
	padding: 8px 0 0 0;
	border-top: 1px solid #eee;
	}
#content .note strong {
	color: #333;
	}
#content .note code {
	color: #444;
	}
#content .alert {
	padding-left: 18px;
	background: url(../img/alert-ora.gif) no-repeat 0 50%;
	}
#content .check {
	background-image: url(../img/check.gif);
	}
#home #content .note, #content .plain {
	padding: 0;
	border: none;
	}

/* confirm box */

#content .confirm {
	margin: 1.5em 0;
	padding: 20px;
	font-size: 90%;
	line-height: 1.5em;
	color: #963;
	border: 1px solid #EBD0A6;
	background: #FFF5D4 url(../img/confirm-bg.gif) repeat-x top left;
	}
#content .confirm strong {
	display: block;
	margin: 0 0 6px 0;
	color: #493623;
	}

/* ---[ entries ]---------------------------------- */

#home #content h3 {
	margin: 0;
	padding: 0;
	border: none;
	}
#content dl.entries {
	margin: 0;
	padding: 0;
	}
	
#content dl.entries h1{
	margin: 0;
	padding: 10px 0 10px 0;
	font-size: 150%; 
	font-weight: bold;
	color: #EB9F3D;
	}
#content dl.entries h2{
	/*margin: 0;
	padding: 10px 0 10px 0;
	font-size: 150%; */
	font-weight: bold;
	color: #7B9905;
	}
	
#content dl.entries dt {
	font-family: Trebuchet MS, Verdana, sans-serif;
	font-size: 200%;
	line-height: 1.1em;
	font-weight: normal;
	padding:  0 0 5px 0;
	}
#content dl.entries dt a {
	text-decoration: none;
	color: #40659B;
font-weight: Bold;
	}
#content dl.entries dt a:hover {
	color: #036;
	text-decoration: underline;
	}
#content dl.entries dd {
	margin: 0;
	padding: 0;
	font-size: 100%;

	}
#content dl.entries dd .more {
	font-size: 90%;
	}
#content dl.entries dd.tema {
	margin: 0;
	padding: 5px 0 10px 0;
	font-size: 170%; 
	font-weight: bold;
	color: #7B9905;
	}
#content dl.entries dd.editoriale {
	margin: 0;
	padding: 5px 0 10px 0;
	font-size: 170%; 
	font-weight: bold;
	color: #EB9F3D;
	}
#content dl.entries dd.posted {
	margin: 0 0 15px 0;
	padding: 3px 0 15px 0;
	font-size: 90%;
	color: #ccc;
	border-bottom: 1px solid #eee;
	}
a.plink {
	padding-left: 16px;
	color: #999;
	text-decoration: none;
	background: url(../img/perm_doc.gif) no-repeat 0 1px;
	}
a.qblink {
	padding-left: 12px;
	color: #999;
	text-decoration: none;
	background: url(../img/pound.gif) no-repeat 0 3px;
	}
a.qb {
	color: #999;
	text-decoration: none;
	}
a.clink, .commoff {
	margin: 0 0 0 2px;
	padding: 0 0 0 15px;
	color: #999;
	text-decoration: none;
	background: url(../img/com_bubble.gif) no-repeat 0 1px;
	}
.commoff {
	color: #ccc;
	background-image: url(../img/comment_off.gif);
	}
a.plink:hover, a.qblink:hover, a.clink:hover {
	color: #666;
	}
.datestamp { 
	text-align: right;
	}
p#menu {
	color: #999;
	font-size: 90%;
	margin-top: 0;
	}
p#menu.month {
	margin-top: 1em;
	}

/* quickbits specific */
	
#content dl.entries dt.qb {
	text-indent: 15px;
	font-family: Verdana, sans-serif;
	font-size: 100%;
	line-height: 1.5em;
	background: url(../img/star.gif) no-repeat 0 3px;
	}
#content dl.entries dt.qg {
	text-indent: 15px;
	font-family: Verdana, sans-serif;
	font-size: 100%;
	line-height: 1.5em;
	font-weight:bold;
	background: url(../img/star.gif) no-repeat 0 3px;
	}
#content dl.entries dd.qb {
	font-size: 100%;
	line-height: 1.5em;
	color: #666;
	}
#content dl.entries dt.qb a {
	text-decoration: none;
	}

/* notebook main */

#note-ent {
	width: 65%;
	float: right;
	}
#note-ex {
	width: 23%;
	float: left;
	font-size: 90%;
	}
#content #note-ex ul {
	padding-left: 0;
	}
#content h3#note-rec {
	margin-bottom: 15px;
	}

/* ---[ comments ]--------------------------------- */

#comments {
	font-size: 90%;
	}
#comments textarea {
	width: 350px;
	}
#comments h3 {
	font-size: 120%;
	font-weight: normal;
	padding: 0 0 4px 19px;
	margin-bottom: 10px;
	background: url(../images/cube_birch.gif) no-repeat 0 2px;
	}
#comments h3#chead {
	margin-bottom: 8px;
	border-bottom: none;
	}
#comments h3#add-com {
	margin: 0;
	padding: 0 0 0 19px;
	border-bottom: none;
	}
#comments code {
	font-size: 118%;
	}
#comments span {
	color: #999;
	}
#comments dl {
	margin-top: 0;
	color: #666;
	}
#comments dl dt {
	font-weight: normal;
	color: #333;
	padding: 12px 12px 4px 12px;
	margin: 0;
	line-height: 1em;
	background: url(../img/com_bg.gif) no-repeat top left;
	}
#comments dl dt a {
	color: #333;
	}
#comments dl dt img {
	vertical-align: middle;
	}
#comments dl dd {
	color: #666;
	padding: 0 0 0 12px;
	margin: 0 0 20px 0;
	font-size: 100%;
	}
#comments dl dd p {
	margin-top: 0;
	}
#comments input {
	vertical-align: middle;
	}
#comments textarea {
	width: 325px;
	}
#comments .note {
	font-size: 100%;
	}

/* author highlighting */

#comments dl dt.dan {
	color: #526702;
	}
#comments dl dt.dan a {
	font-weight: bold;
	color: #526702;
	}
#comments dl dd.dan {
	color: #526702;
	}
#comments dl dd.dan a {
	color: #526702;
	}

/* ---[ right column ]----------------------------- */

#sidebar {
	width: 150px;
	float: right;
	margin: 0 0 25px 0;
	padding: 0;
	font-size: 90%;
	line-height: 1.5em;
	color: #888;
	}
#sidebar h3 {
	margin: 30px 0 12px 0;
	padding: 5px 10px;
	color: #fff;
	font-size: 120%;
	border: none;
	background: #f90 url(../img/sidebar-h.gif) repeat-x top left;
	}
#sidebar h3#quick {
	margin-top: 24px;
	}
#sidebar h3.sub {
	background: #538620 url(../img/sub-h-bg.gif) repeat-x top left;
	}
#sidebar h4 {
	font-size: 92%;
	font-weight: normal;
	margin: 0;
	}
#sidebar p, #sidebar ul, #sidebar dl {
	margin: 4px 10px 4px 10px;
	padding: 0;
	list-style: none;
	}
#sidebar li {
	margin: 0 0 .5em 0;
	padding: 0 0 0 13px;
	line-height: 1.4em;
	background: url(../img/arrows.gif) no-repeat 0 5px;
	}
#sidebar #quickbits li {
	padding-left: 16px;
	background-image: url(../img/pound.gif);
	background-position: 0 3px;
	}

#sidebar #quickbits dd {
	padding-left: 5px;
	background-position: 0 3px;
	}
	
#sidebar img {
	vertical-align: middle;
	}

/* ---[ left column ]----------------------------- */

#sidebarL {
	width: 150px;
	float: left;
	margin: 0 0 25px 0;
	padding: 0;
	font-size: 90%;
	line-height: 1.5em;
	color: #888;
	}
#sidebarL h2 {
	margin: 30px 0 0 0;
	padding: 0 10px;
	
	font-size: 120%;
	
	}
	
#sidebarL h2  a{
	text-decoration: none;
	color:#7B9905;
	background: url(../img/arrows.gif) no-repeat 0 5px;
	}
#sidebarL h2  a:hover{
	text-decoration: underline;
	color:#7B9905;
	}
	
#sidebarL h3 {
	margin: 30px 0 12px 0;
	padding: 5px 10px;
	color: #fff;
	font-size: 120%;
	border: none;
	background: #f90 url(../img/sidebar-h.gif) repeat-x top left;
	}
#sidebarL h3#quick {
	margin-top: 24px;
	}
#sidebarL h3.sub {
	background: #538620 url(../img/sub-h-bg.gif) repeat-x top left;
	}
#sidebarL h4 {
	font-size: 92%;
	font-weight: normal;
	margin: 0;
	}
#sidebarL p, #sidebarL ul, #sidebarL dl {
	margin: 4px 10px 4px 10px;
	padding: 0;
	list-style: none;
	}
#sidebarL li {
	margin: 0 0 .5em 0;
	padding: 0 0 0 13px;
	line-height: 1.4em;
	background: url(../img/arrows.gif) no-repeat 0 5px;
	}
#sidebarL #quickbits li {
	padding-left: 16px;
	background-image: url(../img/star.gif);
	background-position: 0 3px;
	}

#sidebarL #quickbits dd {
	padding-left: 5px;
	background-position: 0 3px;
	}
	
#sidebarL img {
	vertical-align: middle;
	}

/* custom list styles */

#sidebar #slideshows li {
	margin-bottom: 0;
	padding: 0 0 7px 15px;
	background: url(../img/slides.gif) no-repeat 0 3px;
	}
#sidebar ul.none li {
	margin-bottom: 2px;
	padding-left: 0;
	background: none;
	}
#sidebar ul.sub li {
	padding-left: 12px;
	background: none;
	}
#sidebar ul.sub li.active a:link, #sidebar ul.sub li.active a:visited {
	color: #244008;
	font-weight: bold;
	text-decoration: none;
	}
#sidebar ul.sub a:hover {
	color: #244008;
	}
#sidebar ul.sub li.active {
	background: url(../img/sub-on.gif) no-repeat 0 4px;
	}
#sidebar ul.sub a { 
	color: #538620;
	}
#sidebar .featured dt {
	padding: 0 0 0 0;
	font-weight: normal;
	font-size: 120%;
	background: url(../img/check-cir.gif) no-repeat 0 2px;
	}
#sidebar .featured dd, #sidebar .featured dt {
	margin: 0;
	}

/* book tease */

#myBook {
	margin: 0;
	padding: 0;
	}
#sidebar dl#myBook dt {
	float: left;
	margin: 0;
	padding: 0;
	}


/* ---[ footer ]----------------------------------- */

#footer {
	position: relative;
	clear: both;
	margin: 0;
	padding: 6px 10px 10px 10px;
	font-size: 100%;
	color: #ffffff;
	background: #000 url(../img/backFooter.gif);
	}
#footer p {
	margin: 0;
	padding: 25px;
	}
#footer a {
	color: #ffffff;
	}
#footer a:hover {
	color: #ccc;
	}

/* ---[ forms ]------------------------------------ */

#contactform, #comments-form, #shirt-form, #search-form {
	margin: 0 0 25px 0;
	padding: 15px;
	background: url(../img/form-bg.gif) repeat-x top left;
	}
#search-form {
	background-image: url(../img/search-form-bg.gif);
	}
#search-form p {
	margin: 0 0 10px 0;
	}
#search-form input {
	vertical-align: middle;
	}
#search-box {
	width: 70px;
	}	
#search-box-large {
	width: 250px;
	}	
#contactform dl {
	margin: 0;
	padding: 0;
	font-size: 90%;
	}
#contactform dt {
	color: #333;
	font-weight: normal !important;
	}
#contactform dt em, #contactform .note em {
	color: #c00;
	font-weight: bold;
	font-style: normal;
	}
#contactform #realname, #contactform #email, #contactform #url {
	width: 200px;
	border: 1px solid #ccc;
	padding: 2px;
	color: #444;
	}
#contactform textarea {
	width: 400px;
	height: 180px;
	font-family: inherit;
	font-size: 120%;
	border: 1px solid #ccc;
	}

/* tshirt form */

#tshirt-form {
	margin: 0 auto;
	padding: 0;
	}
#tshirt-form th {
	text-align: right;
	vertical-align: top;
	}
#tshirt-form td {
	padding: 0 0 10px 10px;
	vertical-align: top;
	}

/* ---[ photos ]------------------------------------------ */

#photoGrid {
	width: 450px;
	margin-top: 12px;
	text-align: left;
	}
#photoGrid .photo {
	float: left;
	margin: 0 10px 10px 0;
	border: 1px solid #ccc;
	padding: 5px;
	}	
#photoGrid a {
	color: #999;
	text-decoration: none;
	border-style: none;
	}
#photoGrid a:hover {
	color: #000;
	}
#photoNav {
	margin: 1em 0 0 0;
	}
#photoNav a {	
	float: left;
	margin: 0 1px .5em 1px;
	padding: 1px 4px 0 4px;
	color: #ccc;
	text-decoration: none;
	border: none;
	}
#photoNav a:hover, #photoNav a.active {
	color: #000;
	background: #ccc;
	}
#clearPhoto {
	clear: left;
	}
img#photo {
	margin: 0 0 1em 0;
	padding: 10px;
	border: 1px solid #ccc;
	}

/* photo viewer overrides */

body.viewer #sidebar {
	display: none;
	}

/* ---[ publications ]------------------------------------ */

dl.tiplist em {
	color: #999;
	font-style: normal;
	}
#content dl.solutions dt {
	float: left;
	background: none;
	padding-left: 0;
	margin-right: 10px;
	}
#content dl.solutions dd.sol-title {
	padding-bottom: 0;
	font-weight: bold;
	font-size: 100%;
	}
#content dl.tiplist dd {
	margin-left: 0;
	}

/* ---[ software ]--------------------------------------- */

.softlist dt {
	padding: 0 0 2px 0;
	margin: 1.2em 0 1em 0;
	border-bottom: 1px solid #ddd;
	}
#content dl.softlist dd {
	padding-bottom: 0;
	}
.softlist p {
	margin-top: 0;
	}

/* ---[ work ]-------------------------------------- */

#work-list {
	position: absolute;
	top: 0;
	left: 0;
	width: 130px;
	font-size: 85%;
	line-height: 1.4em;
	color: #777;
	}
#work-list h3 {
	clear: left;
	margin: 0;
	}
#work-list dl {
	margin: 0 0 20px 0;
	padding: 0;
	}
#work-list dt {
	margin: 14px 0 0 0;
	}
#content #work-list dd {
	margin: 0;
	padding: 0;
	font-size: 100%;
	}
#work-list dd strong {
	color: #666;
	}
#work-list dt a {
	float: left;
	display: block;
	margin: 0 6px 0 0;
	padding: 2px;
	background: #fff;
	border: 1px solid #ccc;
	}
#work-list dt a:hover, #work-list dt a.active {
	border-color: #999;
	}
#port {
	position: relative;
	}
#portText {
	padding-left: 220px;
	}
#work-text {
	padding-left: 150px;
	}
#port ul {
	padding-left: 0;
	}

/* portfolio image */

#portimg {
	position: absolute;
	top: 0;
	left: 0;
	width: 199px;
	padding: 0;
	margin: .5em 15px 10px 0;
	color: #666;
	font-size: 100%;
	text-align: left;
	}
#portimg dt {
	padding: 6px;
	border: 1px solid #ddd;
	}
#content dl#portimg dd {
	padding: 0;
	margin: 10px 0 0 0;
	}

/* ---[ shop ]------------------------------------------ */

#buy-list {
	margin-top: 2em;
	}
#content #buy-list dt {
	float: left;
	margin: 0 14px 4px 0;
	padding: 0;
	}
#content #buy-list dd {
	margin-bottom: 10px;
	}
#content #buy-list dd.title {
	margin: 0;
	padding: 0;
	font-size: 100%;
	font-weight: bold;
	}

/* ---[ simplequiz ]------------------------------------ */

#content ol.quiz {
	padding: 0;
	margin: 0;
	list-style: none;
	}
#content ol.quiz li {
	background: none;
	padding: 10px 10px 10px 30px;
	margin-bottom: 1em;
	border: 1px solid #ddd;
	}
#content ol.quiz pre {
	margin: 0;
	padding: 0;
	}
#content ol.quiz li.a {
	background: url(../images/quiz_a.gif) no-repeat top left;
	}
#content ol.quiz li.b {
	background: url(../images/quiz_b.gif) no-repeat top left;
	}
#content ol.quiz li.c {
	background: url(../images/quiz_c.gif) no-repeat top left;
	}
#content ol.quiz li.d {
	background: url(../images/quiz_d.gif) no-repeat top left;
	}

/* ---[ misc. ]---------------------------------------- */

hr {
	border-top: 1px dashed #ccc;
	color: #fff;
	background-color: #fff;
	height: 1px;
	}	
h3 img {
	vertical-align: middle;
	}
ul.noBullet li {
	list-style-type: none;
	}
ul.fiveent em {
	color: #999;
	font-style: normal;
	font-size: 90%;
	}
.center {
	text-align: center;
	}
a img {
	border: none;
	}
.hide {
	display: none;
	}