@media print {
    /*@page {size: landscape}*/

    table { page-break-inside:auto; }
    tr    { page-break-inside:avoid; }
    td    { page-break-inside:avoid; }
    /* PWD firefox repeats the header on each page and adds a left/right border on all of the table cells starting on page
       two. This annoyed a customer and since we are soooooo people friendly we blew HOURS adding this hack. So there.
     */
    @-moz-document url-prefix() {
        .printsignup th    {
            border-right: none !important;
            border-left: none !important;
        }
    }
    thead { display: table-header-group; }
    .spacer { page-break-inside:avoid; }
}

body {
    background-color:#fff;
    color: #250517;
    margin-top: 8px;
    font-family: "Trebuchet MS", Verdana, Arial, Helvetica, sans-serif;
    font-size: 14px;
    /*width: 900px;*/
}

.wrap {
    width: inherit;
    white-space: pre;           /* CSS 2.0 */
    white-space: pre-wrap;      /* CSS 2.1 */
    white-space: pre-line;      /* CSS 3.0 */
    white-space: -pre-wrap;     /* Opera 4-6 */
    white-space: -o-pre-wrap;   /* Opera 7 */
    white-space: -moz-pre-wrap; /* Mozilla */
    white-space: -hp-pre-wrap;  /* HP Printers */
    word-wrap: break-word;      /* IE 5+ */
}

h3 {
    font-weight: bold;
    padding-left: 8px;
}

.small {
    font-size: 7px;
}

.comment {
    margin-left: 10px;
}

.comment-title {
    text-decoration: underline;
}

td {
    vertical-align: top;
}

.table thead th {
    font-weight: bold;
}

.signup {
    width: 100%;
    border: 1px solid #ddd;
    word-wrap:break-word
}

.signup tbody tr .prefilled {
    padding-right: 0;
    border-right: none;
    border-left: none;
}

.signup tbody tr td {
    padding: 0 0 0 8px;
    border: 1px solid #ddd;
    vertical-align: middle;
}

.signup tbody tr td .spacer {
    min-height: 35px;
}

.nowrap {
    word-wrap: normal;
    white-space: nowrap;
}

/* indent to mimic content centered under label behavior */
.table tbody tr .indent {
    padding-left: 25px;
}

.table .subrow td {
    border-top: none;
    padding-left: 80px;
}

.title {
    font-weight: bold;
    font-size: 12px;
    vertical-align: top;
    text-align: left;
}

.content {
    padding-left: 20px;
}

#nav,
#banner,
#banner_bottom,
#footer {
    display: none;
}

#steps .step {
    float: none;
    clear: both !important;
    display: inline-block;
}

#steps .step:after {
    content: ".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;
}