[v-cloak] {
    display: none;
}

body {
    font-family: Helvetica;
}

h1 {
    font-size: 3em;
    font-weight: bold;
}

h2 {
    font-size: 2em;
    font-weight: bold;
}

h3 {
    font-size: 1.3em;
    font-weight: bold;
}

button {
    border: 1px solid slategray;
    border-radius: 3px;
    padding: 10px 15px;
}

button.small {
    padding: 5px;
}

.hidden {
    visibility: hidden;
}

.inline-clique {
    white-space: nowrap;
    display: inline-block;
}

.std-row {
    padding: 10px 0;
}

#top-bar {
    display: flex;
    justify-content: space-between;
    border-bottom: 1px solid slategray;
}

#top-bar h1 {
    font-size: 1.4em;
    font-weight: bold;
}

#top-bar .content {
    flex-grow: 1;
    padding: 5px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}

#top-bar button {
    border-radius: 0;
    border-right: none;
    border-bottom: none;
    border-top: none;
}

.actions-box {
    display: flex;
    align-items: center;
}

.actions-box > i {
    padding: 0 5px;
}

.actions-box input {
    border: none;
    height: 2.5em;
    line-height: 2.5em;
    padding: 0 10px;
    flex-grow: 1;
    min-width: 10px;
}

.actions-box .total {
    padding: 0 20px;
    white-space: nowrap;
}

.actions-box button {
    border-top: none;
    border-bottom: none;
    border-radius: 0;
    height: 100%;
}

.actions-box .clear-input {
    color: gray;
}

.tabs-box {
    border-top: 1px solid slategray;
    border-bottom: 1px solid slategray;
    height: 4em;
    display: flex;
    align-items: center;
    box-shadow: 0 5px 10px rgba(0,0,0,.4);
    margin-bottom: 20px;
}

.tabs-box .title {
    font-size: 1.2em;
    border-bottom: 4px solid transparent;
    padding: 2px 6px;
    user-select: none;
}

.tabs-box li.active .title {
    border-bottom: 4px solid black;
}

.tabs-box li:hover .title {
    color: slategray;
    border-bottom: 4px solid slategray;
}

.tabs-box > * {
    flex-grow: 1;
    text-align: center;
    cursor: pointer;
}

.pane-head-box {
    padding: 10px;
    display: flex;
    align-items: center;
    flex-wrap: wrap;
}

.pane-head-box > * {
    margin: 0 5px;
}

.options-box {
    padding: 10px;
    box-shadow: 0 0 15px -5px inset;
    background-color: gainsboro;
}

.history-filter-row {
    line-height: 2.5em;
}

.history-filter-box strong {
    text-decoration: underline;
    font-weight: bold;
    cursor: pointer;
}

.history-filter-box .edit-time {
    display: inline-block;
}

.download-link {
    text-decoration: underline;
    cursor: pointer;
}

.qol-devices {
    display: flex;
}

.device-cell i {
    padding: 0 5px;
}

.device-cell {
    min-width: 3em;
    max-width: 5em;
    padding: 10px;
}

.device-id {
    white-space: nowrap;
}

.device-history {
    display: flex;
}

.device-history ul > li {
    font-size: .7em;
}

.device-history ul > li + li {
    background-color: crimson;
}

.qollector-table-container {
    overflow-x: scroll;
}

.qollector-table {
    width: 100%;
}

.qollector-table td, .qollector-table th {
    padding: 10px;
}

.qollector-table tr.named {
    border-top: 1px solid slategray;
}

.qollector-table td.stale {
    background-color: crimson;
    color: white;
}

.qollector-table samp {
    font-family: Helvetica;
}

.qollector-table thead {
    border-top: 1px solid slategray;
}

.qollector-table thead th {
    padding: 2px;
    font-weight: bold;
    text-align: center;
}

.qollector-table colgroup + colgroup {
    border-left: 1px solid slategray;
}

.qollector-table .load-cell {
    text-align: center;
    color: lightgray;
}

.qollector-table .load-cell i {
    cursor: pointer;
}

.qollector-list {
    border-top: 1px solid slategray;
}

.qollector-list > li.not-loaded {
    color: lightgray;
}

.qollector-list > li {
    font-size: 1.3em;
    padding: 0 10px;
    border-bottom: 1px solid slategray;
    min-height: 2.5em;
    display: flex;
    align-items: center;
}

.qol-name {
    cursor: pointer;
    padding-right: 30px;
    max-width: 7em;
}

#login-box {
    margin: 0 auto;
    max-width: 500px;
    padding: 50px 5px;
}

.login-top-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.qollector-detail-box {
    margin: 0 auto;
    max-width: 500px;
    padding: 10px;
}

.qollector-detail-box h2 {
    padding: 10px 0;
}

.qollector-detail-box .input-row label {
    width: 30%;
}

.btn-row {
    padding: 5px 0;
    text-align: right;
}

.text-input {
    padding: 5px 10px;
    border: 1px solid slategray;
    border-radius: 3px;
}

.input-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 5px 0;
}

.input-row input[type=checkbox] {
    margin: 0px 10px;
}

.input-row label {
    width: 25%;
    font-weight: bold;
    display: inline-block;
}

.input-row .text-input {
    flex-grow: 1;
}

.input-row .text-input.disabled {
    background-color: rgba(0,0,0,.1);
}

i.nav-arrow {
    font-size: 2em;
}

.info-box {
    border-radius: 3px;
    background-color: honeydew;
    padding: 15px;
    color: black;
}

.warning-box {
    border-radius: 3px;
    background-color: darkorange;
    padding: 15px;
    color: white;
}

.error-box {
    border-radius: 3px;
    background-color: crimson;
    padding: 15px;
    color: white;
}

#map {
    width: 100%;
    min-height: 500px;
}

.race-table {
    min-width: 50vw;
}

.race-table .current {
    background-color: lightblue;
}

.race-table .current .fa-check {
    visibility: visible;
}

.race-table .fa-check {
    visibility: hidden;
}

.race-table thead {
    border-bottom: 1px solid slategray;
}

.race-table tr {
    height: 2.5em;
}

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

.race-table td, .race-table th {
    padding: 5px 10px;
}

.race-table .race-row-controls {
    min-width: 100px;
}

.race-matching-box {
    border-top: 1px solid slategray;
    margin-top: 10px;
}

.action-text, .race-table .race-title {
    text-decoration: underline;
    cursor: pointer;
}

.danger-text {
    color: crimson;
}

.easement-a {
    padding: 10px;
}

.easement-v {
    padding: 10px 0;
}

.easement-h {
    padding: 0 10px;
}

.offsets-table {
    width: 100%;
}

.offsets-table thead {
    border-bottom: 1px solid slategray;
}

.offsets-table th {
    font-weight: bold;
    padding: 5px;
}

.offsets-list {
    padding: 10px;
}

.action-block {
    margin: 5px;
    border-radius: 3px;
    border: 1px solid slategray;
    cursor: pointer;
}

.column-control-box {
    display: flex;
    align-items: center;
    border: 1px solid slategray;
    border-radius: 3px;
}

.column-control-box > input {
    margin-left: 10px;
}

.column-control-box > label, .column-control-box > i {
    padding: 0 10px;
}

.column-control-box i.more {
    border-left: 1px solid slategray;
    line-height: 2.5em;
}

.column-control-box i.more.active {
    background-color: gainsboro;
}

.options-box button, .attrs-selection li {
    background-color: whitesmoke;
}

.attrs-selection {
    display: flex;
    flex-wrap: wrap;
    border-top: 1px solid slategray;
    padding-top: 10px;
    margin-top: 10px;
}

.attrs-selection li {
    border: 1px solid slategray;
    border-radius: 3px;
    margin: 3px;
    padding: 10px;
}

.attrs-selection li input {
    position: relative;
    top: .15em;
}
