/* ============================================
   Plongée Niveau 2 - Jeux interactifs
   Design océan / abysse
   ============================================ */

:root {
  --bg-deep: #02111f;
  --bg-mid: #07304f;
  --bg-shallow: #0b6e9d;
  --bg-surface: #4cc9e0;
  --accent: #ffd166;
  --accent-warm: #ff7043;
  --accent-cool: #29e0c8;
  --text: #eaf6fb;
  --text-dim: #a9c4d4;
  --card: rgba(255, 255, 255, 0.06);
  --card-border: rgba(255, 255, 255, 0.12);
  --correct: #2dd4bf;
  --wrong: #ef476f;
  --shadow: 0 20px 60px rgba(0, 0, 0, 0.5);
  --radius: 18px;
  --radius-sm: 10px;
  --font: -apple-system, BlinkMacSystemFont, "SF Pro Display", "Segoe UI", Roboto, sans-serif;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  min-height: 100vh;
  font-family: var(--font);
  color: var(--text);
  background:
    radial-gradient(ellipse at top, var(--bg-shallow) 0%, var(--bg-mid) 35%, var(--bg-deep) 100%);
  background-attachment: fixed;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* Bulles d'ambiance */
.bubbles {
  position: fixed;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}
.bubble {
  position: absolute;
  bottom: -100px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.55), rgba(255,255,255,0.05));
  animation: rise linear infinite;
  opacity: 0.6;
}
@keyframes rise {
  0%   { transform: translateY(0) translateX(0); opacity: 0; }
  10%  { opacity: 0.7; }
  100% { transform: translateY(-110vh) translateX(40px); opacity: 0; }
}

/* Surface vague (top) */
.wave-top {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 70px;
  z-index: 1;
  pointer-events: none;
  background:
    radial-gradient(ellipse at 50% 100%, rgba(76, 201, 224, 0.35), transparent 70%);
}

main, header, footer {
  position: relative;
  z-index: 2;
}

/* ============================================
   Header global
   ============================================ */
.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 32px;
  max-width: 1300px;
  margin: 0 auto;
}
.brand {
  display: flex;
  align-items: center;
  gap: 14px;
}
.brand-text {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 700;
  letter-spacing: 0.5px;
  font-size: 18px;
  color: var(--text);
  text-decoration: none;
}
.brand-logo {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent-cool), var(--bg-surface));
  display: grid;
  place-items: center;
  font-size: 20px;
  box-shadow: 0 4px 16px rgba(41, 224, 200, 0.4);
}
.brand-vpp {
  display: inline-flex;
  align-items: center;
  background: #fff;
  padding: 5px 10px;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.18);
  text-decoration: none;
  transition: transform 0.2s, box-shadow 0.2s;
}
.brand-vpp:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(0,0,0,0.25);
}
.brand-vpp img {
  height: 24px;
  display: block;
}
.back-link {
  color: var(--text-dim);
  text-decoration: none;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  border-radius: 20px;
  background: var(--card);
  border: 1px solid var(--card-border);
  transition: 0.2s;
}
.back-link:hover {
  background: rgba(255,255,255,0.12);
  color: var(--text);
}

/* ============================================
   Portail (index.html)
   ============================================ */
.hero {
  text-align: center;
  padding: 60px 24px 30px;
  max-width: 1000px;
  margin: 0 auto;
}
.hero h1 {
  font-size: clamp(2.4rem, 6vw, 4.2rem);
  margin: 0 0 16px;
  font-weight: 800;
  background: linear-gradient(135deg, var(--bg-surface) 0%, var(--accent-cool) 50%, var(--accent) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  letter-spacing: -1px;
}
.hero p {
  font-size: 1.15rem;
  color: var(--text-dim);
  max-width: 620px;
  margin: 0 auto;
  line-height: 1.6;
}

.games-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 28px;
  max-width: 1100px;
  margin: 50px auto;
  padding: 0 24px;
}
.game-card {
  background: var(--card);
  border: 1px solid var(--card-border);
  border-radius: var(--radius);
  padding: 36px 30px;
  text-decoration: none;
  color: var(--text);
  position: relative;
  overflow: hidden;
  transition: 0.3s cubic-bezier(0.2, 0.8, 0.2, 1);
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  min-height: 320px;
}
.game-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at var(--mx, 50%) var(--my, 50%), rgba(76, 201, 224, 0.25), transparent 50%);
  opacity: 0;
  transition: opacity 0.4s;
  pointer-events: none;
}
.game-card:hover {
  transform: translateY(-8px);
  border-color: rgba(76, 201, 224, 0.5);
}
.game-card:hover::before { opacity: 1; }
.game-icon {
  font-size: 54px;
  margin-bottom: 18px;
  display: inline-block;
}
.game-card h2 {
  margin: 0 0 12px;
  font-size: 1.7rem;
  font-weight: 700;
}
.game-card p {
  color: var(--text-dim);
  line-height: 1.6;
  flex: 1;
  margin: 0;
}
.game-card .cta {
  margin-top: 24px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
  color: var(--accent-cool);
}
.game-card .tag {
  position: absolute;
  top: 18px;
  right: 18px;
  background: rgba(255, 209, 102, 0.18);
  color: var(--accent);
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.5px;
}

/* ============================================
   Jeu : structures communes
   ============================================ */
.game-wrap {
  max-width: 900px;
  margin: 20px auto 80px;
  padding: 0 20px;
}
.game-header {
  text-align: center;
  margin-bottom: 30px;
}
.game-header h1 {
  margin: 0 0 8px;
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  font-weight: 800;
}
.game-header p {
  margin: 0;
  color: var(--text-dim);
}

/* Barre de progression */
.progress-bar {
  height: 6px;
  background: rgba(255,255,255,0.08);
  border-radius: 6px;
  overflow: hidden;
  margin-bottom: 24px;
}
.progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--accent-cool), var(--bg-surface));
  width: 0%;
  transition: width 0.4s ease;
  border-radius: 6px;
}

/* Statut HUD */
.hud {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 18px;
  font-size: 14px;
  color: var(--text-dim);
}
.hud-score {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--card);
  padding: 6px 14px;
  border-radius: 20px;
  border: 1px solid var(--card-border);
}
.hud-score .val { color: var(--accent); font-weight: 700; }

/* Carte question */
.q-card {
  background: var(--card);
  border: 1px solid var(--card-border);
  border-radius: var(--radius);
  padding: 32px;
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow);
  margin-bottom: 20px;
}
.q-scene {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: 20px;
  background: rgba(76, 201, 224, 0.12);
  color: var(--bg-surface);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.5px;
  margin-bottom: 16px;
  text-transform: uppercase;
}
.q-scene.brief    { background: rgba(255,209,102,0.15); color: var(--accent); }
.q-scene.descente { background: rgba(76,201,224,0.15); color: var(--bg-surface); }
.q-scene.fond     { background: rgba(41,224,200,0.15); color: var(--accent-cool); }
.q-scene.remontee { background: rgba(255,112,67,0.18); color: var(--accent-warm); }
.q-scene.surface  { background: rgba(173,216,255,0.15); color: #ade2ff; }
.q-scene.incident { background: rgba(239,71,111,0.18); color: var(--wrong); }
.q-scene.theorie  { background: rgba(180,167,255,0.18); color: #b4a7ff; }

.q-text {
  font-size: 1.25rem;
  line-height: 1.55;
  margin: 0 0 24px;
  font-weight: 500;
}

.choices {
  display: grid;
  gap: 12px;
}
.choice {
  background: rgba(255,255,255,0.04);
  border: 1.5px solid var(--card-border);
  border-radius: var(--radius-sm);
  padding: 16px 18px;
  text-align: left;
  cursor: pointer;
  color: var(--text);
  font-size: 1rem;
  font-family: inherit;
  transition: 0.2s;
  display: flex;
  align-items: center;
  gap: 14px;
}
.choice:hover:not(:disabled) {
  background: rgba(76, 201, 224, 0.12);
  border-color: rgba(76, 201, 224, 0.5);
  transform: translateX(4px);
}
.choice .letter {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
  display: grid;
  place-items: center;
  font-weight: 700;
  font-size: 13px;
  flex-shrink: 0;
  transition: 0.2s;
}
.choice.correct {
  background: rgba(45, 212, 191, 0.18);
  border-color: var(--correct);
  color: #fff;
}
.choice.correct .letter {
  background: var(--correct);
  color: #002;
}
.choice.wrong {
  background: rgba(239, 71, 111, 0.15);
  border-color: var(--wrong);
}
.choice.wrong .letter {
  background: var(--wrong);
  color: #fff;
}
.choice:disabled { cursor: default; }

/* Explication */
.explain {
  margin-top: 18px;
  padding: 16px 18px;
  background: rgba(255, 209, 102, 0.08);
  border-left: 3px solid var(--accent);
  border-radius: 8px;
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--text-dim);
  display: none;
}
.explain.show { display: block; animation: fadeIn 0.4s ease; }
.explain strong { color: var(--accent); }

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Bouton */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  border-radius: 999px;
  border: none;
  background: linear-gradient(135deg, var(--accent-cool), var(--bg-surface));
  color: #001525;
  font-weight: 700;
  font-size: 1rem;
  cursor: pointer;
  font-family: inherit;
  transition: 0.2s;
  box-shadow: 0 8px 24px rgba(41, 224, 200, 0.3);
}
.btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(41, 224, 200, 0.4);
}
.btn.ghost {
  background: transparent;
  border: 1.5px solid var(--card-border);
  color: var(--text);
  box-shadow: none;
}
.btn.ghost:hover {
  background: var(--card);
  border-color: var(--bg-surface);
}

.actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 20px;
  gap: 12px;
  flex-wrap: wrap;
}

/* ============================================
   Jeu Cavalaire : carte site
   ============================================ */
.site-visual {
  height: 240px;
  border-radius: 14px;
  margin-bottom: 24px;
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, #0b6e9d 0%, #02111f 100%);
  display: grid;
  place-items: center;
}
.site-visual svg {
  width: 100%;
  height: 100%;
}
.site-visual img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.site-meta {
  position: absolute;
  bottom: 12px;
  left: 12px;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.site-meta span {
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(8px);
  padding: 4px 10px;
  border-radius: 12px;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.4px;
}
.site-meta .lvl { background: rgba(255, 209, 102, 0.85); color: #002; }
.site-meta .depth { background: rgba(76, 201, 224, 0.85); color: #002; }
.site-meta .type-tag { background: rgba(41, 224, 200, 0.85); color: #002; }

.facts {
  list-style: none;
  padding: 0;
  margin: 0 0 8px;
}
.facts li {
  position: relative;
  padding: 8px 0 8px 28px;
  font-size: 0.95rem;
  line-height: 1.5;
  color: var(--text-dim);
  opacity: 0;
  animation: factIn 0.4s ease forwards;
}
.facts li::before {
  content: "🐠";
  position: absolute;
  left: 0;
  font-size: 1.1rem;
}
.facts li:nth-child(1)::before { content: "📍"; }
.facts li:nth-child(2)::before { content: "🌊"; }
.facts li:nth-child(3)::before { content: "🐙"; }
.facts li:nth-child(4)::before { content: "⚓"; }
.facts li:nth-child(5)::before { content: "✨"; }

@keyframes factIn {
  to { opacity: 1; }
}

.hint-btn {
  background: transparent;
  border: 1px dashed var(--card-border);
  color: var(--text-dim);
  padding: 8px 14px;
  border-radius: 999px;
  cursor: pointer;
  font-size: 13px;
  font-family: inherit;
  margin-top: 8px;
}
.hint-btn:hover {
  border-color: var(--bg-surface);
  color: var(--text);
}
.hint-btn:disabled { opacity: 0.4; cursor: default; }

/* Écran final */
.result-card {
  text-align: center;
  background: var(--card);
  border: 1px solid var(--card-border);
  border-radius: var(--radius);
  padding: 50px 30px;
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow);
}
.result-emoji {
  font-size: 80px;
  margin-bottom: 16px;
  display: block;
}
.result-card h2 {
  margin: 0 0 12px;
  font-size: 2rem;
}
.result-score {
  font-size: 3.5rem;
  font-weight: 800;
  background: linear-gradient(135deg, var(--accent-cool), var(--accent));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  margin: 16px 0;
}
.result-msg {
  color: var(--text-dim);
  font-size: 1.05rem;
  margin: 0 0 30px;
  line-height: 1.6;
}
.result-card .actions {
  justify-content: center;
}

/* Filtres catégorie pour N2 */
.filters {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 24px;
}
.filter-chip {
  background: var(--card);
  border: 1px solid var(--card-border);
  color: var(--text-dim);
  padding: 7px 14px;
  border-radius: 999px;
  font-size: 13px;
  font-family: inherit;
  cursor: pointer;
  transition: 0.2s;
}
.filter-chip.active {
  background: var(--bg-surface);
  color: #002;
  border-color: var(--bg-surface);
  font-weight: 600;
}
.filter-chip:hover:not(.active) {
  border-color: var(--bg-surface);
  color: var(--text);
}

/* Loading state */
.loading {
  text-align: center;
  color: var(--text-dim);
  padding: 40px;
}

/* Responsif */
@media (max-width: 600px) {
  .q-card { padding: 22px 18px; }
  .topbar { padding: 14px 18px; }
  .hero { padding: 30px 18px; }
  .actions { flex-direction: column-reverse; }
  .actions .btn { width: 100%; justify-content: center; }
}

/* ============================================
   Binôme à 35 m (binome.html)
   ============================================ */
.binome-setup {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  max-width: 480px;
  margin: 22px auto 8px;
  text-align: left;
}
.binome-setup label {
  display: block;
  font-size: 0.85rem;
  color: var(--text-dim);
  margin-bottom: 4px;
}
.binome-rules {
  margin: 20px auto;
  max-width: 520px;
  text-align: left;
  color: var(--text-dim);
  font-size: 0.92rem;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--card-border);
  border-radius: 12px;
  padding: 14px 18px;
}
.binome-rules p { margin: 4px 0; }
.binome-rules strong { color: var(--text); }

.binome-event {
  background: linear-gradient(135deg, rgba(41, 224, 200, 0.12), rgba(80, 140, 220, 0.10));
  border: 1px solid rgba(41, 224, 200, 0.35);
  border-radius: 18px;
  padding: 20px 22px;
  margin-bottom: 18px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.18);
}
.binome-event-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 6px;
}
.binome-victim {
  font-size: 0.85rem;
  color: var(--accent);
  font-weight: 600;
  background: rgba(41, 224, 200, 0.12);
  padding: 4px 10px;
  border-radius: 12px;
}
.binome-event h2 { margin: 6px 0 8px; font-size: 1.4rem; }
.binome-event-text { margin: 0; color: var(--text); font-size: 1.02rem; line-height: 1.5; }

.binome-board {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 16px;
}
.binome-player {
  background: var(--card);
  border: 1px solid var(--card-border);
  border-radius: 16px;
  padding: 16px;
  transition: border-color 0.25s, box-shadow 0.25s;
}
.binome-player.is-victim {
  border-color: rgba(255, 170, 80, 0.55);
  box-shadow: 0 0 0 1px rgba(255, 170, 80, 0.3), 0 10px 24px rgba(0,0,0,0.18);
}
.binome-player.is-ready {
  opacity: 0.78;
}
.binome-player-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 8px;
}
.binome-player-head h3 { margin: 0; font-size: 1.05rem; }
.binome-air {
  font-family: 'Courier New', monospace;
  font-weight: 700;
  font-size: 1rem;
  color: var(--accent);
}
.binome-air.low { color: #ffcc66; }
.binome-air.crit { color: #ff7777; }

.binome-gauge {
  position: relative;
  height: 10px;
  background: rgba(255,255,255,0.07);
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 12px;
}
.binome-gauge-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--accent-cool), var(--accent));
  transition: width 0.4s;
}
.binome-gauge.low .binome-gauge-fill { background: linear-gradient(90deg, #ffaa55, #ffcc66); }
.binome-gauge.crit .binome-gauge-fill { background: linear-gradient(90deg, #ff5555, #ff7777); }
.binome-gauge-mark {
  position: absolute;
  top: -2px;
  bottom: -2px;
  width: 2px;
  background: rgba(255,255,255,0.5);
  pointer-events: none;
}
.binome-hint {
  font-size: 0.82rem;
  color: var(--text-dim);
  margin: 0 0 10px;
  text-align: center;
}
.binome-hand {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px;
  max-height: 360px;
  overflow-y: auto;
  padding-right: 4px;
}
.binome-card {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--card-border);
  border-radius: 10px;
  padding: 8px 10px;
  color: var(--text);
  font-size: 0.82rem;
  font-weight: 500;
  text-align: left;
  cursor: pointer;
  transition: all 0.15s;
}
.binome-card:hover {
  background: rgba(255,255,255,0.09);
  border-color: var(--accent-cool);
}
.binome-card.selected {
  background: rgba(41, 224, 200, 0.18);
  border-color: var(--accent);
  color: var(--text);
}
.bc-emoji { font-size: 1.15rem; flex-shrink: 0; }
.bc-label { line-height: 1.15; }
.binome-pickedmsg {
  margin-top: 10px;
  text-align: center;
  color: var(--accent);
  font-size: 0.88rem;
  font-weight: 600;
}

.binome-resolve { justify-content: center; }

.binome-outcome {
  background: var(--card);
  border: 1px solid var(--card-border);
  border-radius: 18px;
  padding: 24px 22px;
}
.binome-outcome h2 { margin: 0 0 6px; }
.binome-out-explain {
  background: rgba(41, 224, 200, 0.10);
  border-left: 3px solid var(--accent);
  padding: 10px 14px;
  border-radius: 6px;
  margin: 12px 0 18px;
  font-size: 0.95rem;
  line-height: 1.5;
}
.binome-outcome-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 16px;
}
.binome-outcome-side {
  border: 1px solid var(--card-border);
  border-radius: 14px;
  padding: 14px;
  background: rgba(255,255,255,0.03);
}
.binome-outcome-side.good { border-color: rgba(80, 220, 140, 0.45); background: rgba(80, 220, 140, 0.07); }
.binome-outcome-side.bad  { border-color: rgba(255, 100, 100, 0.45); background: rgba(255, 100, 100, 0.06); }
.binome-outcome-side h4 { margin: 0 0 10px; font-size: 1rem; }
.binome-out-card {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,0.07);
  padding: 8px 12px;
  border-radius: 10px;
  margin-bottom: 10px;
  font-size: 0.9rem;
}
.binome-out-verdict {
  font-weight: 600;
  font-size: 0.9rem;
  margin-bottom: 10px;
}
.binome-out-detail {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 0.82rem;
}
.binome-out-detail li {
  display: flex;
  justify-content: space-between;
  padding: 3px 0;
  color: var(--text-dim);
}
.binome-out-detail li.total {
  border-top: 1px dashed var(--card-border);
  margin-top: 4px;
  padding-top: 5px;
  color: var(--text);
  font-weight: 600;
}
.binome-out-detail .pos { color: #6fdfb0; }
.binome-out-detail .neg { color: #ff9999; }

.binome-final {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin: 18px 0 8px;
}
.binome-final > div {
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--card-border);
  border-radius: 12px;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.binome-final-air {
  font-family: 'Courier New', monospace;
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--accent);
}
.binome-final-air.low { color: #ff9999; }

.q-scene.descente { background: rgba(80, 140, 220, 0.16); color: #9fc4ff; }
.q-scene.fond     { background: rgba(41, 224, 200, 0.16); color: var(--accent); }
.q-scene.remontee { background: rgba(255, 170, 80, 0.16); color: #ffcc88; }
.q-scene.bateau   { background: rgba(220, 220, 220, 0.12); color: #e0e0e0; }

@media (max-width: 720px) {
  .binome-board { grid-template-columns: 1fr; }
  .binome-outcome-grid { grid-template-columns: 1fr; }
  .binome-final { grid-template-columns: 1fr; }
  .binome-hand { grid-template-columns: 1fr 1fr; max-height: none; }
}

/* Effets durables sur le panneau joueur */
.binome-effects {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 10px;
}
.binome-effect-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(255, 100, 100, 0.12);
  border: 1px solid rgba(255, 100, 100, 0.35);
  color: #ff9999;
  font-size: 0.78rem;
  padding: 3px 9px;
  border-radius: 12px;
  font-weight: 500;
}
.binome-effect-chip .drain {
  background: rgba(0,0,0,0.25);
  color: #ffcccc;
  padding: 1px 6px;
  border-radius: 8px;
  font-size: 0.7rem;
}

/* Liste d'événements dans l'outcome */
.binome-out-events {
  list-style: none;
  margin: 0 0 10px;
  padding: 8px 12px;
  background: rgba(255,255,255,0.04);
  border-left: 2px solid var(--accent-cool);
  border-radius: 6px;
  font-size: 0.82rem;
  color: var(--text-dim);
}
.binome-out-events li { padding: 2px 0; }

/* Bloc critique : accident */
.binome-critical {
  margin: 16px 0;
  padding: 18px 20px;
  background: linear-gradient(135deg, rgba(255,80,80,0.18), rgba(255,40,40,0.10));
  border: 1px solid rgba(255, 100, 100, 0.55);
  border-radius: 14px;
  box-shadow: 0 0 0 1px rgba(255,80,80,0.25), 0 10px 28px rgba(255,40,40,0.18);
  animation: criticalPulse 1.2s ease-out;
}
.binome-critical h3 {
  margin: 0 0 6px;
  color: #ffb3b3;
  font-size: 1.15rem;
}
.binome-critical p {
  margin: 0;
  color: var(--text);
  line-height: 1.5;
  font-size: 0.95rem;
}
@keyframes criticalPulse {
  0%   { transform: scale(0.97); opacity: 0; }
  60%  { transform: scale(1.02); }
  100% { transform: scale(1); opacity: 1; }
}

.binome-final-sub {
  margin-top: -6px;
  font-size: 0.9rem;
  color: var(--text-dim);
}

/* Événement positif (moment plaisir) */
.binome-event.is-positive {
  background: linear-gradient(135deg, rgba(120, 200, 255, 0.16), rgba(180, 140, 255, 0.12));
  border-color: rgba(150, 200, 255, 0.45);
}
.binome-event.is-positive .binome-victim {
  background: rgba(120, 200, 255, 0.18);
  color: #b8defc;
}
