canvas {
    display: block;
}

#imageContainer {
    position: relative;
    width: 800px;
    height: 800px;
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 10px;
    max-width: 100%;
    filter: none;
    transition: filter 0.5s ease;
}

#imageContainer::after {
    position: absolute;
    inset: 0;
    pointer-events: none;
    background-color: transparent;
    transition: background-color 0.5s ease;
    border-radius: 10px;
    z-index: 2;
}

#imageContainer:hover::after {
    background-color: rgba(0, 123, 255, 0.25);
}

#imageContainer > * {
    position: relative;
    max-width: 100%;
    max-height: 100%;
    width: auto !important;
    height: auto !important;
    object-fit: contain;
    z-index: 1;
}
