.member-card {
  transition: all 0.3s ease-in-out;
  cursor: pointer;
  perspective: 1000px;
}

.card-inner {
  position: relative;
  width: 100%;
  height: 100%;
  text-align: center;
  transition: transform 0.6s;
  transform-style: preserve-3d;
}

.member-card.flipped .card-inner {
  transform: rotateY(180deg);
}

.card-front,
.card-back {
  position: absolute;
  width: 100%;
  height: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  border-radius: 12px;
  padding: 1.5rem;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.card-front {
  background-color: #ffffff;
  border: 1px solid #f0f0f0;
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.05);
}

.card-back {
  background-color: #2c3e50;
  color: #ffffff;
  transform: rotateY(180deg);
  border: 1px solid #2c3e50;
  text-align: left;
}

.role-text {
  color: #34495e;
  font-weight: 500;
}

@media (min-width: 640px) {
  .team-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .team-grid {
    grid-template-columns: repeat(5, 1fr);
  }
}
