body {
    background: #15191A;
    background-repeat: repeat;
    color: white;
    padding-top: 30px;
}

#metadata>.col {
    margin-top: 0px !important;
}

.percentage-div {
    position: relative;
}

.overlay {
    position: absolute;
    z-index: 2;
    width: 100%;
    text-align: center;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    vertical-align: middle;
}

h3 {
    text-align: center;
    word-wrap: break-word;
}

.grid-overview {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    align-items: stretch;
    margin-bottom: 50px;
}

@media (max-width: 1200px) {
    .grid-overview {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 600px) {
    .grid-overview {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 400px) {
    .grid-overview {
        grid-template-columns: repeat(1, 1fr);
    }
}

.row,
.exam {
    background: #1D2224;
    -webkit-box-shadow: 10px 10px 25px 1px rgba(0, 0, 0, 0.75);
    -moz-box-shadow: 10px 10px 25px 1px rgba(0, 0, 0, 0.75);
    box-shadow: 10px 10px 25px 1px rgba(0, 0, 0, 0.75);
}

.col {
    margin: 50px 0px;
}

.categories {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}

.category {
    margin: 0px 10px;
}

.colorbox {
    height: 10px;
    width: 40px;
    margin: 0px auto;
}

.semester {
    text-align: center;
    font-size: 110%;
    margin: 10px 0px;
}

.active-semester {
    border-bottom: yellow solid 3px;
    margin-bottom: 7px;
}

.side-category {
    margin-right: 10px;
}

.software {
    background: #33ccff;
}

.systeme {
    background: #ffbb99;
}

.hardware {
    background: #ffcccc;
}

.grundlagen {
    background: #ccffff;
}

.nebenfach {
    background: #ccffcc;
}

.abschluss {
    background: #bbccff;
}

.exam {
    display: grid;
    grid-template-columns: 20px auto;
    margin-bottom: 5px;
    margin-right: 5px;
    min-height: 170px;
    background: #1D2224;
}

.exam-body {
    display: grid;
    grid-template-rows: 50px 1fr 50px;
}

.header-wrap {
    display: flex;
    justify-content: center;
}

.header {
    font-size: 110%;
    text-align: center;
    flex: 1;
}

.check-mark {
    font-size: 130%;
    margin-right: 3px;
    color: greenyellow;
}

.notsuccessed {
    color: #1D2224;
}

.description {
    font-size: 90%;
    text-align: center;
    margin-right: 15px;
}

.header,
.description {
    margin-bottom: 10px;
}

.info {
    display: flex;
    justify-content: space-around;
    align-self: end;
    margin-bottom: 10px;
}