/* --------------------------------------------------------------

   reset.css
   * Resets default browser CSS.

-------------------------------------------------------------- */
html {
  margin: 0;
  padding: 0;
  border: 0;
}
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
code,
del,
dfn,
em,
img,
q,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
dialog,
figure,
footer,
header,
hgroup,
nav,
section {
  margin: 0;
  padding: 0;
  border: 0;
  font-weight: inherit;
  font-style: inherit;
  font-size: 100%;
  font-family: inherit;
  vertical-align: baseline;
}
/* This helps to make newer HTML5 elements behave like DIVs in older browers */article,
aside,
dialog,
figure,
footer,
header,
hgroup,
nav,
section {
  display: block;
}
/* Line-height should always be unitless! */
body {
  line-height: 1.5;
  background: white;
}
/* Tables still need 'cellspacing="0"' in the markup. */
table {
  border-collapse: separate;
  border-spacing: 0;
}
/* float:none prevents the span-x classes from breaking table-cell display */
caption, th, td {
  text-align: left;
  font-weight: normal;
  float: none !important;
}
table, th, td {
  vertical-align: middle;
}
/* Remove possible quote marks (") from <q>, <blockquote>. */
blockquote:before,
blockquote:after,
q:before,
q:after {
  content: '';
}
blockquote, q {
  quotes: "" "";
}
/* Remove annoying border on linked images. */
a img {
  border: none;
}
/* Remember to define your own focus styles! */
:focus {
  outline: 0;
}
/* --------------------------------------------------------------

   grid.css
   * Sets up an easy-to-use grid of 24 columns.

   By default, the grid is 950px wide, with 24 columns
   spanning 30px, and a 10px margin between columns.

   If you need fewer or more columns, namespaces or semantic
   element names, use the compressor script (lib/compress.rb)

-------------------------------------------------------------- */
/* A container should group all your columns. */
.container {
  width: 950px;
  margin: 0 auto;
}
/* Use this class on any .span / container to see the grid. */
.showgrid {
  background: url(Lib/src/grid.png);
}
/* Columns
-------------------------------------------------------------- */
/* Sets up basic grid floating and margin. */
.column,
.span-1,
.span-2,
.span-3,
.span-4,
.span-5,
.span-6,
.span-7,
.span-8,
.span-9,
.span-10,
.span-11,
.span-12,
.span-13,
.span-14,
.span-15,
.span-16,
.span-17,
.span-18,
.span-19,
.span-20,
.span-21,
.span-22,
.span-23,
.span-24 {
  float: left;
  margin-right: 10px;
}
/* The last column in a row needs this class. */
.last {
  margin-right: 0;
}
/* Use these classes to set the width of a column. */
.span-1 {
  width: 30px;
}
.span-2 {
  width: 70px;
}
.span-3 {
  width: 110px;
}
.span-4 {
  width: 150px;
}
.span-5 {
  width: 190px;
}
.span-6 {
  width: 230px;
}
.span-7 {
  width: 270px;
}
.span-8 {
  width: 310px;
}
.span-9 {
  width: 350px;
}
.span-10 {
  width: 390px;
}
.span-11 {
  width: 430px;
}
.span-12 {
  width: 470px;
}
.span-13 {
  width: 510px;
}
.span-14 {
  width: 550px;
}
.span-15 {
  width: 590px;
}
.span-16 {
  width: 630px;
}
.span-17 {
  width: 670px;
}
.span-18 {
  width: 710px;
}
.span-19 {
  width: 750px;
}
.span-20 {
  width: 790px;
}
.span-21 {
  width: 830px;
}
.span-22 {
  width: 870px;
}
.span-23 {
  width: 910px;
}
.span-24 {
  width: 950px;
  margin-right: 0;
}
/* Use these classes to set the width of an input. */
input.span-1,
textarea.span-1,
input.span-2,
textarea.span-2,
input.span-3,
textarea.span-3,
input.span-4,
textarea.span-4,
input.span-5,
textarea.span-5,
input.span-6,
textarea.span-6,
input.span-7,
textarea.span-7,
input.span-8,
textarea.span-8,
input.span-9,
textarea.span-9,
input.span-10,
textarea.span-10,
input.span-11,
textarea.span-11,
input.span-12,
textarea.span-12,
input.span-13,
textarea.span-13,
input.span-14,
textarea.span-14,
input.span-15,
textarea.span-15,
input.span-16,
textarea.span-16,
input.span-17,
textarea.span-17,
input.span-18,
textarea.span-18,
input.span-19,
textarea.span-19,
input.span-20,
textarea.span-20,
input.span-21,
textarea.span-21,
input.span-22,
textarea.span-22,
input.span-23,
textarea.span-23,
input.span-24,
textarea.span-24 {
  border-left-width: 1px;
  border-right-width: 1px;
  padding-left: 5px;
  padding-right: 5px;
}
input.span-1, textarea.span-1 {
  width: 18px;
}
input.span-2, textarea.span-2 {
  width: 58px;
}
input.span-3, textarea.span-3 {
  width: 98px;
}
input.span-4, textarea.span-4 {
  width: 138px;
}
input.span-5, textarea.span-5 {
  width: 178px;
}
input.span-6, textarea.span-6 {
  width: 218px;
}
input.span-7, textarea.span-7 {
  width: 258px;
}
input.span-8, textarea.span-8 {
  width: 298px;
}
input.span-9, textarea.span-9 {
  width: 338px;
}
input.span-10, textarea.span-10 {
  width: 378px;
}
input.span-11, textarea.span-11 {
  width: 418px;
}
input.span-12, textarea.span-12 {
  width: 458px;
}
input.span-13, textarea.span-13 {
  width: 498px;
}
input.span-14, textarea.span-14 {
  width: 538px;
}
input.span-15, textarea.span-15 {
  width: 578px;
}
input.span-16, textarea.span-16 {
  width: 618px;
}
input.span-17, textarea.span-17 {
  width: 658px;
}
input.span-18, textarea.span-18 {
  width: 698px;
}
input.span-19, textarea.span-19 {
  width: 738px;
}
input.span-20, textarea.span-20 {
  width: 778px;
}
input.span-21, textarea.span-21 {
  width: 818px;
}
input.span-22, textarea.span-22 {
  width: 858px;
}
input.span-23, textarea.span-23 {
  width: 898px;
}
input.span-24, textarea.span-24 {
  width: 938px;
}
/* Add these to a column to append empty cols. */
.append-1 {
  padding-right: 40px;
}
.append-2 {
  padding-right: 80px;
}
.append-3 {
  padding-right: 120px;
}
.append-4 {
  padding-right: 160px;
}
.append-5 {
  padding-right: 200px;
}
.append-6 {
  padding-right: 240px;
}
.append-7 {
  padding-right: 280px;
}
.append-8 {
  padding-right: 320px;
}
.append-9 {
  padding-right: 360px;
}
.append-10 {
  padding-right: 400px;
}
.append-11 {
  padding-right: 440px;
}
.append-12 {
  padding-right: 480px;
}
.append-13 {
  padding-right: 520px;
}
.append-14 {
  padding-right: 560px;
}
.append-15 {
  padding-right: 600px;
}
.append-16 {
  padding-right: 640px;
}
.append-17 {
  padding-right: 680px;
}
.append-18 {
  padding-right: 720px;
}
.append-19 {
  padding-right: 760px;
}
.append-20 {
  padding-right: 800px;
}
.append-21 {
  padding-right: 840px;
}
.append-22 {
  padding-right: 880px;
}
.append-23 {
  padding-right: 920px;
}
/* Add these to a column to prepend empty cols. */
.prepend-1 {
  padding-left: 40px;
}
.prepend-2 {
  padding-left: 80px;
}
.prepend-3 {
  padding-left: 120px;
}
.prepend-4 {
  padding-left: 160px;
}
.prepend-5 {
  padding-left: 200px;
}
.prepend-6 {
  padding-left: 240px;
}
.prepend-7 {
  padding-left: 280px;
}
.prepend-8 {
  padding-left: 320px;
}
.prepend-9 {
  padding-left: 360px;
}
.prepend-10 {
  padding-left: 400px;
}
.prepend-11 {
  padding-left: 440px;
}
.prepend-12 {
  padding-left: 480px;
}
.prepend-13 {
  padding-left: 520px;
}
.prepend-14 {
  padding-left: 560px;
}
.prepend-15 {
  padding-left: 600px;
}
.prepend-16 {
  padding-left: 640px;
}
.prepend-17 {
  padding-left: 680px;
}
.prepend-18 {
  padding-left: 720px;
}
.prepend-19 {
  padding-left: 760px;
}
.prepend-20 {
  padding-left: 800px;
}
.prepend-21 {
  padding-left: 840px;
}
.prepend-22 {
  padding-left: 880px;
}
.prepend-23 {
  padding-left: 920px;
}
/* Border on right hand side of a column. */
.border {
  padding-right: 4px;
  margin-right: 5px;
  border-right: 1px solid #ddd;
}
/* Border with more whitespace, spans one column. */
.colborder {
  padding-right: 24px;
  margin-right: 25px;
  border-right: 1px solid #ddd;
}
/* Use these classes on an element to push it into the
next column, or to pull it into the previous column.  */
.pull-1 {
  margin-left: -40px;
}
.pull-2 {
  margin-left: -80px;
}
.pull-3 {
  margin-left: -120px;
}
.pull-4 {
  margin-left: -160px;
}
.pull-5 {
  margin-left: -200px;
}
.pull-6 {
  margin-left: -240px;
}
.pull-7 {
  margin-left: -280px;
}
.pull-8 {
  margin-left: -320px;
}
.pull-9 {
  margin-left: -360px;
}
.pull-10 {
  margin-left: -400px;
}
.pull-11 {
  margin-left: -440px;
}
.pull-12 {
  margin-left: -480px;
}
.pull-13 {
  margin-left: -520px;
}
.pull-14 {
  margin-left: -560px;
}
.pull-15 {
  margin-left: -600px;
}
.pull-16 {
  margin-left: -640px;
}
.pull-17 {
  margin-left: -680px;
}
.pull-18 {
  margin-left: -720px;
}
.pull-19 {
  margin-left: -760px;
}
.pull-20 {
  margin-left: -800px;
}
.pull-21 {
  margin-left: -840px;
}
.pull-22 {
  margin-left: -880px;
}
.pull-23 {
  margin-left: -920px;
}
.pull-24 {
  margin-left: -960px;
}
.pull-1,
.pull-2,
.pull-3,
.pull-4,
.pull-5,
.pull-6,
.pull-7,
.pull-8,
.pull-9,
.pull-10,
.pull-11,
.pull-12,
.pull-13,
.pull-14,
.pull-15,
.pull-16,
.pull-17,
.pull-18,
.pull-19,
.pull-20,
.pull-21,
.pull-22,
.pull-23,
.pull-24 {
  float: left;
  position: relative;
}
.push-1 {
  margin: 0 -40px 1.5em 40px;
}
.push-2 {
  margin: 0 -80px 1.5em 80px;
}
.push-3 {
  margin: 0 -120px 1.5em 120px;
}
.push-4 {
  margin: 0 -160px 1.5em 160px;
}
.push-5 {
  margin: 0 -200px 1.5em 200px;
}
.push-6 {
  margin: 0 -240px 1.5em 240px;
}
.push-7 {
  margin: 0 -280px 1.5em 280px;
}
.push-8 {
  margin: 0 -320px 1.5em 320px;
}
.push-9 {
  margin: 0 -360px 1.5em 360px;
}
.push-10 {
  margin: 0 -400px 1.5em 400px;
}
.push-11 {
  margin: 0 -440px 1.5em 440px;
}
.push-12 {
  margin: 0 -480px 1.5em 480px;
}
.push-13 {
  margin: 0 -520px 1.5em 520px;
}
.push-14 {
  margin: 0 -560px 1.5em 560px;
}
.push-15 {
  margin: 0 -600px 1.5em 600px;
}
.push-16 {
  margin: 0 -640px 1.5em 640px;
}
.push-17 {
  margin: 0 -680px 1.5em 680px;
}
.push-18 {
  margin: 0 -720px 1.5em 720px;
}
.push-19 {
  margin: 0 -760px 1.5em 760px;
}
.push-20 {
  margin: 0 -800px 1.5em 800px;
}
.push-21 {
  margin: 0 -840px 1.5em 840px;
}
.push-22 {
  margin: 0 -880px 1.5em 880px;
}
.push-23 {
  margin: 0 -920px 1.5em 920px;
}
.push-24 {
  margin: 0 -960px 1.5em 960px;
}
.push-1,
.push-2,
.push-3,
.push-4,
.push-5,
.push-6,
.push-7,
.push-8,
.push-9,
.push-10,
.push-11,
.push-12,
.push-13,
.push-14,
.push-15,
.push-16,
.push-17,
.push-18,
.push-19,
.push-20,
.push-21,
.push-22,
.push-23,
.push-24 {
  float: left;
  position: relative;
}
/* Misc classes and elements
-------------------------------------------------------------- */
/* In case you need to add a gutter above/below an element */
div.prepend-top, .prepend-top {
  margin-top: 1.5em;
}
div.append-bottom, .append-bottom {
  margin-bottom: 1.5em;
}
/* Use a .box to create a padded box inside a column.  */
.box {
  padding: 1.5em;
  margin-bottom: 1.5em;
  background: #e5eCf9;
}
/* Use this to create a horizontal ruler across a column. */
hr {
  background: #ddd;
  color: #ddd;
  clear: both;
  float: none;
  width: 100%;
  height: 1px;
  margin: 0 0 1.45em;
  border: none;
}
hr.space {
  background: #fff;
  color: #fff;
  visibility: hidden;
}
/* Clearing floats without extra markup
   Based on How To Clear Floats Without Structural Markup by PiE
   [http://www.positioniseverything.net/easyclearing.html] */
.clearfix-after-code {
  content: "\0020";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
  overflow: hidden;
}
.clearfix:after, .container:after {
  content: "\0020";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
  overflow: hidden;
}
.clearfix, .container {
  display: block;
}
/* Regular clearing
   apply to column that should drop below previous ones. */
.clear {
  clear: both;
}
/* Extension point A: Put colors/variable definitions here */
/* MIXINS/FUNCTIONS */
.centered {
  margin-left: auto;
  margin-right: auto;
  text-align: left;
}
/* HTML */
html, body {
  height: 100%;
}
body {
  font-family: Helvetica, Arial, Sans-serif;
  font-size: 14px;
  color: #666666;
  background-color: white;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  color: #0c4552;
  font-family: "Trebuchet MS", Verdana, Sans-Serif;
}
h2 {
  font-size: 36px;
  margin: 0 0 20px 0;
  font-weight: normal;
  padding-top: 39px;
}
@media (max-width: 568px) {
  h2 {
    font-size: 30px;
    margin: 0 0 10px 0;
    font-weight: normal;
    padding-top: 17px;
  }
}
h3 {
  font-weight: bold;
  font-size: 16px;
}
p {
  padding: 0.5em;
}
hr {
  border-top: 1px solid #cccccc;
  color: #cccccc;
  background-color: #cccccc;
  height: 1px;
  margin: 20px 0;
}
a {
  color: #0066ff;
  text-decoration: none;
}
a:visited {
  color: #0066ff;
}
a:hover, a:active {
  text-decoration: underline;
  color: #0043a8;
}
.extra-info {
  color: #e4eaeb;
  font-size: 14px;
}
ul.menu {
  color: #666666;
  border-bottom: 1px solid #cccccc;
}
ul.menu li {
  padding: 15px 0 15px 60px;
  border-top: 1px solid #cccccc;
  list-style-type: none;
  font-weight: bold;
}
ul.menu li:hover {
  background: #e4eaeb;
}
ul.menu li.placeholder {
  border: none;
  padding-top: 1px;
}
ul.menu li.placeholder:hover {
  background: none;
}
ul.menu li a {
  text-decoration: none;
  color: #666666;
}
ul.submenu li {
  border: none;
  padding: 0 0 0 2em;
  font-weight: normal;
}
#header {
  width: 100%;
  margin: 0;
  background: white;
}
#header img {
  margin: 10px 10px;
}
@media (max-width: 568px) {
  #header img {
    max-height: 100px;
    margin: 0px 0px 0px 0px;
    max-width: 100%;
  }
}
#main {
  position: relative;
  padding-bottom: 50px;
  /* for footer */

  padding-left: 0px;
  padding-right: 0px;
  width: 100%;
  max-width: 960px;
  min-width: 320px;
  min-height: 100%;
  height: auto !important;
  height: 100%;
  background-color: white;
}
@media screen and (min-width: 1100px) {
  #main {
    margin: auto auto;
    box-shadow: 0px 5px 18px #cccccc;
    -moz-box-shadow: 0px 5px 18px #cccccc;
    -webkit-box-shadow: 0px 5px 18px #cccccc;
  }
}
#footer {
  position: absolute;
  bottom: 0;
  height: 30px;
  text-align: center;
  vertical-align: bottom;
  width: 100%;
  font-size: 10px;
}
#footer img {
  vertical-align: bottom;
}
#single-column {
  width: 319px;
  margin-left: auto;
  margin-right: auto;
  text-align: left;
}
#wide-column {
  margin-left: auto;
  margin-right: auto;
  text-align: left;
  min-width: 310px;
  max-width: 725px;
  margin: 0 auto 0 5px;
}
#usermenu {
  display: inline;
}
#usermenu li {
  display: inline;
  left: 50%;
  list-style: none;
  font-size: 15px;
  margin-right: 10px;
  margin-left: 10px;
  font-weight: bold;
}
#usermenu li.first {
  margin-right: 10px;
  margin-bottom: 0px;
  font-size: 18px;
  font-weight: bold;
}
#userframe {
  background-color: transparent;
  height: 200px;
  font-size: 12px;
  position: absolute;
  top: -40px;
  right: 1px;
}
#userframe li {
  display: inline;
}
@media (max-width: 568px) {
  #overlay.open {
    background: url("/css/img/bg-overlay.png") repeat scroll 0 0 transparent;
    position: fixed;
    height: 100%;
    width: 100%;
    z-index: 1;
    top: 0;
    display: block;
    transition: none;
  }
  
  #footer.open {
    background: url("/css/img/bg-overlay.png") repeat scroll 0 0 transparent;
    height: 30px;
    width: 100%;
    z-index: 1;
    padding-top: 110px;
    display: block;
    transition: none;
  }
  
  #userframe.open {
    background-color: #fbe444;
    border-style: solid;
    border-width: 2px;
    border-color: #fbe444;
    height: 340px;
    font-size: 12px;
    position: fixed;
    top: 0px;
    right: 1px;
    width: 240px;
    z-index: 2000000;
  }
  
  #usermenu {
    display: none;
  }
  
  #usermenu.open {
    text-align: center;
    background-color: #fbe444;
    display: block;
    width: 100px;
    top: 50px;
  }
  #usermenu.open li {
    position: relative;
    display: list-item;
    left: 50%;
    list-style: none;
    margin-top: 10px;
    margin-bottom: 10px;
    font-weight: bold;
  }
  #usermenu.open li.first {
    margin-top: 45px;
    margin-bottom: 25px;
    font-size: 15px;
    font-weight: bold;
  }
  
  #nav-icon1,
  #nav-icon2,
  #nav-icon3,
  #nav-icon4 {
    right: 20px;
    width: 40px;
    height: 20px;
    position: absolute;
    margin: 0px auto;
    -webkit-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    transform: rotate(0deg);
    -webkit-transition: 0.5s ease-in-out;
    -moz-transition: 0.5s ease-in-out;
    -o-transition: 0.5s ease-in-out;
    transition: 0.5s ease-in-out;
    cursor: pointer;
  }
  
  #nav-icon1 span, #nav-icon3 span, #nav-icon4 span {
    display: block;
    position: absolute;
    height: 5px;
    width: 100%;
    background: #e2001a;
    border-radius: 3px;
    opacity: 1;
    left: 0;
    -webkit-transform: rotate(0deg);
    -moz-transform: rotate(0deg);
    -o-transform: rotate(0deg);
    transform: rotate(0deg);
    -webkit-transition: 0.25s ease-in-out;
    -moz-transition: 0.25s ease-in-out;
    -o-transition: 0.25s ease-in-out;
    transition: 0.25s ease-in-out;
  }
  
  #nav-icon1 span:nth-child(1) {
    top: -30px;
  }
  
  #nav-icon1 span:nth-child(2) {
    top: -20px;
  }
  
  #nav-icon1 span:nth-child(3) {
    top: -10px;
  }
  
  #nav-icon1.open span:nth-child(1) {
    top: 35px;
    -webkit-transform: rotate(135deg);
    -moz-transform: rotate(135deg);
    -o-transform: rotate(135deg);
    transform: rotate(135deg);
  }
  
  #nav-icon1.open span:nth-child(2) {
    opacity: 0;
    left: -60px;
  }
  
  #nav-icon1.open span:nth-child(3) {
    top: 35px;
    -webkit-transform: rotate(-135deg);
    -moz-transform: rotate(-135deg);
    -o-transform: rotate(-135deg);
    transform: rotate(-135deg);
  }
}
/* Elements */
.details a {
  background: url(Img/Icons/View_Details.png) no-repeat;
  display: block;
  color: transparent;
  font-size: 25px;
  width: 25px;
  height: 25px;
}
.cancel a {
  background: url(Img/Icons/Cancel.png) no-repeat;
  display: block;
  color: transparent;
  font-size: 25px;
  width: 25px;
  height: 25px;
}
.back {
  background-repeat: no-repeat;
  background-position: left center;
}
.forward {
  background-repeat: no-repeat;
  background-position: right center;
}
.buttons {
  text-align: right;
  padding-top: 40px;
  clear: both;
  display: block;
}
.buttons form {
  display: inline;
}
.buttons input {
  float: right;
}
.buttons .buttonContainer {
  display: inline-block;
  padding: 11px 4px 4px;
}
.buttons .buttonContainer a {
  background-repeat: no-repeat;
  background-position: left center;
  padding-left: 12px;
  margin-right: 20px;
}
.buttons .backButton {
  display: block;
  color: white;
  border-radius: 10px 1em 1em 1em;
  -moz-border-radius: 10px 1em 1em 1em;
  -webkit-border-radius: 10px 1em 1em 1em;
  border-radius: 10px 10px 10px 10px;
  -moz-border-radius: 10px 10px 10px 10px;
  -webkit-border-radius: 10px 10px 10px 10px;
  background-color: #b4dae4;
  padding: 10px;
  min-height: 20px;
  font-weight: bold;
  font-family: Helvetica, Arial, Sans-serif;
  cursor: pointer;
  border: none;
  text-decoration: none;
  float: right;
  margin-right: 20px;
}
.buttons .backButton:hover {
  background-color: #56adc2;
}
@media (max-width: 320px) {
  .buttons {
    padding-top: 10px;
  }
}
.info {
  background: #e4eaeb;
}
.confirmed {
  background-image: url("Img/Icons/check.gif");
  background-position: 20px 20px;
  background-color: #e4eaeb;
  background-repeat: no-repeat;
  padding: 65px 20px 20px 20px;
}
.separated {
  display: inline-block;
}
.separated li {
  border-top: 1px solid #cccccc;
  padding: 12px 5px 12px 0;
  list-style-type: none;
}
.separated li.first {
  border-top: none;
}
.fieldValue {
  font-weight: bold;
}
/* FORM */
form .field-validation-error {
  color: #f00;
}
form .editor-field {
  margin-bottom: 5px;
}
input[type="text"],
input[type="password"],
input[type="button"],
button {
  padding: 3px 6px;
  border: none;
}
input[type="text"], input[type="password"] {
  width: 260px;
  border: 1px solid #ccc;
  height: 30px;
}
select {
  width: 275px;
  padding: 10px;
}
textarea {
  width: 270px;
}
input.input-validation-error, select.input-validation-error {
  border-color: #f00;
}
.submit, button {
  -webkit-appearance: none;
  color: white;
  border-radius: 10px 1em 1em 1em;
  -moz-border-radius: 10px 1em 1em 1em;
  -webkit-border-radius: 10px 1em 1em 1em;
  border-radius: 10px 10px 10px 10px;
  -moz-border-radius: 10px 10px 10px 10px;
  -webkit-border-radius: 10px 10px 10px 10px;
  background-color: #1f9dbd;
  padding: 5px 10px;
  min-height: 40px;
  font-weight: bold;
  font-family: Helvetica, Arial, Sans-serif;
  cursor: pointer;
  border: none;
}
.submit:hover, button:hover {
  background-color: #156e84;
}
.submit:focus, button:focus {
  background-color: #156e84;
}
.input-validation-error {
  border-color: #f00;
}
.field {
  margin-top: 10px;
}
* {
  margin: 0;
  padding: 0;
}
#cookies {
  left: 100px;
  font-size: 14px;
}
#cookies #linktekst {
  display: block;
  cursor: pointer;
  position: relative;
  font-size: 10px;
  vertical-align: bottom;
}
#cookies p, #cookies h2, #cookies #close {
  display: none;
}
#cookies.open {
  position: absolute;
  cursor: pointer;
  bottom: 30px;
  left: 35%;
  width: 250px;
  background-color: #e4eaeb;
}
#cookies.open p, #cookies.open h2, #cookies.open #Close {
  display: block;
}
#cookies.open p {
  margin-left: 10px;
  margin-right: 10px;
  font-weight: bold;
}
#cookies.open #linktekst {
  display: none;
}
#cookies.open #Close {
  position: absolute;
  display: block;
  position: relative;
  left: 50%;
  bottom: 0%;
  width: 35px;
  height: 34px;
  background: url(/CSS/Img/Icons/Cancel.png) no-repeat;
  color: transparent;
}
@media (min-width: 960px) {
  body {
    margin: 0;
    padding: 0;
    height: 100%;
    /* this is the key! */
  
  }
  
  #left {
    position: absolute;
    left: 0px;
    top: 0px;
    padding: 0;
    width: 220px;
    height: 100%;
    /* works only if parent container is assigned a height value */
  
  }
  
  #content {
    margin-left: 240px;
    margin-right: 20px;
  }
}
/* BOOKING PROCESS */
#process {
  height: 100%;
  background: white;
  border-left: 1px solid #b4dae4;
}
#process ol {
  padding-top: 18px;
}
#process ol li {
  list-style-type: none;
  height: 80px;
  background: white;
  color: #c4c4c4;
}
#process ol li img {
  display: none;
}
#process ol li div.stepName {
  display: inline-block;
  max-width: 120px;
  vertical-align: middle;
}
#process ol li div.stepNumber {
  width: 40px;
  height: 80px;
  margin-right: 10px;
  margin-left: 45px;
  vertical-align: middle;
  text-align: center;
  font-weight: bold;
  font-size: 18px;
  color: #fff;
  display: inline-block;
  background-position: center bottom;
  background-repeat: no-repeat;
}
#process ol li div.stepNumber span {
  top: 27px;
  left: -2px;
  position: relative;
}
#process ol li.completed, #process ol li.completed a, #process ol li.finished {
  background: white;
  color: #666666;
  text-decoration: none;
}
#process ol li.completed:hover {
  background-repeat: no-repeat;
  background-position: 190px center;
}
#process ol li.completed:hover a {
  text-decoration: underline;
}
#process ol li.active, #process ol li.active a {
  position: relative;
  color: #0c4552;
  text-decoration: none;
  font-weight: bold;
}
#process ol li.active img, #process ol li.active a img {
  position: absolute;
  right: -16px;
}
#process ol li div.stepNumber {
  background-image: url('Img/Process/step-middle-passive.jpg');
}
#process ol li.last div.stepNumber {
  background-image: url('Img/Process/step-last-passive.jpg');
}
#process ol li.active div.stepNumber {
  background-image: url('Img/Process/step-middle-active.jpg');
}
#process ol li.first.active div.stepNumber {
  background-image: url('Img/Process/step-first-active.jpg');
}
#process ol li.last.active div.stepNumber {
  background-image: url('Img/Process/step-last-active.jpg');
}
#process ol li.completed div.stepNumber, #process ol li.finished div.stepNumber {
  background-image: url('Img/Process/step-middle-visited.jpg');
}
#process ol li.first.completed div.stepNumber, #process ol li.first.finished div.stepNumber {
  background-image: url('Img/Process/step-first-visited.jpg');
}
#process ol li.last.completed div.stepNumber, #process ol li.last.finished div.stepNumber {
  background-image: url('Img/Process/step-last-visited.jpg');
}
#step {
  position: relative;
  width: 640px;
  margin: 0 auto 0 60px;
}
#step h2 {
  font-size: 28px;
  font-weight: bold;
}
@media (max-width: 960px) {
  #step {
    position: relative;
    width: 100%;
    margin: 0 auto 0 5px;
  }
  #step h2 {
    font-size: 28px;
    font-weight: bold;
  }
}
@media (max-width: 960px) {
  #process {
    display: none;
  }
}
ul.resourceList li {
  display: inline-block;
  width: 150px;
  padding-top: 10px;
  padding-left: 30px;
  padding-bottom: 10px;
  padding-right: 30px;
  border-bottom: 1px solid #cccccc;
  vertical-align: top;
}
ul.resourceList li img {
  display: block;
  margin-bottom: 20px;
}
ul.resourceList li p {
  width: 140px;
  padding: 0;
  font-style: italic;
}
ul.resourceList li:hover {
  color: #333333;
  background-color: #e4eaeb;
}
ul.resourceList li.first {
  /*padding-left: 35px;*/
}
ul.resourceList li a {
  color: #0c4552;
  text-decoration: none;
  font-family: "Trebuchet MS", Verdana, Sans-Serif;
  font-weight: bold;
  font-size: 20px;
}
ul.resourceList li a:hover {
  color: #333333;
}
.resourceInfo {
  box-shadow: 0px 6px 12px #cccccc;
  -moz-box-shadow: 0px 6px 12px #cccccc;
  -webkit-box-shadow: 0px 6px 12px #cccccc;
  display: none;
  position: relative;
  background: #e4eaeb;
  max-width: 600px;
  padding: 35px 0;
}
.resourceInfo h3 {
  font-size: 20px;
  font-weight: bold;
  padding-bottom: 25px;
  color: #0c4552;
  font-family: "Trebuchet MS", Verdana, Sans-Serif;
}
.resourceInfo div {
  display: block;
  padding-left: 25px;
  padding-right: 25px;
}
.resourceInfo div.resourceImage {
  width: 130px;
  float: left;
}
.resourceInfo div.resourceImage img {
  float: left;
  padding: 0 20px 20px 0;
}
.resourceInfo div.resourceImage .resourceDescription {
  clear: both;
  padding: 0;
}
.resourceInfo div.resourceImage .resourceDescription h3 {
  vertical-align: middle;
  padding: 0;
}
.resourceInfo div.resourceImage .resourceDescription p {
  padding: 0;
  font-style: italic;
}
.resourceInfo div.resourceText {
  float: right;
  max-width: 360px;
  padding: 35px 25px;
  font-size: 14px;
  background: #e4eaeb;
}
.resourceInfo div.selectResource {
  padding-right: 0;
  padding-left: 0;
}
.resourceInfo div.selectResource a {
  margin-right: 25px;
}
.resourceInfo div.selectResource .buttons {
  float: none;
}
.resourceInfo div.selectResource .buttons input {
  float: none;
}
.resourceInfo div.selectResource .discountType {
  float: left;
  margin-left: 215px;
  padding: 0;
}
.resourceInfo div.selectResource .discountType ul {
  list-style-type: none;
}
.resourceInfo div.selectResource:after {
  content: "\0020";
  display: block;
  height: 0;
  clear: both;
  visibility: hidden;
  overflow: hidden;
}
.resourceInfo .closePopup {
  display: block;
  height: 36px;
  position: absolute;
  right: -10px;
  top: 10px;
  width: 36px;
}
@media (max-width: 320px) {
  .resourceInfo.selectResource .discountType {
    float: left;
    padding: 0;
    width: 100%;
  }
  .resourceInfo.selectResource .discountType ul {
    list-style-type: none;
  }
}
.courseList {
  width: 100%;
}
.courseList li {
  list-style-type: none;
  padding-top: 0.5em;
  padding-bottom: 0.5em;
  vertical-align: top;
}
.courseList li .courseName {
  font-weight: bold;
}
.courseList li .courseDetails {
  display: none;
  padding: 1em 1em;
  margin-right: 1em;
  background: #e4eaeb;
}
.courseTimes {
  margin-top: 15px;
  border-bottom: 1px solid #cccccc;
}
.courseTimes li {
  padding: 15px 0 15px 15px;
  border-top: 1px solid #cccccc;
  list-style-type: none;
}
.courseTimes li:hover {
  background: #e4eaeb;
}
.courseCategory {
  color: #0c4552;
  display: block;
  font-size: 0.5em;
  font-weight: normal;
}
a[data-selectable=false] {
  cursor: default;
  text-decoration: none;
  color: #666666;
  pointer-events: none;
}
.participantSelection, .timeSelection {
  margin-top: 30px;
}
.participantSelection select, .timeSelection select {
  width: 6em;
  padding: 3px;
}
.participantSelection .participants, .timeSelection .participants {
  margin-top: 15px;
}
.participantSelection .participants div, .timeSelection .participants div {
  margin-top: 5px;
}
.participantSelection .participants input[type=text], .timeSelection .participants input[type=text] {
  width: auto;
  height: auto;
}
.participantSelection .participants .unused, .timeSelection .participants .unused {
  display: none;
}
.groupsize {
  margin-top: 10px;
}
.groupsize span {
  margin-right: 35px;
}
.calendarContainer {
  position: relative;
  display: inline-block;
  padding-right: 5px;
}
.calendarContainer .buttons .backButton {
  float: left;
}
.timeSelectionContainer {
  min-width: 320px;
}
h3 .dates {
  font-weight: normal;
}
table.calendar {
  font-size: 14px;
  margin-top: 20px;
  width: 100%;
}
table.calendar thead th {
  color: #747570;
  border-left: 3px solid white;
  border-right: 3px solid white;
  font-size: 12px;
  width: 45px;
  max-width: 45px;
  overflow: hidden;
}
table.calendar tbody th {
  color: #747570;
  border-right: 12px solid white;
  text-align: right;
}
table.calendar tbody td {
  font-size: 12px;
  padding-right: 5px;
  text-align: right;
  vertical-align: middle;
  border-bottom: 1px solid white;
  border-top: 1px solid white;
  border-left: 3px solid white;
  border-right: 3px solid white;
  width: 45px;
  max-width: 45px;
  height: 20px;
}
table.calendar tbody td.available {
  background: #1f9dbd no-repeat center center;
  cursor: pointer;
  color: #fff;
  font-weight: bold;
}
table.calendar tbody td.future-available {
  background: url("Img/Icons/icon-phone.png") no-repeat scroll 33px center #1f9dbd;
}
table.calendar tbody td.not-available {
  background: #b4dae4;
}
table.calendar tbody td.closed {
  background: #b4dae4;
}
table.calendar tbody td.selected, table.calendar tbody td.available:hover, table.calendar tbody td.future-available:hover {
  background-color: #0e4553;
}
.calendar-endtime {
  display: none;
}
.navigation {
  position: relative;
}
.navigation .monthselect {
  cursor: pointer;
  margin-right: 14px;
}
.navigation .back, .navigation .forward {
  margin-left: 0;
  margin-right: 14px;
  vertical-align: top;
}
.navigation .forward {
  margin-right: 0;
}
.legend {
  margin-left: 51px;
  margin-top: 30px;
  font-size: 12px;
}
.legend span.preview {
  width: 17px;
  height: 17px;
  display: inline-block;
}
.legend .available .preview {
  background: #1f9dbd;
}
.legend .future-available .preview {
  background: url("Img/Icons/icon-phone.png") no-repeat scroll center center #1f9dbd;
  margin-left: 10px;
}
.legend .not-available .preview {
  background: #b4dae4;
  margin-left: 10px;
}
@media (max-width: 320px) {
  .legend {
    visibility: hidden;
    display: none;
  }
}
#Selection_NoOfParticipants {
  width: 120px;
  padding: 6px;
}
#NoOfParticipantsHelp {
  color: #777;
}
.timeInfo {
  min-width: 150px;
  background: #d7dcdf;
  padding: 20px 40px;
}
.timeInfo .buttons {
  padding-top: 20px;
}
.timeInfo ul.menu {
  width: 150px;
  padding-top: 10px;
}
.timeInfo ul.menu li {
  padding: 5px;
}
.timeInfo ul.menu li a {
  color: #0c4552;
  font-weight: normal;
}
.timeInfo ul.menu li:hover {
  background: #cccccc;
}
.infoButtons {
  text-align: right;
  margin-top: 20px;
}
.infoButtons a {
  margin-right: 10px;
}
form#loginForm {
  float: left;
  width: 250px;
  padding-right: 20px;
}
form#loginForm input[type=text], form#loginForm input[type=password] {
  width: 235px;
}
form#loginForm label {
  font-size: 12px;
}
form#missingEmailForm {
  width: 250px;
  padding-right: 20px;
}
form#missingEmailForm input[type=text], form#missingEmailForm input[type=password] {
  width: 235px;
}
form#missingEmailForm label {
  font-size: 12px;
}
div#forgottenPassword {
  padding-left: 0px;
  padding-top: 20px;
  float: left;
  width: 310px;
}
div#forgottenPassword form {
  float: left;
  width: 270px;
}
div#forgottenPassword form form input[type=text], div#forgottenPassword form form input[type=password] {
  width: 230px;
}
div#forgottenPassword form .field-validation-error {
  display: block;
}
div#forgottenPassword #help {
  float: right;
  margin-left: 10px;
  width: 110px;
  background-color: #ebe9e3;
  color: #aaa;
  padding: 10px;
  margin-right: 0;
}
div#register {
  padding-top: 10px;
  clear: both;
  width: 310px;
}
div#register form {
  float: left;
  width: 270px;
}
div#register form form input[type=text], div#register form form input[type=password] {
  width: 230px;
}
div#register form .field-validation-error {
  display: block;
}
div#register #help {
  float: right;
  background-color: #ebe9e3;
  color: #aaa;
  padding: 10px;
  margin-right: 0;
}
div#customFields {
  float: left;
  width: 280px;
}
div#customFields ul li {
  list-style-type: none;
}
div#customFieldsTermsAndConditions {
  float: right;
  width: 300px;
  background-color: #e4eaeb;
  color: #aaa;
  padding: 20px;
}
.bookingInfo {
  width: 100%;
  max-width: 450px;
  min-width: 310px;
}
.bookingInfo h3 {
  border-bottom: 1px solid #cccccc;
  padding-bottom: 15px;
}
.bookingInfo ul {
  list-style-type: none;
  margin-bottom: 15px;
  width: 100%;
}
.bookingInfo ul .price {
  float: right;
  font-size: 20px;
  font-weight: bold;
}
.bookingInfo ul .fieldValue {
  color: #0c4552;
}
.bookingInfo ul li {
  border-bottom: 1px solid #cccccc;
  padding: 15px;
}
.bookingInfo ul li ul {
  margin-bottom: 0;
}
.bookingInfo ul li.customFields ul li {
  display: list-item;
  list-style-type: square !important;
  margin-left: 16px;
  padding: 0;
  border: none;
}
.bookingInfo #terms {
  display: none;
}
.bookingInfo #terms h4 {
  font-weight: bold;
  margin-top: 10px;
}
.bookingInfo .buttons {
  padding-right: 20px;
}
.receiptText {
  background: url("Img/Icons/check.png") no-repeat scroll 20px 60px #e4eaeb;
  margin-bottom: 35px;
  margin-top: 10px;
  padding: 100px 20px 60px;
}
@media (max-width: 320px) {
  .receiptText {
    margin-bottom: 10px;
  }
}
.receiptNextActions {
  width: 100%;
}
.cancelInformation {
  display: block;
  padding-top: 1em;
}
.cancelInformation .cancelInformationLabel {
  font-weight: bold;
}
.cancelInformation .cancelText {
  display: block;
}
#myPageContent {
  width: 100%;
}
#myPageContent li {
  list-style-type: none;
}
#myPageContent .buttons {
  text-align: left;
}
#myPageContent .buttons a {
  margin-right: 25px;
  float: none;
  display: inline-block;
}
#myPageContent .buttons input {
  float: none;
}
#myPageHeader {
  margin-bottom: 30px;
}
#myPageHeader h2 {
  margin-bottom: 0;
  float: left;
}
#myPageHeader hr {
  margin-top: 0;
  margin-bottom: 10px;
}
#myPageHeader ul.userInfo {
  float: right;
  margin-top: 60px;
}
#myPageHeader ul.userInfo li {
  display: inline;
  padding-left: 25px;
}
#myPageMenu {
  width: 100%;
}
#myPageMenu ul li {
  display: inline;
  padding: 5px 25px 5px 25px;
  border-right: 1px solid #cccccc;
}
#myPageMenu ul li.active {
  background: #666666;
}
#myPageMenu ul li.active a {
  color: white;
}
#myPageMenu ul li.first {
  padding-left: 5px;
}
#myPageMenu ul li.last {
  border-right: none;
}
#myPageMenu ul li:hover {
  background: #e4eaeb;
}
#myPageMenu ul li a:hover {
  text-decoration: none;
}
table.bookinglist {
  margin-top: 15px;
  width: 100%;
  border-collapse: collapse;
}
table.bookinglist th {
  border-top: none;
  color: #cccccc;
}
table.bookinglist td, table.bookinglist th {
  padding: 12px 15px 12px 0;
  border-bottom: 1px solid #cccccc;
}
table.bookinglist td {
  color: #333333;
}
table.bookinglist tr:hover td {
  background: #e4eaeb;
}
.bookingBasicDetails {
  width: 48%;
  float: left;
}
.customFieldsDetails {
  width: 48%;
  float: left;
}
/* Extension point B: Put CSS class overrides here */
#main {
  margin: auto auto;
  width: 100%;
  box-shadow: none;
  -moz-box-shadow: none;
  -webkit-box-shadow: none;
}
#main #process {
  border-left: none;
  border-right: 1px solid #ccc;
}
