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 = 280 
WHERE 
  cscart_products_categories.product_id IN (
    15745, 15746, 15743, 15738, 15739, 15740, 
    15741, 15742, 15736, 15737, 10668, 
    10669, 10670, 10671, 10672, 10673, 
    10674, 10675, 10676, 10677, 10678, 
    10679, 10680, 10681, 10682, 10683, 
    10684, 10685, 10686, 10607, 10608, 
    10609
  ) 
GROUP BY 
  cscart_products_categories.product_id

Query time 0.00205

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": 102,
      "filtered": 100,
      "index_condition": "cscart_products_categories.product_id in (15745,15746,15743,15738,15739,15740,15741,15742,15736,15737,10668,10669,10670,10671,10672,10673,10674,10675,10676,10677,10678,10679,10680,10681,10682,10683,10684,10685,10686,10607,10608,10609)"
    },
    "table": {
      "table_name": "product_position_source",
      "access_type": "eq_ref",
      "possible_keys": ["PRIMARY", "pt"],
      "key": "PRIMARY",
      "key_length": "6",
      "used_key_parts": ["category_id", "product_id"],
      "ref": [
        "const",
        "noframes_angrybeaver.cscart_products_categories.product_id"
      ],
      "rows": 1,
      "filtered": 100
    },
    "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 position
10607 1659M
10608 1659M
10609 1659M
10668 1661M
10669 1661M
10670 1661M
10671 1661M
10672 1661M
10673 1661M
10674 1661M
10675 1661M
10676 1661M
10677 1661M
10678 1661M
10679 1661M
10680 1661M
10681 1661M
10682 1661M
10683 1661M
10684 1661M
10685 1661M
10686 1661M
15736 301,1673M
15737 301,1673M
15738 301,1673M
15739 1673,301M
15740 301,1673M
15741 301,1673M
15742 1673,301M
15743 301,1673M
15745 301,1673M
15746 301,1673M