/* ── Team Card Grid ──────────────────────────────── */
.otslr-team-grid {
  display: grid;
  gap: 24px;
}

.otslr-team-grid--cols-2 { grid-template-columns: repeat(2, 1fr); }
.otslr-team-grid--cols-3 { grid-template-columns: repeat(3, 1fr); }
.otslr-team-grid--cols-4 { grid-template-columns: repeat(4, 1fr); }
.otslr-team-grid--cols-5 { grid-template-columns: repeat(5, 1fr); }

/* Reset the fixed-width the person-card CSS sets on the Elementor wrapper */
.otslr-team-grid .otslr-person-card {
  width: 100%;
  max-width: none;
  flex: initial;
}

/* Full-width image option */
.otslr-team-grid .otslr-person-card__image--size-full,
.otslr-team-grid .otslr-person-card__image--size-full img {
  width: 100%;
  height: auto;
}

/* ── Responsive ─────────────────────────────────── */
@media (max-width: 1024px) {
  .otslr-team-grid--cols-4,
  .otslr-team-grid--cols-5 {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 767px) {
  .otslr-team-grid--cols-3,
  .otslr-team-grid--cols-4,
  .otslr-team-grid--cols-5 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 480px) {
  .otslr-team-grid {
    grid-template-columns: 1fr !important;
  }
}

/* ── Empty / editor placeholder ─────────────────── */
.otslr-team-card--empty {
  min-height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px dashed #ccc;
  background: #fafafa;
  padding: 24px;
}
