diff --git a/web/src/App.jsx b/web/src/App.jsx
index 5600399..4f03718 100644
--- a/web/src/App.jsx
+++ b/web/src/App.jsx
@@ -2,13 +2,15 @@ import {
   BrowserRouter as Router,
   Switch,
   Route,
-  Link
 } from "react-router-dom";
+import { ThemeProvider } from "styled-components";
 import {CreateUserWidget, RecentActivityWidget, SystemStatusWidget} from './components'
 import {AccountManager, AdminUI, Logger} from './views'
+import theme from './theme';
 function App() {
   return (
     
+      
       
         
           
@@ -21,6 +23,7 @@ function App() {
           
         
       
+      
     
   );
 }
diff --git a/web/src/components/Card.jsx b/web/src/components/Card.jsx
index 28f2ff2..59aae88 100644
--- a/web/src/components/Card.jsx
+++ b/web/src/components/Card.jsx
@@ -1,20 +1,19 @@
 import React from 'react'
 import styled from 'styled-components'
-import { theme } from '../theme';
 const CardDiv = styled.div`
 flex-grow: 1;
-color: ${theme.color6};
-background: ${theme.color1};
+color: ${props=>props.theme.colours.color6};
+background: ${props=>props.theme.colours.color1};
 border-radius: 1em;
 padding: 1em;
 margin: 1em;
 h4 {
-    margin: 0;
-  }
+  margin: 0;
+}
 `;
 export default function Card({children}) {
     return (
-        
+        
             {children}
         
     )
diff --git a/web/src/components/Card.sass b/web/src/components/Card.sass
deleted file mode 100644
index dbd4b02..0000000
--- a/web/src/components/Card.sass
+++ /dev/null
@@ -1,74 +0,0 @@
-.main
-    &__card
-        flex-grow: 1
-        color: $color6
-        background: $color1
-        border-radius: 1em
-        padding: 1em
-        margin: 1em
-        h4
-            margin: 0
-        &__input
-            padding: 1em .2em .1em 0.2em
-            display: inline-block
-            flex-grow: 1
-            with: auto
-            z-index: 1
-            border: none
-            background: none
-            outline: none
-            font-size: 1em
-            &__box
-                font-size: 1.1em
-                overflow: hidden
-                position: relative
-                margin: 0.2em 0
-                display: flex
-                flex-direction: row
-                align-items: stretch
-                background: $color6
-                border-bottom: .3em solid $color5
-                &:hover
-                    border-bottom: .3em solid $color3
-                    outline: auto
-                >button
-                    position: relative
-                    background: $color2
-                    color: $color6
-                    border: none
-                    font-size: 0.8em
-                    font-weight: bold
-                    padding: 0 .5em
-                    transition: ease all 300ms
-                    z-index: 1
-                    &::before
-                        position: absolute
-                        display: block
-                        content: ''
-                        clip-path: polygon(0% 0%, 100% 100%, 0% 100%)
-                        transform: translateX(-90%) rotate(45deg)
-                        height: 1em
-                        width: 1em
-                        background: $color2
-                        transition: ease all 300ms
-                    &:hover
-                        background: $color3
-                        &::before
-                            background: $color3
-                            transform: translateX(-90%) rotate(45deg) scale(1.2)
-
-            &__label
-                padding: 0
-                color: $color2
-                z-index: 0
-                position: absolute
-                left: 0.2em
-                padding-bottom: 0.2em
-                bottom: 0
-                transition: all ease-in-out 350ms
-            &:focus + &__label, &:not(:placeholder-shown) + &__label
-                color: $color5
-                font-size: 0.7em
-                transform: translateY(0)
-                bottom: 50%
-                font-weight: bold
\ No newline at end of file
diff --git a/web/src/components/CreateUserWidget.jsx b/web/src/components/CreateUserWidget.jsx
index f487392..e204e5b 100644
--- a/web/src/components/CreateUserWidget.jsx
+++ b/web/src/components/CreateUserWidget.jsx
@@ -1,20 +1,20 @@
 import React, { Component } from 'react'
 import TextInput from './TextInput'
+import Card from './Card'
 export class CreateUserWidget extends Component {
     render() {
         return (
-            
+                
         )
     }
 }
diff --git a/web/src/components/RecentActivityWidget.jsx b/web/src/components/RecentActivityWidget.jsx
index 961e904..1beb9a1 100644
--- a/web/src/components/RecentActivityWidget.jsx
+++ b/web/src/components/RecentActivityWidget.jsx
@@ -1,9 +1,9 @@
 import React, { Component } from 'react'
-
+import Card from './Card'
 export class RecentActivityWidget extends Component {
     render() {
         return (
-            
+            
             Recent Activity
             
             
@@ -22,7 +22,7 @@ export class RecentActivityWidget extends Component {
                     
                 
             
-        
-                    {children}
-                
-                
+                
+                
+                    {this.props.children}
+                
+                
             >
         )
     }
 }
 
-export default AdminUI
+export default withTheme(AdminUI)
diff --git a/web/src/views/AdminUI.sass b/web/src/views/AdminUI.sass
deleted file mode 100644
index adbc495..0000000
--- a/web/src/views/AdminUI.sass
+++ /dev/null
@@ -1,275 +0,0 @@
-$color1: #1F1E2E
-$color2: #27283A
-$color3: #438AF4
-$color4: rgba(2,0,36,0.7455182756696428)
-$color5: #490428c6
-$color6: #ddd9ebbf
-*
-    box-sizing: border-box
-html, body
-    margin: 0
-#root
-    min-height: 100vh
-    display: grid
-    grid-template-columns: auto 1fr auto
-    grid-template-rows: auto 1fr 2em
-    grid-template-areas: "header header header" " menu main ." "footer footer footer"
-    background: $color2
-    overflow: auto
-
-#header
-    position: relative
-    grid-area: header
-    display: inline-flex
-    flex-wrap: wrap
-    flex-direction: row
-    min-height: auto
-    padding: .5em
-    justify-content: flex-end
-    align-items: center
-    background: $color1
-    color: $color6
-
-    h1
-        flex-wrap: nowrap
-        white-space: nowrap
-        display: inline-flex
-        font-size: 1.5em
-    &::after
-        justify-self: start
-        position: absolute
-        display: block
-        content: ''
-        left: 0
-        right: 0
-        top: 100%
-        background: $color3
-        height: .1em
-
-    &__search
-
-        margin: .5em
-        border-radius: .5rem
-        display: inline-flex
-        white-space: nowrap
-        margin-left: auto
-        transition: ease-in-out all 500ms
-        flex-grow: 0
-        max-width: 20em 
-        &:hover 
-            box-shadow: 0 0 1em $color3
-            flex-grow: 1
-            &__input
-                flex-grow: 1
-        &__input
-            height: 2rem
-            transition: ease all 500ms
-            border-radius: .5rem 0 0 .5rem
-            display: inline-flex
-            background: $color3
-            border: none
-            outline: none
-            color: $color6
-            flex-grow: 0
-            margin-left: auto
-            width: 100%
-            box-shadow: 0 0 .2em $color5
-            padding: .5em
-            &:hover, &:not(:placeholder-shown)
-                transition: ease all 500ms
-                flex-grow: 1
-            + button
-                height: 2rem
-                border: none
-                color: $color6
-                border-radius: 0 .5rem .5rem 0
-                display: inline-flex
-                align-items: center
-                background: $color2
-                font-size: 1em
-                border: .1rem inset $color3
-                border-style: solid
-                padding: .5em
-                &:hover
-                    background: $color6
-                    color: $color3
-    &__menu
-        display: inline-flex
-        flex-wrap: nowrap
-        flex-shrink: 1
-        ul
-            list-style: none
-            padding: 0
-            li
-                display: inline
-                a
-                    text-decoration: none
-                    color: $color6
-                    padding: .5em
-                    white-space: nowrap
-                    &:hover
-                        color: $color3
-#menu
-    grid-area: menu
-    display: flex
-    min-height: 100
-    flex-direction: column
-    align-items: center
-    background: $color1
-    padding: .5em 0
-    overflow: visible
-    h3
-        margin: 0
-        color: $color6
-        text-decoration: bold
-    ul
-        list-style: none
-        padding-left: 0
-        margin: .4em 0
-        a
-            position: relative
-            display: block
-            text-decoration: none
-            margin-left: .4em
-            color: $color6
-            //margin: .5em 0
-            padding: .3em .5em
-            font-size: 1.05em
-            transition: ease all 500ms
-            &::after
-                transition: ease all 500ms
-                position: absolute
-                top: 0
-                bottom: 0
-                right: 100%
-                width: 0em
-                content: ''
-                background: $color6
-            &:hover
-                background: $color3
-                &::after
-                    width: 0.4em
-            &.menu__active
-                color: $color3
-                &::after
-                    width: 0.4em
-                    background: $color2
-                &:hover
-                    color: #fff
-
-                    &::after
-                        width: 0.4em
-                        background: $color6
-
-#main
-    position: relative
-    grid-area: main
-    display: flex
-    align-content: flex-start
-    align-items: flex-start
-    flex-wrap: wrap
-    padding: 1em
-    border-top-left-radius: 1em
-.main
-    &__card
-        flex-grow: 1
-        color: $color6
-        background: $color1
-        border-radius: 1em
-        padding: 1em
-        margin: 1em
-        h4
-            margin: 0
-        &__input
-            padding: 1em .2em .1em 0.2em
-            display: inline-block
-            flex-grow: 1
-            with: auto
-            z-index: 1
-            border: none
-            background: none
-            outline: none
-            font-size: 1em
-            &__box
-                font-size: 1.1em
-                overflow: hidden
-                position: relative
-                margin: 0.2em 0
-                display: flex
-                flex-direction: row
-                align-items: stretch
-                background: $color6
-                border-bottom: .3em solid $color5
-                &:hover
-                    border-bottom: .3em solid $color3
-                    outline: auto
-                >button
-                    position: relative
-                    background: $color2
-                    color: $color6
-                    border: none
-                    font-size: 0.8em
-                    font-weight: bold
-                    padding: 0 .5em
-                    transition: ease all 300ms
-                    z-index: 1
-                    &::before
-                        position: absolute
-                        display: block
-                        content: ''
-                        clip-path: polygon(0% 0%, 100% 100%, 0% 100%)
-                        transform: translateX(-90%) rotate(45deg)
-                        height: 1em
-                        width: 1em
-                        background: $color2
-                        transition: ease all 300ms
-                    &:hover
-                        background: $color3
-                        &::before
-                            background: $color3
-                            transform: translateX(-90%) rotate(45deg) scale(1.2)
-
-            &__label
-                padding: 0
-                color: $color2
-                z-index: 0
-                position: absolute
-                left: 0.2em
-                padding-bottom: 0.2em
-                bottom: 0
-                transition: all ease-in-out 350ms
-            &:focus + &__label, &:not(:placeholder-shown) + &__label
-                color: $color5
-                font-size: 0.7em
-                transform: translateY(0)
-                bottom: 50%
-                font-weight: bold
-#footer
-    position: relative
-    grid-area: footer
-    display: flex
-    justify-content: center
-    align-items: center
-    color: #ffffff67
-    text-transform: uppercase
-    &::after
-        position: absolute
-
-        left: 0
-        right: 0
-        bottom: 0
-        height: 2em
-        widht: 100vw
-        opacity: 0.5
-        background: #000
-        background: linear-gradient(90deg, $color2 0%, $color3% 25%, $color5 50%, $color4 65%, $color1 100%)
-        content: ''
-    &::before
-        position: absolute
-        left: 0
-        right: 0
-        bottom: 100%
-        height: .2em
-        opacity: 0.5
-        content: ''
-        background: linear-gradient($color2,$color3)