.body-hero .lead {
  max-width: 620px;
  font-size: 0.96rem;
}
.body-hero .tiny-help {
  font-size: 0.86rem;
  margin-top: 0.28rem;
  line-height: 1.45;
  color: var(--muted);
  font-weight: 800;
}

.body-card-grid .big-letter {
  font-size: clamp(3.2rem, 12vw, 7rem);
  line-height: 0.95;
  font-weight: 950;
  color: #35213f;
  text-shadow: 0 10px 24px rgba(65, 57, 120, 0.12);
}

.body-card-grid .letter-word {
  font-size: clamp(1.05rem, 3vw, 1.45rem);
  color: #5a4865;
  font-weight: 950;
  line-height: 1.25;
}

.body-chip {
  min-width: 66px;
  padding-inline: 10px;
}
.options {
  grid-template-columns: repeat(2, minmax(120px, 1fr));
}
.option-btn {
  font-size: 1rem;
  text-transform: none;
}
.write-row {
  grid-template-columns: minmax(210px, 1fr) minmax(170px, 260px);
}
.typed-answer {
  font-size: 1rem;
}

@media (max-width: 820px) {
  .options {
    grid-template-columns: 1fr;
  }
}

/* Mixed system: emoji stay as Unicode, unclear body parts use local images.
   These images are displayed as emoji replacements, not as photos/flashcards.
   The slot keeps the label close while preventing overlap. */
.body-card-grid .big-letter.has-kids-image {
  width: clamp(130px, 13vw, 164px);
  height: clamp(122px, 12vw, 146px);
  font-size: 0;
  line-height: 0;
  text-shadow: none;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  flex: 0 0 auto;
  margin: 0 auto;
  overflow: visible;
}

.body-card-grid .kids-listen-item-image {
  display: block;
  width: auto;
  height: clamp(148px, 14.6vw, 178px);
  max-width: 178px;
  max-height: none;
  object-fit: contain;
  border-radius: 0;
  box-shadow: none;
  transform: translateY(0);
}

.body-card-grid .big-letter.has-kids-image + .letter-word {
  margin-top: 4px;
}

@media (max-width: 820px) {
  .body-card-grid .big-letter.has-kids-image {
    width: 132px;
    height: 124px;
  }

  .body-card-grid .kids-listen-item-image {
    height: 142px;
    max-width: 148px;
    transform: translateY(0);
  }

  .body-card-grid .big-letter.has-kids-image + .letter-word {
    margin-top: 4px;
  }
}
.body-card-grid .big-letter.has-kids-image {
  height: 170px !important;
  overflow: visible !important;
}

.body-card-grid .kids-listen-item-image {
  height: 280px !important;
  width: auto !important;
  max-width: 190px !important;
  transform: translateY(0) !important;
}

.body-card-grid .big-letter.has-kids-image + .letter-word {
  margin-top: 4px !important;
}
.body-card-grid .kids-listen-scene:has(.big-letter.has-kids-image) {
  transform: translateY(-28px);
}
