header, article, footer, section {
  display: block; }

html {
  background: #555555 url(/_/img/cf-background.jpg) fixed left top repeat; }

body {
  color: #444444;
  font: normal 15px/1.3 sans-serif;
  box-shadow: 0 0 20px #222222;
  background: white; }

a {
  color: #882222;
  text-decoration: none; }
  a:hover {
    text-decoration: underline; }

a.btn, button, input[type="submit"] {
  padding: 5px 8px;
  color: #222222;
  background-color: #dddddd;
  cursor: pointer;
  border-style: solid;
  border-width: 1px;
  border-color: #cccccc #666666 #666666 #bbbbbb;
  border-radius: 4px;
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr = '#eeeeee', endColorstr = '#cccccc');
  background: -webkit-gradient(linear, left top, left bottom, from(#eeeeee), to(#cccccc));
  background: -moz-linear-gradient(top, #eeeeee, #cccccc); }
  a.btn:hover, button:hover, input[type="submit"]:hover {
    color: black;
    text-decoration: none;
    background: #cccccc;
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr = '#ededed', endColorstr = '#c5c5c5');
    background: -webkit-gradient(linear, left top, left bottom, from(#ededed), to(#c5c5c5));
    background: -moz-linear-gradient(top, #ededed, #c5c5c5); }
  a.btn:active, button:active, input[type="submit"]:active {
    border-color: #666666 #bbbbbb #cccccc #666666;
    background: #cccccc;
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr = '#cccccc', endColorstr = '#dddddd');
    background: -webkit-gradient(linear, left top, left bottom, from(#cccccc), to(#dddddd));
    background: -moz-linear-gradient(top, #cccccc, #dddddd); }

body {
  background: #777777;
  width: 960px;
  margin: 30px auto 90px auto; }

header#sitehead, footer#sitefoot {
  background-color: #993322;
  border-left: 30px solid #882211;
  border-right: 30px solid #882211;
  color: white; }

header#sitehead {
  position: relative;
  padding: 0 30px; }
  header#sitehead h1 {
    font-weight: normal;
    line-height: 1;
    margin: 0;
    padding: 23px 0 13px 75px;
    font-size: 25px;
    background: transparent url(../img/sabc-logo-negative-60x30.png) left center no-repeat; }

footer#sitefoot {
  padding: 18px 0;
  color: white;
  font-size: 165%;
  height: 30px;
  background: #993322 url(../img/sabc-logo-negative-60x30.png) center center no-repeat;
  text-indent: -9999px; }

article {
  background-color: white;
  border-left: 30px solid #eeeeee;
  border-right: 30px solid #eeeeee;
  padding: 30px; }

article#login h1, article#login form, article#login p {
  width: 466px;
  margin: 1em auto; }
article#login h1 {
  text-align: center; }
article#login form {
  border: 1px solid #aaaaaa;
  border-width: 1px 0;
  padding: 16px 0 8px;
  margin: 1.5em auto; }
  article#login form dt {
    display: block;
    float: left;
    width: 120px;
    text-align: right;
    font-weight: bold;
    clear: left;
    padding-top: 5px; }
  article#login form dd {
    margin-left: 128px;
    padding-bottom: 8px; }
    article#login form dd.plain {
      padding-top: 5px;
      padding-left: 6px;
      padding-bottom: 10px; }
  article#login form input {
    font-size: 16px;
    font-family: sans-serif; }
    article#login form input.text {
      padding: 6px 0 6px 4px;
      background: #f6f6f6;
      line-height: 1;
      height: 16px;
      width: 300px;
      margin-bottom: 1px;
      border: 1px solid #aaaaaa;
      border-left-color: #cccccc;
      border-bottom: 2px solid black;
      transition: background 200ms linear;
      -moz-transition: background 200ms linear;
      -webkit-transition: background 200ms linear;
      -o-transition: background 200ms linear; }
      article#login form input.text:focus {
        background: #ffffcc;
        outline: none;
        border-color: #aaaa88 #aaaa88 #886600 #aaaa88; }
article#login p#notice {
  width: 466px;
  font-size: 12px; }

article#data {
  text-align: center; }
  article#data h1, article#data h2 {
    margin: 0; }
  article#data h1 {
    font-size: 180%; }
  article#data h2 {
    font-size: 110%; }
  article#data table {
    width: 100%; }
    article#data table.balances th, article#data table.balances td {
      text-align: right; }
    article#data table.singleyear {
      width: 60%;
      margin: 0 auto; }
  article#data th {
    padding-bottom: 2px;
    border-bottom: 1px solid #dddddd; }
  article#data td {
    padding-top: 3px; }
  article#data td.spacer, article#data th.spacer {
    width: 25px; }
  article#data td.currency, article#data th.currency {
    text-align: right; }
  article#data td.checkno, article#data td.date, article#data th.checkno, article#data th.date {
    text-align: center; }
  article#data ul {
    list-style: none;
    padding-left: 0;
    margin: 1.5em 0; }
    article#data ul label {
      display: block;
      float: left;
      width: 7em;
      padding-top: 4px;
      margin-right: 0.6em;
      font-weight: bold; }
  article#data li {
    margin: 0.35em 0; }
  article#data small {
    display: block;
    margin: 2em 0 0 0;
    line-height: 1.2; }
