:root {
  --bg: #0a0d0a;
  --panel: #0f130f;
  --ink: #39ff14;
  --ink-dim: #4a8a2a;
  --muted: #5a6a4a;
  --accent: #C76F4B;
  --danger: #ff3b3b;
  --gold: #d4a017;
  --border: #1a2210;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  background: var(--bg);
  color: var(--ink);
  font-family: 'SF Mono', 'JetBrains Mono', 'Menlo', monospace;
  min-height: 100vh;
  padding: 1.5rem;
  -webkit-font-smoothing: antialiased;
}

h1 { font-size: 1.4rem; letter-spacing: 0.12em; margin-bottom: 0.25rem; }
.subtitle { color: var(--muted); font-size: 0.78rem; margin-bottom: 1.5rem; }

.layout { max-width: 920px; margin: 0 auto; display: grid; gap: 1rem; }

/* Barre du joueur */
.roster {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 0.5rem;
}
.combatant {
  background: var(--panel);
  border: 1px solid var(--border);
  padding: 0.9rem;
  border-radius: 4px;
}
.combatant .name { font-size: 0.95rem; margin-bottom: 0.4rem; }
.combatant .stat { display: flex; justify-content: space-between; font-size: 0.78rem; color: var(--ink-dim); margin: 0.15rem 0; }
.combatant .stat .v { color: var(--ink); }
.combatant.me { border-left: 2px solid var(--accent); }
.combatant.foe { border-left: 2px solid var(--danger); }
.record { margin-top: 0.6rem; font-size: 0.72rem; color: var(--muted); }
.record .wins { color: var(--gold); }
.record .losses { color: var(--danger); }

/* Stances */
.stance-pick {
  background: var(--panel);
  border: 1px solid var(--border);
  padding: 0.9rem;
  border-radius: 4px;
}
.stance-pick .lbl { color: var(--muted); font-size: 0.72rem; letter-spacing: 0.1em; margin-bottom: 0.6rem; }
.stances { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.5rem; }
.stance-btn {
  background: #0c0f0c;
  color: var(--ink-dim);
  border: 1px solid var(--border);
  padding: 0.7rem 0.4rem;
  font-family: inherit;
  font-size: 0.78rem;
  cursor: pointer;
  border-radius: 3px;
  transition: all 0.12s;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.stance-btn:hover { border-color: var(--ink-dim); color: var(--ink); }
.stance-btn.picked { border-color: var(--accent); color: var(--accent); background: #1a0f0a; }
.stance-btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* Log */
.log {
  background: var(--panel);
  border: 1px solid var(--border);
  padding: 0.9rem;
  border-radius: 4px;
  min-height: 120px;
  font-size: 0.75rem;
  line-height: 1.6;
}
.log .ev { margin: 0.2rem 0; }
.log .ev .tag { color: var(--muted); margin-right: 0.4rem; }
.log .ev.win .tag { color: var(--gold); }
.log .ev.loss .tag { color: var(--danger); }
.log .ev.commit .tag { color: var(--ink-dim); }
.log .ev.block .tag { color: #5a8aa0; }
.log .ev.reveal .tag { color: var(--accent); }

/* Boutons d'action */
.actions { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.act {
  background: #0c0f0c;
  color: var(--ink);
  border: 1px solid var(--ink-dim);
  padding: 0.55rem 0.9rem;
  font-family: inherit;
  font-size: 0.78rem;
  cursor: pointer;
  border-radius: 3px;
  letter-spacing: 0.05em;
}
.act:hover { background: var(--ink-dim); color: var(--bg); }
.act.primary { background: var(--accent); color: #1a0a04; border-color: var(--accent); }
.act.primary:hover { background: #e08a5e; }
.act:disabled { opacity: 0.4; cursor: not-allowed; }

/* Sélecteur de mode */
.controls {
  display: flex; gap: 0.5rem; align-items: center; flex-wrap: wrap;
  font-size: 0.72rem; color: var(--muted);
}
.controls select {
  background: #0c0f0c; color: var(--ink); border: 1px solid var(--border);
  padding: 0.3rem 0.5rem; font-family: inherit; font-size: 0.72rem; border-radius: 3px;
}

/* Banner état */
.banner {
  padding: 0.5rem 0.8rem; font-size: 0.78rem; border-radius: 3px;
  background: #0c0f0c; border: 1px solid var(--border); color: var(--muted);
}
.banner.live { color: var(--gold); border-color: var(--gold); }
.banner.wait { color: var(--accent); }

/* Détails técnicos (commit, block hash, r) */
.tech {
  font-size: 0.68rem; color: var(--muted); line-height: 1.5; word-break: break-all;
  background: #0c0f0c; border: 1px solid var(--border); padding: 0.6rem; border-radius: 3px;
}
.tech .k { color: var(--ink-dim); }

a { color: var(--ink-dim); }
.foot { color: var(--muted); font-size: 0.68rem; text-align: center; margin-top: 1rem; }

/* Lang toggle */
.top-bar { display: flex; justify-content: space-between; align-items: center; }
.lang-toggle { display: flex; align-items: center; gap: 0.2rem; }
.lang-btn {
  background: none; border: none; color: var(--muted); cursor: pointer;
  font-family: inherit; font-size: 0.75rem; padding: 0.2rem 0.4rem; border-radius: 3px;
}
.lang-btn:hover { color: var(--ink-dim); }
.lang-btn.active { color: var(--accent); }
.lang-sep { color: var(--border); font-size: 0.75rem; }
.stance-hint { font-size: 0.68rem; color: var(--muted); margin-top: 0.5rem; }

/* ─── Animations ─── */

/* Stance buttons idle glow */
@keyframes idle-glow {
  0%, 100% { box-shadow: 0 0 0 rgba(57,255,20,0); }
  50% { box-shadow: 0 0 8px rgba(57,255,20,0.15); }
}
.stance-btn:not(:disabled):not(.picked) {
  animation: idle-glow 2.5s ease-in-out infinite;
}
.stance-btn:nth-child(2):not(:disabled):not(.picked) { animation-delay: 0.4s; }
.stance-btn:nth-child(3):not(:disabled):not(.picked) { animation-delay: 0.8s; }

/* Picked stance lock */
@keyframes stance-lock {
  0% { transform: scale(1); }
  50% { transform: scale(1.08); box-shadow: 0 0 16px rgba(199,111,75,0.5); }
  100% { transform: scale(1); }
}
.stance-btn.picked { animation: stance-lock 0.3s ease-out; }

/* Commit flash */
@keyframes commit-flash {
  0% { background: var(--panel); }
  30% { background: #14201a; }
  100% { background: var(--panel); }
}
.combatant.commit-flash { animation: commit-flash 0.5s ease-out; }

/* Mining spinner */
.mining-overlay {
  position: fixed; inset: 0; background: rgba(10,13,10,0.85);
  display: flex; align-items: center; justify-content: center; z-index: 100;
  opacity: 0; pointer-events: none; transition: opacity 0.2s;
}
.mining-overlay.active { opacity: 1; pointer-events: auto; }
.mining-box { text-align: center; }
.mining-spinner {
  width: 48px; height: 48px; border: 2px solid var(--border);
  border-top-color: var(--ink); border-radius: 50%; margin: 0 auto 1rem;
  animation: spin 0.8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
.mining-text { color: var(--ink-dim); font-size: 0.78rem; letter-spacing: 0.1em; }
.mining-dots::after { content: '...'; animation: dots 1.2s steps(4) infinite; }
@keyframes dots { 0% { content: ''; } 25% { content: '.'; } 50% { content: '..'; } 75% { content: '...'; } }

/* Reveal flip */
@keyframes stance-reveal {
  0% { transform: rotateY(90deg); opacity: 0; }
  100% { transform: rotateY(0); opacity: 1; }
}
.reveal-stance { animation: stance-reveal 0.4s ease-out; display: inline-block; }

/* Result flash */
@keyframes win-flash {
  0% { box-shadow: inset 0 0 0 rgba(212,160,23,0); }
  30% { box-shadow: inset 0 0 40px rgba(212,160,23,0.25); }
  100% { box-shadow: inset 0 0 0 rgba(212,160,23,0); }
}
@keyframes loss-flash {
  0% { box-shadow: inset 0 0 0 rgba(255,59,59,0); }
  30% { box-shadow: inset 0 0 40px rgba(255,59,59,0.25); }
  100% { box-shadow: inset 0 0 0 rgba(255,59,59,0); }
}
.layout.win-flash { animation: win-flash 0.8s ease-out; }
.layout.loss-flash { animation: loss-flash 0.8s ease-out; }

/* Force counter pop */
@keyframes force-pop {
  0% { transform: scale(1); }
  40% { transform: scale(1.4); }
  100% { transform: scale(1); }
}
.stat .v.force-changed { animation: force-pop 0.4s ease-out; }

/* Log entry slide-in */
@keyframes log-slide {
  0% { transform: translateX(-8px); opacity: 0; }
  100% { transform: translateX(0); opacity: 1; }
}
.log .ev { animation: log-slide 0.2s ease-out; }
