﻿.Title {
    display: flex;
    gap: 1.3em;
}

    .Title:before {
        content: '';
        display: block;
        width: 4px;
        height: auto;
        background-color: var(--theme-color-light);
    }

    .Title h1 {
        font-size: 2em;
        font-weight: 800;
        text-transform: capitalize;
        line-height: 1;
        padding-block: 0.3em;
    }


.ProductList {
    display: grid;
    gap: 2.5em;
}

    .ProductList .ProductListItem {
        position: relative;
    }

        .ProductList .ProductListItem a {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: .6em;
            color: currentColor;
            position: relative;
        }

            .ProductList .ProductListItem a .ProductImage {
                background: rgba(0 0 0 / 5%);
                box-shadow: rgba(0 0 0 / 5%) 0 0 0 1px;
                overflow: hidden;
                position: relative;
            }

                .ProductList .ProductListItem a .ProductImage[region="none" i]::before {
                    display: none !important;
                }

                .ProductList .ProductListItem a .ProductImage[region]::before {
                    --w: calc(var(--h) * 4 / 3);
                    --h: 2em;
                    position: absolute;
                    z-index: 2;
                    top: 0.6em;
                    right: 1em;
                }

                .ProductList .ProductListItem a .ProductImage img {
                    vertical-align: middle;
                    width: 100%;
                    height: 100%;
                    aspect-ratio: 1 / 1;
                }

                .ProductList .ProductListItem a .ProductImage::after {
                    content: "\f290";
                    font-family: "Font Awesome 6 Free";
                    font-weight: 900;
                    position: absolute;
                    z-index: 2;
                    display: flex;
                    justify-content: center;
                    align-items: center;
                    width: 3em;
                    height: 3em;
                    top: 50%;
                    left: 50%;
                    margin: -28px 0 0 -28px;
                    border-radius: 12px;
                    background-color: rgb(34, 34, 39);
                    color: #fff;
                    transform: scale(0.8);
                    opacity: 0;
                    transition: 0.5s ease;
                    border: 1px solid rgba(255, 255, 255, 0.05);
                    font-size: 1.5em;
                }

@media (any-hover) {
    .ProductList .ProductListItem a:focus .ProductImage,
    .ProductList .ProductListItem a:hover .ProductImage {
        transition: transform .2s;
        transform: scale(1.02);
    }

        .ProductList .ProductListItem a:focus .ProductImage::after,
        .ProductList .ProductListItem a:hover .ProductImage::after {
            opacity: 1;
            transform: scale(1);
        }

        .ProductList .ProductListItem a:focus .ProductImage img,
        .ProductList .ProductListItem a:hover .ProductImage img {
            opacity: 0.8;
        }
}

.ProductList .ProductListItem a .ProductTitle {
    word-break: break-word;
    max-height: 3em;
    overflow: hidden;
    font-weight: 800;
    text-align: center;
    color: rgba(0, 0, 0, 0.8);
    line-height: 1.5;
}

/* <!-- DIRECT TOP UP PAGE CSS START HERE  --!> */
#DirectTopUpPage > .InnerContent,
#GiftCardPage > .InnerContent {
    max-width: 120em;
    margin: 0 auto;
    padding: 3em 2em;
    box-sizing: border-box;
}

#DirectTopUpPage #DirectTopUpWrapper,
#GiftCardPage #GiftCardWrapper {
    display: flex;
    flex-direction: column;
    gap: 2.5em;
}

#DirectTopUpPage .ProductList {
    grid-template-columns: repeat(auto-fill, minmax(16.5em, 1fr));
}

    #DirectTopUpPage .ProductList .ProductListItem a .ProductImage {
        width: 16.5em;
        height: 16.5em;
        border-radius: 1em;
    }

@media only screen and (max-width: 1400px) {
    #DirectTopUpPage .ProductList {
        grid-template-columns: repeat(auto-fill, minmax(14.6em, 1fr));
    }

        #DirectTopUpPage .ProductList .ProductListItem a .ProductImage {
            width: 14.5em;
            height: 14.5em;
        }
}

@media only screen and (max-width: 1300px) {
    #DirectTopUpPage .ProductList {
        grid-template-columns: repeat(auto-fill, minmax(13.6em, 1fr));
    }

        #DirectTopUpPage .ProductList .ProductListItem a .ProductImage {
            width: 13.5em;
            height: 13.5em;
        }
}

@media only screen and (max-width: 990px) {
    #DirectTopUpPage .ProductList {
        grid-template-columns: repeat(auto-fill, minmax(12.6em, 1fr));
    }

        #DirectTopUpPage .ProductList .ProductListItem a .ProductImage {
            width: 12.5em;
            height: 12.5em;
        }
}

@media only screen and (max-width: 925px) {
    #DirectTopUpPage .ProductList {
        grid-template-columns: repeat(auto-fill, minmax(11.6em, 1fr));
        gap: 2em 1.5em;
    }

        #DirectTopUpPage .ProductList .ProductListItem a .ProductImage {
            width: 11.5em;
            height: 11.5em;
        }
}

@media only screen and (max-width: 816px) {
    #DirectTopUpPage .ProductList {
        grid-template-columns: repeat(auto-fill, minmax(10.6em, 1fr));
    }

        #DirectTopUpPage .ProductList .ProductListItem a .ProductImage {
            width: 10.5em;
            height: 10.5em;
        }
}

@media only screen and (max-width: 455px) {
    #DirectTopUpPage .ProductList {
        grid-template-columns: repeat(auto-fill, minmax(9.6em, 1fr));
        gap: 2em 1em;
    }

        #DirectTopUpPage .ProductList .ProductListItem a .ProductImage {
            width: 9.5em;
            height: 9.5em;
        }
}

@media only screen and (max-width: 405px) {
    #DirectTopUpPage .ProductList {
        grid-template-columns: repeat(auto-fill, minmax(8.6em, 1fr));
    }

        #DirectTopUpPage .ProductList .ProductListItem a .ProductImage {
            width: 8.5em;
            height: 8.5em;
        }
}

/* <!-- DIRECT TOP UP PAGE CSS END HERE  --!> */

/* <!-- GIFT CARD PAGE CSS START HERE  --!> */
#GiftCardPage .ProductList {
    grid-template-columns: repeat(auto-fill, minmax(15.6em, 1fr));
}

    #GiftCardPage .ProductList .ProductListItem a .ProductImage {
        width: 16.6em;
        height: 22.3em;
        border-radius: 1.5em;
        position: relative;
    }

@media only screen and (max-width: 1400px) {

    #GiftCardPage .ProductList {
        grid-template-columns: repeat(auto-fill, minmax(14.6em, 1fr));
    }

        #GiftCardPage .ProductList .ProductListItem a .ProductImage {
            width: 15.6em;
            height: 21.3em;
        }
}

@media only screen and (max-width: 1300px) {
    #GiftCardPage .ProductList .ProductListItem a .ProductImage {
        width: 14.6em;
        height: 20.3em;
    }
}

@media only screen and (max-width: 1050px) {

    #GiftCardPage .ProductList {
        grid-template-columns: repeat(auto-fill, minmax(12.6em, 1fr));
        gap: 1.5em;
    }

        #GiftCardPage .ProductList .ProductListItem a .ProductImage {
            width: 12.6em;
            height: 16.3em;
        }

    .ProductList .ProductListItem a .ProductImage[region]::before {
        --h: 1.8em;
        right: 0.8em;
    }
}

@media only screen and (max-width: 876px) {

    #GiftCardPage .ProductList {
        grid-template-columns: repeat(auto-fill, minmax(11.6em, 1fr));
    }

        #GiftCardPage .ProductList .ProductListItem a .ProductImage {
            width: 11.6em;
            height: 15.3em;
        }

    .ProductList .ProductListItem a .ProductImage[region]::before {
        --h: 1.7em;
        right: 0.65em;
    }
}

@media only screen and (max-width: 501px) {

    #GiftCardPage .ProductList {
        grid-template-columns: repeat(auto-fill, minmax(10.6em, 1fr));
        gap: 1em;
    }

        #GiftCardPage .ProductList .ProductListItem a .ProductImage {
            width: 10.6em;
            height: 14.3em;
        }
}

@media only screen and (max-width: 480px) {
    #DirectTopUpPage > .InnerContent,
    #GiftCardPage > .InnerContent {
        padding-inline: 1.5em;
    }
}

@media only screen and (max-width: 455px) {

    #GiftCardPage .ProductList {
        grid-template-columns: repeat(auto-fill, minmax(9.8em, 1fr));
        gap: 1.5em 1em;
    }

        #GiftCardPage .ProductList .ProductListItem a .ProductImage {
            width: 9.8em;
            height: 13em;
            border-radius: 1.3em;
        }

    .ProductList .ProductListItem a .ProductImage[region]::before {
        --h: 1.5em;
        right: 0.55em;
    }
}
/* <!-- GIFT CARD PAGE CSS END HERE  --!> */
