﻿/* Dominatus — Guide & suivi. Langage visuel "cogitator" (sombre, accents or),
   aligné sur le Rules Explorer. Variables locales avec repli sur base.css. */

/* Tokens utilisés par l'admin (formulaires + modale) mais absents de base.css
   (ils ne vivent que dans rules-explorer.css, non chargé ici). On les fournit pour
   que admin-dominatus.html soit complet. Pas de conflit : aucune page ne charge
   à la fois dominatus.css et rules-explorer.css. */
:root {
  --u: 1rem;
  --bg2: var(--bg-2);
  --line2: var(--line-2);
  --gold-bright: var(--accent-b);
  --red: var(--accent);
  --red-bright: var(--accent-b);
  --shadow-lg: var(--shadow, 0 24px 70px rgba(0, 0, 0, 0.6));
}

.dom {
  --dom-gold: var(--accent);
  --dom-red: var(--accent);
  --dom-panel: var(--panel);
  --dom-line: var(--line-2);
  --dom-muted: var(--txt-2);
}

/* ── Layout ───────────────────────────────────────────────── */
/* Marges latérales : .page inset le header + le contenu + le footer (les pages
   Dominatus ne chargent pas index.css). Le contenu est centré et borné en largeur. */
.page { padding-inline: clamp(1rem, 4vw, 2.5rem); }
.dom-wrap { max-width: 1100px; margin-inline: auto; padding-block: 1.25rem 3rem; }

.dom-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; flex-wrap: wrap; margin-bottom: 1.25rem;
}
.dom-toolbar .dom-kicker {
  font: 500 0.72rem/1.4 'IBM Plex Mono', ui-monospace, monospace;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--dom-muted);
}

.dom-layout {
  display: grid; grid-template-columns: minmax(180px, 240px) 1fr;
  gap: 1.5rem; align-items: start;
}
@media (max-width: 760px) { .dom-layout { grid-template-columns: 1fr; } }

/* ── Sidebar : sections ───────────────────────────────────── */
.dom-sidebar { position: sticky; top: 1rem; }
.dom-sec-kicker {
  font: 500 0.7rem/1.4 'IBM Plex Mono', ui-monospace, monospace;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--dom-muted);
  margin-bottom: 0.5rem;
}
.dom-sections { display: flex; flex-direction: column; gap: 2px; }
@media (max-width: 760px) {
  .dom-sections { flex-direction: row; flex-wrap: wrap; }
}
.dom-sec {
  display: flex; align-items: center; gap: 0.6rem; width: 100%;
  padding: 0.55rem 0.7rem; border: 1px solid transparent; border-radius: 8px;
  background: none; color: inherit; cursor: pointer; text-align: left;
  font: inherit; transition: background 0.12s, border-color 0.12s;
}
.dom-sec:hover { background: color-mix(in srgb, var(--dom-gold) 10%, transparent); }
.dom-sec.is-active {
  background: color-mix(in srgb, var(--dom-gold) 16%, transparent);
  border-color: var(--dom-line);
}
.dom-sec-idx {
  font: 600 0.72rem/1 'IBM Plex Mono', monospace; color: var(--dom-gold);
  min-width: 1.4em; text-align: center;
}
.dom-sec-name { font-weight: 500; }

/* ── Main : contenu d'une section ─────────────────────────── */
.dom-main { min-width: 0; }
.dom-sec-hd { margin-bottom: 1rem; }
.dom-sec-hd h2 {
  margin: 0.15rem 0 0; font-family: 'Space Grotesk', system-ui, sans-serif;
  font-size: 1.6rem;
}
.dom-sec-intro { color: var(--dom-muted); margin: 0.6rem 0 0; max-width: 65ch; }

.dom-entries { display: flex; flex-direction: column; gap: 0.9rem; margin-top: 1.25rem; }

.dom-entry {
  border: 1px solid var(--dom-line); border-radius: 12px;
  background: var(--dom-panel); padding: 1rem 1.1rem;
}
.dom-entry-hd { display: flex; align-items: baseline; gap: 0.7rem; }
.dom-entry-num {
  flex: none; display: inline-grid; place-items: center;
  min-width: 1.9rem; height: 1.9rem; padding: 0 0.35rem; border-radius: 8px;
  background: color-mix(in srgb, var(--dom-red) 22%, transparent);
  border: 1px solid color-mix(in srgb, var(--dom-red) 45%, transparent);
  font: 700 0.9rem/1 'IBM Plex Mono', monospace; color: var(--text);
}
.dom-entry-label {
  font: 500 0.68rem/1.4 'IBM Plex Mono', monospace; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--dom-muted);
}
.dom-entry-title {
  margin: 0; font-family: 'Space Grotesk', system-ui, sans-serif;
  font-size: 1.08rem; font-weight: 600;
}
.dom-entry-body { margin-top: 0.6rem; line-height: 1.6; }
.dom-entry-body p { margin: 0 0 0.6rem; }
.dom-entry-body p:last-child { margin-bottom: 0; }
.dom-entry-body .dom-li {
  display: flex; gap: 0.5rem; margin: 0.18rem 0; padding-left: 0.2rem;
}
.dom-entry-body .dom-li::before { content: '▪'; color: var(--dom-gold); }
.dom-entry-body .dom-note {
  display: block; margin: 0.5rem 0; padding: 0.5rem 0.75rem;
  border-left: 2px solid var(--dom-gold);
  background: color-mix(in srgb, var(--dom-gold) 8%, transparent);
  color: var(--dom-muted); font-style: italic;
}

/* Renvoi de règle cliquable (XX.XX) — réutilise la convention du Rules Explorer. */
.dom-ref {
  color: var(--dom-gold); border-bottom: 1px dotted var(--dom-gold);
  cursor: pointer; font-variant-numeric: tabular-nums;
}
.dom-ref:hover { background: color-mix(in srgb, var(--dom-gold) 14%, transparent); }

/* ── Switch de langue (repris du Rules Explorer) ──────────── */
.lang-switch { display: inline-flex; border: 1px solid var(--dom-line); border-radius: 8px; overflow: hidden; }
.lang-switch button {
  border: 0; background: none; color: var(--dom-muted); cursor: pointer;
  padding: 0.35rem 0.7rem; font: 600 0.78rem/1 'IBM Plex Mono', monospace;
}
.lang-switch button.is-active { background: var(--dom-gold); color: var(--on-accent); }

.dom-loading, .dom-empty { color: var(--dom-muted); padding: 1.5rem 0; }

/* ── Modale (popup overlay) — repris du Rules Explorer ──────── */
.modal { position: fixed; inset: 0; z-index: 1000; display: grid; place-items: center; padding: 20px; }
.modal[hidden] { display: none; }
.modal-backdrop { position: absolute; inset: 0; background: rgba(8, 6, 4, 0.72); backdrop-filter: blur(3px); }
.modal-card {
  position: relative; z-index: 1; width: min(680px, 94vw); max-height: 88vh; overflow-y: auto;
  background: var(--panel); border: 1px solid var(--gold-dim); border-radius: var(--radius);
  padding: calc(var(--u) * 1.6) calc(var(--u) * 1.7) calc(var(--u) * 1.7);
  box-shadow: var(--shadow-lg); animation: domModalIn 0.2s ease;
}
@keyframes domModalIn { from { opacity: 0; transform: translateY(10px) scale(0.985); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .modal-card { animation: none; } }
body.ornaments .modal-card::before, body.ornaments .modal-card::after { content: ''; position: absolute; width: 18px; height: 18px; pointer-events: none; }
body.ornaments .modal-card::before { top: 7px; left: 7px; border-top: 2px solid var(--gold); border-left: 2px solid var(--gold); }
body.ornaments .modal-card::after { bottom: 7px; right: 7px; border-bottom: 2px solid var(--gold); border-right: 2px solid var(--gold); }
.modal-close { position: absolute; top: 12px; right: 14px; z-index: 2; background: none; border: none; color: var(--muted); font-size: 1.6rem; line-height: 1; cursor: pointer; transition: color 0.15s; }
.modal-close:hover { color: var(--gold-bright); }

/* ── Tracker (suivi des événements) ────────────────────────── */
.dom-status { font: 500 0.82rem/1.4 'IBM Plex Mono', monospace; color: var(--dom-muted); min-height: 1.2em; margin-bottom: 0.6rem; }
.dom-status.is-error { color: var(--red-bright); }
.dom-status.is-ok { color: var(--gold-bright); }

.dom-btn { background: transparent; color: var(--text); cursor: pointer; border: 1px solid var(--line2); border-radius: 8px; font: 600 0.86rem/1 var(--font); padding: 9px 14px; transition: border-color 0.15s, background 0.15s, filter 0.15s; }
.dom-btn:hover { border-color: var(--gold); }
.dom-btn:disabled { opacity: 0.45; cursor: not-allowed; }
.dom-btn--accent { background: var(--red); border-color: color-mix(in srgb, var(--red-bright) 50%, transparent); color: var(--on-accent); }
.dom-btn--accent:hover { filter: brightness(1.12); border-color: var(--red-bright); }
.dom-btn--sm { padding: 5px 9px; font-size: 0.76rem; }
.dom-btn--danger { color: var(--red-bright); border-color: color-mix(in srgb, var(--red-bright) 40%, transparent); }
.dom-btn--danger:hover { background: color-mix(in srgb, var(--red-bright) 14%, transparent); border-color: var(--red-bright); }
.dom-back { background: none; border: none; color: var(--dom-muted); cursor: pointer; font: 600 0.85rem/1 var(--font); padding: 4px 0; margin-bottom: 0.6rem; }
.dom-back:hover { color: var(--gold-bright); }

/* Cartes d'événement (liste) */
.dom-event-card { display: block; width: 100%; text-align: left; cursor: pointer; border: 1px solid var(--dom-line); border-radius: 12px; background: var(--dom-panel); padding: 0.9rem 1.1rem; margin-bottom: 0.7rem; transition: border-color 0.12s, background 0.12s; }
.dom-event-card:hover { border-color: var(--gold); background: color-mix(in srgb, var(--gold) 6%, var(--dom-panel)); }
.dom-event-main { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.dom-event-name { font-family: 'Space Grotesk', system-ui, sans-serif; font-size: 1.15rem; font-weight: 600; }
.dom-event-meta { color: var(--dom-muted); font-size: 0.82rem; margin-top: 0.35rem; }

.dom-badges { display: inline-flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.dom-badge { font: 600 0.66rem/1 'IBM Plex Mono', monospace; letter-spacing: 0.06em; text-transform: uppercase; padding: 4px 8px; border-radius: 999px; border: 1px solid var(--dom-line); color: var(--dom-muted); }
.dom-badge--owner { color: var(--on-accent); background: var(--gold); border-color: var(--gold); }
.dom-badge--active { color: var(--on-accent); background: color-mix(in srgb, var(--success) 30%, transparent); border-color: var(--success); }
.dom-badge--closed { color: var(--dom-muted); }
.dom-badge--setup { color: var(--gold-bright); border-color: var(--gold-dim); }

/* Détail */
.dom-detail-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 1rem; flex-wrap: wrap; margin-bottom: 0.4rem; }
.dom-detail-name { margin: 0 0 0.4rem; font-family: 'Space Grotesk', system-ui, sans-serif; font-size: 1.6rem; }
.dom-actions { display: flex; gap: 8px; }

.dom-tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--dom-line); margin: 1rem 0 1.2rem; }
.dom-tab { appearance: none; background: none; border: none; cursor: pointer; font: 500 0.78rem/1 'IBM Plex Mono', monospace; letter-spacing: 0.1em; text-transform: uppercase; color: var(--dom-muted); padding: 11px 16px 13px; border-bottom: 2px solid transparent; margin-bottom: -1px; }
.dom-tab:hover { color: var(--text); }
.dom-tab.is-active { color: var(--gold-bright); border-bottom-color: var(--gold); }

/* Tables (roster / classement) */
.dom-table-wrap { overflow-x: auto; border: 1px solid var(--dom-line); border-radius: 12px; background: var(--dom-panel); }
.dom-table { width: 100%; border-collapse: collapse; font-size: 0.88rem; }
.dom-table th, .dom-table td { padding: 9px 12px; text-align: left; border-bottom: 1px solid var(--dom-line); vertical-align: middle; }
.dom-table thead th { font: 500 0.66rem/1.3 'IBM Plex Mono', monospace; letter-spacing: 0.08em; text-transform: uppercase; color: var(--dom-muted); }
.dom-table tbody tr:last-child td { border-bottom: none; }
.dom-table tbody tr.dom-me { background: color-mix(in srgb, var(--gold) 10%, transparent); }
.dom-row-actions { display: flex; gap: 6px; justify-content: flex-end; }
.dom-chip { display: inline-block; padding: 2px 9px; border-radius: 999px; font-size: 0.78rem; color: var(--on-accent); background: var(--c, #888); }

/* Matchs */
.dom-match { display: flex; align-items: center; gap: 0.9rem; border: 1px solid var(--dom-line); border-left: 3px solid var(--dom-line); border-radius: 10px; background: var(--dom-panel); padding: 0.7rem 0.9rem; margin-bottom: 0.55rem; }
.dom-match.win-a { border-left-color: var(--gold); }
.dom-match.win-b { border-left-color: var(--dom-red); }
.dom-match-rd { display: flex; flex-direction: column; gap: 4px; align-items: flex-start; font: 600 0.7rem/1 'IBM Plex Mono', monospace; color: var(--dom-muted); min-width: 3.6em; }
.dom-layout-badge { padding: 1px 7px; border-radius: 6px; font: 600 0.64rem/1.5 'IBM Plex Mono', monospace; background: color-mix(in srgb, var(--gold) 16%, transparent); border: 1px solid var(--dom-line); color: var(--gold-bright); white-space: nowrap; }

/* Layouts recommandés (réutilise images/layouts/ de Primaire) */
.dom-layouts { border: 1px dashed var(--dom-line); border-radius: 8px; padding: 0.6rem 0.8rem; }
.dom-layouts-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 0.4rem; }
.dom-layout-thumb { padding: 0 0 4px; border: 1px solid var(--dom-line); border-radius: 8px; background: var(--dom-panel); cursor: zoom-in; overflow: hidden; display: flex; flex-direction: column; align-items: center; gap: 3px; }
.dom-layout-thumb.is-sel { border-color: var(--gold); box-shadow: 0 0 0 1px var(--gold); }
.dom-layout-thumb img { width: 100%; height: auto; display: block; }
.dom-layout-thumb-lbl { font: 600 0.64rem/1.4 'IBM Plex Mono', monospace; color: var(--dom-muted); }
.dom-lightbox { position: fixed; inset: 0; z-index: 1100; display: grid; place-items: center; padding: 20px; background: rgba(8, 6, 4, 0.85); }
.dom-lightbox[hidden] { display: none; }
.dom-lightbox img { max-width: 96vw; max-height: 92vh; border-radius: 8px; box-shadow: var(--shadow-lg); }
.dom-lightbox-close { position: absolute; top: 14px; right: 18px; background: none; border: none; color: #fff; font-size: 2rem; line-height: 1; cursor: pointer; }
.dom-match-body { flex: 1; min-width: 0; }
.dom-match-line { display: flex; align-items: center; gap: 0.8rem; }
.dom-match-p { flex: 1; min-width: 0; }
.dom-match-p:last-of-type { text-align: right; }
.dom-match-p.is-win { color: var(--gold-bright); font-weight: 600; }
.dom-match-score { font: 700 0.95rem/1 'IBM Plex Mono', monospace; color: var(--text); white-space: nowrap; }
.dom-match-meta { color: var(--dom-muted); font-size: 0.76rem; margin-top: 0.25rem; }

/* Sous-onglets de phase (parties) */
.dom-phase-tabs { display: flex; gap: 5px; flex-wrap: wrap; margin-bottom: 0.8rem; }
.dom-phase-tab { appearance: none; background: none; border: 1px solid var(--dom-line); border-radius: 999px; cursor: pointer; font: 600 0.74rem/1 'IBM Plex Mono', monospace; color: var(--dom-muted); padding: 6px 14px; }
.dom-phase-tab:hover { border-color: var(--gold); }
.dom-phase-tab.is-active { background: color-mix(in srgb, var(--gold) 18%, transparent); border-color: var(--gold); color: var(--gold-bright); }
/* Statut d'une partie */
.dom-mstatus { padding: 1px 7px; border-radius: 6px; font: 600 0.6rem/1.5 'IBM Plex Mono', monospace; letter-spacing: 0.04em; text-transform: uppercase; border: 1px solid var(--dom-line); color: var(--dom-muted); }
.dom-mstatus--active { color: var(--gold-bright); border-color: var(--gold-dim); }
.dom-mstatus--scored { color: var(--on-accent); border-color: var(--success); background: color-mix(in srgb, var(--success) 20%, transparent); }
.dom-mstatus--validated { color: var(--on-accent); background: var(--gold); border-color: var(--gold); }

/* Regroupement des parties par round (en-tête + distribution des cartes) */
.dom-round-group { margin-bottom: 1.2rem; }
.dom-round-head { display: flex; align-items: center; gap: 0.7rem; flex-wrap: wrap; margin-bottom: 0.55rem; padding-bottom: 0.35rem; border-bottom: 1px solid var(--dom-line); }
.dom-round-tag { font: 700 0.78rem/1 'IBM Plex Mono', monospace; letter-spacing: 0.06em; text-transform: uppercase; color: var(--gold-bright); }
.dom-round-meta { font-size: 0.74rem; color: var(--dom-muted); }
.dom-round-head .dom-btn, .dom-round-head .dom-round-done { margin-left: auto; }
.dom-round-done { font: 600 0.72rem/1 'IBM Plex Mono', monospace; color: var(--success); }

/* Win path */
.dom-winpath { display: flex; gap: 3px; }
.wp { display: inline-grid; place-items: center; width: 1.35em; height: 1.35em; border-radius: 4px; font: 700 0.7rem/1 'IBM Plex Mono', monospace; }
.wp-w { background: color-mix(in srgb, var(--success) 35%, transparent); color: var(--on-accent); }
.wp-l { background: color-mix(in srgb, var(--red-bright) 35%, transparent); color: var(--on-accent); }
.wp-d { background: color-mix(in srgb, var(--dom-muted) 30%, transparent); color: var(--text); }

/* Formulaires (modales) */
.dom-form { display: flex; flex-direction: column; gap: 12px; }
.dom-form label { font: 500 0.64rem/1.3 'IBM Plex Mono', monospace; letter-spacing: 0.12em; text-transform: uppercase; color: var(--dom-muted); display: block; margin-bottom: 5px; }
.dom-form input, .dom-form select, .dom-form textarea { width: 100%; padding: 9px 11px; border: 1px solid var(--line2); border-radius: 8px; background: var(--bg2); color: var(--text); font: 0.9rem var(--font); }
.dom-form input:focus, .dom-form select:focus, .dom-form textarea:focus { outline: none; border-color: var(--gold); }
.dom-form input:disabled { opacity: 0.55; }
.dom-grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.dom-grid3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 8px; }
@media (max-width: 560px) { .dom-grid2, .dom-grid3 { grid-template-columns: 1fr; } }
.dom-vs { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
@media (max-width: 620px) { .dom-vs { grid-template-columns: 1fr; } }
.dom-vs-side { display: flex; flex-direction: column; gap: 10px; border: 1px solid var(--dom-line); border-radius: 10px; padding: 0.7rem; }
.dom-side-tag { font: 700 0.7rem/1 'IBM Plex Mono', monospace; letter-spacing: 0.1em; text-transform: uppercase; padding: 4px 8px; border-radius: 6px; align-self: flex-start; }
.dom-side-a { background: color-mix(in srgb, var(--gold) 22%, transparent); color: var(--gold-bright); }
.dom-side-b { background: color-mix(in srgb, var(--dom-red) 24%, transparent); color: var(--on-accent); }
.dom-mission-info { border: 1px dashed var(--dom-line); border-radius: 8px; padding: 0.6rem 0.8rem; font-size: 0.85rem; color: var(--text); }
.dom-mission-info .dom-kicker { display: block; margin-bottom: 0.3rem; color: var(--dom-muted); }
.dom-det-block + .dom-det-block { margin-top: 0.5rem; padding-top: 0.5rem; border-top: 1px dashed var(--dom-line); }
.dom-check label { display: inline-flex; align-items: center; gap: 0.5rem; margin: 0; font: 500 0.88rem var(--font); letter-spacing: normal; text-transform: none; color: var(--text); cursor: pointer; }
.dom-check input { width: auto; }
.dom-ro { padding: 9px 11px; border: 1px dashed var(--line2); border-radius: 8px; background: color-mix(in srgb, var(--bg2) 55%, transparent); color: var(--dom-muted); font-size: 0.9rem; min-height: 1.2em; }
.dom-disp-chip { display: inline-flex; align-items: center; gap: 5px; padding: 2px 9px; border-radius: 999px; background: color-mix(in srgb, var(--c, #888) 22%, transparent); border: 1px solid color-mix(in srgb, var(--c, #888) 60%, transparent); color: var(--text); font-size: 0.8rem; white-space: nowrap; }
.dom-disp-glyph { font-size: 0.95em; line-height: 1; }
.dom-det-row { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin: 0.2rem 0; }

/* Interrupteur (segmented) Tactical / Fixed pour le type de secondaires */
.dom-seg { position: relative; display: inline-flex; border: 1px solid var(--line2); border-radius: 8px; overflow: hidden; }
.dom-seg input { position: absolute; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.dom-seg label { margin: 0; padding: 8px 16px; cursor: pointer; font: 600 0.82rem/1 var(--font); letter-spacing: normal; text-transform: none; color: var(--dom-muted); background: var(--bg2); transition: background 0.12s, color 0.12s; }
.dom-seg label:not(:first-of-type) { border-left: 1px solid var(--line2); }
.dom-seg input:checked + label { background: color-mix(in srgb, var(--gold) 22%, transparent); color: var(--gold-bright); }
.dom-seg input:focus-visible + label { outline: 2px solid var(--gold); outline-offset: -2px; }

/* Détermination des missions sous chaque colonne joueur (prépa) */
.dom-det-side { border: 1px dashed var(--dom-line); border-radius: 8px; padding: 0.45rem 0.6rem; background: color-mix(in srgb, var(--dom-gold) 5%, transparent); font-size: 0.84rem; }
.dom-det-side[hidden] { display: none; }
.dom-det-lbl { font: 600 0.58rem/1.4 'IBM Plex Mono', monospace; letter-spacing: 0.06em; text-transform: uppercase; color: var(--dom-muted); }
.dom-det-ach { font-size: 0.76rem; line-height: 1.45; color: var(--dom-muted); margin: 0.15rem 0 0.35rem; padding-left: 0.1rem; }
/* Case Peinture (score) alignée en bas avec les champs PV */
.dom-grid3 { align-items: end; }
.dom-grid3 .dom-check { padding-bottom: 8px; }
/* Ligne Lieu : sélecteur 1-6 étroit + nom de la carte Lieu */
.dom-lieu-row { display: grid; grid-template-columns: 90px 1fr; gap: 10px; align-items: center; }
.dom-lieu-row .dom-ro { min-height: 0; }
.dom-lieu-rules { border: 1px dashed var(--dom-line); border-radius: 8px; padding: 0.5rem 0.65rem; background: color-mix(in srgb, var(--dom-gold) 4%, transparent); }
.dom-lieu-rules[hidden] { display: none; }
.dom-lieu-rule { font-size: 0.82rem; line-height: 1.45; margin: 0.2rem 0; }
.dom-lieu-rule .dom-det-lbl { color: var(--gold-bright); margin-right: 4px; }
.dom-all-badge { display: inline-flex; align-items: center; gap: 5px; padding: 2px 9px; border-radius: 999px; background: color-mix(in srgb, var(--c, #888) 18%, transparent); border: 1px solid color-mix(in srgb, var(--c, #888) 55%, transparent); color: var(--text); font-size: 0.8rem; white-space: nowrap; }
.dom-all-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--c, #888); flex: none; }
.dom-all-img { width: 19px; height: 19px; object-fit: cover; border-radius: 50%; flex: none; background: #f5f3eb; border: 1px solid color-mix(in srgb, var(--c, #888) 65%, transparent); }
/* Emblèmes de factions (logos Creuset servis à la demande ; repli texte si absent) */
.dom-faction-img { width: 18px; height: 18px; object-fit: contain; vertical-align: -4px; margin-right: 5px; flex: none; }
.dom-faction-cell { display: inline-flex; align-items: center; gap: 5px; }
.dom-faction-line { display: flex; align-items: center; gap: 6px; font-size: 0.82rem; color: var(--dom-muted); min-height: 1em; }
.dom-faction-line:empty { display: none; }
.dom-faction-line .dom-faction-img { width: 22px; height: 22px; margin: 0; }
.dom-det-players { display: flex; flex-wrap: wrap; gap: 0.5rem 1.2rem; margin-bottom: 0.5rem; padding-bottom: 0.5rem; border-bottom: 1px dashed var(--dom-line); }
.dom-det-player { display: inline-flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.dom-result-preview { font: 700 1rem/1 'IBM Plex Mono', monospace; color: var(--gold-bright); text-align: center; padding: 0.4rem 0; }
.dom-hint { font-size: 0.8rem; color: var(--dom-muted); }
.dom-err { font-size: 0.82rem; color: var(--red-bright); min-height: 1.1em; }
.dom-toolbar .dom-kicker { align-self: center; }
.dom-toolbar-btns { display: flex; gap: 8px; flex-wrap: wrap; }

/* Appairage */
.dom-pair { display: flex; align-items: center; gap: 0.7rem; flex-wrap: wrap; border: 1px solid var(--dom-line); border-radius: 10px; background: var(--dom-panel); padding: 0.6rem 0.8rem; margin-bottom: 0.5rem; }
.dom-pair--bye { opacity: 0.8; border-style: dashed; }
.dom-pair-n { font: 700 0.72rem/1 'IBM Plex Mono', monospace; color: var(--dom-muted); min-width: 1.4em; text-align: center; }
.dom-pair-side { flex: 1; min-width: 120px; display: flex; flex-direction: column; gap: 2px; }
.dom-pair-side .dom-hint { font-size: 0.72rem; }
.dom-pair-vs { font: 600 0.72rem/1 'IBM Plex Mono', monospace; color: var(--gold-bright); }
.dom-pair-flag { font-size: 0.72rem; color: #e6b800; background: color-mix(in srgb, #e6b800 16%, transparent); border: 1px solid color-mix(in srgb, #e6b800 40%, transparent); border-radius: 6px; padding: 2px 7px; }
.dom-pair-actions { display: flex; justify-content: flex-end; gap: 8px; margin-top: 1rem; }

/* Progression de campagne */
.dom-prog-block { border: 1px solid var(--dom-line); border-radius: 12px; background: var(--dom-panel); padding: 0.8rem 1rem; margin-bottom: 0.7rem; }
.dom-prog-block.dom-me { border-color: var(--gold-dim); }
.dom-prog-head { display: flex; align-items: baseline; gap: 0.6rem; flex-wrap: wrap; margin-bottom: 0.5rem; }
.dom-prog-name { font-family: 'Space Grotesk', system-ui, sans-serif; font-size: 1.05rem; font-weight: 600; }
.dom-prog-phase { display: flex; align-items: flex-start; gap: 0.6rem; margin: 0.35rem 0; }
.dom-prog-phase-tag { flex: none; font: 600 0.66rem/1.6 'IBM Plex Mono', monospace; letter-spacing: 0.08em; text-transform: uppercase; color: var(--dom-muted); min-width: 4.2em; }
.dom-card-list { display: flex; flex-wrap: wrap; gap: 6px; }
.dom-card-chip { display: inline-flex; align-items: center; gap: 6px; padding: 4px 8px; border-radius: 8px; border: 1px solid var(--dom-line); background: color-mix(in srgb, var(--dom-gold) 5%, transparent); font-size: 0.82rem; }
.dom-card-type { font: 600 0.62rem/1 'IBM Plex Mono', monospace; letter-spacing: 0.04em; text-transform: uppercase; color: var(--dom-muted); }
.dom-card-name em { color: var(--dom-muted); }
.dom-card-chip.dom-card-battle_honour { border-color: color-mix(in srgb, var(--gold) 45%, transparent); }
.dom-card-chip.dom-card-battle_skill { border-color: color-mix(in srgb, #4a76b8 45%, transparent); }
.dom-card-chip.dom-card-upgrade { border-color: color-mix(in srgb, var(--success) 45%, transparent); }
.dom-card-chip.dom-card-agenda_achieved { border-color: color-mix(in srgb, #9a6fb0 50%, transparent); }
.dom-card-chip.dom-card-relic { border-color: color-mix(in srgb, var(--red-bright) 45%, transparent); }
.dom-card-x { background: none; border: none; color: var(--dom-muted); cursor: pointer; font-size: 0.9rem; line-height: 1; padding: 0 2px; }
.dom-card-x:hover { color: var(--gold-bright); }

/* ── Campagne (couche narrative) ───────────────────────────── */
.dom-camp-block { border: 1px solid var(--dom-line); border-radius: 12px; background: var(--dom-panel); padding: 0.9rem 1.1rem; margin-bottom: 0.9rem; }
.dom-camp-head { display: flex; align-items: center; justify-content: space-between; gap: 0.7rem; flex-wrap: wrap; }
.dom-camp-total { font: 700 0.95rem/1 'IBM Plex Mono', monospace; color: var(--gold-bright); }
.dom-camp-total .dom-hint { font-size: 0.66rem; }
.dom-camp-members { color: var(--dom-muted); font-size: 0.82rem; margin: 0.35rem 0 0.2rem; }
.dom-camp-phase { border-top: 1px dashed var(--dom-line); margin-top: 0.7rem; padding-top: 0.7rem; }
.dom-camp-phase-head { display: flex; align-items: baseline; gap: 0.6rem; flex-wrap: wrap; margin-bottom: 0.45rem; }
.dom-camp-phase-head .dom-hint { font-style: italic; }
.dom-pn-controls { display: flex; align-items: center; gap: 1rem 1.4rem; flex-wrap: wrap; margin-bottom: 0.6rem; }
.dom-pn-controls .dom-check label { font-size: 0.84rem; }
.dom-pn-controls .dom-hint { color: var(--gold-bright); }
.dom-pn-badge { margin-left: auto; font: 700 0.78rem/1 'IBM Plex Mono', monospace; color: var(--on-accent); background: var(--gold); border-radius: 999px; padding: 4px 10px; }
.dom-cons { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 8px; }
@media (max-width: 640px) { .dom-cons { grid-template-columns: 1fr; } }
.dom-cons-out { border: 1px solid var(--dom-line); border-radius: 9px; padding: 0.5rem 0.65rem; background: color-mix(in srgb, var(--bg2) 40%, transparent); opacity: 0.55; transition: opacity 0.12s, border-color 0.12s; }
.dom-cons-out p { margin: 0.3rem 0 0; font-size: 0.82rem; line-height: 1.5; }
.dom-cons-out.is-active { opacity: 1; border-color: var(--gold); background: color-mix(in srgb, var(--gold) 10%, transparent); box-shadow: 0 0 0 1px color-mix(in srgb, var(--gold) 40%, transparent); }
.dom-cons-k { font: 700 0.62rem/1 'IBM Plex Mono', monospace; letter-spacing: 0.06em; text-transform: uppercase; color: var(--dom-muted); }
.dom-cons-out.is-active .dom-cons-k { color: var(--gold-bright); }
