/*
|--------------------------------------------------------------------------
| PROJECT REDLINE - LEVEL UP MODAL
|--------------------------------------------------------------------------
*/

.levelup-overlay {

    position: fixed;

    inset: 0;

    display: flex;
    align-items: center;
    justify-content: center;

    background:
        rgba(0,0,0,0);

    backdrop-filter:
        blur(0px);

    opacity: 0;

    visibility: hidden;

    transition:
        opacity 0.45s ease,
        background 0.45s ease,
        backdrop-filter 0.45s ease;

    z-index: 999999;
}

.levelup-overlay.show {

    opacity: 1;

    visibility: visible;

    background:
        rgba(0,0,0,0.78);

    backdrop-filter:
        blur(12px);
}

.levelup-modal {

    position: relative;

    width: 500px;

    max-width: calc(100vw - 50px);

    padding:
        28px
        26px;

    display: flex;

    flex-direction: column;

    align-items: center;

    border-radius: 34px;

    overflow: hidden;

    background:
        linear-gradient(
            180deg,
            rgba(10,10,10,0.98),
            rgba(3,3,3,0.98)
        );

    border:
        1px solid rgba(255,52,52,0.18);

    box-shadow:
        0 0 90px rgba(255,52,52,0.10),
        inset 0 1px 0 rgba(255,255,255,0.04);

    transform:
        translateY(40px)
        scale(0.84);

    opacity: 0;

    transition:
        transform 0.52s cubic-bezier(0.22, 1, 0.36, 1),
        opacity 0.52s ease;
}

.levelup-modal::before {

    content: '';

    position: absolute;

    inset: 0;

    background:
        radial-gradient(
            circle at top,
            rgba(255,52,52,0.16),
            transparent 42%
        );

    pointer-events: none;
}

.levelup-modal::after {

    content: '';

    position: absolute;

    width: 420px;
    height: 420px;

    top: -220px;
    right: -120px;

    border-radius: 50%;

    background:
        radial-gradient(
            circle,
            rgba(255,52,52,0.10),
            transparent 70%
        );

    pointer-events: none;
}

.levelup-overlay.show .levelup-modal {

    transform:
        translateY(0)
        scale(1);

    opacity: 1;
}

.levelup-glow {

    position: absolute;

    top: -120px;

    width: 260px;
    height: 260px;

    border-radius: 50%;

    background:
        radial-gradient(
            circle,
            rgba(255,42,42,0.34),
            transparent 70%
        );
}

.levelup-icon {

    position: relative;

    width: 82px;
    height: 82px;

    display: flex;

    align-items: center;
    justify-content: center;

    border-radius: 24px;

    background:
        linear-gradient(
            180deg,
            rgba(255,52,52,0.18),
            rgba(255,52,52,0.08)
        );

    color: #FF5A5A;

    font-size: 32px;

    box-shadow:
        0 0 40px rgba(255,52,52,0.16);
}

.levelup-title {

    margin-top: 18px;

    color: #FFFFFF;

    font-size: 24px;

    font-weight: 900;

    letter-spacing: 1px;

    text-shadow:
        0 0 18px rgba(255,52,52,0.18);
}

.levelup-level {

    margin-top: 14px;

    color: #2CFF94;

    font-size: 72px;

    font-weight: 900;

    line-height: 0.95;

    text-shadow:
        0 0 24px rgba(44,255,148,0.16);
}

.levelup-button {

    width: 100%;

    height: 68px;

    margin-top: 28px;

    border: none;

    border-radius: 24px;

    background:
        linear-gradient(
            180deg,
            #FF3434,
            #FF2020
        );

    color: #FFFFFF;

    font-size: 22px;

    font-weight: 900;

    letter-spacing: 1px;

    cursor: pointer;

    transition:
        0.22s ease;

    box-shadow:
        0 0 40px rgba(255,52,52,0.18);
}

.levelup-button:hover {

    transform:
        translateY(-2px);

    box-shadow:
        0 0 28px rgba(255,42,42,0.18);
}

/*
|--------------------------------------------------------------------------
| GLOW PULSE
|--------------------------------------------------------------------------
*/

.levelup-glow {

    animation:
        levelGlowPulse 2.6s ease-in-out infinite;
}

/*
|--------------------------------------------------------------------------
| ICON FLOAT
|--------------------------------------------------------------------------
*/

.levelup-icon {

    animation:
        levelIconFloat 3.2s ease-in-out infinite;
}

/*
|--------------------------------------------------------------------------
| TITLE ANIMATION
|--------------------------------------------------------------------------
*/

.levelup-title,
.levelup-level,
.levelup-reward-card,
.levelup-button {

    opacity: 0;

    transform:
        translateY(12px);

    animation:
        levelFadeUp 0.55s forwards;
}

.levelup-level {

    animation-delay: 0.08s;
}

.levelup-reward {

    animation-delay: 0.16s;
}

.levelup-button {

    animation-delay: 0.24s;
}

/*
|--------------------------------------------------------------------------
| KEYFRAMES
|--------------------------------------------------------------------------
*/

@keyframes levelFadeUp {

    to {

        opacity: 1;

        transform:
            translateY(0);
    }
}

@keyframes levelGlowPulse {

    0% {

        transform:
            scale(1);

        opacity: 0.7;
    }

    50% {

        transform:
            scale(1.08);

        opacity: 1;
    }

    100% {

        transform:
            scale(1);

        opacity: 0.7;
    }
}

@keyframes levelIconFloat {

    0% {

        transform:
            translateY(0px);
    }

    50% {

        transform:
            translateY(-6px);
    }

    100% {

        transform:
            translateY(0px);
    }
}

/*
|--------------------------------------------------------------------------
| NEW REWARD CARDS
|--------------------------------------------------------------------------
*/

/*
|--------------------------------------------------------------------------
| AAA REWARD CARDS
|--------------------------------------------------------------------------
*/

.levelup-rewards {

    width: 100%;

    display: flex;

    flex-direction: column;

    gap: 14px;

    margin-top: 26px;
}

.levelup-reward-card {

    position: relative;

    width: 100%;

    min-height: 98px;

    display: flex;

    align-items: center;

    padding:
        18px
        20px;

    border-radius: 24px;

    overflow: hidden;

    backdrop-filter:
        blur(12px);

    transition:
        0.22s ease;
}

.levelup-reward-card::before {

    content: '';

    position: absolute;

    inset: 0;

    background:
        linear-gradient(
            135deg,
            rgba(255,255,255,0.03),
            transparent
        );

    pointer-events: none;
}

.levelup-reward-card.money {

    background:
        linear-gradient(
            135deg,
            rgba(0,255,140,0.08),
            rgba(0,0,0,0.45)
        );

    border:
        1px solid rgba(0,255,140,0.22);

    box-shadow:
        0 0 50px rgba(0,255,140,0.08);
}

.levelup-reward-card.gold {

    background:
        linear-gradient(
            135deg,
            rgba(255,184,0,0.10),
            rgba(0,0,0,0.45)
        );

    border:
        1px solid rgba(255,184,0,0.24);

    box-shadow:
        0 0 60px rgba(255,184,0,0.10);
}

.levelup-reward-top {

    width: 100%;

    display: flex;

    align-items: center;

    gap: 26px;
}

.levelup-reward-icon {

    flex-shrink: 0;

    width: 64px;
    height: 64px;

    display: flex;

    align-items: center;
    justify-content: center;

    border-radius: 20px;

    background:
        rgba(0,255,140,0.12);

    color: #2CFF94;

    font-size: 28px;

    box-shadow:
        0 0 30px rgba(0,255,140,0.10);
}

.levelup-reward-icon.gold {

    background:
        rgba(255,184,0,0.14);

    color: #FFB800;

    box-shadow:
        0 0 60px rgba(255,184,0,0.16);
}

.levelup-reward-top > div:last-child {

    flex: 1;

    min-width: 0;

    padding-left: 26px;

    border-left:
        1px solid rgba(255,255,255,0.12);
}

.levelup-reward-label {

    color:
        rgba(255,255,255,0.68);

    font-size: 15px;

    font-weight: 800;

    letter-spacing: 1px;

    text-transform: uppercase;
}

.levelup-reward-value {

    margin-top: 8px;

    color: #2CFF94;

    font-size: 42px;

    font-weight: 900;

    line-height: 1;

    text-shadow:
        0 0 20px rgba(44,255,148,0.14);
}

.levelup-reward-value.gold {

    color: #FFB800;

    text-shadow:
        0 0 34px rgba(255,184,0,0.22);
}

.levelup-reward-top {

    display: flex;

    align-items: center;

    gap: 18px;
}

.levelup-reward-icon {

    width: 72px;
    height: 72px;

    display: flex;

    align-items: center;
    justify-content: center;

    border-radius: 22px;

    background:
        rgba(44,255,148,0.10);

    color: #2CFF94;

    font-size: 28px;

    box-shadow:
        0 0 30px rgba(44,255,148,0.12);
}

.levelup-reward-icon.gold {

    background:
        rgba(255,184,0,0.14);

    color: #FFB800;

    box-shadow:
        0 0 40px rgba(255,184,0,0.16);
}

.levelup-reward-label {

    color:
        rgba(255,255,255,0.42);

    font-size: 12px;

    font-weight: 800;

    letter-spacing: 1px;
}

.levelup-reward-value {

    margin-top: 8px;

    color: #2CFF94;

    font-size: 32px;

    font-weight: 900;

    line-height: 1.1;
}

.levelup-reward-value.gold {

    color: #FFB800;

    text-shadow:
        0 0 24px rgba(255,184,0,0.24);
}

/*
|--------------------------------------------------------------------------
| AAA MOBILE LEVELUP MODAL
|--------------------------------------------------------------------------
*/

@media (max-width: 768px) {

    /*
    |--------------------------------------------------------------------------
    | OVERLAY
    |--------------------------------------------------------------------------
    */

    .levelup-overlay {

        padding:
            20px
            14px
            130px;

        align-items: center;

        overflow-y: auto;
    }

    /*
    |--------------------------------------------------------------------------
    | MODAL
    |--------------------------------------------------------------------------
    */

    .levelup-modal {

        width: 100%;

        max-width: 420px;

        max-height:
            calc(100vh - 160px);

        padding:
            24px
            18px;

        border-radius: 28px;

        overflow-x: hidden;

        overflow-y: auto;

        scrollbar-width: none;
    }

    .levelup-modal::-webkit-scrollbar {

        display: none;
    }

    /*
    |--------------------------------------------------------------------------
    | GLOW
    |--------------------------------------------------------------------------
    */

    .levelup-glow {

        width: 180px;
        height: 180px;

        top: -80px;
    }

    /*
    |--------------------------------------------------------------------------
    | ICON
    |--------------------------------------------------------------------------
    */

    .levelup-icon {

        width: 70px;
        height: 70px;

        border-radius: 20px;

        font-size: 28px;
    }

    /*
    |--------------------------------------------------------------------------
    | TITLE
    |--------------------------------------------------------------------------
    */

    .levelup-title {

        margin-top: 16px;

        font-size: 20px;

        text-align: center;

        line-height: 1.2;
    }

    /*
    |--------------------------------------------------------------------------
    | LEVEL
    |--------------------------------------------------------------------------
    */

    .levelup-level {

        margin-top: 12px;

        font-size: 56px;

        text-align: center;
    }

    /*
    |--------------------------------------------------------------------------
    | REWARDS
    |--------------------------------------------------------------------------
    */

    .levelup-rewards {

        gap: 12px;

        margin-top: 20px;
    }

    /*
    |--------------------------------------------------------------------------
    | CARD
    |--------------------------------------------------------------------------
    */

    .levelup-reward-card {

        min-height: auto;

        padding:
            16px;

        border-radius: 20px;
    }

    /*
    |--------------------------------------------------------------------------
    | TOP
    |--------------------------------------------------------------------------
    */

    .levelup-reward-top {

        gap: 14px;

        align-items: center;
    }

    /*
    |--------------------------------------------------------------------------
    | ICON
    |--------------------------------------------------------------------------
    */

    .levelup-reward-icon {

        width: 56px;
        height: 56px;

        border-radius: 18px;

        font-size: 22px;

        flex-shrink: 0;
    }

    /*
    |--------------------------------------------------------------------------
    | CONTENT
    |--------------------------------------------------------------------------
    */

    .levelup-reward-top > div:last-child {

        padding-left: 14px;
    }

    /*
    |--------------------------------------------------------------------------
    | LABEL
    |--------------------------------------------------------------------------
    */

    .levelup-reward-label {

        font-size: 11px;

        letter-spacing: 0.8px;
    }

    /*
    |--------------------------------------------------------------------------
    | VALUE
    |--------------------------------------------------------------------------
    */

    .levelup-reward-value {

        margin-top: 6px;

        font-size: 26px;

        line-height: 1.1;
    }

    /*
    |--------------------------------------------------------------------------
    | BUTTON
    |--------------------------------------------------------------------------
    */

    .levelup-button {

        height: 56px;

        margin-top: 20px;

        border-radius: 18px;

        font-size: 16px;

        letter-spacing: 0.6px;
    }

    /*
    |--------------------------------------------------------------------------
    | SAFE AREA
    |--------------------------------------------------------------------------
    */

    @supports (-webkit-touch-callout: none) {

        .levelup-overlay {

            padding-bottom:
                calc(
                    140px +
                    env(safe-area-inset-bottom)
                );
        }
    }
}

/*
|--------------------------------------------------------------------------
| SMALL MOBILE
|--------------------------------------------------------------------------
*/

@media (max-width: 420px) {

    .levelup-modal {

        padding:
            22px
            16px;
    }

    .levelup-level {

        font-size: 48px;
    }

    .levelup-reward-value {

        font-size: 22px;
    }

    .levelup-reward-icon {

        width: 52px;
        height: 52px;

        font-size: 20px;
    }

    .levelup-button {

        height: 52px;

        font-size: 15px;
    }
}