.card {
  transition: box-shadow 0.2s ease;
}
.card:hover {
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
}

/* Category pill active state */
.pill-active {
  color: white !important;
  border-color: transparent !important;
}

/* Category pill scrollbar — hide on mobile for clean look */
#category-pills::-webkit-scrollbar { display: none; }
#category-pills { -ms-overflow-style: none; scrollbar-width: none; }

/* Transcript modal — rendered Markdown styling */
#modal-body h1 { font-size: 1.25rem; font-weight: 700; margin: 1.25rem 0 0.5rem; color: inherit; }
#modal-body h2 { font-size: 1.1rem; font-weight: 600; margin: 1.1rem 0 0.4rem; color: inherit; }
#modal-body h3 { font-size: 1rem; font-weight: 600; margin: 1rem 0 0.35rem; color: inherit; }
#modal-body h4 { font-size: 0.8rem; font-weight: 700; margin: 1.2rem 0 0.15rem; color: inherit; text-transform: uppercase; letter-spacing: 0.05em; opacity: 0.55; }
#modal-body p  { margin: 0.6rem 0; line-height: 1.65; }
#modal-body p.bullet-item { padding-left: 1.1rem; text-indent: -1.1rem; }
#modal-body ul { list-style: disc; padding-left: 1.6rem; margin: 0.6rem 0; }
#modal-body ol { list-style: decimal; padding-left: 1.6rem; margin: 0.6rem 0; }
#modal-body li { margin: 0.3rem 0; line-height: 1.6; }
#modal-body strong { font-weight: 600; }
#modal-body hr { border: none; border-top: 1px solid #e5e7eb; margin: 1rem 0; }

/* Year dropdown — more padding for arrow */
#year-filter {
  padding-right: 2rem;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%239ca3af' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.5rem center;
  background-size: 1.25rem;
}
