@media only screen and (max-width:767px) {

    .reward-box,
    .reward-container .title-container {
        margin-bottom: 10px
    }

    .back-button {
        left: 15px
    }

    .main-back .container {
        border-radius: 0 !important;
        padding: 30px 15px !important
    }

    .card-mockup,
    .input-container svg {
        display: none
    }

    .payment-close {
        right: 15px !important
    }

    .main-back .py-5 {
        padding-top: 1.5rem !important;
        padding-bottom: 1.5rem !important
    }

    .reward-container {
        padding: 20px;
        border-radius: 35px
    }

    .reward-box,
    .reward-container .reward-box .top {
        padding: 5px 0
    }

    .reward-container .claim-reward {
        margin-top: 30px;
        padding: 10px 15px
    }

    img.big-reward {
        height: 120px;
        bottom: -27px
    }

    .close-btn {
        width: 30px;
        height: 30px;
        top: 30px
    }

    #bottom-menu .item .icon-wrapper .icon,
    .close-btn .icon {
        width: 25px;
        height: 25px
    }

    .reward-container .reward-box .reward-name {
        font-size: 16px
    }

    .reward-container .claim-reward span,
    .reward-container .reward-box .day-name {
        font-size: 14px
    }

    #bigSaleModal .modal-title {
        font-size: 50px;
        max-width: 60vw;
        letter-spacing: -3px
    }

    #bigSaleModal .gradient-body {
        width: 85vw;
        height: 85vw
    }

    #bigSaleModal .body {
        width: 80vw;
        height: 80vw
    }

    #bigSaleModal .gradient-body::after,
    #bigSaleModal .gradient-body::before {
        width: 100vw;
        height: 100vw
    }

    #bigSaleModal .gradient-body::after {
        left: 15%
    }

    #bigSaleModal .content .bottom .remaining-time,
    #bigSaleModal .content .bottom .text {
        font-size: 3.5vw
    }

    #bigSaleModal .content .product-title {
        font-size: 5.5vw
    }

    #bigSaleModal .discount-rate {
        width: 18vw;
        height: 18vw
    }

    #bigSaleModal .discount-rate::after {
        width: 20vw;
        height: 20vw
    }

    #bigSaleModal .discount-rate span {
        font-size: 4.5vw
    }

    .reward-container h2.title br {
        display: block
    }

    .purchase-section {
        padding: 1em
    }

    #bottom-menu .item {
        width: 13vw;
        height: 13vw;
        border-radius: 50%
    }

    #bottom-menu .item.active {
        background-color: #000
    }

    #bottom-menu .item.active .icon-wrapper {
        filter: invert(1)
    }

    #header {
        height: 35dvh;
    }

    #form-wrapper {
        background-color: var(--white);
        margin-top: -50px;
        height: calc(65dvh + 50px);
        border-top-left-radius: 40px;
        border-top-right-radius: 40px;
        position: relative;
        z-index: 99;
        padding: 4dvh 20px 0;
    }

    #about-section .container {
        padding-bottom: 200px;
    }

    #about-section .container .image-wrapper {
        clip-path: circle(50% at 50% 50%);
        position: absolute;
        bottom: 0;
        left: 0;
        right: 0;
        transform: translateY(50%);
    }
}

@media only screen and (min-width:768px) and (max-width:1024px) {
    #bigSaleModal .modal-title {
        font-size: 50px;
        max-width: 60vw;
        letter-spacing: -3px
    }

    #bigSaleModal .gradient-body {
        width: 70vw;
        height: 70vw
    }

    #bigSaleModal .body {
        width: 65vw;
        height: 65vw
    }

    #bigSaleModal .gradient-body::after,
    #bigSaleModal .gradient-body::before {
        width: 80vw;
        height: 80vw
    }

    #bigSaleModal .gradient-body::after {
        left: 20%;
        top: 45%
    }

    #bigSaleModal .content .bottom .remaining-time,
    #bigSaleModal .content .bottom .text {
        font-size: 22px
    }

    #bigSaleModal .content .product-title {
        font-size: 32px
    }

    #bigSaleModal .discount-rate {
        width: 125px;
        height: 125px
    }

    #bigSaleModal .discount-rate::after {
        width: 145px;
        height: 145px
    }

    #bigSaleModal .discount-rate span {
        font-size: 24px
    }

    #bigSaleModal .content .top .icon {
        width: 45px;
        height: 45px
    }

    .reward-container h2.title br {
        display: block
    }
}

@media only screen and (max-width:1025px) {
    #bottom-menu {
        background-color: transparent;
    }

    #bottom-menu::before {
        background: url('../images/bottom_nav.svg') center center no-repeat;
        background-size: cover;
        content: '';
        position: absolute;
        left: 50%;
        bottom: 0;
        transform: translateX(-50%);
        width: 100vw;
        height: 100%;
        z-index: -1;
    }

    #profile-info {
        position: relative;
    }

    #profile-info.rookie::after {
        background: url('../images/badges/rookie.png') center center no-repeat;
        background-size: 100% 100%;
    }

    #profile-info.bronze::after {
        background: url('../images/badges/bronze.png') center center no-repeat;
        background-size: 100% 100%;
    }

    #profile-info.silver::after {
        background: url('../images/badges/silver.png') center center no-repeat;
        background-size: 100% 100%;
    }

    #profile-info.gold::after {
        background: url('../images/badges/gold.png') center center no-repeat;
        background-size: 100% 100%;
    }

    #profile-info.legendary::after {
        background: url('../images/badges/legendary.png') center center no-repeat;
        background-size: 100% 100%;
    }

    #profile-info::after {
        content: '';
        position: absolute;
        top: 20px;
        left: 50%;
        transform: translateX(-50%);
        width: 200px;
        height: 200px;
    }
}

#products,
#body .coin-list {
    padding-bottom: 100px;
}

.blink-border {
    position: relative;
}

.blink-border::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 50%;
    border: 3px solid #ff3b30;
    animation: pulseGlow 1.4s ease-out infinite;
    -webkit-animation: pulseGlow 1.4s ease-out infinite;
}

@keyframes pulseGlow {
    0% {
        opacity: 1;
        transform: scale(1);
    }

    100% {
        opacity: 0;
        transform: scale(1.2);
    }
}


.fab {
    position: absolute;
    top: -30px;
    left: 50%;
    transform: translateX(-50%);
    width: 70px;
    height: 70px;
    border-radius: 50%;
    z-index: 100;
}

.fab .profile_photo {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    object-fit: cover;
}
