:root {
  --bg: #0b0f1a;
  --bar: #111726;
  --bubble: #1b2236;
  --fg: #e6ebf5;
  --muted: #8a94ad;
  --accent: #5b8cff;
  --accent-2: #3a6bff;
  --on: #2ecc71;
  --warn: #f1c40f;
  --off: #6b7280;
  --border: #26304a;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  height: 100%;
  background: var(--bg);
  color: var(--fg);
  font-family: -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Noto Sans JP",
    "Segoe UI", Roboto, sans-serif;
  -webkit-font-smoothing: antialiased;
}

/* ===== 全体レイアウト: 上バー / チャット / 下ドック ===== */
.app {
  display: flex;
  flex-direction: column;
  height: 100dvh;
  max-width: 720px;
  margin: 0 auto;
}

/* ===== トップバー ===== */
.appbar {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: max(10px, env(safe-area-inset-top)) 14px 10px;
  background: var(--bar);
  border-bottom: 1px solid var(--border);
}
.appbar-id { display: flex; align-items: center; gap: 10px; min-width: 0; }
.avatar {
  width: 38px; height: 38px;
  flex: 0 0 auto;
  border-radius: 50%;
  display: grid; place-items: center;
  font-weight: 700; color: #fff;
  background: linear-gradient(180deg, var(--accent), var(--accent-2));
}
.appbar-name { display: flex; flex-direction: column; line-height: 1.2; min-width: 0; }
.appbar-name strong { font-size: 1.02rem; }

.status { font-size: 0.74rem; font-weight: 600; }
.status-off { color: var(--off); }
.status-on { color: var(--on); }
.status-warn { color: var(--warn); }

.icon-btn {
  flex: 0 0 auto;
  width: 40px; height: 40px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: var(--bubble);
  color: var(--fg);
  font-size: 1.15rem;
  cursor: pointer;
}
.icon-btn:active { transform: translateY(1px); }

/* ===== チャットルーム ===== */
.chat {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 16px 14px 8px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.chat-empty {
  margin: auto;
  max-width: 320px;
  text-align: center;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.6;
}

/* メッセージの吹き出し（アルファ＝左寄せ受信バブル） */
.msg {
  align-self: flex-start;
  max-width: 86%;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.msg .bubble {
  background: var(--bubble);
  border: 1px solid var(--border);
  border-radius: 14px 14px 14px 4px;
  padding: 10px 13px;
  font-size: 0.96rem;
  line-height: 1.55;
  word-break: break-word;
  white-space: pre-wrap;
}
.msg .meta { font-size: 0.7rem; color: var(--muted); padding-left: 6px; }
.msg.speaking .bubble { border-color: var(--accent); box-shadow: 0 0 0 2px rgba(91,140,255,0.18); }

/* ===== 下部ドック（運転操作） ===== */
.dock {
  flex: 0 0 auto;
  display: flex;
  gap: 10px;
  padding: 10px 14px calc(10px + env(safe-area-inset-bottom));
  background: var(--bar);
  border-top: 1px solid var(--border);
}
.dock-btn {
  flex: 1 1 auto;
  padding: 14px 14px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: var(--bubble);
  color: var(--fg);
  font-size: 0.98rem;
  font-weight: 700;
  cursor: pointer;
}
.dock-btn:active { transform: translateY(1px); }
.dock-btn:disabled { opacity: 0.45; cursor: not-allowed; }
#muteBtn { flex: 0 0 64px; }
.dock-btn.primary {
  background: linear-gradient(180deg, var(--accent), var(--accent-2));
  border-color: var(--accent-2);
  color: #fff;
}
.dock-btn.danger {
  background: #2a3145;
  border-color: var(--border);
  color: var(--fg);
}

/* ===== 設定オーバーレイ ===== */
.overlay {
  position: fixed;
  inset: 0;
  background: rgba(4, 7, 14, 0.6);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  z-index: 50;
}
.overlay.hidden { display: none; }
.sheet {
  width: 100%;
  max-width: 720px;
  max-height: 88dvh;
  overflow-y: auto;
  background: var(--bar);
  border: 1px solid var(--border);
  border-radius: 18px 18px 0 0;
  padding-bottom: calc(16px + env(safe-area-inset-bottom));
}
.sheet-head {
  position: sticky; top: 0;
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px;
  background: var(--bar);
  border-bottom: 1px solid var(--border);
}
.sheet-head h2 { margin: 0; font-size: 1rem; }
.sheet-body { padding: 16px; display: flex; flex-direction: column; gap: 14px; }

.field { display: flex; flex-direction: column; gap: 6px; font-size: 0.85rem; color: var(--muted); }
.field em { color: var(--fg); font-style: normal; }
input[type="url"], input[type="password"], select {
  width: 100%;
  padding: 11px 12px;
  background: var(--bubble);
  border: 1px solid var(--border);
  border-radius: 10px;
  color: var(--fg);
  font-size: 1rem;
}
input:focus, select:focus { outline: none; border-color: var(--accent); }
input[type="range"] { width: 100%; accent-color: var(--accent); }
.hint { font-size: 0.78rem; color: var(--muted); margin: -6px 0 0; }

.ios-note {
  margin: 4px 0 0;
  padding: 11px 12px;
  background: rgba(241, 196, 15, 0.08);
  border: 1px solid rgba(241, 196, 15, 0.25);
  border-radius: 10px;
  font-size: 0.8rem;
  color: #e8dca0;
  line-height: 1.5;
}

/* ===== 自分(ユーザー)の送信バブル＝右寄せ ===== */
.msg.me { align-self: flex-end; align-items: flex-end; }
.msg.me .bubble {
  background: linear-gradient(180deg, var(--accent), var(--accent-2));
  border-color: var(--accent-2);
  color: #fff;
  border-radius: 14px 14px 4px 14px;
}
.msg.me .meta { padding-left: 0; padding-right: 6px; }
.msg.me.pending .bubble { opacity: 0.6; }
.msg.me.failed .bubble {
  background: #3a2030;
  border-color: #7a3550;
  color: #f3c0cf;
}

/* ===== 返信コンポーザ（チャット入力欄） ===== */
.composer {
  flex: 0 0 auto;
  display: flex;
  gap: 8px;
  padding: 8px 14px 0;
  background: var(--bar);
}
.reply-input {
  flex: 1 1 auto;
  min-width: 0;
  padding: 12px 14px;
  background: var(--bubble);
  border: 1px solid var(--border);
  border-radius: 22px;
  color: var(--fg);
  font-size: 1rem;
}
.reply-input:focus { outline: none; border-color: var(--accent); }
.reply-input:disabled { opacity: 0.45; }
/* ===== アプリ内マイクボタン（音声入力） ===== */
.mic-btn {
  flex: 0 0 auto;
  width: 46px; height: 46px;
  border: 1px solid var(--border);
  border-radius: 50%;
  background: var(--bubble);
  color: var(--fg);
  font-size: 1.15rem;
  cursor: pointer;
}
.mic-btn:active { transform: translateY(1px); }
.mic-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  color: var(--muted);
}
/* 録音中: 赤くして点滅させる */
.mic-btn.recording {
  background: #c0392b;
  border-color: #e74c3c;
  color: #fff;
  animation: mic-pulse 1s ease-in-out infinite;
}
@keyframes mic-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(231, 76, 60, 0.55); }
  50%      { box-shadow: 0 0 0 6px rgba(231, 76, 60, 0); }
}
/* 音声認識非対応端末ではアプリ内マイクを隠す（キーボードの🎤を使う） */
.mic-btn.hidden-mic { display: none; }

.send-btn {
  flex: 0 0 auto;
  width: 46px; height: 46px;
  border: 1px solid var(--accent-2);
  border-radius: 50%;
  background: linear-gradient(180deg, var(--accent), var(--accent-2));
  color: #fff;
  font-size: 1.15rem;
  cursor: pointer;
}
.send-btn:active { transform: translateY(1px); }
.send-btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  background: var(--bubble);
  border-color: var(--border);
  color: var(--muted);
}
