SELECT 
  cscart_products_categories.product_id, 
  GROUP_CONCAT(
    IF(
      cscart_products_categories.link_type = "M", 
      CONCAT(
        cscart_products_categories.category_id, 
        "M"
      ), 
      cscart_products_categories.category_id
    )
  ) AS category_ids, 
  product_position_source.position AS position 
FROM 
  cscart_products_categories 
  INNER JOIN cscart_categories ON cscart_categories.category_id = cscart_products_categories.category_id 
  AND cscart_categories.storefront_id IN (0, 1) 
  AND (
    cscart_categories.usergroup_ids = '' 
    OR FIND_IN_SET(
      0, cscart_categories.usergroup_ids
    ) 
    OR FIND_IN_SET(
      1, cscart_categories.usergroup_ids
    )
  ) 
  AND cscart_categories.status IN ('A', 'H') 
  LEFT JOIN cscart_products_categories AS product_position_source ON cscart_products_categories.product_id = product_position_source.product_id 
  AND product_position_source.category_id = 7182 
WHERE 
  cscart_products_categories.product_id IN (
    86856, 85583, 82561, 90268, 90264, 90266, 
    90273, 91311, 91313, 91315, 90267, 
    90274, 85649, 85650, 85651, 91312, 
    91314, 91316, 90263, 90270, 90269, 
    90275, 90265, 93356, 93357, 93358, 
    94117, 94958, 95683, 95702
  ) 
GROUP BY 
  cscart_products_categories.product_id

Query time 0.01476

JSON explain

{
  "query_block": {
    "select_id": 1,
    "cost_info": {
      "query_cost": "81.29"
    },
    "grouping_operation": {
      "using_filesort": false,
      "nested_loop": [
        {
          "table": {
            "table_name": "cscart_products_categories",
            "access_type": "range",
            "possible_keys": [
              "PRIMARY",
              "link_type",
              "pt"
            ],
            "key": "pt",
            "used_key_parts": [
              "product_id"
            ],
            "key_length": "3",
            "rows_examined_per_scan": 90,
            "rows_produced_per_join": 90,
            "filtered": "100.00",
            "using_index": true,
            "cost_info": {
              "read_cost": "9.29",
              "eval_cost": "9.00",
              "prefix_cost": "18.29",
              "data_read_per_join": "1K"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "link_type"
            ],
            "attached_condition": "(`nuie_scalesta_net`.`cscart_products_categories`.`product_id` in (86856,85583,82561,90268,90264,90266,90273,91311,91313,91315,90267,90274,85649,85650,85651,91312,91314,91316,90263,90270,90269,90275,90265,93356,93357,93358,94117,94958,95683,95702))"
          }
        },
        {
          "table": {
            "table_name": "product_position_source",
            "access_type": "eq_ref",
            "possible_keys": [
              "PRIMARY",
              "pt"
            ],
            "key": "PRIMARY",
            "used_key_parts": [
              "category_id",
              "product_id"
            ],
            "key_length": "6",
            "ref": [
              "const",
              "nuie_scalesta_net.cscart_products_categories.product_id"
            ],
            "rows_examined_per_scan": 1,
            "rows_produced_per_join": 90,
            "filtered": "100.00",
            "cost_info": {
              "read_cost": "22.50",
              "eval_cost": "9.00",
              "prefix_cost": "49.79",
              "data_read_per_join": "1K"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "position"
            ]
          }
        },
        {
          "table": {
            "table_name": "cscart_categories",
            "access_type": "eq_ref",
            "possible_keys": [
              "PRIMARY",
              "c_status",
              "p_category_id"
            ],
            "key": "PRIMARY",
            "used_key_parts": [
              "category_id"
            ],
            "key_length": "3",
            "ref": [
              "nuie_scalesta_net.cscart_products_categories.category_id"
            ],
            "rows_examined_per_scan": 1,
            "rows_produced_per_join": 4,
            "filtered": "5.00",
            "cost_info": {
              "read_cost": "22.50",
              "eval_cost": "0.45",
              "prefix_cost": "81.29",
              "data_read_per_join": "11K"
            },
            "used_columns": [
              "category_id",
              "usergroup_ids",
              "status",
              "storefront_id"
            ],
            "attached_condition": "((`nuie_scalesta_net`.`cscart_categories`.`storefront_id` in (0,1)) and ((`nuie_scalesta_net`.`cscart_categories`.`usergroup_ids` = '') or (0 <> find_in_set(0,`nuie_scalesta_net`.`cscart_categories`.`usergroup_ids`)) or (0 <> find_in_set(1,`nuie_scalesta_net`.`cscart_categories`.`usergroup_ids`))) and (`nuie_scalesta_net`.`cscart_categories`.`status` in ('A','H')))"
          }
        }
      ]
    }
  }
}

Result

product_id category_ids position
82561 7167M,7183,7283
85583 7149M,7182,7300 0
85649 7283,7183,7167M
85650 7283,7167M,7183
85651 7167M,7283,7183
86856 7300,7182,7149M 0
90263 7183,7167M,7283
90264 7167M,7183,7283
90265 7167M,7283,7183
90266 7283,7183,7167M
90267 7183,7283,7167M
90268 7283,7183,7167M
90269 7283,7167M,7183
90270 7167M,7283,7183
90273 7183,7283,7167M
90274 7183,7167M,7283
90275 7183,7283,7167M
91311 7183,7283,7167M
91312 7183,7283,7167M
91313 7283,7167M,7183
91314 7167M,7283,7183
91315 7183,7167M,7283
91316 7183,7283,7167M
93356 7183,7283,7167M
93357 7283,7183,7167M
93358 7283,7167M,7183
94117 7167M,7183,7283
94958 7167M,7283,7183
95683 7167M,7283,7183
95702 7183,7167M,7283