diff --git a/src/shell-app.c b/src/shell-app.c
index 2d98eb41a..f9ddd2b31 100644
--- a/src/shell-app.c
+++ b/src/shell-app.c
@@ -237,6 +237,7 @@ typedef struct {
   int size;
   int scale;
   ClutterTextDirection direction;
+  StThemeNode *theme_node;
 } CreateFadedIconData;
 
 static CoglHandle
@@ -264,19 +265,28 @@ shell_app_create_faded_icon_cpu (StTextureCache *cache,
   guint8 *pixels;
   GIcon *icon;
   GtkIconInfo *info;
+  GtkIconLookupFlags lookup_flags;
+  StIconStyle icon_style;
 
   app = data->app;
   size = data->size;
   scale = data->scale;
+  icon_style = st_theme_node_get_icon_style (data->theme_node);
 
   info = NULL;
 
+  lookup_flags = GTK_ICON_LOOKUP_FORCE_SIZE;
+  if (icon_style == ST_ICON_STYLE_REGULAR)
+    lookup_flags |= GTK_ICON_LOOKUP_FORCE_REGULAR;
+  else if (icon_style == ST_ICON_STYLE_SYMBOLIC)
+    lookup_flags |= GTK_ICON_LOOKUP_FORCE_SYMBOLIC;
+
   icon = g_app_info_get_icon (G_APP_INFO (app->info));
   if (icon != NULL)
     {
       info = gtk_icon_theme_lookup_by_gicon_for_scale (gtk_icon_theme_get_default (),
                                                        icon, size, scale,
-                                                       GTK_ICON_LOOKUP_FORCE_SIZE);
+                                                       lookup_flags);
     }
 
   if (info == NULL)
@@ -284,7 +294,7 @@ shell_app_create_faded_icon_cpu (StTextureCache *cache,
       icon = g_themed_icon_new ("application-x-executable");
       info = gtk_icon_theme_lookup_by_gicon_for_scale (gtk_icon_theme_get_default (),
                                                        icon, size, scale,
-                                                       GTK_ICON_LOOKUP_FORCE_SIZE);
+                                                       lookup_flags);
       g_object_unref (icon);
     }
 
@@ -391,6 +401,7 @@ shell_app_get_faded_icon (ShellApp *app, int size, ClutterTextDirection directio
   data.size = size;
   data.scale = scale;
   data.direction = direction;
+  data.theme_node = st_theme_context_get_root_node (context);
   texture = st_texture_cache_load (st_texture_cache_get_default (),
                                    cache_key,
                                    ST_TEXTURE_CACHE_POLICY_FOREVER,