/* ═══════════════════════════════════════════════
   COACH RANKS — badges + progression gauge
   ═══════════════════════════════════════════════ */

.rank-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  vertical-align: middle;
  line-height: 1;
}

.rank-badge-img {
  display: block;
  filter: drop-shadow(0 2px 3px rgba(0, 0, 0, 0.15));
}

.rank-badge-label {
  font-weight: 700;
  font-size: 0.78rem;
  letter-spacing: 0.02em;
  white-space: nowrap;
}

/* ── Gauge card (dashboard) ──────────────────── */
.rank-gauge-card {
  --rank-color: var(--accent);
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.5rem 1.75rem;
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
  box-shadow: var(--shadow-sm);
}

.rank-gauge-head {
  display: flex;
  align-items: center;
  gap: 1.1rem;
}

.rank-gauge-learn {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--rank-color, var(--accent));
  text-decoration: none;
  padding: 0.45rem 0.75rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  transition: background 0.15s, border-color 0.15s;
  white-space: nowrap;
}

.rank-gauge-learn:hover {
  background: var(--bg-soft, rgba(0, 0, 0, 0.03));
  border-color: var(--rank-color, var(--accent));
}

@media (max-width: 560px) {
  .rank-gauge-head { flex-wrap: wrap; }
  .rank-gauge-learn { margin-left: 0; margin-top: 0.5rem; width: 100%; justify-content: center; }
}

.rank-gauge-icon {
  flex-shrink: 0;
  filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.18));
}

.rank-gauge-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.rank-gauge-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.rank-gauge-name {
  font-family: 'Outfit', sans-serif;
  font-size: 1.45rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--rank-color);
  line-height: 1.1;
}

.rank-gauge-count {
  font-size: 0.85rem;
  color: var(--text-soft);
  margin-top: 2px;
}

.rank-gauge-bar {
  position: relative;
  height: 10px;
  border-radius: 99px;
  background: var(--bg-elevated);
  overflow: hidden;
}

.rank-gauge-fill {
  height: 100%;
  border-radius: 99px;
  background: linear-gradient(90deg, var(--rank-color), var(--accent));
  transition: width 0.9s cubic-bezier(.2, .7, .2, 1);
  box-shadow: 0 0 0 1px rgba(124, 58, 237, 0.15);
}

.rank-gauge-next {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.85rem;
  color: var(--text-soft);
  flex-wrap: wrap;
}

.rank-gauge-next-icon {
  flex-shrink: 0;
  opacity: 0.55;
}

.rank-gauge-next-label {
  color: var(--text-soft);
}

.rank-gauge-next-label strong {
  color: var(--text);
}

.rank-gauge-remaining {
  margin-left: auto;
  font-weight: 700;
  font-size: 0.82rem;
  color: var(--rank-color);
  background: var(--accent-subtle);
  padding: 0.25rem 0.65rem;
  border-radius: 99px;
}

.rank-gauge-max {
  justify-content: center;
  font-weight: 700;
  color: var(--rank-color);
  padding: 0.5rem 0;
}

.rank-gauge-max svg {
  color: var(--rank-color);
}

/* ── Coach card variant ──────────────────────── */
.coach-name-with-rank {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

/* ── Header variant ──────────────────────────── */
.nav-rank-badge {
  display: inline-flex;
  vertical-align: middle;
  margin-left: 4px;
}

/* ── Coach card : tag coloré (pill) ──────────── */
.coach-card-badge.rank-tag {
  background: color-mix(in srgb, var(--rank-color) 14%, transparent);
  color: var(--rank-color);
  border: 1px solid color-mix(in srgb, var(--rank-color) 35%, transparent);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-weight: 700;
}

.coach-card-badge.rank-tag .rank-tag-icon {
  display: block;
}

/* ── Coach card : pastille sur avatar ────────── */
.coach-card-avatar-wrap {
  position: relative;
  flex-shrink: 0;
}

.rank-avatar-dot {
  position: absolute;
  right: -4px;
  bottom: -4px;
  border-radius: 50%;
  background: var(--bg-card, #fff);
  border: 2px solid var(--bg-card, #fff);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--rank-color) 40%, transparent), 0 2px 6px rgba(0, 0, 0, 0.08);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.rank-avatar-dot img {
  display: block;
}

@media (max-width: 560px) {
  .rank-gauge-card { padding: 1.25rem; }
  .rank-gauge-name { font-size: 1.2rem; }
  .rank-gauge-remaining { margin-left: 0; }
}

/* ── Coach card rank styling ───────────────────── */

/* Silver */
.coach-card.coach-card-rank-silver {
  border-color: #b0bec5;
  background: linear-gradient(170deg, #e8edf1 0%, var(--bg-card) 50%);
  box-shadow: 0 2px 10px -2px rgba(148,163,184,0.25);
}
.coach-card.coach-card-rank-silver:hover {
  border-color: #94a3b8;
  box-shadow: 0 6px 24px -4px rgba(148,163,184,0.35);
}
.coach-card.coach-card-rank-silver .coach-card-avatar {
  background: linear-gradient(135deg, #cfd8dc, #eceff1);
  border-color: #b0bec5;
}

/* Gold */
.coach-card.coach-card-rank-gold {
  border-width: 2px;
  border-color: #e4b23a;
  background: linear-gradient(170deg, #fdf6e3 0%, #fef9ee 40%, var(--bg-card) 70%);
  box-shadow:
    0 0 0 1px rgba(228,178,58,0.12),
    0 4px 18px -2px rgba(228,178,58,0.22);
}
.coach-card.coach-card-rank-gold:hover {
  border-color: #d4a017;
  box-shadow:
    0 0 0 2px rgba(228,178,58,0.18),
    0 8px 30px -4px rgba(228,178,58,0.35);
  transform: translateY(-4px);
}
.coach-card.coach-card-rank-gold .coach-card-avatar {
  background: linear-gradient(135deg, #f5dfa0, #fef3d0);
  border-color: #e4b23a;
  color: #8b6914;
}
.coach-card.coach-card-rank-gold .coach-name {
  color: #8b6914;
}

/* Platinum */
.coach-card.coach-card-rank-platinum {
  border-width: 2px;
  border-color: #17c4a0;
  background: linear-gradient(170deg, #e6faf5 0%, #f0fdf9 40%, var(--bg-card) 70%);
  box-shadow:
    0 0 0 1px rgba(23,196,160,0.12),
    0 4px 20px -2px rgba(23,196,160,0.2);
  position: relative;
}
.coach-card.coach-card-rank-platinum:hover {
  border-color: #0fa984;
  box-shadow:
    0 0 0 2px rgba(23,196,160,0.2),
    0 8px 32px -4px rgba(23,196,160,0.35);
  transform: translateY(-5px);
}
.coach-card.coach-card-rank-platinum .coach-card-avatar {
  background: linear-gradient(135deg, #6ee7c2, #b2f5ea);
  border-color: #17c4a0;
  color: #065f46;
}
.coach-card.coach-card-rank-platinum .coach-name {
  color: #0d9474;
}

/* Legend — max prestige */
.coach-card.coach-card-rank-legend {
  border-width: 2px;
  border-color: #7c3aed;
  background:
    linear-gradient(170deg, #ede5ff 0%, #f3eeff 35%, #faf8ff 60%, var(--bg-card) 80%);
  box-shadow:
    0 0 0 2px rgba(124,58,237,0.12),
    0 6px 28px -4px rgba(124,58,237,0.25);
  position: relative;
  overflow: hidden;
}
.coach-card.coach-card-rank-legend::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, #7c3aed, #a78bfa, #c4b5fd, #a78bfa, #7c3aed);
  background-size: 200% 100%;
  animation: rank-legend-shimmer 3s linear infinite;
}
@keyframes rank-legend-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
.coach-card.coach-card-rank-legend:hover {
  border-color: #6d28d9;
  box-shadow:
    0 0 0 3px rgba(124,58,237,0.15),
    0 10px 40px -4px rgba(124,58,237,0.35);
  transform: translateY(-6px);
}
.coach-card.coach-card-rank-legend .coach-card-avatar {
  background: linear-gradient(135deg, #b197fc, #ddd6fe);
  border-color: #7c3aed;
  color: #4c1d95;
  box-shadow: 0 0 12px rgba(124,58,237,0.3);
}
.coach-card.coach-card-rank-legend .coach-name {
  color: #6d28d9;
}
