:root {
  --bg: #0e0f12; --surface: #16181d; --surface-2: #1e2129;
  --text: #e6e7ea; --muted: #9aa0ab; --accent: #40e0d0; --danger: #ff6b6b;
  --border: #262a33; --radius: 10px; --gap: 16px;
  --font: system-ui, -apple-system, "Segoe UI", sans-serif;
  --mono: ui-monospace, "SF Mono", Menlo, monospace;
}
* { box-sizing: border-box; }
body { margin: 0; background: var(--bg); color: var(--text); font-family: var(--font); }
.bar { display: flex; align-items: center; justify-content: space-between;
  padding: 14px 20px; border-bottom: 1px solid var(--border); background: var(--surface); }
.bar h1 { font-size: 16px; font-weight: 500; margin: 0; letter-spacing: .3px; }
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--gap); padding: 20px; }
.card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 16px; text-decoration: none; color: inherit; transition: border-color .15s, transform .15s; }
.card:hover { border-color: var(--accent); transform: translateY(-2px); }
.card .id { font-family: var(--mono); font-size: 13px; color: var(--muted); }
.card .name { font-size: 15px; margin: 6px 0 12px; }
.pill { display: inline-flex; align-items: center; gap: 6px; font-size: 12px;
  padding: 3px 9px; border-radius: 999px; background: var(--surface-2); color: var(--muted); }
.pill::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--muted); }
.pill.online { color: var(--accent); } .pill.online::before { background: var(--accent); }
.login-wrap { min-height: 100vh; display: grid; place-items: center; }
.login { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 28px; width: 320px; }
.login h1 { font-size: 18px; font-weight: 500; margin: 0 0 20px; }
.login input { width: 100%; padding: 11px 12px; margin-bottom: 12px; background: var(--bg);
  border: 1px solid var(--border); border-radius: 8px; color: var(--text); font-size: 14px; }
.login input:focus { outline: none; border-color: var(--accent); }
button { background: var(--accent); color: #06201d; border: 0; border-radius: 8px;
  padding: 11px 16px; font-size: 14px; font-weight: 500; cursor: pointer; width: 100%; }
button:hover { filter: brightness(1.08); }
.stage { display: grid; grid-template-columns: 1fr; gap: 12px; padding: 16px; max-width: 900px; margin: 0 auto; }
canvas { width: 100%; background: #000; border: 1px solid var(--border); border-radius: var(--radius);
  cursor: crosshair; touch-action: none; }
.controls { display: flex; flex-wrap: wrap; gap: 8px; }
.controls button { width: auto; background: var(--surface-2); color: var(--text); border: 1px solid var(--border); }
.controls button:hover { border-color: var(--accent); filter: none; }
.status { font-family: var(--mono); font-size: 12px; color: var(--muted); }
.card { display: flex; flex-direction: column; gap: 5px; }
.card:hover { transform: none; }
.title-input { width: 100%; background: var(--bg); border: 1px solid var(--border);
  border-radius: 6px; color: var(--text); font: 500 15px var(--font); padding: 8px 10px; }
.title-input:focus { outline: none; border-color: var(--accent); }
.title-input::placeholder { color: var(--muted); font-weight: 400; }
.meta { font-family: var(--mono); font-size: 11px; color: var(--muted); }
.row { display: flex; align-items: center; justify-content: space-between; margin-top: 8px; }
.open { color: var(--accent); text-decoration: none; font-size: 13px; font-weight: 500; }
.open:hover { text-decoration: underline; }
.bar-right { display: flex; align-items: center; gap: 12px; }
.search { background: var(--bg); border: 1px solid var(--border); border-radius: 8px;
  color: var(--text); font-size: 14px; padding: 8px 12px; width: min(260px, 46vw); }
.search:focus { outline: none; border-color: var(--accent); }
.search::placeholder { color: var(--muted); }
select.search { cursor: pointer; }
.logwrap { padding: 12px 20px; overflow-x: auto; }
.logs { width: 100%; border-collapse: collapse; font-family: var(--mono); font-size: 12px; }
.logs td { padding: 5px 12px; border-bottom: 1px solid var(--border); vertical-align: top; }
.logs th { text-align: left; padding: 7px 12px; color: var(--muted); font-weight: 500;
  border-bottom: 1px solid var(--border); position: sticky; top: 0; background: var(--bg); }
.log-time { color: var(--muted); white-space: nowrap; }
.log-dev { color: var(--text); white-space: nowrap; }
.log-serial { color: var(--muted); white-space: nowrap; }
.log-type { font-weight: 500; white-space: nowrap; }
.log-detail { color: var(--muted); }
.log-connect .log-type { color: var(--accent); }
.log-disconnect .log-type { color: var(--danger); }
.log-error .log-type { color: var(--danger); }
