diff --git a/assets/scripts/routes/catalog.js b/assets/scripts/routes/catalog.js
index e2744f6..3414188 100644
--- a/assets/scripts/routes/catalog.js
+++ b/assets/scripts/routes/catalog.js
@@ -30,7 +30,7 @@ export default {
 					while (
 						elem.nextElementSibling &&
 						elem.nextElementSibling.tagName !== 'H2'
-						) {
+					) {
 						elems.push( elem.nextElementSibling );
 						elem = elem.nextElementSibling;
 					}
@@ -100,7 +100,7 @@ export default {
 					while (
 						elem.nextElementSibling &&
 						elem.nextElementSibling.tagName !== 'H3'
-						) {
+					) {
 						elems.push( elem.nextElementSibling );
 						elem = elem.nextElementSibling;
 					}
diff --git a/assets/styles/aldine.scss b/assets/styles/aldine.scss
index 0cbde1e..4ba9ec4 100644
--- a/assets/styles/aldine.scss
+++ b/assets/styles/aldine.scss
@@ -11,6 +11,7 @@
 /** Import theme styles */
 @import "common/global";
 @import "components/book";
+@import "components/featured_book";
 @import "components/forms";
 @import "layouts/footer";
 @import "layouts/header";
diff --git a/assets/styles/components/_book.scss b/assets/styles/components/_book.scss
index fd40008..d566d55 100644
--- a/assets/styles/components/_book.scss
+++ b/assets/styles/components/_book.scss
@@ -3,16 +3,18 @@
   flex-direction: column;
   justify-content: flex-start;
   width: 100%;
-  max-width: 18rem;
-  height: 25rem;
-  border: solid 1px var(--accent);
+  max-width: 22.9375rem;
+  height: 24.125rem;
   margin: 0 0 2rem;
+  padding: 1.5rem 1rem 2rem;
+  @media #{$breakpoint-not-small} { padding: 1.5rem 1.85rem 2.1875rem; }
 
-  &__cover {
-    width: 100%;
-    height: 80%;
-    background-repeat: no-repeat;
-    background-size: cover;
+  border: solid 2px var(--accent);
+  background: var(--accent);
+
+  a, p {
+    font-family: $font-family-sans-serif;
+    color: var(--accent-fg);
   }
 
   a {
@@ -23,9 +25,62 @@
   }
 
   &__title {
-    display: flex;
-    justify-content: center;
-    align-items: center;
+    margin: 0;
+    font-size: 1.25rem;
+    @media #{$breakpoint-not-small} { font-size: 1.75rem; }
+
     font-weight: 500;
+    line-height: 1.2;
+    text-align: left;
+  }
+
+  &__subject {
+    margin: 0;
+    font-size: 0.75rem;
+    @media #{$breakpoint-not-small} {
+      font-size: 1rem;
+    }
+
+    text-align: left;
+  }
+
+  &__institutions {
+    margin: .5rem 0 0;
+    font-size: 0.875rem;
+    text-align: left;
+    display: box;
+    overflow: hidden;
+    -webkit-line-clamp: 2;
+    -webkit-box-orient: vertical;
+  }
+
+  &__read-more {
+    margin: auto 0 0;
+    font-size: 1rem;
+    @media #{$breakpoint-not-small} { font-size: 1.125rem; }
+
+    text-align: left;
+
+    a {
+      svg {
+        width: 1rem;
+        height: 1rem;
+        @media #{$breakpoint-not-small} {
+          width: 1.125rem;
+          height: 1.125rem;
+          margin-left: 0.5rem;
+        }
+
+        vertical-align: middle;
+      }
+    }
+  }
+
+  &:last-child {
+    margin-bottom: 0;
+
+    @media #{$breakpoint-large} {
+      margin-bottom: 2rem;
+    }
   }
 }
diff --git a/assets/styles/components/_featured_book.scss b/assets/styles/components/_featured_book.scss
new file mode 100644
index 0000000..4b82fbf
--- /dev/null
+++ b/assets/styles/components/_featured_book.scss
@@ -0,0 +1,31 @@
+.featured_book {
+  display: flex;
+  flex-direction: column;
+  justify-content: flex-start;
+  width: 100%;
+  max-width: 18rem;
+  height: 25rem;
+  border: solid 1px var(--accent);
+  margin: 0 0 2rem;
+
+  &__cover {
+    width: 100%;
+    height: 80%;
+    background-repeat: no-repeat;
+    background-size: cover;
+  }
+
+  a {
+    margin: 0;
+    text-decoration: none;
+    text-align: center;
+    hyphens: auto;
+  }
+
+  &__title {
+    display: flex;
+    justify-content: center;
+    align-items: center;
+    font-weight: 500;
+  }
+}
diff --git a/assets/styles/layouts/_page-catalog.scss b/assets/styles/layouts/_page-catalog.scss
index a8213ef..54e44b2 100644
--- a/assets/styles/layouts/_page-catalog.scss
+++ b/assets/styles/layouts/_page-catalog.scss
@@ -1,6 +1,6 @@
 // stylelint-disable no-descending-specificity
 
-fieldset {
+.network-catalog fieldset {
   border-top: solid 2px var(--accent);
   font-family: $font-family-sans-serif;
 
@@ -128,7 +128,7 @@ fieldset {
     margin: 2rem 0 1rem 1rem;
   }
 
-  .book {
+  .book, .featured_book {
     height: 14.375rem;
     width: calc(50% - 1rem);
     margin: 0 1rem 1rem 0;
diff --git a/assets/styles/layouts/_page-home.scss b/assets/styles/layouts/_page-home.scss
index 8bd4201..c745873 100644
--- a/assets/styles/layouts/_page-home.scss
+++ b/assets/styles/layouts/_page-home.scss
@@ -79,7 +79,7 @@
       flex-direction: row;
       justify-content: center;
 
-      .book {
+      .book, .featured_book {
         margin-right: 1rem;
         margin-left: 1rem;
       }
diff --git a/dist/scripts/aldine.js b/dist/scripts/aldine.js
index 49485a3..659e95d 100644
--- a/dist/scripts/aldine.js
+++ b/dist/scripts/aldine.js
@@ -27,7 +27,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _rou
 /***/ (function(__unused_webpack_module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-eval("__webpack_require__.r(__webpack_exports__);\n/* provided dependency */ var jQuery = __webpack_require__(/*! jquery */ \"./node_modules/jquery/dist/jquery.js\");\nvar Isotope = __webpack_require__(/*! isotope-layout */ \"./node_modules/isotope-layout/js/isotope.js\");\nvar jQueryBridget = __webpack_require__(/*! jquery-bridget */ \"./node_modules/jquery-bridget/jquery-bridget.js\");\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n  /**\n   *\n   */init: function init() {\n    // JavaScript to be fired on the catalog page\n    (function () {\n      // Get all the <h2> headings\n      var headings = document.querySelectorAll('fieldset h2');\n      Array.prototype.forEach.call(headings, function (heading) {\n        // Give each <h3> a toggle button child\n        heading.innerHTML = \"\\n\\t\\t\\t\\t<button type=\\\"button\\\" aria-expanded=\\\"false\\\">\\n\\t\\t\\t\\t\\t\".concat(heading.textContent, \"\\n\\t\\t\\t\\t\\t<svg aria-hidden=\\\"true\\\" focusable=\\\"false\\\" class=\\\"arrow\\\" width=\\\"13\\\" height=\\\"8\\\" viewBox=\\\"0 0 13 8\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\"><path d=\\\"M6.255 8L0 0h12.51z\\\" fill=\\\"currentColor\\\" fill-rule=\\\"evenodd\\\"></path></svg>\\n\\t\\t\\t\\t</button>\\n\\t\\t\\t  \");\n\n        // Function to create a node list\n        // of the content between this <h2> and the next\n        /**\n         * @param elem\n         */\n        var getContent = function getContent(elem) {\n          var elems = [];\n          while (elem.nextElementSibling && elem.nextElementSibling.tagName !== 'H2') {\n            elems.push(elem.nextElementSibling);\n            elem = elem.nextElementSibling;\n          }\n\n          // Delete the old versions of the content nodes\n          elems.forEach(function (node) {\n            node.parentNode.removeChild(node);\n          });\n          return elems;\n        };\n\n        // Assign the contents to be expanded/collapsed (array)\n        var contents = getContent(heading);\n\n        // Create a wrapper element for `contents` and hide it\n        var wrapper = document.createElement('div');\n        wrapper.hidden = true;\n\n        // Add each element of `contents` to `wrapper`\n        contents.forEach(function (node) {\n          wrapper.appendChild(node);\n        });\n\n        // Add the wrapped content back into the DOM\n        // after the heading\n        heading.parentNode.insertBefore(wrapper, heading.nextElementSibling);\n\n        // Assign the button\n        var btn = heading.querySelector('button');\n\n        /**\n         *\n         */\n        btn.onclick = function () {\n          // Cast the state as a boolean\n          var expanded = btn.getAttribute('aria-expanded') === 'true' || false;\n\n          // Switch the state\n          btn.setAttribute('aria-expanded', !expanded);\n          // Switch the content's visibility\n          wrapper.hidden = expanded;\n        };\n      });\n    })();\n    (function () {\n      // Get all the <h3> headings\n      var headings = document.querySelectorAll('fieldset h3');\n      Array.prototype.forEach.call(headings, function (heading) {\n        // Give each <h3> a toggle button child\n        heading.innerHTML = \"\\n\\t\\t\\t\\t<button type=\\\"button\\\" aria-expanded=\\\"false\\\">\\n\\t\\t\\t\\t\\t\".concat(heading.innerHTML, \"\\n\\t\\t\\t\\t\\t<svg class=\\\"arrow\\\" width=\\\"13\\\" height=\\\"8\\\" viewBox=\\\"0 0 13 8\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\"><path d=\\\"M6.255 8L0 0h12.51z\\\" fill=\\\"currentColor\\\" fill-rule=\\\"evenodd\\\"></path></svg>\\n\\t\\t\\t\\t</button>\\n\\t\\t\\t  \");\n\n        // Function to create a node list\n        // of the content between this <h2> and the next\n        /**\n         * @param elem\n         */\n        var getContent = function getContent(elem) {\n          var elems = [];\n          while (elem.nextElementSibling && elem.nextElementSibling.tagName !== 'H3') {\n            elems.push(elem.nextElementSibling);\n            elem = elem.nextElementSibling;\n          }\n\n          // Delete the old versions of the content nodes\n          elems.forEach(function (node) {\n            node.parentNode.removeChild(node);\n          });\n          return elems;\n        };\n\n        // Assign the contents to be expanded/collapsed (array)\n        var contents = getContent(heading);\n\n        // Create a wrapper element for `contents` and hide it\n        var wrapper = document.createElement('div');\n        wrapper.hidden = true;\n\n        // Add each element of `contents` to `wrapper`\n        contents.forEach(function (node) {\n          wrapper.appendChild(node);\n        });\n\n        // Add the wrapped content back into the DOM\n        // after the heading\n        heading.parentNode.insertBefore(wrapper, heading.nextElementSibling);\n\n        // Assign the button\n        var btn = heading.querySelector('button');\n\n        /**\n         *\n         */\n        btn.onclick = function () {\n          // Cast the state as a boolean\n          var expanded = btn.getAttribute('aria-expanded') === 'true' || false;\n\n          // Switch the state\n          btn.setAttribute('aria-expanded', !expanded);\n          // Switch the content's visibility\n          wrapper.hidden = expanded;\n        };\n      });\n    })();\n    jQuery(function ($) {\n      jQueryBridget('isotope', Isotope, $);\n      var $grid = $('.books');\n      $grid.isotope({\n        itemSelector: '.book',\n        getSortData: {\n          title: '.book__title a',\n          subject: '[data-subject]',\n          latest: '[data-date-published]'\n        },\n        sortAscending: {\n          title: true,\n          subject: false,\n          latest: false\n        }\n      });\n      var licenses = document.querySelector('.license-filters');\n      var subjects = document.querySelector('.subject-filters');\n      var institutions = document.querySelector('.institution-filters');\n      var sorts = document.querySelector('.sorts');\n      var clearFilters = document.querySelector('.clear-filters');\n      clearFilters.hidden = false;\n      licenses.addEventListener('click', function (event) {\n        if (event.target.type !== 'radio') {\n          return;\n        }\n        var subject = subjects.querySelector('input[type=\"radio\"]:checked').value ? \"[data-subject=\\\"\".concat(subjects.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n        var institution = institutions.querySelector('input[type=\"radio\"]:checked').value ? \"[data-institution*=\\\"\".concat(institutions.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n        var license = event.target.value ? \"[data-license=\\\"\".concat(event.target.value, \"\\\"]\") : '';\n        var filterValue = subject || license || institution ? \"\".concat(subject).concat(license).concat(institution) : '*';\n        $grid.isotope({\n          filter: filterValue\n        });\n      });\n      institutions.addEventListener('click', function (event) {\n        if (event.target.type !== 'radio') {\n          return;\n        }\n        var subject = subjects.querySelector('input[type=\"radio\"]:checked').value ? \"[data-subject=\\\"\".concat(subjects.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n        var license = licenses.querySelector('input[type=\"radio\"]:checked').value ? \"[data-license=\\\"\".concat(licenses.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n        var institution = event.target.value ? \"[data-institution*=\\\"\".concat(event.target.value, \"\\\"]\") : '';\n        var filterValue = subject || license || institution ? \"\".concat(subject).concat(license).concat(institution) : '*';\n        $grid.isotope({\n          filter: filterValue\n        });\n      });\n      subjects.addEventListener('click', function (event) {\n        if (event.target.type !== 'radio') {\n          return;\n        }\n        var license = licenses.querySelector('input[type=\"radio\"]:checked').value ? \"[data-license=\\\"\".concat(licenses.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n        var institution = institutions.querySelector('input[type=\"radio\"]:checked').value ? \"[data-institution*=\\\"\".concat(institutions.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n        var subject = event.target.value ? \"[data-subject=\\\"\".concat(event.target.value, \"\\\"]\") : '';\n        var filterValue = subject || license || institution ? \"\".concat(subject).concat(license).concat(institution) : '*';\n        $grid.isotope({\n          filter: filterValue\n        });\n      });\n      clearFilters.addEventListener('click', function () {\n        var allLicenses = document.getElementById('all-licenses');\n        var allSubjects = document.getElementById('all-subjects');\n        var allInstitutions = document.getElementById('all-institutions');\n        allLicenses.checked = true;\n        allSubjects.checked = true;\n        allInstitutions.checked = true;\n        $grid.isotope({\n          filter: '*'\n        });\n      });\n      sorts.addEventListener('click', function (event) {\n        if (event.target.type !== 'radio') {\n          return;\n        }\n        $grid.isotope({\n          sortBy: event.target.value\n        });\n      });\n      // \t$('.filters > a').click(e => {\n      // \t\te.preventDefault();\n      // \t\t$('.filters').toggleClass('is-active');\n      // \t\t$('.filter-groups > div').removeClass('is-active');\n      // \t});\n      // \t$('.filter-groups .subjects > a').click(e => {\n      // \t\te.preventDefault();\n      // \t\tlet id = $(e.currentTarget).attr('href');\n      // \t\t$(`.filter-groups .subjects:not(${id})`).removeClass('is-active');\n      // \t\t$(`.filter-groups ${id}`).toggleClass('is-active');\n      // \t});\n      // \t$('.licenses > a').click(e => {\n      // \t\te.preventDefault();\n      // \t\tlet id = $(e.currentTarget).attr('href');\n      // \t\t$(id).toggleClass('is-active');\n      // \t});\n      // \t$('.subjects .filter-list a').click(e => {\n      // \t\te.preventDefault();\n      // \t\tif ($(e.currentTarget).hasClass('is-active')) {\n      // \t\t\t$('.subjects .filter-list a').removeClass('is-active');\n      // \t\t\t$('.subjects').removeClass('has-active-child');\n      // \t\t} else {\n      // \t\t\t$('.subjects .filter-list a').removeClass('is-active');\n      // \t\t\t$(e.currentTarget).addClass('is-active');\n      // \t\t\t$('.subjects').removeClass('has-active-child');\n      // \t\t\t$(e.currentTarget)\n      // \t\t\t\t.parent()\n      // \t\t\t\t.parent()\n      // \t\t\t\t.parent('.subjects')\n      // \t\t\t\t.addClass('has-active-child');\n      // \t\t}\n      // \t\tlet subjectValue = $('.subjects .filter-list a.is-active').attr(\n      // \t\t\t'data-filter'\n      // \t\t);\n      // \t\tlet licenseValue = $('.licenses .filter-list a.is-active').attr(\n      // \t\t\t'data-filter'\n      // \t\t);\n      // \t\tif (typeof licenseValue === 'undefined') {\n      // \t\t\tlicenseValue = '';\n      // \t\t} else {\n      // \t\t\tlicenseValue = `[data-license=\"${licenseValue}\"]`;\n      // \t\t}\n      // \t\tif (typeof subjectValue === 'undefined') {\n      // \t\t\tsubjectValue = '';\n      // \t\t} else {\n      // \t\t\tsubjectValue = `[data-subject=\"${subjectValue}\"]`;\n      // \t\t}\n      // \t\t$grid.isotope({ filter: `${subjectValue}${licenseValue}` });\n      // \t});\n      // \t$('.licenses .filter-list a').click(e => {\n      // \t\te.preventDefault();\n      // \t\tif ($(e.currentTarget).hasClass('is-active')) {\n      // \t\t\t$('.licenses .filter-list a').removeClass('is-active');\n      // \t\t\t$('.licenses').removeClass('has-active-child');\n      // \t\t} else {\n      // \t\t\t$('.licenses .filter-list a').removeClass('is-active');\n      // \t\t\t$(e.currentTarget).addClass('is-active');\n      // \t\t\t$('.licenses').addClass('has-active-child');\n      // \t\t}\n      // \t\tlet subjectValue = $('.subjects .filter-list a.is-active').attr(\n      // \t\t\t'data-filter'\n      // \t\t);\n      // \t\tlet licenseValue = $('.licenses .filter-list a.is-active').attr(\n      // \t\t\t'data-filter'\n      // \t\t);\n      // \t\tif (typeof licenseValue === 'undefined') {\n      // \t\t\tlicenseValue = '';\n      // \t\t} else {\n      // \t\t\tlicenseValue = `[data-license=\"${licenseValue}\"]`;\n      // \t\t}\n      // \t\tif (typeof subjectValue === 'undefined') {\n      // \t\t\tsubjectValue = '';\n      // \t\t} else {\n      // \t\t\tsubjectValue = `[data-subject=\"${subjectValue}\"]`;\n      // \t\t}\n      // \t\t$grid.isotope({ filter: `${subjectValue}${licenseValue}` });\n      // \t});\n      // \t$('.sort > a').click(e => {\n      // \t\te.preventDefault();\n      // \t\t$('.sort').toggleClass('is-active');\n      // \t});\n      // \t$('.sorts a').click(e => {\n      // \t\te.preventDefault();\n      // \t\tlet sortBy = $(e.currentTarget).attr('data-sort');\n      // \t\t$('.sorts a').removeClass('is-active');\n      // \t\t$(e.currentTarget).addClass('is-active');\n      // \t\t$grid.isotope({ sortBy: sortBy });\n      // \t});\n    });\n  },\n  /**\n   *\n   */finalize: function finalize() {}\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./assets/scripts/routes/catalog.js.js","mappings":"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","sources":["webpack://@pressbooks/pressbooks-aldine/./assets/scripts/routes/catalog.js?f5df"],"sourcesContent":["const Isotope = require( 'isotope-layout' );\nconst jQueryBridget = require( 'jquery-bridget' );\n\nexport default {\n\t/**\n\t *\n\t */\n\tinit() {\n\t\t// JavaScript to be fired on the catalog page\n\t\t( function () {\n\t\t\t// Get all the <h2> headings\n\t\t\tconst headings = document.querySelectorAll( 'fieldset h2' );\n\n\t\t\tArray.prototype.forEach.call( headings, heading => {\n\t\t\t\t// Give each <h3> a toggle button child\n\t\t\t\theading.innerHTML = `\n\t\t\t\t<button type=\"button\" aria-expanded=\"false\">\n\t\t\t\t\t${ heading.textContent }\n\t\t\t\t\t<svg aria-hidden=\"true\" focusable=\"false\" class=\"arrow\" width=\"13\" height=\"8\" viewBox=\"0 0 13 8\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.255 8L0 0h12.51z\" fill=\"currentColor\" fill-rule=\"evenodd\"></path></svg>\n\t\t\t\t</button>\n\t\t\t  `;\n\n\t\t\t\t// Function to create a node list\n\t\t\t\t// of the content between this <h2> and the next\n\t\t\t\t/**\n\t\t\t\t * @param elem\n\t\t\t\t */\n\t\t\t\tconst getContent = elem => {\n\t\t\t\t\tlet elems = [];\n\t\t\t\t\twhile (\n\t\t\t\t\t\telem.nextElementSibling &&\n\t\t\t\t\t\telem.nextElementSibling.tagName !== 'H2'\n\t\t\t\t\t\t) {\n\t\t\t\t\t\telems.push( elem.nextElementSibling );\n\t\t\t\t\t\telem = elem.nextElementSibling;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Delete the old versions of the content nodes\n\t\t\t\t\telems.forEach( node => {\n\t\t\t\t\t\tnode.parentNode.removeChild( node );\n\t\t\t\t\t} );\n\n\t\t\t\t\treturn elems;\n\t\t\t\t};\n\n\t\t\t\t// Assign the contents to be expanded/collapsed (array)\n\t\t\t\tlet contents = getContent( heading );\n\n\t\t\t\t// Create a wrapper element for `contents` and hide it\n\t\t\t\tlet wrapper = document.createElement( 'div' );\n\t\t\t\twrapper.hidden = true;\n\n\t\t\t\t// Add each element of `contents` to `wrapper`\n\t\t\t\tcontents.forEach( node => {\n\t\t\t\t\twrapper.appendChild( node );\n\t\t\t\t} );\n\n\t\t\t\t// Add the wrapped content back into the DOM\n\t\t\t\t// after the heading\n\t\t\t\theading.parentNode.insertBefore( wrapper, heading.nextElementSibling );\n\n\t\t\t\t// Assign the button\n\t\t\t\tlet btn = heading.querySelector( 'button' );\n\n\t\t\t\t/**\n\t\t\t\t *\n\t\t\t\t */\n\t\t\t\tbtn.onclick = () => {\n\t\t\t\t\t// Cast the state as a boolean\n\t\t\t\t\tlet expanded = btn.getAttribute( 'aria-expanded' ) === 'true' || false;\n\n\t\t\t\t\t// Switch the state\n\t\t\t\t\tbtn.setAttribute( 'aria-expanded', ! expanded );\n\t\t\t\t\t// Switch the content's visibility\n\t\t\t\t\twrapper.hidden = expanded;\n\t\t\t\t};\n\t\t\t} );\n\t\t} )();\n\n\t\t( function () {\n\t\t\t// Get all the <h3> headings\n\t\t\tconst headings = document.querySelectorAll( 'fieldset h3' );\n\n\t\t\tArray.prototype.forEach.call( headings, heading => {\n\t\t\t\t// Give each <h3> a toggle button child\n\t\t\t\theading.innerHTML = `\n\t\t\t\t<button type=\"button\" aria-expanded=\"false\">\n\t\t\t\t\t${ heading.innerHTML }\n\t\t\t\t\t<svg class=\"arrow\" width=\"13\" height=\"8\" viewBox=\"0 0 13 8\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.255 8L0 0h12.51z\" fill=\"currentColor\" fill-rule=\"evenodd\"></path></svg>\n\t\t\t\t</button>\n\t\t\t  `;\n\n\t\t\t\t// Function to create a node list\n\t\t\t\t// of the content between this <h2> and the next\n\t\t\t\t/**\n\t\t\t\t * @param elem\n\t\t\t\t */\n\t\t\t\tconst getContent = elem => {\n\t\t\t\t\tlet elems = [];\n\t\t\t\t\twhile (\n\t\t\t\t\t\telem.nextElementSibling &&\n\t\t\t\t\t\telem.nextElementSibling.tagName !== 'H3'\n\t\t\t\t\t\t) {\n\t\t\t\t\t\telems.push( elem.nextElementSibling );\n\t\t\t\t\t\telem = elem.nextElementSibling;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Delete the old versions of the content nodes\n\t\t\t\t\telems.forEach( node => {\n\t\t\t\t\t\tnode.parentNode.removeChild( node );\n\t\t\t\t\t} );\n\n\t\t\t\t\treturn elems;\n\t\t\t\t};\n\n\t\t\t\t// Assign the contents to be expanded/collapsed (array)\n\t\t\t\tlet contents = getContent( heading );\n\n\t\t\t\t// Create a wrapper element for `contents` and hide it\n\t\t\t\tlet wrapper = document.createElement( 'div' );\n\t\t\t\twrapper.hidden = true;\n\n\t\t\t\t// Add each element of `contents` to `wrapper`\n\t\t\t\tcontents.forEach( node => {\n\t\t\t\t\twrapper.appendChild( node );\n\t\t\t\t} );\n\n\t\t\t\t// Add the wrapped content back into the DOM\n\t\t\t\t// after the heading\n\t\t\t\theading.parentNode.insertBefore( wrapper, heading.nextElementSibling );\n\n\t\t\t\t// Assign the button\n\t\t\t\tlet btn = heading.querySelector( 'button' );\n\n\t\t\t\t/**\n\t\t\t\t *\n\t\t\t\t */\n\t\t\t\tbtn.onclick = () => {\n\t\t\t\t\t// Cast the state as a boolean\n\t\t\t\t\tlet expanded = btn.getAttribute( 'aria-expanded' ) === 'true' || false;\n\n\t\t\t\t\t// Switch the state\n\t\t\t\t\tbtn.setAttribute( 'aria-expanded', ! expanded );\n\t\t\t\t\t// Switch the content's visibility\n\t\t\t\t\twrapper.hidden = expanded;\n\t\t\t\t};\n\t\t\t} );\n\t\t} )();\n\n\t\tjQuery( $ => {\n\t\t\tjQueryBridget( 'isotope', Isotope, $ );\n\t\t\tlet $grid = $( '.books' );\n\t\t\t$grid.isotope( {\n\t\t\t\titemSelector: '.book',\n\t\t\t\tgetSortData: {\n\t\t\t\t\ttitle: '.book__title a',\n\t\t\t\t\tsubject: '[data-subject]',\n\t\t\t\t\tlatest: '[data-date-published]',\n\t\t\t\t},\n\t\t\t\tsortAscending: {\n\t\t\t\t\ttitle: true,\n\t\t\t\t\tsubject: false,\n\t\t\t\t\tlatest: false,\n\t\t\t\t},\n\t\t\t} );\n\t\t\tlet licenses = document.querySelector( '.license-filters' );\n\t\t\tlet subjects = document.querySelector( '.subject-filters' );\n\t\t\tlet institutions = document.querySelector( '.institution-filters' );\n\t\t\tlet sorts = document.querySelector( '.sorts' );\n\t\t\tlet clearFilters = document.querySelector( '.clear-filters' );\n\t\t\tclearFilters.hidden = false;\n\t\t\tlicenses.addEventListener( 'click', function ( event ) {\n\t\t\t\tif ( event.target.type !== 'radio' ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tconst subject = subjects.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-subject=\"${ subjects.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst institution = institutions.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-institution*=\"${ institutions.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst license = event.target.value\n\t\t\t\t\t? `[data-license=\"${ event.target.value }\"]`\n\t\t\t\t\t: '';\n\n\t\t\t\tconst filterValue = subject || license || institution ? `${ subject }${ license }${ institution }` : '*';\n\n\t\t\t\t$grid.isotope( { filter: filterValue } );\n\t\t\t} );\n\t\t\tinstitutions.addEventListener( 'click', function ( event ) {\n\t\t\t\tif ( event.target.type !== 'radio' ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tconst subject = subjects.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-subject=\"${ subjects.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst license = licenses.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-license=\"${ licenses.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst institution = event.target.value\n\t\t\t\t\t? `[data-institution*=\"${ event.target.value }\"]`\n\t\t\t\t\t: '';\n\n\t\t\t\tconst filterValue = subject || license || institution ? `${ subject }${ license }${ institution }` : '*';\n\n\t\t\t\t$grid.isotope( { filter: filterValue } );\n\t\t\t} );\n\t\t\tsubjects.addEventListener( 'click', function ( event ) {\n\t\t\t\tif ( event.target.type !== 'radio' ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tconst license = licenses.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-license=\"${ licenses.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst institution = institutions.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-institution*=\"${ institutions.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst subject = event.target.value\n\t\t\t\t\t? `[data-subject=\"${ event.target.value }\"]`\n\t\t\t\t\t: '';\n\n\t\t\t\tconst filterValue = subject || license || institution ? `${ subject }${ license }${ institution }` : '*';\n\n\t\t\t\t$grid.isotope( { filter: filterValue } );\n\t\t\t} );\n\t\t\tclearFilters.addEventListener( 'click', function () {\n\t\t\t\tlet allLicenses = document.getElementById( 'all-licenses' );\n\t\t\t\tlet allSubjects = document.getElementById( 'all-subjects' );\n\t\t\t\tlet allInstitutions = document.getElementById( 'all-institutions' );\n\t\t\t\tallLicenses.checked = true;\n\t\t\t\tallSubjects.checked = true;\n\t\t\t\tallInstitutions.checked = true;\n\t\t\t\t$grid.isotope( { filter: '*' } );\n\t\t\t} );\n\t\t\tsorts.addEventListener( 'click', function ( event ) {\n\t\t\t\tif ( event.target.type !== 'radio' ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\t$grid.isotope( { sortBy: event.target.value } );\n\t\t\t} );\n\t\t\t// \t$('.filters > a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\t$('.filters').toggleClass('is-active');\n\t\t\t// \t\t$('.filter-groups > div').removeClass('is-active');\n\t\t\t// \t});\n\t\t\t// \t$('.filter-groups .subjects > a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tlet id = $(e.currentTarget).attr('href');\n\t\t\t// \t\t$(`.filter-groups .subjects:not(${id})`).removeClass('is-active');\n\t\t\t// \t\t$(`.filter-groups ${id}`).toggleClass('is-active');\n\t\t\t// \t});\n\t\t\t// \t$('.licenses > a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tlet id = $(e.currentTarget).attr('href');\n\t\t\t// \t\t$(id).toggleClass('is-active');\n\t\t\t// \t});\n\t\t\t// \t$('.subjects .filter-list a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tif ($(e.currentTarget).hasClass('is-active')) {\n\t\t\t// \t\t\t$('.subjects .filter-list a').removeClass('is-active');\n\t\t\t// \t\t\t$('.subjects').removeClass('has-active-child');\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\t$('.subjects .filter-list a').removeClass('is-active');\n\t\t\t// \t\t\t$(e.currentTarget).addClass('is-active');\n\t\t\t// \t\t\t$('.subjects').removeClass('has-active-child');\n\t\t\t// \t\t\t$(e.currentTarget)\n\t\t\t// \t\t\t\t.parent()\n\t\t\t// \t\t\t\t.parent()\n\t\t\t// \t\t\t\t.parent('.subjects')\n\t\t\t// \t\t\t\t.addClass('has-active-child');\n\t\t\t// \t\t}\n\t\t\t// \t\tlet subjectValue = $('.subjects .filter-list a.is-active').attr(\n\t\t\t// \t\t\t'data-filter'\n\t\t\t// \t\t);\n\t\t\t// \t\tlet licenseValue = $('.licenses .filter-list a.is-active').attr(\n\t\t\t// \t\t\t'data-filter'\n\t\t\t// \t\t);\n\t\t\t// \t\tif (typeof licenseValue === 'undefined') {\n\t\t\t// \t\t\tlicenseValue = '';\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\tlicenseValue = `[data-license=\"${licenseValue}\"]`;\n\t\t\t// \t\t}\n\t\t\t// \t\tif (typeof subjectValue === 'undefined') {\n\t\t\t// \t\t\tsubjectValue = '';\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\tsubjectValue = `[data-subject=\"${subjectValue}\"]`;\n\t\t\t// \t\t}\n\t\t\t// \t\t$grid.isotope({ filter: `${subjectValue}${licenseValue}` });\n\t\t\t// \t});\n\t\t\t// \t$('.licenses .filter-list a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tif ($(e.currentTarget).hasClass('is-active')) {\n\t\t\t// \t\t\t$('.licenses .filter-list a').removeClass('is-active');\n\t\t\t// \t\t\t$('.licenses').removeClass('has-active-child');\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\t$('.licenses .filter-list a').removeClass('is-active');\n\t\t\t// \t\t\t$(e.currentTarget).addClass('is-active');\n\t\t\t// \t\t\t$('.licenses').addClass('has-active-child');\n\t\t\t// \t\t}\n\t\t\t// \t\tlet subjectValue = $('.subjects .filter-list a.is-active').attr(\n\t\t\t// \t\t\t'data-filter'\n\t\t\t// \t\t);\n\t\t\t// \t\tlet licenseValue = $('.licenses .filter-list a.is-active').attr(\n\t\t\t// \t\t\t'data-filter'\n\t\t\t// \t\t);\n\t\t\t// \t\tif (typeof licenseValue === 'undefined') {\n\t\t\t// \t\t\tlicenseValue = '';\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\tlicenseValue = `[data-license=\"${licenseValue}\"]`;\n\t\t\t// \t\t}\n\t\t\t// \t\tif (typeof subjectValue === 'undefined') {\n\t\t\t// \t\t\tsubjectValue = '';\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\tsubjectValue = `[data-subject=\"${subjectValue}\"]`;\n\t\t\t// \t\t}\n\t\t\t// \t\t$grid.isotope({ filter: `${subjectValue}${licenseValue}` });\n\t\t\t// \t});\n\t\t\t// \t$('.sort > a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\t$('.sort').toggleClass('is-active');\n\t\t\t// \t});\n\t\t\t// \t$('.sorts a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tlet sortBy = $(e.currentTarget).attr('data-sort');\n\t\t\t// \t\t$('.sorts a').removeClass('is-active');\n\t\t\t// \t\t$(e.currentTarget).addClass('is-active');\n\t\t\t// \t\t$grid.isotope({ sortBy: sortBy });\n\t\t\t// \t});\n\t\t} );\n\t},\n\t/**\n\t *\n\t */\n\tfinalize() {},\n};\n"],"names":["Isotope","require","jQueryBridget","init","headings","document","querySelectorAll","Array","prototype","forEach","call","heading","innerHTML","textContent","getContent","elem","elems","nextElementSibling","tagName","push","node","parentNode","removeChild","contents","wrapper","createElement","hidden","appendChild","insertBefore","btn","querySelector","onclick","expanded","getAttribute","setAttribute","jQuery","$","$grid","isotope","itemSelector","getSortData","title","subject","latest","sortAscending","licenses","subjects","institutions","sorts","clearFilters","addEventListener","event","target","type","value","institution","license","filterValue","filter","allLicenses","getElementById","allSubjects","allInstitutions","checked","sortBy","finalize"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./assets/scripts/routes/catalog.js\n");
+eval("__webpack_require__.r(__webpack_exports__);\n/* provided dependency */ var jQuery = __webpack_require__(/*! jquery */ \"./node_modules/jquery/dist/jquery.js\");\nvar Isotope = __webpack_require__(/*! isotope-layout */ \"./node_modules/isotope-layout/js/isotope.js\");\nvar jQueryBridget = __webpack_require__(/*! jquery-bridget */ \"./node_modules/jquery-bridget/jquery-bridget.js\");\n/* harmony default export */ __webpack_exports__[\"default\"] = ({\n  /**\n   *\n   */init: function init() {\n    // JavaScript to be fired on the catalog page\n    (function () {\n      // Get all the <h2> headings\n      var headings = document.querySelectorAll('fieldset h2');\n      Array.prototype.forEach.call(headings, function (heading) {\n        // Give each <h3> a toggle button child\n        heading.innerHTML = \"\\n\\t\\t\\t\\t<button type=\\\"button\\\" aria-expanded=\\\"false\\\">\\n\\t\\t\\t\\t\\t\".concat(heading.textContent, \"\\n\\t\\t\\t\\t\\t<svg aria-hidden=\\\"true\\\" focusable=\\\"false\\\" class=\\\"arrow\\\" width=\\\"13\\\" height=\\\"8\\\" viewBox=\\\"0 0 13 8\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\"><path d=\\\"M6.255 8L0 0h12.51z\\\" fill=\\\"currentColor\\\" fill-rule=\\\"evenodd\\\"></path></svg>\\n\\t\\t\\t\\t</button>\\n\\t\\t\\t  \");\n\n        // Function to create a node list\n        // of the content between this <h2> and the next\n        /**\n         * @param elem\n         */\n        var getContent = function getContent(elem) {\n          var elems = [];\n          while (elem.nextElementSibling && elem.nextElementSibling.tagName !== 'H2') {\n            elems.push(elem.nextElementSibling);\n            elem = elem.nextElementSibling;\n          }\n\n          // Delete the old versions of the content nodes\n          elems.forEach(function (node) {\n            node.parentNode.removeChild(node);\n          });\n          return elems;\n        };\n\n        // Assign the contents to be expanded/collapsed (array)\n        var contents = getContent(heading);\n\n        // Create a wrapper element for `contents` and hide it\n        var wrapper = document.createElement('div');\n        wrapper.hidden = true;\n\n        // Add each element of `contents` to `wrapper`\n        contents.forEach(function (node) {\n          wrapper.appendChild(node);\n        });\n\n        // Add the wrapped content back into the DOM\n        // after the heading\n        heading.parentNode.insertBefore(wrapper, heading.nextElementSibling);\n\n        // Assign the button\n        var btn = heading.querySelector('button');\n\n        /**\n         *\n         */\n        btn.onclick = function () {\n          // Cast the state as a boolean\n          var expanded = btn.getAttribute('aria-expanded') === 'true' || false;\n\n          // Switch the state\n          btn.setAttribute('aria-expanded', !expanded);\n          // Switch the content's visibility\n          wrapper.hidden = expanded;\n        };\n      });\n    })();\n    (function () {\n      // Get all the <h3> headings\n      var headings = document.querySelectorAll('fieldset h3');\n      Array.prototype.forEach.call(headings, function (heading) {\n        // Give each <h3> a toggle button child\n        heading.innerHTML = \"\\n\\t\\t\\t\\t<button type=\\\"button\\\" aria-expanded=\\\"false\\\">\\n\\t\\t\\t\\t\\t\".concat(heading.innerHTML, \"\\n\\t\\t\\t\\t\\t<svg class=\\\"arrow\\\" width=\\\"13\\\" height=\\\"8\\\" viewBox=\\\"0 0 13 8\\\" xmlns=\\\"http://www.w3.org/2000/svg\\\"><path d=\\\"M6.255 8L0 0h12.51z\\\" fill=\\\"currentColor\\\" fill-rule=\\\"evenodd\\\"></path></svg>\\n\\t\\t\\t\\t</button>\\n\\t\\t\\t  \");\n\n        // Function to create a node list\n        // of the content between this <h2> and the next\n        /**\n         * @param elem\n         */\n        var getContent = function getContent(elem) {\n          var elems = [];\n          while (elem.nextElementSibling && elem.nextElementSibling.tagName !== 'H3') {\n            elems.push(elem.nextElementSibling);\n            elem = elem.nextElementSibling;\n          }\n\n          // Delete the old versions of the content nodes\n          elems.forEach(function (node) {\n            node.parentNode.removeChild(node);\n          });\n          return elems;\n        };\n\n        // Assign the contents to be expanded/collapsed (array)\n        var contents = getContent(heading);\n\n        // Create a wrapper element for `contents` and hide it\n        var wrapper = document.createElement('div');\n        wrapper.hidden = true;\n\n        // Add each element of `contents` to `wrapper`\n        contents.forEach(function (node) {\n          wrapper.appendChild(node);\n        });\n\n        // Add the wrapped content back into the DOM\n        // after the heading\n        heading.parentNode.insertBefore(wrapper, heading.nextElementSibling);\n\n        // Assign the button\n        var btn = heading.querySelector('button');\n\n        /**\n         *\n         */\n        btn.onclick = function () {\n          // Cast the state as a boolean\n          var expanded = btn.getAttribute('aria-expanded') === 'true' || false;\n\n          // Switch the state\n          btn.setAttribute('aria-expanded', !expanded);\n          // Switch the content's visibility\n          wrapper.hidden = expanded;\n        };\n      });\n    })();\n    jQuery(function ($) {\n      jQueryBridget('isotope', Isotope, $);\n      var $grid = $('.books');\n      $grid.isotope({\n        itemSelector: '.book',\n        getSortData: {\n          title: '.book__title a',\n          subject: '[data-subject]',\n          latest: '[data-date-published]'\n        },\n        sortAscending: {\n          title: true,\n          subject: false,\n          latest: false\n        }\n      });\n      var licenses = document.querySelector('.license-filters');\n      var subjects = document.querySelector('.subject-filters');\n      var institutions = document.querySelector('.institution-filters');\n      var sorts = document.querySelector('.sorts');\n      var clearFilters = document.querySelector('.clear-filters');\n      clearFilters.hidden = false;\n      licenses.addEventListener('click', function (event) {\n        if (event.target.type !== 'radio') {\n          return;\n        }\n        var subject = subjects.querySelector('input[type=\"radio\"]:checked').value ? \"[data-subject=\\\"\".concat(subjects.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n        var institution = institutions.querySelector('input[type=\"radio\"]:checked').value ? \"[data-institution*=\\\"\".concat(institutions.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n        var license = event.target.value ? \"[data-license=\\\"\".concat(event.target.value, \"\\\"]\") : '';\n        var filterValue = subject || license || institution ? \"\".concat(subject).concat(license).concat(institution) : '*';\n        $grid.isotope({\n          filter: filterValue\n        });\n      });\n      institutions.addEventListener('click', function (event) {\n        if (event.target.type !== 'radio') {\n          return;\n        }\n        var subject = subjects.querySelector('input[type=\"radio\"]:checked').value ? \"[data-subject=\\\"\".concat(subjects.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n        var license = licenses.querySelector('input[type=\"radio\"]:checked').value ? \"[data-license=\\\"\".concat(licenses.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n        var institution = event.target.value ? \"[data-institution*=\\\"\".concat(event.target.value, \"\\\"]\") : '';\n        var filterValue = subject || license || institution ? \"\".concat(subject).concat(license).concat(institution) : '*';\n        $grid.isotope({\n          filter: filterValue\n        });\n      });\n      subjects.addEventListener('click', function (event) {\n        if (event.target.type !== 'radio') {\n          return;\n        }\n        var license = licenses.querySelector('input[type=\"radio\"]:checked').value ? \"[data-license=\\\"\".concat(licenses.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n        var institution = institutions.querySelector('input[type=\"radio\"]:checked').value ? \"[data-institution*=\\\"\".concat(institutions.querySelector('input[type=\"radio\"]:checked').value, \"\\\"]\") : '';\n        var subject = event.target.value ? \"[data-subject=\\\"\".concat(event.target.value, \"\\\"]\") : '';\n        var filterValue = subject || license || institution ? \"\".concat(subject).concat(license).concat(institution) : '*';\n        $grid.isotope({\n          filter: filterValue\n        });\n      });\n      clearFilters.addEventListener('click', function () {\n        var allLicenses = document.getElementById('all-licenses');\n        var allSubjects = document.getElementById('all-subjects');\n        var allInstitutions = document.getElementById('all-institutions');\n        allLicenses.checked = true;\n        allSubjects.checked = true;\n        allInstitutions.checked = true;\n        $grid.isotope({\n          filter: '*'\n        });\n      });\n      sorts.addEventListener('click', function (event) {\n        if (event.target.type !== 'radio') {\n          return;\n        }\n        $grid.isotope({\n          sortBy: event.target.value\n        });\n      });\n      // \t$('.filters > a').click(e => {\n      // \t\te.preventDefault();\n      // \t\t$('.filters').toggleClass('is-active');\n      // \t\t$('.filter-groups > div').removeClass('is-active');\n      // \t});\n      // \t$('.filter-groups .subjects > a').click(e => {\n      // \t\te.preventDefault();\n      // \t\tlet id = $(e.currentTarget).attr('href');\n      // \t\t$(`.filter-groups .subjects:not(${id})`).removeClass('is-active');\n      // \t\t$(`.filter-groups ${id}`).toggleClass('is-active');\n      // \t});\n      // \t$('.licenses > a').click(e => {\n      // \t\te.preventDefault();\n      // \t\tlet id = $(e.currentTarget).attr('href');\n      // \t\t$(id).toggleClass('is-active');\n      // \t});\n      // \t$('.subjects .filter-list a').click(e => {\n      // \t\te.preventDefault();\n      // \t\tif ($(e.currentTarget).hasClass('is-active')) {\n      // \t\t\t$('.subjects .filter-list a').removeClass('is-active');\n      // \t\t\t$('.subjects').removeClass('has-active-child');\n      // \t\t} else {\n      // \t\t\t$('.subjects .filter-list a').removeClass('is-active');\n      // \t\t\t$(e.currentTarget).addClass('is-active');\n      // \t\t\t$('.subjects').removeClass('has-active-child');\n      // \t\t\t$(e.currentTarget)\n      // \t\t\t\t.parent()\n      // \t\t\t\t.parent()\n      // \t\t\t\t.parent('.subjects')\n      // \t\t\t\t.addClass('has-active-child');\n      // \t\t}\n      // \t\tlet subjectValue = $('.subjects .filter-list a.is-active').attr(\n      // \t\t\t'data-filter'\n      // \t\t);\n      // \t\tlet licenseValue = $('.licenses .filter-list a.is-active').attr(\n      // \t\t\t'data-filter'\n      // \t\t);\n      // \t\tif (typeof licenseValue === 'undefined') {\n      // \t\t\tlicenseValue = '';\n      // \t\t} else {\n      // \t\t\tlicenseValue = `[data-license=\"${licenseValue}\"]`;\n      // \t\t}\n      // \t\tif (typeof subjectValue === 'undefined') {\n      // \t\t\tsubjectValue = '';\n      // \t\t} else {\n      // \t\t\tsubjectValue = `[data-subject=\"${subjectValue}\"]`;\n      // \t\t}\n      // \t\t$grid.isotope({ filter: `${subjectValue}${licenseValue}` });\n      // \t});\n      // \t$('.licenses .filter-list a').click(e => {\n      // \t\te.preventDefault();\n      // \t\tif ($(e.currentTarget).hasClass('is-active')) {\n      // \t\t\t$('.licenses .filter-list a').removeClass('is-active');\n      // \t\t\t$('.licenses').removeClass('has-active-child');\n      // \t\t} else {\n      // \t\t\t$('.licenses .filter-list a').removeClass('is-active');\n      // \t\t\t$(e.currentTarget).addClass('is-active');\n      // \t\t\t$('.licenses').addClass('has-active-child');\n      // \t\t}\n      // \t\tlet subjectValue = $('.subjects .filter-list a.is-active').attr(\n      // \t\t\t'data-filter'\n      // \t\t);\n      // \t\tlet licenseValue = $('.licenses .filter-list a.is-active').attr(\n      // \t\t\t'data-filter'\n      // \t\t);\n      // \t\tif (typeof licenseValue === 'undefined') {\n      // \t\t\tlicenseValue = '';\n      // \t\t} else {\n      // \t\t\tlicenseValue = `[data-license=\"${licenseValue}\"]`;\n      // \t\t}\n      // \t\tif (typeof subjectValue === 'undefined') {\n      // \t\t\tsubjectValue = '';\n      // \t\t} else {\n      // \t\t\tsubjectValue = `[data-subject=\"${subjectValue}\"]`;\n      // \t\t}\n      // \t\t$grid.isotope({ filter: `${subjectValue}${licenseValue}` });\n      // \t});\n      // \t$('.sort > a').click(e => {\n      // \t\te.preventDefault();\n      // \t\t$('.sort').toggleClass('is-active');\n      // \t});\n      // \t$('.sorts a').click(e => {\n      // \t\te.preventDefault();\n      // \t\tlet sortBy = $(e.currentTarget).attr('data-sort');\n      // \t\t$('.sorts a').removeClass('is-active');\n      // \t\t$(e.currentTarget).addClass('is-active');\n      // \t\t$grid.isotope({ sortBy: sortBy });\n      // \t});\n    });\n  },\n  /**\n   *\n   */finalize: function finalize() {}\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./assets/scripts/routes/catalog.js.js","mappings":"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","sources":["webpack://@pressbooks/pressbooks-aldine/./assets/scripts/routes/catalog.js?f5df"],"sourcesContent":["const Isotope = require( 'isotope-layout' );\nconst jQueryBridget = require( 'jquery-bridget' );\n\nexport default {\n\t/**\n\t *\n\t */\n\tinit() {\n\t\t// JavaScript to be fired on the catalog page\n\t\t( function () {\n\t\t\t// Get all the <h2> headings\n\t\t\tconst headings = document.querySelectorAll( 'fieldset h2' );\n\n\t\t\tArray.prototype.forEach.call( headings, heading => {\n\t\t\t\t// Give each <h3> a toggle button child\n\t\t\t\theading.innerHTML = `\n\t\t\t\t<button type=\"button\" aria-expanded=\"false\">\n\t\t\t\t\t${ heading.textContent }\n\t\t\t\t\t<svg aria-hidden=\"true\" focusable=\"false\" class=\"arrow\" width=\"13\" height=\"8\" viewBox=\"0 0 13 8\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.255 8L0 0h12.51z\" fill=\"currentColor\" fill-rule=\"evenodd\"></path></svg>\n\t\t\t\t</button>\n\t\t\t  `;\n\n\t\t\t\t// Function to create a node list\n\t\t\t\t// of the content between this <h2> and the next\n\t\t\t\t/**\n\t\t\t\t * @param elem\n\t\t\t\t */\n\t\t\t\tconst getContent = elem => {\n\t\t\t\t\tlet elems = [];\n\t\t\t\t\twhile (\n\t\t\t\t\t\telem.nextElementSibling &&\n\t\t\t\t\t\telem.nextElementSibling.tagName !== 'H2'\n\t\t\t\t\t) {\n\t\t\t\t\t\telems.push( elem.nextElementSibling );\n\t\t\t\t\t\telem = elem.nextElementSibling;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Delete the old versions of the content nodes\n\t\t\t\t\telems.forEach( node => {\n\t\t\t\t\t\tnode.parentNode.removeChild( node );\n\t\t\t\t\t} );\n\n\t\t\t\t\treturn elems;\n\t\t\t\t};\n\n\t\t\t\t// Assign the contents to be expanded/collapsed (array)\n\t\t\t\tlet contents = getContent( heading );\n\n\t\t\t\t// Create a wrapper element for `contents` and hide it\n\t\t\t\tlet wrapper = document.createElement( 'div' );\n\t\t\t\twrapper.hidden = true;\n\n\t\t\t\t// Add each element of `contents` to `wrapper`\n\t\t\t\tcontents.forEach( node => {\n\t\t\t\t\twrapper.appendChild( node );\n\t\t\t\t} );\n\n\t\t\t\t// Add the wrapped content back into the DOM\n\t\t\t\t// after the heading\n\t\t\t\theading.parentNode.insertBefore( wrapper, heading.nextElementSibling );\n\n\t\t\t\t// Assign the button\n\t\t\t\tlet btn = heading.querySelector( 'button' );\n\n\t\t\t\t/**\n\t\t\t\t *\n\t\t\t\t */\n\t\t\t\tbtn.onclick = () => {\n\t\t\t\t\t// Cast the state as a boolean\n\t\t\t\t\tlet expanded = btn.getAttribute( 'aria-expanded' ) === 'true' || false;\n\n\t\t\t\t\t// Switch the state\n\t\t\t\t\tbtn.setAttribute( 'aria-expanded', ! expanded );\n\t\t\t\t\t// Switch the content's visibility\n\t\t\t\t\twrapper.hidden = expanded;\n\t\t\t\t};\n\t\t\t} );\n\t\t} )();\n\n\t\t( function () {\n\t\t\t// Get all the <h3> headings\n\t\t\tconst headings = document.querySelectorAll( 'fieldset h3' );\n\n\t\t\tArray.prototype.forEach.call( headings, heading => {\n\t\t\t\t// Give each <h3> a toggle button child\n\t\t\t\theading.innerHTML = `\n\t\t\t\t<button type=\"button\" aria-expanded=\"false\">\n\t\t\t\t\t${ heading.innerHTML }\n\t\t\t\t\t<svg class=\"arrow\" width=\"13\" height=\"8\" viewBox=\"0 0 13 8\" xmlns=\"http://www.w3.org/2000/svg\"><path d=\"M6.255 8L0 0h12.51z\" fill=\"currentColor\" fill-rule=\"evenodd\"></path></svg>\n\t\t\t\t</button>\n\t\t\t  `;\n\n\t\t\t\t// Function to create a node list\n\t\t\t\t// of the content between this <h2> and the next\n\t\t\t\t/**\n\t\t\t\t * @param elem\n\t\t\t\t */\n\t\t\t\tconst getContent = elem => {\n\t\t\t\t\tlet elems = [];\n\t\t\t\t\twhile (\n\t\t\t\t\t\telem.nextElementSibling &&\n\t\t\t\t\t\telem.nextElementSibling.tagName !== 'H3'\n\t\t\t\t\t) {\n\t\t\t\t\t\telems.push( elem.nextElementSibling );\n\t\t\t\t\t\telem = elem.nextElementSibling;\n\t\t\t\t\t}\n\n\t\t\t\t\t// Delete the old versions of the content nodes\n\t\t\t\t\telems.forEach( node => {\n\t\t\t\t\t\tnode.parentNode.removeChild( node );\n\t\t\t\t\t} );\n\n\t\t\t\t\treturn elems;\n\t\t\t\t};\n\n\t\t\t\t// Assign the contents to be expanded/collapsed (array)\n\t\t\t\tlet contents = getContent( heading );\n\n\t\t\t\t// Create a wrapper element for `contents` and hide it\n\t\t\t\tlet wrapper = document.createElement( 'div' );\n\t\t\t\twrapper.hidden = true;\n\n\t\t\t\t// Add each element of `contents` to `wrapper`\n\t\t\t\tcontents.forEach( node => {\n\t\t\t\t\twrapper.appendChild( node );\n\t\t\t\t} );\n\n\t\t\t\t// Add the wrapped content back into the DOM\n\t\t\t\t// after the heading\n\t\t\t\theading.parentNode.insertBefore( wrapper, heading.nextElementSibling );\n\n\t\t\t\t// Assign the button\n\t\t\t\tlet btn = heading.querySelector( 'button' );\n\n\t\t\t\t/**\n\t\t\t\t *\n\t\t\t\t */\n\t\t\t\tbtn.onclick = () => {\n\t\t\t\t\t// Cast the state as a boolean\n\t\t\t\t\tlet expanded = btn.getAttribute( 'aria-expanded' ) === 'true' || false;\n\n\t\t\t\t\t// Switch the state\n\t\t\t\t\tbtn.setAttribute( 'aria-expanded', ! expanded );\n\t\t\t\t\t// Switch the content's visibility\n\t\t\t\t\twrapper.hidden = expanded;\n\t\t\t\t};\n\t\t\t} );\n\t\t} )();\n\n\t\tjQuery( $ => {\n\t\t\tjQueryBridget( 'isotope', Isotope, $ );\n\t\t\tlet $grid = $( '.books' );\n\t\t\t$grid.isotope( {\n\t\t\t\titemSelector: '.book',\n\t\t\t\tgetSortData: {\n\t\t\t\t\ttitle: '.book__title a',\n\t\t\t\t\tsubject: '[data-subject]',\n\t\t\t\t\tlatest: '[data-date-published]',\n\t\t\t\t},\n\t\t\t\tsortAscending: {\n\t\t\t\t\ttitle: true,\n\t\t\t\t\tsubject: false,\n\t\t\t\t\tlatest: false,\n\t\t\t\t},\n\t\t\t} );\n\t\t\tlet licenses = document.querySelector( '.license-filters' );\n\t\t\tlet subjects = document.querySelector( '.subject-filters' );\n\t\t\tlet institutions = document.querySelector( '.institution-filters' );\n\t\t\tlet sorts = document.querySelector( '.sorts' );\n\t\t\tlet clearFilters = document.querySelector( '.clear-filters' );\n\t\t\tclearFilters.hidden = false;\n\t\t\tlicenses.addEventListener( 'click', function ( event ) {\n\t\t\t\tif ( event.target.type !== 'radio' ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tconst subject = subjects.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-subject=\"${ subjects.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst institution = institutions.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-institution*=\"${ institutions.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst license = event.target.value\n\t\t\t\t\t? `[data-license=\"${ event.target.value }\"]`\n\t\t\t\t\t: '';\n\n\t\t\t\tconst filterValue = subject || license || institution ? `${ subject }${ license }${ institution }` : '*';\n\n\t\t\t\t$grid.isotope( { filter: filterValue } );\n\t\t\t} );\n\t\t\tinstitutions.addEventListener( 'click', function ( event ) {\n\t\t\t\tif ( event.target.type !== 'radio' ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tconst subject = subjects.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-subject=\"${ subjects.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst license = licenses.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-license=\"${ licenses.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst institution = event.target.value\n\t\t\t\t\t? `[data-institution*=\"${ event.target.value }\"]`\n\t\t\t\t\t: '';\n\n\t\t\t\tconst filterValue = subject || license || institution ? `${ subject }${ license }${ institution }` : '*';\n\n\t\t\t\t$grid.isotope( { filter: filterValue } );\n\t\t\t} );\n\t\t\tsubjects.addEventListener( 'click', function ( event ) {\n\t\t\t\tif ( event.target.type !== 'radio' ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tconst license = licenses.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-license=\"${ licenses.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst institution = institutions.querySelector( 'input[type=\"radio\"]:checked' ).value\n\t\t\t\t\t? `[data-institution*=\"${ institutions.querySelector( 'input[type=\"radio\"]:checked' ).value }\"]`\n\t\t\t\t\t: '';\n\t\t\t\tconst subject = event.target.value\n\t\t\t\t\t? `[data-subject=\"${ event.target.value }\"]`\n\t\t\t\t\t: '';\n\n\t\t\t\tconst filterValue = subject || license || institution ? `${ subject }${ license }${ institution }` : '*';\n\n\t\t\t\t$grid.isotope( { filter: filterValue } );\n\t\t\t} );\n\t\t\tclearFilters.addEventListener( 'click', function () {\n\t\t\t\tlet allLicenses = document.getElementById( 'all-licenses' );\n\t\t\t\tlet allSubjects = document.getElementById( 'all-subjects' );\n\t\t\t\tlet allInstitutions = document.getElementById( 'all-institutions' );\n\t\t\t\tallLicenses.checked = true;\n\t\t\t\tallSubjects.checked = true;\n\t\t\t\tallInstitutions.checked = true;\n\t\t\t\t$grid.isotope( { filter: '*' } );\n\t\t\t} );\n\t\t\tsorts.addEventListener( 'click', function ( event ) {\n\t\t\t\tif ( event.target.type !== 'radio' ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\t$grid.isotope( { sortBy: event.target.value } );\n\t\t\t} );\n\t\t\t// \t$('.filters > a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\t$('.filters').toggleClass('is-active');\n\t\t\t// \t\t$('.filter-groups > div').removeClass('is-active');\n\t\t\t// \t});\n\t\t\t// \t$('.filter-groups .subjects > a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tlet id = $(e.currentTarget).attr('href');\n\t\t\t// \t\t$(`.filter-groups .subjects:not(${id})`).removeClass('is-active');\n\t\t\t// \t\t$(`.filter-groups ${id}`).toggleClass('is-active');\n\t\t\t// \t});\n\t\t\t// \t$('.licenses > a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tlet id = $(e.currentTarget).attr('href');\n\t\t\t// \t\t$(id).toggleClass('is-active');\n\t\t\t// \t});\n\t\t\t// \t$('.subjects .filter-list a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tif ($(e.currentTarget).hasClass('is-active')) {\n\t\t\t// \t\t\t$('.subjects .filter-list a').removeClass('is-active');\n\t\t\t// \t\t\t$('.subjects').removeClass('has-active-child');\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\t$('.subjects .filter-list a').removeClass('is-active');\n\t\t\t// \t\t\t$(e.currentTarget).addClass('is-active');\n\t\t\t// \t\t\t$('.subjects').removeClass('has-active-child');\n\t\t\t// \t\t\t$(e.currentTarget)\n\t\t\t// \t\t\t\t.parent()\n\t\t\t// \t\t\t\t.parent()\n\t\t\t// \t\t\t\t.parent('.subjects')\n\t\t\t// \t\t\t\t.addClass('has-active-child');\n\t\t\t// \t\t}\n\t\t\t// \t\tlet subjectValue = $('.subjects .filter-list a.is-active').attr(\n\t\t\t// \t\t\t'data-filter'\n\t\t\t// \t\t);\n\t\t\t// \t\tlet licenseValue = $('.licenses .filter-list a.is-active').attr(\n\t\t\t// \t\t\t'data-filter'\n\t\t\t// \t\t);\n\t\t\t// \t\tif (typeof licenseValue === 'undefined') {\n\t\t\t// \t\t\tlicenseValue = '';\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\tlicenseValue = `[data-license=\"${licenseValue}\"]`;\n\t\t\t// \t\t}\n\t\t\t// \t\tif (typeof subjectValue === 'undefined') {\n\t\t\t// \t\t\tsubjectValue = '';\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\tsubjectValue = `[data-subject=\"${subjectValue}\"]`;\n\t\t\t// \t\t}\n\t\t\t// \t\t$grid.isotope({ filter: `${subjectValue}${licenseValue}` });\n\t\t\t// \t});\n\t\t\t// \t$('.licenses .filter-list a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tif ($(e.currentTarget).hasClass('is-active')) {\n\t\t\t// \t\t\t$('.licenses .filter-list a').removeClass('is-active');\n\t\t\t// \t\t\t$('.licenses').removeClass('has-active-child');\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\t$('.licenses .filter-list a').removeClass('is-active');\n\t\t\t// \t\t\t$(e.currentTarget).addClass('is-active');\n\t\t\t// \t\t\t$('.licenses').addClass('has-active-child');\n\t\t\t// \t\t}\n\t\t\t// \t\tlet subjectValue = $('.subjects .filter-list a.is-active').attr(\n\t\t\t// \t\t\t'data-filter'\n\t\t\t// \t\t);\n\t\t\t// \t\tlet licenseValue = $('.licenses .filter-list a.is-active').attr(\n\t\t\t// \t\t\t'data-filter'\n\t\t\t// \t\t);\n\t\t\t// \t\tif (typeof licenseValue === 'undefined') {\n\t\t\t// \t\t\tlicenseValue = '';\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\tlicenseValue = `[data-license=\"${licenseValue}\"]`;\n\t\t\t// \t\t}\n\t\t\t// \t\tif (typeof subjectValue === 'undefined') {\n\t\t\t// \t\t\tsubjectValue = '';\n\t\t\t// \t\t} else {\n\t\t\t// \t\t\tsubjectValue = `[data-subject=\"${subjectValue}\"]`;\n\t\t\t// \t\t}\n\t\t\t// \t\t$grid.isotope({ filter: `${subjectValue}${licenseValue}` });\n\t\t\t// \t});\n\t\t\t// \t$('.sort > a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\t$('.sort').toggleClass('is-active');\n\t\t\t// \t});\n\t\t\t// \t$('.sorts a').click(e => {\n\t\t\t// \t\te.preventDefault();\n\t\t\t// \t\tlet sortBy = $(e.currentTarget).attr('data-sort');\n\t\t\t// \t\t$('.sorts a').removeClass('is-active');\n\t\t\t// \t\t$(e.currentTarget).addClass('is-active');\n\t\t\t// \t\t$grid.isotope({ sortBy: sortBy });\n\t\t\t// \t});\n\t\t} );\n\t},\n\t/**\n\t *\n\t */\n\tfinalize() {},\n};\n"],"names":["Isotope","require","jQueryBridget","init","headings","document","querySelectorAll","Array","prototype","forEach","call","heading","innerHTML","textContent","getContent","elem","elems","nextElementSibling","tagName","push","node","parentNode","removeChild","contents","wrapper","createElement","hidden","appendChild","insertBefore","btn","querySelector","onclick","expanded","getAttribute","setAttribute","jQuery","$","$grid","isotope","itemSelector","getSortData","title","subject","latest","sortAscending","licenses","subjects","institutions","sorts","clearFilters","addEventListener","event","target","type","value","institution","license","filterValue","filter","allLicenses","getElementById","allSubjects","allInstitutions","checked","sortBy","finalize"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./assets/scripts/routes/catalog.js\n");
 
 /***/ }),
 
diff --git a/dist/scripts/aldine.js.LICENSE.txt b/dist/scripts/aldine.js.LICENSE.txt
index aa91eb9..692dd6b 100644
--- a/dist/scripts/aldine.js.LICENSE.txt
+++ b/dist/scripts/aldine.js.LICENSE.txt
@@ -15,7 +15,7 @@
  */
 
 /*!
- * Masonry v4.2.2
+ * Masonry v4.2.1
  * Cascading grid layout library
  * https://masonry.desandro.com
  * MIT License
diff --git a/dist/styles/aldine.css b/dist/styles/aldine.css
index 573f7de..cae2b0b 100644
--- a/dist/styles/aldine.css
+++ b/dist/styles/aldine.css
@@ -1840,6 +1840,104 @@ nav {
 }
 
 .book {
+  display: -webkit-box;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-orient: vertical;
+  -webkit-box-direction: normal;
+      -ms-flex-direction: column;
+          flex-direction: column;
+  -webkit-box-pack: start;
+      -ms-flex-pack: start;
+          justify-content: flex-start;
+  width: 100%;
+  max-width: 22.9375rem;
+  height: 24.125rem;
+  margin: 0 0 2rem;
+  padding: 1.5rem 1rem 2rem;
+  border: solid 2px var(--accent);
+  background: var(--accent);
+}
+@media screen and (min-width: 30rem) {
+  .book {
+    padding: 1.5rem 1.85rem 2.1875rem;
+  }
+}
+.book a, .book p {
+  font-family: "Karla", sans-serif;
+  color: var(--accent-fg);
+}
+.book a {
+  margin: 0;
+  text-decoration: none;
+  text-align: center;
+  -webkit-hyphens: auto;
+      -ms-hyphens: auto;
+          hyphens: auto;
+}
+.book__title {
+  margin: 0;
+  font-size: 1.25rem;
+  font-weight: 500;
+  line-height: 1.2;
+  text-align: left;
+}
+@media screen and (min-width: 30rem) {
+  .book__title {
+    font-size: 1.75rem;
+  }
+}
+.book__subject {
+  margin: 0;
+  font-size: 0.75rem;
+  text-align: left;
+}
+@media screen and (min-width: 30rem) {
+  .book__subject {
+    font-size: 1rem;
+  }
+}
+.book__institutions {
+  margin: 0.5rem 0 0;
+  font-size: 0.875rem;
+  text-align: left;
+  display: box;
+  overflow: hidden;
+  -webkit-line-clamp: 2;
+  -webkit-box-orient: vertical;
+}
+.book__read-more {
+  margin: auto 0 0;
+  font-size: 1rem;
+  text-align: left;
+}
+@media screen and (min-width: 30rem) {
+  .book__read-more {
+    font-size: 1.125rem;
+  }
+}
+.book__read-more a svg {
+  width: 1rem;
+  height: 1rem;
+  vertical-align: middle;
+}
+@media screen and (min-width: 30rem) {
+  .book__read-more a svg {
+    width: 1.125rem;
+    height: 1.125rem;
+    margin-left: 0.5rem;
+  }
+}
+.book:last-child {
+  margin-bottom: 0;
+}
+@media screen and (min-width: 60rem) {
+  .book:last-child {
+    margin-bottom: 2rem;
+  }
+}
+
+.featured_book {
   display: -webkit-box;
   display: -ms-flexbox;
   display: flex;
@@ -1856,13 +1954,13 @@ nav {
   border: solid 1px var(--accent);
   margin: 0 0 2rem;
 }
-.book__cover {
+.featured_book__cover {
   width: 100%;
   height: 80%;
   background-repeat: no-repeat;
   background-size: cover;
 }
-.book a {
+.featured_book a {
   margin: 0;
   text-decoration: none;
   text-align: center;
@@ -1870,7 +1968,7 @@ nav {
       -ms-hyphens: auto;
           hyphens: auto;
 }
-.book__title {
+.featured_book__title {
   display: -webkit-box;
   display: -ms-flexbox;
   display: flex;
@@ -2289,7 +2387,7 @@ body #content a.call-to-action {
         -ms-flex-pack: center;
             justify-content: center;
   }
-  .latest-books .books .book {
+  .latest-books .books .book, .latest-books .books .featured_book {
     margin-right: 1rem;
     margin-left: 1rem;
   }
@@ -2312,24 +2410,24 @@ body #content a.call-to-action {
   text-align: center;
 }
 
-fieldset {
+.network-catalog fieldset {
   border-top: solid 2px var(--accent);
   font-family: "Karla", sans-serif;
 }
-fieldset h2,
-fieldset h3 {
+.network-catalog fieldset h2,
+.network-catalog fieldset h3 {
   margin-bottom: 0;
   font-size: 1rem;
   font-weight: bold;
   text-align: left;
   text-transform: none;
 }
-fieldset h2::before,
-fieldset h3::before {
+.network-catalog fieldset h2::before,
+.network-catalog fieldset h3::before {
   display: none;
 }
-fieldset h2 button,
-fieldset h3 button {
+.network-catalog fieldset h2 button,
+.network-catalog fieldset h3 button {
   display: -webkit-box;
   display: -ms-flexbox;
   display: flex;
@@ -2346,36 +2444,36 @@ fieldset h3 button {
   margin: 0;
   border-top: 0;
 }
-fieldset h2 button svg,
-fieldset h3 button svg {
+.network-catalog fieldset h2 button svg,
+.network-catalog fieldset h3 button svg {
   display: block;
   float: right;
   margin-top: 0.5rem;
 }
-fieldset h2 button:hover, fieldset h2 button:focus,
-fieldset h3 button:hover,
-fieldset h3 button:focus {
+.network-catalog fieldset h2 button:hover, .network-catalog fieldset h2 button:focus,
+.network-catalog fieldset h3 button:hover,
+.network-catalog fieldset h3 button:focus {
   color: var(--primary);
   background: var(--bg-body);
 }
-fieldset h2 button:active,
-fieldset h3 button:active {
+.network-catalog fieldset h2 button:active,
+.network-catalog fieldset h3 button:active {
   -webkit-box-shadow: none;
           box-shadow: none;
 }
-fieldset [aria-expanded=true] {
+.network-catalog fieldset [aria-expanded=true] {
   color: var(--primary);
 }
-fieldset [aria-expanded=true] svg {
+.network-catalog fieldset [aria-expanded=true] svg {
   -webkit-transform: rotate(180deg);
        -o-transform: rotate(180deg);
           transform: rotate(180deg);
 }
-fieldset h2 [aria-expanded=true] {
+.network-catalog fieldset h2 [aria-expanded=true] {
   border-bottom: solid 2px var(--accent);
   background: var(--body-bg-alt);
 }
-fieldset [type=radio] {
+.network-catalog fieldset [type=radio] {
   position: absolute !important;
   width: 1px !important;
   height: 1px !important;
@@ -2384,28 +2482,28 @@ fieldset [type=radio] {
   overflow: hidden !important;
   clip: rect(1px, 1px, 1px, 1px);
 }
-fieldset .label {
+.network-catalog fieldset .label {
   display: inline-block;
   width: calc(100% - 2rem);
 }
-fieldset [type=radio] + label {
+.network-catalog fieldset [type=radio] + label {
   cursor: pointer;
   display: block;
   padding: 1rem 1.1875rem;
   margin-bottom: 0;
 }
-fieldset [type=radio] + label svg {
+.network-catalog fieldset [type=radio] + label svg {
   display: none;
 }
-fieldset [type=radio]:focus label {
+.network-catalog fieldset [type=radio]:focus label {
   cursor: pointer;
   display: block;
 }
-fieldset [type=radio]:checked + label {
+.network-catalog fieldset [type=radio]:checked + label {
   color: var(--primary);
   font-weight: bold;
 }
-fieldset [type=radio]:checked + label svg {
+.network-catalog fieldset [type=radio]:checked + label svg {
   display: block;
   float: right;
   margin-top: 0.5rem;
@@ -2413,7 +2511,7 @@ fieldset [type=radio]:checked + label svg {
   height: 1rem;
   fill: transparent;
 }
-fieldset:last-of-type {
+.network-catalog fieldset:last-of-type {
   border-bottom: solid 2px var(--accent);
   margin-bottom: 1rem;
 }
@@ -2432,7 +2530,7 @@ fieldset:last-of-type {
   padding: 0;
   margin: 2rem 0 1rem 1rem;
 }
-.page-template-page-catalog .book {
+.page-template-page-catalog .book, .page-template-page-catalog .featured_book {
   height: 14.375rem;
   width: calc(50% - 1rem);
   margin: 0 1rem 1rem 0;
diff --git a/inc/customizer/namespace.php b/inc/customizer/namespace.php
index 241a538..b2a7385 100644
--- a/inc/customizer/namespace.php
+++ b/inc/customizer/namespace.php
@@ -209,6 +209,7 @@ function customize_register( \WP_Customize_Manager $wp_customize ) {
 
 		$options = get_catalog_options();
 		$books = collect( $options['books'] )->pluck( 'title', 'id' )->toArray();
+		$books = [ '' => __( 'Select a book', 'pressbooks-aldine' ) ] + $books;
 
 		foreach ( range( 1, MAX_FEATURED_BOOKS ) as $i ) {
 			$wp_customize->add_setting(
diff --git a/inc/helpers/namespace.php b/inc/helpers/namespace.php
index 0c9cf3f..9533865 100644
--- a/inc/helpers/namespace.php
+++ b/inc/helpers/namespace.php
@@ -70,8 +70,13 @@ function get_featured_books(): array {
 		}
 	}
 
+	if ( empty( $featured_books ) ) {
+		return [];
+	}
+
 	$args = [
 		'site__in'      => $featured_books,
+		'sort_by_featured' => true,
 	];
 
 	return get_catalog_data( $args );
@@ -109,8 +114,114 @@ function get_catalog_data( array $args ): array {
 			$books[] = $book;
 		}
 	}
+	// Sort by featured books.
+	if ( isset( $args['sort_by_featured'] ) ) {
+		usort( $books, function ( $a, $b ) use ( $args ) {
+			return array_search( $a['id'], $args['site__in'], true ) - array_search($b['id'],
+			$args['site__in'], true);
+		} );
+	}
+
+	return [
+		'books' => $books,
+	];
+}
+
+/**
+ * Get paginated catalog data
+ *
+ * @param int $page Catalog page
+ * @param int $per_page Books per page
+ * @param string $orderby Sort order
+ * @param string $license Copyright license
+ * @param string $subject Subject
+ *
+ * @return array
+ */
+function get_paginated_catalog_data( $page = 1, $per_page = 10, $orderby = 'title', $license = '', $subject = '' ) {
+
+	if ( ! defined( 'PB_PLUGIN_VERSION' ) ) {
+		return [
+			'pages' => 0,
+			'books' => [],
+		];
+	}
+
+	$dc = BookDataCollector::init();
+
+	/**
+	 * Filter the WP_Site_Query args for the catalog display.
+	 *
+	 * @since 1.0.0
+	 */
+	$args = apply_filters(
+		'pb_aldine_catalog_query_args',
+		/**
+		 * Deprecation notice
+		 *
+		 * @deprecated 1.0.0
+		 *
+		 * @see Pressbooks Publisher
+		 */
+		apply_filters(
+			'pb_publisher_catalog_query_args',
+			[
+				'number' => 1000000,
+				'meta_key' => $dc::IN_CATALOG, // @codingStandardsIgnoreLine
+				'meta_value' => 1, // @codingStandardsIgnoreLine
+				'public' => 1,
+				'archived' => 0,
+				'spam' => 0,
+				'deleted' => 0,
+				'network_id' => get_network()->site_id,
+			]
+		)
+	);
+
+	/**
+	 * WordPress site
+	 *
+	 * @var \WP_Site $site
+	 */
+
+	$sites_in_catalog = [];
+	$sites = get_sites( $args );
+	foreach ( $sites as $site ) {
+		$site->pb_title = $dc->get( $site->blog_id, $dc::TITLE );
+		$sites_in_catalog[] = $site;
+	}
+	if ( $orderby === 'latest' ) {
+		$sites_in_catalog = wp_list_sort( $sites_in_catalog, 'last_updated', 'DESC' );
+	} else {
+		$sites_in_catalog = wp_list_sort( $sites_in_catalog, 'pb_title', 'ASC' );
+	}
+
+	$total_pages = ceil( count( $sites_in_catalog ) / $per_page );
+	$offset = ( $page - 1 ) * $per_page;
+	$books = [];
+	foreach ( $sites_in_catalog as $i => $site ) {
+		if ( $i < $offset ) {
+			continue;
+		}
+
+		$book_information = $dc->get( $site->blog_id, $dc::BOOK_INFORMATION_ARRAY );
+		if ( is_array( $book_information ) && ! empty( $book_information ) ) {
+			$schema = book_information_to_schema( $book_information );
+			$book['title'] = $schema['name'];
+			$book['date-published'] = $schema['datePublished'] ?? '';
+			$book['subject'] = $schema['about'][0]['identifier'] ?? '';
+			$book['link'] = get_blogaddress_by_id( $site->blog_id );
+			$book['metadata'] = $schema;
+			$books[] = $book;
+		}
+
+		if ( count( $books ) >= $per_page ) {
+			break;
+		}
+	}
 
 	return [
+		'pages' => $total_pages,
 		'books' => $books,
 	];
 }
diff --git a/languages/pressbooks-aldine.pot b/languages/pressbooks-aldine.pot
index 0577f8e..a27ebfb 100644
--- a/languages/pressbooks-aldine.pot
+++ b/languages/pressbooks-aldine.pot
@@ -2,16 +2,16 @@
 # This file is distributed under the GNU GPL v3 or later.
 msgid ""
 msgstr ""
-"Project-Id-Version: Aldine 1.16.1\n"
+"Project-Id-Version: Aldine 1.17.0\n"
 "Report-Msgid-Bugs-To: https://github.com/pressbooks/pressbooks-aldine/issues\n"
 "Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
 "Language-Team: LANGUAGE <LL@li.org>\n"
 "MIME-Version: 1.0\n"
 "Content-Type: text/plain; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
-"POT-Creation-Date: 2022-10-17T15:53:25+00:00\n"
+"POT-Creation-Date: 2022-11-04T17:15:14+00:00\n"
 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"X-Generator: WP-CLI 2.7.0\n"
+"X-Generator: WP-CLI 2.7.1\n"
 "X-Domain: pressbooks-aldine\n"
 
 #. Theme Name of the theme
diff --git a/page-catalog.php b/page-catalog.php
index 2610783..d94ebc4 100644
--- a/page-catalog.php
+++ b/page-catalog.php
@@ -18,15 +18,15 @@ use function Aldine\Helpers\get_available_institutions;
 use function Aldine\Helpers\get_available_licenses;
 use function Aldine\Helpers\get_available_subjects;
 use function Aldine\Helpers\get_catalog_licenses;
-use function Aldine\Helpers\get_featured_books;
 use function Aldine\Helpers\get_institutions;
+use function Aldine\Helpers\get_paginated_catalog_data;
 
 $current_page = ( get_query_var( 'paged' ) ) ? get_query_var( 'paged' ) : 1;
 $orderby = ( get_query_var( 'orderby' ) ) ? get_query_var( 'orderby' ) : 'title';
 $subject = ( get_query_var( 'subject' ) ) ? get_query_var( 'subject' ) : '';
 $license = ( get_query_var( 'license' ) ) ? get_query_var( 'license' ) : '';
 $institution = get_query_var( 'institution' ) ?? '';
-$catalog_data = get_featured_books();
+$catalog_data = get_paginated_catalog_data();
 $previous_page = ( $current_page > 1 ) ? $current_page - 1 : 0;
 $next_page = $current_page + 1;
 $licenses = get_catalog_licenses();
diff --git a/partials/book.php b/partials/book.php
index 7dd6c58..01f05a9 100644
--- a/partials/book.php
+++ b/partials/book.php
@@ -6,10 +6,54 @@
  */
 
 use function \Aldine\Helpers\maybe_truncate_string;
+use function \Pressbooks\Metadata\is_bisac;
+
+$subject = ( isset( $book['subject'] ) && ! is_bisac( $book['subject'] ) ) ? substr( $book['subject'], 0, 2 ) : '';
+$date = ( isset( $book['metadata']['datePublished'] ) ) ? str_replace( '-', '', $book['metadata']['datePublished'] ) : '';
+$institution_codes = array_map( static function ( $item ) {
+	return $item['code'];
+}, $book['metadata']['institutions'] ?? [] );
+$institution_names = array_map( static function ( $item ) {
+	return \Pressbooks\Metadata\get_institution_name( $item['code'] );
+}, $book['metadata']['institutions'] ?? [] );
 ?>
-<div class="book">
-	<div class="book__cover" style="background-image: url('<?php echo $book['metadata']['image']; ?>' );"></div>
+<li class="book"
+		<?php
+		if ( $date ) {
+			?>
+			data-date-published="<?php echo $date; ?>"<?php } ?>
+	data-license="<?php echo ( new \Pressbooks\Licensing() )->getLicenseFromUrl( $book['metadata']['license']['url'] ); ?>"
+	data-institution="<?php echo implode( ',', $institution_codes ); ?>"
+		<?php
+		if ( ! empty( $subject ) ) {
+			?>
+			data-subject="<?php echo $subject ?>"<?php } ?>
+>
 	<p class="book__title">
 		<a href="<?php echo $book['link']; ?>"><?php echo maybe_truncate_string( $book['metadata']['name'] ); ?></a>
 	</p>
-</div>
+	<?php
+	/*
+	<?php if (isset( $book['metadata']['author'] ) ) { ?>
+	<p class="book__author">
+		<?php _e( 'By', 'pressbooks-aldine' ); ?> <?php foreach ( $book['metadata']['author'] as $author ) {
+			echo $author['name'];
+		} ?>
+	</p>
+	<?php } ?>
+	*/
+	?>
+	<?php if ( ! empty( $subject ) ) { ?>
+		<p class="book__subject">
+			<a href="<?php echo network_home_url( "/catalog/#$subject" ) ?>"><?php echo \Pressbooks\Metadata\get_subject_from_thema( $book['subject'] ); ?></a>
+		</p>
+	<?php } ?>
+	<?php if ( $institution_names ) : ?>
+		<p class="book__institutions">
+			<?php echo implode( ', ', $institution_names ); ?>
+		</p>
+	<?php endif; ?>
+	<p class="book__read-more">
+		<a href="<?php echo $book['link']; ?>"><?php _e( 'About this book', 'pressbooks-aldine' ); ?> <svg aria-hidden="true"><use xlink:href="#arrow-right" /></svg></a>
+	</p>
+</li>
diff --git a/partials/content-front-page.php b/partials/content-front-page.php
index 85bb0d6..f667307 100644
--- a/partials/content-front-page.php
+++ b/partials/content-front-page.php
@@ -56,7 +56,7 @@ if ( $catalog_page ) {
 		<div class="books">
 			<?php
 			foreach ( $catalog_data['books'] as $book ) :
-				include( locate_template( 'partials/book.php' ) );
+				include( locate_template( 'partials/featured-book.php' ) );
 			endforeach;
 			?>
 		</div>
diff --git a/partials/content-page-catalog.php b/partials/content-page-catalog.php
index 4d6b18e..97c4aa4 100644
--- a/partials/content-page-catalog.php
+++ b/partials/content-page-catalog.php
@@ -89,7 +89,7 @@
 	endforeach;
 	?>
 </ul>
-<?php if ( isset($catalog_data['pages']) && $catalog_data['pages'] > 1 ) : ?>
+<?php if ( isset( $catalog_data['pages'] ) && $catalog_data['pages'] > 1 ) : ?>
 <nav class="catalog-navigation">
 	<?php
 	if ( $previous_page ) :
diff --git a/partials/featured-book.php b/partials/featured-book.php
new file mode 100644
index 0000000..09af159
--- /dev/null
+++ b/partials/featured-book.php
@@ -0,0 +1,15 @@
+<?php
+/**
+ * Template for displaying books in network catalog
+ *
+ * @package Aldine
+ */
+
+use function \Aldine\Helpers\maybe_truncate_string;
+?>
+<div class="featured_book">
+	<div class="featured_book__cover" style="background-image: url('<?php echo $book['metadata']['image']; ?>' );"></div>
+	<p class="featured_book__title">
+		<a href="<?php echo $book['link']; ?>"><?php echo maybe_truncate_string( $book['metadata']['name'] ); ?></a>
+	</p>
+</div>