/* =====================================================================
   FOOT VERTICAL — HOMEPAGE CINÉMATIQUE
   Refonte graphique de la page d'accueil. TOUT est scopé sous body.home
   pour ne jamais impacter les autres pages. Cible les classes réelles du
   thème (front-page.php) ; aucune logique PHP n'est modifiée.
   Direction : éditorial premium · ADN gardé · accent vert + or · pas de glow
   ===================================================================== */

/* ---------------------------------------------------------------------
   1. TOKENS + BASE (override des variables du thème sur la home)
   --------------------------------------------------------------------- */
body.home {
  --fv-black:        #080B12;
  --fv-surface:      #0C111B;
  --fv-surface-2:    #111826;
  --fv-surface-3:    #161F30;
  --fv-border:       rgba(237, 241, 247, 0.12);
  --fv-green-glow:   none;                       /* tue le néon */
  --fv-white:        #EDF1F7;
  --fv-grey-700:     #6E7E92;

  /* nouveaux tokens cinématiques */
  --fv-serif:        'Twemoji Country Flags', 'Fraunces', Georgia, 'Times New Roman', serif;
  --fv-line:         rgba(237, 241, 247, 0.12);
  --fv-line-2:       rgba(237, 241, 247, 0.06);
  --fv-pad:          clamp(20px, 5vw, 72px);
  --fv-ease:         cubic-bezier(0.22, 1, 0.36, 1);
  --fv-sec:          clamp(60px, 8.5vh, 116px);
  --fv-accent-soft:  rgba(0, 224, 90, 0.12);
  --fv-gold-soft:    rgba(232, 184, 75, 0.14);

  background: #080B12;
}

/* retire la trame scanline verte du fond (broadcast) */
body.home::before { content: none !important; display: none !important; }

/* blancs froids + désaturation */
body.home { color: var(--fv-white); }
body.home a { color: var(--fv-green); }

/* ---------------------------------------------------------------------
   2. TYPO — Fraunces serif sur les titres
   --------------------------------------------------------------------- */
body.home h1, body.home h2, body.home h3,
body.home .fv-section-title,
body.home .fv-hero__title,
body.home .fv-card__title,
body.home .fv-card-horizontal__title {
  font-family: var(--fv-serif);
  font-weight: 500;
  letter-spacing: -0.015em;
  font-optical-sizing: auto;
}

/* ---------------------------------------------------------------------
   3. HEADER / NAV — verre dépoli cinématique (image bannière retirée)
   --------------------------------------------------------------------- */
body.home .fv-header {
  background-image: none !important;
  background-color: rgba(8, 11, 18, 0.72);
  backdrop-filter: blur(16px) saturate(140%);
  -webkit-backdrop-filter: blur(16px) saturate(140%);
  border-bottom: 1px solid var(--fv-line-2);
  box-shadow: none;
}
body.home .fv-header.is-scrolled {
  background-image: none !important;
  background-color: rgba(8, 11, 18, 0.86);
  border-bottom-color: var(--fv-line);
}
/* fine ligne accent en haut, plus discrète */
body.home .fv-header::before {
  height: 1px;
  opacity: 0.5;
  background: linear-gradient(90deg, transparent, var(--fv-green) 35%, var(--fv-gold) 65%, transparent);
}
body.home .fv-logo__img { border-color: var(--fv-line); }
body.home .fv-nav__link {
  font-size: 0.78rem; letter-spacing: 0.08em; color: var(--fv-grey-700);
}
body.home .fv-nav__link:hover,
body.home .fv-nav__link.is-active { color: var(--fv-white); }
body.home .fv-nav__cta {
  color: var(--fv-gold);
  border: 1px solid var(--fv-gold-soft);
  background: transparent;
}
body.home .fv-nav__cta:hover { background: var(--fv-gold); color: var(--fv-black); }

/* ---------------------------------------------------------------------
   4. FOOTER — éditorial sombre
   --------------------------------------------------------------------- */
body.home .fv-footer {
  background: #05070C;
  border-top: 1px solid var(--fv-line-2);
}
body.home .fv-footer__nav a:hover,
body.home .fv-footer__social a:hover { color: var(--fv-green); }

/* ---------------------------------------------------------------------
   5. CONTENEUR + TITRES DE SECTION (partagé)
   --------------------------------------------------------------------- */
body.home .fv-section-title {
  font-size: clamp(30px, 4vw, 52px);
  line-height: 1.05;
}
/* supprime la puce/dash décoratif broadcast devant les titres */
body.home .fv-section-title::before { display: none !important; }
body.home .fv-section-title em { color: var(--fv-gold); font-style: italic; }

/* ---------------------------------------------------------------------
   6. LIVE TICKER
   --------------------------------------------------------------------- */
body.home .fv-live-ticker {
  background: #05070C;
  border-bottom: 1px solid var(--fv-line-2);
}
body.home .fv-live-ticker__label { color: #FF3B57; }
body.home .fv-live-ticker__dot { background: #FF3B57; box-shadow: none; }
body.home .fv-live-ticker__item { color: var(--fv-grey-700); }
body.home .fv-live-ticker__item strong {
  font-family: var(--fv-serif); font-weight: 600; color: var(--fv-white);
  font-variant-numeric: tabular-nums;
}

/* ---------------------------------------------------------------------
   7. COMPTE À REBOURS (kickoff)
   --------------------------------------------------------------------- */
body.home .fv-kickoff {
  border: 1px solid var(--fv-line);
  border-radius: 6px;
  background: linear-gradient(180deg, var(--fv-surface-3), var(--fv-surface));
  box-shadow: none;
  position: relative;
  overflow: hidden;
}
body.home .fv-kickoff::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: linear-gradient(180deg, var(--fv-green), var(--fv-gold));
  opacity: 1;
}
body.home .fv-kickoff__cell b {
  font-family: var(--fv-serif); font-weight: 500; color: var(--fv-gold);
  font-variant-numeric: tabular-nums;
}
body.home .fv-kickoff__sep { font-family: var(--fv-serif); color: var(--fv-line); }
body.home .fv-kickoff__match b { font-family: var(--fv-serif); font-weight: 500; }

/* ---------------------------------------------------------------------
   8. MATCHDAY BANNER
   --------------------------------------------------------------------- */
body.home .fv-matchday__kicker { color: var(--fv-green); }
body.home .fv-matchday__label b { font-family: var(--fv-serif); font-weight: 500; }
body.home .fv-matchday__match {
  border: 1px solid var(--fv-line);
  border-radius: 5px;
  background: var(--fv-surface);
  box-shadow: none;
}
body.home .fv-matchday__match:hover { border-color: var(--fv-line); transform: translateY(-2px); }
body.home .fv-matchday__score { font-family: var(--fv-serif); color: var(--fv-gold); }
body.home .fv-matchday__time { font-family: var(--fv-serif); color: var(--fv-gold); }
body.home .fv-matchday__slot--article { color: var(--fv-green); }

/* ---------------------------------------------------------------------
   9. HERO — full-bleed cinématique
   --------------------------------------------------------------------- */
body.home .fv-hero {
  position: relative;
  min-height: clamp(520px, 86vh, 880px);
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background: var(--fv-black);
}
body.home .fv-hero__img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  aspect-ratio: auto;
  object-fit: cover;
  transform: scale(1.06);
  will-change: transform;
}
body.home .fv-hero__overlay {
  position: absolute; inset: 0; pointer-events: none;
  background:
    linear-gradient(to top, rgba(5,7,12,0.94) 0%, rgba(5,7,12,0.45) 40%, rgba(5,7,12,0.06) 70%, rgba(5,7,12,0.30) 100%),
    linear-gradient(to right, rgba(5,7,12,0.72) 0%, rgba(5,7,12,0.16) 54%, rgba(5,7,12,0) 84%);
}
body.home .fv-hero::after { display: none !important; } /* retire l'effet broadcast */
body.home .fv-hero__content {
  position: relative; z-index: 2;
  width: 100%;
  padding-top: clamp(40px, 8vh, 90px);
  padding-bottom: clamp(48px, 9vh, 100px);
}
body.home .fv-hero__title {
  font-size: clamp(40px, 6.4vw, 88px);
  font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1.02;
  max-width: 16ch;
  margin: 0 0 22px;
}
body.home .fv-hero__excerpt {
  font-size: clamp(16px, 1.6vw, 20px);
  color: #D6DEEA;
  max-width: 56ch;
  margin: 0 0 30px;
  text-shadow: 0 1px 18px rgba(0,0,0,0.6);
}
body.home .fv-badge--wc2026,
body.home .fv-hero .fv-badge {
  background: var(--fv-green); color: var(--fv-black);
  border: 0; box-shadow: none;
  letter-spacing: 0.14em; text-transform: uppercase; font-size: 0.7rem;
}

/* ---------------------------------------------------------------------
   10. BOUTONS
   --------------------------------------------------------------------- */
body.home .fv-btn {
  background: var(--fv-green); color: var(--fv-black);
  border: 0; border-radius: 999px;
  box-shadow: none; font-weight: 500; letter-spacing: 0.02em;
  transition: transform .25s var(--fv-ease), opacity .25s;
}
body.home .fv-btn:hover { transform: translateY(-2px); opacity: 0.92; box-shadow: none; }
body.home .fv-btn:active { transform: translateY(0) scale(0.98); }

/* ---------------------------------------------------------------------
   11. QUIZ CTA
   --------------------------------------------------------------------- */
body.home .fv-quiz-cta {
  border: 1px solid var(--fv-line);
  border-radius: 8px;
  background: linear-gradient(135deg, var(--fv-surface-3), var(--fv-surface));
  box-shadow: none;
}
body.home .fv-quiz-cta:hover {
  transform: translateY(-3px);
  border-color: var(--fv-gold-soft);
  box-shadow: none;
}
body.home .fv-quiz-cta::after {
  background: radial-gradient(circle, var(--fv-gold-soft), transparent 70%);
}
body.home .fv-quiz-cta__timer .bg { stroke: var(--fv-line); }
body.home .fv-quiz-cta__timer .fg { stroke: var(--fv-gold); }
body.home .fv-quiz-cta__timer span { font-family: var(--fv-serif); color: var(--fv-gold); }
body.home .fv-quiz-cta__txt h2 { font-family: var(--fv-serif); }
body.home .fv-quiz-cta__txt h2 b { color: var(--fv-gold); }
body.home .fv-quiz-cta__go { background: var(--fv-gold); color: var(--fv-black); }

/* ---------------------------------------------------------------------
   12. CARTES ARTICLES (.fv-card) — grille à chaud + carrousel joueurs
   --------------------------------------------------------------------- */
body.home .fv-card {
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  overflow: visible;
}
body.home .fv-card:hover { transform: none; box-shadow: none; }
body.home .fv-card__img-wrap {
  border-radius: 5px;
  overflow: hidden;
  aspect-ratio: 16 / 10;
}
body.home .fv-card__img-wrap::after { display: none; }
body.home .fv-card:hover .fv-card__img { transform: scale(1.05); }
body.home .fv-card__body { padding: 14px 0 0; }
body.home .fv-card__title {
  font-family: var(--fv-serif); font-weight: 500;
  font-size: clamp(17px, 1.5vw, 21px); line-height: 1.2;
}
body.home .fv-card__title a:hover { color: var(--fv-gold); }
body.home .fv-card__meta { color: var(--fv-grey-700); font-size: 0.78rem; }

/* badges sur cartes : pastilles éditoriales sobres */
body.home .fv-card .fv-badge,
body.home .fv-section-hot .fv-card .fv-badge {
  background: rgba(5,7,12,0.7);
  backdrop-filter: blur(6px);
  border: 1px solid var(--fv-line);
  color: var(--fv-white);
  font-size: 0.62rem; letter-spacing: 0.12em; text-transform: uppercase;
}

/* en-tête « à chaud » */
body.home .fv-hot-accent { color: var(--fv-green); }
body.home .fv-hot-title::before { display: none !important; }
body.home .fv-hot-all {
  border: 1px solid var(--fv-line); border-radius: 999px;
  color: var(--fv-grey-700); background: transparent;
}
body.home .fv-hot-all:hover { background: transparent; border-color: var(--fv-green); color: var(--fv-green); }

/* ---------------------------------------------------------------------
   13. GROUPES WC2026
   --------------------------------------------------------------------- */
body.home .fv-section-groupes::before { display: none !important; }
body.home .fv-groups-link {
  color: var(--fv-grey-700);
  border-bottom: 1px solid var(--fv-line); padding-bottom: 4px;
}
body.home .fv-groups-link:hover { color: var(--fv-green); border-color: var(--fv-green); }
body.home .fv-group-card {
  border: 1px solid var(--fv-line);
  border-radius: 6px;
  background: var(--fv-surface);
  box-shadow: none;
}
body.home .fv-group-card:hover { border-color: var(--fv-line); transform: none; }
body.home .fv-group-card__head { border-bottom: 1px solid var(--fv-line); }
body.home .fv-group-card__letter {
  color: var(--fv-green); letter-spacing: 0.14em; font-weight: 700; text-transform: uppercase;
}
body.home .fv-group-standings thead th { color: var(--fv-grey-700); }
body.home .fv-gs-th-pts { color: var(--fv-gold) !important; }
body.home .fv-group-standings tbody td { border-top: 1px solid var(--fv-line-2); }
body.home .fv-gs-pts { font-family: var(--fv-serif); font-weight: 600; color: var(--fv-gold); }
body.home .fv-gs-name { color: var(--fv-grey-700); }
body.home .fv-group-standings tbody tr:nth-child(1) .fv-gs-name,
body.home .fv-group-standings tbody tr:nth-child(2) .fv-gs-name { color: var(--fv-white); }
/* onglets mobile groupes */
body.home .fv-groups-tab {
  border: 1px solid var(--fv-line); background: transparent;
  font-family: var(--fv-serif); color: var(--fv-grey-700);
}
body.home .fv-groups-tab.is-active { background: var(--fv-green); color: var(--fv-black); border-color: var(--fv-green); }

/* ---------------------------------------------------------------------
   14. CLASSEMENTS INDIVIDUELS
   --------------------------------------------------------------------- */
body.home .fv-rk-card {
  border: 1px solid var(--fv-line);
  border-radius: 6px;
  background: var(--fv-surface);
  box-shadow: none;
}
body.home .fv-rk-head { border-bottom: 1px solid var(--fv-line); }
body.home .fv-rk-head h3 { font-family: var(--fv-serif); font-weight: 500; }
body.home .fv-rk-list li { border-bottom: 1px solid var(--fv-line-2); }
body.home .fv-rk-list li:nth-child(-n+3) .fv-rk-pos { color: var(--fv-gold); }
body.home .fv-rk-name i { color: var(--fv-grey-700); }
body.home .fv-rk-val { font-family: var(--fv-serif); font-weight: 600; color: var(--fv-green); }
body.home .fv-rk-asof, body.home .fv-rk-foot, body.home .fv-rk-note { color: var(--fv-grey-700); }

/* ---------------------------------------------------------------------
   15. TACTIQUE
   --------------------------------------------------------------------- */
body.home .fv-section-tactique::before { display: none !important; }
body.home .fv-card-horizontal {
  border: 1px solid var(--fv-line);
  border-radius: 6px;
  background: var(--fv-surface);
  box-shadow: none;
}
body.home .fv-card-horizontal:hover { border-color: var(--fv-line); transform: translateY(-3px); }
body.home .fv-card-horizontal__title { font-family: var(--fv-serif); font-weight: 500; }
body.home .fv-card-horizontal__title a:hover { color: var(--fv-green); }
body.home .fv-card-horizontal__excerpt { color: var(--fv-grey-700); }

/* ---------------------------------------------------------------------
   16. JOUEURS À SUIVRE (carrousel)
   --------------------------------------------------------------------- */
body.home .fv-joueurs-arrow {
  border: 1px solid var(--fv-line); background: transparent; color: var(--fv-white);
}
body.home .fv-joueurs-arrow:hover { border-color: var(--fv-green); color: var(--fv-green); background: transparent; }
body.home .fv-section-joueurs .fv-card__img-wrap { aspect-ratio: 3 / 4; }
body.home .fv-joueurs-view-all {
  border: 1px solid var(--fv-line); border-radius: 999px;
  color: var(--fv-white); background: transparent; padding: 12px 26px;
}
body.home .fv-joueurs-view-all:hover { border-color: var(--fv-green); color: var(--fv-green); background: transparent; }

/* ---------------------------------------------------------------------
   17. STATS / DATA — gros chiffres serif, compteurs
   --------------------------------------------------------------------- */
body.home .fv-section-data { background: #05070C; border-top: 1px solid var(--fv-line-2); border-bottom: 1px solid var(--fv-line-2); }
body.home .fv-section-data::before { display: none !important; }
body.home .fv-stat-card {
  border: 0; border-left: 1px solid var(--fv-line);
  border-radius: 0; background: transparent !important; padding: 6px 0 6px 28px;
}
body.home .fv-stat-card::before { display: none !important; }
body.home .fv-stat-card:hover { background: transparent !important; }
body.home .fv-stat-card__value {
  font-family: var(--fv-serif); font-weight: 500;
  font-size: clamp(52px, 7vw, 96px); line-height: 0.95; color: var(--fv-white);
  font-variant-numeric: tabular-nums;
}
body.home .fv-stat-card__label { color: var(--fv-grey-700); letter-spacing: 0.14em; }

/* ---------------------------------------------------------------------
   18. SONDAGE
   --------------------------------------------------------------------- */
body.home .fv-poll {
  border: 1px solid var(--fv-line);
  border-radius: 8px;
  background: var(--fv-surface);
  box-shadow: none;
}
body.home .fv-poll__title { font-family: var(--fv-serif); }
body.home .fv-poll__title span { color: var(--fv-green); }
body.home .fv-poll__tag { color: var(--fv-green); }
body.home .fv-poll__option {
  border: 1px solid var(--fv-line); border-radius: 6px; background: transparent;
}
body.home .fv-poll__option:hover { border-color: var(--fv-accent-soft); background: var(--fv-accent-soft); }
body.home .fv-poll__option.is-selected { border-color: var(--fv-green); background: var(--fv-accent-soft); }
body.home .fv-poll__option.is-selected .fv-poll__check { background: var(--fv-green); border-color: var(--fv-green); }
body.home .fv-poll__bar-fill { background: linear-gradient(90deg, var(--fv-green), var(--fv-gold)); }
body.home .fv-poll__pct { font-family: var(--fv-serif); color: var(--fv-green); }
body.home .fv-poll__result-row.is-voted .fv-poll__pct { color: var(--fv-gold); }
body.home .fv-poll__results-title { font-family: var(--fv-serif); }

/* ---------------------------------------------------------------------
   19. NEWSLETTER
   --------------------------------------------------------------------- */
body.home .fv-cta-newsletter {
  background:
    radial-gradient(ellipse at 50% 0%, rgba(0,224,90,0.06), transparent 60%),
    var(--fv-surface);
  border-top: 1px solid var(--fv-line-2);
}
body.home .fv-cta-newsletter::before,
body.home .fv-cta-newsletter::after { display: none !important; }
body.home .fv-cta-newsletter h2 { font-family: var(--fv-serif); }
body.home .fv-cta-newsletter p { color: #D6DEEA; }
body.home .fv-cta-newsletter__input {
  border: 1px solid var(--fv-line); background: var(--fv-black); border-radius: 999px;
}
body.home .fv-cta-newsletter__input:focus { border-color: var(--fv-green); }

/* ---------------------------------------------------------------------
   20. COUCHE MOTION (additive) — reveals + masked hero title
   Hidden states gated by html.fv-cine (posée en JS si le script charge).
   --------------------------------------------------------------------- */
html.fv-cine body.home .fv-section-title,
html.fv-cine body.home .fv-hot-all,
html.fv-cine body.home .fv-groups-link,
html.fv-cine body.home .fv-card,
html.fv-cine body.home .fv-group-card,
html.fv-cine body.home .fv-rk-card,
html.fv-cine body.home .fv-card-horizontal,
html.fv-cine body.home .fv-stat-card,
html.fv-cine body.home .fv-quiz-cta,
html.fv-cine body.home .fv-poll,
html.fv-cine body.home .fv-kickoff,
html.fv-cine body.home .fv-cta-newsletter > * {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity 0.8s var(--fv-ease), transform 0.8s var(--fv-ease);
  will-change: opacity, transform;
}
html.fv-cine body.home .is-shown {
  opacity: 1 !important;
  transform: none !important;
}

/* masked hero title */
html.fv-cine body.home .fv-hero__title .ml-line { display: block; overflow: hidden; padding-bottom: 0.06em; margin-bottom: -0.06em; }
html.fv-cine body.home .fv-hero__title .ml-line__inner { display: block; transform: translateY(110%); transition: transform 1s var(--fv-ease); transition-delay: var(--ml-delay, 0s); will-change: transform; }
html.fv-cine body.home .fv-hero__title.is-shown .ml-line__inner { transform: translateY(0); }

/* ---------------------------------------------------------------------
   21. RESPONSIVE (compléments — le thème gère déjà ses breakpoints)
   --------------------------------------------------------------------- */
@media (max-width: 820px) {
  body.home .fv-hero { min-height: 70vh; }
  body.home .fv-hero__title { font-size: clamp(34px, 9vw, 52px); }
}

/* ---------------------------------------------------------------------
   22. REDUCED MOTION — neutralise toute la couche motion
   --------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  html.fv-cine body.home .fv-section-title,
  html.fv-cine body.home .fv-hot-all,
  html.fv-cine body.home .fv-groups-link,
  html.fv-cine body.home .fv-card,
  html.fv-cine body.home .fv-group-card,
  html.fv-cine body.home .fv-rk-card,
  html.fv-cine body.home .fv-card-horizontal,
  html.fv-cine body.home .fv-stat-card,
  html.fv-cine body.home .fv-quiz-cta,
  html.fv-cine body.home .fv-poll,
  html.fv-cine body.home .fv-kickoff,
  html.fv-cine body.home .fv-cta-newsletter > * {
    opacity: 1 !important; transform: none !important; transition: none !important;
  }
  html.fv-cine body.home .fv-hero__title .ml-line__inner { transform: none !important; }
  body.home .fv-hero__img { transform: scale(1.02) !important; }
}

/* =====================================================================
   23. TABLEAU FINAL (BRACKET) — homepage
   --------------------------------------------------------------------- */
.fv-section-bracket {
  background:
    radial-gradient(120% 70% at 50% 0%, rgba(0,224,90,.06), transparent 55%),
    var(--fv-black);
  border-top: 1px solid var(--fv-border);
  border-bottom: 1px solid var(--fv-border);
  padding: 3.5rem 0 3rem;
  position: relative;
  overflow: hidden;
}
.fv-section-bracket::before {
  content: '';
  position: absolute; inset: 0; pointer-events: none;
  background-image:
    repeating-linear-gradient(90deg, transparent, transparent 79px, rgba(232,184,75,.035) 79px, rgba(232,184,75,.035) 80px);
  mask-image: linear-gradient(180deg, transparent, #000 18%, #000 82%, transparent);
}
.fv-section-bracket > .fv-container { position: relative; z-index: 1; }

.fv-bracket__intro {
  color: var(--fv-grey-700);
  font-size: .95rem;
  margin: .15rem 0 1.6rem;
  max-width: 60ch;
}

.fv-bracket-scroll {
  overflow-x: auto; overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  padding: .25rem .25rem 1rem;
  scrollbar-width: thin;
  scrollbar-color: var(--fv-grey-300) transparent;
}
.fv-bracket-scroll::-webkit-scrollbar { height: 8px; }
.fv-bracket-scroll::-webkit-scrollbar-thumb { background: var(--fv-grey-300); border-radius: 4px; }
.fv-bracket-scroll:focus-visible { outline: 2px solid var(--fv-green); outline-offset: 3px; border-radius: 4px; }

.fv-bracket {
  --bk-gap: 36px;
  display: flex;
  gap: var(--bk-gap);
  min-width: 1060px;
  align-items: stretch;
}

.fv-bk-round {
  flex: 1 1 0;
  min-width: 168px;
  display: flex;
  flex-direction: column;
}
.fv-bk-roundhead {
  flex: 0 0 auto;
  font-family: var(--fv-font-scoreboard);
  letter-spacing: .16em;
  text-transform: uppercase;
  font-size: 1.05rem;
  color: var(--fv-gold);
  text-align: center;
  padding-bottom: .6rem;
  margin-bottom: .4rem;
  border-bottom: 1px solid var(--fv-border);
}
.fv-bk-round--fin .fv-bk-roundhead { color: var(--fv-green); }

.fv-bk-ties { flex: 1 1 auto; display: flex; flex-direction: column; justify-content: center; }
.fv-bk-tie {
  flex: 1 1 0;
  display: flex; flex-direction: column; justify-content: center; gap: 3px;
  padding: 7px 0;
  position: relative;
}

/* --- Slot (équipe) --- */
.fv-bk-slot {
  display: grid;
  grid-template-columns: 1.35em 1fr auto;
  align-items: center;
  gap: .5rem;
  background: var(--fv-surface-2);
  border: 1px solid var(--fv-border);
  border-left: 3px solid var(--fv-grey-300);
  border-radius: var(--fv-radius-sm);
  padding: .42rem .55rem;
}
.fv-bk-flag { font-size: 1.05em; line-height: 1; text-align: center; }
.fv-bk-team {
  font-family: var(--fv-font-display);
  font-weight: 600;
  font-size: .82rem;
  letter-spacing: .01em;
  color: var(--fv-grey-900);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.fv-bk-score {
  font-family: var(--fv-font-scoreboard);
  font-size: 1.05rem; line-height: 1;
  color: var(--fv-white);
  min-width: 1ch; text-align: center;
}
.fv-bk-slot.is-win {
  border-color: rgba(0,224,90,.4);
  border-left-color: var(--fv-green);
  background: var(--fv-green-dim);
  box-shadow: 0 0 14px rgba(0,224,90,.12);
}
.fv-bk-slot.is-win .fv-bk-team { color: var(--fv-white); }
.fv-bk-slot.is-tbd {
  border-left-color: var(--fv-border);
  background: rgba(16,27,46,.5);
}
.fv-bk-slot.is-tbd .fv-bk-flag { opacity: .35; }
.fv-bk-slot.is-tbd .fv-bk-team {
  font-family: var(--fv-font-body);
  font-weight: 400; font-style: italic;
  font-size: .72rem;
  color: var(--fv-grey-500);
}

/* --- Finale : carte trophée --- */
.fv-bk-tie.is-final {
  border: 1px solid var(--fv-gold);
  border-radius: var(--fv-radius-md);
  background: linear-gradient(180deg, rgba(232,184,75,.10), rgba(232,184,75,.02));
  padding: 1.6rem .6rem .7rem;
  box-shadow: 0 0 26px rgba(232,184,75,.12);
  flex: 0 0 auto; align-self: center;
}
.fv-bk-trophy {
  position: absolute; top: -.7rem; left: 50%; transform: translateX(-50%);
  font-size: 1.5rem; filter: drop-shadow(0 0 8px rgba(232,184,75,.5));
}

/* --- Connecteurs (⊐ reliant chaque paire + amorces horizontales) --- */
.fv-bk-round:not(.fv-bk-round--fin) .fv-bk-tie:nth-child(odd)::after {
  content: '';
  position: absolute;
  left: 100%;
  top: 50%;
  width: calc(var(--bk-gap) * .5);
  height: 100%;
  border: 2px solid var(--fv-border);
  border-left: 0;
  border-radius: 0 9px 9px 0;
  pointer-events: none;
}
.fv-bk-round:not(.fv-bk-round--r32) .fv-bk-tie::before {
  content: '';
  position: absolute;
  right: 100%;
  top: 50%;
  width: calc(var(--bk-gap) * .5);
  height: 2px;
  margin-top: -1px;
  background: var(--fv-border);
  pointer-events: none;
}

.fv-bracket__legend {
  color: var(--fv-grey-700);
  font-size: .8rem;
  margin-top: .5rem;
}
.fv-bracket__legend a { color: var(--fv-grey-700); }
.fv-bracket__legend a:hover { color: var(--fv-green); }
.fv-bk-tag--win { color: var(--fv-green); }

@media (max-width: 600px) {
  .fv-bracket { --bk-gap: 26px; }
  .fv-bk-round { min-width: 150px; }
  .fv-bk-team { font-size: .78rem; }
}
