/* UAVPCB control-plane — минимальный CSS, расширяется в фазе 1. */

:root {
    --bg: #0B0B0E;
    --fg: #E5E7EB;
    --accent: #5BA8A0;
    --border: #1F2937;
    --font: 'IBM Plex Sans', system-ui, -apple-system, sans-serif;
    --mono: 'JetBrains Mono', ui-monospace, monospace;
}

* { box-sizing: border-box; }

body {
    margin: 0;
    background: var(--bg);
    color: var(--fg);
    font-family: var(--font);
    font-size: 14px;
    line-height: 1.5;
}

.topbar {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    padding: 0.75rem 1.5rem;
    border-bottom: 1px solid var(--border);
}

.topbar .logo {
    font-family: var(--mono);
    font-weight: 700;
    color: var(--accent);
    text-decoration: none;
    letter-spacing: 0.05em;
}

.topbar nav { display: flex; gap: 1rem; margin-left: auto; }
.topbar nav a { color: var(--fg); text-decoration: none; }
.topbar nav a:hover { color: var(--accent); }

.container {
    max-width: 800px;
    margin: 2rem auto;
    padding: 0 1.5rem;
}

h1 { font-size: 1.5rem; margin-top: 0; }

form { display: flex; flex-direction: column; gap: 0.75rem; max-width: 320px; }
label { display: flex; flex-direction: column; gap: 0.25rem; }
input {
    background: transparent;
    color: var(--fg);
    border: 1px solid var(--border);
    padding: 0.5rem;
    font-family: var(--mono);
    font-size: 14px;
}
input:focus { outline: none; border-color: var(--accent); }

button {
    background: var(--accent);
    color: var(--bg);
    border: none;
    padding: 0.5rem 1rem;
    cursor: pointer;
    font-family: var(--mono);
    font-weight: 600;
}
button:hover { filter: brightness(1.1); }
button.danger {
    background: transparent;
    color: #EF4444;
    border: 1px solid #EF4444;
    padding: 0.2rem 0.5rem;
}

.error { color: #EF4444; min-height: 1.2em; }
.dim { color: #6B7280; font-size: 12px; }

table { width: 100%; border-collapse: collapse; margin: 1rem 0; }
th, td { text-align: left; padding: 0.5rem 0.75rem; border-bottom: 1px solid var(--border); }
th { font-weight: 600; color: var(--accent); font-size: 12px; text-transform: uppercase; letter-spacing: 0.05em; }
td a { color: var(--fg); text-decoration: none; }
td a:hover { color: var(--accent); }

.status {
    display: inline-block;
    padding: 0.1rem 0.5rem;
    border-radius: 2px;
    font-family: var(--mono);
    font-size: 11px;
    text-transform: uppercase;
}
.status-ready { background: #064E3B; color: #34D399; }
.status-pending, .status-provisioning, .status-bootstrapping { background: #1F2937; color: #FBBF24; }
.status-failed { background: #1F2937; color: #EF4444; }
.status-offline { background: #1F2937; color: #EF4444; }
.status-destroyed { background: #1F2937; color: #6B7280; }

dl.kv { display: grid; grid-template-columns: max-content 1fr; gap: 0.25rem 1rem; max-width: 600px; }
dl.kv dt { color: var(--accent); font-family: var(--mono); font-size: 12px; }
dl.kv dd { margin: 0; }

code {
    font-family: var(--mono);
    background: var(--border);
    padding: 0 0.25rem;
    border-radius: 2px;
    font-size: 13px;
}
code.big {
    font-size: 18px;
    letter-spacing: 0.15em;
    background: transparent;
    color: var(--accent);
    font-weight: 700;
}

fieldset.provider-choice {
    border: 1px solid var(--border);
    padding: 0.5rem 1rem;
    display: flex;
    gap: 1rem;
}
fieldset.provider-choice legend { color: var(--accent); font-size: 12px; padding: 0 0.3rem; }
fieldset.provider-choice label { flex-direction: row; align-items: center; gap: 0.3rem; }
