/* =====================================================
   MORDHEIM
   style.css — v6.3.1
   - Palette révisée (purple2, blue2, green2, red2, amber2, text, bg2)
   - UnifrakturCook en priorité pour les titres blackletter
   - Cartes guerrier + HUD recrutement : bordure crème 2px
   - Tags guerrier : fond rouge solid
   - Tags blessure : outline rouge sans fond
   - Compteurs −/+ et .inp : outline #6e6555, sans fond
   - Barre progression étape active : #bcad8a
   - Bannière déroute : fond plein #7a1f17, sans bordure ni pulse
   - Nouvelles vars --dark-deep et --parchment
   ===================================================== */

/* --- Polices Google — Design System V2 --- */
@import url('https://fonts.googleapis.com/css2?family=EB+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=JetBrains+Mono:wght@400;500;700&family=IM+Fell+English:ital@0;1&family=UnifrakturCook:wght@700&display=swap');

/* --- Police Mordheim custom (titres blackletter) --- */
@font-face {
  font-family: 'MordheimFont';
  src: url('Mordheim-font.woff2') format('woff2');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

/* --- Variables & reset --- */
/* Palette Design System v2 — Mode Crépuscule (dark) */
:root {
  --bg:       #14110e;
  --bg2:      #1d1915;
  --bg3:      #1f1a15;
  --bg4:      #2a221d;
  --text:     #ebdfc9;
  --text1:    #ebdfc9;
  --text2:    #9a8f7d;
  --text3:    #6e6555;
  --border:   #2a221d;
  --border2:  #3a3028;
  --gold:     #ebdfc9;
  --gold2:    #d8cdb1;
  --red:      #8b3020;
  --red2:     #c34d3a;
  --red-bg:   #7a1f17;
  --green:    #4d6a35;
  --green2:   #7e9461;
  --green-bg: #0c140a;
  --amber:    #7a4a18;
  --amber2:   #dc703c;
  --amber-bg: #1a0e06;
  --blue:     #2a4a6a;
  --blue2:    #7dabd6;
  --blue-bg:  #080e18;
  --purple:   #4a2a7a;
  --purple1:  #2a1550;
  --purple2:  #ad90da;
  --purple-bg:#120820;
  --pm2:      #7e9461;
  --pm-bg:    #0c140a;
  --dark-deep: #151210;
  --parchment: #bcad8a;

  /* Couleurs pleines pour tags sans bordure */
  --tag-amber-solid:  #7a4a18;
  --tag-blue-solid:   #2a4a6a;
  --tag-red-solid:    #c34d3a;
  --tag-green-solid:  #3a5228;
  --tag-purple-solid: #836aba;
  --tag-grey-solid:   #2a221d;

  /* Tokens cards guerriers */
  --orange:      #e8943a;  /* Héros mineur */
  --bonus-color: #6fcf45;  /* Vert saturé caracs */
  --malus-color: #e84040;  /* Rouge saturé caracs */

  /* Fond crème campagne */
  --camp-hud-bg:  #ece3cf;
  --camp-hud-txt: #14110e;
  --camp-hud-lbl: #4a443d;

  /* Zéro arrondi */
  --radius:    0px;
  --radius-sm: 0px;
  --radius-xs: 0px;

  --ft: 'UnifrakturCook', 'MordheimFont', serif;
  --fs: 'EB Garamond', 'IM Fell English', Georgia, serif;
  --fm: 'JetBrains Mono', monospace;
  --fb: 'EB Garamond', Georgia, serif;

  /* Immersion — textures sombres */
  --tex-fiber-light : rgba(236, 227, 207, 0.018); /* fibre fond */
  --tex-corner-warm : rgba(194,  86,  63, 0.10);  /* coin rouille */
  --tex-corner-cold : rgba(154, 143, 125, 0.09);  /* coin graphite */
  --tex-erase       : rgba( 14,  12,  10, 0.14);  /* masque effacement */
}

* { box-sizing: border-box; margin: 0; padding: 0; -webkit-tap-highlight-color: transparent; }

body {
  font-family: var(--fb);
  background: var(--bg);
  color: var(--text);
  font-size: 18px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  min-height: 100vh;
  overflow-x: hidden;
}

/* --- Layout --- */
#app {
  max-width: 480px;
  margin: 0 auto;
  padding: 12px 14px 90px;
  min-height: 100vh;
  position: relative; /* prérequis #app::before */
}

/* Spec 1 — Fond fibres : parchemin usé dans l'obscurité */
#app::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background:
    repeating-linear-gradient(
      0deg,
      rgba(236, 227, 207, 0.07) 0 1px,
      transparent 1px 6px
    ),
    repeating-linear-gradient(
      92deg,
      rgba(236, 227, 207, 0.05) 0 1px,
      transparent 1px 11px
    ),
    radial-gradient(
      ellipse 60% 40% at 30% 20%,
      rgba(236, 227, 207, 0.10),
      transparent 70%
    );
  mix-blend-mode: overlay;
}

/* --- Navigation --- */
.nav {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 4px;
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 480px;
  background: var(--bg2);
  padding: 7px 10px 13px;
  border-top: 3px solid var(--border2);
  z-index: 100;
}
.nav-btn {
  padding: 5px 2px;
  border: 1px solid var(--border);
  border-radius: 0;
  background: var(--bg3);
  color: var(--text2);
  font-size: 13px;
  cursor: pointer;
  text-align: center;
  line-height: 1.3;
  font-family: var(--fb);
}
.nav-btn.active { background: var(--text); color: var(--bg); border-color: var(--text2); font-weight: 600; }
.nav-icon { font-size: 19px; display: block; margin-bottom: 2px; }

/* --- Pages --- */
.page { display: none; }
.page.active { display: block; }

/* --- Typography --- */
.pt  { font-family: var(--ft); font-size: 25px; color: var(--text); margin-bottom: 2px; text-transform: none; position: relative; overflow: visible; }
.pt.pt-type { font-size: 32px; margin-bottom: 0; position: relative; overflow: visible; }

/* Spec 3 — Effacement typographique subtil (titres Fraktur) */
.pt::after,
.pt.pt-type::after {
  content: "";
  position: absolute;
  top: 2px;
  right: 8px;
  width: 28px;
  height: 14px;
  background: rgba(236, 227, 207, 0.08);
  mix-blend-mode: overlay;
  border-radius: 0;
  pointer-events: none;
  transform: rotate(-1.5deg);
}
.pt-bandname { font-family: 'EB Garamond', Georgia, serif; font-size: 36px; color: var(--gold); margin-bottom: 2px; line-height: 1.2; }
.ps  { font-size: 15px; color: var(--text2); margin-bottom: 14px; }
.sec {
  font-family: var(--ft);
  font-size: 27px;
  color: var(--text);
  margin: 14px 0 6px;
  display: flex;
  align-items: center;
  gap: 6px;
  text-transform: none;
}
.sec::after { content: ''; flex: 1; height: 3px; background: var(--text); }

/* --- Cards --- */
.card {
  background: var(--bg2);
  border: 2px solid var(--text);
  border-radius: 0;
  padding: 12px 14px;
  margin-bottom: 9px;
  position: relative;
}
.card.dead  { opacity: .35; border-style: dashed; border-color: var(--red); }
.card.dim   { opacity: .4;  border-style: dashed; }
.card.gold-b { border-color: var(--border2); }
.card.alert-b { border: 3px solid var(--red2); }

/* --- Warrior Card (roster + recrutement) --- */
.warrior-card {
  background:    var(--bg2);
  border:        2px solid var(--text);
  border-radius: 0;
  padding:       12px 14px;
  margin-bottom: 16px;
  position:      relative;
}
.warrior-card.hero {
  border:         2px solid var(--text);
  outline:        2px solid var(--text);
  outline-offset: -8px;
}
.warrior-card.ft                    { border-color: var(--blue2); }
.warrior-card.ft .warrior-sep        { border-top-color: var(--blue2); }
.warrior-card.ft .warrior-sep.dotted { border-top-color: var(--blue); }
.warrior-card.dead  { opacity: 0.35; }
.warrior-card.dim   { opacity: 0.5; border-style: dotted; }
.warrior-card.alert { border: 2px solid var(--red2); }

/* ── Collapsible warrior cards ──────────────────── */
.wc-header { cursor: pointer; user-select: none; -webkit-user-select: none; }

/* ── Compact battle rows ─────────────────────────── */
.warrior-card.wc-battle { padding: 8px 10px; margin-bottom: 6px; }
.wc-row-main { display: flex; align-items: center; gap: 8px; }

.wc-hdc-toggle {
  flex-shrink: 0; width: 32px; height: 32px;
  border: 2px solid var(--green2); background: var(--green-bg); color: var(--green2);
  font-size: 16px; border-radius: 0; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; padding: 0; line-height: 1; font-family: var(--fm);
}
.wc-hdc-toggle.hdc { border-color: var(--red2); background: var(--red-bg); color: var(--red2); }
.wc-hdc-toggle:active { opacity: 0.7; }

.wc-hdm-hdc {
  flex-shrink: 0; display: flex; flex-direction: column;
  align-items: center; gap: 1px; width: 36px;
}
.wc-hdm-hdc-count { font-family: var(--fm); font-size: 16px; font-weight: 700; color: var(--red2); line-height: 1; }
.wc-hdm-hdc .ab { padding: 2px 0; font-size: 12px; width: 100%; text-align: center; }

.wc-row-info { flex: 1; min-width: 0; }
.wc-row-name { display: flex; align-items: center; gap: 5px; flex-wrap: wrap; line-height: 1.2; }
.wc-row-name .wn { font-size: 18px !important; line-height: 1.1; }
.wc-mini-stats {
  font-size: 11px; color: var(--text2); font-family: var(--fm);
  margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.wc-kills { flex-shrink: 0; display: flex; flex-direction: column; gap: 4px; align-items: flex-end; }
.wc-kill-line { display: flex; align-items: center; gap: 3px; }
.wc-kill-lbl { font-family: var(--fm); font-size: 9px; color: var(--text2); min-width: 22px; text-align: right; }
.wc-kill-n { font-family: var(--fm); font-size: 15px; font-weight: 700; min-width: 16px; text-align: center; }
.wc-kills .ab { padding: 2px 8px; font-size: 12px; }
.wc-chevron {
  font-size: 10px; color: var(--text2); display: inline-block;
  transition: transform 0.15s ease; margin-left: 4px; vertical-align: middle;
}
.warrior-card.wc-open .wc-chevron { transform: rotate(90deg); }
.wc-body { display: none; }
.warrior-card.wc-open .wc-body { display: block; }
/* Les cards mortes/absentes n'ont pas de body à déployer */
.warrior-card.dead .wc-header,
.warrior-card.dim .wc-header { cursor: default; }

/* ── Battle list rows ─────────────────────────────── */
.wc-row-b {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 11px 12px;
  border: 1px solid var(--border2);
  margin-bottom: 4px;
  cursor: pointer;
  user-select: none;
  -webkit-user-select: none;
  transition: background 0.1s ease;
  -webkit-tap-highlight-color: transparent;
}
.wc-row-b:hover  { background: var(--bg3); }
.wc-row-b:active { background: var(--bg4); }
.wc-row-b.hdc-row { opacity: 0.45; border-style: dashed; }
.wc-row-b .wn { font-size: 17px !important; }

/* Indicateur de statut (carré coloré) */
.wc-dot {
  flex-shrink: 0;
  width: 8px; height: 8px;
  background: var(--green2);
}
.wc-dot.hdc     { background: var(--red2); }
.wc-dot.partial { background: var(--amber2); }

/* Badge HDC dans la ligne */
.wc-hdc-tag {
  font-family: var(--fm);
  font-size: 9px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--red2);
  border: 1px solid var(--red2);
  padding: 1px 5px;
  flex-shrink: 0;
  margin-left: auto;
}

/* ── Overlay détail guerrier ──────────────────────── */
.wc-detail-bg {
  position: fixed;
  inset: 0;
  background: rgba(14, 11, 8, 0.72);
  z-index: 200;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
}
.wc-detail-bg.on { opacity: 1; pointer-events: all; }

.wc-detail-panel {
  position: fixed;
  top: 0; left: 50%;
  transform: translateX(-50%) translateY(-100%);
  width: 100%;
  max-width: 480px;
  max-height: 88vh;
  overflow-y: auto;
  background: var(--bg2);
  border: 2px solid var(--text);
  border-top: none;
  z-index: 201;
  padding-bottom: 28px;
  transition: transform 0.26s cubic-bezier(0.2, 0, 0, 1);
  overscroll-behavior: contain;
}
.wc-detail-panel.on { transform: translateX(-50%) translateY(0); }

/* Header sticky de l'overlay */
.wc-detail-sticky {
  position: sticky;
  top: 0;
  background: var(--bg2);
  border-bottom: 2px solid var(--border2);
  padding: 12px 14px 10px;
  display: flex;
  align-items: center;
  gap: 8px;
  z-index: 1;
}
.wc-detail-sticky .wn { font-size: 21px !important; flex: 1; min-width: 0; }

.wc-detail-close {
  flex-shrink: 0;
  width: 36px; height: 36px;
  border: 1px solid var(--border2);
  background: transparent;
  color: var(--text2);
  font-size: 20px;
  cursor: pointer;
  font-family: var(--fm);
  display: flex; align-items: center; justify-content: center;
}
.wc-detail-close:active { opacity: 0.6; }

/* Corps de l'overlay */
.wc-detail-body { padding: 0 14px; }

.wc-detail-slbl {
  font-family: var(--fm);
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--text2);
  margin-bottom: 8px;
}
.wc-detail-section { margin-top: 16px; }

/* Séparateur info / actions */
.wc-detail-divider {
  border: none;
  border-top: 2px solid var(--text);
  margin: 20px 0 0;
}

/* Bouton HDC (grand, pleine largeur) */
.wc-hdc-btn {
  display: block;
  width: 100%;
  padding: 15px 12px;
  margin-top: 8px;
  font-family: var(--fm);
  font-size: 13px;
  letter-spacing: .1em;
  text-transform: uppercase;
  font-weight: 700;
  cursor: pointer;
  border: 2px solid var(--green2);
  background: var(--green-bg);
  color: var(--green2);
  text-align: center;
}
.wc-hdc-btn.hdc { border-color: var(--red2); background: var(--red-bg); color: var(--red2); }
.wc-hdc-btn:active { opacity: 0.7; }

/* Compteur HDC pour groupes HdM */
.wc-hdm-hdc-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 8px;
}
.wc-hdm-hdc-display {
  flex: 1;
  text-align: center;
  font-family: var(--fm);
  font-size: 24px;
  font-weight: 700;
}
.wc-detail-cnt { color: var(--red2); }

/* Kill counters */
.wc-kill-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}
.wc-kill-row:last-child { border-bottom: none; }
.wc-kill-label {
  flex: 1;
  font-family: var(--fm);
  font-size: 12px;
  color: var(--text2);
}
.wc-detail-kill-n {
  font-family: var(--fm);
  font-size: 26px;
  font-weight: 700;
  min-width: 36px;
  text-align: center;
}
.wc-kill-btn {
  min-width: 48px;
  height: 48px;
  border: 1px solid var(--border2);
  background: var(--bg3);
  color: var(--text);
  font-size: 24px;
  font-family: var(--fm);
  font-weight: 700;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.wc-kill-btn.off { opacity: 0.25; pointer-events: none; }
.wc-kill-btn:active { background: var(--bg4); }

.warrior-card-overlay {
  position:        absolute;
  inset:           0;
  display:         flex;
  align-items:     center;
  justify-content: center;
  font-family:     var(--fm);
  font-size:       28px;
  font-weight:     700;
  letter-spacing:  0.15em;
  text-transform:  uppercase;
  color:           var(--text);
  pointer-events:  none;
}

/* --- HUD --- */
.hud {
  background: linear-gradient(135deg, var(--bg3), var(--bg2));
  border: 1px solid var(--border2);
  border-radius: 0;
  padding: 16px;
  margin-bottom: 12px;
  text-align: center;
}
.hud-band { font-family: var(--ft); font-size: 27px; color: var(--text); text-transform: none; }
.hud-sub  { font-size: 15px; color: var(--text2); margin: 2px 0 10px; }
.hud-div  { border: none; border-top: 3px solid var(--border2); margin: 10px 0; }
.hud-val  { font-family: var(--fm); font-size: 37px; color: var(--text); }
.hud-val-l{ font-size: 14px; color: var(--text2); margin-top: 2px; }

/* --- Metric grids --- */
.mg  { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 10px; }
.mc  { background: var(--bg3); border: 1px solid var(--border2); border-radius: 0; padding: 10px 12px; }
.ml  { font-size: 14px; color: var(--text2); margin-bottom: 2px; }
.mv  { font-family: var(--fm); font-size: 23px; font-weight: 700; }
.mv.gold  { color: var(--text); }
.mv.green { color: var(--text); }

.m2  { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 10px; }
.m2c { background: var(--bg3); border: 1px solid var(--border); border-radius: 0; padding: 10px 12px; text-align: center; }
.m2l { font-size: 14px; color: var(--text2); }
.m2v { font-family: var(--fm); font-size: 21px; font-weight: 700; }

/* --- Warrior info --- */
.wn { font-family: 'UnifrakturCook', 'UnifrakturMaguntia', var(--ft), serif; font-size: 24px !important; font-weight: 700; line-height: 1.15; }
.wt { font-size: 13px; color: var(--text2); margin-top: 2px; }

/* Trait séparateur interne des cards guerriers */
.card-sep { border: none; border-top: 2px solid var(--text); margin: 8px -14px 10px; opacity: 1; }

/* Séparateurs warrior-card */
.warrior-sep        { border: none; border-top: 2px solid var(--text);         margin: 8px 0 10px; opacity: 1; }
.warrior-sep.dotted { border: none; border-top: 1px dashed var(--text3);       margin: 8px 0 6px;  opacity: 1; }

/* Centrage des blocs métriques de bande */
.mc { text-align: center; }

/* --- Badges --- */
.badge {
  display: inline-block;
  font-family: var(--fm);
  font-size: 13px; font-weight: 600;
  padding: 2px 7px;
  border-radius: 0;
  margin-left: 4px;
  vertical-align: middle;
}
.bh    { background: var(--tag-amber-solid);  color: var(--amber2);  border: none; }
.bhdm  { background: var(--tag-grey-solid);   color: var(--text);    border: none; }
.bwarn { background: var(--tag-red-solid);    color: #1a0a08;        border: none; }
.bsuc  { background: var(--tag-green-solid);  color: var(--green2);  border: none; text-transform: uppercase; }
.binfo { background: var(--tag-blue-solid);   color: var(--blue2);   border: none; }
.bgold { background: transparent; color: var(--bonus-color); border: 1px solid var(--bonus-color); text-transform: uppercase; font-size: 11px; padding: 3px 8px; }
.prog-b {
  display: inline-block;
  font-family: var(--fm);
  background: var(--tag-amber-solid); color: var(--amber2); border: none;
  border-radius: 0; padding: 3px 8px; font-size: 14px; font-weight: 600; margin-top: 5px;
}

/* Badge « ABSENT DE LA BATAILLE » — fond blanc-crème, rayures rouges 45°,
   texte noir, outline rouge, uppercase. Même rôle/placement que le tag MORT. */
.tag-absent-battle {
  display: inline-block;
  font-family: var(--fm);
  font-size: 11px; font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  padding: 3px 8px;
  margin-left: 4px;
  vertical-align: middle;
  color: #14110e;
  border: 1px solid var(--red2);
  border-radius: 0;
  background-color: #ece3cf;
  background-image: repeating-linear-gradient(
    45deg,
    rgba(195, 77, 58, 0.30) 0,
    rgba(195, 77, 58, 0.30) 5px,
    transparent 5px,
    transparent 11px
  );
}

/* --- Stats table (JetBrains Mono) --- */
.stbl { width: 100%; border-collapse: collapse; font-size: 15px; font-family: var(--fm); table-layout: fixed; margin: 6px 0; }
.stbl th { color: var(--text2); font-weight: 600; text-align: center; padding: 4px 1px; border-bottom: 3px solid var(--border); }
.stbl td { text-align: center; padding: 5px 1px; font-weight: 700; color: var(--text); }
.stbl td.boosted    { color: var(--bonus-color);  font-weight: 700; }
.stbl td.carac-malus { color: var(--malus-color); font-weight: 700; }
.stbl td.carac-bonus { color: var(--bonus-color); font-weight: 700; }

/* --- XP bar --- */
.xpr { display: flex; align-items: center; gap: 6px; margin: 5px 0; }
.xpw { flex: 1; height: 5px; background: var(--border); border-radius: 0; overflow: hidden; }
.xpb { height: 5px; border-radius: 0; background: var(--text); }
.xpl { font-family: var(--fm); font-size: 14px; color: var(--text2); white-space: nowrap; min-width: 20px; }
.xpi { font-family: var(--fm); font-size: 14px; color: var(--text2); text-align: center; margin-top: 2px; }

/* --- Tags — système sémantique v6 — pleins, sans bordure, JetBrains Mono --- */
.tag-base {
  display: inline-block;
  font-family: var(--fm);
  border-radius: 0;
  padding: 3px 8px;
  font-size: 14px;
  font-weight: 600;
  margin: 2px 2px 0 0;
  line-height: 1.5;
  vertical-align: middle;
  white-space: nowrap;
  border: none;
}

/* Guerrier → ROUGE plein (CHEF/CHAMPION) — conservé pour compatibilité */
.tag-guerrier {
  display: inline-block;
  font-family: var(--fm);
  background: var(--tag-red-solid); color: #f0c0b0; border: none;
  border-radius: 0; padding: 3px 8px; font-size: 11px; font-weight: 600;
  margin: 2px 2px 0 0; line-height: 1.5; vertical-align: middle; white-space: nowrap;
  cursor: default; text-transform: uppercase;
}

/* Tags type guerrier — système .tg-* */
.tag-guerrier.tg-chef     { background: var(--red2);   color: #1a0a08; }
.tag-guerrier.tg-hero-maj { background: var(--orange); color: #1a0a08; }
.tag-guerrier.tg-hero-min { background: #f2c49a;       color: #1a0a08; }
.tag-guerrier.tg-sorcier  { background: var(--purple2); color: #1a0a08; }
.tag-guerrier.tg-ft       { background: var(--blue2);  color: #1a0a08; }
.tag-guerrier.tg-hdm      { background: var(--text);   color: #1a0a08; }

/* Compétences → fond card, outline crème, texte crème, CAPITALES */
.tag-competence {
  display: inline-block;
  font-family: var(--fm);
  background: var(--bg2); color: var(--text); border: 1px solid var(--text);
  border-radius: 0; padding: 3px 8px; font-size: 11px; font-weight: 600;
  margin: 2px 2px 0 0; line-height: 1.5; vertical-align: middle; white-space: nowrap;
  cursor: pointer;
  text-transform: uppercase;
  transition: filter .15s;
}
.tag-competence:hover { filter: brightness(1.25); }

/* Blessures → ROUGE outline, sans fond */
.tag-blessure {
  display: inline-block;
  font-family: var(--fm);
  background: transparent; color: var(--red2); border: 2px solid var(--red2);
  border-radius: 0; padding: 2px 6px; font-size: 11px; font-weight: 600;
  margin: 2px 2px 0 0; line-height: 1.5; vertical-align: middle; white-space: nowrap;
  cursor: default;
}

/* Équipement → fond neutre visible */
.tag-equip {
  display: inline-block;
  font-family: var(--fm);
  background: var(--border2); color: var(--text2); border: none;
  border-radius: 0; padding: 3px 8px; font-size: 11px; font-weight: 600;
  margin: 2px 2px 0 0; line-height: 1.5; vertical-align: middle; white-space: nowrap;
  cursor: default; text-transform: uppercase;
}

/* Équipement usage limité → fond ambre */
.tag-limited-use {
  display: inline-block;
  font-family: var(--fm);
  background: var(--gold2); color: #1a0a08; border: none;
  border-radius: 0; padding: 3px 8px; font-size: 11px; font-weight: 600;
  margin: 2px 2px 0 0; line-height: 1.5; vertical-align: middle; white-space: nowrap;
  cursor: default; text-transform: uppercase;
}

/* Kills → VERT plein */
.tag-kill {
  display: inline-block;
  font-family: var(--fm);
  background: var(--tag-green-solid); color: #a0cc80; border: none;
  border-radius: 0; padding: 3px 8px; font-size: 11px; font-weight: 600;
  margin: 2px 2px 0 0; line-height: 1.5; vertical-align: middle; white-space: nowrap;
  cursor: default;
}

/* Sorts → VIOLET outline, sans fond — cliquables */
.tag-sort {
  display: inline-block;
  font-family: var(--fm);
  background: transparent; color: var(--purple2); border: 2px solid var(--purple2);
  border-radius: 0; padding: 2px 6px; font-size: 11px; font-weight: 600;
  margin: 2px 2px 0 0; line-height: 1.5; vertical-align: middle; white-space: nowrap;
  cursor: pointer;
  text-transform: uppercase;
  transition: filter .15s;
}
.tag-sort:hover { filter: brightness(1.25); }

/* Tag type sorcier — violet plein (indicateur passif prioritaire) */
.tag-sort-outline {
  display: inline-block;
  font-family: var(--fm);
  background: var(--purple2);
  color: var(--bg);
  border: none;
  border-radius: 0;
  padding: 3px 8px;
  font-size: 11px;
  font-weight: 600;
  margin: 2px 2px 0 0;
  line-height: 1.5;
  vertical-align: middle;
  white-space: nowrap;
  cursor: default;
  text-transform: uppercase;
  letter-spacing: .04em;
}

/* Aliases de rétrocompatibilité */
.sk-tag  { display:inline-block; font-family:var(--fm); background:var(--bg2); color:var(--text); border:1px solid var(--text); border-radius:0; padding:3px 8px; font-size:11px; font-weight:600; margin:2px 2px 0 0; cursor:pointer; text-transform:uppercase; transition:filter .15s; }
.sk-tag:hover { filter:brightness(1.25); }
.inj-tag { display:inline-block; font-family:var(--fm); background:transparent; color:var(--text); border:1px solid var(--red); border-radius:0; padding:3px 8px; font-size:11px; font-weight:600; margin:2px 2px 0 0; cursor:default; text-transform:uppercase; }
.eq-tag  { display:inline-block; font-family:var(--fm); background:var(--tag-grey-solid);   color:var(--text2); border:none; border-radius:0; padding:3px 8px; font-size:11px; font-weight:600; margin:2px 2px 0 0; cursor:default; }
.res-tag { display:inline-flex; align-items:center; gap:6px; background:var(--border2); color:var(--text2); border:none; border-radius:0; padding:0 8px; font-family:var(--fm); font-size:11px; font-weight:600; height:25px; line-height:25px; box-sizing:border-box; text-transform:uppercase; white-space:nowrap; margin:2px 2px 0 0; vertical-align:middle; }
.res-tag-rm { cursor:pointer; color:var(--text2); font-size:14px; line-height:1; }

/* ── Normalisation badges & tags : hauteur 25px + uppercase ───
   Règle centralisée appliquée après toutes les définitions
   individuelles pour garantir cohérence sur tous les écrans.
   box-sizing:border-box inclut les bordures dans les 25px.      */
.badge,
.tag-guerrier, .tag-competence, .tag-sort, .tag-sort-outline,
.tag-equip, .tag-limited-use, .tag-kill, .tag-blessure,
.sk-tag, .inj-tag, .eq-tag, .prog-b {
  height: 25px;
  line-height: 25px;
  padding-top: 0;
  padding-bottom: 0;
  box-sizing: border-box;
  text-transform: uppercase;
}

/* --- Buttons --- */
.btn {
  width: 100%; padding: 12px;
  border: 1px solid var(--border2); border-radius: 0;
  background: var(--bg3); color: var(--text);
  font-size: 18px; font-weight: 600; cursor: pointer; margin-top: 8px;
  font-family: var(--fb);
}
.btn:active { opacity: .8; }
.btn.primary { background: var(--text); color: var(--bg); border-color: var(--text2); font-family: var(--ft); font-size: 24px; outline: 2px solid var(--bg); outline-offset: -5px; }
.btn.danger  { background: var(--red-bg); color: var(--red2); border-color: var(--red); }
.btn:disabled { opacity: .3; cursor: default; }

/* Séparateur diamant — élément DOM dédié .sep-diamond
   Layout : 44px total, ligne + diamant centrés, aucun conflit de positionnement */
.sep-diamond {
  position: relative;
  height: 44px;
}
.sep-diamond::before {
  content: '';
  position: absolute;
  top: 50%; left: 0; right: 0;
  height: 2px;
  background: var(--text);
  transform: translateY(-50%);
}
.sep-diamond::after {
  content: '◆';
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, calc(-50% - 1px));
  color: var(--text);
  font-size: 20px;
  line-height: 1;
  font-family: var(--fm);
}
/* Supprime le margin-top du bouton qui suit directement un .sep-diamond */
.sep-diamond + .btn { margin-top: 0; }

/* Séparateur avec badge texte centré */
.sep-badge {
  display: flex;
  align-items: center;
  margin: 22px 0 12px;
}
.sep-badge::before, .sep-badge::after {
  content: '';
  flex: 1;
  height: 2px;
  background: var(--text);
}
.sep-badge-lbl {
  font-family: var(--fm);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--text);
  background: var(--bg);
  padding: 3px 12px;
  margin: 0 8px;
}
.br { display: flex; gap: 8px; margin-top: 8px; }
.br .btn { margin-top: 0; }

.ab {
  padding: 8px 14px;
  border: 1px solid var(--border); border-radius: 20px;
  background: var(--bg3); color: var(--text);
  font-size: 13px; cursor: pointer;
  font-family: var(--fm); font-weight: 600;
  text-transform: uppercase;
  transition: filter .15s, color .15s, background .15s, border-color .15s;
}
.ab:hover  { filter: brightness(1.5); color: var(--text); }
.ab:active { opacity: .7; }
/* HDC — rouge sombre au repos, vif au survol */
.ab.d { border: 1px solid var(--red); color: var(--red2); background: var(--red-bg); }
.ab.d:hover { background: var(--red2); border-color: var(--red2); color: var(--text); filter: none; }
/* Kill — vert sombre au repos, vif au survol */
.ab.w { border: 1px solid var(--green); color: var(--green2); background: var(--green-bg); }
.ab.w:hover { background: var(--green2); border-color: var(--green2); color: var(--bg); filter: none; }
.ab.s { border-color:var(--green); color:var(--green2); background:var(--green-bg); }
.ab.s:hover { filter: brightness(1.4); color: var(--text); }
.ab.g { border-color:var(--border2); color:var(--text); }
.ab.off { opacity: .25; pointer-events: none; }

/* Boutons circulaires action bataille */
.ab-circle {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: none;
  font-size: 22px; font-weight: 700; line-height: 1;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: filter .15s, background .15s;
  flex-shrink: 0;
}
.ab-circle:active { opacity: .7; }
.ab-circle.d  { background: var(--red);   color: var(--text); }
.ab-circle.d:hover  { filter: brightness(1.4); }
.ab-circle.w  { background: var(--tag-green-solid); color: var(--text); }
.ab-circle.w:hover  { background: var(--green2); color: var(--bg); filter: none; }
.ab-circle.sub { background: var(--bg4); color: var(--text2); border: 1px solid var(--border2); }
.ab-circle.sub:hover { filter: brightness(1.5); }
.ab-circle.off { opacity: .2; pointer-events: none; }

/* Colonne action bataille (label + boutons) */
.bact-col {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  min-width: 80px;
}
.bact-col-label {
  font-family: var(--fm); font-size: 11px; font-weight: 600;
  text-transform: uppercase; color: var(--text2); letter-spacing: 0.08em;
}
.bact-col-btns {
  display: flex; gap: 6px; align-items: center;
}
.bact-col-count {
  font-family: var(--fm); font-size: 18px; font-weight: 700;
  color: var(--text); min-width: 18px; text-align: center;
}


.badge-ft-recruit {
  display: inline-block;
  padding: 6px 12px;
  border: 2px solid var(--green2);
  border-radius: 0;
  background: transparent;
  color: var(--green2);
  font-size: 12px;
  font-weight: 600;
  font-family: var(--fm);
  cursor: pointer;
  line-height: 1.4;
  text-transform: uppercase;
}
.badge-ft-recruit:active,
.badge-ft-recruit.recruited {
  background: var(--tag-green-solid);
  border-color: var(--tag-green-solid);
  color: var(--gold);
}
.badge-ft-recruit:active { opacity: .75; }

/* --- Inputs --- */
.inp {
  width: 100%;
  border: 2px solid var(--text3); border-radius: 0;
  padding: 10px 12px; font-size: 17px;
  background: transparent; color: var(--text);
  margin-top: 5px; font-family: var(--fb);
}
.inp:focus { outline: 3px solid var(--text2); outline-offset: -1px; }
select.inp {
  appearance: none; -webkit-appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23a89880' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 12px center; padding-right: 32px;
}
textarea.inp { resize: none; }

/* --- Boutons — 3 variants (P7) --- */
.btn {
  display: block;
  width: 100%;
  padding: 12px 16px;
  border: 2px solid var(--text);
  border-radius: 0;
  background: transparent;
  color: var(--text);
  font-family: var(--fs);
  font-size: 18px;
  cursor: pointer;
  text-align: center;
  margin-top: 8px;
  line-height: 1.3;
}
.btn:active { opacity: .75; }

/* Primary : UnifrakturCook, fond plein, outline intérieur */
.btn.primary {
  font-family: var(--ft);
  font-size: 24px;
  background: var(--text);
  color: var(--bg);
  border-color: var(--text);
  outline: 2px solid var(--bg);
  outline-offset: -6px;
}
.btn.primary:active { opacity: .85; }

/* Danger */
.btn.danger {
  font-family: var(--ft);
  font-size: 24px;
  background: var(--red2);
  color: var(--text);
  border-color: var(--red2);
  outline: 2px solid var(--text);
  outline-offset: -6px;
}
.btn.danger:active { opacity: .85; }

/* Outline secondaire — sans fond */
.btn.outline {
  background: transparent;
  color: var(--text);
  border-color: var(--text3);
}

/* Progression — vert saturé, UnifrakturCook, bordure intérieure noire */
.btn.prog {
  background: var(--bonus-color);
  color: #0a1a06;
  border-color: var(--bonus-color);
  font-family: var(--ft);
  font-size: 22px;
  outline: 2px solid #0a1a06;
  outline-offset: -6px;
  transition: background 0.15s ease, transform 0.15s ease;
}
.btn.prog:hover {
  background: #8fe055;
  transform: translateY(-2px);
}
.btn.prog:active {
  transform: translateY(0);
  opacity: .85;
}

/* Boutons inline côte à côte */
.br { display: flex; gap: 8px; margin-top: 8px; }
.br .btn { flex: 1; margin-top: 0; }

/* --- HUD accueil (home.js état B) --- */
.home-hud {
  background: var(--camp-hud-bg);
  color: var(--camp-hud-txt);
  border: 2px solid var(--gold2);
  padding: 14px;
  margin-top: 12px;
}
.home-hud-name {
  font-family: var(--fs);
  font-size: 30px;
  font-weight: 600;
  color: var(--camp-hud-txt);
  text-align: center;
  margin-bottom: 4px;
}
.home-hud-type {
  font-family: var(--ft);
  font-size: 18px;
  color: var(--camp-hud-lbl);
  text-align: center;
  margin-bottom: 10px;
}
.home-hud-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 6px;
}
.home-hud-cell {
  text-align: center;
  background: rgba(0,0,0,.07);
  padding: 6px 4px;
}
.home-hud-lbl {
  font-family: var(--fm);
  font-size: 10px;
  color: var(--camp-hud-lbl);
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-bottom: 2px;
}
.home-hud-val {
  font-family: var(--fm);
  font-size: 17px;
  font-weight: 700;
  color: var(--camp-hud-txt);
}

/* --- Info / Alert boxes --- */
.ib { background:var(--bg3); border:1px solid var(--border2); border-radius:0; padding:10px 12px; margin-bottom:10px; font-size:16px; color:var(--text2); line-height:1.7; }
.wb { background:var(--amber-bg); color:var(--amber2); border:1px solid var(--amber); border-radius:0; padding:10px 12px; font-size:16px; margin-bottom:10px; line-height:1.6; }
.sb { background:var(--green-bg); color:var(--green2); border:1px solid var(--green); border-radius:0; padding:10px 12px; font-size:16px; margin-bottom:10px; }
.db { background:var(--blue-bg);  border:1px solid var(--blue);  border-radius:0; padding:14px; margin-bottom:10px; }
.dt { font-family:var(--ft); font-size:18px; color:var(--text); margin-bottom:6px; text-transform: none; }
.dx { font-size:16px; color:var(--text); line-height:1.7; }
.ALERT { background:var(--red-bg); border:3px solid var(--red2); border-radius:0; padding:12px; margin-bottom:10px; text-align:center; color:var(--red2); font-weight:700; font-size:17px; }
.lock-b { background:var(--amber-bg); border:1px solid var(--amber); border-radius:0; padding:10px 12px; margin-bottom:10px; font-size:16px; color:var(--amber2); text-align:center; font-weight:600; }

/* --- Step dots --- */
.dots { display:flex; gap:5px; justify-content:center; margin-bottom:10px; }
.dot  { width:7px; height:7px; border-radius:0; background:var(--border2); }
.dot.on { background:var(--text); }
.sl { font-family:var(--ft); font-size:15px; color:var(--text2); text-align:center; margin-bottom:12px; letter-spacing:.03em; text-transform: none; }

/* --- Builder steps bar --- */
.sb2 { display:flex; gap:4px; margin-bottom:12px; }
.sp  { flex:1; height:5px; border-radius:0; background:var(--border); }
.sp.done   { background:var(--text); }
.sp.active { background:var(--parchment); }

/* Tags Obligatoire en capitales */
.bwarn { background: var(--tag-red-solid); color: #1a0a08; border: none; text-transform: uppercase; font-size: 11px; }
.bsuc  { background: var(--tag-green-solid); color: var(--green2); border: none; text-transform: uppercase; font-size: 11px; }

/* --- Bordures cards recrutement : double pour héros, simple pour HdM --- */
.rc { background: var(--bg2); border: 2px solid var(--text); border-radius: 0; padding: 12px 14px; margin-bottom: 9px; position: relative; }

/* Spec 2b — Coins vieillis cards (version réduite) */
.rc::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background:
    radial-gradient(
      ellipse 80px 50px at 0% 0%,
      rgba(194, 86, 63, 0.05),
      transparent 70%
    );
  mix-blend-mode: overlay;
}
.rc.rc-hero {
  border: 2px solid var(--text);
  outline: 2px solid var(--text);
  outline-offset: -8px;
}

/* Trait pointillé japonais entre caracs et tags compétence — pleine largeur */
.card-sep-dot { border: none; border-top: 1px dashed var(--text3); margin: 8px -14px 6px; opacity: 1; }

/* Min/Max recrutement +3px */
.qr-minmax { font-size: 14px; color: var(--text2); margin-left: auto; }
.qr { display:flex; align-items:center; gap:10px; margin-top:8px; }
.qb { width:38px; height:38px; border:2px solid var(--text3); border-radius:0; background:transparent; font-size:22px; cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--text); }
.qb:disabled { opacity:.2; }
.qv { font-family:var(--fm); font-size:21px; font-weight:700; min-width:28px; text-align:center; color:var(--text); }

/* --- Equip tags in builder --- */
.etag  { display:inline-flex; align-items:center; gap:6px; background:var(--tag-grey-solid); border:none; border-radius:0; padding:0 8px; font-family:var(--fm); font-size:11px; font-weight:600; color:var(--text2); text-transform:uppercase; height:25px; line-height:25px; box-sizing:border-box; white-space:nowrap; margin:2px 2px 0 0; }
.etrm  { cursor:pointer; color:var(--text2); font-size:14px; line-height:1; }

/* --- PM table --- */
.pm-tbl { width:100%; border-collapse:collapse; font-family:var(--fm); font-size:14px; margin-top:6px; }
.pm-tbl th { background:var(--bg3); padding:5px 3px; text-align:center; font-weight:600; font-size:13px; color:var(--text2); }
.pm-tbl td { padding:5px 3px; text-align:center; border-top:3px solid var(--border); color:var(--text2); }
.pm-tbl tr.hl td { font-weight:700; color:var(--text); background:var(--bg3); }

/* --- Recap / screenshot screen --- */
.rfs { border-radius:0; padding:18px; margin-bottom:10px; text-align:center; }
.rfs.win  { background:linear-gradient(135deg,#0e2e0e,#1a4a1a); border:3px solid var(--green2); }
.rfs.loss { background:linear-gradient(135deg,#2e0e0e,#4a1a1a); border:3px solid var(--red2); }
.rfs.draw { background:linear-gradient(135deg,#2e220e,#4a3a1a); border:3px solid var(--amber2); }
.re { font-size:48px; margin-bottom:6px; }
.rb { font-family:var(--ft); font-size:22px; color:var(--text); margin-bottom:3px; text-transform: none; }
.rv { font-size:16px; color:var(--text2); margin-bottom:10px; }

.mirror { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:10px; }
.mirror-side  { background:rgba(0,0,0,.35); border-radius:0; padding:10px; text-align:center; }
.mirror-label { font-size:13px; color:var(--text2); margin-bottom:4px; }
.mirror-name  { font-size:16px; font-weight:700; color:var(--text); margin-bottom:6px; }
.mirror-val   { font-size:15px; color:var(--text2); margin-bottom:6px; }
.mirror-hdc   { font-family:var(--fm); font-size:27px; font-weight:700; }
.hdc-bad  { color:var(--red2); }
.hdc-good { color:var(--green2); }

/* --- Combat reference tables --- */
.ref-section-title { font-family:var(--ft); font-size:15px; color:var(--text2); margin-bottom:5px; margin-top:10px; text-transform: none; }
.ref-t { width:100%; border-collapse:collapse; font-family:var(--fm); font-size:14px; margin-bottom:8px; }
.ref-t th { background:var(--bg3); color:var(--text2); padding:4px 3px; text-align:center; font-size:13px; border:1px solid var(--border); }
.ref-t td { padding:4px 3px; text-align:center; border:1px solid var(--border); color:var(--text); }
.ref-t tr:nth-child(even) td { background:var(--bg3); }

/* --- Shop row (campagne) --- */
.shop-row { display:flex; justify-content:space-between; align-items:center; padding:8px 0; border-bottom:3px solid var(--border); }
.shop-row:last-child { border-bottom:none; }

/* --- Progression result box --- */
.prog-rb { background:var(--bg3); border:1px solid var(--border2); border-radius:0; padding:14px; margin-top:10px; }
.prgt { font-family:var(--ft); font-size:17px; color:var(--text); margin-bottom:8px; text-transform: none; }

/* --- Modal / Overlay --- */
.ov { display:none; position:fixed; top:0; left:0; right:0; bottom:0; background:rgba(0,0,0,.8); z-index:200; align-items:flex-end; justify-content:center; padding:0; }
.ov.show { display:flex; }
.modal { background:var(--bg2); border:1px solid var(--border2); border-radius:0; padding:20px; width:100%; max-width:480px; max-height:88vh; overflow-y:auto; position: relative; }

/* Spec 2a — Coins vieillis modales (version pleine) */
.modal::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background:
    radial-gradient(
      ellipse 160px 100px at 0% 0%,
      rgba(194, 86, 63, 0.10),
      transparent 70%
    ),
    radial-gradient(
      ellipse 140px 90px at 100% 100%,
      rgba(194, 86, 63, 0.08),
      transparent 70%
    ),
    radial-gradient(
      ellipse 120px 80px at 100% 0%,
      rgba(154, 143, 125, 0.09),
      transparent 70%
    ),
    radial-gradient(
      ellipse 130px 85px at 0% 100%,
      rgba(154, 143, 125, 0.07),
      transparent 70%
    );
  mix-blend-mode: overlay;
}
.modal-t { font-family:var(--ft); font-size:21px; color:var(--text); margin-bottom:12px; text-transform: none; }
.mcl { float:right; background:none; border:none; color:var(--text2); font-size:24px; cursor:pointer; margin-top:-4px; line-height:1; }

/* --- Modals dynamiques (modalAlert / modalConfirm / modalPrompt) --- */
.modal-msg    { position:relative; z-index:2; font-size:14px; line-height:1.6; color:var(--text); margin-bottom:14px; white-space:pre-line; }
.modal-input  { position:relative; z-index:2; width:100%; box-sizing:border-box; background:var(--bg); color:var(--text); font-family:var(--fm); font-size:16px; border:2px solid var(--border2); border-radius:0; padding:9px 10px; min-height:44px; margin-bottom:16px; }
.modal-input:focus { border-color:var(--text); outline:none; }
.modal-actions { position:relative; z-index:2; display:flex; gap:10px; justify-content:flex-end; }

/* --- Panier campagne --- */
.panier-vente        { color: var(--bonus-color);  font-weight: 700; font-family: var(--fm); }
.panier-achat        { color: var(--malus-color);  font-weight: 700; font-family: var(--fm); }
.panier-total-credit { font-family:var(--fm); color: var(--bonus-color); font-weight: 700; font-size: 18px; }
.panier-total-debit  { font-family:var(--fm); color: var(--malus-color); font-weight: 700; font-size: 18px; }

/* Tableau panier FLUX/MONTANT/ACTION */
.panier-tbl { width:100%; border-collapse:collapse; font-family:var(--fm); font-size:13px; }
.panier-tbl thead th {
  color: var(--text2);
  font-size: 10px;
  letter-spacing: .12em;
  text-transform: uppercase;
  text-align: left;
  padding: 0 6px 6px;
  border-bottom: 1px solid var(--border2);
}
.panier-tbl td { padding: 7px 6px; border-bottom: 1px dotted var(--border); vertical-align: middle; }
.panier-tbl tfoot td { border-bottom: none; border-top: 2px solid var(--text); padding-top: 9px; font-weight: 700; }
.col-montant { text-align: right; width: 90px; }
.col-action  { text-align: center; width: 36px; }
.panier-rm {
  font-family: var(--fm);
  font-size: 15px;
  font-weight: 700;
  width: 28px; height: 28px;
  border: 1px solid var(--red2);
  background: var(--red-bg);
  color: var(--red2);
  cursor: pointer;
  border-radius: 0;
  line-height: 1;
  padding: 0;
}
.panier-rm:active { opacity: 0.7; }

/* Badge Promu HDM — fond app, outline + texte orange héros majeur */
.badge-promu-hdm {
  background: var(--bg);
  color: var(--orange);
  border: 1px solid var(--orange);
}

/* Citations écrans vides — EB Garamond italique, grands guillemets */
.citation-block { text-align:center; margin:28px 0 20px; padding:0 20px; }
.cit-guillemet  { font-family:'EB Garamond',Georgia,serif; font-size:52px; color:var(--text3); line-height:0.65; display:block; }
.cit-txt        { font-family:'EB Garamond',Georgia,serif; font-style:italic; font-size:18px; color:var(--text2); line-height:1.65; display:block; margin:6px 0; }

/* --- Builder : sélection race / bande --- */
.wb-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-bottom: 12px;
}
.wb-btn {
  position: relative;
  padding: 12px 8px 10px;
  border: 1px solid var(--border2);
  border-radius: 0;
  background: var(--bg3);
  color: var(--text);
  font-size: 16px;
  font-family: var(--fb);
  cursor: pointer;
  text-align: center;
  line-height: 1.3;
  transition: background .15s, border-color .15s;
  height: 100%;
  box-sizing: border-box;
}
.wb-btn:active { opacity: .75; }
.wb-btn.selected {
  background: var(--text);
  color: var(--bg);
  border-color: var(--text2);
  font-weight: 600;
}
.wb-btn-badge {
  display: inline-block;
  font-family: var(--fm);
  font-size: 11px;
  font-weight: 600;
  padding: 1px 5px;
  border-radius: 0;
  margin-top: 5px;
  background: var(--bg4);
  color: var(--text2);
  border: 1px solid var(--border);
  letter-spacing: .02em;
}
.wb-btn.selected .wb-btn-badge {
  background: rgba(0,0,0,.2);
  color: var(--bg);
  border-color: rgba(0,0,0,.15);
}

/* --- Bannière déroute sticky --- */
#deroute-banner {
  position: fixed;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 480px;
  background: var(--red-bg);
  color: var(--text);
  font-weight: 700;
  font-size: 16px;
  text-align: center;
  padding: 9px 12px;
  z-index: 150;
  letter-spacing: .02em;
}

body.deroute-active #app { padding-top: 50px; }

/* =====================================================
   HUD CAMPAGNE STICKY — fond crème / parchemin
   VDB, Effectif, Frags, Magot
   ===================================================== */
#camp-hud-sticky {
  position: sticky;
  top: 0;
  z-index: 90;
  background: var(--bg);
  padding: 8px 0 4px;
  margin-bottom: 2px;
}
#camp-hud-sticky .mg {
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 6px;
  margin-bottom: 0;
}
/* Cartes métriques : fond crème, texte foncé */
#camp-hud-sticky .mc {
  padding: 7px 8px;
  background: var(--camp-hud-bg);
  border: 1px solid #c8b898;
}
#camp-hud-sticky .ml {
  color: var(--camp-hud-lbl);
  font-size: 12px;
}
#camp-hud-sticky .mv {
  font-family: var(--fm);
  font-size: 18px;
  color: var(--camp-hud-txt);
}

/* ===== BURGER MENU — CONV-2 ===== */

/*
 * Animation robuste : visibility + opacity + transform
 * (display:none bloque les transitions CSS sur mobile)
 * État fermé : invisible + non interactif
 * État ouvert (.burger-open) : visible + interactif, transition 120ms
 */

#burger-btn {
  position: fixed;
  top: 12px;
  right: 12px;
  z-index: 160;
  width: 36px;
  height: 36px;
  background: var(--bg2);
  color: var(--text);
  border: 2px solid var(--text);
  border-radius: 0;
  font-family: var(--fs);
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
}
#burger-btn:active { opacity: .75; }

/* Overlay transparent — intercepte les clics hors menu */
#burger-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 155;
  background: transparent;
}

/* Panneau menu — invisible par défaut (visibility + opacity) */
#burger-menu {
  position: fixed;
  top: 52px;
  right: 12px;
  z-index: 160;
  min-width: 220px;
  background: var(--bg2);
  border: 2px solid var(--text);
  border-radius: 0;
  /* Animation robuste : pas de display toggle, transition sur visibility+opacity */
  visibility: hidden;
  opacity: 0;
  transform: translateY(-6px);
  pointer-events: none;
  transition: opacity 120ms ease, transform 120ms ease, visibility 0ms 120ms;
}
/* État ouvert : délai 0ms sur visibility pour qu'elle s'applique immédiatement */
#burger-menu.burger-open {
  visibility: visible;
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
  transition: opacity 120ms ease, transform 120ms ease, visibility 0ms 0ms;
}

.burger-item {
  display: block;
  width: 100%;
  padding: 10px 16px;
  background: transparent;
  border: none;
  border-radius: 0;
  font-family: var(--fs);
  font-size: 16px;
  color: var(--text);
  text-align: left;
  cursor: pointer;
  line-height: 1.4;
}
.burger-item:hover:not(:disabled) {
  background: var(--text);
  color: var(--bg);
}
.burger-item:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.burger-sep {
  border: none;
  border-top: 1px solid var(--text3);
  margin: 2px 0;
}

/* ===== TABLES DE RÉFÉRENCE — CONV-3 ===== */

/* Bouton fermeture : min 40×40px, positionné dans le flux (float:right remplacé) */
.ref-close {
  float: right;
  width: 40px;
  height: 40px;
  background: transparent;
  border: none;
  color: var(--text);
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: -4px -6px 0 0;
}
.ref-close:active { opacity: .7; }

/* Navigation onglets — JetBrains Mono CAPITALES */
.tabs {
  display: flex;
  gap: 0;
  margin-bottom: 12px;
  border-bottom: 2px solid var(--border2);
}
.tab {
  flex: 1;
  padding: 8px 4px;
  background: transparent;
  border: none;
  border-radius: 0;
  font-family: var(--fm);
  font-size: 12px;
  font-weight: 600;
  color: var(--text2);
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: .04em;
  text-align: center;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
}
.tab.active {
  background: var(--text);
  color: var(--bg);
  border-bottom-color: var(--text);
}
.tab:not(.active):hover { color: var(--text); }

/* Panneaux — un seul visible à la fois */
.tab-panel { display: none; }
.tab-panel.active { display: block; }

/* Description courte au-dessus de chaque table */
.ref-desc {
  font-family: var(--fm);
  font-size: 12px;
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-bottom: 6px;
  margin-top: 4px;
}

/* Cellule d'en-tête de ligne (première colonne) */
.ref-t .ref-th {
  color: var(--text2);
  font-weight: 600;
  background: var(--bg3);
  text-align: center;
}

/* Modificateurs de tir : liste de rows flex */
.ref-mods { padding: 8px 14px; }
.ref-mod-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 5px 0;
  border-bottom: 1px solid var(--border);
  font-family: var(--fs);
  font-size: 15px;
  color: var(--text);
}
.ref-mod-row:last-child { border-bottom: none; }
.ref-mod-label { color: var(--text); }
.ref-mod-val {
  font-family: var(--fm);
  font-size: 14px;
  font-weight: 700;
  color: var(--red2);
  min-width: 28px;
  text-align: right;
}

/* Grille dégâts — 3 cellules côte à côte */
.ref-deg-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0;
  padding: 10px 10px 8px;
}
.ref-deg-cell {
  text-align: center;
  padding: 6px 4px;
}
.ref-deg-cell:not(:last-child) {
  border-right: 1px solid var(--border2);
}
.ref-deg-roll {
  font-family: var(--fm);
  font-size: 20px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 4px;
}
.ref-deg-name {
  font-family: var(--fs);
  font-size: 14px;
  color: var(--text2);
  line-height: 1.3;
}

/* --- Ajustements tailles mobile --- */
@media (max-width: 380px) {
  body { font-size: 17px; }
  .btn { font-size: 17px; padding: 11px; }
  .ab  { font-size: 15px; padding: 7px 10px; }
  .tag-guerrier, .tag-competence, .tag-blessure,
  .tag-equip, .tag-kill, .tag-sort,
  .sk-tag, .inj-tag, .eq-tag { font-size: 13px; }
  .wn { font-size: 21px !important; }
  .pt { font-size: 22px; }
  .pt.pt-type { font-size: 28px; }
  .pt-bandname { font-size: 25px; }
  .hud-band { font-size: 24px; }
  .nav-btn  { font-size: 12px; }
  .nav-icon { font-size: 18px; }
  .stbl     { font-size: 14px; }
  .modal-t  { font-size: 19px; }
}

/* ============================================================
   CONV-4a — Camp : onglet BANDE (roster + réserve)
   ============================================================ */

/* Tag Vieille Blessure (ambre outline, CAPITALES) */
.camp-tag-vb {
  border-color: var(--gold2);
  color: var(--gold2);
  background: transparent;
}

/* Ligne d'un item d'équipement inline sur carte guerrier */
.camp-equip-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 3px 0;
  border-bottom: 1px dotted var(--border);
  font-size: 13px;
}
.camp-equip-row:last-child { border-bottom: none; }

/* Ligne d'un item de la section Réserve */
.camp-reserve-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 5px 0;
  border-bottom: 1px dotted var(--border);
  font-size: 13px;
}
.camp-reserve-row:last-child { border-bottom: none; }

/* Bouton inline sur carte (outline compact) */
.camp-btn-inline {
  font-family: var(--fm);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  padding: 4px 8px;
  min-height: 28px;
  white-space: nowrap;
}

/* Panneau d'affectation inline (sélecteur guerrier cible) */
.camp-affect-panel {
  background: var(--bg2);
  border: 2px solid var(--text);
  padding: 10px 12px;
  margin-bottom: 8px;
}

/* Séparateur de section Réserve */
.camp-tabs { margin-top: 10px; }

/* ======================================================
   CAMP — onglets RECRUTER + MARCHÉS (CONV-4b)
   ====================================================== */

/* Titre de section dans les onglets camp */
.camp-sec-title {
  font-family: var(--fm);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--text2);
  margin: 0 0 6px;
}

/* Sous-titre de section (ex: "Malepierre") */
.camp-sub-title {
  font-family: var(--fm);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--text);
}

/* Sélecteur standardisé dans les onglets camp */
.camp-select {
  width: 100%;
  font-family: var(--fm);
  font-size: 13px;
  background: var(--bg);
  color: var(--text);
  border: 2px solid var(--border2);
  border-radius: 0;
  padding: 8px 10px;
  margin-bottom: 8px;
  appearance: none;
  -webkit-appearance: none;
}
.camp-select:focus { border-color: var(--text); outline: none; }

/* Ligne bouton d'action (ferré droite) */
.camp-recruit-row {
  display: flex;
  justify-content: flex-end;
  margin-top: 6px;
}

/* Input numérique compact (jets de dés, prix) */
.camp-roll-input {
  font-family: var(--fm);
  font-size: 18px;
  font-weight: 700;
  text-align: center;
  width: 90px;
  min-height: 44px;
  background: var(--bg);
  color: var(--text);
  border: 2px solid var(--border2);
  border-radius: 0;
  padding: 4px 8px;
}
.camp-roll-input:focus { border-color: var(--text); outline: none; }

/* Résultat inline d'un jet (vert/rouge) */
.camp-roll-result {
  font-family: var(--fm);
  font-size: 15px;
  font-weight: 700;
  margin-left: 8px;
  align-self: center;
}

/* Ligne d'un jet de rareté */
.camp-rare-roll-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 0;
  border-bottom: 1px dotted var(--border);
  flex-wrap: wrap;
}
.camp-rare-roll-row:last-child { border-bottom: none; }

/* Conteneur des jets de rareté */
.camp-rare-rolls { margin-bottom: 10px; }

/* Preview achat (coût total calculé dynamiquement) */
.camp-buy-preview {
  font-family: var(--fm);
  font-size: 12px;
  color: var(--text2);
  min-height: 18px;
  margin: 4px 0 6px;
}

/* Stock XP vétéran */
.camp-vet-stock {
  padding: 6px 0;
  border-bottom: 1px dotted var(--border);
  margin-bottom: 10px;
}

/* Preview coût/XP vétéran */
.camp-vet-preview {
  font-family: var(--fm);
  font-size: 12px;
  min-height: 18px;
  margin: 4px 0 6px;
  color: var(--text2);
}

/* Alerte vétéran équipement (fond ambre discret) */
.camp-vet-alert {
  border-color: var(--gold2) !important;
}

/* Bouton inline de type danger (revente) */
.camp-btn-danger {
  color: var(--red2);
  border-color: var(--red2);
}
.camp-btn-danger:hover { background: var(--red2); color: var(--bg); }

/* ==========================================================
   APB — Classes spécifiques à la séquence Après-Bataille
   CONV-5a : étapes 0–2
   ========================================================== */

/* --- Pastilles de progression APB (9 étapes) --- */
.apb-progress {
  display: flex;
  gap: 6px;
  justify-content: center;
  align-items: center;
  margin-bottom: 14px;
  padding: 0 4px;
}
.apb-dot {
  width: 10px;
  height: 10px;
  border-radius: 0;
  flex-shrink: 0;
}
.apb-dot-past   { background: var(--text); }
.apb-dot-future { background: transparent; border: 2px solid var(--border2); }
.apb-dot-active {
  background: transparent;
  border: 2px solid var(--text);
  animation: apb-pulse 1.4s ease-in-out infinite;
}
@keyframes apb-pulse {
  0%, 100% { border-color: var(--text); }
  50%       { border-color: var(--text2); }
}

/* --- En-tête d'étape --- */
.apb-step-header {
  margin-bottom: 16px;
  text-align: center;
}
.apb-step-counter {
  font-family: var(--fm);
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--text2);
  margin-bottom: 4px;
}
.apb-step-name {
  font-family: var(--ft);
  font-size: 28px;
  color: var(--text);
  line-height: 1.1;
}
.apb-step-sub {
  font-family: 'EB Garamond', Georgia, serif;
  font-style: italic;
  font-size: 15px;
  color: var(--text2);
  margin-bottom: 12px;
  line-height: 1.5;
}

/* Numéro de bataille dans le titre */
.apb-num {
  font-family: var(--fm);
  font-size: 18px;
  color: var(--text2);
  vertical-align: middle;
}

/* --- Séparateur de section (titre Mono CAPITALES) --- */
.apb-section-title {
  font-family: var(--fm);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text2);
  margin: 16px 0 8px;
  border-top: 1px solid var(--border2);
  padding-top: 10px;
}

/* --- Étape 0 — Résultat --- */
.apb-result-choices {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 4px;
}
.apb-result-btn {
  font-family: var(--fm);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 12px 16px;
  border: 2px solid;
  border-radius: 0;
  cursor: pointer;
  text-align: left;
  transition: opacity .15s;
}
.apb-result-btn:active { opacity: .75; }

.apb-result-label {
  font-family: var(--ft);
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 8px;
}

.apb-stats-row {
  display: flex;
  gap: 16px;
  align-items: baseline;
}
.apb-stat-lbl {
  font-family: var(--fm);
  font-size: 10px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--text2);
}
.apb-stat-val {
  font-family: var(--fm);
  font-size: 20px;
  font-weight: 700;
  color: var(--text);
  margin-right: 12px;
}

/* --- Inputs de dés --- */
.apb-die-input {
  width: 72px !important;
  height: 48px !important;
  font-size: 22px !important;
  font-family: var(--fm) !important;
  font-weight: 700 !important;
  text-align: center;
  margin-top: 0 !important;
}

/* --- Ligne d'un jet de dé (label + input + badge) --- */
.apb-roll-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.apb-roll-lbl {
  font-family: var(--fm);
  font-size: 11px;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--text2);
}

/* Badge résultat inline (mort / survie / etc.) */
.apb-result-badge {
  font-family: var(--fm);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 4px 10px;
  border: 2px solid;
  border-radius: 0;
}

/* --- D66 : deux inputs côte à côte avec séparateur --- */
.apb-d66-block {
  display: flex;
  align-items: flex-end;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 4px;
}
.apb-d66-group {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.apb-d66-sep {
  font-family: var(--fm);
  font-size: 20px;
  font-weight: 700;
  color: var(--text3);
  padding-bottom: 6px;
  align-self: flex-end;
}

/* --- Cards résultat D66 --- */
.apb-inj-card { margin-top: 10px; }
.apb-inj-code {
  font-family: var(--fm);
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.apb-inj-title {
  font-family: var(--fm);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.apb-inj-desc {
  font-family: 'EB Garamond', Georgia, serif;
  font-size: 15px;
  color: var(--text2);
  line-height: 1.5;
}

/* --- Titres options capture --- */
.apb-capture-opt-title {
  font-family: var(--fm);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: var(--text);
  margin-bottom: 4px;
}

/* ==========================================================
   APB — Classes spécifiques CONV-5b : étapes 3–8
   ========================================================== */

/* --- XP : badges récapitulatif --- */
.apb-xp-badge {
  font-family: var(--fm);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 4px 10px;
  border: 2px solid;
  border-radius: 0;
}
.apb-xp-bad  { color: var(--red2);   border-color: var(--red);   }
.apb-xp-good { color: var(--green2); border-color: var(--green); }

/* --- XP : total gain (valeur principale) --- */
.apb-xp-total {
  font-family: var(--fm);
  font-size: 15px;
  font-weight: 700;
  color: var(--green2);
}

/* --- XP : détail de calcul --- */
.apb-xp-detail {
  font-family: 'EB Garamond', Georgia, serif;
  font-size: 13px;
  color: var(--text2);
  margin-top: 4px;
  line-height: 1.5;
}

/* --- XP : valeur manuelle stepper --- */
.apb-xp-adj {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 8px;
}
.apb-xp-manual {
  font-family: var(--fm);
  font-size: 15px;
  font-weight: 700;
  min-width: 28px;
  text-align: center;
  color: var(--text);
}

/* --- Badge "Promotion disponible" vert solid --- */
.apb-promo-badge {
  font-family: var(--fm);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 3px 10px;
  background: var(--green);
  color: var(--bg);
  border-radius: 0;
  white-space: nowrap;
}

/* --- Boutons découvertes exploration --- */
.apb-disc-btn {
  display: block;
  width: 100%;
  margin-top: 8px;
  padding: 11px 14px;
  font-family: var(--fm);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  text-align: left;
  background: var(--bg2);
  color: var(--text);
  border: 2px solid var(--border2);
  border-radius: 0;
  cursor: pointer;
  transition: opacity .15s;
}
.apb-disc-btn:active { opacity: .75; }
.apb-disc-done {
  background: var(--green-bg);
  border-color: var(--green);
  color: var(--green2);
}

/* --- Clôture : bloc récap principal --- */
.apb-recap-block {
  margin-bottom: 10px;
}

/* --- Clôture : miroir des deux bandes --- */
.apb-mirror-block {
  padding: 12px;
}
.apb-mirror-row {
  display: flex;
  gap: 0;
  align-items: stretch;
}
.apb-mirror-side {
  flex: 1;
  text-align: center;
  padding: 8px 6px;
}
.apb-mirror-divider {
  width: 2px;
  background: var(--border2);
  flex-shrink: 0;
}
.apb-mirror-name {
  font-family: var(--ft);
  font-size: 18px;
  color: var(--text);
  margin: 4px 0 6px;
  line-height: 1.1;
}
.apb-mirror-hdc {
  font-family: var(--fm);
  font-size: 28px;
  font-weight: 700;
  margin-top: 4px;
}
