@media (max-width: 600px) {
    body {
        font-size: 12px;
    }
}

@media (max-width: 600px) {
    button {
        font-size: 10px;
    }
}


@media (max-width: 500px) {
    body {
        font-size: 10px;
    }
}

@media (max-width: 500px) {
    button {
        font-size: 8px;
    }
}


table.recordings {
    width: 100%;
    margin-top: 10px;
    margin-bottom: 30px;
    padding-left: 38px;
}

tr {
    height: 1.5em;
}

td.leftcol {
    padding-top: 7px;
    width: 70vw;
}

td.rightcol {
    padding-top: 1em;
    width: 16em;
    float: right;
}

td.userfill {
    width: 80vw;
    background-color: beige;
    padding: 5px;
}

span.note {
    font-size: smaller;
}

label {
    margin-right: 20px;
}

input.text {
    width: 200px;
}

details {
    font-size: smaller;
    padding-top: 1px;
}

p.feature {
    padding-left: 5vw;
}

p.sources {
    padding-top: 3px;
    padding-left: 5vw;
    padding-bottom: 3px;
}

span.source {
    display: inline-block;
    font-family: monospace;
    padding-top: 1px;
    width: 200px;
    cursor: pointer;
}

.disabled {
    color: lightgray;
}

p.mapinstructions {
    float: right;
    padding-top: 5px;
    padding-bottom: 10px;
}

@media (max-width: 500px) {
    input.text {
        width: 100px;
    }
}

input.upload {
    float: right;
}

hr.separate {
    margin-top: 20px;
    margin-bottom: 20px;
}

table.settings {
    width: 100%;
    margin-top: 10px;
    padding-left: 38px;
}

td.paramname {
    width: 100px;
}

td.paramedit {
    width: 70px;
    text-align: right;
}

span.error {
    color: red;
    font-size: smaller;
}

a.download {
    float: right;
    padding-right: 10px;
}

button.delete {
    float: right;
    color: red;
    margin-right: 2px;
    margin-left: 5px;
}

button.save {
    float: right;
}

h2.addspace {
    margin-top: 25px;
    margin-bottom: 5px;
}

p.item {
    margin-top: 13px;
    margin-left: 42px;
}

p.note {
    margin-left: 42px;
    margin-top: 10px; 
}

table.subscriptions {
    width: 100%;
    margin-top: 10px;
    padding-left: 38px;
}

span.status {
    display: inline-block;
    width: 25px;
    font-size: larger;
}

span.status_ok {
    color: green;
}

span.status_warning {
    color: orange;
}

span.status_expired {
    color: red;
}

/* gateway */

p.gwpage {
    margin-top: 1vh;
}

div.downloads {
    margin-top: 3vh;
    margin-left: 20px;
    margin-right: 20px;
    display: flex;
    justify-content: space-between;
}

div.download {
    width: 35vw;
}