/* ==============================================================
   FSF Matchs — frontend.css v2.1.0
   ============================================================== */
:root {
  --fsfm-vert:  #00843D;
  --fsfm-gd:    #005a2b;
  --fsfm-jaune: #FDEF00;
  --fsfm-rouge: #E2001A;
  --fsfm-rd:    #aa0013;
  --t:          .2s ease;
}
.fsfm-wrap { font-family: 'Lato', sans-serif; }

/* ── ONGLETS ──────────────────────────────────────────────── */
.fsfm-tabs {
  display: flex;
  border-bottom: 3px solid var(--fsfm-vert);
  margin-bottom: 20px;
}
.fsfm-tab {
  background: none; border: none;
  padding: 12px 28px;
  font-family: 'Oswald', sans-serif; font-size: 14px;
  letter-spacing: 1.5px; text-transform: uppercase;
  cursor: pointer; color: #777;
  border-bottom: 3px solid transparent; margin-bottom: -3px;
  transition: color var(--t), border-color var(--t);
}
.fsfm-tab:hover         { color: var(--fsfm-vert); }
.fsfm-tab.active        { color: var(--fsfm-vert); border-bottom-color: var(--fsfm-vert); font-weight: 700; }

/* Panels : masqués par défaut — double protection !important */
.fsfm-tab-panel        { display: none !important; }
.fsfm-tab-panel.active  { display: block !important; }

/* ── LIEN COMPÉTITION (pied de liste) ─────────────────────── */
.fsfm-comp-link { text-align: right; padding-top: 14px; margin-top: 8px; border-top: 1px solid #eee; }
.fsfm-comp-link-btn {
  display: inline-flex; align-items: center; gap: 4px;
  font-family: 'Oswald', sans-serif; font-size: 13px;
  letter-spacing: 1.2px; text-transform: uppercase;
  color: var(--fsfm-vert) !important; text-decoration: none;
  border-bottom: 2px solid transparent; padding-bottom: 2px;
  transition: border-color var(--t);
}
.fsfm-comp-link-btn:hover { border-bottom-color: var(--fsfm-vert); }

/* ── CARTE DE MATCH ───────────────────────────────────────── */
.fsfm-match-card {
  background: #fff; border: 1px solid #e8e8e8; margin-bottom: 12px;
  border-left: 4px solid var(--fsfm-comp-accent, var(--fsfm-vert));
  transition: box-shadow var(--t);
}
.fsfm-match-card:hover              { box-shadow: 0 6px 20px rgba(0,0,0,.08); }
.fsfm-match-card.fsfm-mc-live      { border-left-color: var(--fsfm-rouge); }
.fsfm-match-card.fsfm-mc-mi_temps  { border-left-color: var(--fsfm-rouge); }
.fsfm-match-card.fsfm-mc-programme { border-left-color: var(--fsfm-comp-accent, var(--fsfm-vert)); }
.fsfm-match-card.fsfm-mc-reporte   { border-left-color: #999; }
.fsfm-match-card.fsfm-mc-annule    { border-left-color: #ccc; opacity: .7; }

/* ── HEADER CARTE : compétition + date sur 2 lignes ─────────
   Gauche : .fsfm-mc-info (column flex)
     ligne 1 → .fsfm-mc-competition
     ligne 2 → .fsfm-mc-date
   Droite : .fsfm-mc-comp-link (lien, visible si lien_competition renseigné)
────────────────────────────────────────────────────────────── */
.fsfm-mc-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 9px 14px 9px 18px;
  background: #f8f8f8;
  border-bottom: 1px solid #eee;
  gap: 12px;
}

/* Bloc gauche — les deux lignes */
.fsfm-mc-info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;          /* allow text-overflow in children */
  flex: 1;
}

/* Ligne 1 : nom de la compétition */
.fsfm-mc-competition {
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 700;
  color: var(--fsfm-gd);
  text-transform: uppercase;
  letter-spacing: .8px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.3;
}
.fsfm-mc-journee {
  color: #888;
  font-style: normal;
  font-weight: 400;
}

/* Ligne 2 : date + heure */
.fsfm-mc-date {
  font-size: 11px;
  color: #777;
  letter-spacing: .4px;
  white-space: nowrap;
  line-height: 1.3;
}

/* Lien compétition — coin droit du header */
.fsfm-mc-comp-link {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  font-family: 'Oswald', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  color: var(--fsfm-vert) !important;
  text-decoration: none;
  border: 1.5px solid var(--fsfm-vert);
  padding: 3px 10px;
  white-space: nowrap;
  line-height: 1;
  transition: background var(--t), color var(--t);
}
.fsfm-mc-comp-link:hover {
  background: var(--fsfm-vert);
  color: #fff !important;
}

/* ── CORPS CARTE ──────────────────────────────────────────── */
/*
  CORPS DE CARTE — grid 1fr auto 1fr
  Chaque équipe prend exactement la moitié de l'espace disponible.
  Le bloc score/heure prend juste la place dont il a besoin (auto).
  Résultat : les noms d'équipes sont toujours collés vers le centre,
  aucun espace vide entre le nom et le score.
*/
.fsfm-mc-body {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding: 16px 18px;
  gap: 8px;
}

/* Équipe domicile — contenu poussé vers la droite (vers le score) */
.fsfm-mc-team {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
/* DOM : flag | name → pushés à droite (vers le score) */
.fsfm-mc-dom {
  justify-content: flex-end;
  text-align: right;
}
/* EXT : order row-reverse → [name | flag] ; flex-end en row-reverse = pousse à GAUCHE (vers le score)
   Résultat : name colle au score, flag est à droite de la cellule, gap à droite */
.fsfm-mc-ext {
  justify-content: flex-end;
  text-align: left;
  flex-direction: row-reverse;
}

.fsfm-mc-flag  { font-size: 28px; line-height: 1; flex-shrink: 0; }
.fsfm-mc-logo  { width: 40px; height: 40px; object-fit: contain; flex-shrink: 0; }
.fsfm-mc-team-name {
  font-family: 'Oswald', sans-serif; font-size: 16px; font-weight: 700;
  color: #111;
  /* Autoriser le retour à la ligne sur les noms longs */
  overflow-wrap: break-word; word-break: break-word;
  white-space: normal;
  line-height: 1.2;
}
/* Équipe vainqueure aux tirs au but */
.fsfm-mc-team-name.fsfm-mc-winner {
  color: var(--fsfm-comp-accent, var(--fsfm-vert));
  font-size: 18px;
}

/* Bloc central : score ou heure */
.fsfm-mc-score-block {
  text-align: center;
  padding: 0 14px;
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  flex-shrink: 0;
  min-width: 100px;
}
.fsfm-mc-score {
  display: flex; align-items: center; gap: 4px;
  font-family: 'Oswald', sans-serif; font-size: 32px; font-weight: 700;
}
.fsfm-mc-score .s-dom,
.fsfm-mc-score .s-ext { color: var(--fsfm-gd); }
.fsfm-mc-score .s-dom.s-winner,
.fsfm-mc-score .s-ext.s-winner {
  color: var(--fsfm-comp-accent, var(--fsfm-vert));
  font-size: 36px;
}
.fsfm-mc-score .s-sep { color: #ccc; }
.fsfm-mc-kickoff {
  font-family: 'Oswald', sans-serif; font-size: 20px; font-weight: 700;
  color: var(--fsfm-rd); white-space: nowrap;
}
.fsfm-mc-halftime { font-size: 11px; color: #888; margin-top: 2px; }

/* Prolongations (ap) */
.fsfm-mc-ap {
  font-size: 10px; font-style: italic; color: #888;
  letter-spacing: .5px; margin-top: 2px;
}

/* Tirs au but — [score_dom] [TAB] [score_ext] sans tiret */
.fsfm-mc-tab {
  display: flex; align-items: center; justify-content: center;
  gap: 5px; margin-top: 5px;
  background: #fff8e7; border: 1.5px solid #f59e0b;
  border-radius: 4px; padding: 4px 10px;
}
.fsfm-mc-ap-inline {
  font-size: 9px; font-style: italic; color: #888;
  letter-spacing: .3px; margin-right: 2px;
}
.fsfm-mc-tab-label {
  font-size: 9px; font-weight: 800; letter-spacing: 1.5px;
  text-transform: uppercase; color: #92400e;
  margin: 0 2px;
}
.fsfm-mc-tab-score {
  font-family: 'Oswald', sans-serif;
  font-size: 16px; font-weight: 700;
  color: #b45309;
}
.fsfm-mc-tab-score.tab-winner {
  font-size: 20px;
  color: var(--fsfm-comp-accent, var(--fsfm-vert));
}
.fsfm-mc-statut {
  font-family: 'Oswald', sans-serif; font-size: 10px; letter-spacing: 1.5px;
  text-transform: uppercase; padding: 3px 10px;
  background: #f0f0f0; color: #666; font-weight: 700;
  white-space: nowrap;
}
.fsfm-mc-statut.is-live { background: var(--fsfm-rouge); color: #fff; animation: fsfm-blink 1.2s infinite; }
@keyframes fsfm-blink { 0%,100%{ opacity:1 } 50%{ opacity:.55 } }

/* ── PIED CARTE ───────────────────────────────────────────── */
.fsfm-mc-footer {
  display: flex; justify-content: space-between; align-items: center;
  padding: 8px 18px; background: #fafafa; border-top: 1px solid #eee; font-size: 12px;
}
.fsfm-mc-venue { color: #888; }
.fsfm-mc-links { display: flex; gap: 8px; }
.fsfm-link-live   { background: var(--fsfm-rouge); color: #fff !important; padding: 3px 10px; font-family: 'Oswald', sans-serif; font-size: 10px; letter-spacing: 1px; text-decoration: none; }
.fsfm-link-ticket { background: var(--fsfm-vert);  color: #fff !important; padding: 3px 10px; font-family: 'Oswald', sans-serif; font-size: 10px; letter-spacing: 1px; text-decoration: none; }
.fsfm-link-report { background: #555;              color: #fff !important; padding: 3px 10px; font-family: 'Oswald', sans-serif; font-size: 10px; letter-spacing: 1px; text-decoration: none; }
.fsfm-link-live:hover, .fsfm-link-ticket:hover, .fsfm-link-report:hover { opacity: .85; }

/* ── CLASSEMENT ───────────────────────────────────────────── */
.fsfm-standings-block  { margin-bottom: 32px; }
.fsfm-standings-header { background: var(--fsfm-gd); padding: 12px 16px; }
.fsfm-standings-title  {
  font-family: 'Oswald', sans-serif; font-size: 15px; font-weight: 700;
  color: var(--fsfm-jaune); letter-spacing: 1px; text-transform: uppercase;
}
.fsfm-standings-table-front { width: 100%; border-collapse: collapse; font-size: 13px; }
.fsfm-standings-table-front thead th {
  background: var(--fsfm-gd); color: var(--fsfm-jaune);
  font-family: 'Oswald', sans-serif; font-size: 11px; letter-spacing: 1.5px;
  text-transform: uppercase; padding: 10px 12px; text-align: center; cursor: help;
}
.fsfm-standings-table-front .col-equipe { text-align: left; }
.fsfm-standings-table-front td { padding: 11px 12px; border-bottom: 1px solid #eee; text-align: center; }
.fsfm-standings-table-front tbody tr:hover td       { background: #f0f9f4; }
.fsfm-standings-table-front tr.leader td            { background: #fffce0; font-weight: 700; }
.fsfm-standings-table-front tr.qualification td     { background: #f0f9f4; }
.fsfm-standings-table-front .pos-num  { font-family: 'Oswald', sans-serif; font-size: 16px; font-weight: 700; color: var(--fsfm-gd); }
.fsfm-standings-table-front .col-equipe { min-width: 160px; }
.fsfm-standings-table-front .eq-flag { font-size: 20px; margin-right: 8px; }
.fsfm-standings-table-front .eq-name { font-weight: 600; }
.fsfm-standings-table-front .col-pts strong { font-family: 'Oswald', sans-serif; font-size: 17px; color: var(--fsfm-rouge); }
.fsfm-standings-table-front .db-pos { color: var(--fsfm-vert); font-weight: 700; }
.fsfm-standings-table-front .db-neg { color: var(--fsfm-rouge); }
.col-forme { min-width: 80px; }
.fb { display: inline-block; width: 16px; height: 16px; border-radius: 50%; font-size: 9px; font-weight: 700; line-height: 16px; text-align: center; margin: 0 1px; }
.fv { background: #00843D; color: #fff; }
.fn { background: #888;    color: #fff; }
.fd { background: #E2001A; color: #fff; }

/* ── PROCHAIN MATCH ───────────────────────────────────────── */
.fsfm-next-match     { background: linear-gradient(135deg, var(--fsfm-gd) 0%, #001a10 100%); padding: 28px; color: #fff; text-align: center; }
.fsfm-nm-competition { font-family: 'Oswald', sans-serif; font-size: 11px; letter-spacing: 3px; text-transform: uppercase; color: rgba(255,255,255,.6); margin-bottom: 18px; }
.fsfm-nm-competition span { color: rgba(255,255,255,.4); }
.fsfm-nm-teams  { display: flex; align-items: center; justify-content: center; gap: 24px; margin-bottom: 16px; }
.fsfm-nm-team   { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.fsfm-nm-flag   { font-size: 48px; }
.fsfm-nm-name   { font-family: 'Oswald', sans-serif; font-size: 18px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; }
.fsfm-nm-vs     { font-family: 'Oswald', sans-serif; font-size: 14px; font-weight: 700; color: rgba(255,255,255,.4); }
.fsfm-nm-meta   { display: flex; justify-content: center; gap: 20px; font-size: 12px; color: rgba(255,255,255,.6); margin-bottom: 20px; flex-wrap: wrap; }
.fsfm-countdown { display: flex; justify-content: center; align-items: center; gap: 4px; margin-bottom: 20px; }
.fsfm-cd-unit   { text-align: center; min-width: 64px; }
.fsfm-cd-val    { display: block; font-family: 'Oswald', sans-serif; font-size: 42px; font-weight: 700; color: var(--fsfm-jaune); line-height: 1; }
.fsfm-cd-label  { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: rgba(255,255,255,.5); }
.fsfm-cd-sep    { font-family: 'Oswald', sans-serif; font-size: 36px; font-weight: 700; color: rgba(255,255,255,.2); align-self: flex-start; margin-top: 4px; }
.fsfm-nm-ticket { display: inline-block; background: var(--fsfm-rouge); color: #fff !important; font-family: 'Oswald', sans-serif; font-size: 13px; letter-spacing: 2px; text-transform: uppercase; padding: 12px 28px; text-decoration: none; margin-top: 4px; transition: background var(--t); }
.fsfm-nm-ticket:hover { background: var(--fsfm-rd); }

.fsfm-no-content { color: #888; font-style: italic; padding: 20px; text-align: center; }

/* ── LAYOUT COLONNES (paramètre cols="1|2|3") ─────────────── */
.fsfm-match-list { display: grid; gap: 0; grid-template-columns: 1fr; }
.fsfm-match-list.fsfm-cols-1 { grid-template-columns: 1fr; }
.fsfm-match-list.fsfm-cols-2 { grid-template-columns: 1fr 1fr; gap: 12px; }
.fsfm-match-list.fsfm-cols-3 { grid-template-columns: 1fr 1fr 1fr; gap: 12px; }
.fsfm-match-list.fsfm-cols-2 .fsfm-match-card,
.fsfm-match-list.fsfm-cols-3 .fsfm-match-card { margin-bottom: 0; }
.fsfm-match-list.fsfm-cols-2 .fsfm-mc-team-name,
.fsfm-match-list.fsfm-cols-3 .fsfm-mc-team-name { font-size: 13px; }
.fsfm-match-list.fsfm-cols-3 .fsfm-mc-score   { font-size: 22px; }
.fsfm-match-list.fsfm-cols-3 .fsfm-mc-kickoff { font-size: 16px; }
.fsfm-match-list.fsfm-cols-3 .fsfm-mc-body    { padding: 12px 10px; }

/* ── RESPONSIVE ───────────────────────────────────────────── */

/* Tablette ≤ 900px : noms plus petits, score un peu réduit */
@media (max-width: 900px) {
  .fsfm-mc-team-name   { font-size: 14px; }
  .fsfm-mc-score       { font-size: 28px; }
  .fsfm-mc-kickoff     { font-size: 18px; }
  .fsfm-mc-score-block { min-width: 90px; padding: 0 10px; }
  .fsfm-mc-body        { padding: 14px 14px; gap: 6px; }
  .fsfm-mc-flag        { font-size: 24px; }
  .fsfm-mc-logo        { width: 34px; height: 34px; }
  .fsfm-match-list.fsfm-cols-3 { grid-template-columns: 1fr 1fr; }
}

/* Mobile ≤ 600px : conserver le grid horizontal DOM | SCORE | EXT */
@media (max-width: 600px) {
  /* Header carte : empiler */
  .fsfm-mc-header      { flex-direction: column; align-items: flex-start; gap: 6px; }
  .fsfm-mc-info        { width: 100%; }
  .fsfm-mc-competition { white-space: normal; }
  .fsfm-mc-comp-link   { align-self: flex-start; }

  /* Corps : CONSERVER grid 3 colonnes horizontal — même disposition que desktop */
  .fsfm-mc-body {
    grid-template-columns: 1fr auto 1fr;
    grid-template-rows: auto;
    text-align: inherit;
    padding: 12px 10px;
    gap: 4px;
  }
  /* Réinitialiser les éventuels grid-row forcés */
  .fsfm-mc-score-block { grid-row: auto; min-width: 70px; padding: 0 6px; }
  .fsfm-mc-dom         { grid-row: auto; justify-content: flex-end;   text-align: right; }
  .fsfm-mc-ext         { grid-row: auto; justify-content: flex-end;   text-align: left; flex-direction: row-reverse; }

  /* Typographie compacte mobile */
  .fsfm-mc-team-name   { font-size: 11px; line-height: 1.2; }
  .fsfm-mc-score       { font-size: 20px; }
  .fsfm-mc-kickoff     { font-size: 16px; }
  .fsfm-mc-statut      { font-size: 9px; padding: 2px 6px; letter-spacing: 1px; }
  .fsfm-mc-flag        { font-size: 18px; }
  .fsfm-mc-logo        { width: 24px; height: 24px; }
  /* Masquer logo/drapeau si espace insuffisant */
  .fsfm-mc-flag        { display: none; }
  .fsfm-mc-logo        { display: none; }

  /* Classement : masquer colonnes secondaires */
  .fsfm-standings-table-front .col-forme,
  .fsfm-standings-table-front .col-db { display: none; }
  /* Multi-colonnes → 1 col sur mobile */
  .fsfm-match-list.fsfm-cols-2,
  .fsfm-match-list.fsfm-cols-3 { grid-template-columns: 1fr; }

  .fsfm-tab        { padding: 10px 14px; font-size: 12px; }
  .fsfm-nm-flag    { font-size: 36px; }
  .fsfm-cd-val     { font-size: 30px; }
  .fsfm-cd-unit    { min-width: 48px; }
  .fsfm-comp-link  { text-align: center; }
}


/* ══════════════════════════════════════════════════════════
   BRACKET DE TOURNOI — frontend.css v1.0
   [fsf_bracket]  Couleur pilotée par --bk-color (CSS var)
══════════════════════════════════════════════════════════ */

.fsfm-bracket-wrap {
  --bk-color: #00843D;
  --bk-dark:  color-mix(in srgb, var(--bk-color) 80%, #000);
  --bk-light: color-mix(in srgb, var(--bk-color) 12%, #fff);
  --bk-mid:   color-mix(in srgb, var(--bk-color) 45%, #fff);
  font-family: 'Lato', sans-serif;
  margin-bottom: 24px;
}

/* ── En-tête ── */
.fsfm-bk-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
  gap: 10px;
  flex-wrap: wrap;
}
.fsfm-bk-title {
  font-family: 'Oswald', sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: var(--bk-dark);
  letter-spacing: .5px;
}
.fsfm-bk-type {
  font-size: 11px;
  color: var(--bk-color);
  border: 1.5px solid var(--bk-color);
  padding: 3px 10px;
  font-family: 'Oswald', sans-serif;
  letter-spacing: 1px;
  text-transform: uppercase;
}

/* ── Scroll wrapper (overflow horizontal) ── */
.fsfm-bk-scroll {
  overflow-x: auto;
  padding-bottom: 8px;
}

/* ── Grid de colonnes ── */
.fsfm-bk-bracket {
  display: flex;
  align-items: stretch;
  gap: 0;
  min-width: max-content;
}

/* ── Colonne (1 tour) ── */
.fsfm-bk-col {
  display: flex;
  flex-direction: column;
  min-width: 152px;
}
.fsfm-bk-round-lbl {
  font-family: 'Oswald', sans-serif;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: #888;
  text-align: center;
  padding: 0 6px 10px;
}

/* ── Liste des matchs dans une colonne ── */
.fsfm-bk-matches {
  display: flex;
  flex-direction: column;
  flex: 1;
  justify-content: space-around;
  gap: 6px;
}

/* ── Wrapper match + connecteur ── */
.fsfm-bk-match-wrap {
  display: flex;
  align-items: center;
  flex: 1;
}

/* ── Boîte de match ── */
.fsfm-bk-match {
  flex: 1;
  border: 0.5px solid #e0e0e0;
  border-radius: 6px;
  background: #fff;
  overflow: hidden;
  margin: 3px 4px;
  box-shadow: 0 1px 4px rgba(0,0,0,.04);
}

/* ── Slot (ligne d'équipe) ── */
.fsfm-bk-slot {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 7px 10px;
  font-size: 12px;
  min-height: 34px;
  border-bottom: 0.5px solid #f0f0f0;
  transition: background .12s;
  user-select: none;
}
.fsfm-bk-slot:last-child { border-bottom: none; }

.fsfm-bk-seed {
  font-size: 10px;
  color: #aaa;
  min-width: 14px;
  font-weight: 700;
  font-family: 'Oswald', sans-serif;
}
.fsfm-bk-name {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: #222;
  font-size: 12.5px;
}
.fsfm-bk-w {
  font-size: 10px;
  color: #fff;
  background: var(--bk-color);
  border-radius: 50%;
  width: 16px;
  height: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-weight: 700;
}

/* États des slots */
.fsfm-bk-clickable {
  cursor: pointer;
}
.fsfm-bk-clickable:hover {
  background: var(--bk-light);
}
.fsfm-bk-win {
  background: var(--bk-light);
}
.fsfm-bk-win .fsfm-bk-name  { color: var(--bk-dark); font-weight: 700; }
.fsfm-bk-win .fsfm-bk-seed  { color: var(--bk-mid); }
.fsfm-bk-los {
  opacity: .32;
}
.fsfm-bk-tbd .fsfm-bk-name  { color: #bbb; font-style: italic; font-size: 11px; }

/* ── Connecteur entre matchs ── */
.fsfm-bk-conn {
  width: 18px;
  flex-shrink: 0;
  border-top: 1px solid #ddd;
  height: 0;
  align-self: center;
}

/* ── Colonne champion ── */
.fsfm-bk-champ-col {
  min-width: 136px;
  justify-content: center;
}
.fsfm-bk-champ {
  border: 2px solid var(--bk-color);
  border-radius: 8px;
  background: var(--bk-light);
  padding: 14px 10px;
  text-align: center;
  margin: 3px 4px;
}
.fsfm-bk-trophy   { font-size: 26px; line-height: 1; margin-bottom: 6px; }
.fsfm-bk-champ-name {
  font-family: 'Oswald', sans-serif;
  font-size: 13px;
  font-weight: 700;
  color: var(--bk-dark);
}

/* ── Bannière champion ── */
.fsfm-bk-banner {
  margin-top: 12px;
  padding: 10px 16px;
  background: var(--bk-light);
  border-left: 4px solid var(--bk-color);
  border-radius: 0 6px 6px 0;
  font-size: 13px;
  color: var(--bk-dark);
}

/* ── Hint bas de page ── */
.fsfm-bk-hint {
  font-size: 11px;
  color: #aaa;
  margin-top: 8px;
  font-style: italic;
}

/* ── Loader AJAX ── */
.fsfm-bk-loading {
  opacity: .5;
  pointer-events: none;
  cursor: wait;
}

/* ── Responsive ── */
@media (max-width: 600px) {
  .fsfm-bk-col        { min-width: 120px; }
  .fsfm-bk-name       { font-size: 11px; }
  .fsfm-bk-slot       { padding: 6px 8px; min-height: 30px; }
  .fsfm-bk-champ-col  { min-width: 110px; }
}

/* ── Bracket v2 : couleur accent (bannière champion) ── */
.fsfm-bk-banner {
  border-color: var(--bk-color2, #E2001A);
  background: color-mix(in srgb, var(--bk-color2, #E2001A) 10%, #fff);
  color: color-mix(in srgb, var(--bk-color2, #E2001A) 80%, #000);
}
.fsfm-bk-champ { border-color: var(--bk-color); }

/* ── Badge type d'élimination ── */
.fsfm-bk-type-badge {
  font-family: 'Oswald', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--bk-color);
  border: 1.5px solid var(--bk-color);
  padding: 3px 10px;
  border-radius: 20px;
  flex-shrink: 0;
}

/* ── Layout compact ── */
.fsfm-bk-compact .fsfm-bk-col       { min-width: 120px; }
.fsfm-bk-compact .fsfm-bk-slot      { padding: 5px 8px; min-height: 27px; font-size: 11px; }
.fsfm-bk-compact .fsfm-bk-team-name { font-size: 11px; }
.fsfm-bk-compact .fsfm-bk-round-lbl { font-size: 9px; padding-bottom: 6px; }
.fsfm-bk-compact .fsfm-bk-champ     { padding: 10px 8px; }
.fsfm-bk-compact .fsfm-bk-trophy    { font-size: 20px; }
.fsfm-bk-compact .fsfm-bk-champ-col { min-width: 110px; }

/* ── Layout large ── */
.fsfm-bk-large .fsfm-bk-col         { min-width: 180px; }
.fsfm-bk-large .fsfm-bk-slot        { padding: 10px 14px; min-height: 42px; font-size: 14px; }
.fsfm-bk-large .fsfm-bk-name        { font-size: 14px; }
.fsfm-bk-large .fsfm-bk-seed        { font-size: 12px; min-width: 18px; }
.fsfm-bk-large .fsfm-bk-round-lbl   { font-size: 12px; padding-bottom: 12px; }
.fsfm-bk-large .fsfm-bk-champ       { padding: 18px 14px; }
.fsfm-bk-large .fsfm-bk-trophy      { font-size: 32px; }
.fsfm-bk-large .fsfm-bk-champ-name  { font-size: 15px; }
.fsfm-bk-large .fsfm-bk-champ-col   { min-width: 158px; }
.fsfm-bk-large .fsfm-bk-matches     { gap: 10px; }

/* ── Bracket v3 : footer + bouton sync ── */
.fsfm-bk-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}
.fsfm-bk-sync-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 13px;
  background: none;
  border: 1.5px solid var(--bk-color);
  border-radius: 20px;
  color: var(--bk-color);
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .8px;
  text-transform: uppercase;
  cursor: pointer;
  transition: all .15s;
}
.fsfm-bk-sync-btn:hover {
  background: var(--bk-color);
  color: #fff;
}
.fsfm-bk-sync-btn:disabled {
  opacity: .5;
  cursor: wait;
}
.fsfm-bk-sync-ico { font-size: 12px; }
.fsfm-bk-sync-msg {
  font-size: 11px;
  color: var(--bk-color);
  margin-top: 4px;
  display: block;
}

/* ══════════════════════════════════════════════════════════
   TIRAGE AU SORT — frontend.css
══════════════════════════════════════════════════════════ */
.fsfm-tirage-wrap { font-family: 'Lato', sans-serif; }

.fsfm-tirage-pending {
  text-align: center;
  padding: 48px 20px;
  color: #888;
}
.fsfm-tirage-pending-ico { font-size: 40px; margin-bottom: 12px; }
.fsfm-tirage-pending p   { font-size: 15px; color: #666; }

/* Réutilise le rendu de fsfm_tirage_render_results */
.fsfm-tirage-results {
  font-family: 'Lato', sans-serif;
}
