@layer components {
  .todolist-manager {
    display: flex;
    flex-direction: column;
  }

  .todolist-manager__item {
    border-bottom: 1px solid var(--rd-border);

    &:last-child {
      border-bottom: none;
    }
  }

  .todolist-manager__row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 6px 16px;
    gap: 8px;
    min-height: 36px;

    &:hover {
      background: var(--rd-bg-hover);
    }
  }

  .todolist-manager__row--group {
    padding-left: 32px;
  }

  .todolist-manager__name {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
    min-width: 0;
    font-size: var(--rd-text-sm);
    color: var(--rd-fg);

    [data-inline-field-target="display"] {
      cursor: pointer;
      font-weight: 500;
      padding: 2px 4px;
      border-radius: var(--rd-radius-sm);

      &:hover {
        background: var(--rd-bg-sunken);
      }
    }
  }

  .todolist-manager__row--group .todolist-manager__name [data-inline-field-target="display"] {
    font-weight: 400;
    color: var(--rd-fg-muted);
  }

  .todolist-manager__inline-input {
    width: 200px;
    font-size: var(--rd-text-sm);
    padding: 2px 6px;
  }

  .todolist-manager__actions {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
  }

  .todolist-manager__groups {
    border-top: 1px solid var(--rd-border);
  }

  .todolist-manager__add-group {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 16px 8px 32px;
    opacity: 0.6;
    transition: opacity var(--rd-dur-fast) var(--rd-ease);

    &:hover,
    &:focus-within {
      opacity: 1;
    }
  }

  .todolist-manager__add-group-input {
    width: 180px;
    border: none;
    border-bottom: 1px solid var(--rd-border);
    border-radius: 0;
    background: transparent;
    padding: 2px 4px;
    font-size: var(--rd-text-sm);
    color: var(--rd-fg);
    font-family: var(--rd-font-sans);
    outline: none;

    &::placeholder {
      color: var(--rd-fg-subtle);
      font-style: italic;
    }

    &:focus {
      border-bottom-color: var(--rd-accent);
    }
  }
}
