:root{
  --bg:#0b1020;
  --panel:#111a33;
  --panel2:#0f1730;
  --text:#e9ecf5;
  --muted:#9aa6c3;
  --line:#203057;
  --good:#49d17c;
  --bad:#ff5d5d;
  --warn:#ffcc66;
}

*{box-sizing:border-box}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  background: radial-gradient(1000px 600px at 10% 0%, #182553 0%, var(--bg) 55%);
  color:var(--text);
}

.wrap{max-width:1100px;margin:0 auto;padding:18px}
.top{
  display:flex;gap:16px;align-items:center;justify-content:space-between;
  padding:14px 14px;
  border:1px solid var(--line);
  background:linear-gradient(180deg,var(--panel),var(--panel2));
  border-radius:14px;
}
.brand{display:flex;align-items:center;gap:12px}
.logo{font-size:28px}
.title{font-size:18px;font-weight:700}
.sub{font-size:12px;color:var(--muted)}
.controls{display:flex;gap:10px;align-items:end;flex-wrap:wrap;justify-content:flex-end}
.field{display:flex;flex-direction:column;gap:6px}
label{font-size:11px;color:var(--muted)}
input{
  background:#0a1228;border:1px solid var(--line);color:var(--text);
  padding:10px 10px;border-radius:10px;outline:none;
}
input:focus{border-color:#3554a9}
button{
  padding:10px 12px;border-radius:10px;border:1px solid #3554a9;
  background:#2a46a2;color:white;font-weight:600;cursor:pointer;
}
button.ghost{background:transparent;border-color:var(--line);color:var(--text)}
button:active{transform:translateY(1px)}
.main{
  margin-top:14px;
  display:grid;
  grid-template-columns: 1fr 320px;
  gap:14px;
}
@media (max-width: 980px){
  .main{grid-template-columns:1fr}
}
.chat{
  border:1px solid var(--line);
  background:linear-gradient(180deg,var(--panel),var(--panel2));
  border-radius:14px;
  padding:12px;
  display:flex;flex-direction:column;
  min-height:70vh;
}
.meta{
  display:flex;justify-content:space-between;gap:10px;
  padding:6px 6px 10px 6px;
  color:var(--muted);font-size:12px;
}
.mono{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;}
.log{
  flex:1;
  overflow:auto;
  border:1px solid var(--line);
  border-radius:12px;
  padding:10px;
  background:#07102a;
}
.row{margin:6px 0;line-height:1.35}
.time{color:var(--muted);font-size:11px;margin-right:6px}
.nick{font-weight:700;margin-right:6px}
.msg{white-space:pre-wrap;word-break:break-word}
.sys{color:var(--muted)}
.good{color:var(--good)}
.bad{color:var(--bad)}
.warn{color:var(--warn)}
.send{display:flex;gap:10px;margin-top:10px}
.send input{flex:1}
.hint{margin-top:8px;color:var(--muted);font-size:12px}
.kbd{padding:2px 6px;border:1px solid var(--line);border-radius:8px;background:#0a1228;font-family:ui-monospace}

.side{display:flex;flex-direction:column;gap:14px}
.card{
  border:1px solid var(--line);
  background:linear-gradient(180deg,var(--panel),var(--panel2));
  border-radius:14px;
  padding:12px;
}
.cardTitle{font-weight:800;margin-bottom:8px}
.events{display:flex;flex-direction:column;gap:8px}
.ev{font-size:12px;color:var(--muted);border-left:2px solid var(--line);padding-left:10px}
.small{font-size:13px;color:var(--muted)}
.foot{margin-top:14px;color:var(--muted);font-size:12px;text-align:center}