.tbox {
    background-color:#E5E7E9;
    color:#000000;
    padding:10px;
    border: 2px solid #2980B9;
    border-radius: 10px;
    display: flex;
    flex-wrap: wrap;
    text-align: left;
    justify-content: flex-start;
    box-sizing: border-box;
    max-width: 100%;
}

.tbox li {
    margin: 10px 0;
}

.tbox a:link, .tbox a:visited {
    color: #2980B9;
    font-weight: bold;
    text-decoration: none;
    border-bottom: 2px solid #2980B9;
}

.tbox a:hover {
    color: blue;
}

.tbox-item {
    display: inline;
    padding: 5px;
    max-width: 120px;
    flex: 1;
    text-align: center;
}

.tbox-item:hover img {
    transform: scale(1.15);
}

.tbox-item img {
    border: none;
    height: 120px;
    display: block;
    transition: transform .2s ease-in-out;
    margin-left: auto;
    margin-right: auto;
}

.tbox-scroll {
    display: block;
    max-height: 6em;
    overflow-y: auto;
    white-space: pre-wrap;
    width: 100%;
}

.tbox-label {
    display: block;
    text-align: left;
    margin-top: 12px;
}

.grail-item {
    width: 100%;
    padding: 15px;
    border: 2px solid #2980B9;
    border-radius: 10px;
    box-sizing: border-box;
    overflow: hidden;
}

.grail-item-header {
    text-align: left;
}

.grail-item-header h3 {
    margin: 0 0 10px 0;
}

.grail-item-header p {
    margin: 8px 0;
}

.grail-link {
    margin-top: 10px;
}

.grail-images {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 15px;
}

.grail-images .cb-item {
    max-width: 120px;
    flex: 1;
}

.grail-item .tbox,
.grail-item .tbox-scroll,
.grail-item-header,
.grail-link,
.tbox-label {
    width: 100%;
    box-sizing: border-box;
}
