/* DDD – Player & Admin */
:root {
  --bg: #0d1117;
  --fg: #e6edf3;
  --muted: #8b949e;
  --accent: #58a6ff;
  --border: #30363d;
  --font: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
}

* { box-sizing: border-box; }
body { font-family: var(--font); background: var(--bg); color: var(--fg); margin: 0; min-height: 100vh; line-height: 1.5; }
a { color: var(--accent); }
header { padding: 0.75rem 1rem; border-bottom: 1px solid var(--border); display: flex; justify-content: space-between; align-items: center; }
header h1 { margin: 0; font-size: 1.1rem; }
main { padding: 1rem; max-width: 720px; margin: 0 auto; }

.player .terminal { background: #161b22; border: 1px solid var(--border); border-radius: 6px; overflow: hidden; }
.player .scrollback { min-height: 240px; max-height: 60vh; overflow-y: auto; padding: 1rem; white-space: pre-wrap; word-break: break-word; }
.player .scrollback .in { color: var(--muted); }
.player .scrollback .out { margin-bottom: 0.75rem; }
.player .input-row { display: flex; gap: 0.5rem; padding: 0.5rem 1rem; border-top: 1px solid var(--border); }
.player .input-row input { flex: 1; background: var(--bg); border: 1px solid var(--border); color: var(--fg); padding: 0.5rem 0.75rem; font: inherit; border-radius: 4px; }
.player .input-row input:focus { outline: none; border-color: var(--accent); }
.player .input-row button { padding: 0.5rem 1rem; background: var(--accent); color: var(--bg); border: none; border-radius: 4px; cursor: pointer; font: inherit; }
.player .actions { margin-top: 1rem; }
.player .actions button { padding: 0.5rem 1rem; background: var(--border); color: var(--fg); border: none; border-radius: 4px; cursor: pointer; font: inherit; }
.player .player-picker { margin: 1rem 0; }
.player .player-picker select { padding: 0.5rem; margin-right: 0.5rem; font: inherit; background: var(--bg); color: var(--fg); border: 1px solid var(--border); border-radius: 4px; }
.player .player-picker button { padding: 0.5rem 1rem; background: var(--accent); color: var(--bg); border: none; border-radius: 4px; cursor: pointer; font: inherit; }

/* Admin */
.admin table { width: 100%; border-collapse: collapse; }
.admin th, .admin td { padding: 0.5rem; text-align: left; border-bottom: 1px solid var(--border); }
.admin form { max-width: 480px; }
.admin input[type=text], .admin input[type=email], .admin input[type=password], .admin textarea { width: 100%; padding: 0.5rem; margin-bottom: 0.5rem; font: inherit; }
.admin .msg { padding: 0.5rem; margin-bottom: 1rem; border-radius: 4px; }
.admin .msg.error { background: #3d1f1f; color: #f85149; }
.admin .msg.success { background: #1a2f1a; color: #3fb950; }
.admin label { cursor: help; }
.admin .page-hint { color: var(--muted); font-size: 0.9rem; margin-top: -0.25rem; margin-bottom: 0.5rem; }
.admin .json-format { font-size: 0.8rem; color: var(--muted); margin-top: 0.25rem; margin-bottom: 0.75rem; }
.admin .manual-table { width: 100%; border-collapse: collapse; margin: 0.5rem 0; font-size: 0.9rem; }
.admin .manual-table th, .admin .manual-table td { padding: 0.35rem 0.5rem; text-align: left; border-bottom: 1px solid var(--border); }
.admin .manual-table code { font-size: 0.85em; }
.admin .version { font-size: 0.85rem; color: var(--muted); margin: -0.25rem 0 0.75rem 0; }
