/*
 * GanjehKala MiniCart - Footer Drawer
 * Refactored to Canonical Tokens
 */

/* کانتینر اصلی - پیش‌فرض مخفی */
#gkMiniCart {
    display: none; /* توسط JS باز می‌شود */
    position: fixed !important;
    inset: 0 !important;
    z-index: 2147483647 !important; /* بالاتر از همه */
    width: 100% !important;
    height: 100% !important;
    pointer-events: none;
}

/* حالت باز - بسیار مهم */
#gkMiniCart.is-open {
    display: block !important;
    pointer-events: auto;
}

/* لایه سیاه پشت */
.gk-minicart-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,var(--gk-opacity-overlay));
    opacity: 0;
    transition: opacity 0.3s;
    cursor: pointer;
}
#gkMiniCart.is-open .gk-minicart-backdrop { opacity: 1; }

/* پنل سفید */
.gk-minicart-panel {
    position: absolute;
    top: 0; bottom: 0; left: 0;
    width: 380px; max-width: 85vw;
    background: var(--gk-surface);
    box-shadow: var(--gk-shadow-lg);
    transform: translateX(-100%);
    transition: transform 0.3s cubic-bezier(0.25, 1, 0.5, 1);
    display: flex; flex-direction: column;
}

html[dir="rtl"] .gk-minicart-panel {
    left: auto; right: 0;
    transform: translateX(100%);
}

#gkMiniCart.is-open .gk-minicart-panel {
    transform: translateX(0) !important;
}

/* هدر و بدنه */
.gk-minicart-head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px; border-bottom: var(--gk-border-width) solid var(--gk-border-color); background: var(--gk-surface);
}
.gk-minicart-title { font-weight: var(--gk-heading-weight); font-size: 16px; }
.gk-minicart-close {
    background: none; border: none; font-size: 28px; line-height: 1; cursor: pointer; padding: 0 5px;
}

.gk-minicart-body { flex: 1; overflow-y: auto; padding: 0; }

/* استایل لیست محصولات (مانند قبل) */
.gk-mini-items { list-style: none; margin: 0; padding: 0; }
.gk-mini-item { display: flex; gap: 12px; padding: 15px; border-bottom: var(--gk-border-width) solid var(--gk-border-color); position: relative; }
.gk-mi-thumb img { width: 70px; height: 70px; object-fit: cover; border-radius: var(--gk-radius-md); border: var(--gk-border-width) solid var(--gk-border-color); }
.gk-mi-main { flex: 1; display: flex; flex-direction: column; justify-content: space-between; }
.gk-mi-title { font-size: 13px; margin: 0 0 5px; font-weight: var(--gk-heading-weight); line-height: 1.4; }
.gk-mi-title a { color: var(--gk-text); text-decoration: none; }
.gk-mi-row { display: flex; align-items: center; justify-content: space-between; margin-top: auto; }
.gk-mi-qty { display: flex; align-items: center; border: var(--gk-border-width) solid var(--gk-border-color); border-radius: var(--gk-radius-sm); height: 28px; }
.gk-mi-step { width: 24px; height: 100%; border: none; background: transparent; cursor: pointer; }
.gk-mi-input { width: 28px; height: 100%; border: none; text-align: center; font-size: 12px; padding: 0; background: transparent; }
.gk-mi-remove { position: absolute; top: 10px; left: 10px; color: var(--gk-primary); background: none; border: none; font-size: 18px; cursor: pointer; }
html[dir="ltr"] .gk-mi-remove { left: auto; right: 10px; }

/* فوتر */
.gk-mini-summary { padding: 20px; border-top: var(--gk-border-width) solid var(--gk-border-color); background: var(--gk-surface); }
.gk-ms-row { display: flex; justify-content: space-between; margin-bottom: 15px; }
.gk-ms-total { font-size: 18px; font-weight: var(--gk-heading-weight); color: var(--gk-text); }
.gk-ms-actions { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.gk-btn { display: flex; align-items: center; justify-content: center; padding: 12px; border-radius: var(--gk-radius-md); font-weight: var(--gk-heading-weight); font-size: 13px; text-decoration: none; }
.gk-btn-primary { background: var(--gk-primary); color: var(--gk-surface); }
.gk-btn-outline { background: var(--gk-surface); border: var(--gk-border-width) solid var(--gk-border-color); color: var(--gk-text); }

.gk-mini-empty { padding: 50px 20px; text-align: center; color: var(--gk-neutral-500); }
