diff --git a/.htmlhintrc b/.htmlhintrc
new file mode 100644
index 0000000000000000000000000000000000000000..19115c1c25ab059dee0544148e5b8d088533ce9b
--- /dev/null
+++ b/.htmlhintrc
@@ -0,0 +1,12 @@
+{
+  "doctype-first": false,
+  "tagname-lowercase": true,
+  "attr-lowercase": false,
+  "attr-value-double-quotes": true,
+  "inline-style-disabled": true,
+  "inline-script-disabled": true,
+  "space-tab-mixed-disabled": true,
+  "style-disabled": true,
+  "attr-no-duplication": true,
+  "tagname-lowercase": true
+}
diff --git a/package-lock.json b/package-lock.json
index 84760f2dce6660614a256752110dc959a0f931bd..01035eb0c17eee0b373b49a5e84b0fee8bd358fc 100644
--- a/package-lock.json
+++ b/package-lock.json
@@ -1248,6 +1248,32 @@
         "to-fast-properties": "^2.0.0"
       }
     },
+    "@fortawesome/angular-fontawesome": {
+      "version": "0.6.1",
+      "resolved": "https://registry.npmjs.org/@fortawesome/angular-fontawesome/-/angular-fontawesome-0.6.1.tgz",
+      "integrity": "sha512-ARQjtRuT+ZskzJDJKPwuiGO3+7nS0iyNLU/uHVJHfG4LwGJxwVIGldwg1SU957sra0Z0OtWEajHMhiS4vB9LwQ=="
+    },
+    "@fortawesome/fontawesome-common-types": {
+      "version": "0.2.28",
+      "resolved": "https://registry.npmjs.org/@fortawesome/fontawesome-common-types/-/fontawesome-common-types-0.2.28.tgz",
+      "integrity": "sha512-gtis2/5yLdfI6n0ia0jH7NJs5i/Z/8M/ZbQL6jXQhCthEOe5Cr5NcQPhgTvFxNOtURE03/ZqUcEskdn2M+QaBg=="
+    },
+    "@fortawesome/fontawesome-svg-core": {
+      "version": "1.2.28",
+      "resolved": "https://registry.npmjs.org/@fortawesome/fontawesome-svg-core/-/fontawesome-svg-core-1.2.28.tgz",
+      "integrity": "sha512-4LeaNHWvrneoU0i8b5RTOJHKx7E+y7jYejplR7uSVB34+mp3Veg7cbKk7NBCLiI4TyoWS1wh9ZdoyLJR8wSAdg==",
+      "requires": {
+        "@fortawesome/fontawesome-common-types": "^0.2.28"
+      }
+    },
+    "@fortawesome/free-solid-svg-icons": {
+      "version": "5.13.0",
+      "resolved": "https://registry.npmjs.org/@fortawesome/free-solid-svg-icons/-/free-solid-svg-icons-5.13.0.tgz",
+      "integrity": "sha512-IHUgDJdomv6YtG4p3zl1B5wWf9ffinHIvebqQOmV3U+3SLw4fC+LUCCgwfETkbTtjy5/Qws2VoVf6z/ETQpFpg==",
+      "requires": {
+        "@fortawesome/fontawesome-common-types": "^0.2.28"
+      }
+    },
     "@istanbuljs/schema": {
       "version": "0.1.2",
       "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.2.tgz",
@@ -2671,6 +2697,17 @@
       "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==",
       "dev": true
     },
+    "cli": {
+      "version": "1.0.1",
+      "resolved": "https://registry.npmjs.org/cli/-/cli-1.0.1.tgz",
+      "integrity": "sha1-IoF1NPJL+klQw01TLUjsvGIbjBQ=",
+      "dev": true,
+      "optional": true,
+      "requires": {
+        "exit": "0.1.2",
+        "glob": "^7.1.1"
+      }
+    },
     "cli-cursor": {
       "version": "3.1.0",
       "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz",
@@ -3403,6 +3440,17 @@
       "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==",
       "dev": true
     },
+    "csslint": {
+      "version": "1.0.5",
+      "resolved": "https://registry.npmjs.org/csslint/-/csslint-1.0.5.tgz",
+      "integrity": "sha1-Gcw+2jIhYP0/cjKvHLKjYOiYouk=",
+      "dev": true,
+      "optional": true,
+      "requires": {
+        "clone": "~2.1.0",
+        "parserlib": "~1.1.1"
+      }
+    },
     "cssnano": {
       "version": "4.1.10",
       "resolved": "https://registry.npmjs.org/cssnano/-/cssnano-4.1.10.tgz",
@@ -3546,6 +3594,13 @@
       "integrity": "sha512-bYQuGLeFxhkxNOF3rcMtiZxvCBAquGzZm6oWA1oZ0g2THUzivaRhv8uOhdr19LmoobSOLoIAxeUK2RdbM8IFTA==",
       "dev": true
     },
+    "date-now": {
+      "version": "0.1.4",
+      "resolved": "https://registry.npmjs.org/date-now/-/date-now-0.1.4.tgz",
+      "integrity": "sha1-6vQ5/U1ISK105cx9vvIAZyueNFs=",
+      "dev": true,
+      "optional": true
+    },
     "debug": {
       "version": "4.1.1",
       "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz",
@@ -3875,6 +3930,16 @@
       "integrity": "sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w==",
       "dev": true
     },
+    "domhandler": {
+      "version": "2.3.0",
+      "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-2.3.0.tgz",
+      "integrity": "sha1-LeWaCCLVAn+r/28DLCsloqir5zg=",
+      "dev": true,
+      "optional": true,
+      "requires": {
+        "domelementtype": "1"
+      }
+    },
     "domutils": {
       "version": "1.7.0",
       "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.7.0.tgz",
@@ -4915,6 +4980,42 @@
         "path-is-absolute": "^1.0.0"
       }
     },
+    "glob-base": {
+      "version": "0.3.0",
+      "resolved": "https://registry.npmjs.org/glob-base/-/glob-base-0.3.0.tgz",
+      "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=",
+      "dev": true,
+      "requires": {
+        "glob-parent": "^2.0.0",
+        "is-glob": "^2.0.0"
+      },
+      "dependencies": {
+        "glob-parent": {
+          "version": "2.0.0",
+          "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-2.0.0.tgz",
+          "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=",
+          "dev": true,
+          "requires": {
+            "is-glob": "^2.0.0"
+          }
+        },
+        "is-extglob": {
+          "version": "1.0.0",
+          "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz",
+          "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=",
+          "dev": true
+        },
+        "is-glob": {
+          "version": "2.0.1",
+          "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz",
+          "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=",
+          "dev": true,
+          "requires": {
+            "is-extglob": "^1.0.0"
+          }
+        }
+      }
+    },
     "glob-parent": {
       "version": "3.1.0",
       "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz",
@@ -5190,6 +5291,167 @@
       "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==",
       "dev": true
     },
+    "htmlhint": {
+      "version": "0.11.0",
+      "resolved": "https://registry.npmjs.org/htmlhint/-/htmlhint-0.11.0.tgz",
+      "integrity": "sha512-uXuRyVhQa0HlNmZg5LJ1BRJvRq5f7IJL/34tItHhZr9re15pwaqAuLUAIcqtwd1bLUCE++7HVPtR+NSReFW0iA==",
+      "dev": true,
+      "requires": {
+        "async": "2.6.1",
+        "colors": "1.3.2",
+        "commander": "2.17.1",
+        "csslint": "^1.0.5",
+        "glob": "7.1.3",
+        "jshint": "^2.9.6",
+        "parse-glob": "3.0.4",
+        "path-parse": "1.0.6",
+        "request": "2.88.0",
+        "strip-json-comments": "2.0.1",
+        "xml": "1.0.1"
+      },
+      "dependencies": {
+        "async": {
+          "version": "2.6.1",
+          "resolved": "https://registry.npmjs.org/async/-/async-2.6.1.tgz",
+          "integrity": "sha512-fNEiL2+AZt6AlAw/29Cr0UDe4sRAHCpEHh54WMz+Bb7QfNcFw4h3loofyJpLeQs4Yx7yuqu/2dLgM5hKOs6HlQ==",
+          "dev": true,
+          "requires": {
+            "lodash": "^4.17.10"
+          }
+        },
+        "colors": {
+          "version": "1.3.2",
+          "resolved": "https://registry.npmjs.org/colors/-/colors-1.3.2.tgz",
+          "integrity": "sha512-rhP0JSBGYvpcNQj4s5AdShMeE5ahMop96cTeDl/v9qQQm2fYClE2QXZRi8wLzc+GmXSxdIqqbOIAhyObEXDbfQ==",
+          "dev": true
+        },
+        "commander": {
+          "version": "2.17.1",
+          "resolved": "https://registry.npmjs.org/commander/-/commander-2.17.1.tgz",
+          "integrity": "sha512-wPMUt6FnH2yzG95SA6mzjQOEKUU3aLaDEmzs1ti+1E9h+CsrZghRlqEM/EJ4KscsQVG8uNN4uVreUeT8+drlgg==",
+          "dev": true
+        },
+        "glob": {
+          "version": "7.1.3",
+          "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.3.tgz",
+          "integrity": "sha512-vcfuiIxogLV4DlGBHIUOwI0IbrJ8HWPc4MU7HzviGeNho/UJDfi6B5p3sHeWIQ0KGIU0Jpxi5ZHxemQfLkkAwQ==",
+          "dev": true,
+          "requires": {
+            "fs.realpath": "^1.0.0",
+            "inflight": "^1.0.4",
+            "inherits": "2",
+            "minimatch": "^3.0.4",
+            "once": "^1.3.0",
+            "path-is-absolute": "^1.0.0"
+          }
+        },
+        "punycode": {
+          "version": "1.4.1",
+          "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz",
+          "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=",
+          "dev": true
+        },
+        "request": {
+          "version": "2.88.0",
+          "resolved": "https://registry.npmjs.org/request/-/request-2.88.0.tgz",
+          "integrity": "sha512-NAqBSrijGLZdM0WZNsInLJpkJokL72XYjUpnB0iwsRgxh7dB6COrHnTBNwN0E+lHDAJzu7kLAkDeY08z2/A0hg==",
+          "dev": true,
+          "requires": {
+            "aws-sign2": "~0.7.0",
+            "aws4": "^1.8.0",
+            "caseless": "~0.12.0",
+            "combined-stream": "~1.0.6",
+            "extend": "~3.0.2",
+            "forever-agent": "~0.6.1",
+            "form-data": "~2.3.2",
+            "har-validator": "~5.1.0",
+            "http-signature": "~1.2.0",
+            "is-typedarray": "~1.0.0",
+            "isstream": "~0.1.2",
+            "json-stringify-safe": "~5.0.1",
+            "mime-types": "~2.1.19",
+            "oauth-sign": "~0.9.0",
+            "performance-now": "^2.1.0",
+            "qs": "~6.5.2",
+            "safe-buffer": "^5.1.2",
+            "tough-cookie": "~2.4.3",
+            "tunnel-agent": "^0.6.0",
+            "uuid": "^3.3.2"
+          }
+        },
+        "tough-cookie": {
+          "version": "2.4.3",
+          "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.4.3.tgz",
+          "integrity": "sha512-Q5srk/4vDM54WJsJio3XNn6K2sCG+CQ8G5Wz6bZhRZoAe/+TxjWB/GlFAnYEbkYVlON9FMk/fE3h2RLpPXo4lQ==",
+          "dev": true,
+          "requires": {
+            "psl": "^1.1.24",
+            "punycode": "^1.4.1"
+          }
+        }
+      }
+    },
+    "htmlparser2": {
+      "version": "3.8.3",
+      "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-3.8.3.tgz",
+      "integrity": "sha1-mWwosZFRaovoZQGn15dX5ccMEGg=",
+      "dev": true,
+      "optional": true,
+      "requires": {
+        "domelementtype": "1",
+        "domhandler": "2.3",
+        "domutils": "1.5",
+        "entities": "1.0",
+        "readable-stream": "1.1"
+      },
+      "dependencies": {
+        "domutils": {
+          "version": "1.5.1",
+          "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.5.1.tgz",
+          "integrity": "sha1-3NhIiib1Y9YQeeSMn3t+Mjc2gs8=",
+          "dev": true,
+          "optional": true,
+          "requires": {
+            "dom-serializer": "0",
+            "domelementtype": "1"
+          }
+        },
+        "entities": {
+          "version": "1.0.0",
+          "resolved": "https://registry.npmjs.org/entities/-/entities-1.0.0.tgz",
+          "integrity": "sha1-sph6o4ITR/zeZCsk/fyeT7cSvyY=",
+          "dev": true,
+          "optional": true
+        },
+        "isarray": {
+          "version": "0.0.1",
+          "resolved": "https://registry.npmjs.org/isarray/-/isarray-0.0.1.tgz",
+          "integrity": "sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=",
+          "dev": true,
+          "optional": true
+        },
+        "readable-stream": {
+          "version": "1.1.14",
+          "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-1.1.14.tgz",
+          "integrity": "sha1-fPTFTvZI44EwhMY23SB54WbAgdk=",
+          "dev": true,
+          "optional": true,
+          "requires": {
+            "core-util-is": "~1.0.0",
+            "inherits": "~2.0.1",
+            "isarray": "0.0.1",
+            "string_decoder": "~0.10.x"
+          }
+        },
+        "string_decoder": {
+          "version": "0.10.31",
+          "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-0.10.31.tgz",
+          "integrity": "sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=",
+          "dev": true,
+          "optional": true
+        }
+      }
+    },
     "http-cache-semantics": {
       "version": "3.8.1",
       "resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-3.8.1.tgz",
@@ -5706,6 +5968,12 @@
       "integrity": "sha1-YTObbyR1/Hcv2cnYP1yFddwVSuE=",
       "dev": true
     },
+    "is-dotfile": {
+      "version": "1.0.3",
+      "resolved": "https://registry.npmjs.org/is-dotfile/-/is-dotfile-1.0.3.tgz",
+      "integrity": "sha1-pqLzL/0t+wT1yiXs0Pa4PPeYoeE=",
+      "dev": true
+    },
     "is-extendable": {
       "version": "0.1.1",
       "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz",
@@ -6128,6 +6396,42 @@
       "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==",
       "dev": true
     },
+    "jshint": {
+      "version": "2.11.0",
+      "resolved": "https://registry.npmjs.org/jshint/-/jshint-2.11.0.tgz",
+      "integrity": "sha512-ooaD/hrBPhu35xXW4gn+o3SOuzht73gdBuffgJzrZBJZPGgGiiTvJEgTyxFvBO2nz0+X1G6etF8SzUODTlLY6Q==",
+      "dev": true,
+      "optional": true,
+      "requires": {
+        "cli": "~1.0.0",
+        "console-browserify": "1.1.x",
+        "exit": "0.1.x",
+        "htmlparser2": "3.8.x",
+        "lodash": "~4.17.11",
+        "minimatch": "~3.0.2",
+        "shelljs": "0.3.x",
+        "strip-json-comments": "1.0.x"
+      },
+      "dependencies": {
+        "console-browserify": {
+          "version": "1.1.0",
+          "resolved": "https://registry.npmjs.org/console-browserify/-/console-browserify-1.1.0.tgz",
+          "integrity": "sha1-8CQcRXMKn8YyOyBtvzjtx0HQuxA=",
+          "dev": true,
+          "optional": true,
+          "requires": {
+            "date-now": "^0.1.4"
+          }
+        },
+        "strip-json-comments": {
+          "version": "1.0.4",
+          "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-1.0.4.tgz",
+          "integrity": "sha1-HhX7ysl9Pumb8tc7TGVrCCu6+5E=",
+          "dev": true,
+          "optional": true
+        }
+      }
+    },
     "json-parse-better-errors": {
       "version": "1.0.2",
       "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz",
@@ -7807,6 +8111,35 @@
         "safe-buffer": "^5.1.1"
       }
     },
+    "parse-glob": {
+      "version": "3.0.4",
+      "resolved": "https://registry.npmjs.org/parse-glob/-/parse-glob-3.0.4.tgz",
+      "integrity": "sha1-ssN2z7EfNVE7rdFz7wu246OIORw=",
+      "dev": true,
+      "requires": {
+        "glob-base": "^0.3.0",
+        "is-dotfile": "^1.0.0",
+        "is-extglob": "^1.0.0",
+        "is-glob": "^2.0.0"
+      },
+      "dependencies": {
+        "is-extglob": {
+          "version": "1.0.0",
+          "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz",
+          "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=",
+          "dev": true
+        },
+        "is-glob": {
+          "version": "2.0.1",
+          "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz",
+          "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=",
+          "dev": true,
+          "requires": {
+            "is-extglob": "^1.0.0"
+          }
+        }
+      }
+    },
     "parse-json": {
       "version": "4.0.0",
       "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz",
@@ -7832,6 +8165,13 @@
         "better-assert": "~1.0.0"
       }
     },
+    "parserlib": {
+      "version": "1.1.1",
+      "resolved": "https://registry.npmjs.org/parserlib/-/parserlib-1.1.1.tgz",
+      "integrity": "sha1-pkz6ckBiQ0/fw1HJpOwtkrlMBvQ=",
+      "dev": true,
+      "optional": true
+    },
     "parseuri": {
       "version": "0.0.5",
       "resolved": "https://registry.npmjs.org/parseuri/-/parseuri-0.0.5.tgz",
@@ -9803,6 +10143,13 @@
       "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=",
       "dev": true
     },
+    "shelljs": {
+      "version": "0.3.0",
+      "resolved": "https://registry.npmjs.org/shelljs/-/shelljs-0.3.0.tgz",
+      "integrity": "sha1-NZbmMHp4FUT1kfN9phg2DzHbV7E=",
+      "dev": true,
+      "optional": true
+    },
     "signal-exit": {
       "version": "3.0.3",
       "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.3.tgz",
@@ -10550,6 +10897,12 @@
       "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=",
       "dev": true
     },
+    "strip-json-comments": {
+      "version": "2.0.1",
+      "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz",
+      "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=",
+      "dev": true
+    },
     "style-loader": {
       "version": "1.0.0",
       "resolved": "https://registry.npmjs.org/style-loader/-/style-loader-1.0.0.tgz",
@@ -13282,6 +13635,12 @@
         "async-limiter": "~1.0.0"
       }
     },
+    "xml": {
+      "version": "1.0.1",
+      "resolved": "https://registry.npmjs.org/xml/-/xml-1.0.1.tgz",
+      "integrity": "sha1-eLpyAgApxbyHuKgaPPzXS0ovweU=",
+      "dev": true
+    },
     "xml2js": {
       "version": "0.4.23",
       "resolved": "https://registry.npmjs.org/xml2js/-/xml2js-0.4.23.tgz",
diff --git a/package.json b/package.json
index 82a91bc4cea86b9d15b31d704ddd0e84a7b68fa9..036558308792a258ebc54a8cd05cfd0c83f77005 100644
--- a/package.json
+++ b/package.json
@@ -6,7 +6,7 @@
     "start": "ng serve",
     "build": "ng build",
     "test": "ng test",
-    "lint": "ng lint",
+    "lint": "ng lint && htmlhint",
     "e2e": "ng e2e"
   },
   "private": true,
@@ -19,6 +19,9 @@
     "@angular/platform-browser": "~9.0.2",
     "@angular/platform-browser-dynamic": "~9.0.2",
     "@angular/router": "~9.0.2",
+    "@fortawesome/angular-fontawesome": "^0.6.1",
+    "@fortawesome/fontawesome-svg-core": "^1.2.28",
+    "@fortawesome/free-solid-svg-icons": "^5.13.0",
     "bulma": "^0.8.1",
     "python": "0.0.4",
     "python-shell": "^1.0.8",
@@ -36,6 +39,7 @@
     "@types/jasminewd2": "~2.0.3",
     "@types/node": "^12.12.32",
     "codelyzer": "^5.1.2",
+    "htmlhint": "^0.11.0",
     "jasmine-core": "~3.5.0",
     "jasmine-spec-reporter": "~4.2.1",
     "karma": "~4.3.0",
diff --git a/src/app/app-routing.module.ts b/src/app/app-routing.module.ts
index 06c734263e1716e120bbb2771845eca1ae74c055..a407a1a14f74ac657d9f4f02f089037999778af7 100644
--- a/src/app/app-routing.module.ts
+++ b/src/app/app-routing.module.ts
@@ -1,8 +1,16 @@
 import { NgModule } from '@angular/core';
 import { Routes, RouterModule } from '@angular/router';
+import {ExplorerPageComponent} from './pages/explorer-page/explorer-page.component';
+import {AboutPageComponent} from './pages/about-page/about-page.component';
+import {HomePageComponent} from './pages/home-page/home-page.component';
 
 
-const routes: Routes = [];
+export const routes: Routes = [
+  { path: '', component: HomePageComponent },
+  { path: 'explorer', component: ExplorerPageComponent},
+  { path: 'explorer/:proteinGroup', component: ExplorerPageComponent},
+  { path: 'about', component: AboutPageComponent }
+];
 
 @NgModule({
   imports: [RouterModule.forRoot(routes)],
diff --git a/src/app/app.component.css b/src/app/app.component.css
deleted file mode 100644
index b7ef084c563fcdce196a2076486d16c87ef19cbf..0000000000000000000000000000000000000000
--- a/src/app/app.component.css
+++ /dev/null
@@ -1,3 +0,0 @@
-p {
-  font-family: Lato;
-}
\ No newline at end of file
diff --git a/src/app/app.component.html b/src/app/app.component.html
index d6bbe573ea62de61c74d361bd4f32080bb51baf3..77a029646b99af4c2db67dd808eecdc979d5f760 100644
--- a/src/app/app.component.html
+++ b/src/app/app.component.html
@@ -1,29 +1,33 @@
-<nav class="navbar" role="navigation" aria-label="main navigation">
-  <div class="navbar-brand">
-    <a class="navbar-item" href="https://bulma.io">
-      <img src="" height="28">
-    </a>
-
-    <a role="button" class="navbar-burger burger" aria-label="menu" aria-expanded="false">
-      <span aria-hidden="true"></span>
-      <span aria-hidden="true"></span>
-      <span aria-hidden="true"></span>
-    </a>
-  </div>
-
-  <div class="navbar-menu">
-    <div class="navbar-start">
-      <a class="navbar-item">
-        Network
+<div class="container is-fluid">
+  <nav class="navbar" role="navigation" aria-label="main navigation">
+    <div class="navbar-brand">
+      <img src="assets/logo.png" class="menu-icon" alt="logo" width="50px"/>
+      <a role="button" class="navbar-burger burger" aria-label="menu" aria-expanded="false">
+        <span aria-hidden="true"></span>
+        <span aria-hidden="true"></span>
+        <span aria-hidden="true"></span>
       </a>
     </div>
 
-    <div class="navbar-end">
-      <a class="navbar-item">
-        About
-      </a>
+    <div class="navbar-menu is-active">
+      <div class="navbar-start">
+        <a routerLink="/" routerLinkActive="is-active" class="navbar-item">
+          <span class="icon"><i class="fa fa-home"></i></span>
+          <span>Home</span>
+        </a>
+        <a routerLink="/explorer" routerLinkActive="is-active" class="navbar-item">
+          <span class="icon"><i class="fa fa-project-diagram"></i></span>
+          <span>Explorer</span>
+        </a>
+        <a routerLink="/about" routerLinkActive="is-active" class="navbar-item">
+          <span class="icon"><i class="fa fa-question"></i></span>
+          <span>About</span>
+        </a>
+      </div>
     </div>
-  </div>
-</nav>
+  </nav>
+</div>
 
-<router-outlet></router-outlet>
+<main>
+  <router-outlet></router-outlet>
+</main>
diff --git a/src/app/app.component.scss b/src/app/app.component.scss
index e69de29bb2d1d6434b8b29ae775ad8c2e48c5391..8b137891791fe96927ad78e64b0aad7bded08bdc 100644
--- a/src/app/app.component.scss
+++ b/src/app/app.component.scss
@@ -0,0 +1 @@
+
diff --git a/src/app/app.module.ts b/src/app/app.module.ts
index bf189ee6a5abcf6411e9988afea859b9357fab4e..3929e22a3cc505c855f89dd9636d02ea317b939a 100644
--- a/src/app/app.module.ts
+++ b/src/app/app.module.ts
@@ -1,30 +1,31 @@
 import { BrowserModule } from '@angular/platform-browser';
 import { NgModule } from '@angular/core';
 
+import { CommonModule } from '@angular/common';
 import { FormsModule } from '@angular/forms';
 
 import { AppRoutingModule } from './app-routing.module';
 import { AppComponent } from './app.component';
+import {ExplorerPageComponent} from './pages/explorer-page/explorer-page.component';
+import {AboutPageComponent} from './pages/about-page/about-page.component';
+import {HomePageComponent} from './pages/home-page/home-page.component';
 
 
-
-
-// @NgModule({
-//   declarations: [
-//     AppComponent
-//   ],
-//   imports: [
-//     BrowserModule,
-//     AppRoutingModule
-//   ],
-//   providers: [],
-//   bootstrap: [AppComponent]
-// })
-// export class AppModule { }
-
 @NgModule({
-  imports:      [ BrowserModule, FormsModule, AppRoutingModule],
-  declarations: [ AppComponent ],
-  bootstrap:    [ AppComponent ]
+  declarations: [
+    AppComponent,
+    ExplorerPageComponent,
+    AboutPageComponent,
+    HomePageComponent
+  ],
+  imports: [
+    BrowserModule,
+    AppRoutingModule,
+    FormsModule,
+    CommonModule
+  ],
+  providers: [],
+  bootstrap: [AppComponent]
+
 })
 export class AppModule { }
diff --git a/src/app/pages/about-page/about-page.component.html b/src/app/pages/about-page/about-page.component.html
new file mode 100644
index 0000000000000000000000000000000000000000..45094ab126acc03f58f9fb5790d98ac26065126d
--- /dev/null
+++ b/src/app/pages/about-page/about-page.component.html
@@ -0,0 +1,4 @@
+<div class="content">
+Write information about the project and website here
+</div>
+
diff --git a/src/app/pages/about-page/about-page.component.scss b/src/app/pages/about-page/about-page.component.scss
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
diff --git a/src/app/pages/about-page/about-page.component.ts b/src/app/pages/about-page/about-page.component.ts
new file mode 100644
index 0000000000000000000000000000000000000000..c93a5e594bbffb94c24ebb2e9ad1fd8474b73fd9
--- /dev/null
+++ b/src/app/pages/about-page/about-page.component.ts
@@ -0,0 +1,15 @@
+import { Component, OnInit } from '@angular/core';
+
+@Component({
+  selector: 'app-about-page',
+  templateUrl: './about-page.component.html',
+  styleUrls: ['./about-page.component.scss']
+})
+export class AboutPageComponent implements OnInit {
+
+  constructor() { }
+
+  ngOnInit() {
+  }
+
+}
diff --git a/src/app/pages/explorer-page/explorer-page.component.html b/src/app/pages/explorer-page/explorer-page.component.html
new file mode 100644
index 0000000000000000000000000000000000000000..79847ed623d8ab3f30e5dbb914648628812a3e1f
--- /dev/null
+++ b/src/app/pages/explorer-page/explorer-page.component.html
@@ -0,0 +1,136 @@
+<div class="content fullscreen">
+  <div class="modal" [class.is-active]="showModal">
+    <div class="modal-background"></div>
+    <div class="modal-card">
+      <header class="modal-card-head">
+        <p class="modal-card-title">{{groupId}}</p>
+        <button class="delete" aria-label="close" (click)="closeSummary()"></button>
+      </header>
+      <section class="modal-card-body">
+        <h2>General Information</h2>
+        <ul>
+          <li><b>Protein Group:</b> {{proteinGroup}}</li>
+          <li><b>Gene Name(s):</b> <span *ngFor="let geneName of geneNames"> {{ geneName }}</span>
+          <li><b>Protein Name(s):</b> <span *ngFor="let proteinName of proteinNames"> {{ proteinName }}</span>
+          </li>
+          <li><b>Protein AC(s):</b>
+            <a href="https://www.uniprot.org/uniprot/{{proteinAC}}" target="_blank"
+               *ngFor="let proteinAC of proteinACs">
+              {{ proteinAC }}<span><img class="inline" align="center" src="../assets/uniprot.png"></span>
+            </a>
+          </li>
+          <li><b>Number of Interactions:</b> {{numberOfInteractions}}</li>
+        </ul>
+
+        <h2>Summary</h2>
+        <figure class="image" (click)="openSummary('A4435')">
+          <img src="../assets/boxplot.png" alt="Boxplots">
+        </figure>
+      </section>
+
+      <footer class="modal-card-foot">
+        <button class="button is-danger" (click)="closeSummary()">Close</button>
+      </footer>
+    </div>
+  </div>
+
+
+  <div class="content left-bar">
+
+    <div class="card left-bar-item">
+      <header class="card-header">
+        <p class="card-header-title">
+          <span class="icon">
+        <i class="fas fa-info" aria-hidden="true"></i>
+      </span> Info
+        </p>
+      </header>
+      <div class="card-content">
+        <div class="content">
+          Information about how to use the explorer
+        </div>
+      </div>
+    </div>
+
+    <div class="card left-bar-item">
+      <header class="card-header">
+        <p class="card-header-title">
+          <span class="icon">
+        <i class="fas fa-search" aria-hidden="true"></i>
+      </span> Query Protein/Gene
+        </p>
+      </header>
+      <div class="card-content">
+        <div class="content">
+          <div class="field">
+            <div class="control is-loading">
+              <input class="input" type="text" placeholder="Search for Protein/Gene...">
+            </div>
+          </div>
+        </div>
+      </div>
+    </div>
+
+    <div class="card left-bar-item">
+      <header class="card-header">
+        <p class="card-header-title">
+          <span class="icon">
+        <i class="fas fa-filter" aria-hidden="true"></i>
+      </span> Filtering
+        </p>
+      </header>
+      <div class="card-content">
+        <div class="content">
+          <p><b>Baits</b></p>
+          <label class="checkbox" *ngFor="let baitName of baitNames">
+            <input type="checkbox" class="checkbox">
+            {{ baitName }}
+          </label>
+        </div>
+      </div>
+      <footer class="card-footer">
+        <button class="card-footer-item button is-danger">Reset
+        </button>
+      </footer>
+    </div>
+  </div>
+
+  <div class="card right-big" >
+    <header class="card-header">
+      <p class="card-header-title">
+        SARS-CoV-2 Protein-Protein Interaction Network
+      </p>
+      <a href="#" class="card-header-icon" aria-label="more options">
+      <span class="icon">
+        <i class="fas fa-sliders-h" aria-hidden="true"></i>
+      </span>
+      </a>
+    </header>
+    <div class="card-content">
+      <div class="card-image">
+        <figure class="image" (click)="openSummary('A4435')">
+          <img src="assets/graph_example.png" alt="PPI Network" class="network">
+        </figure>
+      </div>
+      <footer class="card-footer">
+        <button class="card-footer-item button is-primary">
+                <span class="icon">
+        <i class="fas fa-cloud-download-alt" aria-hidden="true"></i>
+      </span>
+        </button>
+        <a class="card-footer-item">
+        <span class="icon">
+        <i class="fas fa-search-plus" aria-hidden="true"></i>
+      </span>
+        </a>
+        <a href="#" class="card-footer-item">
+         <span class="icon">
+        <i class="fas fa-search-minus" aria-hidden="true"></i>
+      </span>
+        </a>
+      </footer>
+    </div>
+  </div>
+</div>
+
+
diff --git a/src/app/pages/explorer-page/explorer-page.component.scss b/src/app/pages/explorer-page/explorer-page.component.scss
new file mode 100644
index 0000000000000000000000000000000000000000..230c9db23bc69c20eda1da9a21c0b05c93ebbbdb
--- /dev/null
+++ b/src/app/pages/explorer-page/explorer-page.component.scss
@@ -0,0 +1,9 @@
+.card {
+  height: 100%;
+  display:flex;
+  flex-direction: column;
+}
+
+.card-block{
+  height: 100%;
+}
diff --git a/src/app/pages/explorer-page/explorer-page.component.ts b/src/app/pages/explorer-page/explorer-page.component.ts
new file mode 100644
index 0000000000000000000000000000000000000000..a16def7f2caa1fd8f8d35d039178fad0d69e1dc3
--- /dev/null
+++ b/src/app/pages/explorer-page/explorer-page.component.ts
@@ -0,0 +1,71 @@
+import {Component, OnInit} from '@angular/core';
+import {ActivatedRoute, Router} from '@angular/router';
+
+@Component({
+  selector: 'app-explorer-page',
+  templateUrl: './explorer-page.component.html',
+  styleUrls: ['./explorer-page.component.scss'],
+})
+export class ExplorerPageComponent implements OnInit {
+
+  public showModal = false;
+  public groupId = '';
+  public geneNames: Array<string> = [];
+  public proteinGroup = '';
+  public proteinNames: Array<string> = [];
+  public proteinACs: Array<string> = [];
+  public numberOfInteractions = 0;
+  public baitNames: Array<string> = [];
+
+  constructor(private route: ActivatedRoute, private router: Router) {
+
+    this.groupId = 'IFI16';
+    this.geneNames.push('IFI16');
+    this.proteinNames.push('Gamma-interface-inducible protein 16');
+    this.proteinACs.push('Q16666');
+    this.numberOfInteractions = 25;
+    this.baitNames.push('Bait Protein 1');
+    this.baitNames.push('Bait Protein 2');
+    this.baitNames.push('Bait Protein 3');
+    this.baitNames.push('Bait Protein 4');
+    this.baitNames.push('Bait Protein 5');
+
+    this.route.params.subscribe(async (params) => {
+      const proteinGroup = params.proteinGroup;
+      if (!proteinGroup) {
+        // In this case, the URL is just `/explorer`
+        // Therefore, we do not show a modal
+        this.showModal = false;
+        return;
+      }
+
+      // In this case, the URL is `/explorer/<proteinGroup>`
+
+      if (this.proteinGroup === proteinGroup) {
+        // The protein group is the same as before, so we do not need to do anything
+        return;
+      }
+
+      // We have a new proteinGroup id, so we need to load it and show the modal...
+
+      this.proteinGroup = proteinGroup;
+
+      // TODO: Perform call here for 'proteinGroup'...
+
+      this.showModal = true;
+    });
+  }
+
+  ngOnInit() {
+
+  }
+
+  public async openSummary(groupId: string) {
+    await this.router.navigate(['explorer', groupId]);
+  }
+
+  public async closeSummary() {
+    await this.router.navigate(['explorer']);
+  }
+
+}
diff --git a/src/app/pages/home-page/home-page.component.html b/src/app/pages/home-page/home-page.component.html
new file mode 100644
index 0000000000000000000000000000000000000000..d0d4cd44afe8063d7785b8b4bbb2eddaee71b5aa
--- /dev/null
+++ b/src/app/pages/home-page/home-page.component.html
@@ -0,0 +1,17 @@
+<section class="hero is-primary is-large">
+  <div class="hero-body">
+    <div class="container">
+      <h1 class="title">
+        SARS-CoV-2 Explorer
+      </h1>
+      <h2 class="subtitle">
+        Explore the Protein interactions of SARS-CoV-2
+      </h2>
+    </div>
+  </div>
+</section>
+
+<div class="content">
+General Information about the Website
+</div>
+
diff --git a/src/app/pages/home-page/home-page.component.scss b/src/app/pages/home-page/home-page.component.scss
new file mode 100644
index 0000000000000000000000000000000000000000..e69de29bb2d1d6434b8b29ae775ad8c2e48c5391
diff --git a/src/app/pages/home-page/home-page.component.ts b/src/app/pages/home-page/home-page.component.ts
new file mode 100644
index 0000000000000000000000000000000000000000..4f49595151dfc8f84a5391366a3ea01dc1b07e65
--- /dev/null
+++ b/src/app/pages/home-page/home-page.component.ts
@@ -0,0 +1,15 @@
+import { Component, OnInit } from '@angular/core';
+
+@Component({
+  selector: 'app-home-page',
+  templateUrl: './home-page.component.html',
+  styleUrls: ['./home-page.component.scss']
+})
+export class HomePageComponent implements OnInit {
+
+  constructor() { }
+
+  ngOnInit() {
+  }
+
+}
diff --git a/src/assets/boxplot.png b/src/assets/boxplot.png
new file mode 100644
index 0000000000000000000000000000000000000000..4e8eb829cd5c8581bca92b8ced95653e47b93a46
Binary files /dev/null and b/src/assets/boxplot.png differ
diff --git a/src/assets/graph_example.png b/src/assets/graph_example.png
new file mode 100644
index 0000000000000000000000000000000000000000..a7ed6b8a5ff329c8812c46fabaaf3d8e0a95970d
Binary files /dev/null and b/src/assets/graph_example.png differ
diff --git a/src/assets/logo.png b/src/assets/logo.png
new file mode 100644
index 0000000000000000000000000000000000000000..066eb713ee455cebe340dc8504fe6fcf1bfad8d0
Binary files /dev/null and b/src/assets/logo.png differ
diff --git a/src/assets/uniprot.png b/src/assets/uniprot.png
new file mode 100644
index 0000000000000000000000000000000000000000..c2f607535a9d0f1e6cbe3a7e7d6388c14ac86282
Binary files /dev/null and b/src/assets/uniprot.png differ
diff --git a/src/index.html b/src/index.html
index 1eb0ed1f005def2751a3ac0fb4a4069d919443d0..82b85d025b288c79124f834415b62d664a6bc593 100644
--- a/src/index.html
+++ b/src/index.html
@@ -2,10 +2,10 @@
 <html lang="en">
 <head>
   <meta charset="utf-8">
-  <title>Covid19</title>
+  <title>CovPPI</title>
   <base href="/">
   <meta name="viewport" content="width=device-width, initial-scale=1">
-  <link rel="icon" type="image/x-icon" href="favicon.ico">
+  <link rel="icon" type="image/ico" href="../../assets/logo.png">
   <script src="https://kit.fontawesome.com/3ad4fe992f.js" crossorigin="anonymous"></script>
 </head>
 <body>
diff --git a/src/styles.scss b/src/styles.scss
index 7d85f64db268396b259b1bf8cf1a6f1e1422b9d8..cb26458e9f9ffa624ee3e9d1b066af42fe8d5e7a 100644
--- a/src/styles.scss
+++ b/src/styles.scss
@@ -1,3 +1,92 @@
 /* You can add global styles to this file, and also import other style files */
 
-@import '~bulma';
+@charset "utf-8";
+
+@import url('https://fonts.googleapis.com/css?family=Varela+Round');
+$family-sans-serif: "Varela Round", sans-serif;
+@import "~bulma/bulma.sass";
+
+.hero.is-primary {
+  background-color: #118AB2;
+  background-image: url("assets/logo.png"), linear-gradient(to left, #f2fcfe, #118AB2);
+  background-repeat: no-repeat;
+  background-position: 80%;
+  padding: 50px;
+}
+
+.button.is-primary, .button.is-primary:hover, .button.is-primary:disabled {
+  background-color: #118AB2;
+}
+
+.button.is-danger, .button.is-danger:hover, .button.is-danger:disabled {
+  background-color: #EF476F;
+}
+
+.button.is-success, .button.is-success:hover, .button.is-success:disabled {
+  background-color: #06D6A0;
+}
+
+div.content {
+  margin: 30px;
+}
+
+div.content.fullscreen {
+  margin: 20px;
+  height: calc(100vh - 120px);
+  width: 100%;
+}
+
+div.navbar-menu {
+  margin-left: 5px;
+}
+
+div.content.left-bar {
+  float: left;
+  width: 400px;
+}
+
+div.card.left-bar-item {
+  margin-bottom: 30px;
+}
+
+div.card.right-big {
+  float: right;
+  width: calc(100% - 460px);
+  height: calc(100vh - 105px);
+}
+
+button.i {
+  margin-left: 5px;
+}
+
+body {
+   height: 100%;
+}
+
+img {
+  margin: 10px;
+}
+
+span.icon {
+  margin-right: 5px;
+}
+
+img.inline {
+  height: 30px;
+  margin-left: 0px;
+}
+
+img.network {
+  height: calc(100vh - 270px);
+}
+
+main {
+  height: calc(100vh - 500px);
+}
+
+input.checkbox {
+  margin-left: 15px;
+}
+
+
+