/* ==========================================
   PAYMENT METHODS
========================================== */

.payment-methods{
    margin: 50px 25px;
    padding:20px;

    border-radius:18px;

    background:
    linear-gradient(
    180deg,
    rgba(255,255,255,.03),
    rgba(255,255,255,.01)
    );

    border:1px solid
    rgba(255,255,255,.06);
}

.payment-title{

    text-align:center;

    color:#fff;

    font-size:14px;

    font-weight:700;

    letter-spacing:.5px;

    text-transform:uppercase;

    margin-bottom:15px;
}

.payment-logos{

    display:flex;

    align-items:center;

    justify-content:center;

    flex-wrap:wrap;

    gap:12px;
}

.payment-logos img{

    height:34px;

    width:auto;

    object-fit:contain;

    padding:8px 12px;

    border-radius:10px;

    background:
    rgba(255,255,255,.04);

    border:1px solid
    rgba(255,255,255,.05);

    transition:.3s;
}

.payment-logos img:hover{

    transform:translateY(-2px);

    background:
    rgba(255,255,255,.08);
}

/* ==========================================
   MOBILE
========================================== */

@media(max-width:768px){

    .payment-methods{
       margin: 50px 10px;
        padding:16px;
    }

    .payment-logos{

        gap:10px;
    }

    .payment-logos img{

        height:28px;

        padding:6px 10px;
    }

}
 /* ==========================================
   CHECKOUT PAGE
========================================== */

.checkout-page{
       padding: 120px 0 !important;
}

/* ==========================================
   LAYOUT
========================================== */

.checkout-wrapper{

    display:grid;

    grid-template-columns:
    520px 1fr;

    gap:25px;
}

/* ==========================================
   SUMMARY
========================================== */

.checkout-summary{

    background:
    linear-gradient(
    180deg,
    #0b1633,
    #071022
    );

    border-radius:24px;

    padding:10px;

    border:1px solid
    rgba(255,255,255,.06);
}

.checkout-summary h2 {
    color: #fff;
    margin-bottom: 10px;
    text-align: center;
}

.checkout-summary p {
    color: #94a3b8;
    margin-bottom: 30px;
    text-align: center;
    font-size: 13px;
}

/* ==========================================
   SUMMARY CARD
========================================== */

.summary-card{

    background:
    rgba(255,255,255,.03);

    border-radius:18px;

    padding:22px;

    border:1px solid
    rgba(255,255,255,.06);
}

.summary-card h4{

    color:#fff;

    margin-bottom:20px;
}

.summary-row{

    display:flex;

    justify-content:space-between;

    margin-bottom:16px;

    color:#c8d2e4;
}

.summary-row strong{

    color:#fff;
}

.summary-total{

    margin-top:20px;

    padding-top:20px;

    border-top:1px solid
    rgba(255,255,255,.08);

    display:flex;

    justify-content:space-between;
}

.summary-total strong{

    color:#b993ff;

    font-size:34px;
}

/* ==========================================
   FORM
========================================== */

.checkout-form-wrap{

    background:
    linear-gradient(
    180deg,
    #0b1633,
    #071022
    );

    border-radius:24px;

    padding:30px;

    border:1px solid
    rgba(255,255,255,.06);
}

.checkout-form-wrap h3{

    color:#fff;

    margin-bottom:25px;
}

/* ==========================================
   FORM GROUP
========================================== */

.form-group{

    margin-bottom:18px;
}

.form-group label{

    display:block;

    color:#fff;

    margin-bottom:8px;
}

.form-group input,
.form-group textarea{

    width:100%;

    height:52px;

    padding:0 15px;

    background:
    rgba(255,255,255,.03);

    border:1px solid
    rgba(255,255,255,.08);

    border-radius:14px;

    color:#fff;
}

.form-group textarea{

    height:auto;

    padding:15px;
}

/* ==========================================
   BUTTON
========================================== */

.place-order-btn{

    display:flex;

    align-items:center;

    justify-content:center;

    margin:24px auto 0;
    gap:10px;

    padding:14px 24px;

    border:none;

    border-radius:14px;

    background:
    linear-gradient(
        135deg,
        #25D366,
        #1faa52
    );

    color:#fff;

    font-weight:700;

    cursor:pointer;

    overflow:hidden;

    transition:
    transform .3s ease,
    box-shadow .3s ease,
    background .3s ease;
}

.place-order-btn svg{

    width:20px;
    height:20px;

    transition:
    transform .3s ease;
}
/* Hover */

.place-order-btn:hover{

    transform:
    translateY(-3px);

    box-shadow:
    0 12px 30px rgba(37,211,102,.25);

    background:
    linear-gradient(
        135deg,
        #2be06f,
        #25D366
    );
}

.place-order-btn:hover svg{

    transform:scale(1.08);
}

/* Click */

.place-order-btn:active{

    transform:
    translateY(-1px);
}

/* Shine Effect */

.place-order-btn::before{

    content:'';

    position:absolute;

    top:0;
    left:-120%;

    width:60%;

    height:100%;

    background:
    linear-gradient(
        90deg,
        transparent,
        rgba(255,255,255,.25),
        transparent
    );

    transition:left .8s ease;
}


/* ==========================================
   MOBILE
========================================== */

@media(max-width:991px){

.checkout-wrapper{

    grid-template-columns:1fr;
}

.checkout-summary h2{

    font-size:34px;
}

}   
.form-group input.error,
.form-group textarea.error{

    border-color:#ef4444 !important;

    box-shadow:
    0 0 0 4px rgba(239,68,68,.12);

    animation:
    shake .25s ease;
}

@keyframes shake{

    0%{
        transform:translateX(0);
    }

    25%{
        transform:translateX(-3px);
    }

    50%{
        transform:translateX(3px);
    }

    75%{
        transform:translateX(-3px);
    }

    100%{
        transform:translateX(0);
    }

}
#checkout-error{

    display:none;

    margin-bottom:18px;

    padding:14px 16px;

    border-radius:12px;

    background:
    rgba(239,68,68,.08);

    color:#ff6b6b;

    font-size:.92rem;

    font-weight:600;

    border-left:3px solid #ef4444;
}

#checkout-error.show{

    display:block;
}
