:root {
  --bg: #0a0a0d;
  --panel: #13131a;
  --panel-2: #1a1a22;
  --line: #2a2a36;
  --ink: #e8e8ee;
  --dim: #8a8a99;
  --destroyer: #e64545;
  --guardian: #4ab2ff;
  --humanity: #e9c46a;
  --accent: #d4af37;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: 'Noto Serif JP', 'Noto Serif SC', serif;
  -webkit-font-smoothing: antialiased;
}
header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 24px; border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, #14141c 0%, #0a0a0d 100%);
}
.brand .title { font-size: 22px; font-weight: 700; letter-spacing: 0.3em; color: var(--accent); }
.brand .sub   { font-size: 12px; color: var(--dim); margin-top: 2px; letter-spacing: 0.1em; }
.controls { display: flex; align-items: center; gap: 12px; }
.controls select {
  background: var(--panel-2); color: var(--ink); border: 1px solid var(--line);
  padding: 6px 10px; border-radius: 4px; font-family: inherit;
}
.controls .status {
  font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--dim);
}
.controls .status.live::before { content: '● '; color: #44dd66; }

main {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 0;
  height: calc(100vh - 64px);
}
.recent { padding: 20px 24px; overflow-y: auto; }
.history { border-left: 1px solid var(--line); background: var(--panel); padding: 16px 18px; overflow-y: auto; }

.phase-banner {
  font-family: 'JetBrains Mono', monospace; font-size: 12px;
  color: var(--accent); letter-spacing: 0.15em; margin-bottom: 16px;
}
.phase-banner .sep { color: var(--dim); margin: 0 8px; }

.latest-turn {
  background: var(--panel); border: 1px solid var(--line); border-radius: 8px;
  padding: 22px 26px; margin-bottom: 18px;
  position: relative; overflow: hidden;
}
.latest-turn::before {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 4px;
  background: var(--dim);
}
.latest-turn.destroyer::before { background: var(--destroyer); }
.latest-turn.guardian::before  { background: var(--guardian); }
.latest-turn.humanity::before  { background: var(--humanity); }
.latest-turn .meta-row {
  display: flex; gap: 8px; flex-wrap: wrap; margin-top: 14px;
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
}
.latest-turn .badge {
  padding: 3px 8px; border-radius: 3px; background: var(--panel-2);
  border: 1px solid var(--line); color: var(--dim); letter-spacing: 0.1em;
}
.badge.stealth { color: var(--destroyer); border-color: var(--destroyer); }
.badge.noticed-yes { color: var(--humanity); border-color: var(--humanity); }
.badge.noticed-no  { color: var(--dim); }
.badge.requested   { color: var(--guardian); border-color: var(--guardian); }

.speaker-tag {
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 0.2em; color: var(--dim); margin-bottom: 8px; text-transform: uppercase;
}
.latest-turn.destroyer .speaker-tag { color: var(--destroyer); }
.latest-turn.guardian  .speaker-tag { color: var(--guardian); }
.latest-turn.humanity  .speaker-tag { color: var(--humanity); }

.headline {
  font-size: 20px; font-weight: 700; margin-bottom: 14px; line-height: 1.5;
}
.speech {
  font-size: 17px; line-height: 1.8; margin-bottom: 12px;
  border-left: 2px solid var(--line); padding-left: 14px;
  white-space: pre-wrap;
}
.narration {
  font-size: 14px; line-height: 1.7; color: var(--dim);
  white-space: pre-wrap;
}

.dashboard {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 10px;
  margin-bottom: 18px;
}
.metric {
  background: var(--panel-2); border: 1px solid var(--line); border-radius: 6px;
  padding: 10px 12px;
}
.metric label { display: block; font-size: 11px; color: var(--dim); letter-spacing: 0.1em; }
.metric span { font-size: 22px; font-weight: 700; font-family: 'JetBrains Mono', monospace; }
.metric small { font-size: 11px; color: var(--dim); margin-left: 4px; }

#map { height: 360px; border-radius: 8px; border: 1px solid var(--line); background: #050508; }
.leaflet-container { background: #050508; }

.history h2 { font-size: 14px; letter-spacing: 0.2em; color: var(--accent); margin: 0 0 14px; }
#history-list .item {
  padding: 10px 8px; border-bottom: 1px solid var(--line); cursor: pointer;
  transition: background 0.15s;
}
#history-list .item:hover { background: var(--panel-2); }
#history-list .item .meta {
  font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--dim);
  letter-spacing: 0.1em; margin-bottom: 4px;
}
#history-list .item.destroyer .meta { color: var(--destroyer); }
#history-list .item.guardian  .meta { color: var(--guardian); }
#history-list .item.humanity  .meta { color: var(--humanity); }
#history-list .item .hl { font-size: 13px; line-height: 1.5; }

#load-more {
  width: 100%; margin-top: 10px; padding: 10px;
  background: var(--panel-2); color: var(--ink); border: 1px solid var(--line);
  border-radius: 4px; cursor: pointer; font-family: inherit;
}
#load-more:hover { background: var(--line); }

.modal { position: fixed; inset: 0; background: rgba(0,0,0,0.75); display: flex; align-items: center; justify-content: center; z-index: 1000; }
.modal.hidden { display: none; }
.modal-inner { background: var(--panel); border: 1px solid var(--line); border-radius: 8px; max-width: 720px; width: 90%; max-height: 85vh; overflow-y: auto; padding: 24px; position: relative; }
.modal-inner .close { position: absolute; top: 8px; right: 12px; background: none; border: none; color: var(--ink); font-size: 28px; cursor: pointer; }
.modal-body .reasoning {
  margin-top: 16px; padding: 12px; background: var(--panel-2); border-radius: 4px;
  font-size: 12px; line-height: 1.6; color: var(--dim); white-space: pre-wrap;
  font-family: 'Noto Serif SC', serif;
  max-height: 300px; overflow-y: auto;
}

@media (max-width: 1200px) {
  .dashboard { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 900px) {
  main { grid-template-columns: 1fr; height: auto; }
  .history { border-left: none; border-top: 1px solid var(--line); }
  .dashboard { grid-template-columns: repeat(2, 1fr); }
}
