/* =========================================================================
   WOOCOMMERCE OVERRIDES · Roll&Comb Chile
   Carrito (card-based), checkout, thank you, single-product.
   Layout 2 cols, paleta negro+amarillo.
   ========================================================================= */

/* -------------------------------------------------------------------------
   1) CARRITO  /carrito/  — basado en prototipos/carrito.html (aprobado)
   ------------------------------------------------------------------------- */

/* Esconder título "Carrito" del theme — lo renderea cart.php */
.woocommerce-cart .entry-title,
.woocommerce-cart h1.page-title {
    display: none;
}

/* Notice WC "se ha agregado..." — banda slim ámbar */
.woocommerce-cart .woocommerce-notices-wrapper,
.woocommerce-cart .woocommerce-message,
.woocommerce-cart .woocommerce-info {
    max-width: 1200px;
    margin: 16px auto;
    padding: 0 16px;
}
.woocommerce-cart .woocommerce-message,
.woocommerce-cart .woocommerce-info {
    background: var(--rc-bg-warm) !important;
    border-left: 4px solid var(--rc-amber) !important;
    border-top: 0 !important;
    border-radius: 10px !important;
    color: var(--rc-black) !important;
    font-weight: 500;
    padding: 14px 18px !important;
}
.woocommerce-cart .woocommerce-message::before,
.woocommerce-cart .woocommerce-info::before { color: var(--rc-amber-dark) !important; }
.woocommerce-cart .woocommerce-message .button {
    background: var(--rc-black) !important;
    color: var(--rc-amber) !important;
    border-radius: 8px !important;
    padding: 8px 16px !important;
    font-weight: 700 !important;
    text-transform: none !important;
}

/* Página */
.rc-cart-page {
    max-width: 1200px;
    margin: 0 auto;
    padding: 32px 16px 64px;
}

/* Banner "Producto agregado · Seguir comprando" */
.rc-cart-notice {
    display: flex;
    align-items: center;
    gap: 12px;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: 12px;
    padding: 12px 18px;
    margin: 0 0 24px;
    font-size: 15px;
    color: var(--rc-black);
}
.rc-cart-notice__icon { display: inline-flex; flex-shrink: 0; }
.rc-cart-notice__text { flex: 1; }
.rc-cart-notice__text strong { font-weight: 700; }
.rc-cart-notice__continue {
    color: var(--rc-amber-dark, #e0a800);
    font-weight: 700;
    text-decoration: none;
    white-space: nowrap;
}
.rc-cart-notice__continue:hover { text-decoration: underline; }
@media (max-width: 640px) {
    .rc-cart-notice { flex-wrap: wrap; }
    .rc-cart-notice__continue { width: 100%; text-align: right; }
}
.rc-cart-page h1 {
    font-size: clamp(28px, 4vw, 36px);
    font-weight: 800;
    margin: 0 0 8px;
    color: var(--rc-black);
}
.rc-cart-page__subtitle {
    color: var(--rc-gray-500);
    font-size: 15px;
    margin: 0 0 28px;
}

/* Grid 2 cols (desktop) */
.rc-cart-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
}
@media (min-width: 1024px) {
    .rc-cart-grid { grid-template-columns: 1fr 380px; align-items: start; }
}

/* === Items: cards === */
.rc-cart-items { display: flex; flex-direction: column; gap: 12px; }
.rc-cart-item {
    background: var(--rc-white);
    border: 1px solid var(--rc-gray-200);
    border-radius: 14px;
    padding: 16px;
    display: grid;
    grid-template-columns: 96px 1fr auto;
    gap: 16px;
    align-items: center;
    box-shadow: var(--rc-shadow-sm);
    transition: box-shadow 0.15s ease;
}
.rc-cart-item:hover { box-shadow: var(--rc-shadow-md); }
@media (max-width: 640px) {
    .rc-cart-item {
        grid-template-columns: 72px 1fr;
        grid-template-areas: "thumb info" "controls controls";
    }
    .rc-cart-item__thumb-cell { grid-area: thumb; }
    .rc-cart-item__info { grid-area: info; }
    .rc-cart-item__controls { grid-area: controls; justify-self: stretch; }
}

.rc-cart-item__thumb {
    width: 96px; height: 96px;
    border-radius: 10px;
    background: var(--rc-bg-light);
    border: 1px solid var(--rc-gray-200);
    display: flex; align-items: center; justify-content: center;
    overflow: hidden;
}
.rc-cart-item__thumb img,
.rc-cart-item__thumb a img {
    width: 100% !important; height: 100% !important;
    object-fit: contain; display: block;
}
@media (max-width: 640px) { .rc-cart-item__thumb { width: 72px; height: 72px; } }

.rc-cart-item__info { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.rc-cart-item__name {
    font-size: 16px; font-weight: 700; color: var(--rc-black);
    text-decoration: none; line-height: 1.3;
}
.rc-cart-item__name:hover { color: var(--rc-amber-dark); }
.rc-cart-item__meta { font-size: 13px; color: var(--rc-gray-500); }
.rc-cart-item__unit-price { font-size: 13px; color: var(--rc-gray-500); margin-top: 2px; }
.rc-cart-item__unit-price strong { color: var(--rc-black); font-weight: 700; }

.rc-cart-item__controls { display: flex; align-items: center; gap: 16px; }
@media (max-width: 640px) {
    .rc-cart-item__controls {
        justify-content: space-between;
        border-top: 1px solid var(--rc-gray-200);
        padding-top: 12px; margin-top: 8px;
    }
}

/* Stepper de cantidad */
.rc-qty-stepper {
    display: inline-flex; align-items: center;
    border: 1px solid var(--rc-gray-200);
    border-radius: 10px; overflow: hidden;
    background: var(--rc-white);
}
.rc-qty-stepper button {
    display: inline-flex; align-items: center; justify-content: center;
    background: transparent; border: 0;
    width: 36px; height: 36px;
    font-size: 20px; font-weight: 700; color: var(--rc-black);
    line-height: 1; padding: 0;
    cursor: pointer; transition: background 0.15s ease;
    font-family: inherit;
}
.rc-qty-stepper button:hover { background: var(--rc-bg-warm); }
.rc-qty-stepper input.qty {
    width: 44px; height: 36px;
    border: 0 !important; background: transparent !important;
    text-align: center; font-weight: 700; font-size: 15px;
    line-height: 36px;
    color: var(--rc-black); padding: 0 !important;
    -moz-appearance: textfield;
    vertical-align: middle;
}
.rc-qty-stepper input.qty::-webkit-outer-spin-button,
.rc-qty-stepper input.qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

.rc-cart-item__subtotal {
    font-size: 18px; font-weight: 800; color: var(--rc-black);
    min-width: 90px; text-align: right;
}
.rc-cart-item__remove {
    width: 36px; height: 36px; border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    background: transparent; color: var(--rc-gray-500);
    border: 0; cursor: pointer; font-size: 20px; line-height: 1;
    transition: all 0.15s ease;
    text-decoration: none;
}
.rc-cart-item__remove:hover { background: rgba(220,38,38,0.1); color: var(--rc-red); }

/* === Cupón + actualizar carrito === */
.rc-cart-actions {
    display: flex; gap: 12px; align-items: center; flex-wrap: wrap;
    margin-top: 12px; padding: 16px;
    background: var(--rc-white);
    border: 1px solid var(--rc-gray-200);
    border-radius: 14px;
    box-shadow: var(--rc-shadow-sm);
}
.rc-cart-actions__coupon { display: flex; gap: 8px; flex: 1; min-width: 240px; }
.rc-cart-actions__coupon input {
    flex: 1;
    border: 1px solid var(--rc-gray-200);
    border-radius: 10px;
    padding: 10px 14px; font-size: 14px;
    font-family: inherit;
}
.rc-cart-actions__coupon input:focus {
    border-color: var(--rc-amber); outline: none;
    box-shadow: 0 0 0 3px rgba(255,193,7,0.18);
}
.rc-btn-secondary {
    background: var(--rc-white); color: var(--rc-black);
    border: 1.5px solid var(--rc-gray-200);
    border-radius: 10px; padding: 10px 18px;
    font-weight: 700; font-size: 14px; cursor: pointer;
    font-family: inherit; transition: all 0.15s ease;
    white-space: nowrap;
    outline: none;
}
.rc-btn-secondary:hover { border-color: var(--rc-amber); color: var(--rc-amber-dark); }
.rc-btn-secondary:focus,
.rc-btn-secondary:focus-visible {
    outline: 2px solid var(--rc-amber);
    outline-offset: 2px;
    border-color: var(--rc-amber);
}
.rc-btn-secondary:disabled { opacity: 0.5; cursor: not-allowed; }

/* Boton "Actualizar carrito": visible despues de cambiar cantidad con stepper.
 * El stepper +/− solo dispara el evento 'change' pero NO submit AJAX, por eso
 * el subtotal NO se refresca solo. El boton aparece habilitado en amber cuando
 * hay un cambio pendiente. */
.rc-cart-actions button[name="update_cart"] {
    display: inline-block !important;
    background: var(--rc-amber) !important;
    color: var(--rc-black) !important;
    border: 0 !important;
    font-weight: 700 !important;
    padding: 10px 22px !important;
    border-radius: 10px !important;
    box-shadow: 0 2px 8px rgba(255, 193, 7, 0.3);
    transition: all 0.15s ease;
}
.rc-cart-actions button[name="update_cart"]:hover:not(:disabled) {
    background: var(--rc-amber-dark) !important;
    transform: translateY(-1px);
}
.rc-cart-actions button[name="update_cart"]:disabled {
    background: var(--rc-gray-200) !important;
    color: var(--rc-gray-500) !important;
    box-shadow: none;
    cursor: not-allowed;
}

/* === Resumen (sticky card) === */
.rc-summary {
    background: var(--rc-white);
    border: 1px solid var(--rc-gray-200);
    border-radius: 14px;
    padding: 24px;
    box-shadow: var(--rc-shadow-sm);
    position: sticky; top: 100px;
}
.rc-summary__title {
    font-size: 18px; font-weight: 800;
    margin: 0 0 18px; color: var(--rc-black);
    text-transform: uppercase; letter-spacing: 0.04em;
}
.rc-summary__row {
    display: flex; justify-content: space-between; align-items: baseline;
    padding: 10px 0; font-size: 15px; color: var(--rc-black-soft);
}
.rc-summary__row + .rc-summary__row,
.rc-summary__row + .rc-summary__shipping {
    border-top: 1px dashed var(--rc-gray-200);
}
.rc-summary__row strong { font-weight: 700; color: var(--rc-black); }

.rc-summary__shipping {
    display: block;
    padding: 14px 0;
    border-top: 1px dashed var(--rc-gray-200);
    font-size: 15px;
}

/* Layout interno del HTML que renderiza wc_cart_totals_shipping_html() / Shipit */
.rc-summary__shipping .woocommerce-shipping-totals,
.rc-summary__shipping ul#shipping_method,
.rc-summary__shipping ul.woocommerce-shipping-methods {
    margin: 0; padding: 0; list-style: none;
}
.rc-summary__shipping th,
.rc-summary__shipping td { display: block; padding: 0; text-align: left; }
.rc-summary__shipping th {
    font-size: 15px; font-weight: 600; color: var(--rc-black-soft);
    margin: 0 0 8px;
}
.rc-summary__shipping li {
    display: flex; justify-content: space-between; align-items: center;
    gap: 10px; padding: 4px 0;
}
.rc-summary__shipping li label {
    font-weight: 700; color: var(--rc-black);
    display: flex; align-items: center; gap: 8px;
    flex-wrap: wrap;
}
.rc-summary__shipping li img { max-height: 18px; width: auto; vertical-align: middle; }
.rc-summary__shipping .amount,
.rc-summary__shipping .woocommerce-Price-amount { font-weight: 700; color: var(--rc-black); }

/* Bloque "Enviar a ..." y link "Cambiar dirección" */
.rc-summary__shipping .shipping-calculator-button,
.rc-summary__shipping a[href*="shipping"],
.rc-summary__shipping a.edit_address,
.rc-summary__shipping .shipit-edit,
.rc-summary__shipping p a {
    color: var(--rc-amber-dark, #e0a800) !important;
    font-weight: 700;
    text-decoration: none;
}
.rc-summary__shipping a:hover { text-decoration: underline; }

.rc-summary__shipping .destination,
.rc-summary__shipping p {
    margin: 8px 0 0;
    color: var(--rc-black-soft);
    font-size: 14px;
    line-height: 1.45;
}
.rc-summary__shipping .destination strong,
.rc-summary__shipping p strong { color: var(--rc-black); font-weight: 700; }

/* Forzar capitalizacion correcta en fecha de despacho que Shipit a veces
 * imprime "Viernes, 22 De Mayo" con D mayuscula. */
.rc-summary__shipping .delivery-date,
.rc-summary__shipping small { text-transform: lowercase; }
.rc-summary__shipping .delivery-date::first-letter,
.rc-summary__shipping small::first-letter { text-transform: uppercase; }

.rc-summary__total {
    display: flex; justify-content: space-between; align-items: baseline;
    padding: 18px 0 8px; margin-top: 8px;
    border-top: 2px solid var(--rc-black);
}
.rc-summary__total-label {
    font-size: 16px; font-weight: 800; color: var(--rc-black);
    text-transform: uppercase; letter-spacing: 0.04em;
}
.rc-summary__total-amount {
    font-size: 26px; font-weight: 800; color: var(--rc-black);
}
.rc-summary__total-amount .amount,
.rc-summary__total-amount .woocommerce-Price-amount {
    color: var(--rc-black) !important;
    font-size: inherit !important;
    font-weight: inherit !important;
}

/* Botón Finalizar Compra */
.rc-summary__cta,
.wc-proceed-to-checkout a.checkout-button {
    display: block !important; width: 100% !important; text-align: center !important;
    background: var(--rc-amber) !important; color: var(--rc-black) !important;
    padding: 16px 20px !important;
    border-radius: 12px !important;
    font-weight: 800 !important; font-size: 16px !important;
    text-decoration: none !important;
    text-transform: uppercase !important; letter-spacing: 0.04em !important;
    margin-top: 16px !important;
    box-shadow: 0 4px 14px rgba(255,193,7,0.4) !important;
    transition: all 0.15s ease !important;
    border: 0 !important;
    font-family: inherit !important;
}
.rc-summary__cta:hover,
.wc-proceed-to-checkout a.checkout-button:hover {
    background: var(--rc-amber-dark) !important;
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(224,168,0,0.5) !important;
}

/* Trust badges */
.rc-summary__trust {
    display: flex; flex-direction: column; gap: 8px;
    margin-top: 16px; padding-top: 16px;
    border-top: 1px solid var(--rc-gray-200);
}
.rc-summary__trust-item {
    display: flex; align-items: center; gap: 10px;
    font-size: 13px; color: var(--rc-black-soft);
}
.rc-summary__trust-icon {
    width: 28px; height: 28px; border-radius: 50%;
    background: var(--rc-bg-warm);
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--rc-amber-dark); font-weight: 800; flex-shrink: 0;
}

/* Carrito vacío */
.woocommerce-cart .cart-empty {
    max-width: 600px; margin: 80px auto;
    text-align: center; padding: 40px 20px;
    background: var(--rc-white);
    border: 1px solid var(--rc-gray-200);
    border-radius: 14px;
}
.woocommerce-cart .return-to-shop {
    text-align: center; margin: 24px auto;
}
.woocommerce-cart .return-to-shop a.button {
    background: var(--rc-black) !important;
    color: var(--rc-amber) !important;
    border-radius: 10px !important;
    padding: 14px 26px !important;
    font-weight: 700 !important;
    text-transform: none !important;
}

/* -------------------------------------------------------------------------
   2) CHECKOUT  /finalizar-compra/
   Estructura controlada por nuestro form-checkout.php override.
   Wrapper: .rc-checkout > .rc-checkout__form (.rc-checkout__main + .rc-checkout__sidebar)
   ------------------------------------------------------------------------- */

/* ==== Romper contenedor padre (#primary con sidebar de GeneratePress) ==== */
body.woocommerce-checkout #page,
body.woocommerce-checkout #content,
body.woocommerce-checkout #primary,
body.woocommerce-checkout .content-area,
body.woocommerce-checkout .site-main,
body.woocommerce-checkout .inside-article,
body.woocommerce-checkout .entry-content,
body.woocommerce-checkout article,
body.woocommerce-checkout .et_pb_section,
body.woocommerce-checkout .et_pb_row,
body.woocommerce-checkout .et_pb_column {
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}
body.woocommerce-checkout #secondary,
body.woocommerce-checkout .widget-area,
body.woocommerce-checkout .sidebar { display: none !important; }
body.woocommerce-checkout .site-main { padding: 0 !important; }

/* H1 de la pagina ("Finalizar compra") cuando WP lo renderea aparte */
body.woocommerce-checkout .entry-header,
body.woocommerce-checkout .page-header,
body.woocommerce-checkout > .entry-content > h1.entry-title { display: none; }

/* Headings legacy que ya no usamos */
.woocommerce-checkout #order_review_heading { display: none !important; }

/* ==== Wrapper principal ==== */
.rc-checkout {
    max-width: 1200px;
    margin: 0 auto;
    padding: 24px 16px 64px;
    color: var(--rc-black);
    box-sizing: border-box;
}
.rc-checkout__header { margin: 0 0 24px; }
.rc-checkout__title {
    font-size: clamp(28px, 4vw, 36px);
    font-weight: 800;
    margin: 0 0 4px;
    color: var(--rc-black);
}
.rc-checkout__sub {
    color: var(--rc-gray-500, #64748b);
    font-size: 15px;
    margin: 0;
}

/* ==== Grid principal: form + sidebar ==== */
.rc-checkout__form {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
    align-items: start;
}
@media (min-width: 980px) {
    .rc-checkout__form {
        grid-template-columns: minmax(0, 1fr) 380px;
        gap: 32px;
    }
}
.rc-checkout__main { min-width: 0; }
.rc-checkout__sidebar { min-width: 0; }
@media (min-width: 980px) {
    .rc-checkout__sidebar { position: sticky; top: 100px; }
}

/* ==== Card del form (#customer_details) ==== */
.rc-checkout__card {
    background: var(--rc-white);
    border: 1px solid var(--rc-gray-200);
    border-radius: 14px;
    padding: 28px;
    box-shadow: var(--rc-shadow-sm);
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
}
.rc-checkout__card > .col-1,
.rc-checkout__card > .col-2 {
    width: 100% !important;
    max-width: 100% !important;
    float: none !important;
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
}
.rc-checkout__card .col-2:not(:empty) {
    margin-top: 24px !important;
    padding-top: 24px !important;
    border-top: 1px solid var(--rc-gray-200) !important;
}
@media (max-width: 640px) {
    .rc-checkout__card { padding: 20px 18px; }
}

/* ==== Headings dentro del form ==== */
.rc-checkout__card h3 {
    font-size: 18px;
    font-weight: 800;
    color: var(--rc-black);
    margin: 0 0 18px;
    padding: 0;
    border: 0;
}
.rc-checkout__card #ship-to-different-address {
    font-size: 15px !important;
    font-weight: 600 !important;
    margin: 0 !important;
}
.rc-checkout__card #ship-to-different-address label {
    display: inline-flex !important;
    align-items: center;
    gap: 8px;
    font-size: 15px !important;
    font-weight: 600 !important;
    color: var(--rc-black) !important;
    margin: 0 !important;
    cursor: pointer;
}
.rc-checkout__card #ship-to-different-address input[type="checkbox"] {
    width: 18px !important; height: 18px !important;
    min-height: 0 !important;
    margin: 0 !important;
    accent-color: var(--rc-amber);
}

/* ==== Grid 2 cols para los campos billing/shipping ==== */
.rc-checkout__card .woocommerce-billing-fields__field-wrapper,
.rc-checkout__card .woocommerce-shipping-fields__field-wrapper,
.rc-checkout__card .woocommerce-additional-fields__field-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px 18px;
}
.rc-checkout__card .form-row { margin: 0 !important; }
.rc-checkout__card .form-row-wide,
.rc-checkout__card .form-row.notes { grid-column: 1 / -1; }
/* Nombre + Apellidos a fila completa: cada uno ocupa 100% del ancho del form
 * (uno arriba del otro). Más legibles y más fáciles de tipear en cualquier viewport. */
.rc-checkout__card #billing_first_name_field,
.rc-checkout__card #billing_last_name_field,
.rc-checkout__card #shipping_first_name_field,
.rc-checkout__card #shipping_last_name_field { grid-column: 1 / -1; }
@media (max-width: 640px) {
    .rc-checkout__card .woocommerce-billing-fields__field-wrapper,
    .rc-checkout__card .woocommerce-shipping-fields__field-wrapper {
        grid-template-columns: 1fr;
    }
}

/* ==== Inputs (Shopify/Stripe style) ==== */
.rc-checkout__card label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--rc-black-soft, #262626);
    margin: 0 0 6px;
}
.rc-checkout__card label abbr.required,
.rc-checkout__card label .required {
    color: var(--rc-amber-dark, #e0a800);
    text-decoration: none;
    border: 0;
    margin-left: 2px;
    font-weight: 700;
}

.rc-checkout__card input[type="text"],
.rc-checkout__card input[type="email"],
.rc-checkout__card input[type="tel"],
.rc-checkout__card input[type="number"],
.rc-checkout__card input[type="password"],
.rc-checkout__card textarea,
.rc-checkout__card select,
.rc-checkout__card .select2-selection {
    width: 100% !important;
    height: 44px !important;
    min-height: 44px !important;
    background: var(--rc-white) !important;
    border: 1px solid #d1d5db !important;
    border-radius: 8px !important;
    padding: 0 12px !important;
    font-size: 15px !important;
    font-family: inherit !important;
    color: var(--rc-black) !important;
    box-shadow: 0 1px 2px rgba(0,0,0,0.04);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
    box-sizing: border-box !important;
}
.rc-checkout__card textarea {
    height: auto !important;
    min-height: 88px !important;
    padding: 10px 12px !important;
    line-height: 1.45;
}
.rc-checkout__card select { padding-right: 32px !important; }
.rc-checkout__card input::placeholder,
.rc-checkout__card textarea::placeholder {
    color: #9ca3af;
    font-weight: 400;
}
.rc-checkout__card input:hover:not(:focus),
.rc-checkout__card select:hover:not(:focus),
.rc-checkout__card textarea:hover:not(:focus) {
    border-color: #9ca3af !important;
}
.rc-checkout__card input:focus,
.rc-checkout__card select:focus,
.rc-checkout__card textarea:focus,
.rc-checkout__card .select2-container--focus .select2-selection {
    border-color: var(--rc-amber) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(255, 193, 7, 0.22) !important;
}

/* Select2 (dropdowns custom de WC) */
.rc-checkout__card .select2-container .select2-selection--single {
    height: 44px !important;
    display: flex !important;
    align-items: center !important;
    border: 1px solid #d1d5db !important;
    border-radius: 8px !important;
}
.rc-checkout__card .select2-container .select2-selection__rendered {
    line-height: 44px !important;
    padding-left: 12px !important;
    color: var(--rc-black) !important;
}
.rc-checkout__card .select2-container .select2-selection__arrow { height: 42px !important; }

/* ==== Ocultar campo redundante "Comuna / Ciudad" (Shipit ya pone dropdown Comunas) ==== */
.rc-checkout__card #billing_city_field,
.rc-checkout__card #shipping_city_field { display: none !important; }

/* Render duplicado solucionado de raiz via remove_action en functions.php
 * (seccion 23) — el callback woocommerce_checkout_payment estaba pintando
 * su propio #payment + boton "Realizar el pedido" en paralelo a nuestro
 * review-order.php. No necesitamos CSS hide aca. */

/* ==== Cupon banner ====
 * El banner vive FUERA de .rc-checkout (lo inyecta woocommerce_before_checkout_form).
 * Lo metemos en un wrapper centrado de 1200px max, con padding lateral
 * normal (sin viewport tricks). */
body.woocommerce-checkout .woocommerce-form-coupon-toggle {
    max-width: 1200px;
    margin: 16px auto 0;
    padding: 0 16px;
    box-sizing: border-box;
}
.woocommerce-form-coupon-toggle .woocommerce-info {
    position: relative;
    border-radius: 10px;
    font-size: 14px;
    padding: 10px 16px;
    background: var(--rc-bg-warm);
    border-left: 4px solid var(--rc-amber);
    border-top: 0;
    color: var(--rc-black);
    margin: 0;
    display: inline-block;
    max-width: 100%;
}
/* Si hay multiples notices al hilo, ocupan todo el ancho */
body.woocommerce-checkout .woocommerce-notices-wrapper:has(> :nth-child(2)) {
    display: block;
}
body.woocommerce-checkout .woocommerce-notices-wrapper > * { margin-bottom: 8px; }
/* Ocultar el ::before de WC en TODOS los mensajes (info, message, error,
 * notice). La fuente WooCommerce no carga en este theme → los iconos salen
 * como emoji/cuadrado Unicode raro superpuesto al texto. Ajustamos padding
 * para que no quede espacio en blanco a la izquierda. */
.woocommerce-info::before,
.woocommerce-message::before,
.woocommerce-error::before,
.woocommerce-notice::before,
.woocommerce-noreviews::before,
.woocommerce-form-coupon-toggle .woocommerce-info::before,
.woocommerce-checkout .woocommerce-info::before {
    display: none !important;
    content: none !important;
}
.woocommerce-info,
.woocommerce-message,
.woocommerce-error,
.woocommerce-notice {
    padding-left: 1em !important;
}
.woocommerce-form-coupon-toggle .woocommerce-info a {
    color: var(--rc-amber-dark) !important;
    font-weight: 700;
}
.woocommerce-form-coupon.checkout_coupon {
    background: var(--rc-bg-light);
    border: 1px solid var(--rc-gray-200);
    border-radius: 10px;
    padding: 16px;
    margin: 0 0 24px;
}

/* ==== Nota de factura (Haulmer) ==== */
.rc-factura-note {
    margin: 16px 0 0;
    padding: 14px 18px;
    background: var(--rc-bg-warm);
    border: 1px solid var(--rc-amber);
    border-radius: 10px;
    font-size: 14px;
    line-height: 1.5;
    color: var(--rc-black);
}
.rc-factura-note strong { font-weight: 700; }

/* ==== Sidebar "Tu Pedido" (rc-summary, mismo del carrito) ==== */
.rc-checkout__sidebar .rc-summary {
    background: var(--rc-white);
    border: 1px solid var(--rc-gray-200);
    border-radius: 14px;
    padding: 24px;
    box-shadow: var(--rc-shadow-sm);
}

/* Lista de productos */
.rc-summary__items { margin: 0 0 16px; }
.rc-summary__item {
    display: grid;
    grid-template-columns: 56px 1fr auto;
    gap: 12px;
    padding: 12px 0;
    border-bottom: 1px solid var(--rc-gray-200);
    align-items: center;
}
.rc-summary__item:first-child { padding-top: 0; }
.rc-summary__item:last-child { border-bottom: 0; padding-bottom: 16px; }
.rc-summary__item-thumb {
    position: relative;
    width: 56px; height: 56px;
    background: var(--rc-bg-light);
    flex-shrink: 0;
}
.rc-summary__item-thumb img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 10px;
    border: 1px solid var(--rc-gray-200);
}
.rc-summary__item-qty {
    position: absolute; top: -6px; right: -6px;
    background: var(--rc-black); color: var(--rc-white);
    border-radius: 999px; font-size: 11px; font-weight: 700;
    min-width: 20px; height: 20px;
    display: inline-flex; align-items: center; justify-content: center;
    padding: 0 6px;
    box-shadow: 0 0 0 2px var(--rc-white);
}
.rc-summary__item-name {
    display: block; font-weight: 700; color: var(--rc-black);
    font-size: 14px; line-height: 1.3;
}
.rc-summary__item-subtotal {
    font-weight: 700; color: var(--rc-black); font-size: 14px;
}

/* Totales */
.rc-summary__totals { border-top: 1px solid var(--rc-gray-200); padding-top: 8px; }

/* CTA grande */
.rc-summary__cta,
#place_order.rc-summary__cta,
.woocommerce-checkout #place_order {
    display: block;
    width: 100% !important;
    background: var(--rc-amber) !important;
    color: var(--rc-black) !important;
    border: 0 !important;
    border-radius: 12px !important;
    padding: 16px 24px !important;
    font-size: 16px !important;
    font-weight: 800 !important;
    text-transform: uppercase;
    letter-spacing: 0.03em;
    cursor: pointer;
    margin: 18px 0 0 !important;
    box-shadow: 0 4px 14px rgba(255, 193, 7, 0.35);
    transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}
.woocommerce-checkout #place_order:hover {
    background: var(--rc-amber-dark) !important;
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(255, 193, 7, 0.5);
}

/* Metodos de pago */
.rc-payment-methods,
.woocommerce-checkout ul.payment_methods {
    list-style: none !important;
    padding: 0 !important;
    margin: 16px 0 0 !important;
    border-top: 1px dashed var(--rc-gray-200);
    padding-top: 14px !important;
}
.woocommerce-checkout ul.payment_methods li {
    list-style: none !important;
    padding: 8px 0 !important;
    background: transparent !important;
    border: 0 !important;
    margin: 0 !important;
}
.woocommerce-checkout ul.payment_methods li::before,
.woocommerce-checkout ul.payment_methods li::marker { content: '' !important; display: none !important; }
.woocommerce-checkout ul.payment_methods label {
    display: inline-flex !important;
    align-items: center;
    gap: 10px;
    font-weight: 700; color: var(--rc-black);
}
.woocommerce-checkout ul.payment_methods label img {
    max-width: 110px !important;
    height: auto !important;
    margin: 0 !important;
}
.woocommerce-checkout ul.payment_methods .payment_box {
    background: var(--rc-bg-light);
    border-radius: 8px;
    padding: 12px 14px;
    margin: 8px 0 0 !important;
    font-size: 13px;
    color: var(--rc-black-soft);
    line-height: 1.5;
}
.woocommerce-checkout ul.payment_methods .payment_box p { margin: 0; }
.woocommerce-checkout ul.payment_methods input[type="radio"],
.woocommerce-checkout #shipping_method input[type="radio"] {
    accent-color: var(--rc-amber);
    width: 16px; height: 16px;
    margin-right: 4px;
    vertical-align: middle;
}

/* Mensajes WC */
.woocommerce-error, .woocommerce-info, .woocommerce-message {
    background: var(--rc-bg-warm);
    border-left: 4px solid var(--rc-amber);
    color: var(--rc-black);
    padding: 14px 18px;
    border-radius: 8px;
    margin: 16px 0;
}
.woocommerce-error li { color: var(--rc-red); }

/* Opt-in del plugin Customer Reviews — fuera del checkout */
.woocommerce-checkout .cr-checkout-optin,
.woocommerce-checkout .ivole-checkout-optin,
.woocommerce-checkout .cusrev-checkout-optin,
.woocommerce-checkout .ivole_checkout_optin,
.woocommerce-checkout #ivole_checkout_optin_field,
.woocommerce-checkout #cr_optin_field,
.woocommerce-checkout #cusrev_optin_field,
.woocommerce-checkout input[name*="ivole_optin"],
.woocommerce-checkout input[name*="cr_optin"],
.woocommerce-checkout input[name*="cusrev_optin"] {
    display: none !important;
}

/* -------------------------------------------------------------------------
   3) TRUST BADGES viejos (.rc-trust-badges) — DEPRECADO.
   Ahora se usan los 5 .rc-summary__trust-item del carrito y checkout.
   Reglas mantenidas solo para no romper paginas legacy que aun los usen.
   ------------------------------------------------------------------------- */

.rc-trust-badges {
    display: flex; flex-wrap: wrap; gap: 16px;
    padding: 12px 0; margin: 0;
}
.rc-trust-badge {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 13px; font-weight: 600; color: var(--rc-black);
}
.rc-trust-icon { font-size: 16px; line-height: 1; }

/* -------------------------------------------------------------------------
   4) PÁGINA DE GRACIAS (Thank you)
   ------------------------------------------------------------------------- */

.woocommerce-order-received .woocommerce-order {
    max-width: 800px;
    margin: 32px auto;
}

.rc-thankyou-whatsapp {
    background: var(--rc-bg-warm);
    border: 2px solid var(--rc-amber);
    border-radius: 12px;
    padding: 24px;
    margin: 32px 0;
    text-align: center;
}

.rc-thankyou-whatsapp p {
    margin: 0 0 12px;
    font-size: 17px;
    color: var(--rc-black);
}

.rc-btn--whatsapp {
    display: inline-block;
    background: #25D366;
    color: var(--rc-white) !important;
    padding: 12px 28px;
    border-radius: 999px;
    font-weight: 700;
    text-decoration: none;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.rc-btn--whatsapp:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(37, 211, 102, 0.35);
}

/* -------------------------------------------------------------------------
   5) FICHA DE PRODUCTO single-product
   ------------------------------------------------------------------------- */

.single-product .product {
    max-width: 1200px;
    margin: 32px auto;
    padding: 0 16px;
}

.single-product .product .price {
    font-size: 32px;
    color: var(--rc-black);
    font-weight: 800;
}

.single-product .product .price del {
    color: var(--rc-gray-500);
    font-size: 20px;
    font-weight: 500;
    margin-right: 8px;
}

.single-product .product .price ins {
    text-decoration: none;
    color: var(--rc-black);
}

.single-product .product form.cart .button {
    background: var(--rc-amber);
    color: var(--rc-black);
    border-radius: 10px;
    padding: 16px 32px;
    font-size: 17px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    border: 2px solid var(--rc-amber);
    transition: background 0.15s ease, color 0.15s ease, transform 0.15s ease;
}

.single-product .product form.cart .button:hover {
    background: var(--rc-black);
    color: var(--rc-amber);
    transform: translateY(-2px);
}

/* Tabs de descripción / información adicional */
.woocommerce-tabs ul.tabs {
    border-bottom: 2px solid var(--rc-amber);
    padding: 0;
    margin: 32px 0 0;
}

.woocommerce-tabs ul.tabs li {
    background: var(--rc-bg-light);
    border: none;
    border-bottom: none;
    margin: 0 4px -2px 0;
    border-radius: 8px 8px 0 0;
}

.woocommerce-tabs ul.tabs li.active {
    background: var(--rc-amber);
    color: var(--rc-black);
}

.woocommerce-tabs ul.tabs li a {
    color: var(--rc-black);
    font-weight: 600;
    padding: 10px 18px;
}

/* -------------------------------------------------------------------------
   6) MOBILE
   ------------------------------------------------------------------------- */

@media (max-width: 1023px) {
    .woocommerce-checkout form.checkout {
        display: block;
    }

    .woocommerce-checkout #order_review {
        margin-top: 24px;
        position: static;
    }

    .rc-trust-badges {
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
    }
}

/* -------------------------------------------------------------------------
   5) CHECKOUT POLISH (remanentes)
   ------------------------------------------------------------------------- */

/* Nota de factura post-compra (Haulmer/OpenFactura) */
.rc-factura-note {
    margin: 16px 0 0;
    padding: 14px 18px;
    background: var(--rc-bg-warm);
    border: 1px solid var(--rc-amber);
    border-radius: 10px;
    font-size: 14px;
    line-height: 1.5;
    color: var(--rc-black);
}
.rc-factura-note strong { font-weight: 700; }

/* Cupon banner mas limpio */
.woocommerce-form-coupon-toggle .woocommerce-info {
    border-radius: 10px;
    font-size: 14px;
    padding: 12px 16px;
    background: var(--rc-bg-warm);
    border-left-color: var(--rc-amber);
}
.woocommerce-form-coupon-toggle .woocommerce-info a {
    color: var(--rc-amber-dark) !important;
    font-weight: 700;
}
