html {
    margin: 0;
    padding: 20px 10px;
    background-color: #0e88d3;
    background-image: -webkit-gradient(linear, center top, center 500px,
                                       from(#0b4b6a), to(#0e88d3));
    background-image: -webkit-linear-gradient(top, #0b4b6a 0, #0e88d3 500px);
    background-image:    -moz-linear-gradient(top, #0b4b6a 0, #0e88d3 500px);
    background-image:     -ms-linear-gradient(top, #0b4b6a 0, #0e88d3 500px);
    background-image:      -o-linear-gradient(top, #0b4b6a 0, #0e88d3 500px);
    background-image:         linear-gradient(top, #0b4b6a 0, #0e88d3 500px);
    min-height: 100%;
}
body {
    background: url(images/top.png) no-repeat top left;
    max-width: 908px;
    margin: 0 auto;
    padding: 24px 0 0 0;
    color: #222;
    font-family:  Arial,Verdana,sans-serif;
    font-size: 16px;
    position: relative; /* so that #footer can be absolute */
}
* html body {
  width: 908px;
}

#wrapper {
    background: #fff url(images/middle.png) repeat-y left;
}
#page {
    padding: 0 24px 0;
    background: url(images/bottom.png) no-repeat bottom left;
}
#logo {
    float: left;
    margin: 0;
}
#header {
    text-align: right;
    margin: 0 0 12px 0;
}

#content {
    clear: right;
    margin: 0 0 -100px 220px;
    position: relative;
}
* html #content {
    /* IE6 eats the bottom background when a negative margin is used here
       TODO: find another way to keep the negative margin and the backgroud */
    margin-bottom: 0;
}

#navigation {
    float: left;
    width: 200px;
}
#nav {
    margin-top: 20px;
}
.navigation {
    background: url(images/menu-bottom.png) no-repeat bottom center;
/*    background: #b3db18;*/
    margin: 0;
    padding: 20px 0 16px 0;
    font-size: 90%;
}
.navigation div {
    background: url(images/menu.png) no-repeat top center;
    padding: 0 25px 0 20px;
}
.navigation ul {
    padding: 20px 0 4px;
    margin: 0;
    list-style-image: url(images/favicon.png);
}
.navigation ul ul {
    padding: 0;
    list-style-image: none;
}
.navigation li {
    padding: 0;
    margin: 0 0 2px 20px;
    text-align: left;
}
.navigation li li {
    margin-left: 15px;
}
#contact {
    clear: both;
    font-weight: bold;
    width: 200px;
    padding: 20px 0 44px;
}
#contact div {
    background: url(images/menu.png) no-repeat top center;
    padding-top: 10px;
}
#contact p {
    padding: 10px 30px 0 10px;
    margin: 0;
    text-align: right;
    font-size: 90%;
}
#contact a {
    font-size: 90%;
}
#footer {
    text-align: right;
    font-size: 0.75em;
    margin: 0;
    position: absolute;
    bottom: 10px;
    right: 10px;
}
#footer a {
    color: #000;
}

#content h1 {
    font-size: 2em;
    line-height: 40px;
    margin: 0 0 .5em 0;
    border-bottom: 1px solid;
    text-align: right;
}
#content h1 input {
    font: inherit;
    text-align: inherit;
    color: inherit;
    background-color: inherit;
    width: 100%;
    border: 1px dotted black;
}


form #id_contenu {
    width: 100%;
    height: 35em;
}
form .defaultSkin table.mceLayout {
    border: 1px dotted black;
}
form .defaultSkin table.mceLayout tr.mceFirst td,
form .defaultSkin table.mceLayout tr.mceLast td {
    border: none;
}
#carte_europe {
    position: relative;
    margin: -1em -20px 0 0;
    min-height: 710px;
    background: url(images/Europe.png) top left no-repeat;
}
* html #carte_europe {
    height: 710px;
}
#carte_europe #intro {
    position: absolute;
    top: 20px;
    right: 0;
    width: 220px;
    padding: 0 20px;
    background: url(images/semi_transparent.png);
}
#carte_europe #intro p {
    text-align: right;
}
#destinations {
    font-size: 90%;
    font-weight: bold;
    list-style-position: inside;
}
#destinations input {
    font-size: inherit;
    background: #fff;
    background: rgba(255, 255, 255, 0.6);
    border: 1px dotted black;
}
#destinations p {
    text-align: left;
}
#destinations li {
    position: absolute;
    /* top and right set by each element in its style="" attribute */
/*    background: url(images/semi_transparent.png);*/
    padding: .2em .5em;
}
#destinations .highlight {
    background: #e2ff97;
}
#destinations_form .highlight {
    background: #e2ff97;
}
#destinations_form {
    border-collapse: separate;
    width: 100%;
}
#destinations_form th, #destinations_form td {
    text-align: left;
}
#destinations_form input {
    border: 1px dotted;
    background: transparent;
}
#destinations_form .errors ul {
    margin: 1em 0 0;
}
#destinations_form .top input, #destinations_form .left input {
    width: 3em;
}
form th {
    text-align: right;
/*    vertical-align: bottom;*/
}
form table {
    margin: 0 auto;
}
table input, table textarea {
    width: 100%;
}
table input[type="submit"] {
    width: auto;
}
table textarea {
    height: 5em;
}
#login_notice {
    border: thin solid #dfdb2f;
    background: #fff68f;
    padding: .5em 1em;
    margin: 1em 0;
}
#login_notice input {
    margin: 0 1em;
}

