diff --git a/templates/content/node--uw-ct-single-page-home.html.twig b/templates/content/node--uw-ct-single-page-home.html.twig
new file mode 100644
index 0000000000000000000000000000000000000000..e5a0fb3eacc3faa92550fabdbc6dd901521bde0a
--- /dev/null
+++ b/templates/content/node--uw-ct-single-page-home.html.twig
@@ -0,0 +1,73 @@
+{#
+/**
+ * @file
+ * Theme override to display a node.
+ *
+ * Available variables:
+ * - node: The node entity with limited access to object properties and methods.
+ *   Only method names starting with "get", "has", or "is" and a few common
+ *   methods such as "id", "label", and "bundle" are available. For example:
+ *   - node.getCreatedTime() will return the node creation timestamp.
+ *   - node.hasField('field_example') returns TRUE if the node bundle includes
+ *     field_example. (This does not indicate the presence of a value in this
+ *     field.)
+ *   - node.isPublished() will return whether the node is published or not.
+ *   Calling other methods, such as node.delete(), will result in an exception.
+ *   See \Drupal\node\Entity\Node for a full list of public properties and
+ *   methods for the node object.
+ * - label: The title of the node.
+ * - content: All node items. Use {{ content }} to print them all,
+ *   or print a subset such as {{ content.field_example }}. Use
+ *   {{ content|without('field_example') }} to temporarily suppress the printing
+ *   of a given child element.
+ * - author_picture: The node author user entity, rendered using the "compact"
+ *   view mode.
+ * - metadata: Metadata for this node.
+ * - date: Themed creation date field.
+ * - author_name: Themed author name field.
+ * - url: Direct URL of the current node.
+ * - display_submitted: Whether submission information should be displayed.
+ * - attributes: HTML attributes for the containing element.
+ *   The attributes.class element may contain one or more of the following
+ *   classes:
+ *   - node: The current template type (also known as a "theming hook").
+ *   - node--type-[type]: The current node type. For example, if the node is an
+ *     "Article" it would result in "node--type-article". Note that the machine
+ *     name will often be in a short form of the human readable label.
+ *   - node--view-mode-[view_mode]: The View Mode of the node; for example, a
+ *     teaser would result in: "node--view-mode-teaser", and
+ *     full: "node--view-mode-full".
+ *   The following are controlled through the node publishing options.
+ *   - node--promoted: Appears on nodes promoted to the front page.
+ *   - node--sticky: Appears on nodes ordered above other non-sticky nodes in
+ *     teaser listings.
+ *   - node--unpublished: Appears on unpublished nodes visible only to site
+ *     admins.
+ * - title_attributes: Same as attributes, except applied to the main title
+ *   tag that appears in the template.
+ * - content_attributes: Same as attributes, except applied to the main
+ *   content tag that appears in the template.
+ * - author_attributes: Same as attributes, except applied to the author of
+ *   the node tag that appears in the template.
+ * - title_prefix: Additional output populated by modules, intended to be
+ *   displayed in front of the main title tag that appears in the template.
+ * - title_suffix: Additional output populated by modules, intended to be
+ *   displayed after the main title tag that appears in the template.
+ * - view_mode: View mode; for example, "teaser" or "full".
+ * - teaser: Flag for the teaser state. Will be true if view_mode is 'teaser'.
+ * - page: Flag for the full page state. Will be true if view_mode is 'full'.
+ * - readmore: Flag for more state. Will be true if the teaser content of the
+ *   node cannot hold the main body content.
+ * - logged_in: Flag for authenticated user status. Will be true when the
+ *   current user is a logged-in member.
+ * - is_admin: Flag for admin user status. Will be true when the current user
+ *   is an administrator.
+ *
+ * @see template_preprocess_node()
+ *
+ * @todo Remove the id attribute (or make it a class), because if that gets
+ *   rendered twice on a page this is invalid CSS for example: two lists
+ *   in different view modes.
+ */
+#}
+{% include "@organisms/_node.twig" %}
diff --git a/templates/paragraphs/paragraph--sph-para-header-video.html.twig b/templates/paragraphs/paragraph--sph-para-header-video.html.twig
new file mode 100644
index 0000000000000000000000000000000000000000..b5473a894e65df8df7b2ec7a483e5deefb0d4a28
--- /dev/null
+++ b/templates/paragraphs/paragraph--sph-para-header-video.html.twig
@@ -0,0 +1,47 @@
+{#
+/**
+ * @file
+ * Default theme implementation to display a paragraph.
+ *
+ * Available variables:
+ * - paragraph: Full paragraph entity.
+ *   - id: The paragraph ID.
+ *   - bundle: The type of the paragraph, for example, "image" or "text".
+ *   - authorid: The user ID of the paragraph author.
+ *   - createdtime: Formatted creation date. Preprocess functions can
+ *     reformat it by calling format_date() with the desired parameters on
+ *     $variables['paragraph']->getCreatedTime().
+ * - content: All paragraph items. Use {{ content }} to print them all,
+ *   or print a subset such as {{ content.field_example }}. Use
+ *   {{ content|without('field_example') }} to temporarily suppress the printing
+ *   of a given child element.
+ * - sources: The attributes of the <source> tags for this <picture> tag.
+ * - img_element: The controlling image, with the fallback image in srcset.
+ * - output_image_tag: Whether or not to output an <img> tag instead of a
+ *   <picture> tag.
+ * - attributes: HTML attributes for the containing element.
+ *   The attributes.class element may contain one or more of the following
+ *   classes:
+ *   - paragraphs: The current template type (also known as a "theming hook").
+ *   - paragraphs--type-[type]: The current paragraphs type. For example, if the paragraph is an
+ *     "Image" it would result in "paragraphs--type--image". Note that the machine
+ *     name will often be in a short form of the human readable label.
+ *   - paragraphs--view-mode--[view_mode]: The View Mode of the paragraph; for example, a
+ *     preview would result in: "paragraphs--view-mode--preview", and
+ *     default: "paragraphs--view-mode--default".
+ * - view_mode: View mode; for example, "preview" or "full".
+ * - logged_in: Flag for authenticated user status. Will be true when the
+ *   current user is a logged-in member.
+ * - is_admin: Flag for admin user status. Will be true when the current user
+ *   is an administrator.
+ *
+ * @see template_preprocess_paragraph()
+ *
+ * @ingroup themeable
+ */
+#}
+{{ attach_library('uw_fdsu_theme_resp/header_video') }}
+{% include "@organisms/single-page/header-video/header-video.twig" with {
+  "video_url": content.field_sph_banner_video|field_value,
+  "description": content.field_sph_banner_description|field_value
+} %}
diff --git a/uw_fdsu_theme_resp.libraries.yml b/uw_fdsu_theme_resp.libraries.yml
index 9edaec10bb51d95936fc20eb05a256853cb852bd..ba2dd4af68a7b49b7485d0a62384b01f50aa8f8c 100644
--- a/uw_fdsu_theme_resp.libraries.yml
+++ b/uw_fdsu_theme_resp.libraries.yml
@@ -13,6 +13,10 @@ responsive_menu_combined:
   js:
     uw_wcms_pattern_lab/components/_patterns/02-molecules/menus/responsive-menu-combined/responsive-menu-combined.js: {}
 
+header_video:
+  js:
+    uw_wcms_pattern_lab/components/_patterns/03-organisms/single-page/header-video/header-video.js: {}
+
 main_menu:
   js:
     uw_wcms_pattern_lab/components/_patterns/02-molecules/menus/main-menu/main-menu.js: {}
diff --git a/uw_fdsu_theme_resp.theme b/uw_fdsu_theme_resp.theme
index 3ecc51695116b1aedfc7fe823055e94119cd614d..3255887bcc14e944f3966728674603a6037dae80 100644
--- a/uw_fdsu_theme_resp.theme
+++ b/uw_fdsu_theme_resp.theme
@@ -26,6 +26,22 @@ function uw_fdsu_theme_resp_preprocess_region(&$variables) {
   }
 }
 
+function uw_fdsu_theme_resp_preprocess_node(&$variables) {
+
+  switch ($variables['node']->getType()) {
+    case "uw_ct_single_page_home":
+      $image_or_video = $variables['node']->get('field_sph_image_or_video')->value;
+
+      if ($image_or_video == "Video") {
+        unset($variables['content']['field_uw_sph_header_image']);
+      }
+      else {
+        unset($variables['content']['field_uw_banner_video']);
+      }
+      break;
+  }
+}
+
 /**
  * Implements hook_preprocess_paragraph().
  *