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 = 7148 
WHERE 
  cscart_products_categories.product_id IN (
    87676, 87682, 87683, 87703, 87704, 87713, 
    87715, 87727, 87729, 88692, 88693, 
    88739, 88740, 91897, 91898, 91899, 
    92341, 92343, 92344, 85643, 88925, 
    88926, 88927, 91470, 92186, 92187, 
    92188, 92189, 92190, 92441
  ) 
GROUP BY 
  cscart_products_categories.product_id

Query time 0.00153

JSON explain

{
  "query_block": {
    "select_id": 1,
    "cost_info": {
      "query_cost": "33.76"
    },
    "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": 59,
            "rows_produced_per_join": 59,
            "filtered": "100.00",
            "using_index": true,
            "cost_info": {
              "read_cost": "6.18",
              "eval_cost": "5.90",
              "prefix_cost": "12.08",
              "data_read_per_join": "944"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "link_type"
            ],
            "attached_condition": "(`nuie_scalesta_net`.`cscart_products_categories`.`product_id` in (87676,87682,87683,87703,87704,87713,87715,87727,87729,88692,88693,88739,88740,91897,91898,91899,92341,92343,92344,85643,88925,88926,88927,91470,92186,92187,92188,92189,92190,92441))"
          }
        },
        {
          "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": 2,
            "filtered": "5.00",
            "cost_info": {
              "read_cost": "14.75",
              "eval_cost": "0.30",
              "prefix_cost": "32.73",
              "data_read_per_join": "7K"
            },
            "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')))"
          }
        },
        {
          "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": 2,
            "filtered": "100.00",
            "cost_info": {
              "read_cost": "0.74",
              "eval_cost": "0.30",
              "prefix_cost": "33.76",
              "data_read_per_join": "47"
            },
            "used_columns": [
              "product_id",
              "category_id",
              "position"
            ]
          }
        }
      ]
    }
  }
}

Result

product_id category_ids position
85643 7148,7158M 0
87676 7194M
87682 7194M
87683 7194M
87703 7194M
87704 7194M
87713 7194M
87715 7194M
87727 7194M
87729 7194M
88692 7194M
88693 7194M
88739 7194M
88740 7194M
88925 7226,7225M
88926 7226,7225M
88927 7226,7225M
91470 7226,7225M
91897 7226,7225M
91898 7226,7225M
91899 7226,7225M
92186 7341,7342,7343,7157M
92187 7341,7342,7343,7157M
92188 7341,7342,7343,7157M
92189 7341,7342,7343,7157M
92190 7341,7342,7343,7157M
92341 7226,7225M
92343 7226,7225M
92344 7226,7225M
92441 7341,7342,7343,7157M