/* ═══════════════════════════════════════
   2026 북중미 월드컵 예측
═══════════════════════════════════════ */

/* ── 포인트 색상 변수 ── */
.wc26-page,
.wc26-stage {
  --wc26-accent:  #16a34a;
  --wc26-dark:    #14532d;
  --wc26-light:   #dcfce7;
  --wc26-mid:     #bbf7d0;
  --wc26-border:  rgba(22, 163, 74, 0.25);
}

.wc26-page { display: flex; flex-direction: column; gap: var(--space-4); }

/* 히어로 뱃지 */
.wc26-hero-note { background: var(--wc26-light) !important; color: var(--wc26-dark) !important; }

/* ── 스테이지 ── */
.wc26-stage { padding: var(--space-5); }
.wc26-stage__content { margin-top: var(--space-4); }

/* ── 스텝바 (박스 없이 플랫) ── */
.wc26-stepbar {
  display: flex; align-items: center; gap: 6px;
  padding: var(--space-2) 0 0;
  overflow-x: auto; scrollbar-width: none;
  margin-top: var(--space-3);
}
.wc26-stepbar::-webkit-scrollbar { display: none; }
.wc26-step {
  flex-shrink: 0; font-size: 0.8rem; font-weight: 600; color: var(--text-secondary);
  padding: 4px 10px; border-radius: 20px; transition: all 0.15s;
}
.wc26-step.is-active  { background: var(--wc26-accent); color: #fff; }
.wc26-step.is-done    { color: var(--wc26-accent); }
.wc26-step-arrow      { color: var(--text-secondary); font-size: 0.9rem; flex-shrink: 0; }

.wc26-phase-footer {
  display: flex; justify-content: space-between; align-items: center; gap: var(--space-3);
  margin-top: var(--space-5); padding-top: var(--space-4); border-top: 1px solid var(--line-soft);
}
.wc26-footer-right { display: flex; align-items: center; gap: var(--space-2); }

/* ═══ 조별예선 ═══ */

/* 전체 12조 그리드: 4열 × 3행 */
.wc26-groups-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

/* 개별 조 블록 */
.wc26-group-block { display: flex; flex-direction: column; gap: var(--space-2); }

.wc26-group-label { font-size: 0.78rem; font-weight: 700; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.05em; margin: 0 0 var(--space-1); }
.wc26-team-list   { display: flex; flex-direction: column; gap: 6px; }
.wc26-team-row {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 10px; border-radius: 10px;
  border: 1.5px solid var(--line-soft); background: var(--surface);
  width: 100%; cursor: pointer; transition: all 0.15s; text-align: left;
}
.wc26-team-row:hover:not(.is-first):not(.is-second):not(.is-third) { border-color: var(--wc26-accent); background: #f0fdf4; }
.wc26-team-row.is-first  { border-color: #ca8a04; background: #fefce8; }
.wc26-team-row.is-second { border-color: #94a3b8; background: #f8fafc; }
.wc26-team-row.is-third  { border-color: #a16207; background: #fef9c3; }
.wc26-team-flag  { font-size: 1.4rem; line-height: 1; flex-shrink: 0; }
.wc26-team-name  { flex: 1; font-weight: 600; font-size: 0.82rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.wc26-rank-badge { flex-shrink: 0; padding: 2px 7px; border-radius: 10px; font-size: 0.68rem; font-weight: 700; }
.wc26-rank-badge--1 { background: #fef08a; color: #713f12; }
.wc26-rank-badge--2 { background: #e2e8f0; color: #475569; }
.wc26-rank-badge--3 { background: #fde68a; color: #92400e; }
.wc26-rank-hint     { font-size: 0.7rem; color: var(--text-secondary); flex-shrink: 0; }
.wc26-rank-hint--out { color: #ef4444; }
.wc26-progress-text  { font-size: 0.85rem; color: var(--text-secondary); font-weight: 500; }

/* ═══ 와일드카드 ═══ */
.wc26-wc-header { text-align: center; margin-bottom: var(--space-4); }
.wc26-wc-title  { font-size: 1.05rem; font-weight: 800; margin: 0 0 6px; }
.wc26-wc-sub    { font-size: 0.83rem; color: var(--text-secondary); margin: 0; }

/* 2컬럼 레이아웃: 시드패널(1/3) + 선택패널(2/3) */
.wc26-wc-layout { display: flex; gap: var(--space-4); align-items: flex-start; margin-bottom: var(--space-4); }
.wc26-seeds-panel { flex: 1; min-width: 0; }
.wc26-pick-panel  { flex: 2; min-width: 0; }

.wc26-seeds-label { font-size: 0.78rem; font-weight: 700; color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.04em; margin-bottom: var(--space-2); }
.wc26-seeds       { display: flex; flex-direction: column; gap: 6px; }

.wc26-seed-slot {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px; border-radius: 10px;
  border: 1.5px solid var(--line-soft); background: var(--surface);
  min-height: 42px;
}
.wc26-seed-slot.is-filled { border-color: var(--wc26-accent); background: #f0fdf4; cursor: pointer; }
.wc26-seed-slot.is-filled:hover { background: var(--wc26-light); }
.wc26-seed-slot.is-empty  { border-style: dashed; opacity: 0.6; }
.wc26-seed-num   { font-size: 0.78rem; font-weight: 800; color: var(--text-secondary); min-width: 18px; }
.wc26-seed-flag  { font-size: 1.4rem; line-height: 1; }
.wc26-seed-name  { flex: 1; font-size: 0.88rem; font-weight: 600; }
.wc26-seed-placeholder { flex: 1; font-size: 0.82rem; color: var(--text-secondary); }
.wc26-seed-remove { font-size: 0.75rem; color: #ef4444; font-weight: 700; padding: 2px 4px; }

.wc26-wc-grid-label { font-size: 0.82rem; color: var(--text-secondary); margin-bottom: var(--space-2); }
.wc26-wc-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
  gap: var(--space-2); margin-bottom: var(--space-2);
}
.wc26-wc-card {
  display: flex; flex-direction: column; align-items: center; gap: 3px;
  padding: 10px 6px; border-radius: 10px;
  border: 1.5px solid var(--line-soft); background: var(--surface);
  cursor: pointer; transition: all 0.15s; position: relative;
}
.wc26-wc-card:hover     { border-color: var(--wc26-accent); background: #f0fdf4; }
.wc26-wc-card.is-picked { border-color: var(--wc26-accent); background: var(--wc26-light); }
.wc26-wc-seed-badge {
  position: absolute; top: 4px; right: 4px;
  background: var(--wc26-dark); color: #fff;
  font-size: 0.65rem; font-weight: 800;
  width: 16px; height: 16px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.wc26-wc-flag  { font-size: 1.6rem; line-height: 1; }
.wc26-wc-name  { font-size: 0.73rem; font-weight: 600; text-align: center; line-height: 1.3; }
.wc26-wc-group { font-size: 0.65rem; color: var(--text-secondary); font-weight: 600; }

/* ═══ 브라켓 트리 ═══ */
.wc26-tree-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; padding-bottom: 8px; }

/* 헤더 */
.wc26-tree-hdrs {
  display: flex; min-width: 1000px;
  margin-bottom: 8px;
}
.wc26-tree-hdr {
  flex: 1; text-align: center;
  font-size: 0.7rem; font-weight: 800; color: var(--text-secondary);
  text-transform: uppercase; letter-spacing: 0.05em;
}
.wc26-tree-hdr--final { color: var(--wc26-dark); }

/* 트리 본체 */
.wc26-tree {
  display: flex; align-items: stretch;
  min-width: 1000px;
}
.wc26-half {
  display: flex; flex: 1;
}
.wc26-half--left  { flex-direction: row; }
.wc26-half--right { flex-direction: row; }

/* 각 라운드 컬럼 */
.wc26-tcol {
  display: flex; flex-direction: column;
  justify-content: space-evenly;
  height: 900px;
}
.wc26-tcol--r32 { flex: 1.1; }
.wc26-tcol--r16 { flex: 1.1; }
.wc26-tcol--qf  { flex: 1.1; }
.wc26-tcol--sf  { flex: 1.1; }

/* pair 그룹 (두 매치를 묶어 브라켓선 연결) */
.wc26-pair {
  display: flex; flex-direction: column;
  flex: 1; position: relative;
  gap: 8px;        /* 같은 pair 내 두 매치 사이 간격 */
  padding: 14px 0; /* 다른 pair와의 시각적 분리 */
}
/* 좌측 절반 — 우측에 브라켓 연결선 */
.wc26-half--left .wc26-pair::after {
  content: '';
  position: absolute;
  right: 0; top: 27%; height: 46%; width: 6px;
  border-top: 1.5px solid #cbd5e1;
  border-right: 1.5px solid #cbd5e1;
  border-bottom: 1.5px solid #cbd5e1;
  pointer-events: none;
}
/* 우측 절반 — 좌측에 브라켓 연결선 */
.wc26-half--right .wc26-pair::after {
  content: '';
  position: absolute;
  left: 0; top: 27%; height: 46%; width: 6px;
  border-top: 1.5px solid #cbd5e1;
  border-left: 1.5px solid #cbd5e1;
  border-bottom: 1.5px solid #cbd5e1;
  pointer-events: none;
}

/* 매치 박스 */
.wc26-bm {
  display: flex; flex-direction: column;
  justify-content: center;
  gap: 5px; flex: 1;
  padding: 6px 8px;
}
/* SF 컬럼: 결승 컬럼 트로피 높이와 정렬 맞춤 (gap ≈ 116px) */
.wc26-tcol--sf .wc26-bm { gap: 116px; }

/* 팀 슬롯 */
.wc26-bslot {
  display: flex; align-items: center; gap: 4px;
  height: 34px; padding: 0 8px; border-radius: 6px;
  border: 1px solid #e5e7eb; background: #fff;
  font-size: 0; /* 자식만 보임 */
  overflow: hidden; cursor: default;
  transition: background 0.12s, border-color 0.12s;
}
.wc26-bslot.is-clickable { cursor: pointer; border-color: #d1d5db; }
.wc26-bslot.is-clickable:hover { background: #f0fdf4; border-color: var(--wc26-accent); }
.wc26-bslot.is-winner    { background: var(--wc26-light); border-color: var(--wc26-accent); }
.wc26-bslot.is-loser     { background: #f9fafb; border-color: #f1f5f9; opacity: 0.4; }
.wc26-bslot.is-tbd       { background: #f9fafb; border-color: #f1f5f9; justify-content: center; }

.wc26-bflag { font-size: 1rem; flex-shrink: 0; }
.wc26-bname { font-size: 0.7rem; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; flex: 1; }
.wc26-bcheck { font-size: 0.65rem; color: var(--wc26-accent); font-weight: 800; flex-shrink: 0; }

/* 결승 컬럼 */
.wc26-final-col {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; gap: var(--space-3);
  padding: 0 8px; min-width: 100px;
}
.wc26-final-team {
  width: 100%; justify-content: center;
  border-width: 1.5px; border-radius: 8px;
  height: 36px;
}
.wc26-final-team .wc26-bname { font-size: 0.75rem; text-align: center; }

/* 트로피 + 우승팀 */
.wc26-trophy-wrap {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  padding: var(--space-3) var(--space-2);
  background: linear-gradient(135deg, #fef9c3, #fde68a);
  border: 2px solid #fbbf24; border-radius: 12px;
  text-align: center; min-width: 90px;
}
.wc26-trophy-empty { background: #f9fafb; border-color: #e5e7eb; opacity: 0.6; }
.wc26-trophy-icon  { font-size: 1.8rem; }
.wc26-champ-flag   { font-size: 2rem; }
.wc26-champ-name   { font-size: 0.72rem; font-weight: 800; color: #92400e; line-height: 1.3; }
.wc26-trophy-empty .wc26-champ-name { color: var(--text-secondary); }

/* disabled 버튼 */
.btn--disabled { opacity: 0.35; cursor: not-allowed; pointer-events: none; }

/* 반응형 */
@media (max-width: 900px) {
  .wc26-groups-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 520px) {
  .wc26-stage { padding: var(--space-3); }
  .wc26-groups-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-3); }
  .wc26-phase-footer { flex-direction: column-reverse; align-items: stretch; }
  .wc26-phase-footer .btn { width: 100%; justify-content: center; }
  .wc26-footer-right { flex-direction: column-reverse; align-items: stretch; }
  .wc26-footer-right .btn { width: 100%; justify-content: center; }
  .wc26-wc-layout { flex-direction: column; }
  .wc26-wc-grid { grid-template-columns: repeat(auto-fill, minmax(84px, 1fr)); }
}
