/* ── compare.css — Page Head-to-Head HexLobby ────────────────────────────── */

/* ── Hero / Formulaire ───────────────────────────────────────────────────── */
.cmp-hero {
  padding      : 3.5rem 0 2.5rem;
  border-bottom: 1px solid var(--border);
}
.cmp-title {
  font-size  : 2.2rem;
  font-weight: 900;
  color      : var(--text);
  margin     : 0 0 .5rem;
}
.cmp-sub {
  color    : var(--text-muted);
  font-size: 1rem;
  margin-bottom: 2rem;
}

/* Formulaire de sélection */
.cmp-form {
  display    : flex;
  align-items: flex-end;
  gap        : 1rem;
  flex-wrap  : wrap;
}
.cmp-form-slot {
  display       : flex;
  flex-direction: column;
  gap           : .4rem;
  flex          : 1;
  min-width     : 220px;
}
.cmp-form-label {
  font-size  : .78rem;
  font-weight: 700;
  color      : var(--text-muted);
  letter-spacing: .06em;
  text-transform: uppercase;
}
.cmp-vs-sep {
  font-size  : 1.5rem;
  padding-bottom: .25rem;
  flex-shrink: 0;
  opacity    : .7;
}
.cmp-input {
  width        : 100%;
  padding      : .7rem 1rem;
  background   : var(--bg-card);
  border       : 1px solid var(--border);
  border-radius: .65rem;
  color        : var(--text);
  font-size    : .9rem;
  outline      : none;
  transition   : border-color .2s;
}
.cmp-input:focus { border-color: rgba(129,140,248,.5); }
.cmp-btn { flex-shrink: 0; height: 44px; align-self: flex-end; }
.cmp-error {
  margin-top: 1rem;
  color     : #f87171;
  font-size : .88rem;
}

/* Autocomplete dropdown */
.cmp-autocomplete-wrap { position: relative; }
.cmp-dropdown {
  position  : absolute;
  top       : calc(100% + 4px);
  left      : 0; right: 0;
  background: var(--bg-card);
  border    : 1px solid var(--border);
  border-radius: .65rem;
  z-index   : 200;
  overflow  : hidden;
  display   : none;
  box-shadow: 0 8px 24px rgba(0,0,0,.4);
}
.cmp-drop-open { display: block; }
.cmp-drop-item {
  display    : flex;
  align-items: center;
  gap        : .65rem;
  padding    : .6rem .9rem;
  cursor     : pointer;
  transition : background .12s;
}
.cmp-drop-item img {
  width        : 28px;
  height       : 28px;
  border-radius: 50%;
  object-fit   : cover;
  flex-shrink  : 0;
}
.cmp-drop-item:hover, .cmp-drop-focus { background: rgba(129,140,248,.1); }
.cmp-drop-name { flex: 1; font-size: .88rem; font-weight: 600; color: var(--text); }
.cmp-drop-mmr  { font-size: .75rem; color: var(--text-muted); flex-shrink: 0; }

/* ── Section alt ─────────────────────────────────────────────────────────── */
.cmp-section-dark { background: rgba(255,255,255,.018); }
.cmp-section-title {
  font-size    : 1.4rem;
  font-weight  : 800;
  color        : var(--text);
  margin-bottom: 1.5rem;
}

/* ── Cartes joueurs + score ──────────────────────────────────────────────── */
.cmp-players-section { padding: 3rem 0; }
.cmp-players-row {
  display        : flex;
  align-items    : center;
  justify-content: center;
  gap            : 1.5rem;
  flex-wrap      : wrap;
}

.cmp-player-card {
  display       : flex;
  flex-direction: column;
  align-items   : center;
  gap           : .5rem;
  padding       : 1.75rem 2rem;
  background    : var(--bg-card);
  border        : 1px solid var(--border);
  border-radius : 1rem;
  text-decoration: none;
  transition    : border-color .2s, transform .15s;
  flex          : 1;
  max-width     : 220px;
  min-width     : 160px;
}
.cmp-player-card:hover { border-color: rgba(129,140,248,.35); transform: translateY(-3px); }
.cmp-card-a:hover { border-color: rgba(129,140,248,.5); }
.cmp-card-b:hover { border-color: rgba(251,191,36,.4); }

.cmp-avatar {
  width        : 72px;
  height       : 72px;
  border-radius: 50%;
  object-fit   : cover;
  border       : 3px solid var(--border);
}
.cmp-card-a .cmp-avatar { border-color: rgba(129,140,248,.5); }
.cmp-card-b .cmp-avatar { border-color: rgba(251,191,36,.4); }

.cmp-player-name {
  font-size  : 1rem;
  font-weight: 800;
  color      : var(--text);
  text-align : center;
}
.cmp-player-mmr {
  font-size  : 1.5rem;
  font-weight: 900;
  color      : var(--text);
}
.cmp-player-mmr span { font-size: .8rem; font-weight: 500; color: var(--text-muted); }
.cmp-player-rank {
  font-size: .78rem;
  color    : var(--text-muted);
}

/* Score H2H central */
.cmp-score-block {
  text-align: center;
  flex-shrink: 0;
  min-width  : 140px;
}
.cmp-score-row {
  display    : flex;
  align-items: center;
  gap        : .5rem;
  justify-content: center;
}
.cmp-score-num {
  font-size  : 3.5rem;
  font-weight: 900;
  color      : var(--text-muted);
  line-height: 1;
  transition : color .2s;
}
.cmp-score-winner { color: var(--text); }
.cmp-score-a.cmp-score-winner { color: #818cf8; }
.cmp-score-b.cmp-score-winner { color: #fbbf24; }
.cmp-score-dash {
  font-size  : 2rem;
  color      : var(--border);
  font-weight: 300;
}
.cmp-score-label {
  font-size : .78rem;
  color     : var(--text-muted);
  margin-top: .4rem;
}
.cmp-score-ties { font-size: .72rem; color: var(--text-muted); opacity: .6; margin-top: .2rem; }
.cmp-score-nodata {
  font-size : .9rem;
  color     : var(--text-muted);
  line-height: 1.5;
}

/* ── Tableau de stats ────────────────────────────────────────────────────── */
.cmp-stat-table {
  display       : flex;
  flex-direction: column;
  gap           : .5rem;
}
.cmp-stat-row {
  display        : grid;
  grid-template-columns: 1fr auto 1fr;
  align-items    : center;
  gap            : 1rem;
  padding        : .7rem 1.25rem;
  background     : var(--bg-card);
  border         : 1px solid var(--border);
  border-radius  : .65rem;
}
.cmp-stat-label {
  font-size  : .82rem;
  color      : var(--text-muted);
  text-align : center;
  white-space: nowrap;
}
.cmp-stat-val {
  font-size  : 1rem;
  font-weight: 700;
  color      : var(--text-muted);
  transition : color .2s;
}
.cmp-stat-a { text-align: right; }
.cmp-stat-b { text-align: left; }
.cmp-stat-best { color: var(--text); }
.cmp-stat-a.cmp-stat-best { color: #818cf8; }
.cmp-stat-b.cmp-stat-best { color: #fbbf24; }

/* ── Stats H2H ───────────────────────────────────────────────────────────── */
.cmp-h2h-stats {
  display              : grid;
  grid-template-columns: 1fr 1.2fr;
  gap                  : 1.5rem;
  align-items          : start;
}
@media (max-width: 760px) { .cmp-h2h-stats { grid-template-columns: 1fr; } }

.cmp-h2h-table { align-self: start; }

/* Distribution placements */
.cmp-placement-wrap {
  background   : var(--bg-card);
  border       : 1px solid var(--border);
  border-radius: .85rem;
  padding      : 1.25rem;
}
.cmp-placement-title {
  font-size    : .82rem;
  font-weight  : 700;
  color        : var(--text-muted);
  margin-bottom: 1rem;
}
.cmp-placement-chart {
  display    : flex;
  align-items: flex-end;
  gap        : .5rem;
  height     : 120px;
}
.cmp-pd-col {
  flex          : 1;
  display       : flex;
  flex-direction: column;
  align-items   : center;
  height        : 100%;
}
.cmp-pd-bars {
  flex    : 1;
  width   : 100%;
  display : flex;
  align-items: flex-end;
  gap     : 2px;
  justify-content: center;
}
.cmp-pd-bar {
  width        : 45%;
  border-radius: 3px 3px 0 0;
  min-height   : 0;
  transition   : height .5s ease;
}
.cmp-pd-a { background: rgba(129,140,248,.7); }
.cmp-pd-b { background: rgba(251,191,36,.7); }
.cmp-pd-label {
  font-size : .72rem;
  color     : var(--text-muted);
  margin-top: .3rem;
  font-weight: 700;
}
.cmp-pd-legend {
  display    : flex;
  align-items: center;
  gap        : .3rem;
  font-size  : .75rem;
  color      : var(--text-muted);
  margin-top : .75rem;
}
.cmp-pd-dot {
  display      : inline-block;
  width        : 10px;
  height       : 10px;
  border-radius: 2px;
}
.cmp-pd-a-dot { background: rgba(129,140,248,.8); }
.cmp-pd-b-dot { background: rgba(251,191,36,.8); }

/* ── Feed confrontations ─────────────────────────────────────────────────── */
.cmp-matches { display: flex; flex-direction: column; gap: .4rem; }
.cmp-matches-head {
  display              : grid;
  grid-template-columns: 1fr auto 1fr;
  padding              : 0 1rem .5rem;
  font-size            : .78rem;
  font-weight          : 700;
  color                : var(--text-muted);
  letter-spacing       : .05em;
  text-transform       : uppercase;
}
.cmp-mh-a { text-align: right; color: rgba(129,140,248,.8); }
.cmp-mh-b { text-align: left;  color: rgba(251,191,36,.8); }
.cmp-mh-center { text-align: center; }

.cmp-match-row {
  display              : grid;
  grid-template-columns: 1fr auto 1fr;
  align-items          : center;
  gap                  : .75rem;
  padding              : .75rem 1rem;
  background           : var(--bg-card);
  border               : 1px solid var(--border);
  border-radius        : .7rem;
  text-decoration      : none;
  transition           : border-color .2s, transform .12s;
}
.cmp-match-row:hover { border-color: rgba(255,255,255,.2); transform: scale(1.005); }

.cmp-match-side {
  display    : flex;
  align-items: center;
  gap        : .6rem;
  padding    : .3rem .5rem;
  border-radius: .5rem;
  transition : background .2s;
}
.cmp-match-side-a {
  justify-content: flex-end;
  text-align     : right;
}
.cmp-match-side-b { justify-content: flex-start; }

.cmp-side-win  { background: rgba(52,211,153,.08); }
.cmp-side-loss { background: rgba(248,113,113,.06); }
.cmp-side-tie  { background: rgba(255,255,255,.03); }

.cmp-match-place {
  font-size : 1rem;
  flex-shrink: 0;
}
.cmp-match-delta {
  font-size  : .82rem;
  font-weight: 700;
  flex-shrink: 0;
}
.cmp-match-mmr {
  font-size : .78rem;
  color     : var(--text-muted);
  flex-shrink: 0;
  font-variant-numeric: tabular-nums;
}
.delta-pos { color: #34d399; }
.delta-neg { color: #f87171; }

.cmp-match-center {
  display       : flex;
  flex-direction: column;
  align-items   : center;
  gap           : .15rem;
  flex-shrink   : 0;
}
.cmp-match-id {
  font-size  : .72rem;
  font-weight: 700;
  color      : var(--accent);
}
.cmp-match-date {
  font-size: .68rem;
  color    : var(--text-muted);
}
.cmp-match-outcome {
  font-size  : .65rem;
  font-weight: 700;
  padding    : .1rem .35rem;
  border-radius: .3rem;
}
.cmp-outcome-a { color: #818cf8; background: rgba(129,140,248,.12); }
.cmp-outcome-b { color: #fbbf24; background: rgba(251,191,36,.1); }
.cmp-outcome-tie { color: var(--text-muted); background: rgba(255,255,255,.05); }

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 640px) {
  .cmp-title       { font-size: 1.5rem; }
  .cmp-score-num   { font-size: 2.5rem; }
  .cmp-match-mmr   { display: none; }
  .cmp-form        { flex-direction: column; }
  .cmp-vs-sep      { text-align: center; }
  .cmp-stat-row    { grid-template-columns: 1fr auto 1fr; gap: .5rem; padding: .6rem .75rem; }
}
