.elements-container {
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
    text-align: left;
    border: none;
}
.elements-container.container-contents [class^=element-] {
    width: calc(100% / 4);
    height: 40px;
    min-height: 40px;
    padding: 0 18px;
}
.elements-container.container-contents tbody [class^=element-], tbody > tr td.element-name span {
    max-width: 0;
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
}
.elements-container.container-contents .element-options {
    width: 40px;
    min-width: 40px;
    padding: 0;
}
.options-button:hover, .options-button:focus { background-color: rgba(148, 148, 148, .2); }

thead { border-bottom: 1px solid rgba(148, 148, 148, .2); }
thead > tr {
    height: 45px;
    width: 100%;
    color: rgba(24, 24, 24, .6);
}

tbody {
    height: 100%;
    width: 100%;
    padding: 10px 0;
    overflow-x: hidden;
    overflow-y: auto;
}
tbody::-webkit-scrollbar { width: 5px; }
tbody::-webkit-scrollbar-thumb {
    background-color: rgba(148, 148, 148, .5);
    border-radius: 10px;
}
tbody > tr {
    height: 40px;
    border-radius: 10px;
    font-size: 14px;
    color: rgba(24, 24, 24, .6);
}
tbody > tr:hover, tbody > tr:focus { background-color: rgba(148, 148, 148, .2); }
tbody > tr:active {
    color: #FFFFFF;
    background-color: #2492C1;
}
tbody > tr td:first-child {
    border-top-left-radius: 10px;
    border-bottom-left-radius: 10px;
}
tbody > tr td:last-child {
    border-top-right-radius: 10px;
    border-bottom-right-radius: 10px;
}
tbody > tr td.element-name {
    font-size: 16px;
    color: rgb(24, 24, 24);
}
tbody > tr td.element-name span.mobile-type {
    font-size: 12px;
    color: rgba(24, 24, 24, .6);
}
tbody > tr td.element-options svg {
    font-weight: 100;
    color: rgba(24, 24, 24, .4);
}
tbody > tr:active td.element-name, tbody > tr:active td.element-name span.mobile-type, tbody > tr:active td.element-options svg { color: #FFFFFF; }

@media screen and (max-width: 768px) {
    .elements-container.container-contents [class^=element-] { width: calc(100% / 3); }
}

@media screen and (max-width: 480px) {
    .elements-container.container-contents [class^=element-] { display: flex; }
    .elements-container.container-contents .element-name {
        flex-direction: column;
        justify-content: center;
        height: 100%;
        width: 100%;
    }
    .elements-container.container-contents .element-name, tbody > tr td.element-name span { max-width: none !important; }

    tbody { padding: 0; }
    tbody > tr {
        display: flex;
        align-items: center;
        height: 50px;
    }
    tbody > tr td.element-options svg { height: 15px; }
}