diff --git a/config.js b/config.js
index 5a3c980..8640648 100644
--- a/config.js
+++ b/config.js
@@ -6,7 +6,7 @@ module.exports = {
   subtitle: 'Pellentesque odio nisi, euismod in, pharetra a, ultricies in, diam. Sed arcu.',
   copyright: '© All rights reserved.',
   disqusShortname: '',
-  postsPerPage: 1,
+  postsPerPage: 4,
   googleAnalyticsId: 'UA-73379983-2',
   menu: [
     {
diff --git a/gatsby-config.js b/gatsby-config.js
index 2d7283b..b0cce10 100644
--- a/gatsby-config.js
+++ b/gatsby-config.js
@@ -22,9 +22,9 @@ module.exports = {
       }
     },
     {
-      resolve: "gatsby-source-filesystem",
+      resolve: 'gatsby-source-filesystem',
       options: {
-        name: "assets",
+        name: 'assets',
         path: `${__dirname}/static`
       }
     },
diff --git a/gatsby/on-create-node.js b/gatsby/on-create-node.js
index aa47919..9686ea1 100644
--- a/gatsby/on-create-node.js
+++ b/gatsby/on-create-node.js
@@ -2,10 +2,13 @@
 
 const _ = require('lodash');
 const { createFilePath } = require('gatsby-source-filesystem');
+const { fmImagesToRelative } = require('gatsby-remark-relative-images');
 
 const onCreateNode = ({ node, actions, getNode }) => {
   const { createNodeField } = actions;
 
+  fmImagesToRelative(node);
+
   if (node.internal.type === 'MarkdownRemark') {
     if (typeof node.frontmatter.path !== 'undefined') {
       createNodeField({
@@ -23,12 +26,12 @@ const onCreateNode = ({ node, actions, getNode }) => {
     }
 
     if (node.frontmatter.tags) {
-      const tagSlugs = node.frontmatter.tags.map((tag) => `/tags/${_.kebabCase(tag)}/`);
+      const tagSlugs = node.frontmatter.tags.map((tag) => `/tag/${_.kebabCase(tag)}/`);
       createNodeField({ node, name: 'tagSlugs', value: tagSlugs });
     }
 
     if (node.frontmatter.category) {
-      const categorySlug = `/categories/${_.kebabCase(node.frontmatter.category)}/`;
+      const categorySlug = `/category/${_.kebabCase(node.frontmatter.category)}/`;
       createNodeField({ node, name: 'categorySlug', value: categorySlug });
     }
   }
diff --git a/gatsby/pagination/create-categories-pages.js b/gatsby/pagination/create-categories-pages.js
index 290d744..4114324 100644
--- a/gatsby/pagination/create-categories-pages.js
+++ b/gatsby/pagination/create-categories-pages.js
@@ -6,6 +6,7 @@ const siteConfig = require('../../config.js');
 
 module.exports = async (graphql, actions) => {
   const { createPage } = actions;
+  const { postsPerPage } = siteConfig;
 
   const result = await graphql(`
     {
@@ -21,17 +22,22 @@ module.exports = async (graphql, actions) => {
   `);
 
   _.each(result.data.allMarkdownRemark.group, (category) => {
-    const numPages = Math.ceil(category.totalCount / siteConfig.postsPerPage);
+    const numPages = Math.ceil(category.totalCount / postsPerPage);
+    const categorySlug = `/category/${_.kebabCase(category.fieldValue)}`;
 
     for (let i = 0; i < numPages; i += 1) {
       createPage({
-        path: i === 0 ? `/category/${_.kebabCase(category.fieldValue)}` : `/category/${_.kebabCase(category.fieldValue)}/page/${i}`,
+        path: i === 0 ? categorySlug : `${categorySlug}/page/${i}`,
         component: path.resolve('./src/templates/category-template.js'),
         context: {
-          page: i,
           category: category.fieldValue,
-          limit: siteConfig.postsPerPage,
-          skip: i * siteConfig.postsPerPage,
+          currentPage: i,
+          postsLimit: postsPerPage,
+          postsOffset: i * postsPerPage,
+          prevPagePath: i <= 1 ? categorySlug : `${categorySlug}/page/${i - 1}`,
+          nextPagePath: `/${categorySlug}/page/${i + 1}`,
+          hasPrevPage: i !== 0,
+          hasNextPage: i !== numPages - 1
         }
       });
     }
diff --git a/gatsby/pagination/create-posts-pages.js b/gatsby/pagination/create-posts-pages.js
index df32ab8..792bcde 100644
--- a/gatsby/pagination/create-posts-pages.js
+++ b/gatsby/pagination/create-posts-pages.js
@@ -14,16 +14,21 @@ module.exports = async (graphql, actions) => {
     }
   `);
 
-  const numPages = Math.ceil(result.data.allMarkdownRemark.totalCount / siteConfig.postsPerPage);
+  const { postsPerPage } = siteConfig;
+  const numPages = Math.ceil(result.data.allMarkdownRemark.totalCount / postsPerPage);
 
   for (let i = 0; i < numPages; i += 1) {
     createPage({
       path: i === 0 ? '/' : `/page/${i}`,
       component: path.resolve('./src/templates/index-template.js'),
       context: {
-        page: i,
-        limit: siteConfig.postsPerPage,
-        skip: i * siteConfig.postsPerPage,
+        currentPage: i,
+        postsLimit: postsPerPage,
+        postsOffset: i * postsPerPage,
+        prevPagePath: i <= 1 ? '/' : `/page/${i - 1}`,
+        nextPagePath: `/page/${i + 1}`,
+        hasPrevPage: i !== 0,
+        hasNextPage: i !== numPages - 1
       }
     });
   }
diff --git a/gatsby/pagination/create-tags-pages.js b/gatsby/pagination/create-tags-pages.js
index f6d506e..a2683d0 100644
--- a/gatsby/pagination/create-tags-pages.js
+++ b/gatsby/pagination/create-tags-pages.js
@@ -6,6 +6,7 @@ const siteConfig = require('../../config.js');
 
 module.exports = async (graphql, actions) => {
   const { createPage } = actions;
+  const { postsPerPage } = siteConfig;
 
   const result = await graphql(`
     {
@@ -21,17 +22,22 @@ module.exports = async (graphql, actions) => {
   `);
 
   _.each(result.data.allMarkdownRemark.group, (tag) => {
-    const numPages = Math.ceil(tag.totalCount / siteConfig.postsPerPage);
+    const numPages = Math.ceil(tag.totalCount / postsPerPage);
+    const tagSlug = `/tag/${_.kebabCase(tag.fieldValue)}`;
 
     for (let i = 0; i < numPages; i += 1) {
       createPage({
-        path: i === 0 ? `/tag/${_.kebabCase(tag.fieldValue)}` : `/tag/${_.kebabCase(tag.fieldValue)}/page/${i}`,
+        path: i === 0 ? tagSlug : `${tagSlug}/page/${i}`,
         component: path.resolve('./src/templates/tag-template.js'),
         context: {
-          page: i,
           tag: tag.fieldValue,
-          limit: siteConfig.postsPerPage,
-          skip: i * siteConfig.postsPerPage,
+          currentPage: i,
+          postsLimit: postsPerPage,
+          postsOffset: i * postsPerPage,
+          prevPagePath: i <= 1 ? tagSlug : `${tagSlug}/page/${i - 1}`,
+          nextPagePath: `${tagSlug}/page/${i + 1}`,
+          hasPrevPage: i !== 0,
+          hasNextPage: i !== numPages - 1
         }
       });
     }
diff --git a/package.json b/package.json
index 721f2fc..a36efc0 100644
--- a/package.json
+++ b/package.json
@@ -30,6 +30,7 @@
     "starter"
   ],
   "dependencies": {
+    "classnames": "^2.2.6",
     "bluebird": "^3.5.2",
     "codecov": "^3.1.0",
     "gatsby": "^2.0.38",
@@ -38,7 +39,7 @@
     "gatsby-plugin-feed": "^2.0.8",
     "gatsby-plugin-google-analytics": "^2.0.6",
     "gatsby-plugin-netlify": "^2.0.3",
-    "gatsby-plugin-netlify-cms": "^3.0.5",
+    "gatsby-plugin-netlify-cms": "^3.0.7",
     "gatsby-plugin-offline": "^2.0.6",
     "gatsby-plugin-react-helmet": "^3.0.0",
     "gatsby-plugin-sass": "^2.0.3",
@@ -48,6 +49,7 @@
     "gatsby-remark-images": "^2.0.4",
     "gatsby-remark-prismjs": "^3.0.2",
     "gatsby-remark-responsive-iframe": "^2.0.5",
+    "gatsby-remark-relative-images": "^0.2.0",
     "gatsby-remark-smartypants": "^2.0.5",
     "gatsby-source-filesystem": "^2.0.3",
     "gatsby-transformer-remark": "^2.1.7",
diff --git a/src/components/Pagination/Pagination.js b/src/components/Pagination/Pagination.js
new file mode 100644
index 0000000..faa217f
--- /dev/null
+++ b/src/components/Pagination/Pagination.js
@@ -0,0 +1,37 @@
+import React from 'react';
+import classNames from 'classnames/bind';
+import { Link } from 'gatsby';
+import { PAGINATION } from '../../constants';
+import styles from './Pagination.module.scss';
+
+const cx = classNames.bind(styles);
+
+const Pagination = ({
+  prevPagePath,
+  nextPagePath,
+  hasNextPage,
+  hasPrevPage
+}) => {
+  const prevClassName = cx({
+    'pagination__prev-link': true,
+    'pagination__prev-link--disable': !hasPrevPage
+  });
+
+  const nextClassName = cx({
+    'pagination__next-link': true,
+    'pagination__next-link--disable': !hasNextPage
+  });
+
+  return (
+    
+      
+        {PAGINATION.PREV_PAGE}
+      
+      
+        {PAGINATION.NEXT_PAGE}
+      
+    
+  
+    
+      ← PREV
+    
+  
+  
+    
+      → NEXT
+    
+  
+
+          
+            
+              ← PREV
+            
+          
+          
+            
+              → NEXT
+            
+          
+        
+          
+            
+              ← PREV
+            
+          
+          
+            
+              → NEXT
+            
+          
+        
+          
+            
+              ← PREV
+            
+          
+          
+            
+              → NEXT
+            
+          
+