diff --git a/aspnetcore/blazor/hybrid/handle-errors.md b/aspnetcore/blazor/hybrid/handle-errors.md
new file mode 100644
index 000000000000..eaadc52d5127
--- /dev/null
+++ b/aspnetcore/blazor/hybrid/handle-errors.md
@@ -0,0 +1,101 @@
+---
+title: Handle errors in ASP.NET Core Blazor Hybrid
+author: guardrex
+description: Learn how to develop ASP.NET Core Blazor Hybrid apps that detect and handle errors.
+monikerRange: '>= aspnetcore-6.0'
+ms.author: riande
+ms.custom: "mvc"
+ms.date: 03/24/2022
+no-loc: ["Blazor Hybrid", Home, Privacy, Kestrel, appsettings.json, "ASP.NET Core Identity", cookie, Cookie, Blazor, "Blazor Server", "Blazor WebAssembly", "Identity", "Let's Encrypt", Razor, SignalR]
+uid: blazor/hybrid/handle-errors
+zone_pivot_groups: blazor-hybrid-operating-systems
+---
+# Handle errors in ASP.NET Core Blazor Hybrid
+
+This article explains how to use [browser developer tools](https://developer.mozilla.org/docs/Glossary/Developer_Tools) with Blazor Hybrid apps.
+
+[!INCLUDE[](~/blazor/includes/blazor-hybrid-preview-notice.md)]
+
+## Browser developer tools with .NET MAUI Blazor
+
+Ensure the Blazor Hybrid project is configured to support browser developer tools. Locate the `CreateMauiApp` method in the app, which is likely within the app's `Program.cs` or `Startup.cs` file and contains `services.AddMauiBlazorWebView()`. If the services extension method to add services for `BlazorWebView` developer tools (`AddBlazorWebViewDeveloperTools`) isn't present in the app's `CreateMauiApp` method for debug app execution (compiler directive: `DEBUG`), add it to the `CreateMauiApp` method:
+
+```csharp
+#if DEBUG
+ services.AddBlazorWebViewDeveloperTools();
+#endif
+```
+
+> [!NOTE]
+> Guidance on popular browsers' developer tools can be found in the documentation of each browser maintainer:
+>
+> * [Chrome DevTools](https://developer.chrome.com/docs/devtools/)
+> * [Microsoft Edge Developer Tools overview](/microsoft-edge/devtools-guide-chromium/)
+> * [Safari Web Inspector](https://support.apple.com/guide/safari-developer/welcome/mac)
+
+:::zone pivot="windows"
+
+To use browser developer tools with a Windows app:
+
+1. Run the .NET MAUI Blazor app for Windows and navigate to an app page that uses a `BlazorWebView`.
+1. Use the keyboard shortcut Ctrl+Shift+I to open browser developer tools.
+1. Developer tools provide a variety of features for working with apps, including which assets the page requested, how long assets took to load, and the content of loaded assets. The following example shows the **Console** tab to see the console messages, which includes any exception messages generated by the framework or developer code:
+
+ data:image/s3,"s3://crabby-images/de310/de310b320f5019adb1da25457e7900f10b877922" alt="Microsoft Edge DevTools window for a Blazor Hybrid app running on Windows"
+
+:::zone-end
+
+:::zone pivot="android"
+
+To use browser developer tools with an Android app:
+
+1. Start the Android emulator and navigate to an app page that uses a `BlazorWebView`.
+1. Open Google Chrome or Microsoft Edge.
+1. Navigate to `chrome://inspect/#devices` (Google Chrome) or `edge://inspect/#devices` (Microsoft Edge).
+1. Select the **`inspect`** link button to open developer tools. The following example shows the **DevTools** page in Microsoft Edge:
+
+ data:image/s3,"s3://crabby-images/b7ad1/b7ad1109bee4ae6e2a3bf033f8cb1f2c3c56b6b3" alt="Microsoft Edge Devices showing the BlazorWebView's "inspect" link button to open developer tools."
+
+1. Developer tools provide a variety of features for working with apps, including which assets the page requested, how long assets took to load, and the content of loaded assets. The following example shows the **Console** tab to see the console messages, which includes any exception messages generated by the framework or developer code:
+
+ data:image/s3,"s3://crabby-images/4bd6d/4bd6d8a43c9f385e3cc5cb8995415f6a709ae465" alt="Microsoft Edge DevTools window for a Blazor Hybrid app running on an emulated Pixel 5"
+
+:::zone-end
+
+:::zone pivot="ios"
+
+To use Safari developer tools with an iOS app:
+
+1. Open desktop Safari.
+1. Select the **Preferences** > **Advanced** > **Show Develop** menu item.
+1. Run the .NET MAUI Blazor app in the iOS simulator and navigate to an app page that uses a `BlazorWebView`.
+1. Return to desktop Safari. Select **Develop** > **Simulator** > **0.0.0.0**. If multiple entries for **0.0.0.0** are present, select the entry that highlights the `BlazorWebView`. The `BlazorWebView` is highlighted in blue in the iOS simulator when the correct **0.0.0.0** entry is selected.
+
+ data:image/s3,"s3://crabby-images/5d3c5/5d3c5236367a0705bfc6957be0e8b2007ecf53dc" alt="Safari Develop Simulator open showing two entries for "0.0.0.0" with the second entry selected because it highlights the BlazorWebView in the Visual Studio emulator UI."
+
+1. The **Web Inspector** window appears for the `BlazorWebView`.
+1. Developer tools provide a variety of features for working with apps, including which assets the page requested, how long assets took to load, and the content of loaded assets. The following example shows the **Console** tab, which includes any exception messages generated by the framework or developer code:
+
+ data:image/s3,"s3://crabby-images/bced7/bced7028f3a65f451abc446ec67d0ec3d20f23de" alt="Safari Web Inspector and Simulator windows for a Blazor Hybrid app running on an emulated iPad mini"
+
+:::zone-end
+
+:::zone pivot="macos"
+
+Using browser developer tools with Mac Catalyst apps isn't currently supported. Please use the guidance for [iOS](?pivots=ios) apps, as the behavior is similar between the two platforms.
+
+
+
+:::zone-end
diff --git a/aspnetcore/blazor/hybrid/handle-errors/_static/android.png b/aspnetcore/blazor/hybrid/handle-errors/_static/android.png
new file mode 100644
index 000000000000..84b98ae6a472
Binary files /dev/null and b/aspnetcore/blazor/hybrid/handle-errors/_static/android.png differ
diff --git a/aspnetcore/blazor/hybrid/handle-errors/_static/edge1.png b/aspnetcore/blazor/hybrid/handle-errors/_static/edge1.png
new file mode 100644
index 000000000000..4613da7ff80b
Binary files /dev/null and b/aspnetcore/blazor/hybrid/handle-errors/_static/edge1.png differ
diff --git a/aspnetcore/blazor/hybrid/handle-errors/_static/edge2.png b/aspnetcore/blazor/hybrid/handle-errors/_static/edge2.png
new file mode 100644
index 000000000000..777c14d9dc48
Binary files /dev/null and b/aspnetcore/blazor/hybrid/handle-errors/_static/edge2.png differ
diff --git a/aspnetcore/blazor/hybrid/handle-errors/_static/ios.png b/aspnetcore/blazor/hybrid/handle-errors/_static/ios.png
new file mode 100644
index 000000000000..32240a9e1cc1
Binary files /dev/null and b/aspnetcore/blazor/hybrid/handle-errors/_static/ios.png differ
diff --git a/aspnetcore/blazor/hybrid/handle-errors/_static/safari1.png b/aspnetcore/blazor/hybrid/handle-errors/_static/safari1.png
new file mode 100644
index 000000000000..3caa86922634
Binary files /dev/null and b/aspnetcore/blazor/hybrid/handle-errors/_static/safari1.png differ
diff --git a/aspnetcore/blazor/hybrid/handle-errors/_static/safari2.png b/aspnetcore/blazor/hybrid/handle-errors/_static/safari2.png
new file mode 100644
index 000000000000..e9b862a1119b
Binary files /dev/null and b/aspnetcore/blazor/hybrid/handle-errors/_static/safari2.png differ
diff --git a/aspnetcore/toc.yml b/aspnetcore/toc.yml
index 9415ed2ae6bb..263520d307c9 100644
--- a/aspnetcore/toc.yml
+++ b/aspnetcore/toc.yml
@@ -351,6 +351,8 @@ items:
uid: blazor/hybrid/tutorials/wpf
- name: Routing and navigation
uid: blazor/hybrid/routing
+ - name: Handle errors
+ uid: blazor/hybrid/handle-errors
- name: Project structure
uid: blazor/project-structure
- name: Fundamentals
diff --git a/aspnetcore/zone-pivot-groups.yml b/aspnetcore/zone-pivot-groups.yml
index 3b67a1693e88..a598186e4a45 100644
--- a/aspnetcore/zone-pivot-groups.yml
+++ b/aspnetcore/zone-pivot-groups.yml
@@ -18,3 +18,15 @@ groups:
title: Blazor Server
- id: webassembly
title: Blazor WebAssembly
+- id: blazor-hybrid-operating-systems
+ title: Operating System
+ prompt: Target operating system
+ pivots:
+ - id: android
+ title: Android
+ - id: ios
+ title: iOS
+ - id: macos
+ title: macOS
+ - id: windows
+ title: Windows