/**
 * Zorketing Products Grid Widget
 * Exact match: product grid.html design
 * 4-column grid · 14px radius · 18px gap · Cart + Buy Now buttons
 */

/* ── RESET & WRAPPER ── */
.zk-products-wrapper {
    position: relative !important;
    display: flow-root !important;
    width: 100% !important;
    clear: both !important;
    margin: 0 !important;
    padding: 0 0 40px 0 !important;
    box-sizing: border-box !important;
    font-family: 'Inter', sans-serif !important;
}

/* Elementor container fix */
.elementor-widget-zorketing_products,
.elementor-widget-zorketing_products .elementor-widget-container {
    display: block !important;
    height: auto !important;
    min-height: fit-content !important;
    overflow: visible !important;
}

/* ── PRODUCT GRID ── */
.zk-products-grid {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    gap: var(--zk-gap, 18px) !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

/* ── PRODUCT CARD ── */
.zk-product-card {
    background: var(--zk-card-bg, #ffffff) !important;
    border-radius: var(--zk-radius, 14px) !important;
    overflow: hidden !important;
    border: 1px solid var(--zk-border-color, #e8e3f5) !important;
    display: flex !important;
    flex-direction: column !important;
    transition: box-shadow 0.28s ease, transform 0.28s ease !important;
    position: relative !important;
}

.zk-product-card:hover {
    box-shadow: 0 10px 36px rgba(108, 34, 224, 0.12) !important;
    transform: translateY(-4px) !important;
}

/* ── IMAGE AREA ── */
.zk-card-image {
    position: relative !important;
    width: 100% !important;
    aspect-ratio: 1 / 1 !important;
    background: var(--zk-surface, #ece8f6) !important;
    overflow: hidden !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.zk-card-image a {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
}

.zk-card-image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: var(--zk-img-fit, cover) !important;
    display: block !important;
    transition: transform 0.45s ease !important;
}

.zk-product-card:hover .zk-card-image img {
    transform: scale(1.1) !important;
}

/* ── BADGE ── */
.zk-badge {
    position: absolute !important;
    top: 12px !important;
    left: 12px !important;
    font-size: 0.65rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
    padding: 4px 10px !important;
    border-radius: 6px !important;
    z-index: 2 !important;
    pointer-events: none !important;
}

.zk-badge-new {
    background: var(--zk-accent, #6c22e0) !important;
    color: #fff !important;
}

.zk-badge-sale {
    background: #c8553d !important;
    color: #fff !important;
}

.zk-badge-hot {
    background: #7c3aed !important;
    color: #fff !important;
}

/* ── CARD BODY ── */
.zk-card-body {
    padding: 16px 16px 0 !important;
    flex: 1 !important;
    display: flex !important;
    flex-direction: column !important;
}

.zk-category {
    display: block !important;
    font-size: 0.65rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase !important;
    color: var(--zk-accent, #6c22e0) !important;
    margin: 0 0 5px 0 !important;
    padding: 0 !important;
}

.zk-title-wrap {
    margin: 0 !important;
    padding: 0 !important;
    font-size: inherit !important;
    font-weight: inherit !important;
}

.zk-title {
    font-size: 0.95rem !important;
    font-weight: 600 !important;
    color: var(--zk-text-color, #1a1a1a) !important;
    line-height: 1.35 !important;
    margin-bottom: 10px !important;
    flex: 1 !important;
    text-decoration: none !important;
    display: block !important;
}

.zk-title:hover {
    color: var(--zk-accent, #6c22e0) !important;
}

/* ── PRICE ROW ── */
.zk-price-row {
    display: flex !important;
    align-items: baseline !important;
    gap: 7px !important;
    margin-bottom: 14px !important;
}

.zk-price-current {
    font-size: 1.05rem !important;
    font-weight: 700 !important;
    color: var(--zk-accent, #6c22e0) !important;
}

/* WooCommerce get_price_html() outputs <del> and <ins> tags */
.zk-price-current del {
    font-size: 0.8rem !important;
    color: var(--zk-muted, #8888a0) !important;
    text-decoration: line-through !important;
    font-weight: 400 !important;
    opacity: 0.7 !important;
}

.zk-price-current ins {
    text-decoration: none !important;
    font-weight: 700 !important;
    color: var(--zk-accent, #6c22e0) !important;
}

.zk-price-old {
    font-size: 0.8rem !important;
    color: var(--zk-muted, #8888a0) !important;
    text-decoration: line-through !important;
}

/* ── CARD ACTIONS (Cart icon 44px + Buy Now button) ── */
.zk-card-actions {
    display: grid !important;
    grid-template-columns: 44px 1fr !important;
    gap: 8px !important;
    padding: 0 16px 16px !important;
    align-items: center !important;
}

/* Cart icon button */
.zk-btn-cart {
    width: 44px !important;
    height: 44px !important;
    border-radius: 10px !important;
    border: 1.5px solid var(--zk-border-color, #e8e3f5) !important;
    background: var(--zk-surface, #ece8f6) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
    flex-shrink: 0 !important;
    padding: 0 !important;
    text-decoration: none !important;
    color: var(--zk-text-color, #1a1a1a) !important;
}

.zk-btn-cart:hover {
    background: var(--zk-accent, #6c22e0) !important;
    border-color: var(--zk-accent, #6c22e0) !important;
    transform: scale(1.05) !important;
    color: #fff !important;
}

.zk-btn-cart svg {
    width: 18px !important;
    height: 18px !important;
    transition: stroke 0.2s !important;
    stroke: currentColor !important;
}

.zk-btn-cart:hover svg {
    stroke: #fff !important;
}

/* Buy Now button */
.zk-btn-buy {
    height: 44px !important;
    border-radius: 10px !important;
    border: none !important;
    background: var(--zk-accent, #6c22e0) !important;
    color: #fff !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 0.85rem !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    letter-spacing: 0.02em !important;
    transition: background 0.2s, transform 0.15s !important;
    text-decoration: none !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.zk-btn-buy:hover {
    background: #5718c2 !important;
    transform: scale(1.02) !important;
}

.zk-btn-buy:active {
    transform: scale(0.98) !important;
}

/* ── AJAX Loading States ── */
.zk-btn-cart.zk-loading {
    pointer-events: none !important;
    opacity: 0.7 !important;
}

.zk-btn-cart.zk-loading svg {
    opacity: 0.3 !important;
}

.zk-btn-cart.zk-added {
    background: #10b981 !important;
    border-color: #10b981 !important;
    color: #fff !important;
}

.zk-btn-cart.zk-added svg {
    stroke: #fff !important;
}

.zk-spinner {
    display: inline-block !important;
    width: 16px !important;
    height: 16px !important;
    border: 2px solid currentColor !important;
    border-right-color: transparent !important;
    border-radius: 50% !important;
    animation: zk-spin 0.6s linear infinite !important;
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    margin: -8px 0 0 -8px !important;
}

@keyframes zk-spin {
    to {
        transform: rotate(360deg);
    }
}

/* ── PAGINATION ── */
.zk-pagination {
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 6px !important;
    margin-top: 48px !important;
}

.zk-pagination a,
.zk-pagination span {
    width: 38px !important;
    height: 38px !important;
    border-radius: 9px !important;
    border: 1.5px solid var(--zk-border-color, #e8e3f5) !important;
    background: #fff !important;
    color: var(--zk-text-color, #1a1a1a) !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 0.85rem !important;
    font-weight: 500 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-decoration: none !important;
    transition: all 0.2s !important;
    cursor: pointer !important;
}

.zk-pagination a:hover,
.zk-pagination span.current {
    background: var(--zk-accent, #6c22e0) !important;
    border-color: var(--zk-accent, #6c22e0) !important;
    color: #fff !important;
}

/* ── FOOTER FIX ── */
.elementor-location-footer {
    clear: both !important;
    position: relative !important;
    z-index: 10 !important;
}

/* ═══════════════════════════════════════════ */
/*  RESPONSIVE BREAKPOINTS                     */
/* ═══════════════════════════════════════════ */

@media (max-width: 1200px) {
    .zk-products-grid {
        grid-template-columns: repeat(3, 1fr) !important;
    }
}

@media (max-width: 900px) {
    .zk-products-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 14px !important;
    }
}

@media (max-width: 540px) {
    .zk-products-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 10px !important;
    }

    .zk-card-body {
        padding: 12px 12px 0 !important;
    }

    .zk-card-actions {
        padding: 0 12px 12px !important;
        gap: 6px !important;
        grid-template-columns: 38px 1fr !important;
    }

    .zk-title {
        font-size: 0.82rem !important;
    }

    .zk-price-current {
        font-size: 0.95rem !important;
    }

    .zk-btn-cart {
        width: 38px !important;
        height: 38px !important;
    }

    .zk-btn-buy {
        height: 38px !important;
        font-size: 0.78rem !important;
    }
}

@media (max-width: 360px) {
    .zk-products-grid {
        grid-template-columns: 1fr !important;
    }
}