.selfie-body {
  --selfie-accent: var(--game-accent);
  --selfie-muted: var(--game-card-muted);
}

.selfie-list-header,
.selfie-album-header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.selfie-challenge-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  margin-top: 18px;
}

.selfie-challenge-card {
  display: grid;
  gap: 8px;
  padding: 16px;
  border-radius: 18px;
  background: var(--game-row-alt);
  border: 1px solid var(--game-border);
  text-decoration: none;
  color: inherit;
  transition:
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.selfie-challenge-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(16, 28, 28, 0.12);
}

.selfie-challenge-card__title {
  font-weight: 700;
  font-size: 1.05rem;
}

.selfie-challenge-card__hint {
  color: var(--selfie-muted);
  font-size: 0.95rem;
}

.selfie-count {
  font-size: 0.85rem;
  font-weight: 600;
  padding: 4px 10px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--selfie-accent) 18%, transparent);
  justify-self: start;
}

.selfie-album-title {
  margin-top: 16px;
}

.selfie-upload {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-top: 16px;
  flex-wrap: wrap;
}

.selfie-upload-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}

.selfie-upload .primary {
  padding: 10px 18px;
}

.selfie-gallery {
  margin-top: 18px;
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(220px, 1fr);
  gap: 14px;
  overflow-x: auto;
  padding-bottom: 8px;
  scroll-snap-type: x mandatory;
}

.selfie-card {
  display: grid;
  gap: 6px;
  scroll-snap-align: center;
}

.selfie-card img {
  width: 100%;
  height: 240px;
  object-fit: cover;
  border-radius: 16px;
  border: 1px solid var(--game-border);
}

.selfie-card__meta {
  font-size: 0.85rem;
  color: var(--selfie-muted);
}

#selfie-load-more {
  margin-top: 12px;
}

@media (max-width: 640px) {
  .selfie-gallery {
    grid-auto-columns: minmax(180px, 75vw);
  }
  .selfie-card img {
    height: 200px;
  }
}
