form {
    margin-bottom: 0;
}

.narrow-page {
    max-width: 34rem;
}

.form-error {
    color: #991b1b;
}

.user-create-form,
.user-row-form {
    display: flex;
    align-items: end;
    gap: .5rem;
    flex-wrap: wrap;
}

.user-create-form label,
.user-row-form label {
    width: auto;
    margin: 0;
}

.user-row-form input,
.user-row-form select,
.user-row-form button,
.user-create-form input,
.user-create-form select,
.user-create-form button {
    width: auto;
    margin: 0;
}

.app-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.account-nav {
    display: inline-flex;
    align-items: center;
    gap: .75rem;
    flex-wrap: wrap;
}

.account-nav form {
    display: inline-flex;
}

.account-nav button {
    width: auto;
    margin: 0;
    padding: .35rem .6rem;
}

.admin-server-tools {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: .75rem;
    flex-wrap: wrap;
    margin-bottom: .75rem;
}

.add-server-form {
    display: flex;
    align-items: end;
    gap: .75rem;
    flex-wrap: wrap;
}

.add-server-form label {
    width: auto;
    min-width: 12rem;
    margin: 0;
}

.add-server-form input {
    margin-bottom: 0;
}

.add-server-form button,
.refresh-all-button {
    width: auto;
    margin: 0;
}

form.server-filters {
    --filter-control-height: 2.35rem;
    display: grid;
    grid-template-columns: minmax(18rem, 1.4fr) minmax(10rem, .75fr) minmax(11rem, .8fr) auto;
    align-items: end;
    gap: .75rem;
    padding: .625rem .75rem;
    margin-bottom: 1rem;
    border: 1px solid var(--pico-muted-border-color);
    border-radius: .375rem;
    background: var(--pico-card-background-color);
}

.filter-group,
.filter-field {
    display: grid;
    grid-template-rows: 1rem var(--filter-control-height);
    gap: .25rem;
    min-width: 0;
    margin: 0;
}

.filter-label {
    color: var(--pico-muted-color);
    font-size: .75rem;
    font-weight: 600;
    line-height: 1;
    margin: 0;
}

.filter-checks {
    display: flex;
    align-items: center;
    gap: .5rem;
    height: var(--filter-control-height);
    min-width: 0;
}

.filter-check {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    height: var(--filter-control-height);
    padding: 0 .65rem;
    border: 1px solid var(--pico-muted-border-color);
    border-radius: .25rem;
    margin: 0;
    background: var(--pico-background-color);
    white-space: nowrap;
    font-size: .9rem;
}

.filter-check input {
    margin: 0;
}

.filter-select {
    height: var(--filter-control-height);
    min-width: 0;
}

.filter-select select {
    box-sizing: border-box;
    display: block;
    width: 100%;
    height: 100%;
    min-height: 0;
    margin: 0;
    padding-top: 0;
    padding-bottom: 0;
    font-size: .9rem;
    line-height: normal;
    color: var(--pico-color);
}

.filter-actions {
    display: flex;
    align-items: center;
    gap: .5rem;
    justify-self: end;
}

form.server-filters button,
form.server-filters .filter-clear {
    width: auto;
    min-height: var(--filter-control-height);
    margin: 0;
    padding: .45rem .7rem;
    white-space: nowrap;
}

@media (max-width: 900px) {
    form.server-filters {
        grid-template-columns: minmax(18rem, 1fr) minmax(10rem, 1fr);
    }

    .filter-actions {
        justify-self: start;
    }
}

@media (max-width: 640px) {
    form.server-filters {
        grid-template-columns: 1fr;
    }

    .filter-checks {
        flex-wrap: wrap;
    }

    .filter-actions {
        justify-self: stretch;
    }

    form.server-filters button,
    form.server-filters .filter-clear {
        flex: 1 1 auto;
        text-align: center;
    }
}

tr.server-row {
    cursor: pointer;
}

.row-actions {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
}

.row-actions form {
    display: inline-flex;
}

.icon-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    margin: 0;
    padding: 0;
    line-height: 1;
}

.icon-button.danger {
    --pico-background-color: #991b1b;
    --pico-border-color: #991b1b;
}

tr.server-row:hover td {
    background: rgba(105, 117, 90, .08);
}

tr.server-row:focus-visible {
    outline: 2px solid #6b705c;
    outline-offset: -2px;
}

tr.server-row.offline td {
    background: rgba(153, 27, 27, .10);
    color: var(--pico-muted-color);
}

tr.server-row.offline:hover td {
    background: rgba(153, 27, 27, .16);
}

tr.server-row.server-row-updated td {
    animation: server-row-updated 1.8s ease-out;
}

tr.server-row.offline.server-row-updated td {
    animation-name: server-row-updated-offline;
}

@keyframes server-row-updated {
    from {
        background-color: rgba(250, 204, 21, .26);
    }

    to {
        background-color: transparent;
    }
}

@keyframes server-row-updated-offline {
    from {
        background-color: rgba(250, 204, 21, .26);
    }

    to {
        background-color: rgba(153, 27, 27, .10);
    }
}

.row-caret {
    display: inline-block;
    margin-right: .35rem;
    transition: transform .12s ease;
}

tr.server-row[aria-expanded="true"] .row-caret {
    transform: rotate(90deg);
}

.time-of-day {
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    white-space: nowrap;
}

.time-icon {
    display: inline-flex;
    justify-content: center;
    width: 1.1em;
    line-height: 1;
}

.time-icon-day {
    color: #a16207;
}

.time-icon-night {
    color: #475569;
}

tr.server-detail-row td {
    background: var(--pico-card-background-color);
}

.server-detail-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
    gap: .75rem 1.25rem;
    margin: .25rem 0;
}

.server-detail-grid div,
.detail-grid div {
    min-width: 0;
}

.server-detail-grid strong,
.detail-grid dt {
    color: var(--pico-muted-color);
    font-size: .85rem;
    font-weight: 600;
}

.server-detail-grid strong {
    display: block;
}

.server-detail-grid code,
.detail-grid code {
    white-space: normal;
    word-break: break-word;
}

.server-title {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 1rem;
    flex-wrap: wrap;
}

.server-status {
    color: var(--pico-muted-color);
}

.detail-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
    gap: 1rem 1.5rem;
    margin-top: 1.5rem;
}

.detail-grid dt {
    margin: 0;
}

.detail-grid dd {
    margin: .15rem 0 0;
}

.server-mods {
    grid-column: 1 / -1;
}

.mod-list {
    margin: .25rem 0 0;
    padding-left: 1.25rem;
}

.copy-line {
    display: flex;
    align-items: center;
    gap: .5rem;
    flex-wrap: wrap;
}

.copy-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
    margin: 0;
    padding: 0;
    line-height: 1;
    flex: 0 0 auto;
}

.copy-button::before {
    content: "⧉";
    font-size: 1rem;
}

.copy-button[data-copy-state="copied"]::before {
    content: "✓";
}

.copy-button[data-copy-state="failed"]::before {
    content: "!";
    font-weight: 700;
}
