body {
    height: 100%;
    background-color: #333;
    color: #ccc;
}

body::-webkit-scrollbar {
    width: 20px
}

body::-webkit-scrollbar-track {
    background: #1f1f1f
}

body::-webkit-scrollbar-thumb {
    background-color: #2d2d2d
}

h3 {
    font-size: 1.4em;
    margin-bottom: 0;
}


/* Timeline styles based on https://bootsnipp.com/snippets/featured/timeline-responsive */

.timeline {
    list-style: none;
    padding: 20px 0 20px;
    position: relative;
}

.timeline:before {
    top: 80px;
    border-radius: 4px;
    bottom: 0;
    position: absolute;
    content: " ";
    width: 8px;
    background-color: #666;
    left: 55%;
    margin-left: -1.5px;
}

.timeline>li {
    margin-bottom: 20px;
    position: relative;
}

.timeline>li:before,
.timeline>li:after {
    content: " ";
    display: table;
}

.timeline>li:after {
    clear: both;
}

.timeline>li:before,
.timeline>li:after {
    content: " ";
    display: table;
}

.timeline>li:after {
    clear: both;
}

.timeline>li>.timeline-panel {
    width: 48%;
    float: left;
    background-color: #444;
    border: 3px solid #ddd;
    color: #eee;
    border-radius: 12px;
    padding: 20px;
    position: relative;
    -webkit-box-shadow: 0 1px 6px rgba(0, 0, 0, 0.175);
    box-shadow: 0 1px 6px rgba(0, 0, 0, 0.175);
    line-break: anywhere;
}

.timeline>li>.timeline-panel:before {
    position: absolute;
    top: 26px;
    right: -15px;
    display: inline-block;
    border-top: 15px solid transparent;
    border-left: 15px solid #ccc;
    border-right: 0 solid #ccc;
    border-bottom: 15px solid transparent;
    content: " ";
}

.timeline>li>.timeline-panel:after {
    position: absolute;
    top: 27px;
    right: -14px;
    display: inline-block;
    border-top: 14px solid transparent;
    border-left: 14px solid #ccc;
    border-right: 0 solid #ccc;
    border-bottom: 14px solid transparent;
    /* content: " "; */
}

.timeline>li>.timeline-badge {
    color: #ccc;
    width: 128px;
    height: 128px;
    line-height: 96px;
    font-size: 1.4em;
    text-align: center;
    position: absolute;
    /* top: 10px; */
    left: 50%;
    /* margin-left: -25px; */
    z-index: 100;
}

.timeline>li>.first {
    background-color: rgb(49, 125, 13);
}

.timeline>li>.round {
    background-color: rgb(86, 9, 85);
}

.timeline>li>.round:before {
    visibility: collapse;
}

.timeline-badge .btn-group {
    display: flex;
    flex-direction: column;
}

.timeline-badge .btn {
    border-radius: 50%;
}


/* Custom icons */

.icon {
    background-color: #444;
    background-size: cover;
    border-radius: 20%;
    border: 3px solid #ccc;
    box-shadow: inset -2px -2px rgba(0, 0, 0, .5);
    margin: auto;
    overflow: hidden;
    position: relative;
    width: 100%;
    height: 100%;
}


/* Table styles */

.table {
    color: #ccc;
    margin-top: 20px;
}

/* @media all and (max-width: 479px) {
    .table {
        visibility: collapse;
    }
} */

.table thead {
    background-color: #444;
    color: #eee;
}

.table td,
.table th {
    vertical-align: middle;
}


/* Custom styles */

.strikethrough {
    text-decoration: line-through;
    opacity: 0.5;
}

.top-btn {
    width: 250px;
    height: 48px;
    font-size: 150%;
}

.btn-addChar {
    padding: 2px;
    margin: 2px;
}

.btn-addChar > img {
    width: 128px;
    height: 128px;
    border-radius: 20%;
    box-shadow: inset -2px -2px rgba(0, 0, 0, .5);
}

#btn-add {
    margin: 2px 0px;
    padding: 0px 12px;
    height: 48px;
    font-size: 150%;
}

#newCharButtons {
    margin-left: -2px;
}

#btn-round {
    opacity: 1;
}