/* ========================================
   GENERAL FORM STYLES
======================================== */

.template-cart .check-out_calculator input[type=text],
.template-cart .check-out_calculator select,
.template-cart .check-out_calculator textarea,
.template-cart .shipping_calculator input[type=text],
.template-cart .shipping_calculator select {
    border-radius: 5px !important;
}

.checkout-payment{
    border:none;
}

/* ========================================
   BLINK TEXT
======================================== */

.blink-text{
    font-size:12px;
    font-weight:bold;
    color:green;
    animation:blink 1s infinite;
}

@keyframes blink{
    0%{opacity:1;}
    50%{opacity:0;}
    100%{opacity:1;}
}

/* ========================================
   CHECKOUT BOX
======================================== */

.checkout-box{
    background:#fff;
    padding:28px;
    border-radius:18px;
    box-shadow:0 15px 35px rgba(0,0,0,0.08);
}

/* ========================================
   FORM FIELD
======================================== */

.field{
    position:relative;
    margin-bottom:20px;
}

/* INPUT / SELECT */

.field input,
.field select{
    width:100%;
    height:52px;
    padding:18px 14px 8px;
    border-radius:14px;
    border:1.5px solid #dadada;
    background:#fafafa;
    font-size:15px;
    transition:.25s;
}

.field input:focus,
.field select:focus{
    border-color:#0d6efd;
    background:#fff;
    outline:none;
    box-shadow:0 0 0 3px rgba(13,110,253,0.12);
}

/* FLOAT LABEL */

.field label{
    position:absolute;
    left:14px;
    top:16px;
    font-size:14px;
    color:#777;
    transition:.22s;
    pointer-events:none;
}

/* LABEL FLOAT */

.field input:focus + label,
.field input:not(:placeholder-shown) + label,
.field select:focus + label,
.field select:valid + label{
    top:-8px;
    font-size:12px;
    color:#0d6efd;
    background:#fff;
}

/* ========================================
   MOBILE OTP INPUT
======================================== */

.mobile-group{
    display:flex;
}

.mobile-group input{
    border-radius:14px 0 0 14px;
}

.otp-btn{
    height:52px;
    padding:0 18px;
    border:none;
    background:linear-gradient(135deg,#0d6efd,#084298);
    color:#fff;
    font-weight:600;
    border-radius:0 14px 14px 0;
    cursor:pointer;
    transition:.25s;
}

.otp-btn:hover{
    background:linear-gradient(135deg,#084298,#052c65);
}

/* ERROR TEXT */

.error{
    font-size:12px;
    color:#e63946;
    margin-top:4px;
}

/* ========================================
   PAYMENT SECTION
======================================== */

.checkout-payment{
    margin-top:30px;
    font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

.pay-title-main{
    font-size:22px;
    font-weight:600;
    color:#111;
    margin-bottom:6px;
}

.pay-secure{
    color:#6b7280;
    font-size:14px;
    margin-bottom:18px;
}

/* PAYMENT BLOCK */

.payment-block{
    position:relative;
    margin-bottom:14px;
}

.payment-block input{
    position:absolute;
    opacity:0;
}

/* PAYMENT CARD */

.payment-option{
    display:block;
    background:#fff;
    border:1.5px solid #dedede;
    border-radius:14px;
    padding:16px 18px;
    cursor:pointer;
    transition:.18s;
}

.payment-option:hover{
    border-color:#cfcfcf;
}

/* SELECTED PAYMENT */

.payment-block input:checked + .payment-option{
    border:2px solid #2b6cb0;
    background:#f7fbff;
}

/* METHOD ROW */

.method-row{
    display:flex;
    align-items:center;
    justify-content:space-between;
}

.method-name{
    font-size:16px;
    font-weight:600;
}

.method-name span{
    display:block;
    font-size:13px;
    color:#6b7280;
    font-weight:400;
    margin-top:3px;
}

/* ICONS */

.method-icons{
    display:flex;
    align-items:center;
    gap:8px;
}

.method-icons img{
    height:18px;
}

.more{
    font-size:12.5px;
    background:#f1f5f9;
    padding:5px 8px;
    border-radius:6px;
    color:#374151;
    font-weight:600;
}

/* DESCRIPTION PANEL */

.method-info{
    border:1.5px solid #e5e7eb;
    border-top:none;
    border-radius:0 0 14px 14px;
    padding:14px 18px;
    color:#4b5563;
    font-size:14px;
    background:#fafafa;
    display:none;
}

.payment-block input:checked + .payment-option + .method-info{
    display:block;
}

/* ========================================
   ORDER SUMMARY
======================================== */

.lux-checkout{
    background:#fff;
    padding:32px;
    border-radius:22px;
    box-shadow:0 20px 50px rgba(0,0,0,0.06);
}

.lux-header{
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:28px;
}

.lux-header h2{
    font-size:20px;
    font-weight:700;
}

.lux-header span{
    font-size:13px;
    color:#888;
}

/* PRODUCT ITEM */

.lux-item{
    display:flex;
    align-items:center;
    padding:16px 0;
    border-bottom:1px solid #f1f1f1;
}

.lux-img{
    width:65px;
    height:85px;
    object-fit:cover;
    border-radius:12px;
}

.lux-info{
    flex:1;
    padding:0 16px;
}

.lux-name{
    font-size:14px;
    font-weight:600;
}

.lux-qty{
    font-size:12px;
    color:#888;
}

.lux-price{
    font-size:15px;
    font-weight:700;
}

/* SUMMARY */

.lux-summary{
    margin-top:24px;
    padding-top:20px;
    border-top:1px solid #eaeaea;
}

.lux-row{
    display:flex;
    justify-content:space-between;
    padding:8px 0;
    font-size:14px;
    color:#555;
}

.lux-total{
    display:flex;
    justify-content:space-between;
    margin-top:14px;
    padding-top:14px;
    border-top:2px solid #ddd;
    font-size:18px;
    font-weight:800;
}

/* ========================================
   MOBILE RESPONSIVE
======================================== */

@media(max-width:768px){

    .mt__60{
        margin-top:0!important;
    }

    .lux-checkout{
        padding:20px;
        border-radius:16px;
    }

    .lux-img{
        width:55px;
        height:75px;
    }

    .lux-name{
        font-size:13px;
    }

    .lux-price{
        font-size:14px;
    }

    .lux-total{
        font-size:17px;
    }

}

@media(max-width:380px){

    .method-row{
        gap:8px;
    }

    .method-icons img{
        height:16px;
    }

    .more{
        padding:4px 6px;
        font-size:11.5px;
    }

}