/**
 * Mr. Ted Shop — Checkout CSS
 * Layout 2 columnas: form izquierda, resumen derecha
 * Referencia visual: Neon Void checkout
 */

/* ── Wrapper principal ── */
.woocommerce-checkout #content,
.woocommerce-checkout .entry-content,
.woocommerce-checkout .woocommerce {
    max-width: 1200px;
    margin: 0 auto;
    padding: 3rem 2rem;
}

/* Quitar título "Finalizar compra" nativo */
.woocommerce-checkout h1.entry-title,
.woocommerce-checkout h1.page-title {
    display: none;
}

/* ── Grid 2 columnas ── */
.woocommerce-checkout form.woocommerce-checkout {
    display: grid;
    grid-template-columns: 1fr 420px;
    grid-template-rows: auto auto;
    gap: 2rem;
    align-items: start;
}

/* Columna izquierda: billing + shipping + notas */
#customer_details {
    grid-column: 1;
    grid-row: 1;
}

/* Columna derecha: resumen pedido */
#order_review_heading,
#order_review {
    grid-column: 2;
    grid-row: 1 / 3;
    position: sticky;
    top: 100px;
}

/* Payment en columna izquierda debajo de detalles */
#payment {
    grid-column: 1;
    grid-row: 2;
}

/* ── Sección headings ── */
.woocommerce-checkout h3,
.woocommerce-checkout #order_review_heading {
    font-family: var(--mt-font-display) !important;
    font-size: var(--mt-text-3xl) !important;
    color: var(--mt-white) !important;
    text-transform: uppercase !important;
    letter-spacing: -0.01em !important;
    line-height: 1 !important;
    margin-bottom: 1.5rem !important;
    padding-bottom: 1rem !important;
    border-bottom: 1px solid rgba(123, 66, 205, 0.2) !important;
}

/* Numeración estilo Neon Void */
#billing_fields > h3::before  { content: "01. "; color: var(--mt-mint); }
#shipping_fields > h3::before { content: "02. "; color: var(--mt-mint); }
#payment > h3::before         { content: "03. "; color: var(--mt-mint); }

/* ── Form fields ── */
.woocommerce-checkout .form-row {
    margin-bottom: 1.25rem !important;
}

.woocommerce-checkout .form-row label {
    display: block !important;
    font-family: var(--mt-font-ui) !important;
    font-size: 0.62rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.15em !important;
    text-transform: uppercase !important;
    color: rgba(205, 195, 213, 0.55) !important;
    margin-bottom: 0.4rem !important;
}

.woocommerce-checkout .form-row label .required {
    color: var(--mt-mint) !important;
}

.woocommerce-checkout .form-row input[type="text"],
.woocommerce-checkout .form-row input[type="email"],
.woocommerce-checkout .form-row input[type="tel"],
.woocommerce-checkout .form-row input[type="password"],
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea {
    width: 100% !important;
    background: rgba(30, 21, 82, 0.7) !important;
    border: 1px solid rgba(123, 66, 205, 0.25) !important;
    border-radius: 4px !important;
    color: var(--mt-white) !important;
    padding: 0.875rem 1rem !important;
    font-family: var(--mt-font-body) !important;
    font-size: 0.875rem !important;
    outline: none !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    box-shadow: none !important;
}

.woocommerce-checkout .form-row input:focus,
.woocommerce-checkout .form-row select:focus,
.woocommerce-checkout .form-row textarea:focus {
    border-color: var(--mt-violet) !important;
    box-shadow: 0 0 0 3px rgba(123, 66, 205, 0.15) !important;
}

/* Autofill oscuro */
.woocommerce-checkout input:-webkit-autofill,
.woocommerce-checkout input:-webkit-autofill:focus {
    -webkit-box-shadow: 0 0 0 1000px #1a104e inset !important;
    -webkit-text-fill-color: #ffffff !important;
}

/* Select arrow */
.woocommerce-checkout select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239ca3af' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 1rem center !important;
    padding-right: 2.5rem !important;
}

/* 2 columnas para nombre/apellido */
.woocommerce-checkout .form-row-first,
.woocommerce-checkout .form-row-last {
    width: calc(50% - 0.5rem) !important;
    display: inline-block !important;
    vertical-align: top !important;
}

.woocommerce-checkout .form-row-first { margin-right: 0.5rem !important; }
.woocommerce-checkout .form-row-last  { margin-left:  0.5rem !important; }

/* ── Checkbox "enviar a otra dirección" ── */
.woocommerce-checkout .woocommerce-shipping-fields h3 label {
    font-family: var(--mt-font-display) !important;
    font-size: var(--mt-text-2xl) !important;
    color: var(--mt-white) !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
    text-transform: uppercase !important;
}

.woocommerce-checkout .woocommerce-shipping-fields h3 input[type="checkbox"] {
    width: 18px !important;
    height: 18px !important;
    accent-color: var(--mt-violet) !important;
    flex-shrink: 0 !important;
}

/* ── Order review (resumen) ── */
#order_review_heading {
    font-family: var(--mt-font-display) !important;
    font-size: var(--mt-text-3xl) !important;
    color: var(--mt-white) !important;
    text-transform: uppercase !important;
    margin-bottom: 0 !important;
    padding: 1.5rem 1.75rem 1.25rem !important;
    border-bottom: 1px solid rgba(123, 66, 205, 0.2) !important;
    background: rgba(30, 21, 82, 0.5) !important;
    border-radius: 6px 6px 0 0 !important;
}

#order_review {
    background: rgba(63, 33, 105, 0.25) !important;
    border: 1px solid rgba(123, 66, 205, 0.2) !important;
    border-radius: 0 0 6px 6px !important;
    overflow: hidden !important;
}

/* Tabla productos en resumen */
.woocommerce-checkout-review-order-table {
    width: 100% !important;
    border-collapse: collapse !important;
}

.woocommerce-checkout-review-order-table thead th {
    font-family: var(--mt-font-ui) !important;
    font-size: 0.62rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.15em !important;
    text-transform: uppercase !important;
    color: rgba(205, 195, 213, 0.4) !important;
    padding: 1rem 1.5rem 0.75rem !important;
    text-align: left !important;
    border-bottom: 1px solid rgba(123, 66, 205, 0.15) !important;
}

.woocommerce-checkout-review-order-table tbody tr td {
    padding: 0.875rem 1.5rem !important;
    border-bottom: 1px solid rgba(123, 66, 205, 0.1) !important;
    font-family: var(--mt-font-body) !important;
    font-size: 0.85rem !important;
    color: rgba(205, 195, 213, 0.85) !important;
    vertical-align: middle !important;
}

.woocommerce-checkout-review-order-table tbody .cart-subtotal td,
.woocommerce-checkout-review-order-table tfoot tr td,
.woocommerce-checkout-review-order-table tfoot tr th {
    padding: 0.75rem 1.5rem !important;
    font-family: var(--mt-font-ui) !important;
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.1em !important;
    text-transform: uppercase !important;
    color: rgba(205, 195, 213, 0.55) !important;
    border-bottom: 1px solid rgba(123, 66, 205, 0.1) !important;
}

/* Total final */
.woocommerce-checkout-review-order-table tfoot .order-total th,
.woocommerce-checkout-review-order-table tfoot .order-total td {
    font-family: var(--mt-font-display) !important;
    font-size: var(--mt-text-2xl) !important;
    color: var(--mt-white) !important;
    padding: 1.25rem 1.5rem !important;
    border-top: 1px solid rgba(123, 66, 205, 0.3) !important;
    border-bottom: none !important;
}

.woocommerce-checkout-review-order-table tfoot .order-total td .woocommerce-Price-amount {
    color: var(--mt-mint) !important;
    font-size: var(--mt-text-3xl) !important;
}

/* ── Payment section ── */
#payment {
    background: rgba(30, 21, 82, 0.4) !important;
    border: 1px solid rgba(123, 66, 205, 0.2) !important;
    border-radius: 6px !important;
    padding: 0 !important;
    overflow: hidden !important;
}

#payment > h3 {
    padding: 1.5rem 1.75rem 1.25rem !important;
    background: rgba(30, 21, 82, 0.5) !important;
    margin: 0 !important;
    border-bottom: 1px solid rgba(123, 66, 205, 0.2) !important;
}

#payment .wc_payment_methods {
    list-style: none !important;
    margin: 0 !important;
    padding: 1.25rem 1.5rem !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 0.5rem !important;
}

#payment .wc_payment_methods li {
    background: rgba(63, 33, 105, 0.3) !important;
    border: 1px solid rgba(123, 66, 205, 0.15) !important;
    border-radius: 4px !important;
    padding: 1rem 1.25rem !important;
    transition: border-color 0.15s ease !important;
}

#payment .wc_payment_methods li:has(input:checked) {
    border-color: var(--mt-violet) !important;
    background: rgba(123, 66, 205, 0.15) !important;
}

#payment .wc_payment_methods li label {
    font-family: var(--mt-font-ui) !important;
    font-size: 0.8rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    color: var(--mt-white) !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    gap: 0.75rem !important;
    margin: 0 !important;
}

#payment .wc_payment_methods li input[type="radio"] {
    accent-color: var(--mt-violet) !important;
    width: 16px !important;
    height: 16px !important;
}

#payment .payment_box {
    padding: 1rem 1.25rem !important;
    font-family: var(--mt-font-body) !important;
    font-size: 0.8rem !important;
    color: rgba(205, 195, 213, 0.6) !important;
    background: rgba(30, 21, 82, 0.4) !important;
    border-top: 1px solid rgba(123, 66, 205, 0.1) !important;
    margin: 0 !important;
}

/* Place order button */
#payment #place_order {
    display: block !important;
    width: calc(100% - 3rem) !important;
    margin: 1.5rem !important;
    padding: 1.1rem 2rem !important;
    background: var(--mt-mint) !important;
    color: var(--mt-navy) !important;
    font-family: var(--mt-font-display) !important;
    font-size: var(--mt-text-2xl) !important;
    font-weight: 900 !important;
    letter-spacing: 0.05em !important;
    text-transform: uppercase !important;
    border: none !important;
    border-radius: 3px !important;
    cursor: pointer !important;
    transition: opacity 0.2s ease, transform 0.1s ease !important;
    box-shadow: 0 0 30px rgba(83, 255, 167, 0.2) !important;
}

#payment #place_order:hover {
    opacity: 0.9 !important;
    transform: translateY(-1px) !important;
}

#payment #place_order:active {
    transform: scale(0.98) !important;
}

/* Términos */
.woocommerce-checkout .woocommerce-terms-and-conditions-wrapper {
    padding: 0 1.5rem 1rem !important;
    font-family: var(--mt-font-body) !important;
    font-size: 0.75rem !important;
    color: rgba(205, 195, 213, 0.4) !important;
}

/* ── Notices en checkout ── */
.woocommerce-checkout .woocommerce-error,
.woocommerce-checkout .woocommerce-message,
.woocommerce-checkout .woocommerce-info {
    background: rgba(83, 255, 167, 0.08) !important;
    border-left: 3px solid var(--mt-mint) !important;
    color: var(--mt-mint) !important;
    padding: 0.875rem 1.25rem !important;
    margin-bottom: 1.5rem !important;
    font-family: var(--mt-font-body) !important;
    font-size: 0.85rem !important;
    list-style: none !important;
    border-radius: 0 4px 4px 0 !important;
}

.woocommerce-checkout .woocommerce-error {
    border-left-color: #ff6464 !important;
    color: #ff9999 !important;
    background: rgba(255, 100, 100, 0.08) !important;
}

.woocommerce-checkout .woocommerce-error::before,
.woocommerce-checkout .woocommerce-message::before,
.woocommerce-checkout .woocommerce-info::before {
    display: none !important;
}

/* ── Responsive ── */
@media (max-width: 900px) {
    .woocommerce-checkout form.woocommerce-checkout {
        grid-template-columns: 1fr !important;
    }

    #order_review_heading,
    #order_review {
        grid-column: 1 !important;
        grid-row: auto !important;
        position: static !important;
    }

    #payment {
        grid-column: 1 !important;
    }

    .woocommerce-checkout .form-row-first,
    .woocommerce-checkout .form-row-last {
        width: 100% !important;
        display: block !important;
        margin: 0 0 1.25rem !important;
    }
}
