/* ==============================
   UC MIXCOCO PREMIUM CART
   Drawer moderno independiente
   ============================== */

/* Oculta el drawer viejo del header para que no se abran dos carritos */
#uc-mixcoco-header .ucmh-cart-panel {
    display: none !important;
}

body.ucpc-cart-open {
    overflow: hidden !important;
}

.ucpc-cart-panel,
.ucpc-cart-panel * {
    box-sizing: border-box !important;
}

.ucpc-cart-panel {
    position: fixed !important;
    inset: 0 !important;
    z-index: 10000000 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    font-family: "Poppins", Arial, sans-serif !important;
}

.ucpc-cart-panel.is-open {
    visibility: visible !important;
    pointer-events: auto !important;
}

.ucpc-backdrop {
    position: absolute !important;
    inset: 0 !important;
    background: rgba(0, 0, 0, 0.58) !important;
    backdrop-filter: blur(5px) !important;
    opacity: 0 !important;
    transition: opacity 0.28s ease !important;
}

.ucpc-cart-panel.is-open .ucpc-backdrop {
    opacity: 1 !important;
}

.ucpc-drawer {
    position: absolute !important;
    top: 0 !important;
    right: 0 !important;
    width: min(94vw, 460px) !important;
    height: 100dvh !important;
    background: #ffffff !important;
    color: #111111 !important;
    transform: translateX(108%) !important;
    transition: transform 0.32s cubic-bezier(.22,.9,.31,1) !important;
    box-shadow: -28px 0 80px rgba(0, 0, 0, 0.28) !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
}

.ucpc-cart-panel.is-open .ucpc-drawer {
    transform: translateX(0) !important;
}

/* Header */
.ucpc-head {
    flex: 0 0 auto !important;
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 18px !important;
    padding: 24px 24px 18px !important;
    background:
        radial-gradient(circle at 12% 0%, rgba(199, 0, 0, 0.12), transparent 36%),
        linear-gradient(180deg, #ffffff, #fff8f8) !important;
    border-bottom: 1px solid #f0f0f0 !important;
}

.ucpc-title {
    margin: 0 !important;
    color: #111111 !important;
    font-family: "Montserrat", Arial, sans-serif !important;
    font-size: 31px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    letter-spacing: -0.055em !important;
}

.ucpc-subtitle {
    margin: 9px 0 0 !important;
    color: #667085 !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    line-height: 1.35 !important;
}

.ucpc-count {
    color: #c70000 !important;
    font-weight: 900 !important;
}

.ucpc-close {
    width: 48px !important;
    height: 48px !important;
    flex: 0 0 48px !important;
    border: none !important;
    border-radius: 999px !important;
    background: #111111 !important;
    color: #ffffff !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 31px !important;
    line-height: 1 !important;
    cursor: pointer !important;
    transition: all .22s ease !important;
}

.ucpc-close:hover {
    background: #c70000 !important;
    transform: rotate(90deg) !important;
}

/* Trust row */
.ucpc-trust-row {
    flex: 0 0 auto !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    padding: 12px 24px !important;
    background: #111111 !important;
}

.ucpc-trust-row span {
    min-height: 34px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, 0.08) !important;
    color: #ffffff !important;
    font-family: "Montserrat", Arial, sans-serif !important;
    font-size: 10px !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: .04em !important;
}

/* Body */
.ucpc-body {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 12px 24px 20px !important;
    background: #ffffff !important;
}

.ucpc-items {
    display: grid !important;
    gap: 0 !important;
}

/* Empty */
.ucpc-empty {
    margin: 24px 0 !important;
    padding: 42px 20px !important;
    border: 1px dashed #d6d6d6 !important;
    border-radius: 24px !important;
    background:
        radial-gradient(circle at top, rgba(199,0,0,.08), transparent 40%),
        #fafafa !important;
    text-align: center !important;
}

.ucpc-empty h4 {
    margin: 0 0 7px !important;
    color: #111111 !important;
    font-family: "Montserrat", Arial, sans-serif !important;
    font-size: 17px !important;
    font-weight: 900 !important;
}

.ucpc-empty p {
    margin: 0 !important;
    color: #6b7280 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
}

/* Product item */
.ucpc-item {
    position: relative !important;
    display: grid !important;
    grid-template-columns: 82px minmax(0, 1fr) !important;
    gap: 14px !important;
    align-items: start !important;
    padding: 18px 0 !important;
    border-bottom: 1px solid #f1f3f5 !important;
}

.ucpc-item-image {
    width: 82px !important;
    height: 82px !important;
    overflow: hidden !important;
    border-radius: 18px !important;
    background: #f8fafc !important;
    border: 1px solid #eeeeee !important;
    box-shadow: 0 12px 28px rgba(0,0,0,.07) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-decoration: none !important;
}

.ucpc-item-image img,
.ucpc-product-img {
    width: 82px !important;
    height: 82px !important;
    max-width: 82px !important;
    max-height: 82px !important;
    object-fit: cover !important;
    margin: 0 !important;
    float: none !important;
    display: block !important;
}

.ucpc-item-content {
    min-width: 0 !important;
    padding-right: 32px !important;
}

.ucpc-item-name {
    display: block !important;
    color: #111111 !important;
    text-decoration: none !important;
    font-family: "Poppins", Arial, sans-serif !important;
    font-size: 13px !important;
    font-weight: 900 !important;
    line-height: 1.28 !important;
}

.ucpc-item-name:hover {
    color: #c70000 !important;
}

.ucpc-item-data {
    margin-top: 6px !important;
    color: #6b7280 !important;
    font-size: 11px !important;
    line-height: 1.35 !important;
}

.ucpc-item-data dl,
.ucpc-item-data dt,
.ucpc-item-data dd,
.ucpc-item-data p {
    margin: 0 !important;
    padding: 0 !important;
}

.ucpc-item-bottom {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    margin-top: 12px !important;
}

.ucpc-item-price {
    color: #c70000 !important;
    font-family: "Montserrat", Arial, sans-serif !important;
    font-size: 13px !important;
    font-weight: 900 !important;
    white-space: nowrap !important;
}

/* Quantity */
.ucpc-qty {
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
    padding: 4px !important;
    width: max-content !important;
    border-radius: 999px !important;
    background: #f8fafc !important;
    border: 1px solid #e5e7eb !important;
}

.ucpc-qty button {
    width: 28px !important;
    height: 28px !important;
    border: none !important;
    border-radius: 999px !important;
    background: #ffffff !important;
    color: #111111 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    font-size: 17px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    box-shadow: 0 4px 10px rgba(0,0,0,.06) !important;
    transition: all .2s ease !important;
}

.ucpc-qty button:hover {
    background: #c70000 !important;
    color: #ffffff !important;
}

.ucpc-qty input {
    width: 34px !important;
    height: 28px !important;
    border: none !important;
    background: transparent !important;
    text-align: center !important;
    color: #111111 !important;
    font-size: 13px !important;
    font-weight: 900 !important;
    padding: 0 !important;
    pointer-events: none !important;
    box-shadow: none !important;
}

/* Remove */
.ucpc-remove {
    position: absolute !important;
    top: 18px !important;
    right: 0 !important;
    z-index: 4 !important;
    width: 28px !important;
    height: 28px !important;
    border: none !important;
    border-radius: 999px !important;
    background: #fff0f0 !important;
    color: #c70000 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-decoration: none !important;
    font-size: 22px !important;
    line-height: 1 !important;
    font-weight: 700 !important;
    cursor: pointer !important;
}

.ucpc-remove:hover {
    background: #c70000 !important;
    color: #ffffff !important;
}

/* Footer */
.ucpc-footer {
    flex: 0 0 auto !important;
    padding: 18px 24px 22px !important;
    background: #ffffff !important;
    border-top: 1px solid #eeeeee !important;
    box-shadow: 0 -12px 32px rgba(0,0,0,.06) !important;
}

.ucpc-total-row {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 16px !important;
    margin-bottom: 14px !important;
    color: #111111 !important;
    font-family: "Montserrat", Arial, sans-serif !important;
    font-size: 16px !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
}

.ucpc-total-value {
    color: #c70000 !important;
}

.ucpc-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
}

.ucpc-actions a {
    min-height: 52px !important;
    border-radius: 999px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-decoration: none !important;
    text-align: center !important;
    font-family: "Montserrat", Arial, sans-serif !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: .03em !important;
    transition: all .2s ease !important;
}

.ucpc-checkout {
    background: #c70000 !important;
    color: #ffffff !important;
    box-shadow: 0 14px 30px rgba(199,0,0,.24) !important;
}

.ucpc-checkout:hover {
    background: #a00000 !important;
    color: #ffffff !important;
    transform: translateY(-1px) !important;
}

.ucpc-viewcart {
    background: #111111 !important;
    color: #ffffff !important;
}

.ucpc-viewcart:hover {
    background: #2a2a2a !important;
    color: #ffffff !important;
}

.ucpc-empty-state .ucpc-checkout {
    opacity: 0.45 !important;
    pointer-events: none !important;
}

.ucpc-updating {
    opacity: .45 !important;
    pointer-events: none !important;
}

@media (max-width: 480px) {
    .ucpc-drawer {
        width: 96vw !important;
    }

    .ucpc-head,
    .ucpc-body,
    .ucpc-footer {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    .ucpc-title {
        font-size: 28px !important;
    }

    .ucpc-item {
        grid-template-columns: 76px minmax(0, 1fr) !important;
        gap: 12px !important;
    }

    .ucpc-item-image,
    .ucpc-item-image img,
    .ucpc-product-img {
        width: 76px !important;
        height: 76px !important;
        max-width: 76px !important;
        max-height: 76px !important;
    }

    .ucpc-item-bottom {
        align-items: flex-start !important;
        flex-direction: column !important;
        gap: 9px !important;
    }
}
.ucpc-error-message {
    margin: 12px 0 14px !important;
    padding: 14px 16px !important;
    border-radius: 18px !important;
    background: #fff1f1 !important;
    border: 1px solid rgba(199, 0, 0, 0.18) !important;
    color: #111111 !important;
    display: grid !important;
    gap: 4px !important;
}

.ucpc-error-message strong {
    color: #c70000 !important;
    font-family: "Montserrat", Arial, sans-serif !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
}

.ucpc-error-message span {
    color: #4b5563 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    line-height: 1.35 !important;
}

.ucpc-checkout.ucpc-loading {
    opacity: 0.75 !important;
    pointer-events: none !important;
}

/* ==============================
   MODAL PRODUCTOS AGOTADOS
   ============================== */

body.ucpc-modal-open {
    overflow: hidden !important;
}

.ucpc-stock-modal,
.ucpc-stock-modal * {
    box-sizing: border-box !important;
}

.ucpc-stock-modal {
    position: fixed !important;
    inset: 0 !important;
    z-index: 10000020 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    font-family: "Poppins", Arial, sans-serif !important;
}

.ucpc-stock-modal.is-open {
    visibility: visible !important;
    pointer-events: auto !important;
}

.ucpc-stock-modal-backdrop {
    position: absolute !important;
    inset: 0 !important;
    background: rgba(0, 0, 0, 0.62) !important;
    backdrop-filter: blur(7px) !important;
    opacity: 0 !important;
    transition: opacity 0.24s ease !important;
}

.ucpc-stock-modal.is-open .ucpc-stock-modal-backdrop {
    opacity: 1 !important;
}

.ucpc-stock-modal-box {
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    width: min(92vw, 560px) !important;
    max-height: min(82vh, 720px) !important;
    overflow-y: auto !important;
    transform: translate(-50%, -46%) scale(0.96) !important;
    opacity: 0 !important;
    background: #ffffff !important;
    color: #111111 !important;
    border-radius: 28px !important;
    box-shadow: 0 34px 90px rgba(0, 0, 0, 0.32) !important;
    padding: 24px !important;
    transition: opacity 0.24s ease, transform 0.24s ease !important;
}

.ucpc-stock-modal.is-open .ucpc-stock-modal-box {
    opacity: 1 !important;
    transform: translate(-50%, -50%) scale(1) !important;
}

.ucpc-stock-modal-close {
    position: absolute !important;
    top: 16px !important;
    right: 16px !important;
    width: 42px !important;
    height: 42px !important;
    border: none !important;
    border-radius: 999px !important;
    background: #111111 !important;
    color: #ffffff !important;
    font-size: 29px !important;
    line-height: 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
}

.ucpc-stock-modal-close:hover {
    background: #c70000 !important;
}

.ucpc-stock-modal-head {
    padding-right: 48px !important;
    margin-bottom: 18px !important;
}

.ucpc-stock-modal-head span {
    display: inline-flex !important;
    color: #c70000 !important;
    font-family: "Montserrat", Arial, sans-serif !important;
    font-size: 10px !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.15em !important;
    margin-bottom: 8px !important;
}

.ucpc-stock-modal-head h3 {
    margin: 0 !important;
    color: #111111 !important;
    font-family: "Montserrat", Arial, sans-serif !important;
    font-size: 28px !important;
    font-weight: 900 !important;
    line-height: 1.05 !important;
    letter-spacing: -0.045em !important;
}

.ucpc-stock-modal-head p {
    margin: 10px 0 0 !important;
    color: #667085 !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    line-height: 1.45 !important;
}

.ucpc-stock-modal-items {
    display: grid !important;
    gap: 12px !important;
    margin: 18px 0 !important;
}

.ucpc-stock-item {
    display: grid !important;
    grid-template-columns: 72px minmax(0, 1fr) !important;
    gap: 14px !important;
    align-items: center !important;
    padding: 12px !important;
    border-radius: 20px !important;
    background: #fafafa !important;
    border: 1px solid #eeeeee !important;
}

.ucpc-stock-img-wrap {
    width: 72px !important;
    height: 72px !important;
    overflow: hidden !important;
    border-radius: 16px !important;
    background: #f3f4f6 !important;
    border: 1px solid #eeeeee !important;
}

.ucpc-stock-img-wrap img {
    width: 72px !important;
    height: 72px !important;
    object-fit: cover !important;
    display: block !important;
}

.ucpc-stock-info {
    min-width: 0 !important;
}

.ucpc-stock-info h4 {
    margin: 0 0 5px !important;
    color: #111111 !important;
    font-family: "Poppins", Arial, sans-serif !important;
    font-size: 14px !important;
    font-weight: 900 !important;
    line-height: 1.25 !important;
}

.ucpc-stock-info p {
    margin: 0 0 5px !important;
    color: #c70000 !important;
    font-size: 12px !important;
    font-weight: 800 !important;
    line-height: 1.3 !important;
}

.ucpc-stock-info span {
    color: #111111 !important;
    font-family: "Montserrat", Arial, sans-serif !important;
    font-size: 12px !important;
    font-weight: 900 !important;
}

.ucpc-stock-modal-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    margin-top: 18px !important;
}

.ucpc-stock-modal-actions button {
    min-height: 50px !important;
    border: none !important;
    border-radius: 999px !important;
    font-family: "Montserrat", Arial, sans-serif !important;
    font-size: 12px !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
}

.ucpc-stock-confirm {
    background: #c70000 !important;
    color: #ffffff !important;
    box-shadow: 0 14px 30px rgba(199, 0, 0, 0.22) !important;
}

.ucpc-stock-confirm:hover {
    background: #a00000 !important;
}

.ucpc-stock-cancel {
    background: #f3f4f6 !important;
    color: #111111 !important;
}

.ucpc-stock-cancel:hover {
    background: #e5e7eb !important;
}

.ucpc-stock-confirm.ucpc-loading {
    opacity: 0.7 !important;
    pointer-events: none !important;
}

@media (max-width: 480px) {
    .ucpc-stock-modal-box {
        width: 94vw !important;
        padding: 20px !important;
        border-radius: 24px !important;
    }

    .ucpc-stock-modal-head h3 {
        font-size: 24px !important;
    }

    .ucpc-stock-item {
        grid-template-columns: 62px minmax(0, 1fr) !important;
    }

    .ucpc-stock-img-wrap,
    .ucpc-stock-img-wrap img {
        width: 62px !important;
        height: 62px !important;
    }
}

