@layer components {
  /* Entity list -- rendered in the left drawer (story bible) */
  .entity-list {
    display: flex;
    flex-direction: column;
    gap: var(--block-space-half);
  }

  /* Search/filter input */
  .entity-list__search {
    margin-block-end: var(--block-space-half);
  }

  .entity-list__search .input {
    font-size: var(--text-small);
    padding: var(--block-space-half) var(--inline-space);
  }

  /* Group (characters, locations, lore) */
  .entity-list__group {
    border: var(--border);
    border-radius: var(--radius);
    overflow: hidden;
  }

  .entity-list__group-header {
    align-items: center;
    cursor: pointer;
    display: flex;
    font-size: var(--text-small);
    font-weight: 600;
    gap: var(--inline-space);
    justify-content: space-between;
    list-style: none;
    padding: var(--block-space-half) var(--inline-space);
    user-select: none;
  }

  .entity-list__group-header::-webkit-details-marker {
    display: none;
  }

  .entity-list__group-header::before {
    content: "";
    border-block-start: 0.35em solid var(--color-ink-muted);
    border-inline: 0.3em solid transparent;
    display: inline-block;
    transition: transform var(--transition-fast);
  }

  .entity-list__group[open] > .entity-list__group-header::before {
    transform: rotate(90deg);
  }

  .entity-list__group-name {
    flex: 1;
  }

  .entity-list__group-count {
    background: var(--color-surface);
    border-radius: var(--radius-pill);
    color: var(--color-ink-muted);
    font-size: var(--text-xs);
    font-weight: 600;
    min-inline-size: 1.5em;
    padding: 0.1em 0.5em;
    text-align: center;
  }

  /* Entity items container */
  .entity-list__items {
    display: flex;
    flex-direction: column;
  }

  /* Add entity button */
  .entity-list__add-btn {
    align-items: center;
    color: var(--color-link);
    display: flex;
    font-size: var(--text-xs);
    gap: 0.3em;
    padding: var(--block-space-half) var(--inline-space);
    text-decoration: none;
  }

  .entity-list__add-btn:hover {
    background: var(--color-surface);
  }

  /* Empty state actions */
  .entity-list__add-actions {
    display: flex;
    flex-wrap: wrap;
    gap: var(--inline-space-half);
    justify-content: center;
  }

  /* Entity card -- clickable item in the list */
  .entity-card {
    align-items: flex-start;
    border-block-start: var(--border);
    color: var(--color-ink);
    display: flex;
    flex-direction: column;
    gap: 0.2em;
    padding: var(--block-space-half) var(--inline-space);
    text-decoration: none;
    transition: background-color var(--transition-fast);
  }

  .entity-card:hover {
    background: var(--color-surface);
  }

  .entity-card:focus-visible {
    outline: var(--focus-ring);
    outline-offset: -2px;
  }

  .entity-card__header {
    align-items: baseline;
    display: flex;
    gap: var(--inline-space-half);
    inline-size: 100%;
  }

  .entity-card__name {
    flex: 1;
    font-size: var(--text-small);
    font-weight: 600;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .entity-card__role,
  .entity-card__category {
    color: var(--color-ink-muted);
    flex-shrink: 0;
    font-size: var(--text-xs);
  }

  .entity-card__meta {
    align-items: center;
    display: flex;
    gap: var(--inline-space-half);
    inline-size: 100%;
  }

  /* Completeness indicator bar */
  .entity-card__completeness {
    flex: 1;
    max-inline-size: 4rem;
  }

  .entity-card__completeness-bar {
    background: var(--color-surface);
    block-size: 3px;
    border-radius: 2px;
    display: block;
    overflow: hidden;
  }

  .entity-card__completeness-fill {
    background: var(--color-positive);
    block-size: 100%;
    border-radius: 2px;
    display: block;
    transition: inline-size var(--transition-normal);
  }

  /* Edited badge (pen icon) */
  .entity-card__edited-badge {
    color: var(--color-link);
    display: inline-flex;
    flex-shrink: 0;
  }

  /* Hidden state for search filtering */
  .entity-card[hidden] {
    display: none;
  }
}
