/* === Bracket viz (WVIZ-144) ===
   Knockout bracket rendered as horizontally-scrolling columns of
   matches, left-to-right by round. HTML/CSS-based — no SVG. Each
   round is a column; matches stack vertically. Connector lines
   between rounds are implied by column position. */

.bracket-wrap {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--space-4);
  overflow-x: auto;
}

.bracket-wrap:focus-visible {
  outline: 2px solid var(--color-link);
  outline-offset: -2px;
}

.bracket {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(220px, 1fr);
  gap: var(--space-4);
  margin: 0;
  padding: 0;
  list-style: none;
  min-width: max-content;
}

.bracket__round {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.bracket__round-title {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-display);
  margin: 0 0 var(--space-2);
  color: var(--color-text);
  text-align: center;
}

.bracket__matches {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  flex: 1;
  justify-content: space-around;
  list-style: none;
  margin: 0;
  padding: 0;
}

.bracket__match {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  font-family: var(--font-tabular);
  font-size: var(--fs-body-sm);
}

.bracket__match--empty {
  background: transparent;
  border-style: dashed;
}

.bracket__match--tbd {
  opacity: 0.7;
}

.bracket__empty-note {
  color: var(--color-text-muted);
  font-size: var(--fs-body-sm);
  margin: 0;
  text-align: center;
}

.bracket__team {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) 0;
  color: var(--color-text-muted);
}

.bracket__team + .bracket__team {
  border-top: 1px solid color-mix(in srgb, var(--color-border) 50%, transparent);
}

.bracket__team--winner {
  color: var(--color-text);
  font-weight: var(--fw-semibold);
}

.bracket__team-logo {
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  object-fit: contain;
}

.bracket__team-name {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.bracket__team-score {
  font-variant-numeric: tabular-nums;
  font-weight: var(--fw-bold);
  min-width: 1.2em;
  text-align: right;
}

.bracket__agg {
  margin-top: var(--space-2);
  font-size: var(--fs-caption);
  font-variant-numeric: tabular-nums;
  color: var(--color-text-muted);
  text-align: right;
}

.bracket__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-2);
  padding-top: var(--space-2);
  border-top: 1px dashed color-mix(in srgb, var(--color-border) 60%, transparent);
  font-size: var(--fs-caption);
  color: var(--color-text-muted);
}

.bracket__date {
  font-variant-numeric: tabular-nums;
}

.bracket__venue {
  flex: 1;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Placeholder for non-knockout contexts. */
.bracket-placeholder {
  max-width: 600px;
  margin: var(--space-12) auto;
  padding: var(--space-6) var(--space-4);
  text-align: center;
}

.bracket-placeholder__body {
  color: var(--color-text-muted);
  font-size: var(--fs-body);
  margin: 0;
}
