/* ============================================================================
   Almanac — music-codes table component (.almanac-mc)
   A searchable / genre-filterable list of Roblox music IDs with per-row copy.
   Sits on TOP of the theme's native .almanac-post__content table styling
   (dark header bar, zebra rows, hover) and only adds the toolbar, the scroll
   container (its own sticky header — exempt from the JS wide-table expand wrap),
   the copy buttons and the verified caption. Tokens only; light + dark safe.
   ============================================================================ */

.almanac-mc { margin: 1.75rem 0; }

/* ---- toolbar: search + genre chips + live count -------------------------- */
.almanac-mc__bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}
.almanac-mc__search {
  flex: 1 1 240px;
  min-width: 180px;
  font: inherit;
  font-size: 0.9375rem;
  padding: 0.6rem 0.85rem;
  color: var(--almanac-fg-primary);
  background: var(--almanac-bg-canvas);
  border: 1px solid var(--almanac-border);
  border-radius: var(--almanac-radius-md);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.almanac-mc__search::placeholder { color: var(--almanac-fg-quaternary); }
.almanac-mc__search:focus {
  outline: none;
  border-color: var(--almanac-yellow-deep);
  box-shadow: 0 0 0 3px var(--almanac-yellow-soft);
}
.almanac-mc__chips { display: flex; flex-wrap: wrap; gap: 0.35rem; }
.almanac-mc__chip {
  font: inherit;
  font-size: 0.8125rem;
  font-weight: 600;
  line-height: 1;
  cursor: pointer;
  padding: 0.45rem 0.75rem;
  color: var(--almanac-fg-secondary);
  background: var(--almanac-bg-canvas);
  border: 1px solid var(--almanac-border);
  border-radius: 999px;
  transition: color 0.15s ease, background 0.15s ease, border-color 0.15s ease;
}
.almanac-mc__chip:hover { border-color: var(--almanac-fg-tertiary); }
.almanac-mc__chip[aria-pressed="true"] {
  color: var(--almanac-on-yellow, #1A1612);
  background: var(--almanac-yellow);
  border-color: var(--almanac-yellow-deep);
}
.almanac-mc__count {
  margin-left: auto;
  font-size: 0.8125rem;
  color: var(--almanac-fg-tertiary);
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

/* ---- scroll container (owns sticky header; no theme expand-wrap) --------- */
.almanac-mc__scroll {
  max-height: 70vh;
  overflow: auto;
  border: 1px solid var(--almanac-border);
  border-radius: var(--almanac-radius-md);
  -webkit-overflow-scrolling: touch;
}
.almanac-mc__scroll table { margin: 0 !important; }
.almanac-mc__scroll thead th { position: sticky; top: 0; z-index: 2; }

/* Compact density + column behaviour so the full list fits the reading column
   (loads after almanac-overrides, so equal-specificity rules win on cascade order). */
.almanac-mc__scroll table th,
.almanac-mc__scroll table td { padding: 0.6rem 0.75rem !important; }
.almanac-mc__scroll table td:nth-child(2) { max-width: 16rem; overflow-wrap: break-word; }  /* Song — wrap, don't widen */
.almanac-mc__scroll table td:nth-child(3) { max-width: 12rem; overflow-wrap: break-word; }  /* Artist */
.almanac-mc__idcell, .almanac-mc__table .is-center { white-space: nowrap; }

/* numbered index column stays tight */
.almanac-mc__num { color: var(--almanac-fg-quaternary); font-variant-numeric: tabular-nums; width: 1%; white-space: nowrap; }

/* ---- ID cell: mono id + copy button -------------------------------------- */
.almanac-mc__idcell { white-space: nowrap; }
.almanac-mc__id {
  font-family: var(--almanac-font-code, ui-monospace, Menlo, Consolas, monospace);
  font-variant-numeric: tabular-nums;
  font-size: 0.9375rem;
}
.almanac-mc__copy {
  margin-left: 0.5rem;
  font: inherit;
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1;
  cursor: pointer;
  padding: 0.3rem 0.6rem;
  color: var(--almanac-fg-secondary);
  background: var(--almanac-bg-canvas);
  border: 1px solid var(--almanac-border);
  border-radius: var(--almanac-radius-sm);
  vertical-align: middle;
  transition: color 0.15s ease, background 0.15s ease, border-color 0.15s ease;
}
.almanac-mc__copy:hover {
  background: var(--almanac-yellow);
  color: var(--almanac-on-yellow, #1A1612);
  border-color: var(--almanac-yellow-deep);
}
.almanac-mc__copy.is-copied {
  background: var(--almanac-success, #1f8a44);
  color: #fff;
  border-color: transparent;
}

/* genre tag (hub master table) */
.almanac-mc__gtag { font-size: 0.8125rem; color: var(--almanac-fg-tertiary); text-transform: capitalize; }

/* empty state */
.almanac-mc__empty { display: none; padding: 1.25rem; text-align: center; color: var(--almanac-fg-tertiary); }
.almanac-mc.is-empty .almanac-mc__empty { display: block; }

/* verified caption */
.almanac-mc__verified {
  margin: 0.75rem 0 0;
  font-size: 0.8125rem;
  line-height: 1.5;
  color: var(--almanac-fg-tertiary);
}
.almanac-mc__verified strong { color: var(--almanac-fg-secondary); font-weight: 600; }

/* mobile */
@media (max-width: 600px) {
  .almanac-mc__hide-sm { display: none; }
  .almanac-mc__scroll { max-height: 68vh; }
  .almanac-mc__search { flex-basis: 100%; }
  .almanac-mc__count { margin-left: 0; }
}
