/* ═══════════════════════════════════════════════════════════════
   BAND MEMBERS — card & form styles
   ═══════════════════════════════════════════════════════════════ */

.members-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.member-card {
  background: var(--surface2, #16213e);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 8px;
  padding: 0.75rem;
  transition: border-color 0.2s;
}

.member-card:hover {
  border-color: rgba(255, 255, 255, 0.15);
}

.member-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
}

.member-info {
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  flex: 1;
  min-width: 0;
}

.member-name {
  font-weight: 700;
  font-size: 0.92rem;
}

.member-role {
  font-size: 0.78rem;
  color: var(--muted, #888);
}

.member-badges {
  display: flex;
  gap: 0.3rem;
  flex-shrink: 0;
}

.member-badge {
  font-size: 0.68rem;
  padding: 0.15rem 0.45rem;
  border-radius: 10px;
  font-weight: 600;
  white-space: nowrap;
}

.member-badge.vocalist {
  background: rgba(233, 69, 96, 0.15);
  color: var(--accent, #e94560);
}

.member-badge.instrument {
  background: rgba(78, 204, 163, 0.15);
  color: var(--green, #4ecca3);
}

.member-voice-summary {
  font-size: 0.78rem;
  color: var(--muted, #888);
  font-style: italic;
  margin-top: 0.3rem;
  padding-left: 0.25rem;
}

.member-actions {
  display: flex;
  gap: 0.35rem;
  margin-top: 0.5rem;
  justify-content: flex-end;
}

.member-actions .btn {
  font-size: 0.72rem;
  padding: 0.2rem 0.5rem;
  min-height: 28px;
}

/* ── Member form (inline add/edit) ─────────── */

.member-form {
  background: var(--surface, #1a1a2e);
  border: 1px solid var(--accent, #e94560);
  border-radius: 8px;
  padding: 0.75rem;
}

.member-form .edit-field label {
  font-size: 0.7rem;
  color: var(--muted, #888);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.member-form .edit-input,
.member-form .edit-select {
  font-size: 0.85rem;
  padding: 0.4rem 0.5rem;
}

/* ── Mobile ────────────────────────────────── */
@media (max-width: 640px) {
  .member-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.25rem;
  }

  .member-badges {
    flex-wrap: wrap;
  }

  .member-actions {
    justify-content: stretch;
  }

  .member-actions .btn {
    flex: 1;
    text-align: center;
  }
}
