/* ════════════════════════════════
   SEASONAL EVENT BANNER
════════════════════════════════ */
.seasonal-banner {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border: 1.5px solid transparent;
  border-radius: 18px;
  margin-bottom: 12px;
  position: relative;
  animation: fadeSlideIn .4s var(--spring) both;
}
@keyframes fadeSlideIn {
  from { opacity: 0; transform: translateY(-10px); }
  to   { opacity: 1; transform: translateY(0); }
}
.season-emoji { font-size: 28px; flex-shrink: 0; }
.season-body { flex: 1; }
.season-title { font-size: 15px; font-weight: 800; }
.season-en { font-size: 12px; opacity: .65; margin-top: 1px; }
.season-close {
  font-size: 16px;
  opacity: .45;
  cursor: pointer;
  padding: 4px 6px;
  flex-shrink: 0;
}
.season-close:hover { opacity: .8; }

