:root {
  --bg: #0e1013;
  --panel: #171a20;
  --border: #262b33;
  --text: #e6e8eb;
  --mute: #8b909a;
  --accent: #7c9cff;
  --good: #66c08d;
  --warn: #d88c3a;
  --bad: #d86969;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--text);
  font: 15px/1.5 ui-sans-serif, system-ui, -apple-system, "SF Pro Text", sans-serif; }
main { max-width: 640px; margin: 0 auto; padding: 32px 24px 80px; }

header { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 28px; }
header h1 { font-size: 20px; font-weight: 600; margin: 0; flex: 1; }
.who { color: var(--mute); font-size: 13px; }

main.auth { max-width: 420px; margin: 80px auto; padding: 32px 24px; text-align: center; }
main.auth h1 { font-size: 22px; margin: 0 0 28px; }
main.auth form { display: flex; flex-direction: column; gap: 12px; margin: 20px 0; }
main.auth input { padding: 12px 14px; font-size: 15px; }
main.auth button { padding: 12px 16px; font-size: 15px; background: var(--accent); color: #0b0e16; border: none; font-weight: 600; }
main.auth button:hover:not(:disabled) { filter: brightness(1.08); }
main.auth .error { color: var(--bad); font-size: 13px; margin-top: 12px; }

h2 { font-size: 13px; font-weight: 500; color: var(--mute); text-transform: uppercase;
  letter-spacing: 0.08em; margin: 0 0 12px; }

section { margin-bottom: 32px; }

input, button {
  font: inherit; color: var(--text); background: var(--panel);
  border: 1px solid var(--border); border-radius: 8px; padding: 8px 12px;
}
input { min-width: 240px; }
input::placeholder { color: var(--mute); }

button { cursor: pointer; transition: background 0.12s, border-color 0.12s; }
button:hover:not(:disabled) { border-color: var(--accent); }
button:disabled { opacity: 0.4; cursor: not-allowed; }
button.small { padding: 4px 10px; font-size: 13px; }
button.secondary { background: transparent; color: var(--mute); border-color: transparent; }
button.secondary:hover { color: var(--text); border-color: var(--border); }
button.danger { background: #2a1a1a; border-color: #5a2a2a; color: #eca; }
button.danger:hover { border-color: var(--bad); }

.kind-row { display: flex; gap: 10px; flex-wrap: wrap; }
.kind { padding: 14px 20px; font-size: 15px; font-weight: 500; background: var(--panel); }
.kind:hover:not(:disabled) { background: #1c2029; }

.hint { color: var(--mute); font-size: 13px; margin-top: 12px; }

.status-card { background: var(--panel); border: 1px solid var(--border);
  border-radius: 10px; padding: 16px; }
.row { display: flex; align-items: baseline; gap: 12px; padding: 6px 0;
  border-bottom: 1px solid var(--border); }
.row:last-child { border-bottom: none; }
.row .label { color: var(--mute); font-size: 13px; width: 86px; flex: 0 0 86px; }
.row code { font-family: ui-monospace, "SF Mono", monospace; font-size: 13px; }
.row.error { color: var(--bad); }

.state { font-weight: 500; }
.state.searching, .state.provisioning, .state.pulling_image,
.state.loading_model, .state.archiving, .state.ending { color: var(--warn); }
.state.ready, .state.active { color: var(--good); }
.state.destroyed { color: var(--mute); }
.state.failed { color: var(--bad); }

progress { width: 100%; height: 6px; margin: 16px 0; -webkit-appearance: none; appearance: none;
  border: none; border-radius: 3px; overflow: hidden; background: var(--border); }
progress::-webkit-progress-bar { background: var(--border); }
progress::-webkit-progress-value { background: var(--accent); transition: width 0.3s; }
progress::-moz-progress-bar { background: var(--accent); }

.actions { display: flex; gap: 10px; margin-top: 16px; }

#history { list-style: none; padding: 0; margin: 0; }
#history li { padding: 8px 0; border-bottom: 1px solid var(--border);
  display: flex; gap: 12px; align-items: center; font-size: 13px; }
#history code { color: var(--mute); font-family: ui-monospace, monospace; }
#history .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--mute); }
#history .dot.ready, #history .dot.active { background: var(--good); }
#history .dot.failed { background: var(--bad); }
#history .dot.destroyed { background: var(--mute); }

.hidden { display: none !important; }
