.weather-hero .lead {
  max-width: 620px;
  font-size: 0.96rem;
}
.weather-hero .tiny-help {
  font-size: 0.86rem;
  margin-top: 0.28rem;
  line-height: 1.45;
  color: var(--muted);
  font-weight: 800;
}
.weather-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);
}
.weather-card-grid .letter-word {
  font-size: clamp(1.05rem, 3vw, 1.45rem);
  color: #5a4865;
  font-weight: 950;
  line-height: 1.25;
}
.weather-chip {
  min-width: 66px;
  padding-inline: 10px;
  text-transform: none;
}
.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 emoji + WebP icon rules for Weather.
   WebP images are custom emoji replacements: transparent object only,
   label separate, visually aligned with Unicode emoji cards. */
.weather-card-grid .big-letter.has-kids-image {
  height: 170px;
  overflow: visible;
  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;
}

.weather-card-grid .kids-listen-item-image {
  display: block;
  height: 220px;
  width: auto;
  max-width: 190px;
  max-height: none;
  object-fit: contain;
  border-radius: 0;
  box-shadow: none;
  transform: translateY(0);
}

.weather-card-grid .big-letter.has-kids-image + .letter-word {
  margin-top: 4px;
}

.weather-card-grid .kids-listen-scene:has(.big-letter.has-kids-image) {
  transform: translateY(-28px);
}
