/*
 * Sparks Type: Awards
 * Category cards with expand/collapse nominees, winner badges, film strip.
 * Used by: oscars-2024, oscars-2025, oscars-2026
 *
 * Structure:
 *   .film-strip → .film-chip (top films overview)
 *   .cat-grid → .cat-card (category cards)
 *     .cat-header → .cat-icon + .cat-name + .cat-meta + .cat-toggle
 *     .winner-row → .win-badge + .winner-info
 *     .nominees-wrap → .nominees → .nom-row
 *   .milestones → .milestone-item
 *
 * Requires a theme that defines:
 *   --gold, --gold-light, --gold-dim, --gold-bg,
 *   --gold-border, --gold-border-dim,
 *   --card-bg-hover, --card-bg-active, --divider,
 *   --text-body, --text-mid, --text-dim, --text-faint
 */

/* ══════════════════════════════════════
   Film Strip (top overview)
   ══════════════════════════════════════ */

.film-strip {
  display: flex;
  justify-content: center;
  gap: 40px;
  flex-wrap: wrap;
  padding: 36px 0;
  border-bottom: 1px solid var(--divider, rgba(255,255,255,0.06));
}

.film-chip {
  text-decoration: none;
  text-align: center;
  cursor: pointer;
  transition: filter 0.3s ease, box-shadow 0.3s ease;
}

/* Hover signal via brightness + elevation shadow. No translate —
   moving the chip with text inside breaks reading (P14). */
.film-chip:hover { filter: brightness(1.1); box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18); }

.film-chip-wins {
  /* lint-allow: raw-px — oversized display number for the film-chip count;
     no h1-equivalent token covers 42px and this is decorative, not prose. */
  font-size: 42px;
  font-weight: var(--font-weight-bold);
  color: var(--gold, var(--accent-primary));
  line-height: 1;
}

.film-chip-label {
  font-size: var(--font-size-caption);
  letter-spacing: 2px;
  color: var(--text-mid, var(--text-secondary));
  text-transform: uppercase;
  font-weight: var(--font-weight-medium);
}

.film-chip-noms {
  font-size: var(--font-size-caption);
  color: var(--text-dim, var(--text-tertiary));
  letter-spacing: 0.5px;
  margin-top: 2px;
}

.film-chip-title {
  font-size: var(--font-size-body);
  color: var(--text-primary);
  margin-top: 6px;
  font-weight: var(--font-weight-medium);
  transition: color 0.3s;
}

.film-chip:hover .film-chip-title {
  color: var(--gold-light, var(--accent-primary-text));
}


/* ══════════════════════════════════════
   Category Cards
   ══════════════════════════════════════ */

.cat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(365px, 1fr));
  gap: 18px;
  padding-bottom: 68px;
}

.cat-card {
  background: var(--card-bg);
  backdrop-filter: blur(8px);
  border: 1px solid var(--card-border);
  border-left: 3px solid transparent;
  border-radius: var(--card-radius);
  padding: 24px 26px;
  cursor: pointer;
  transition: all 0.35s ease;
  position: relative;
  overflow: hidden;
}

.cat-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 20% 50%, rgba(var(--accent-primary-rgb), 0.03) 0%, transparent 70%);
  opacity: 0;
  transition: opacity 0.35s ease;
  pointer-events: none;
}

.cat-card:hover {
  border-color: var(--gold-border-dim, rgba(var(--accent-primary-rgb), 0.2));
  border-left-color: var(--gold, var(--accent-primary));
  background: var(--card-bg-hover, rgba(11, 21, 53, 0.8));
  /* No translate — text inside this card must stay put on hover (P14
     animation discipline). Box-shadow alone signals elevation. */
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
}

.cat-card:hover::before { opacity: 1; }

.cat-card.open {
  border-color: var(--gold-border, rgba(var(--accent-primary-rgb), 0.3));
  border-left-color: var(--gold, var(--accent-primary));
  background: var(--card-bg-active, rgba(11, 21, 53, 0.85));
  transform: none;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}

/* Header */
.cat-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}

/* lint-allow: raw-px — emoji/icon glyph size; off the text scale on purpose. */
.cat-icon { font-size: 24px; }

.cat-name {
  font-size: var(--font-size-badge);
  font-weight: var(--font-weight-semibold);
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--text-mid, var(--text-secondary));
  flex: 1;
  transition: color 0.3s;
}

.cat-card:hover .cat-name,
.cat-card.open .cat-name {
  color: var(--gold, var(--accent-primary));
}

.cat-meta {
  font-size: var(--font-size-caption);
  color: var(--text-faint, var(--text-tertiary));
  letter-spacing: 0.5px;
  transition: all 0.3s;
  font-weight: var(--font-weight-normal);
}

.cat-card:hover .cat-meta { color: var(--text-dim, var(--text-secondary)); }
.cat-card.open .cat-meta { opacity: 0; width: 0; overflow: hidden; }

.cat-toggle {
  font-size: var(--font-size-h2);
  color: var(--text-faint, var(--text-tertiary));
  transition: transform 0.35s ease, color 0.3s;
  font-weight: 300;
  line-height: 1;
}

.cat-card.open .cat-toggle {
  transform: rotate(45deg);
  color: var(--gold-dim, var(--accent-primary));
}


/* ══════════════════════════════════════
   Winner + Nominees
   ══════════════════════════════════════ */

.winner-row {
  display: flex;
  align-items: baseline;
  gap: 12px;
}

.win-badge {
  font-size: var(--font-size-caption);
  letter-spacing: 2px;
  color: var(--gold, var(--accent-primary));
  font-weight: var(--font-weight-bold);
  background: var(--gold-bg, rgba(var(--accent-primary-rgb), 0.1));
  padding: 3px 10px;
  border-radius: 4px;
  flex-shrink: 0;
  margin-top: 3px;
  border: 1px solid var(--gold-border-dim, rgba(var(--accent-primary-rgb), 0.2));
}

.winner-info { line-height: 1.5; }

.winner-person {
  font-size: var(--font-size-h2);
  font-weight: var(--font-weight-bold);
  color: var(--white);
}

.winner-film {
  font-size: var(--font-size-body);
  color: var(--text-mid, var(--text-secondary));
  font-style: italic;
}

.winner-label, .nom-label {
  font-size: var(--font-size-caption);
  color: var(--text-dim, var(--text-tertiary));
}

/* Nominees */
.nominees-wrap {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height 0.5s ease, opacity 0.3s ease;
}

.cat-card.open .nominees-wrap {
  max-height: 600px;
  opacity: 1;
}

.nominees {
  border-top: 1px solid var(--divider, rgba(255,255,255,0.06));
  padding-top: 14px;
  margin-top: 14px;
}

.nom-row {
  display: flex;
  align-items: baseline;
  gap: 12px;
  padding: 6px 0;
  opacity: 0;
  transform: translateX(-6px);
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.cat-card.open .nom-row { opacity: 1; transform: translateX(0); }
.cat-card.open .nom-row:nth-child(1) { transition-delay: 0.08s; }
.cat-card.open .nom-row:nth-child(2) { transition-delay: 0.13s; }
.cat-card.open .nom-row:nth-child(3) { transition-delay: 0.18s; }
.cat-card.open .nom-row:nth-child(4) { transition-delay: 0.23s; }
.cat-card.open .nom-row:nth-child(5) { transition-delay: 0.28s; }

.nom-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--text-faint, var(--text-tertiary));
  flex-shrink: 0;
  margin-top: 9px;
  align-self: flex-start;
}

.nom-person {
  font-size: var(--font-size-body);
  color: var(--text-body, var(--text-primary));
  font-weight: var(--font-weight-medium);
}

.nom-film {
  font-size: var(--font-size-small);
  color: var(--text-mid, var(--text-secondary));
  font-style: italic;
  font-weight: var(--font-weight-normal);
}

.nom-dash {
  color: var(--text-faint, var(--text-tertiary));
  margin: 0 5px;
}


/* ══════════════════════════════════════
   Milestones
   ══════════════════════════════════════ */

.milestones {
  max-width: 880px;
  margin: 0 auto 60px;
  background: var(--card-bg);
  backdrop-filter: blur(8px);
  border: 1px solid var(--gold-border-dim, var(--card-border));
  border-radius: var(--card-radius);
  padding: 30px 34px;
}

.milestones h2 {
  font-size: var(--font-size-badge);
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--gold, var(--accent-primary));
  margin-bottom: 20px;
  font-weight: var(--font-weight-semibold);
}

.milestone-item {
  display: flex;
  gap: 12px;
  align-items: baseline;
  padding: 6px 0;
}

.milestone-diamond {
  color: var(--gold, var(--accent-primary));
  font-size: var(--font-size-badge);
  flex-shrink: 0;
  margin-top: 4px;
}

.milestone-text {
  font-size: var(--font-size-body);
  color: var(--text-body, var(--text-primary));
  line-height: 1.65;
  font-weight: var(--font-weight-normal);
}


/* ══════════════════════════════════════
   Mobile
   ══════════════════════════════════════ */

@media (max-width: 600px) {
  .cat-grid { grid-template-columns: 1fr; }
  .film-strip { gap: 16px; padding: 28px 0; }
}
