:root{--bg:#0f1115;--card:#1a1d24;--head:#232734;--text:#e8eaed;--muted:#9aa0aa;--border:#2a2e39;
  --accent:#2ea043;--accent2:#1f6feb;--warn:#e3873b;--err:#d11f2a;}
*{box-sizing:border-box}html,body{margin:0;min-height:100%}
body{background:var(--bg);color:var(--text);font-family:'Segoe UI',Roboto,system-ui,sans-serif;
  padding-bottom:env(safe-area-inset-bottom)}
header{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg)}
header h1{font-size:1.15rem;margin:0}
header .sub{color:var(--muted);font-size:.85rem}
header .icon{margin-left:auto;background:var(--head);border:1px solid var(--border);color:var(--text);
  border-radius:10px;font-size:1.1rem;padding:6px 10px}
.hidden{display:none!important}
.card{background:var(--card);border:1px solid var(--border);border-radius:12px;margin:16px;padding:16px}
.card h2{margin:0 0 8px}
input{width:100%;padding:12px;border-radius:10px;border:1px solid var(--border);background:#11141a;color:var(--text);font-size:1.05rem}
button{cursor:pointer}
button.primary{background:var(--accent);color:#06210f;border:0;border-radius:10px;padding:12px 16px;font-weight:700;font-size:1rem}
button.stop{background:var(--err);color:#fff;border:0;border-radius:10px;padding:12px 16px;font-weight:700}
button.link{background:none;border:0;color:var(--muted);text-decoration:underline}
.err{color:var(--err)} .muted{color:var(--muted)}
main{padding:8px 16px 24px}
.buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:10px;margin:8px 0 14px}
.buttons button{background:var(--head);color:var(--text);border:1px solid var(--border);border-radius:12px;
  padding:14px 8px;font-size:1.05rem;font-weight:700}
.buttons button .tag{display:block;font-size:.7rem;font-weight:500;color:var(--muted);margin-top:2px}
.cmdrow{display:flex;gap:8px;margin-bottom:12px}
.cmdrow input{flex:1}
.log{display:flex;flex-direction:column;gap:6px}
.log .row{background:var(--card);border:1px solid var(--border);border-left:4px solid var(--border);
  border-radius:8px;padding:8px 10px;font-size:.95rem;white-space:pre-wrap;font-variant-numeric:tabular-nums}
.log .row.head{border-left-color:var(--accent2);font-weight:700;background:var(--head)}
.log .row.steht{border-left-color:var(--accent)}
.log .row.faehrt{border-left-color:var(--warn)}
.log .row.weg{border-left-color:var(--err);font-weight:700}
.log .row .t{color:var(--muted);margin-right:8px}
footer{display:flex;align-items:center;gap:12px;padding:10px 16px;border-top:1px solid var(--border)}
footer .muted{flex:1;font-size:.8rem}

/* v2: aufgeraeumte Zeilen */
button.ghost{background:var(--head);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:12px 14px;font-size:1.05rem}
.log .row{display:flex;flex-direction:column;gap:2px}
.log .row .r1{font-weight:700;font-size:1rem}
.log .row .r2{color:var(--muted);font-size:.88rem}
.log .row .t{color:var(--muted);font-weight:400;margin-right:6px;font-size:.82rem}
.badge-line{display:inline-block;min-width:26px;text-align:center;border-radius:6px;padding:0 6px;margin-right:6px;color:#06210f;font-weight:800}
.b-steht{background:#2ea043}.b-faehrt{background:#e3873b}.b-weg{background:#d11f2a;color:#fff}.b-none{background:#3a4150;color:#cfd3da}
.wake{margin-left:8px;font-size:.78rem;color:var(--accent)}
.log .row.info{border-left-color:var(--accent2);background:#191d27;font-size:.9rem}
.log .row.info .r1{font-weight:500}
.log .row.approach{border-left-color:#3b82f6}
.b-approach{background:#3b82f6;color:#fff}
