/* OTS Premium Side Cart */

:root {
    --ots-navy: #1B365D;
    --ots-cyan: #00A3E0;
    --ots-cyan-soft: rgba(0, 163, 224, 0.1);
    --ots-white: #FFFFFF;
    --ots-border: rgba(27, 54, 93, 0.08);
    --ots-text-light: #718096;
    --sc-width: 400px;
    --sc-transition: all 0.45s cubic-bezier(0.77, 0, 0.175, 1);
}

/* ==============================
   Floating Trigger Button
   ============================== */
#ots-cart-trigger {
    position: fixed !important;
    bottom: 80px !important;
    left: 30px !important;
    z-index: 99999 !important;
    cursor: pointer !important;
    transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275) !important;
}

#ots-cart-trigger:hover {
    transform: scale(1.1) !important;
}

.ots-cart-icon-wrapper {
    width: 54px !important;
    height: 54px !important;
    background: linear-gradient(135deg, var(--ots-navy) 0%, #102138 100%) !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-shadow: 0 8px 25px rgba(27, 54, 93, 0.35) !important;
    position: relative !important;
    border: 2px solid rgba(255, 255, 255, 0.3) !important;
    transition: 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275) !important;
}

.ots-cart-icon-main svg {
    width: 22px !important;
    height: 22px !important;
    color: #fff !important;
    stroke: #fff !important;
    display: block !important;
}

.ots-cart-badge {
    position: absolute !important;
    top: -4px !important;
    right: -4px !important;
    background: var(--ots-cyan) !important;
    color: #fff !important;
    min-width: 20px !important;
    height: 20px !important;
    border-radius: 10px !important;
    padding: 0 5px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 10px !important;
    font-weight: 900 !important;
    font-family: "IBM Plex Sans Arabic", sans-serif !important;
    border: 2px solid #fff !important;
    box-shadow: 0 3px 8px rgba(0, 163, 224, 0.4) !important;
    animation: ots-badge-pulse 2s infinite !important;
}

@keyframes ots-badge-pulse {
    0%, 100% { transform: scale(1); }
    50% { transform: scale(1.1); }
}

/* ==============================
   Overlay
   ============================== */
#ots-side-cart-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(10, 25, 47, 0.5) !important;
    backdrop-filter: blur(6px) !important;
    z-index: 999998 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    transition: all 0.4s ease !important;
}

#ots-side-cart-overlay.is-active {
    opacity: 1 !important;
    visibility: visible !important;
}

/* ==============================
   Side Cart Panel
   ============================== */
#ots-side-cart {
    position: fixed !important;
    top: 0 !important;
    right: calc(var(--sc-width) * -1 - 20px) !important;
    width: var(--sc-width) !important;
    height: 100% !important;
    background: #fff !important;
    z-index: 999999 !important;
    box-shadow: -10px 0 50px rgba(0, 0, 0, 0.08) !important;
    transition: var(--sc-transition) !important;
    display: flex !important;
    flex-direction: column !important;
    direction: rtl !important;
    text-align: right !important;
    font-family: "IBM Plex Sans Arabic", sans-serif !important;
}

#ots-side-cart * {
    font-family: "IBM Plex Sans Arabic", sans-serif !important;
}

#ots-side-cart.is-active {
    right: 0 !important;
}

/* ==============================
   Header
   ============================== */
.ots-side-cart-header {
    padding: 20px 24px !important;
    background: linear-gradient(135deg, var(--ots-navy) 0%, #1e4070 100%) !important;
    color: #fff !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-shrink: 0 !important;
    box-shadow: 0 4px 20px rgba(27, 54, 93, 0.15) !important;
    position: relative !important;
    z-index: 2 !important;
}

.ots-sc-header-info {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
}

.ots-side-cart-header h3 {
    margin: 0 !important;
    font-size: 18px !important;
    font-weight: 800 !important;
    color: #fff !important;
    line-height: 1.3 !important;
}

.ots-sc-header-count {
    font-size: 12px !important;
    color: rgba(255, 255, 255, 0.6) !important;
    font-weight: 500 !important;
}

#ots-close-cart {
    background: rgba(255, 255, 255, 0.1) !important;
    border: none !important;
    color: #fff !important;
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
    padding: 0 !important;
    flex-shrink: 0 !important;
}

#ots-close-cart:hover {
    background: rgba(255, 255, 255, 0.2) !important;
    transform: rotate(90deg) !important;
}

#ots-close-cart svg {
    width: 16px !important;
    height: 16px !important;
    stroke: #fff !important;
}

/* ==============================
   Scrollable Body
   ============================== */
.ots-side-cart-body {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    scrollbar-width: thin !important;
    scrollbar-color: #e2e8f0 transparent !important;
}

.ots-side-cart-body::-webkit-scrollbar {
    width: 4px !important;
}

.ots-side-cart-body::-webkit-scrollbar-track {
    background: transparent !important;
}

.ots-side-cart-body::-webkit-scrollbar-thumb {
    background: #e2e8f0 !important;
    border-radius: 4px !important;
}

.ots-side-cart-items {
    padding: 0 20px !important;
}

/* ==============================
   Cart Items
   ============================== */
.widget_shopping_cart_content .cart_list.product_list_widget {
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

.widget_shopping_cart_content li.mini_cart_item {
    display: block !important;
    padding: 12px 0 !important;
    border-bottom: 1px solid #f0f4f8 !important;
    position: relative !important;
    margin: 0 !important;
    direction: rtl !important;
}

.widget_shopping_cart_content li.mini_cart_item:last-child {
    border-bottom: none !important;
}

/* بطاقة المنتج: صورة + عمود نصي (بدون شبكة تكسر المتغيرات والتركيب) */
.widget_shopping_cart_content .ots-mini-cart-item__card {
    display: flex !important;
    flex-direction: row !important;
    align-items: flex-start !important;
    gap: 12px !important;
    position: relative !important;
    padding-inline-start: 36px !important;
    min-width: 0 !important;
}

.widget_shopping_cart_content .ots-mini-cart-item__thumb {
    flex-shrink: 0 !important;
    width: 72px !important;
}

.widget_shopping_cart_content .ots-mini-cart-item__thumb a {
    display: block !important;
    text-decoration: none !important;
}

.widget_shopping_cart_content .ots-mini-cart-item__thumb img {
    width: 72px !important;
    height: 72px !important;
    object-fit: cover !important;
    background: #f8fafc !important;
    border: 1px solid #edf2f7 !important;
    border-radius: 14px !important;
    display: block !important;
    margin: 0 !important;
}

.widget_shopping_cart_content .ots-mini-cart-item__main {
    flex: 1 !important;
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
}

.widget_shopping_cart_content .ots-mini-cart-item__title {
    font-size: 13px !important;
    font-weight: 700 !important;
    color: var(--ots-navy) !important;
    line-height: 1.45 !important;
    margin: 0 !important;
    padding: 0 !important;
}

.widget_shopping_cart_content .ots-mini-cart-item__title a {
    color: inherit !important;
    text-decoration: none !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

/* بيانات المتغير (dl) */
.widget_shopping_cart_content .ots-mini-cart-item__data {
    font-size: 11px !important;
    color: #64748b !important;
    line-height: 1.5 !important;
    margin: 0 !important;
}

.widget_shopping_cart_content .ots-mini-cart-item__data dl {
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
}

.widget_shopping_cart_content .ots-mini-cart-item__data dt {
    display: inline !important;
    font-weight: 600 !important;
    margin: 0 !important;
}

.widget_shopping_cart_content .ots-mini-cart-item__data dd {
    display: inline !important;
    margin: 0 !important;
}

/* Quantity + Price Row */
.widget_shopping_cart_content li.mini_cart_item .ots-sc-qty-row {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    margin: 6px 0 0 0 !important;
    padding: 0 !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
}

/* Quantity Control Wrapper */
.ots-sc-qty-control {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0 !important;
    background: #f1f5f9 !important;
    border-radius: 10px !important;
    overflow: hidden !important;
    border: 1px solid #e2e8f0 !important;
    transition: border-color 0.2s ease !important;
}

.ots-sc-qty-control:hover {
    border-color: var(--ots-cyan) !important;
}

.ots-sc-qty-control.ots-sc-qty-loading {
    opacity: 0.5 !important;
    pointer-events: none !important;
}

/* +/- Buttons */
.ots-sc-qty-btn {
    width: 30px !important;
    height: 30px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: transparent !important;
    border: none !important;
    cursor: pointer !important;
    color: var(--ots-navy) !important;
    transition: all 0.2s ease !important;
    padding: 0 !important;
    margin: 0 !important;
    line-height: 1 !important;
}

.ots-sc-qty-btn:hover {
    background: var(--ots-cyan-soft) !important;
    color: var(--ots-cyan) !important;
}

.ots-sc-qty-btn svg {
    width: 12px !important;
    height: 12px !important;
    display: block !important;
}

/* Quantity Value */
.ots-sc-qty-value {
    min-width: 28px !important;
    text-align: center !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    color: var(--ots-navy) !important;
    user-select: none !important;
    line-height: 30px !important;
}

/* Item Price (beside qty control) */
.ots-sc-item-price {
    font-size: 13px !important;
    font-weight: 800 !important;
    color: var(--ots-cyan) !important;
    white-space: nowrap !important;
}

.ots-sc-item-price .amount {
    color: var(--ots-cyan) !important;
    font-weight: 800 !important;
}

/* Hide the old default WC quantity span if it leaks through */
.widget_shopping_cart_content li.mini_cart_item > .quantity {
    display: none !important;
}

/* زر الحذف — زاوية البطاقة */
.widget_shopping_cart_content .ots-mini-cart-item__card > a.remove {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 30px !important;
    height: 30px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #fef2f2 !important;
    color: #ef4444 !important;
    border-radius: 10px !important;
    font-size: 18px !important;
    font-weight: 400 !important;
    text-decoration: none !important;
    transition: all 0.25s ease !important;
    line-height: 1 !important;
    z-index: 2 !important;
}

.widget_shopping_cart_content .ots-mini-cart-item__card > a.remove:hover {
    background: #ef4444 !important;
    color: #fff !important;
    transform: scale(1.05) !important;
}

/* ==============================
   Footer (Total + Buttons)
   ============================== */
.widget_shopping_cart_content .total {
    padding: 16px 20px !important;
    margin: 0 -20px !important;
    background: #f8fafc !important;
    border-top: 1px solid #edf2f7 !important;
    color: var(--ots-navy) !important;
    font-weight: 700 !important;
    font-size: 14px !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
}

.widget_shopping_cart_content .total strong {
    font-weight: 700 !important;
    color: var(--ots-navy) !important;
}

.widget_shopping_cart_content .total .amount {
    font-size: 20px !important;
    font-weight: 900 !important;
    color: var(--ots-navy) !important;
}

.widget_shopping_cart_content .buttons {
    padding: 16px 20px 20px !important;
    margin: 0 -20px -20px !important;
    background: #f8fafc !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
}

.widget_shopping_cart_content .buttons a {
    text-align: center !important;
    border-radius: 14px !important;
    font-weight: 800 !important;
    text-decoration: none !important;
    font-size: 14px !important;
    margin: 0 !important;
    transition: all 0.3s ease !important;
    display: block !important;
}

.widget_shopping_cart_content .buttons a.checkout {
    background: linear-gradient(135deg, var(--ots-cyan) 0%, #0089bd 100%) !important;
    color: #fff !important;
    padding: 14px 20px !important;
    box-shadow: 0 6px 20px rgba(0, 163, 224, 0.25) !important;
}

.widget_shopping_cart_content .buttons a.checkout:hover {
    box-shadow: 0 8px 28px rgba(0, 163, 224, 0.35) !important;
    transform: translateY(-1px) !important;
}

.widget_shopping_cart_content .buttons a:not(.checkout) {
    background: transparent !important;
    color: var(--ots-navy) !important;
    padding: 10px 20px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    text-decoration: underline !important;
    text-underline-offset: 3px !important;
}

.widget_shopping_cart_content .buttons a:not(.checkout):hover {
    color: var(--ots-cyan) !important;
}

/* Tax Note */
.widget_shopping_cart_content .buttons::after {
    content: "* الأسعار شاملة الضريبة";
    display: block !important;
    text-align: center !important;
    font-size: 11px !important;
    color: #a0aec0 !important;
    font-weight: 500 !important;
    margin-top: 2px !important;
}

/* ==============================
   Empty Cart State
   ============================== */
.ots-side-cart-empty {
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 40px 30px !important;
    text-align: center !important;
    gap: 12px !important;
}

.ots-side-cart-empty svg {
    opacity: 0.4 !important;
    margin-bottom: 8px !important;
}

.ots-empty-title {
    font-size: 18px !important;
    font-weight: 800 !important;
    color: var(--ots-navy) !important;
    margin: 0 !important;
}

.ots-empty-sub {
    font-size: 13px !important;
    color: var(--ots-text-light) !important;
    margin: 0 !important;
    line-height: 1.6 !important;
}

.ots-empty-shop-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 12px 32px !important;
    background: var(--ots-cyan-soft) !important;
    color: var(--ots-cyan) !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    border-radius: 14px !important;
    text-decoration: none !important;
    margin-top: 8px !important;
    transition: all 0.3s ease !important;
}

.ots-empty-shop-btn:hover {
    background: var(--ots-cyan) !important;
    color: #fff !important;
    box-shadow: 0 6px 20px rgba(0, 163, 224, 0.25) !important;
}

/* Hide empty state when cart has items, handled by JS too */
.ots-side-cart-body:has(.mini_cart_item) ~ .ots-side-cart-empty {
    display: none !important;
}

/* Hide body when cart is empty (no items, only "no products" message) */
.widget_shopping_cart_content .woocommerce-mini-cart__empty-message {
    display: none !important;
}

/* خيار التركيب — السلة الجانبية */
#ots-side-cart .ots-mini-cart-install {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 4px !important;
    margin-top: 6px !important;
    width: 100% !important;
    min-width: 0 !important;
}

#ots-side-cart .ots-mini-cart-install__label {
    display: block !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    color: #64748b !important;
    letter-spacing: 0.02em !important;
}

#ots-side-cart .ots-mini-install-select {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    line-height: 1.35 !important;
    padding: 8px 12px !important;
    border-radius: 10px !important;
    border: 1px solid #e2e8f0 !important;
    background: #fff !important;
    color: var(--ots-navy) !important;
    white-space: normal !important;
    word-break: break-word !important;
    cursor: pointer !important;
    box-shadow: 0 1px 2px rgba(27, 54, 93, 0.04) !important;
}

#ots-side-cart .ots-mini-install-select:focus {
    outline: none !important;
    border-color: var(--ots-cyan) !important;
    box-shadow: 0 0 0 2px rgba(0, 163, 224, 0.2) !important;
}

#ots-side-cart .ots-mini-cart-install.ots-install-loading {
    opacity: 0.6 !important;
    pointer-events: none !important;
}

/* ==============================
   Body Scroll Lock
   ============================== */
body.ots-cart-open {
    overflow: hidden !important;
}

/* ==============================
   Mobile Overrides
   ============================== */
@media (max-width: 480px) {
    #ots-side-cart {
        width: 100% !important;
        right: -105% !important;
    }

    #ots-cart-trigger {
        bottom: 70px !important;
        left: 16px !important;
    }

    .ots-cart-icon-wrapper {
        width: 48px !important;
        height: 48px !important;
    }

    .ots-cart-icon-main svg {
        width: 20px !important;
        height: 20px !important;
    }
}
