/* hosting-admin — минимальная тёмная тема */

:root {
    --bg:       #0b1020;
    --bg2:      #0f172a;
    --bg3:      #1e293b;
    --border:   #334155;
    --text:     #e2e8f0;
    --dim:      #94a3b8;
    --brand:    #60a5fa;
    --ok:       #22c55e;
    --warn:     #facc15;
    --crit:     #ef4444;
    --unknown:  #94a3b8;
    --link:     #93c5fd;
}

* { box-sizing: border-box; }

body {
    margin: 0;
    background: var(--bg);
    color: var(--text);
    font: 14px/1.45 system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

a       { color: var(--link); text-decoration: none; }
a:hover { text-decoration: underline; }

.topbar {
    display: flex;
    align-items: center;
    gap: 24px;
    padding: 12px 24px;
    background: var(--bg2);
    border-bottom: 1px solid var(--border);
}
.topbar .brand {
    font-weight: 600;
    color: var(--brand);
}
.topbar nav { display: flex; gap: 16px; margin-left: 8px; flex: 1; }
.topbar nav a { color: var(--text); }
.topbar nav a.logout { margin-left: auto; color: var(--dim); }

.page {
    padding: 24px;
    max-width: 1400px;
    margin: 0 auto;
}

h1 {
    margin: 0 0 16px;
    font-size: 22px;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 12px;
}
h2 {
    margin: 24px 0 8px;
    font-size: 16px;
    font-weight: 600;
    color: var(--dim);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.action {
    font-size: 12px;
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 2px 8px;
    color: var(--dim);
}

.empty {
    color: var(--dim);
    padding: 24px;
    text-align: center;
    background: var(--bg2);
    border: 1px dashed var(--border);
    border-radius: 6px;
}

/* === server grid === */

.server-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 16px;
}

.server-card {
    display: block;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 16px;
    color: var(--text);
}
.server-card:hover { border-color: var(--brand); text-decoration: none; }
.server-card.stale { border-color: var(--crit); }

.server-card .row { display: flex; align-items: center; gap: 8px; }
.server-card .row.meta { margin-top: 4px; flex-wrap: wrap; }
.server-card .hostname { font-size: 16px; font-weight: 600; }
.server-card .ip { color: var(--dim); margin-left: auto; font-family: monospace; font-size: 13px; }

.tag {
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: 3px;
    padding: 1px 6px;
    font-size: 11px;
    color: var(--dim);
}

.metrics {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    margin-top: 12px;
}
.metrics .m .lbl { font-size: 11px; color: var(--dim); text-transform: uppercase; letter-spacing: 0.05em; }
.metrics .m .val { font-size: 15px; font-weight: 500; margin-top: 2px; }

.footer { margin-top: 12px; padding-top: 8px; border-top: 1px solid var(--border); }
.last-seen { font-size: 12px; color: var(--dim); }

/* === table === */

.table {
    width: 100%;
    border-collapse: collapse;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 6px;
    overflow: hidden;
}
.table th {
    text-align: left;
    padding: 10px 12px;
    background: var(--bg3);
    border-bottom: 1px solid var(--border);
    font-size: 12px;
    text-transform: uppercase;
    color: var(--dim);
    font-weight: 600;
}
.table td {
    padding: 10px 12px;
    border-bottom: 1px solid var(--border);
    font-size: 13px;
}
.table tr:last-child td { border-bottom: 0; }

/* === details kv === */

.meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 12px 16px;
    margin-bottom: 8px;
    font-size: 13px;
}

.kv {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 6px 16px;
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 12px 16px;
    font-size: 13px;
}
.kv .k { color: var(--dim); display: inline-block; min-width: 110px; }

/* === status colors === */

.ok      { color: var(--ok); }
.warn    { color: var(--warn); }
.crit    { color: var(--crit); font-weight: 600; }
.unknown { color: var(--unknown); }
.dim     { color: var(--dim); font-weight: normal; }

/* === login === */

body.login {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
}
body.login .card {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: 8px;
    padding: 24px;
    min-width: 320px;
}
body.login h1 { margin: 0 0 16px; font-size: 18px; }
body.login label { display: block; margin-bottom: 12px; }
body.login label span { display: block; font-size: 12px; color: var(--dim); margin-bottom: 4px; }
body.login input[type=text],
body.login input[type=password] {
    width: 100%;
    background: var(--bg3);
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: 4px;
    padding: 8px 10px;
    font-size: 14px;
}
body.login button {
    width: 100%;
    background: #2563eb;
    color: white;
    border: 0;
    border-radius: 4px;
    padding: 10px;
    cursor: pointer;
    font-size: 14px;
    margin-top: 8px;
}
body.login .err {
    color: #fca5a5;
    background: #7f1d1d;
    border: 1px solid var(--crit);
    border-radius: 4px;
    padding: 8px 10px;
    margin-bottom: 12px;
    font-size: 13px;
}
