diff --git a/src/css/calendar.css b/src/css/calendar.css
new file mode 100644
index 0000000..a6d979b
--- /dev/null
+++ b/src/css/calendar.css
@@ -0,0 +1,47 @@
+.calendar {
+  margin: 10px auto 40px auto;
+  border-collapse: collapse;
+}
+
+.calendar td {
+  padding: 8px;
+  min-width: 75px;
+}
+
+.calendar .day {
+  border: solid 1px black;
+}
+
+.calendar .day .date {
+  font-weight: bold;
+}
+
+select {
+  border-radius: 3px;
+}
+
+select[data-value="0"] {
+  background: #FF1744;
+  color: white;
+}
+
+select[data-value="1"] {
+  background: #00E5FF;
+  color: black;
+}
+
+select[data-value="2"] {
+  background: #00E676;
+  color: black;
+}
+
+select option {
+  background: white;
+  color: black;
+}
+
+.month {
+  font-weight: light;
+  font-size: 18px;
+  text-align: center;
+}
diff --git a/src/css/dashboard.css b/src/css/dashboard.css
new file mode 100644
index 0000000..7bec14f
--- /dev/null
+++ b/src/css/dashboard.css
@@ -0,0 +1,320 @@
+:root {
+  --material-green: rgb(76,175,80);
+}
+
+body {
+  font-family: "Roboto", "Helvetica", "Arial", sans-serif;
+}
+
+.main {
+  position: relative;
+  display: block;
+  width: Calc(100% - 64px);
+  max-width: 1024px;
+  margin: 20px auto;
+  padding: 16px 16px 32px 16px;
+  border-radius: 2px;
+  background: #FFFFFF;
+}
+
+.main.withfab {
+  padding: 16px 16px 64px 16px!important;
+}
+
+.delete, .icon {
+  color: black!important;
+  vertical-align: middle;
+}
+
+.icon-no-black {
+  vertical-align: middle;
+}
+
+a.backbtn {
+  text-decoration: none;
+  color: #424242;
+}
+
+a.backbtn .material-icons {
+  vertical-align: middle;
+}
+
+.mdl-tabs__panel {
+  padding-top: 16px;
+}
+
+.mdl-navigation__link span {
+  vertical-align: middle;
+}
+
+dynscript {
+  display: none;
+}
+
+details.debug summary {
+  color: rgb(255, 64, 129);
+  font-size: 12px;
+  cursor: pointer;
+}
+
+.overflow-wrapper {
+  max-width: 100%;
+  overflow-x: auto;
+  -webkit-overflow-scrolling: touch;
+}
+
+.overflow-wrapper.overflow-wrapper--for-table {
+  padding: 4px;
+  margin: -4px;
+}
+
+details.debug pre {
+  margin: 0;
+  max-width: 100%;
+  overflow: auto;
+}
+
+.margintop {
+  margin-top: 16px;
+}
+
+i.help {
+  vertical-align: middle;
+  cursor: help;
+}
+
+.mdl-data-table__cell--centered {
+  text-align: center!important;
+}
+
+.mdl-dialog .mdl-dialog__content, .copyto {
+  overflow-y: auto;
+  background: linear-gradient(white 30%, rgba(255, 255, 255, 0)), linear-gradient(rgba(255, 255, 255, 0), white 70%) 0 100%, radial-gradient(farthest-side at 50% 0, rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0)), radial-gradient(farthest-side at 50% 100%, rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0)) 0 100%;
+  background-repeat: no-repeat;
+  background-color: white;
+  background-size: 100% 40px, 100% 40px, 100% 14px, 100% 14px;
+  background-attachment: local, local, scroll, scroll;
+}
+
+.mdl-dialog .mdl-dialog__content {
+  max-height: Calc(100vh - 232px);
+}
+
+.copyto {
+  max-height: 300px;
+}
+
+.mdl-dialog .mdl-dialog__title {
+  margin-bottom: 4px; /* Otherwise sometimes the title is not entirely shown */
+}
+
+a.mdl-js-ripple-effect {
+  position: relative;
+}
+
+.always-focused {
+  font-size: 12px;
+  top: 4px;
+  visibility: visible;
+}
+
+.clicky-container {
+  text-decoration: none!important;
+  color: black!important;
+}
+
+.clicky {
+  position: relative;
+  display: block;
+  width: Calc(100% - 10px);
+  margin-bottom: 5px;
+  overflow-x: hidden;
+  overflow-y: hidden;
+  padding: 5px;
+  border-left: 4px solid #212121;
+}
+
+.clicky:hover {
+  background-color: #EEE;
+}
+
+.clicky .icon {
+  float: left;
+  margin-right: 8px;
+}
+
+.clicky .material-icons {
+  font-size: 40px;
+}
+
+.clicky .title {
+  font-weight: bold;
+}
+
+.clicky .description {
+  color: rgba(0, 0, 0, .54);
+  font-weight: 400;
+}
+
+main .actions {
+  margin: 16px 0 16px 16px;
+  float: right;
+}
+
+.mdl-menu a {
+  text-decoration: none;
+}
+
+.oneline {
+  overflow: hidden;
+  white-space: nowrap;
+  text-overflow: ellipsis;
+}
+
+.icon-text {
+  font-size: 14px!important;
+  vertical-align: middle;
+}
+
+.pagination {
+  margin: 16px 0;
+}
+
+.pagination .page {
+  padding: 0 4px;
+}
+
+.mdl-button .material-icons {
+  vertical-align: middle;
+}
+
+[data-dyndialog-href] {
+  cursor: pointer;
+}
+
+.mdl-dialog__actions .mdl-button.mdl-button--icon {
+  height: 32px!important;
+  margin-top: 2px;
+}
+
+
+.mdl-layout__drawer>span.mdl-layout-title {
+    line-height: 20px!important;
+    margin-top: 22px;
+}
+
+body.dark-background header, body.dark-background header .material-icons {
+  color: white!important;
+}
+
+.mdl-layout__drawer .logo {
+  max-height: 32px;
+}
+
+option:disabled {
+  color: graytext!important;
+}
+
+.subtitle {
+  display: inline-block;
+  padding-top: 8px;
+  padding-left: 40px;
+  padding-right: 40px;
+}
+
+.help-btn--top-right {
+  float: right;
+  margin: 16px 0;
+}
+
+.help-btn--top-right.help-btn--top-right-margin {
+  margin: 16px;
+}
+
+.mdl-button .material-icons, .mdl-button span {
+  vertical-align: middle;
+}
+
+/* Multiselect custom element stylings */
+.mdl-custom-multiselect__item {
+  line-height: normal;
+  height: auto;
+  padding: 0;
+}
+
+.mdl-custom-multiselect__item .mdl-checkbox {
+  height: auto;
+  padding: 4px 16px 4px 40px;
+}
+
+.mdl-custom-multiselect__item .mdl-checkbox__focus-helper, .mdl-custom-multiselect__item .mdl-checkbox__box-outline {
+  top: Calc(3px + 4px);
+  left: 16px;
+}
+
+.mdl-custom-multiselect__item {
+  line-height: normal;
+  height: auto;
+  padding: 0;
+}
+
+.mdl-custom-multiselect__item, .mdl-custom-multiselect__item .mdl-checkbox {
+  cursor: pointer!important;
+}
+
+.mdl-custom-selectfield__select {
+  user-select: none;
+}
+
+/* mdlext-selectfield color fix */
+.mdlext-selectfield__label::after {
+  background-color: var(--material-green);
+}
+
+.mdlext-selectfield.is-focused .mdlext-selectfield__label {
+  color: var(--material-green)!important;
+}
+
+/* Date-picker polyfill fixes */
+dialog {
+  z-index: 10;
+}
+
+/* Limit change */
+.limit-change-container {
+  margin: 4px 0;
+  padding: 4px 0 4px 8px;
+  border-left: 2px solid #212121;
+}
+
+/* Left actions above table */
+.left-actions {
+  position: sticky;
+  z-index: 10;
+  background: white;
+  top: 0;
+  padding: 8px 0;
+  border-top: 1px solid rgba(0,0,0,.12);
+  border-bottom: 1px solid rgba(0,0,0,.12);
+}
+
+.highlighted {
+  font-weight: 500;
+}
+
+@media (max-width: 700px) {
+  .main {
+    width: Calc(100% - 40px);
+  }
+}
+
+@media screen and (max-width: 1024px) {
+  .mdl-layout__drawer>span.mdl-layout-title {
+    margin-top: 18px;
+  }
+
+  .subtitle {
+    padding-left: 16px;
+    padding-right: 16px;
+  }
+}
diff --git a/src/css/incidents.css b/src/css/incidents.css
new file mode 100644
index 0000000..2104748
--- /dev/null
+++ b/src/css/incidents.css
@@ -0,0 +1,75 @@
+.incidents-wrapper {
+  display: inline-block;
+}
+
+.incidents-wrapper--scrollable {
+  max-height: 400px;
+  overflow-y: auto;
+}
+
+.incidents {
+  border: solid 1px rgba(0,0,0,.12);
+  border-collapse: collapse;
+  white-space: nowrap;
+}
+
+.incidents tr.artificial-height {
+  height: 32px;
+}
+
+.incidents tr:not(:last-child) {
+  border-bottom: solid 1px rgba(0,0,0,.24);
+}
+
+.incidents td, .incidents th {
+  padding: 1px 8px;
+}
+
+.incidents .centered {
+  text-align: center;
+}
+
+.incidents .icon-cell {
+  user-select: none;
+}
+
+.incidents .has-checkbox {
+  padding-left: 14px;
+  padding-right: 0;
+}
+
+.incidents .has-checkbox .mdl-checkbox__ripple-container {
+  height: 34px!important;
+  width: 34px!important;
+  top: -5px!important;
+  left: -9px!important;
+}
+
+.incidents .icon-cell .material-icons {
+  cursor: pointer;
+}
+
+.incidents .material-icons {
+  vertical-align: middle;
+}
+
+.incidents .verification-actions {
+  display: inline-block;
+}
+
+.incidents .more {
+  cursor: pointer;
+}
+
+.incidents-wrapper .mdl-menu__container {
+  top: 0;
+  right: 0;
+}
+
+.notvisible {
+  display: none;
+}
+
+.incidents tr.line-through td.can-strike {
+  text-decoration: line-through;
+}
diff --git a/src/css/index.css b/src/css/index.css
new file mode 100644
index 0000000..e6b4c36
--- /dev/null
+++ b/src/css/index.css
@@ -0,0 +1,13 @@
+.login {
+  display: block;
+  max-width: 400px;
+  margin: 20px auto;
+  padding: 16px;
+  border-radius: 2px;
+  background: #FFFFFF;
+}
+
+#about {
+  max-width: Calc(100% - 64px);
+  max-width: 700px;
+}
diff --git a/src/css/schedule.css b/src/css/schedule.css
new file mode 100644
index 0000000..d655252
--- /dev/null
+++ b/src/css/schedule.css
@@ -0,0 +1,130 @@
+.schedule {
+  display: inline-flex;
+  flex: none;
+  border: 1px solid rgba(0,0,0,.12);
+
+  --hour-height: 30px;
+}
+
+.schedule .sidetime {
+  padding-top: 36px;
+  width: 40px;
+}
+
+.schedule .sidetime .hour {
+  position: relative;
+  height: var(--hour-height);
+}
+
+.schedule .sidetime .hour .hour--text {
+  position: absolute;
+  top: -9px;
+  right: 7px;
+  font-size: 11px;
+}
+
+.schedule .day {
+  flex: 1 0 auto;
+  width: 100px;
+  min-width: 100px;
+}
+
+.schedule .day .day--header {
+  text-align: center;
+  box-sizing: content-box;
+  height: 20px;
+  font-size: 18px;
+  font-weight: 300;
+  padding: 8px 0;
+  border-bottom: solid 1px #ccc;
+}
+
+.schedule .day .day--content {
+  position: relative;
+}
+
+.schedule .day .day--content .hour {
+  height: Calc(var(--hour-height) - 1px);
+}
+
+.schedule .day .day--content .hour:not(:last-child) {
+  border-bottom: solid 1px #ddd;
+}
+
+.schedule .day .day--content .hour:last-child, .schedule .sidetime .hour:last-child {
+  height: 13px;
+}
+
+.schedule .day .day--content .work-event, .schedule .day .day--content .inline-event {
+  position: absolute;
+  border-radius: 3px;
+  overflow-y: auto;
+}
+
+.schedule .day .day--content .event--actions {
+  position: absolute;
+  top: 4px;
+  right: 4px;
+  line-height: 14px;
+  background: #00000077;
+  border-radius: 5px;
+  z-index: 2;
+}
+
+.schedule .day .day--content .event--actions .material-icons {
+  color: white;
+  font-size: 20px;
+}
+
+.schedule .day .day--content .event--header, .schedule .day .day--content .event--body {
+  text-align: left;
+  font-size: 11px;
+}
+
+.schedule .day .day--content .work-event {
+  left: 4px;
+  width: 92px;
+  background: #2E7D32;
+}
+
+.schedule .day .day--content .work-event .event--header, .schedule .day .day--content .work-event .event--body {
+  line-height: 14px;
+  color: white;
+}
+
+.schedule .day .day--content .work-event .event--header {
+  margin: 5px 5px 0 5px;
+  font-weight: bold;
+}
+
+.schedule .day .day--content .work-event .event--body {
+  margin: 0 5px;
+}
+
+.schedule .day .day--content .inline-event {
+  left: 3px;
+  width: 86px;
+  background: #81C784;
+}
+
+.schedule .day .day--content .inline-event .event--header {
+  font-weight: 500;
+}
+
+.schedule .day .day--content .inline-event .event--header, .schedule .day .day--content .inline-event .event--body {
+  line-height: 14px;
+  margin: 0 5px;
+  color: black;
+}
+
+@media (hover: hover) {
+  .schedule .day .day--content .event--actions {
+    opacity: 0;
+    transition: opacity 0.15s ease-in;
+    background: #00000099;
+  }
+
+  .schedule .day .day--content .work-event:hover .event--actions {
+    opacity: 1;
+  }
+}
