@layer components {
  /* ========================================
   * Outline / Chapter List (Right Drawer)
   * ======================================== */

  .outline {
    --outline-hairline: 2px;

    display: flex;
    flex-direction: column;
    gap: var(--block-space-half);
  }

  .outline__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-inline: var(--inline-space-half);
  }

  .outline__count {
    font-size: var(--text-small);
    color: oklch(var(--lch-ink-dark));
    font-variant-numeric: tabular-nums;
  }

  /* -- Chapter List -- */

  .outline__list {
    display: flex;
    flex-direction: column;
    gap: var(--outline-hairline);
  }

  /* -- Chapter Card -- */

  .outline__card {
    display: flex;
    align-items: flex-start;
    gap: var(--inline-space-half);
    padding: var(--block-space-half) var(--inline-space-half);
    border-radius: var(--radius-lg);
    color: var(--color-ink);
    transition: background-color var(--transition-fast);
  }

  .outline__card:hover {
    background: oklch(var(--lch-ink-lighter) / 0.5);
  }

  .outline__card--active {
    background: oklch(var(--lch-ink-lighter));
  }

  .outline__card--active:hover {
    background: oklch(var(--lch-ink-lighter));
  }

  /* Card link (navigates to chapter editor) */

  .outline__card-link {
    flex: 1;
    min-inline-size: 0;
    text-decoration: none;
    color: inherit;
    cursor: pointer;
  }

  /* Move-up / Move-down buttons */

  .outline__card-actions {
    display: flex;
    flex-direction: column;
    gap: var(--outline-hairline);
    flex-shrink: 0;
    align-self: center;
  }

  /* button_to generates <form> wrappers -- reset their layout */
  .outline__card-actions form {
    display: contents;
  }

  /* Desktop: hidden until card is hovered or focused-within */
  @media (min-width: 800px) {
    .outline__card-actions {
      opacity: 0;
      transition: opacity var(--transition-fast);
    }

    .outline__card:hover .outline__card-actions,
    .outline__card:focus-within .outline__card-actions {
      opacity: 1;
    }
  }

  .outline__move-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-block-size: 28px;
    min-inline-size: 28px;
    padding: 0;
    border: none;
    border-radius: var(--radius);
    background: transparent;
    color: oklch(var(--lch-ink-medium));
    cursor: pointer;
    transition: background-color var(--transition-fast), color var(--transition-fast);
  }

  .outline__move-btn:hover {
    background: oklch(var(--lch-ink-lighter));
    color: var(--color-ink);
  }

  /* Mobile: 44px minimum tap targets */
  @media (max-width: 799px) {
    .outline__move-btn {
      min-block-size: 44px;
      min-inline-size: 44px;
    }
  }

  /* Drag handle */

  .outline__card-drag {
    display: flex;
    align-items: center;
    padding-block-start: var(--outline-hairline);
    color: oklch(var(--lch-ink-medium));
    cursor: grab;
    touch-action: none;
    flex-shrink: 0;
  }

  .outline__card-drag:active {
    cursor: grabbing;
  }

  .outline__card-title {
    display: block;
    font-weight: 500;
    font-size: var(--text-small);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .outline__card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--inline-space-half);
    font-size: var(--text-xs);
    color: oklch(var(--lch-ink-medium));
    margin-block-start: var(--outline-hairline);
  }

  /* -- SortableJS ghost/drag states -- */

  .outline__card.sortable-ghost {
    opacity: 0.4;
    background: oklch(var(--lch-ink-lighter));
  }

  .outline__card.sortable-chosen {
    background: oklch(var(--lch-ink-lighter));
    box-shadow: var(--shadow);
  }

  /* -- Outline notes (inline in drawer) -- */

  .outline__notes {
    padding: var(--block-space-half) var(--inline-space-half);
    border-block-start: var(--border);
    margin-block-start: var(--block-space-half);
  }

  .outline__notes-label {
    font-size: var(--text-small);
    font-weight: 600;
    color: oklch(var(--lch-ink-dark));
    margin-block-end: var(--block-space-half);
  }

  .outline__notes-content {
    font-size: var(--text-small);
    color: oklch(var(--lch-ink-dark));
    line-height: 1.5;
    white-space: pre-wrap;
  }
}
