diff --git a/package.json b/package.json
index 27cb1a2..97bf983 100644
--- a/package.json
+++ b/package.json
@@ -40,6 +40,7 @@
     "dexie": "^1.5.1",
     "inferno": "^1.6.0",
     "inferno-component": "^1.6.0",
+    "inferno-devtools": "^1.6.0",
     "marked": "^0.3.6",
     "papaparse": "^4.2.0"
   }
diff --git a/src/components/Lexiconga.jsx b/src/components/Lexiconga.jsx
new file mode 100644
index 0000000..a22f2c3
--- /dev/null
+++ b/src/components/Lexiconga.jsx
@@ -0,0 +1,45 @@
+import Inferno from 'inferno';
+import Component from 'inferno-component';
+
+import {LeftColumn} from './structure/LeftColumn';
+import {RightColumn} from './structure/RightColumn';
+
+import {WordForm} from './management/WordForm';
+import {DictionaryDetails} from './display/DictionaryDetails';
+
+export class Lexiconga extends Component {
+  constructor (props) {
+    super(props);
+  }
+
+  render () {
+    return (
+      
+    );
+  }
+}
diff --git a/src/components/display/DictionaryDetails.jsx b/src/components/display/DictionaryDetails.jsx
new file mode 100644
index 0000000..0a98c82
--- /dev/null
+++ b/src/components/display/DictionaryDetails.jsx
@@ -0,0 +1,204 @@
+import Inferno from 'inferno';
+import Component from 'inferno-component';
+import marked from 'marked';
+
+import {SearchBox} from '../management/SearchBox';
+
+const DISPLAY = {
+  NONE: false
+, DESCRIPTION: 1
+, DETAILS: 2
+, STATS: 3
+, SEARCH: 4
+}
+
+export class DictionaryDetails extends Component {
+  constructor (props) {
+    super(props);
+
+    this.state = {
+      currentDisplay: DISPLAY.NONE
+    }
+
+    this._descriptionHTML = marked(props.description);
+  }
+
+  componentWillReceiveProps (nextProps) {
+    const currentDescription = this.props.description
+    ,     nextDescription = nextProps.description;
+
+    if (currentDescription !== nextDescription) {
+      this._descriptionHTML = marked(nextProps.description);
+    }
+  }
+
+  toggleDisplay (display) {
+    display = (this.state.currentDisplay !== display) ? display : DISPLAY.NONE;
+
+    this.setState({
+      currentDisplay: display
+    });
+  }
+
+  displayInfo () {
+    if (this.state.currentDisplay !== DISPLAY.NONE) {
+      let displayJSX;
+
+      switch(this.state.currentDisplay) {
+        case DISPLAY.DESCRIPTION : {
+          // Not sure why, but the dangerouslySet div needs to be wrapped in another div or else
+          // the HTML content sticks around for some reason.
+          displayJSX = (
+            
+          );
+          break;
+        }
+
+        case DISPLAY.DETAILS : {
+          let additionalMenu;
+          if (this.props.details.hasOwnProperty('custom')) {
+            let customTabsJSX = this.props.details.custom.map((tab) => {
+              return (
+                
+                  
+                    {tab.name}
+                  
+                
+              );
+            });
+
+            additionalMenu = (
+              
+            );
+          }
+
+          const menu = (
+            
+          );
+
+          let content = (
+            
+          );
+
+          displayJSX = (
+            
+              {menu}
+              {content}
+            
+          );
+          break;
+        }
+
+        case DISPLAY.STATS : {
+          displayJSX = (
+            
+          );
+          break;
+        }
+
+        case DISPLAY.SEARCH : {
+          displayJSX = ;
+          break;
+        }
+      }
+
+      return (
+        
+          {displayJSX}
+        
+      )
+    }
+  }
+
+  render () {
+    return (
+      
+
+        
+          
+            
+              
+                Dictionary Name
+              
+            
+          
+
+          
+        
+
+        
+
+        {this.displayInfo()}
+
+      
+          
+          
+            {filterOptionsJSX}
+          
+        
+        
+        
+        
+        {this.showFilterOptions()}
+
+      
+        
+
+        
+
+        
+          
+          
+            
+              
+            
+          
+        
+
+        
+        
+        
+      
+        {this.props.children}
+      
+    );
+  }
+}
diff --git a/src/components/structure/RightColumn.jsx b/src/components/structure/RightColumn.jsx
new file mode 100644
index 0000000..7197067
--- /dev/null
+++ b/src/components/structure/RightColumn.jsx
@@ -0,0 +1,16 @@
+import Inferno from 'inferno';
+import Component from 'inferno-component';
+
+export class RightColumn extends Component {
+  constructor (props) {
+    super(props);
+  }
+
+  render () {
+    return (
+      
+        {this.props.children}
+      
+    );
+  }
+}
diff --git a/src/index.jsx b/src/index.jsx
index d1ef6e0..d4481d5 100644
--- a/src/index.jsx
+++ b/src/index.jsx
@@ -3,6 +3,14 @@ import './sass/main.scss';
 import Inferno from 'inferno';
 import Component from 'inferno-component';
 
+if (process.env.NODE_ENV !== 'production') {
+  require('inferno-devtools');
+}
+
+import {Header} from './components/structure/Header';
+import {Lexiconga} from './components/Lexiconga';
+import {Footer} from './components/structure/Footer';
+
 class App extends Component {
   constructor (props) {
     super(props);
@@ -11,95 +19,11 @@ class App extends Component {
   render () {
     return (
       
-        
+        
 
-        
-          
-            
-              
-                
-                  
-                  
-                  
-                    
-                    
-                      
-                        
-                      
-                    
-                  
-                  
-                    
-                    
-                      
-                    
-                  
-                  
-                    
-                    
-                      
-                    
-                  
-                
-              
-
-              
-
-              
-
-              
-            
-          
+        
 
+