* {
  margin: 0;
  padding: 0; }

body {
  background: url(../img/hub/bg.gif);
  font: 11px "Lucida Grande"; }

#background_pattern {
  background: url(../img/hub/bg_grad.jpg) repeat-x top center;
  height: 501px; }

#wrapper, #contact_wrapper {
  display: block;
  margin: 0 0 0 -378px;
  width: 759px;
  position: absolute;
  top: 46px;
  left: 50%; }

#contact_wrapper {
  top: -22em; }

.center {
  text-align: center; }

.clear {
  clear: both; }

.green {
  color: #00aa00; }

.invisible {
  display: none; }

#header {
  background: transparent url(../img/hub/header.png) no-repeat 0 0;
  display: block;
  height: 145px; }
  #header h1, #header h2 {
    text-indent: -9999px; }
  #header h1 {
    background: transparent url(../img/hub/logo.png) no-repeat 0px 8px;
    color: #60809B;
    display: block;
    float: left;
    font-size: 1px;
    height: 118px;
    width: 378px;
    margin: 0px 20px; }
    #header h1 a {
      display: block;
      height: 109px;
      text-indent: -9999px; }
  #header p {
    padding-top: 67px; }
    #header p a {
      color: #fff;
      padding: 12px 7px;
      text-decoration: none; }
      #header p a:hover {
        text-decoration: underline; }
      #header p a.active {
        color: #000;
        cursor: default;
        text-decoration: underline; }

a#kc {
  position: absolute;
  top: 92px;
  right: 110px;
  letter-spacing: 1px;
  color: #fff; }
  a#kc:hover {
    color: #000; }

#content {
  background: transparent url(../img/hub/content.png) repeat-y top center;
  padding: 12px 72px;
  width: 615px;
  display: block;
  float: left; }
  #content p {
    margin: 12px 0px; }

#footer {
  background: transparent url(../img/hub/footer.png) no-repeat bottom center;
  clear: both;
  padding-bottom: 2em; }
  #footer p {
    color: #999;
    padding-top: 12px;
    text-align: center; }

h1 {
  font-size: 18px;
  color: #777; }

h2 {
  border-bottom: 3px solid #ddd;
  font: 28px "Georgia";
  color: #bbb;
  margin-bottom: 15px;
  padding-top: 6px;
  text-align: center; }
  h2#appointments {
    margin-top: 25px; }

#about_page h2 {
  font-size: 18px;
  text-align: left; }

#contact_info h2 {
  font: italic 14px;
  border: 0; }

a {
  color: #60809b;
  outline: none; }
  a:hover {
    color: #000; }

p.quote {
  font: italic 14px "Georgia"; }

#content.blog {
  padding: 15px 30px;
  width: 700px; }
  #content.blog label {
    background: #ccc;
    display: block;
    color: #666;
    font-size: 12px;
    padding: 4px 6px; }
  #content.blog input, #content.blog textarea {
    width: 99%;
    font-size: 12px; }
  #content.blog .auto_complete {
    background: #eee;
    border: 1px solid #bbb; }
    #content.blog .auto_complete ul li {
      display: block;
      color: #3370ce;
      font-weight: bold;
      text-indent: 4px; }
      #content.blog .auto_complete ul li:hover {
        background: #3370ce;
        color: #fff; }
  #content.blog .title {
    font: bold 18px "Georgia"; }
  #content.blog p {
    padding: 8px;
    margin: 0; }
    #content.blog p.field {
      padding: 0px 0px 10px 0px; }
    #content.blog p.read_more {
      text-align: right;
      padding: 0px 0px 10px 0px; }
    #content.blog p.post_date {
      color: #777;
      padding: 3px 8px; }
    #content.blog p#prev_next {
      text-align: center; }
  #content.blog a {
    color: #000;
    font-weight: bold;
    text-decoration: none; }
    #content.blog a:hover {
      text-decoration: underline; }
    #content.blog a.rss {
      background: url(../img/hub/rss.gif) no-repeat;
      margin-top: 22px;
      clear: both;
      padding: 4px 4px 4px 25px; }
      #content.blog a.rss:hover {
        background-position: -300px 0px; }
  #content.blog ul {
    list-style-type: none; }
    #content.blog ul li {
      background: url(../img/bullets/admin_li.gif) no-repeat 0px 6px;
      padding: 2px 2px 2px 10px; }
  #content.blog table {
    width: 100%; }
    #content.blog table tr.odd td {
      background: #eee; }
    #content.blog table th {
      background: #ddd;
      padding: 3px;
      text-align: left; }
    #content.blog table .nuke, #content.blog table .edit, #content.blog table .show {
      font-size: 11px;
      text-align: center;
      width: 40px; }
      #content.blog table .nuke a, #content.blog table .edit a, #content.blog table .show a {
        color: #f70;
        display: block;
        padding: 4px 6px; }
        #content.blog table .nuke a:hover, #content.blog table .edit a:hover, #content.blog table .show a:hover {
          background: #f70;
          color: #fff;
          text-decoration: none; }
  #content.blog #posts, #content.blog #side {
    float: left; }
  #content.blog #posts {
    position: relative;
    width: 467px; }
    #content.blog #posts h2 {
      background: #bebebe;
      border: 0;
      color: #000;
      font-size: 17px;
      font-weight: bold;
      padding: 4px 7px;
      margin: 0;
      text-align: left; }
      #content.blog #posts h2 a {
        background: #bebebe;
        color: #000;
        display: block;
        text-decoration: none; }
        #content.blog #posts h2 a:hover {
          text-decoration: underline; }
    #content.blog #posts p a {
      text-decoration: underline; }
      #content.blog #posts p a:hover {
        background: #000;
        color: #fff;
        text-decoration: none; }
    #content.blog #posts .errorExplanation {
      background: #fcc; }
      #content.blog #posts .errorExplanation h2 {
        background: #f00;
        color: #fff;
        font-weight: normal; }
      #content.blog #posts .errorExplanation ul {
        color: #f00; }
    #content.blog #posts span.field_error {
      display: block;
      clear: both;
      width: 100%; }
  #content.blog #side {
    background: #bebebe;
    margin-left: 15px;
    padding: 12px;
    width: 194px; }
    #content.blog #side div {
      margin-bottom: 12px; }
      #content.blog #side div#search input {
        margin-bottom: 12px; }
      #content.blog #side div#recently {
        padding-top: 10px; }
    #content.blog #side h2 {
      border: 0;
      color: #666;
      font-size: 16px;
      font-weight: normal;
      padding: 0px 0px 3px 0px;
      margin: 0;
      text-align: left; }
    #content.blog #side input {
      width: 185px; }
    #content.blog #side a#fineprintschool {
      background: url(../img/hub/kc_link.gif);
      display: block;
      height: 46px;
      margin-bottom: 12px;
      width: 192px;
      text-indent: -9999px; }
      #content.blog #side a#fineprintschool:hover {
        background-position: -192px 0px; }

a#edit, a.create {
  background: #fff;
  color: #f70;
  font-weight: bold;
  position: absolute;
  top: 6px;
  right: 6px;
  padding: 2px 4px; }
  a#edit:hover, a.create:hover {
    background: #f70;
    color: #fff;
    text-decoration: none; }

#services_page h3 {
  color: #60809b;
  border-bottom: 2px solid #ccc;
  display: inline;
  font: 18px "Georgia" serif; }
  #services_page h3 span {
    font-size: 24px; }
#services_page ul {
  padding-top: 14px; }
  #services_page ul li {
    font-size: 10px; }

#excellence {
  text-align: center;
  line-height: 18px; }

#create, #print, #deliver {
  float: left;
  display: block;
  margin-top: 18px;
  width: 180px; }

#create {
  margin-left: 30px;
  width: 190px; }

#print {
  margin-left: 10px;
  width: 170px; }

#deliver {
  margin-left: 20px;
  width: 160px; }

#recycle {
  clear: both;
  color: #080;
  display: block;
  padding-top: 26px;
  text-align: center; }

#recycle strong {
  background: url(../img/hub/recycle.jpg)no-repeat left center;
  display: block;
  width: 39em;
  padding: 8px 0px 8px 15px;
  margin: 0 auto; }

p#request_estimate {
  margin: 3px 0px 0px 0px;
  padding-top: 5px;
  text-align: center; }
  p#request_estimate a {
    background: #60809b;
    border: 5px solid #bfc1c4;
    color: #fff;
    display: block;
    font: 15px "Georgia" serif;
    letter-spacing: 1px;
    padding: 8px;
    margin: 0 auto;
    text-decoration: none;
    width: 13em; }
    p#request_estimate a:hover {
      background: #3b5366;
      border-color: #83858a; }

#errorExplanation ul, #services_page ul {
  list-style-type: none; }

#errorExplanation ul li, #services_page ul li {
  background: url(../img/bullets/li.gif) no-repeat 0 6px;
  padding: 3px 3px 3px 15px; }

body#estimate_page label {
  display: block;
  padding: 6px 4px;
  width: 100px;
  text-align: right; }
body#estimate_page input, body#estimate_page textarea {
  background: #ddd;
  color: #60809b;
  font: bold 14px "Lucida Grande";
  width: 260px;
  margin: 0;
  padding: 0; }
body#estimate_page select {
  width: 260px; }

body#estimate_page #form div {
  margin-left: 72px;
  width: 520px;
  clear: both; }
  body#estimate_page #form div.finishing_check {
    border: 1px solid #00f;
    display: inline;
    float: left;
    margin: 0;
    padding: 0;
    width: 100px; }
  body#estimate_page #form div p {
    padding: 0;
    margin: 4px 0px; }
body#estimate_page #form div p, body#estimate_page #form label, body#estimate_page #form input, body#estimate_page #form textarea, body#estimate_page #form select {
  float: left; }
body#estimate_page h3 {
  clear: both;
  margin-left: 180px;
  font: 18px "Georgia";
  color: #777; }
body#estimate_page div#errorExplanation {
  border: 1px solid #f44;
  color: #f00;
  margin-left: 180px;
  width: 260px; }

ul#finishing {
  float: left;
  list-style-type: none;
  width: 300px; }
  ul#finishing li {
    display: block;
    float: left; }
    ul#finishing li.other label {
      width: 150px; }
  ul#finishing input {
    margin-top: 8px;
    width: 12px; }
  ul#finishing label {
    text-align: left;
    width: 70px;
    display: inline; }

p#submit_estimate input {
  border: 2px solid #000;
  display: block;
  float: none;
  margin-left: 107px; }

div#errorExplanation h3 {
  font: 14px "Georgia" serif;
  padding: 4px 6px; }

div#errorExplanation h3, span.field_error input, span.field_error textarea {
  background-color: #fcc;
  border: 2px solid #f00;
  color: #f00;
  margin: 0; }

div#errorExplanation ul, div#errorExplanation p {
  margin: 4px 10px; }

span.field_error {
  display: block;
  float: left;
  margin: 0;
  padding: 0; }

body#estimate_thanks_page #wrapper {
  top: -160px; }
body#estimate_thanks_page #content {
  width: 590px; }

#client_list {
  width: 616px; }
  #client_list li {
    display: block;
    float: left;
    width: 150px;
    text-indent: -9999px; }
    #client_list li a {
      background: transparent url(../img/hub/client_logos.gif) no-repeat;
      display: block;
      float: left;
      height: 65px;
      width: 150px; }
    #client_list li#ms a {
      background-position: -308px -230px; }
      #client_list li#ms a:hover {
        background-position: -308px -582px; }
    #client_list li#ahm a {
      background-position: 0px -10px; }
      #client_list li#ahm a:hover {
        background-position: 0px -362px; }
    #client_list li#bm a {
      background-position: -154px -10px; }
      #client_list li#bm a:hover {
        background-position: -154px -362px; }
    #client_list li#cc a {
      background-position: -462px -10px; }
      #client_list li#cc a:hover {
        background-position: -462px -362px; }
    #client_list li#cp a {
      background-position: 0px -90px; }
      #client_list li#cp a:hover {
        background-position: 0px -442px; }
    #client_list li#dj a {
      background-position: -154px -96px; }
      #client_list li#dj a:hover {
        background-position: -154px -448px; }
    #client_list li#er a {
      background-position: -462px -86px; }
      #client_list li#er a:hover {
        background-position: -462px -438px; }
    #client_list li#tf a {
      background-position: 0px -172px; }
      #client_list li#tf a:hover {
        background-position: 0px -524px; }
    #client_list li#kc a {
      background-position: -308px -162px; }
      #client_list li#kc a:hover {
        background-position: -308px -514px; }
    #client_list li#lb a {
      background-position: -462px -162px; }
      #client_list li#lb a:hover {
        background-position: -462px -514px; }
    #client_list li#kfg a {
      background-position: 0px -230px; }
      #client_list li#kfg a:hover {
        background-position: 0px -582px; }
    #client_list li#nike a {
      background-position: -462px -230px; }
      #client_list li#nike a:hover {
        background-position: -462px -582px; }
    #client_list li#os a {
      background-position: -5px -290px; }
      #client_list li#os a:hover {
        background-position: -5px -642px; }
    #client_list li#puma a {
      background-position: -154px -298px; }
      #client_list li#puma a:hover {
        background-position: -154px -650px; }
    #client_list li#rr a {
      background-position: -300px -298px; }
      #client_list li#rr a:hover {
        background-position: -300px -650px; }
    #client_list li#vh a {
      background-position: -468px -293px; }
      #client_list li#vh a:hover {
        background-position: -468px -645px; }
    #client_list li#msg a {
      background-position: -154px -215px; }
      #client_list li#msg a:hover {
        background-position: -154px -567px; }
    #client_list li#bn a {
      background-position: -308px 0px; }
      #client_list li#bn a:hover {
        background-position: -308px -352px; }
    #client_list li#hs a {
      background-position: -154px -160px; }
      #client_list li#hs a:hover {
        background-position: -154px -512px; }
    #client_list li#dfd a {
      background-position: -308px -81px; }
      #client_list li#dfd a:hover {
        background-position: -308px -433px; }

#contact_info, #contact_form {
  display: block;
  float: left;
  width: 536px; }

#contact_form {
  margin: 15px 0px 0px 15px;
  padding-bottom: 15px;
  width: 176px; }
  #contact_form p {
    color: #fff;
    text-align: center; }
  #contact_form label {
    display: block;
    color: #c0c2c4;
    margin: 8px 0px 2px 0px; }
  #contact_form input, #contact_form textarea {
    width: 100%; }
  #contact_form textarea {
    font: 11px "Lucida Grande" sans-serif;
    margin-bottom: 12px; }
  #contact_form #errorExplanation ul {
    text-align: center; }
  #contact_form .fieldWithErrors {
    border: 2px solid #000; }

#errorExplanation h2 {
  border: 0; }

#contact_header h2 {
  background: transparent url(../img/hub/contact.png) no-repeat top center;
  width: 100%;
  height: 83px;
  margin: 0;
  padding: 0;
  border: 0;
  text-indent: -9999px; }

#contact_content {
  background: transparent url(../img/hub/contact_bg.png) repeat-y top center;
  padding: 0;
  margin: 0;
  display: block;
  float: left;
  width: 100%; }
  #contact_content #home {
    margin: 0 0 0 -400px;
    position: absolute;
    top: -40px;
    left: 50%; }

#contact_info {
  margin-top: 199px; }
  #contact_info h2 {
    font: italic 22px "Georgia" serif;
    padding-bottom: 12px; }
  #contact_info p {
    color: #777;
    margin-top: 12px;
    text-align: center; }
  #contact_info a {
    font-weight: bold; }

#contact_footer {
  background: transparent url(../img/hub/contact_footer.png) no-repeat top center;
  display: block;
  clear: both;
  height: 15px; }

body#contact_thanks_page #contact_wrapper {
  top: -180px; }

#horizon {
  position: absolute;
  top: 50%;
  overflow: visible;
  width: 100%;
  height: 1px;
  display: block; }

#home {
  background: transparent url(../img/hub/card.png) no-repeat top center;
  display: block;
  height: 332px;
  width: 503px;
  margin: 0 0 0 -251px;
  position: absolute;
  top: -166px;
  left: 50%; }
  #home h1 {
    background-image: none;
    text-indent: -9999px; }
  #home ul {
    display: block;
    height: 62px;
    width: 322px;
    margin: 0;
    padding: 0;
    position: absolute;
    top: 221px;
    left: 108px; }
    #home ul li {
      display: block;
      float: left; }
      #home ul li a {
        background: transparent url(../img/hub/home_nav.gif) no-repeat 0px 0px;
        display: block;
        height: 26px;
        padding-right: 4px;
        text-indent: -9999px; }
        #home ul li a#about {
          background-position: 0px -36px;
          width: 50px;
          margin-top: 36px; }
          #home ul li a#about:hover {
            background-position: -322px -36px; }
        #home ul li a#services {
          background-position: -54px -28px;
          margin-top: 28px;
          width: 63px; }
          #home ul li a#services:hover {
            background-position: -376px -28px; }
        #home ul li a#clients {
          background-position: -121px -20px;
          width: 56px;
          margin-top: 20px; }
          #home ul li a#clients:hover {
            background-position: -443px -20px; }
        #home ul li a#estimate {
          background-position: -181px -11px;
          width: 73px;
          margin-top: 11px; }
          #home ul li a#estimate:hover {
            background-position: -503px -11px; }
        #home ul li a#contact {
          background-position: -258px 0px;
          width: 64px;
          padding: 0; }

#home li a:hover#contact, body#contact_page #home li a#contact, body#send_contact_request #home li a#contact, body#contact_thanks_page #home li a#contact {
  background-position: -580px 0px; }

a.active {
  cursor: default; }

a#home_contact_link, a#contact_home {
  display: block;
  text-indent: -9999px; }

a#home_contact_link {
  width: 160px;
  height: 160px;
  margin: 97px 0px 0px 38px; }

a#contact_home {
  width: 372px;
  height: 85px;
  margin: 84px 0 0 65px; }

#kc_card {
  background: transparent url(../img/bg/kc_card.png) no-repeat top center;
  display: block;
  height: 332px;
  width: 503px;
  margin: 0 0 0 -395px;
  position: absolute;
  top: -12px;
  left: 50%; }
  #kc_card h1 {
    background-image: none;
    text-indent: -9999px; }
  #kc_card ul {
    display: block;
    height: 62px;
    width: 230px;
    margin: 0;
    padding: 0;
    position: absolute;
    top: 170px;
    left: 210px; }
    #kc_card ul li {
      display: block;
      float: left; }
      #kc_card ul li a {
        background: transparent url(../img/bg/kc_card_nav.gif) no-repeat 0px 0px;
        display: block;
        height: 25px;
        text-indent: -9999px; }
        #kc_card ul li a#articles {
          background-position: 0px -21px;
          width: 60px;
          margin-top: 21px; }
          #kc_card ul li a#articles:hover, #kc_card ul li a#articles.active {
            background-position: -230px -21px; }
        #kc_card ul li a#terms {
          background-position: -60px -14px;
          width: 66px;
          margin-top: 14px; }
          #kc_card ul li a#terms:hover, #kc_card ul li a#terms.active {
            background-position: -290px -14px; }
        #kc_card ul li a#faqs {
          background-position: -126px -6px;
          width: 45px;
          margin-top: 6px; }
          #kc_card ul li a#faqs:hover, #kc_card ul li a#faqs.active {
            background-position: -356px -6px; }
        #kc_card ul li a#contact {
          background-position: -171px 0px;
          width: 57px;
          margin-top: 0px; }
          #kc_card ul li a#contact:hover, #kc_card ul li a#contact.active {
            background-position: -401px 0px; }
