/* TYX UI Core */


/*

Style modifications
1) Typography
2) Background
3) Buttons
4) Cards
5) Tables
6) Dropdown-menu
7) Nav pills
8) Datatables
9) Hide navbar dropdown indicators
10) Alerts
11) Collapse buttons
12) List groups

Custom additions
1) Navbar-collage open/close annimation
2) Table-responsive max/min widths
3) Affix/sticky positioning
4) Character limits
5) Buttons
6) Timeline

*/


/* Style modifications */

/* Border Radius */

.rounded {
    border-radius: 8px !important;
}

/* Typography */

.text-exo2-regular {
    font-family: "Exo 2",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";
    font-weight: 500;
}

.text-exo2-bold {
    font-family: "Exo 2",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";
    font-weight: 700;
}

h1, .h1, h2, .h2, h3, .h3, h4, .h4, h5, .h5, h6, .h6, .navbar-brand {
    font-family: "Exo 2",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";
    font-weight: 500;
}

div.modal-header > h5, .h5, h6, .h6 {
    font-family: -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";
    font-weight: 500;
}

a {
    color: #0E76BC;
}

strong {
    font-weight: 500;
}

.text-primary {
    color: #0E76BC !important;
}

.text-primary-alt {
    color: #002753 !important;
}

.text-secondary {
    color: #6c757d !important;
}

.text-success {
    color: #28A745 !important;
}

.text-info {
    color: #17A2B8 !important;
}

.text-warning {
    color: #FFC107 !important;
}

.text-danger {
    color: #dc3545 !important;
}

.text-light {
    color: #f8f9fa !important;
}

.text-dark {
    color: #343a40 !important;
}

.text-transparent {
    color: transparent;
}

.text-transnetyx {
    color: #0E76BC !important;
}

.text-colony {
    color: #41BEAB !important;
}

.text-automatedgenotyping {
    color: #0E76BC !important;
}

.text-geneticmonitoring {
    color: #5C2D91 !important;
}

.text-tagcenter {
    color: #8DD32F !important;
}

.text-microbiome {
    color: #ED705D !important;
}

/* Background */

.bg-primary {
    background-color: #0E76BC !important;
}

.bg-primary-alt {
    background-color: #002753 !important;
}

.bg-secondary {
    background-color: #6c757d !important;
}

.bg-success {
    background-color: #28A745 !important;
}

.bg-info {
    background-color: #17A2B8 !important;
}

.bg-warning {
    background-color: #FFC107 !important;
}

.bg-danger {
    background-color: #dc3545 !important;
}

.bg-light {
    background-color: #f8f9fa !important;
}

.bg-dark {
    background-color: #343a40 !important;
}

.bg-black {
    background-color: #000 !important;
    color: #fff !important;
    border: none;
}

.bg-transparent {
    background-color: transparent !important;
}

.bg-transnetyx {
    background-color: #0E76BC !important;
}

.bg-colony {
    background-color: #41BEAB !important;
}

.bg-automatedgenotyping {
    background-color: #0E76BC !important;
}

.bg-geneticmonitoring {
    background-color: #5C2D91 !important;
}

.bg-tagcenter {
    background-color: #8DD32F !important;
}

.bg-microbiome {
    background-color: #ED705D !important;
}

/* Buttons */

.btn {
    transition: color .2s ease-in-out,background-color .2s ease-in-out,border-color .2s ease-in-out,box-shadow .2s ease-in-out;
    border: 1px solid rgba(0,0,0,.1);
}

    .btn.btn-pill {
        border-radius: 20em;
    }

.btn-primary {
    color: #fff !important;
    background-color: #0E76BC !important;
}

    .btn-primary:hover {
        background-color: #0b66a3 !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

    .btn-primary.disabled, .btn-primary:disabled {
        border-color: #0b66a3;
    }

.btn-outline-primary {
    color: #0E76BC !important;
    background-color: transparent !important;
    border: 1px solid #0E76BC !important;
}

    .btn-outline-primary:hover {
        color: #fff !important;
        background-color: #0E76BC !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-primary-alt {
    background-color: #002753 !important;
    color: #fff !important;
}

    .btn-primary-alt:hover {
        background-color: #011e3f !important;
    }

.btn-outline-primary-alt {
    color: #002753 !important;
    background-color: transparent !important;
    border: 1px solid #002753 !important;
}

    .btn-outline-primary-alt:hover {
        color: #fff !important;
        background-color: #002753 !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-secondary {
    background-color: #6c757d !important;
    color: #fff !important;
}

    .btn-secondary:hover {
        background-color: #5a6269 !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-outline-secondary {
    color: #5a6269 !important;
    background-color: transparent !important;
    border: 1px solid #5a6269 !important;
}

    .btn-outline-secondary:hover {
        color: #fff !important;
        background-color: #5a6269 !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-success {
    background-color: #28A745 !important;
    color: #fff !important;
}

    .btn-success:hover {
        background-color: #23953e !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-outline-success {
    color: #28A745 !important;
    background-color: transparent !important;
    border: 1px solid #28A745 !important;
}

    .btn-outline-success:hover {
        color: #fff !important;
        background-color: #28A745 !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-info {
    background-color: #17A2B8 !important;
    color: #fff !important;
}

    .btn-info:hover {
        background-color: #148c9e !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-outline-info {
    color: #17A2B8 !important;
    background-color: transparent !important;
    border: 1px solid #17A2B8 !important;
}

    .btn-outline-info:hover {
        color: #fff !important;
        background-color: #17A2B8 !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-warning {
    background-color: #FFC107 !important;
    color: #2c2c2c !important;
}

    .btn-warning:hover {
        background-color: #ebb206 !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-outline-warning {
    color: #FFC107 !important;
    background-color: transparent !important;
    border: 1px solid #FFC107 !important;
}

    .btn-outline-warning:hover {
        color: #2c2c2c !important;
        background-color: #FFC107 !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-danger {
    background-color: #dc3545 !important;
    color: #fff !important;
}

    .btn-danger:hover {
        background-color: #c02d3c !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-outline-danger {
    color: #dc3545 !important;
    background-color: transparent !important;
    border: 1px solid #dc3545 !important;
}

    .btn-outline-danger:hover {
        color: #fff !important;
        background-color: #dc3545 !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-white {
    background-color: #ffffff !important;
    color: #000 !important;
}

    .btn-white:hover {
        background-color: #fafafa !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-outline-white {
    color: #fff !important;
    background-color: transparent !important;
    border: 1px solid #fff !important;
}

    .btn-outline-white:hover {
        color: #000 !important;
        background-color: #fff !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-light:hover {
    box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
}

.btn-outline-light {
    color: #f8f9fa !important;
    background-color: transparent !important;
    border: 1px solid #f8f9fa !important;
}

    .btn-outline-light:hover {
        color: #000 !important;
        background-color: #f8f9fa !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-outline-dark {
    color: #343a40 !important;
    background-color: transparent !important;
    border: 1px solid #343a40 !important;
}

    .btn-outline-dark:hover {
        color: #fff !important;
        background-color: #343a40 !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-black {
    background-color: #000 !important;
    color: #fff !important;
}

    .btn-black:hover {
        background-color: #2c2c2c !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-outline-black {
    color: #000 !important;
    background-color: transparent !important;
    border: 1px solid #000 !important;
}

    .btn-outline-black:hover {
        color: #fff !important;
        background-color: #000 !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-transparent {
    background-color: transparent !important;
}

    .btn-transparent:hover {
        background-color: #0000000a !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-transnetyx {
    background-color: #0E76BC !important;
    color: #fff !important;
}

    .btn-transnetyx:hover {
        background-color: #0b66a3 !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-outline-transnetyx {
    color: #0E76BC !important;
    background-color: transparent !important;
    border: 1px solid #0E76BC !important;
}

    .btn-outline-transnetyx:hover {
        color: #fff !important;
        background-color: #0E76BC !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-colony {
    background-color: #41BEAB !important;
    color: #fff !important;
}

    .btn-colony:hover {
        background-color: #3bad9c !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-outline-colony {
    color: #41BEAB !important;
    background-color: transparent !important;
    border: 1px solid #41BEAB !important;
}

    .btn-outline-colony:hover {
        color: #fff !important;
        background-color: #41BEAB !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-automatedgenotyping {
    background-color: #0e76bc !important;
    color: #fff !important;
}

    .btn-automatedgenotyping:hover {
        background-color: #0b66a3 !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-outline-automatedgenotyping {
    color: #0E76BC !important;
    background-color: transparent !important;
    border: 1px solid #0E76BC !important;
}

    .btn-outline-automatedgenotyping:hover {
        color: #fff !important;
        background-color: #0E76BC !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-geneticmonitoring {
    background-color: #5C2D91 !important;
    color: #fff !important;
}

    .btn-geneticmonitoring:hover {
        background-color: #4c2579 !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-outline-geneticmonitoring {
    color: #5C2D91 !important;
    background-color: transparent !important;
    border: 1px solid #5C2D91 !important;
}

    .btn-outline-geneticmonitoring:hover {
        color: #fff !important;
        background-color: #5C2D91 !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-tagcenter {
    background-color: #8DD32F !important;
    color: #fff !important;
}

    .btn-tagcenter:hover {
        background-color: #7dbe28 !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-outline-tagcenter {
    color: #8DD32F !important;
    background-color: transparent !important;
    border: 1px solid #8DD32F !important;
}

    .btn-outline-tagcenter:hover {
        color: #fff !important;
        background-color: #8DD32F !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-microbiome {
    background-color: #ED705D !important;
    color: #fff !important;
}

    .btn-microbiome:hover {
        background-color: #d46351 !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

.btn-outline-microbiome {
    color: #ED705D !important;
    background-color: transparent !important;
    border: 1px solid #ED705D !important;
}

    .btn-outline-microbiome:hover {
        color: #fff !important;
        background-color: #ED705D !important;
        box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
    }

/* Badges */

.badge {
    font-weight: 300;
}

.badge-primary {
    background-color: #0E76BC !important;
    color: #fff !important;
}

.badge-primary-alt {
    background-color: #002753 !important;
    color: #fff !important;
}

.badge-secondary {
    background-color: #6c757d !important;
    color: #fff !important;
}

.badge-success {
    background-color: #28A745 !important;
    color: #fff !important;
}

.badge-info {
    background-color: #17A2B8 !important;
    color: #fff !important;
}

.badge-warning {
    background-color: #FFC107 !important;
    color: #000 !important;
}

.badge-danger {
    background-color: #dc3545 !important;
    color: #fff !important;
}

.badge-light {
    background-color: #f8f9fa !important;
    color: #000 !important;
}

.badge-dark {
    background-color: #343a40 !important;
    color: #fff !important;
}

.badge-black {
    background-color: #000 !important;
    color: #fff !important;
    border: none;
}

.badge-white {
    background-color: #fff !important;
    color: #000 !important;
    border: none;
}

.badge-transparent {
    background-color: transparent !important;
}

.badge-automatedgenotyping {
    background-color: #0E76BC !important;
    color: #fff !important;
}

.badge-geneticmonitoring {
    background-color: #5C2D91 !important;
    color: #fff !important;
}

.badge-microbiome {
    background-color: #ED705D !important;
    color: #fff !important;
}

.badge-tagcenter {
    background-color: #8DD32F !important;
    color: #fff !important;
}

/* Cards */

.card {
    border-radius: .5em;
}

.card-header {
    font-size: 1rem;
    font-weight: 500;
    background-color: transparent !important;
}

    .card-header:first-child {
        border-radius: .5em .5rem 0 0;
    }

.card-footer {
    background-color: transparent;
}

.card .table td, .table th {
    padding: .75rem 1.25rem;
}

.card-img-top {
    width: 100%;
    border-top-left-radius: calc(.5rem - 1px);
    border-top-right-radius: calc(.5rem - 1px);
}

/* Dropdown menus */

.dropdown-menu {
    box-shadow: 0 .125rem .25rem rgba(0,0,0,.1);
}

.dropdown-item {
    padding: .25rem .8rem !important;
}

/* Nav pills */

.nav-pills > .nav-item > .nav-link, .cart-link {
    box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
}

.nav-pills .nav-link.active, .nav-pills .show > .nav-link {
    color: #000;
    background: none;
    border: none;
    box-shadow: none !important;
}

.nav-pills .nav-link {
    border-radius: .25rem;
    background: #fff;
    border: 1px solid rgba(0,0,0,.125);
    color: #000;
    margin: .5rem .5rem;
}





/* Data tables */

table.dataTable.no-footer {
    border-bottom: 1px solid rgba(0,0,0,.125);
}

table.dataTable thead th, table.dataTable thead td {
    border-bottom: 1px solid rgba(0,0,0,.125);
}

.lengthMenuLabel {
    float: left !important;
    margin: 1rem;
}

.paginationLabel {
    float: right !important;
    margin: 1rem;
}

table.dataTable {
    margin-top: 0px !important;
}

table.dataTable thead th {
    border-top: none !important;
}

/* Hide navbar dropdown indicator */

#mainNav .navbar-collapse .navbar-nav > .nav-item.dropdown.hidden > .nav-link:after {
    display: none;
}

.card-columns {
    @include media-breakpoint-only(lg) {
        column-count: 4;
    }

    @include media-breakpoint-only(xl) {
        column-count: 5;
    }
}

/* Alerts */

.alert {
    border-radius: .5rem;
    background-color: #fff;
    color: inherit;
    border: 1px solid rgba(0,0,0,.125);
}

.alert-dismissible {
    box-shadow: 0 .125rem .25rem rgba(0,0,0,.075) !important;
}

.alert-primary {
    border-left: 10px solid #0E76BC;
}

.alert-primary-alt {
    border-left: 10px solid #002753;
}

.alert-secondary {
    border-left: 10px solid #6c757d;
}

.alert-success {
    border-left: 10px solid #28A745;
}

.alert-info {
    border-left: 10px solid #17A2B8;
}

.alert-warning {
    border-left: 10px solid #FFC107;
}

.alert-danger {
    border-left: 10px solid #dc3545;
}

.alert-light {
    border-left: 10px solid #f8f9fa;
}

.alert-dark {
    border-left: 10px solid #343a40;
}

.alert-transnetyx {
    border-left: 10px solid #0E76BC;
}

.alert-colony {
    border-left: 10px solid #41BEAB;
}

.alert-automatedgenotyping {
    border-left: 10px solid #0E76BC;
}

.alert-geneticmonitoring {
    border-left: 10px solid #5C2D91;
}

.alert-tagcenter {
    border-left: 10px solid #8DD32F;
}

.alert-microbiome {
    border-left: 10px solid #ED705D;
}

/* Collapse */

[data-toggle="collapse"].collapsed .fa:before {
    content: "\f078";
    font-weight: 500;
}

[data-toggle="collapse"] .fa:before {
    content: "\f077";
    font-weight: 500;
}

/* List groups */

.list-group {
    border-radius: .5rem;
}

.list-group-item:first-child {
    border-top-left-radius: .5rem;
    border-top-right-radius: .5rem;
}

.list-group-item:last-child {
    border-bottom-left-radius: .5rem;
    border-bottom-right-radius: .5rem;
}

.card > .list-group:last-child .list-group-item:last-child {
    border-bottom-left-radius: .5rem;
    border-bottom-right-radius: .5rem;
}

.list-group-item-info.list-group-item-action:focus, .list-group-item-info.list-group-item-action {
    color: #fff !important;
    background-color: #17A2B8 !important;
}

    .list-group-item-info.list-group-item-action:focus, .list-group-item-info.list-group-item-action:hover {
        color: #fff !important;
        background-color: #148c9e !important;
    }

/* Custom additions */

/* Navbar-collapse open/close animation */

.icon-bar {
    width: 22px;
    height: 2px;
    background-color: rgba(0, 0, 0, 0.5);
    display: block;
    transition: all 0.2s;
    margin-top: 4px
}

.navbar-toggler {
    border: none;
    background: transparent !important;
}

    .navbar-toggler .top-bar {
        transform: rotate(45deg);
        transform-origin: 10% 10%;
    }

    .navbar-toggler .middle-bar {
        opacity: 0;
    }

    .navbar-toggler .bottom-bar {
        transform: rotate(-45deg);
        transform-origin: 10% 90%;
    }

    .navbar-toggler.collapsed .top-bar {
        transform: rotate(0);
    }

    .navbar-toggler.collapsed .middle-bar {
        opacity: 1;
    }

    .navbar-toggler.collapsed .bottom-bar {
        transform: rotate(0);
    }

/* Table-responsive max/min widths */

.td-xs {
    max-width: 1rem;
}

.td-sm {
    min-width: 3rem;
}

.td-md {
    min-width: 5rem;
}

.td-lg {
    min-width: 7rem;
}

.td-xl {
    min-width: 10rem;
}

.th-xs {
    max-width: 1rem;
}

.th-sm {
    min-width: 4rem;
}

.th-md {
    min-width: 6rem;
}

.th-lg {
    min-width: 8rem;
}

.th-xl {
    min-width: 10rem;
}

th {
    font-weight: 500;
}

@media (max-width: 1365px) {
    .top-scrollbar-container {
        width: 100%;
        overflow-x: scroll;
        overflow-y: hidden;
    }

    .top-scrollbar {
        height: 1px;
    }
}

/* Affix */

/* 

Important info:
- Object must be inside a container
- Adjust exact line positioning with in-line styling

*/

.affix {
    position: sticky;
}

@media (min-width: 576px) {
    .affix-sm {
        position: sticky;
    }
}

@media (min-width: 768px) {
    .affix-md {
        position: sticky;
    }
}

@media (min-width: 992px) {
    .affix-lg {
        position: sticky;
    }
}

@media (min-width: 1200px) {
    .affix-xl {
        position: sticky;
    }
}

/* Tables */

/* For highlighted table rows */

tr.text-light > td > a {
    color: white;
    text-decoration: underline dotted white;
}

    tr.text-light > td > a:hover {
        color: white;
        text-decoration: underline white;
    }

.table.align-middle td, .table.align-middle th {
    vertical-align: middle;
}

.page-link {
    color: #0E76BC;
}

/* Progress */

.progress {
    height: 3px;
}

/* Forms */

.col-form-label {
    font-size: .7em;
    text-transform: uppercase;
    font-weight: 600;
    padding-top: calc(.6rem + 1px);
    padding-bottom: calc(.6rem + 1px);
}

label {
    display: inline-block;
    margin-bottom: .5rem;
    text-transform: uppercase !important;
    font-size: .7em !important;
}

    label.form-check-label {
        display: inline-block;
        margin-bottom: .5rem;
        text-transform: none !important;
        font-size: inherit !important;
    }

/* Character limits */

.char-limit-auto {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}

/* Buttons */

@media (max-width: 767px) {
    .btn-xs-block {
        display: block;
        width: 100%;
    }

    input[type="submit"].btn-xs-block,
    input[type="reset"].btn-xs-block,
    input[type="button"].btn-xs-block {
        width: 100%;
    }

    .btn-block + .btn-xs-block,
    .btn-xs-block + .btn-block,
    .btn-xs-block + .btn-xs-block {
        margin-top: 0.5rem;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .btn-sm-block {
        display: block;
        width: 100%;
    }

    input[type="submit"].btn-sm-block,
    input[type="reset"].btn-sm-block,
    input[type="button"].btn-sm-block {
        width: 100%;
    }

    .btn-block + .btn-sm-block,
    .btn-sm-block + .btn-block,
    .btn-sm-block + .btn-sm-block {
        margin-top: 0.5rem;
    }
}

@media (min-width: 992px) and (max-width: 1199px) {
    .btn-md-block {
        display: block;
        width: 100%;
    }

    input[type="submit"].btn-md-block,
    input[type="reset"].btn-md-block,
    input[type="button"].btn-md-block {
        width: 100%;
    }

    .btn-block + .btn-md-block,
    .btn-md-block + .btn-block,
    .btn-md-block + .btn-md-block {
        margin-top: 0.5rem;
    }
}

@media (min-width: 1200px) {
    .btn-lg-block {
        display: block;
        width: 100%;
    }

    input[type="submit"].btn-lg-block,
    input[type="reset"].btn-lg-block,
    input[type="button"].btn-lg-block {
        width: 100%;
    }

    .btn-block + .btn-lg-block,
    .btn-lg-block + .btn-block,
    .btn-lg-block + .btn-lg-block {
        margin-top: 0.5rem;
    }
}

/* Timeline */

ul.timeline {
    list-style-type: none;
    position: relative;
}

    ul.timeline:before {
        content: ' ';
        background: #d4d9df;
        display: inline-block;
        position: absolute;
        left: 19px;
        width: 1px;
        height: 100%;
        z-index: 400;
    }

    ul.timeline > li {
        margin: 20px 0 20px 20px;
        border-bottom: 1px solid rgba(0,0,0,.05);
    }

        ul.timeline > li:nth-last-child(1) {
            padding-bottom: 20px;
            border-bottom: none;
            margin-bottom: 0;
        }

        ul.timeline > li.milestone.incomplete:before {
            font-family: "Font Awesome 5 Pro";
            content: "\f111";
            font-weight: 500;
            color: #d4d9df;
            font-size: 1.25rem;
            background: #fff;
            display: inline-block;
            position: absolute;
            left: 10px;
            z-index: 400;
        }

        ul.timeline > li.milestone.complete:before {
            font-family: "Font Awesome 5 Pro";
            content: "\f058";
            font-weight: 900;
            color: #28A745;
            font-size: 1.25rem;
            background: #fff;
            display: inline-block;
            position: absolute;
            left: 10px;
            z-index: 400;
        }

div.card.task {
    padding: .75rem 1rem .75rem 3.75rem;
    margin-bottom: 1rem
}

    div.card.task:before {
        font-family: "Font Awesome 5 Pro";
        content: "\f111";
        font-weight: 500;
        color: #d4d9df;
        font-size: 1.25rem;
        background: #fff;
        display: inline-block;
        position: absolute;
        left: 20px;
        z-index: 400;
    }

    div.card.task > hr {
        margin: .75rem 0 .75rem 0;
    }

p.task-title {
    margin-bottom: .35rem;
}

p.task-info {
    margin-bottom: .35rem;
    color: #6c757d;
}

a.task-info {
    margin-bottom: .75rem;
}

div.subtask > hr {
    margin: .75rem 0 .75rem 0;
}

div.card.subtask {
    padding: .75rem 1rem .75rem 3.75rem;
    margin-bottom: .25rem
}

p.subtask-title {
    margin-bottom: .35rem;
}

    p.subtask-title:before {
        font-family: "Font Awesome 5 Pro";
        content: "\f111";
        font-weight: 500;
        color: #d4d9df;
        font-size: 1.25rem;
        background: #fff;
        display: inline-block;
        position: absolute;
        left: 20px;
        z-index: 400;
    }
