:root{

    --package-bg:#ffffff;
    --package-text:#111827;
    --package-input:#f3f4f6;
    --package-border:#e5e7eb;
    --package-primary:#5b5cf0;
    --package-overlay:rgba(0,0,0,.65);
    --package-shadow:0 20px 60px rgba(0,0,0,.25);
}

[data-bs-theme="dark"]{

    --package-bg:#111827;
    --package-text:#ffffff;
    --package-input:#1f2937;
    --package-border:#374151;
    --package-overlay:rgba(0,0,0,.8);
}

.package-popup-overlay{

    position:fixed;
    inset:0;

    background:var(--package-overlay);

    display:flex;
    align-items:center;
    justify-content:center;

    padding:20px;

    opacity:0;
    visibility:hidden;

    transition:.35s ease;

    z-index:999999;

    backdrop-filter:blur(6px);
}

.package-popup-overlay.active{

    opacity:1;
    visibility:visible;
}

.package-popup-box{

    width:100%;
    max-width:420px;

    background:var(--package-bg);

    color:var(--package-text);

    border-radius:24px;

    padding:28px;

    position:relative;

    border:1px solid var(--package-border);

    box-shadow:var(--package-shadow);

    transform:translateY(40px) scale(.95);

    opacity:0;

    transition:.35s ease;
}

.package-popup-overlay.active .package-popup-box{

    transform:translateY(0) scale(1);

    opacity:1;
}

.package-popup-close{

    position:absolute;

    top:14px;
    right:14px;

    width:38px;
    height:38px;

    border:none;

    border-radius:50%;

    background:var(--package-input);

    color:var(--package-text);

    font-size:24px;

    cursor:pointer;

    transition:.3s;
}

.package-popup-close:hover{

    transform:rotate(90deg);
}

.package-popup-header{

    margin-bottom:20px;
}

.package-popup-badge{

    display:inline-block;

    padding:7px 12px;

    border-radius:50px;

    background:rgba(91,92,240,.12);

    color:var(--package-primary);

    font-size:12px;
    font-weight:600;

    margin-bottom:14px;
}

.package-popup-header h3{

    font-size:30px;

    margin-bottom:8px;
}

.package-popup-header p{

    color:#6b7280;

    font-size:14px;

    line-height:1.6;
}

.package-input-group{

    margin-bottom:14px;
}

.package-input-group input{

    width:100%;

    border:none;

    background:var(--package-input);

    border:1px solid var(--package-border);

    border-radius:14px;

    padding:14px 16px;

    color:var(--package-text);

    font-size:15px;

    outline:none;

    transition:.3s ease;
}

.package-input-group input:focus{

    border-color:var(--package-primary);

    box-shadow:0 0 0 4px rgba(91,92,240,.12);
}

#packageSubmitBtn{

    width:100%;

    height:52px;

    border:none;

    border-radius:14px;

    background:linear-gradient(
        135deg,
        #5b5cf0,
        #7c3aed
    );

    color:#fff;

    font-size:15px;
    font-weight:600;

    cursor:pointer;

    transition:.3s ease;
}

#packageSubmitBtn:hover{

    transform:translateY(-2px);
}

.package-btn-loader{

    display:none;
}

#packageSubmitBtn.loading .package-btn-text{

    display:none;
}

#packageSubmitBtn.loading .package-btn-loader{

    display:inline-block;
}

#packageResponseBox{

    margin-top:14px;

    font-size:14px;
}

.package-success-msg{

    color:#16a34a;
}

.package-error-msg{

    color:#dc2626;
}



.package-readonly-note{

    display:block;

    margin-top:6px;

    font-size:12px;

    color:#9ca3af;
}

/* readonly field style */

#packageSelected{

    cursor:not-allowed;

    font-weight:600;

}

@media(max-width:480px){

    .package-popup-box{

        padding:24px 18px;
    }

    .package-popup-header h3{

        font-size:24px;
    }
}

#packageSubmitBtn:disabled{
    opacity:.75;
    cursor:not-allowed;
    transform:none !important;
}

#packageSubmitBtn.loading{
    pointer-events:none;
}

.package-btn-loader{
    display:none;
}

#packageSubmitBtn.loading .package-btn-text{
    display:none;
}

#packageSubmitBtn.loading .package-btn-loader{
    display:inline-flex;
    align-items:center;
    gap:8px;
    justify-content:center;
}

#packageSubmitBtn.loading .package-btn-loader::before{
    content:'';
    width:16px;
    height:16px;
    border:2px solid rgba(255,255,255,.35);
    border-top-color:#fff;
    border-radius:50%;
    animation:packageSpin .8s linear infinite;
}

@keyframes packageSpin{
    to{
        transform:rotate(360deg);
    }
}