/* 基础样式 */
:root {
  --bg: #0b1020;
  --panel: #141a2e;
  --text: #e6eefc;
  --muted: #9fb0d3;
  --accent: #4ea1ff;
  --ok: #2ecc71;
  --warn: #f1c40f;
  --err: #e74c3c;
  --border: #24314f;
}

* { box-sizing: border-box; }
html, body { height: 100%; }
body {
  margin: 0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  background: linear-gradient(180deg, #0b1020, #0f1530);
  color: var(--text);
  line-height: 1.5;
}

header { padding: 20px; text-align: center; background: transparent; }
header { position: relative; }
header h1 { margin: 0; font-size: 22px; font-weight: 600; color: var(--text); }

/* 右上角模式切换按钮 */
.mode-toggle {
  position: absolute;
  right: 20px;
  top: 20px;
  padding: 8px 12px;
  border: 1px solid var(--border);
  background: #17213f;
  color: var(--text);
  border-radius: 8px;
  cursor: pointer;
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
}
.mode-toggle:hover { background: #1b2850; }
.mode-toggle:disabled { opacity: .5; cursor: not-allowed; }

main { max-width: 1000px; margin: 0 auto; padding: 16px; }

.connect-panel, .io-panel { background: var(--panel); border: 1px solid var(--border); border-radius: 12px; padding: 16px; box-shadow: 0 10px 30px rgba(0,0,0,.35); }
.connect-panel { margin-bottom: 16px; }

.field { display: flex; gap: 12px; align-items: center; }
.field label { width: 96px; color: var(--muted); }
.field input {
  flex: 1;
  padding: 10px 12px;
  border: 1px solid var(--border);
  background: #0f1630;
  color: var(--text);
  border-radius: 8px;
}

.actions { display: flex; gap: 10px; margin-top: 10px; }
button {
  padding: 10px 16px;
  border: 1px solid var(--border);
  background: #17213f;
  color: var(--text);
  border-radius: 8px;
  cursor: pointer;
}
button:hover { background: #1b2850; }
button:disabled { opacity: .5; cursor: not-allowed; }

.status { margin-top: 8px; color: var(--muted); }
.status.ok { color: var(--ok); }
.status.err { color: var(--err); }

.io-panel { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

.send textarea {
  width: 100%;
  padding: 10px;
  border: 1px solid var(--border);
  background: #0f1630;
  color: var(--text);
  border-radius: 8px;
}

/* 应用模式：快捷指令按钮网格 */
.cmd-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
  margin-top: 8px;
}
.app-cmd {
  min-height: 40px;
}

.log h3 { margin: 0 0 8px; color: var(--muted); font-weight: 600; }
.log-box {
  height: 260px;
  overflow: auto;
  border: 1px solid var(--border);
  background: #0f1630;
  border-radius: 8px;
  padding: 8px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 12px;
}

.log-line { margin: 0; white-space: pre-wrap; word-break: break-word; }
.log-line .t { color: var(--muted); }
.log-line .rx { color: var(--ok); }
.log-line .tx { color: var(--accent); }
.log-line .sys { color: var(--warn); }

footer { text-align: center; padding: 12px; color: var(--muted); }

@media (max-width: 840px) {
  .io-panel { grid-template-columns: 1fr; }
}

/* 优化连接卡片布局：让登录区块更松弛、更美观 */
.connect-panel > #auth-block {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  padding-bottom: 8px;
  border-bottom: 1px dashed var(--border);
  margin-bottom: 10px;
}

/* 登录表单行：可换行，按钮与输入保持间距 → 升级为两行布局 */
#auth-block .auth-status-row {
  display: flex;
  align-items: center;
  gap: 12px; /* 与 .field 的 gap(12px) 保持一致，解决视觉错位 */
  flex-wrap: wrap;
}
#auth-block .auth-input-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px 10px;
  margin-top: 2px;
}

/* 登录输入宽度与可读性 */
#auth-block input[type="text"],
#auth-block input[type="password"] {
  width: 180px;
}

/* 登录状态徽标化（增强对比 + 对齐修正） */
#login-status {
  display: inline-flex;              /* 使徽标内文字垂直置中 */
  align-items: center;
  line-height: 1;
  padding: 4px 10px;                /* 稍厚的内边距，增强识别性 */
  background: #17213f;              /* 中性底色，默认态 */
  border: 1px solid var(--border);
  border-radius: 999px;
  font-size: 12px;
  color: var(--muted);
  margin-top: 0;                    /* 覆盖 .status 的 margin-top，避免下沉导致未对齐 */
}
#login-status.ok {                  /* 已登录：强对比绿色徽标 */
  background: var(--ok);
  color: #0b1020;
  border-color: transparent;
}
#login-status.err {                 /* 未登录/失败：强对比红色徽标 */
  background: var(--err);
  color: #ffffff;
  border-color: transparent;
}
#login-status.warn {                /* 异常/未知：高对比黄色徽标 */
  background: var(--warn);
  color: #0b1020;
  border-color: transparent;
}

/* 提示信息弱化与换行 */
#login-hint {
  font-size: 12px;
  color: var(--muted);
}

/* 连接卡片通用纵向间距 */
.connect-panel .field { margin-bottom: 10px; }
.connect-panel .actions { margin-top: 8px; }

@media (max-width: 600px) {
  #auth-block input[type="text"],
  #auth-block input[type="password"] { width: 130px; }
}