* {
    font-family: "Courier New", Courier, monospace;
}

body {
    min-width: 1280px;
    min-height: 800px;
    font-size: 12px;
    margin: 0px;
}

h1 {
    font-size: 20px;
    margin: 2px;
}

button {
    font-size: 12px;
}

#viewContainer {
    position: relative;
    min-width: 1280px;
    min-height: 720px;
    contain: content;
}

#view {
    image-rendering: pixelated;
    image-rendering: -moz-crisp-edges;
}

#viewDebug {
    display:none;
    position: absolute;
    top: 0px;
    left: 0px;
    pointer-events: none;
}

.table-header-rotated {
    border-collapse: collapse;
}
.table-header-rotated td {
    width: 30px;
}
.table-header-rotated td {
    text-align: center;
    padding: 10px 5px;
    border: 1px solid #ccc;
}
.table-header-rotated th.rotate {
    height: 140px;
    white-space: nowrap;
}
.table-header-rotated th.rotate > div {
    -webkit-transform: translate(25px, 51px) rotate(270deg);
    transform: translate(25px, 51px) rotate(315deg);
    width: 30px;
}
.table-header-rotated th.rotate > div > span {
    border-bottom: 1px solid #ccc;
    padding: 5px 10px;
}
.table-header-rotated th.row-header {
    padding: 0 10px;
    border-bottom: 1px solid #ccc;
}
