/* pages/team.css - 球队管理页面 Premium */
.team-header {
  text-align: center;
  padding: var(--sp-4) 0 var(--sp-3);
}
.team-name {
  font-size: 22px;
  font-weight: 800;
  color: var(--green-primary);
  letter-spacing: 0.5px;
}
.team-info {
  display: flex;
  justify-content: center;
  gap: var(--sp-4);
  margin-top: var(--sp-2);
  font-size: 12px;
  color: var(--gray-500);
}
.team-info span {
  display: flex;
  align-items: center;
  gap: 4px;
}

/* 阵容 */
.formation-selector {
  display: flex; gap: var(--sp-2); margin-bottom: var(--sp-3);
}
.formation-selector select { flex: 1; }

.pitch {
  position: relative;
  background: linear-gradient(180deg, #1b5e20 0%, #2e7d32 20%, #388e3c 40%, #2e7d32 60%, #1b5e20 80%, #2e7d32 100%);
  border-radius: var(--radius-lg);
  height: 420px;
  margin: 0 auto var(--sp-4);
  overflow: hidden;
  box-shadow: inset 0 0 40px rgba(0,0,0,0.2), var(--shadow-md);
}
.pitch::before {
  content: '';
  position: absolute; inset: 8px;
  border: 1.5px solid rgba(255,255,255,0.2);
  border-radius: calc(var(--radius-lg) - 8px);
}
.pitch::after {
  content: '';
  position: absolute;
  top: 50%; left: 10%; right: 10%;
  height: 1px;
  background: rgba(255,255,255,0.15);
}
.pitch-label {
  position: absolute; top: 8px; left: 50%;
  transform: translateX(-50%);
  color: rgba(255,255,255,0.35); font-size: 10px; font-weight: 600;
  letter-spacing: 1px; text-transform: uppercase;
}
.pitch-slot {
  position: absolute; z-index: 1; width: 64px; text-align: center;
  transition: transform var(--duration-normal) var(--ease-spring);
}
.pitch-player {
  background: var(--bg-card);
  border-radius: var(--radius-sm);
  padding: 4px 2px;
  box-shadow: 0 3px 8px rgba(0,0,0,0.25);
  cursor: pointer;
  transition: transform var(--duration-fast) var(--ease-bounce), box-shadow var(--duration-fast);
  border: 1px solid rgba(255,255,255,0.3);
}
.pitch-player:active { transform: scale(1.1); }
.pitch-player-name {
  display: block; font-size: 10px; font-weight: 700;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  color: var(--gray-800);
}
.pitch-player-rating {
  display: block; font-size: 13px; font-weight: 800;
  text-align: center; color: var(--gray-700);
}
.pitch-player-pos {
  display: block; font-size: 9px; color: var(--gray-400);
  text-align: center;
}
.pitch-slot-empty {
  background: rgba(255,255,255,0.1);
  border-radius: var(--radius-sm);
  padding: 4px 2px;
  border: 1px dashed rgba(255,255,255,0.2);
}
.slot-pos {
  display: block; font-size: 13px; font-weight: 800;
  color: rgba(255,255,255,0.6);
}
.slot-pos-name {
  display: block; font-size: 9px; color: rgba(255,255,255,0.35);
}
.pitch-player.green { border-bottom: 2px solid #2e7d32; }
.pitch-player.yellow { border-bottom: 2px solid #f57f17; }
.pitch-player.blue { border-bottom: 2px solid #1565c0; }
.pitch-player.purple { border-bottom: 2px solid #6a1b9a; }
.pitch-player.red { border-bottom: 2px solid #c62828; }

/* 替补 */
.subs-section { margin-top: var(--sp-3); }
.subs-list { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.sub-player {
  background: var(--bg-card);
  border-radius: var(--radius-sm);
  padding: var(--sp-1) var(--sp-2);
  display: flex; align-items: center; gap: var(--sp-2);
  cursor: pointer; font-size: 12px;
  border: 1px solid var(--gray-200);
  transition: all var(--duration-fast);
}
.sub-player:active { transform: scale(0.97); }
.sub-name { font-weight: 600; }
.sub-rating { font-weight: 800; }
.sub-pos { color: var(--gray-500); font-weight: 600; }

/* 球员详情弹窗 */
.player-detail { }
.detail-header {
  display: flex; align-items: center; gap: var(--sp-3);
  margin-bottom: var(--sp-4);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--gray-100);
}
.detail-pos {
  width: 44px; height: 44px; border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
  color: white; font-weight: 800; font-size: 15px;
  box-shadow: 0 3px 8px rgba(0,0,0,0.2);
}
.detail-name { font-size: 18px; font-weight: 800; }
.detail-meta { font-size: 12px; color: var(--gray-500); margin-top: 2px; }
.detail-rating {
  width: 52px; height: 52px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: white; font-size: 20px; font-weight: 800;
  box-shadow: 0 3px 8px rgba(0,0,0,0.2);
  margin-left: auto;
}
.detail-stats {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-2); margin-bottom: var(--sp-4);
  padding: var(--sp-3); background: var(--gray-50);
  border-radius: var(--radius-md);
}
.stat-item { text-align: center; }
.stat-item span { display: block; font-size: 11px; color: var(--gray-500); }
.stat-item strong { font-size: 18px; font-weight: 800; }
.detail-status { margin-bottom: var(--sp-3); }
.status-flags {
  display: flex; gap: var(--sp-2); margin-top: var(--sp-2);
  font-size: 12px; flex-wrap: wrap;
}
.flag.injured { color: #d32f2f; font-weight: 600; }
.flag.suspended { color: #e65100; font-weight: 600; }
.detail-attributes { margin-top: var(--sp-3); }
.detail-attributes h4 { font-size: 14px; margin-bottom: var(--sp-2); }

/* 战术 */
.tactics-container { }
.tactic-item {
  display: flex; justify-content: space-between; align-items: center;
  padding: var(--sp-3) 0;
  border-bottom: 1px solid var(--gray-100);
}
.tactic-item:last-child { border-bottom: none; }
.tactic-label { font-size: 14px; font-weight: 600; min-width: 60px; }
.tactic-options { display: flex; gap: 4px; flex-wrap: wrap; justify-content: flex-end; }
.tactic-options .btn { font-size: 11px; padding: 5px 10px; transition: all 0.2s ease; }

/* 战术选中态 - 醒目色块高亮 */
.tactic-options .tactic-active {
  background: linear-gradient(135deg, #1b5e20, #2e7d32) !important;
  color: #fff !important;
  border: 1.5px solid #1b5e20 !important;
  box-shadow: 0 2px 8px rgba(27, 94, 32, 0.35);
  font-weight: 700;
  transform: scale(1.02);
}
.tactic-options .tactic-option {
  background: var(--gray-100);
  color: var(--gray-600);
  border: 1.5px solid var(--gray-200);
  opacity: 0.75;
}
.tactic-options .tactic-option:active {
  opacity: 1;
  transform: scale(0.97);
}

/* 球员列表 */
.roster-filters { display: flex; gap: var(--sp-2); margin-bottom: var(--sp-3); }
.roster-filters select { flex: 1; }
.player-card-list { }

/* ==================== 更换球员 ==================== */
.replace-player-panel { padding: 0; }
.replace-header-info {
  padding: var(--sp-2) var(--sp-3);
  background: linear-gradient(135deg, #e3f2fd, #bbdefb);
  border-radius: var(--radius-md);
  margin-bottom: var(--sp-2);
  font-size: 13px;
  color: var(--gray-700);
}
.replace-header-info strong { color: var(--gray-800); }
.replace-hint {
  font-size: 12px;
  color: var(--gray-500);
  margin-bottom: var(--sp-2);
  padding-left: 4px;
}
.replace-candidate-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
  max-height: 320px;
  overflow-y: auto;
}
.replace-candidate {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--sp-2) var(--sp-3);
  background: var(--bg-card);
  border-radius: var(--radius-md);
  border: 1px solid var(--gray-200);
  cursor: pointer;
  transition: all var(--duration-fast);
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}
.replace-candidate:active {
  transform: scale(0.98);
  background: var(--primary-light, #e3f2fd);
  border-color: var(--primary, #1565c0);
}
.candidate-info {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}
.candidate-pos {
  font-size: 11px;
  font-weight: 800;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  background: var(--gray-100);
  color: var(--gray-600);
}
.candidate-pos.exact {
  background: #c8e6c9;
  color: #1b5e20;
}
.candidate-pos.compatible {
  background: #fff3e0;
  color: #e65100;
}
.candidate-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--gray-800);
}
.candidate-rating {
  font-size: 16px;
  font-weight: 900;
  color: var(--gray-700);
  margin-left: var(--sp-1);
}
.candidate-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  color: var(--gray-500);
}
.exact-badge {
  font-size: 10px;
  padding: 1px 6px;
  background: #c8e6c9;
  color: #1b5e20;
  border-radius: var(--radius-sm);
  font-weight: 700;
}
.compatible-badge {
  font-size: 10px;
  padding: 1px 6px;
  background: #fff3e0;
  color: #e65100;
  border-radius: var(--radius-sm);
  font-weight: 600;
}
.other-badge {
  font-size: 10px;
  padding: 1px 6px;
  background: #f3e5f5;
  color: #7b1fa2;
  border-radius: var(--radius-sm);
  font-weight: 600;
}
.candidate-pos.other {
  background: #f3e5f5;
  color: #7b1fa2;
}
.replace-empty {
  text-align: center;
  padding: var(--sp-4);
  color: var(--gray-400);
  font-size: 13px;
}
.replace-candidate.disabled {
  opacity: 0.55;
  border-color: #ef9a9a;
  background: #fff5f5;
  cursor: not-allowed;
  pointer-events: auto;
}
.replace-candidate.disabled:active {
  transform: none;
  background: #fff5f5;
  border-color: #ef9a9a;
}
.candidate-unavail {
  display: block;
  width: 100%;
  font-size: 10px;
  color: #c62828;
  font-weight: 600;
  margin-top: 3px;
  padding-left: 2px;
}
