.icons__container {
    display: inline-flex;
    flex-wrap: nowrap;
    gap: 8px;
    position: relative;
    width: max-content;
}
.icons__img-wrapper {
    cursor: pointer;
    border-radius: 23.3%; /* more dynamic with size */
    overflow: hidden;
}
.icons__img-wrapper.smaller > img {
    width: 45px;
    height: 45px;
}
.icons__img-wrapper.small > img {
    width: 52px;
    height: 52px;
}
.icons__img-wrapper.medium > img {
    width: 80px;
    height: 80px;
}
.icons__img-wrapper.large > img {
    width: 130px;
    height: 130px;
}
.with-shadow {
    box-shadow: 0px 4px 40px 0px #1c3f5d;
}
.icons__popover {
    position: absolute;
    top: 120%;
    left: 50%;
    border-radius: var(--borderRadius-extra-large);
    width: 400px;
    padding: 5px 20px;
    display: flex;
    flex-direction: column;
    gap: 5px;
    align-items: center;
    visibility: hidden;
    opacity: 0;
    transition: opacity 0.3s;
    z-index: 100;
    box-shadow: 0px 4px 20px rgba(0,0,0,0.25);
}

.icons__popover.co {
    color: #000;
    background-color: var(--camoverlay-color);
}
.icons__popover.cs {
    color: #fff;
    background-color: var(--camstreamer-color);
}
.icons__popover.csw {
    color: #fff;
    background-color: var(--camswitcher-color);
}
.icons__popover.csc {
    color: #fff;
    background-color: var(--camscripter-color);
}
.icons__popover.ndi {
    color: #fff;
    background-color: var(--ndi-color);
}
.icons__popover.sporttracker {
    color: #fff;
    background-color: var(--sport-color);
}
.popover__title {
    font-size: 18px;
    font-weight: 400;
}
.popover__paragraph {
    font-family: "Gotham";
}

.icons__img-wrapper[data-app="co"]:hover ~ .icons__popover[data-app="co"] {
    visibility: visible;
    opacity: 1;
}
.icons__img-wrapper[data-app="csw"]:hover ~ .icons__popover[data-app="csw"] {
    visibility: visible;
    opacity: 1;
}
.icons__img-wrapper[data-app="csc"]:hover ~ .icons__popover[data-app="csc"] {
    visibility: visible;
    opacity: 1;
}
.icons__img-wrapper[data-app="cs"]:hover ~ .icons__popover[data-app="cs"] {
    visibility: visible;
    opacity: 1;
}
.icons__img-wrapper[data-app="ndi"]:hover ~ .icons__popover[data-app="ndi"] {
    visibility: visible;
    opacity: 1;
}
.icons__img-wrapper[data-app="sporttracker"]:hover ~ .icons__popover[data-app="sporttracker"] {
    visibility: visible;
    opacity: 1;
}