.critters-page {
  display: grid;
  gap: 1.25rem;
}

.glass-card {
  background: rgba(255, 255, 255, 0.78);
  border: 2px solid rgba(76, 175, 80, 0.45);
  border-radius: 22px;
  padding: 1rem 1.1rem;
  box-shadow:
    0 10px 30px rgba(76, 175, 80, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.5);
  backdrop-filter: blur(10px);
}

.critters-hero h1,
.critter-card h2 {
  margin: 0 0 0.35rem;
}

.critters-hero p {
  margin: 0.4rem 0 0;
}

.critters-stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 1rem;
}

.stat-pill {
  padding: 0.5rem 0.8rem;
  border-radius: 999px;
  background: rgba(232, 245, 233, 0.95);
  border: 1px solid rgba(76, 175, 80, 0.4);
}

.critters-controls,
.critters-now,
.critters-leaving {
  display: grid;
  gap: 1rem;
}

.filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  align-items: end;
}

.filter-row label,
.critters-now__controls label {
  display: grid;
  gap: 0.35rem;
  min-width: 150px;
}

.filter-row span,
.critters-now__controls span {
  font-weight: 700;
}

.filter-row select,
.filter-row input,
.critters-now__controls select {
  width: 100%;
  min-width: 0;
  border: 2px solid rgba(76, 175, 80, 0.35);
  border-radius: 14px;
  padding: 0.65rem 0.75rem;
  background: rgba(255, 255, 255, 0.92);
  color: inherit;
  font: inherit;
  box-sizing: border-box;
}

.quick-toggles {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: center;
}

.filter-chip {
  appearance: none;
  border: 2px solid rgba(76, 175, 80, 0.35);
  background: rgba(255, 255, 255, 0.9);
  color: inherit;
  border-radius: 999px;
  padding: 0.55rem 0.9rem;
  font: inherit;
  line-height: 1.1;
  cursor: pointer;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    background 0.18s ease,
    border-color 0.18s ease;
}

.filter-chip:hover,
.filter-chip:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 6px 16px rgba(76, 175, 80, 0.16);
}

.filter-chip.is-active {
  background: rgba(205, 255, 212, 0.95);
  border-color: rgba(76, 175, 80, 0.75);
  box-shadow: 0 0 0 2px rgba(76, 175, 80, 0.12);
}

.results-line {
  margin: 0;
}

.critters-now__top h2,
.critters-now__list h3,
.critters-leaving__top h2,
.critters-leaving__list h3 {
  margin: 0 0 0.25rem;
}

.critters-now__top p,
.critters-now__list p,
.critters-leaving__top p,
.critters-leaving__list p {
  margin: 0;
}

.critters-now__controls {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85rem;
  align-items: end;
}

.critters-now__stats,
.critters-leaving__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

.now-pill,
.leave-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.55rem 0.85rem;
  border-radius: 999px;
}

.now-pill {
  background: rgba(232, 245, 233, 0.95);
  border: 1px solid rgba(76, 175, 80, 0.4);
}

.leave-pill {
  background: rgba(255, 248, 225, 0.95);
  border: 1px solid rgba(255, 193, 7, 0.4);
}

.critters-now__list,
.critters-leaving__list {
  display: grid;
  gap: 0.25rem;
}

.critters-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1rem;
}

.critter-card {
  display: grid;
  grid-template-columns: 78px 1fr;
  grid-template-areas:
    "header header"
    "img bells"
    "img tags"
    "img details";
  gap: 0.75rem 0.9rem;
  align-items: start;

  background: rgba(255, 255, 255, 0.82);
  border: 2px solid rgba(76, 175, 80, 0.28);
  border-radius: 20px;
  padding: 1rem;
  box-shadow: 0 8px 20px rgba(76, 175, 80, 0.1);

  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    filter 0.18s ease,
    opacity 0.18s ease,
    border-color 0.18s ease;
}

.critter-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 26px rgba(76, 175, 80, 0.16);
}

.critter-card.is-missing {
  opacity: 0.72;
}

.critter-card.is-caught {
  opacity: 1;
}

.critter-card.is-donated {
  border-color: rgba(156, 39, 176, 0.45);
  box-shadow: 0 10px 24px rgba(156, 39, 176, 0.12);
}

.critter-card.is-leaving-soon {
  border-color: rgba(255, 193, 7, 0.7);
  box-shadow:
    0 0 0 2px rgba(255, 193, 7, 0.12),
    0 10px 24px rgba(255, 193, 7, 0.14);
}

.critter-card__header {
  grid-area: header;
  min-width: 0;
}

.critter-card__header h2 {
  margin: 0 0 0.2rem;
  font-size: 1.08rem;
  line-height: 1.2;
}

.critter-meta {
  margin: 0;
  opacity: 0.8;
  font-size: 0.95rem;
}

.critter-card__img {
  grid-area: img;
  width: 78px;
  height: 78px;
  border-radius: 16px;
  overflow: hidden;
  background: rgba(232, 245, 233, 0.88);
  border: 2px solid rgba(76, 175, 80, 0.28);

  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.critter-card__img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  image-rendering: auto;
  transition:
    transform 0.18s ease,
    filter 0.18s ease,
    opacity 0.18s ease;
}

.critter-card:hover .critter-card__img img {
  transform: scale(1.04);
}

.critter-card.is-missing .critter-card__img img {
  filter: grayscale(1);
  opacity: 0.72;
}

.critter-card.is-caught .critter-card__img img {
  filter: none;
  opacity: 1;
}

.critter-card.is-caught .critter-card__img {
  box-shadow:
    0 0 0 2px rgba(76, 175, 80, 0.14),
    0 6px 14px rgba(76, 175, 80, 0.18);
}

.critter-card.is-donated .critter-card__img {
  border-color: rgba(156, 39, 176, 0.35);
}

.critter-bells {
  grid-area: bells;
  justify-self: start;
  white-space: nowrap;
  font-weight: 700;
  background: rgba(232, 245, 233, 0.95);
  border: 1px solid rgba(76, 175, 80, 0.35);
  border-radius: 999px;
  padding: 0.38rem 0.7rem;
  font-size: 0.92rem;
}

.critter-tags {
  grid-area: tags;
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin: 0;
}

.tag {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  border-radius: 999px;
  padding: 0.28rem 0.65rem;
  font-size: 0.88rem;
  border: 1px solid transparent;
}

.tag-caught {
  background: rgba(220, 248, 224, 0.95);
  border-color: rgba(76, 175, 80, 0.35);
}

.tag-missing {
  background: rgba(245, 245, 245, 0.95);
  border-color: rgba(160, 160, 160, 0.35);
}

.tag-donated {
  background: rgba(243, 229, 245, 0.95);
  border-color: rgba(156, 39, 176, 0.3);
}

.critter-details {
  grid-area: details;
  display: grid;
  gap: 0.5rem;
  margin: 0;
}

.critter-details div {
  display: grid;
  gap: 0.1rem;
}

.critter-details dt {
  font-weight: 700;
  font-size: 0.92rem;
}

.critter-details dd {
  margin: 0;
  opacity: 0.88;
  font-size: 0.95rem;
  line-height: 1.3;
}

@media (max-width: 640px) {
  .critters-grid {
    grid-template-columns: 1fr;
  }

  .filter-row,
  .quick-toggles,
  .critters-now__controls,
  .critters-now__stats,
  .critters-leaving__stats,
  .critters-stats {
    flex-direction: column;
    align-items: stretch;
  }

  .filter-row label,
  .critters-now__controls label {
    min-width: 0;
    width: 100%;
  }

  .filter-chip {
    width: 100%;
    text-align: center;
  }

  .critter-card {
    grid-template-columns: 64px 1fr;
    grid-template-areas:
      "header header"
      "img bells"
      "img tags"
      "img details";
    gap: 0.65rem 0.75rem;
    padding: 0.9rem;
  }

  .critter-card__img {
    width: 64px;
    height: 64px;
    border-radius: 14px;
  }

  .critter-bells {
    align-self: start;
  }
}