/* === Checkout compartido TED Innova === */

.checkout-hero {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: white;
    padding: 2.5rem 1rem;
    text-align: center;
}
.checkout-hero h1 { font-size: 2rem; font-weight: 700; margin: 0; }

.checkout-container { max-width: 1100px; margin: 2rem auto; padding: 0 1rem; }

.checkout-wrapper .wrapper {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 4px 24px rgba(102,126,234,.13);
    padding: 1.2rem;
    margin-bottom: .6rem;
}
.checkout-wrapper .wrapper h4 {
    color: #4a3b8c; font-weight: 700;
    padding-bottom: .75rem;
    border-bottom: 2px solid #f0ecff;
    margin-bottom: 1.25rem;
}
.checkout-wrapper .bg-container { border: none; background: transparent; border-radius: 0; }

/* Formulario */
.form-group { margin-bottom: 1rem; }
.form-group label { font-weight: 600; font-size: .88rem; color: #555; margin-bottom: .3rem; display: block; }
.form-group .form-control {
    border-radius: 10px; border: 1.5px solid #ddd;
    padding: .6rem .9rem; font-size: .9rem;
    transition: border-color .2s;
}
.form-group .form-control:focus {
    border-color: #667eea; box-shadow: 0 0 0 3px rgba(102,126,234,.15); outline: none;
}
.form-group .error { color: #e05555; font-size: .78rem; }

/* Botones de método de pago */
.payment-wrapper {
    display: flex; align-items: center; justify-content: space-between;
    background: #fff; border-radius: 12px;
    padding: .2rem 1.2rem; cursor: pointer !important;
    border: 2px solid transparent; width: 100%;
    transition: border-color .2s, box-shadow .2s;
    text-align: left; min-height: unset; height: auto; line-height: 1.3;
}
.payment-wrapper:hover { border-color: #667eea; box-shadow: 0 2px 12px rgba(102,126,234,.15); }
.payment-wrapper h6 { margin: 0; font-weight: 700; color: #4a3b8c; font-size: .92rem; line-height: 1.3; }
.payment-wrapper img { height: 28px; width: auto; }

/* Botón pagar */
.innova-button.purple-button {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: #fff; border: none; border-radius: 12px;
    padding: .8rem 2rem; font-weight: 700; font-size: 1rem;
    cursor: pointer; transition: opacity .2s, transform .15s;
    display: inline-block; text-decoration: none;
}
.innova-button.purple-button:hover { opacity: .9; transform: translateY(-1px); color: #fff; }

/* Tarjetas de tipo de pago (bancos/apps) */
.paymenttype-card {
    background: #f8f6ff; border-radius: 12px;
    padding: 1rem; text-align: center; cursor: pointer;
    border: 2px solid transparent; transition: border-color .2s;
}
.paymenttype-card:hover, .paymenttype-card.active { border-color: #667eea; }
.payment-icon {
    background-color: #4a3b8c; padding: .4rem; border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    width: 56px; height: 56px; margin: 0 auto;
}
.payment-icon img { width: 34px; height: 34px; object-fit: contain; filter: brightness(0) invert(1); }
.paymenttype-card p { margin: .5rem 0 0; font-weight: 600; font-size: .9rem; color: #4a3b8c; }

/* Selector tipo de pago (ciclos) */
.payment-type-selector .form-check { padding: .4rem .6rem; border-radius: 8px; }
.payment-type-selector .form-check:hover { background: #f0ecff; }
.payment-type-selector .payment-price { font-weight: 700; color: #4a3b8c; margin-left: .5rem; }

/* Tabs Yape / Plin */
.btn-mp-tab {
    border: 2px solid #e9ecef; border-radius: 20px;
    padding: .25rem .9rem; background: #fff; color: #666;
    font-weight: 600; font-size: .82rem; cursor: pointer; transition: all .2s;
}
.btn-mp-tab.active { border-color: #667eea; background: #f0ecff; color: #5b21b6; }
#mpQrCode img { border-radius: 8px; }

/* === Izipay Payment Modal === */
#izipayModal .modal-dialog {
    max-width: 460px;
}
#izipayModal .modal-content {
    border-radius: 16px;
    overflow: hidden;
    border: none;
    box-shadow: 0 8px 32px rgba(0, 0, 0, .18);
}
#izipayModal .modal-header {
    background: linear-gradient(135deg, #1a0ea0 0%, #5c3ec4 100%);
    border: none;
    padding: 1rem 1.5rem;
    color: #fff;
}
#izipayModal .modal-header .modal-title {
    font-weight: 700;
    font-size: 1rem;
}
#izipayModal .modal-body {
    padding: 0;
    background: #f5f4ff;
}
#izipayModal .modal-footer {
    background: #f5f4ff;
    border: none;
    justify-content: center;
    padding: .4rem;
}
#izipay-form-container {
    min-height: 260px;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding: 1rem;
}
#izipay-form-container .kr-embedded {
    border-radius: 8px !important;
    border: 1px solid #e0e0e0 !important;
}
#izipay-form-container .kr-payment-button {
    background-color: #2a14b8 !important;
    color: #fff !important;
    border-radius: 8px !important;
    height: 50px !important;
    margin-bottom: 0 !important;
}
#izipay-form-container .kr-payment-button:hover {
    background-color: #4338ca !important;
}
@media (max-width: 576px) {
    #izipayModal .modal-dialog {
        max-width: calc(100% - 1rem);
        margin: .5rem auto;
    }
}
