.premium-page{
    padding:40px 20px;
    background:#0e0e0e;
}

.premium-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
    gap:25px;
}

.premium-card{
    background:linear-gradient(180deg, #101010, #0b0b0b);
    border-radius:14px;
    padding:24px;
    display:flex;
    flex-direction:column;
    gap:16px;

    box-shadow:
        0 0 0 1px rgba(255,255,255,.06),
        0 10px 30px rgba(0,0,0,.8);
}

.premium-title{
    font-size:17px;
    font-weight:700;
    color:#ffffff;
}


.premium-logo{
    background:#0f0f0f;
    border-radius:10px;
    padding:16px;
    display:flex;
    align-items:center;
    justify-content:center;
    box-shadow:inset 0 0 0 1px rgba(255,255,255,.05);
}

.premium-input{
    background:#0a0a0a;
    border:1px solid rgba(255,255,255,.08);
    border-radius:10px;
    padding:13px 14px;
    font-size:15px;
    color:#ffffff;
    outline:none;
}

.premium-input::placeholder{
    color:#777;
}

.premium-input[readonly]{
    cursor:default;
    opacity:.95;
}

.premium-desc{
    font-size:15px;
    color:#cfcfcf;
    line-height:1.55;
}

.premium-btn{
    margin-top:auto;
    background:linear-gradient(180deg,#111,#000);
    border:1px solid rgba(255,255,255,.12);
    border-radius:10px;
    padding:14px;

    font-size:16px;
    font-weight:700;
    letter-spacing:.3px;

    color:#ffffff;
    cursor:pointer;
    transition:background .2s, box-shadow .2s, transform .15s;
}

.premium-btn:hover{
    background:#111;
    box-shadow:0 6px 18px rgba(0,0,0,.6);
}

.premium-btn:active{
    transform:scale(.98);
}

/* OUTLINE */
.premium-btn.outline{
    background:transparent;
    border:1px solid #ffffff;
}

.premium-btn.outline:hover{
    background:#0f0f0f;
}

.premium-modal{
    position:fixed;
    inset:0;
    z-index:9999;

    opacity:0;
    visibility:hidden;
    transition:.25s ease;
}

.premium-modal.active{
    opacity:1;
    visibility:visible;
}

.premium-modal-overlay{
    position:absolute;
    inset:0;
    background:rgba(0,0,0,.75);
    backdrop-filter:blur(4px);
}

.premium-sale{
    position:relative;
}

.premium-sale-badge{
    position:absolute;
    top:16px;
    right:16px;

    padding:6px 12px;
    border-radius:10px;

    font-size:12px;
    font-weight:700;
    letter-spacing:.5px;
    text-transform:uppercase;

    color:#fff;
    background:
        linear-gradient(135deg,#ff2d2d,#ff6a00);

    box-shadow:
        0 0 0 1px rgba(255,255,255,.15),
        0 8px 24px rgba(255,80,0,.45);

    pointer-events:none;
}

.premium-modal-box{
    position:relative;
    max-width:520px;
    max-height:80vh;
    margin:8vh auto;

    display:flex;
    flex-direction:column;

    background:linear-gradient(180deg,#0b0b0b,#000);
    border-radius:14px;

    transform:translateY(20px) scale(.98);
    transition:.25s ease;

    box-shadow:
        0 0 0 1px rgba(255,255,255,.06),
        0 20px 50px rgba(0,0,0,.9);
}

.premium-modal.active .premium-modal-box{
    transform:translateY(0) scale(1);
}

.premium-modal-header{
    display:flex;
    justify-content:space-between;
    align-items:center;

    padding:18px 22px;
    font-size:16px;
    font-weight:700;
    color:#ffffff;

    border-bottom:1px solid rgba(255,255,255,.06);
}

.premium-modal-header button{
    background:none;
    border:none;
    color:#ffffff;
    font-size:22px;
    cursor:pointer;
    line-height:1;
}

.premium-modal-body{
    padding:18px 22px;
    overflow-y:auto;
}

/* custom scrollbar */
.premium-modal-body::-webkit-scrollbar{
    width:6px;
}

.premium-modal-body::-webkit-scrollbar-thumb{
    background:rgba(255,255,255,.15);
    border-radius:6px;
}

.premium-modal-body ul{
    list-style:none;
    padding:0;
    margin:0;
}

.premium-modal-body li{
    padding:12px 0;
    font-size:14px;
    color:#d6d6d6;
    border-bottom:1px solid rgba(255,255,255,.05);
}

.premium-modal-body li:last-child{
    border-bottom:none;
}

/* document.body { overflow:hidden; } */

@media (max-width:600px){
    .premium-title{
        font-size:16px;
    }

    .premium-desc{
        font-size:14px;
    }

    .premium-btn{
        font-size:15px;
        padding:13px;
    }

    .premium-modal-box{
        margin:12vh 14px;
        max-height:78vh;
    }
}
