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 
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') 
WHERE 
  cscart_products_categories.product_id IN (
    10386, 10387, 10388, 10389, 10390, 10392, 
    10393, 10394, 10395, 10397, 10398, 
    10399, 10400, 10401, 10402, 10403, 
    10404, 10405, 15781, 10406
  ) 
GROUP BY 
  cscart_products_categories.product_id

Query time 0.00505

JSON explain

{
  "query_block": {
    "select_id": 1,
    "table": {
      "table_name": "cscart_products_categories",
      "access_type": "range",
      "possible_keys": ["PRIMARY", "pt"],
      "key": "pt",
      "key_length": "3",
      "used_key_parts": ["product_id"],
      "rows": 23,
      "filtered": 100,
      "index_condition": "cscart_products_categories.product_id in (10386,10387,10388,10389,10390,10392,10393,10394,10395,10397,10398,10399,10400,10401,10402,10403,10404,10405,15781,10406)"
    },
    "table": {
      "table_name": "cscart_categories",
      "access_type": "eq_ref",
      "possible_keys": ["PRIMARY", "c_status", "p_category_id"],
      "key": "PRIMARY",
      "key_length": "3",
      "used_key_parts": ["category_id"],
      "ref": ["noframes_angrybeaver.cscart_products_categories.category_id"],
      "rows": 1,
      "filtered": 100,
      "attached_condition": "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')"
    }
  }
}

Result

product_id category_ids
10386 1650M
10387 1650M
10388 1650M
10389 1650M
10390 1650M
10392 1650M
10393 1650M
10394 1650M
10395 1650M
10397 787M
10398 787M
10399 787M
10400 787M
10401 787M
10402 787M
10403 1655M
10404 1655M
10405 1655M
10406 1655M
15781 1655M