.char-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 1.5rem;
    width: 100%;
    align-items: center;
    justify-content: center;
    margin: 2rem 0;
}

.char-group {
    text-transform: capitalize;
}

.char {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-decoration: none;
    border-radius: 2px;
}
.char .img-container {
    width: 9rem;
    height: 9rem;
    overflow: hidden;
    border: 4px solid var(--color-text);
    background: linear-gradient(var(--color-accent) 80%,var(--color-background) 100%);
    border-radius: 8px;

    box-shadow: 0 32px var(--color-text), 8px -10px var(--character-color);

    display: flex;
    justify-content: center;
    align-items: center;
}
.char .img-container img {
    height: 100%;
    width: auto;
}
.char-name {
    color: var(--color-text-inverse);
    margin: 0;
    padding: 0.15rem 0.4rem;
    font-weight: bold;
}
.char:hover > .img-container {
    border-color: var(--character-color);
    box-shadow: 0 32px var(--character-color), 8px -10px var(--color-text);
}
.char:hover > .char-name {
    border-color: var(--color-text-inverse);
    color: var(--color-text);
}