/* === Roster Page === */

/* Filter Bar */
.roster-filters {
  position: sticky;
  top: var(--header-height);
  z-index: var(--z-sticky);
  background: var(--color-bg-secondary);
  border-bottom: 1px solid var(--color-border);
  padding: var(--space-4) 0;
  backdrop-filter: blur(12px);
}

.roster-filters__inner {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.roster-filters__search {
  flex: 1 1 220px;
  min-width: 180px;
}

.roster-filters__search .form-input {
  width: 100%;
}

.roster-filters__selects {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
  flex: 2 1 auto;
}

.roster-filters__selects .form-select {
  flex: 1 1 150px;
  min-width: 140px;
}

.roster-filters__count {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  white-space: nowrap;
  font-weight: 500;
}

.roster-filters__count span {
  color: var(--color-accent-primary);
  font-weight: 700;
}

/* Member Cards */
.member-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: var(--space-8) var(--space-6);
  gap: var(--space-3);
}

.member-card__avatar {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: var(--color-bg-elevated);
  border: 2px solid var(--color-accent-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  font-weight: 700;
  color: var(--color-accent-primary);
  flex-shrink: 0;
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.member-card__avatar--has-image {
  overflow: hidden;
  padding: 0;
}

.member-card__avatar--has-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}

.member-card:hover .member-card__avatar {
  box-shadow: 0 0 18px rgba(0, 180, 216, 0.4);
  transform: scale(1.05);
}

.member-card__name {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-text-heading);
  margin: 0;
}

.member-card__details {
  display: flex;
  justify-content: center;
}

.member-card__info {
  display: flex;
  gap: var(--space-4);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}

.member-card__info span {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}

.member-card__joined {
  font-size: var(--text-xs);
  color: var(--color-metallic-dark);
  margin-top: auto;
  padding-top: var(--space-2);
}

/* Loading State */
.roster-loading {
  display: flex;
  justify-content: center;
  padding: var(--space-16) 0;
}

/* Empty State */
.roster-empty {
  text-align: center;
  padding: var(--space-16) 0;
}

.roster-empty p {
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
}

/* Responsive */
@media (max-width: 1024px) {
  .roster-filters__inner {
    flex-direction: column;
    align-items: stretch;
  }

  .roster-filters__search {
    flex: 1 1 100%;
  }

  .roster-filters__selects {
    flex: 1 1 100%;
  }

  .roster-filters__count {
    text-align: center;
  }
}

@media (max-width: 768px) {
  .roster-filters__selects .form-select {
    flex: 1 1 calc(50% - var(--space-3));
    min-width: 0;
  }

  .member-card {
    padding: var(--space-6) var(--space-4);
  }

  .member-card__avatar {
    width: 60px;
    height: 60px;
    font-size: var(--text-xl);
  }
}

@media (max-width: 480px) {
  .roster-filters__selects .form-select {
    flex: 1 1 100%;
  }

  .member-card__info {
    flex-direction: column;
    gap: var(--space-1);
  }
}
