/* =============================================
   Products Grid Widget v2.0 — Fully Scoped
   ============================================= */

.pgw-wrapper {
    --pgw-green:      #2D5A1B;
    --pgw-green-mid:  #3d7a25;
    --pgw-green-glow: rgba(45,90,27,0.22);
    --pgw-radius:     18px;
    --pgw-ease:       cubic-bezier(0.34, 1.56, 0.64, 1);
    --pgw-ease-soft:  cubic-bezier(0.25, 0.46, 0.45, 0.94);

    width: 100%;
    font-family: 'DM Sans', 'Segoe UI', system-ui, sans-serif;
    box-sizing: border-box;
}

.pgw-wrapper *,
.pgw-wrapper *::before,
.pgw-wrapper *::after {
    box-sizing: border-box;
}

/* ===== Filter Bar ===== */
.pgw-wrapper .pgw-filter-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 32px;
    align-items: center;
}

.pgw-wrapper .pgw-filter-btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 9px 22px;
    border-radius: 50px;
    border: 1.5px solid #e0e0e0;
    background: #ffffff;
    color: #444;
    font-family: inherit;
    font-size: 13.5px;
    font-weight: 500;
    letter-spacing: 0.01em;
    cursor: pointer;
    outline: none;
    user-select: none;
    overflow: hidden;
    line-height: 1.4;
    text-decoration: none;
    text-transform: none;
    margin: 0;
    transition:
        background-color 0.28s ease,
        color            0.28s ease,
        border-color     0.28s ease,
        box-shadow       0.28s ease,
        transform        0.2s cubic-bezier(0.34,1.56,0.64,1);
}

.pgw-wrapper .pgw-filter-btn:hover {
    transform: translateY(-2px);
    border-color: #c0c0c0;
    box-shadow: 0 4px 14px rgba(0,0,0,0.09);
    background: #ffffff;
    color: #444;
}

.pgw-wrapper .pgw-filter-btn:focus {
    outline: 2px solid var(--pgw-green);
    outline-offset: 2px;
}

.pgw-wrapper .pgw-filter-btn:active {
    transform: scale(0.95) !important;
    transition-duration: 0.1s;
}

.pgw-wrapper .pgw-filter-btn.active {
    background: linear-gradient(135deg, var(--pgw-green) 0%, var(--pgw-green-mid) 100%);
    color: #fff !important;
    border-color: transparent;
    box-shadow: 0 4px 18px var(--pgw-green-glow);
    transform: translateY(-1px);
}

/* Ripple */
.pgw-wrapper .pgw-filter-btn.pgw-ripple::before {
    content: '';
    position: absolute;
    width: 200%;
    height: 200%;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%) scale(0);
    background: rgba(255,255,255,0.28);
    border-radius: 50%;
    animation: pgw-ripple-anim 0.5s ease-out forwards;
    pointer-events: none;
}

/* ===== Keyframes ===== */
@keyframes pgw-ripple-anim {
    to { transform: translate(-50%,-50%) scale(1); opacity: 0; }
}

@keyframes pgw-shimmer-anim {
    0%   { background-position: -400px 0; }
    100% { background-position:  400px 0; }
}

@keyframes pgw-card-out {
    to { opacity: 0; transform: translateY(8px) scale(0.96); }
}

@keyframes pgw-card-in {
    from { opacity: 0; transform: translateY(18px) scale(0.96); }
    to   { opacity: 1; transform: translateY(0)    scale(1); }
}

@keyframes pgw-card-enter {
    from { opacity: 0; transform: translateY(28px) scale(0.94); }
    to   { opacity: 1; transform: translateY(0)    scale(1); }
}

/* ===== Grid ===== */
.pgw-wrapper .pgw-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 22px;
    align-items: start;
}

/* ===== Card ===== */
.pgw-wrapper .pgw-card {
    background: #ffffff;
    border-radius: var(--pgw-radius);
    overflow: visible;
    text-decoration: none !important;
    color: inherit;
    display: block;
    cursor: pointer;
    position: relative;
    box-shadow: 0 2px 14px rgba(0,0,0,0.07);
    border: 1px solid rgba(0,0,0,0.06);
    transition:
        transform  0.42s var(--pgw-ease),
        box-shadow 0.42s var(--pgw-ease-soft);
    will-change: transform;
}

.pgw-wrapper .pgw-card-inner {
    border-radius: var(--pgw-radius);
    overflow: hidden;
}

.pgw-wrapper .pgw-card:hover {
    transform: translateY(-7px) scale(1.012);
    box-shadow: 0 20px 55px rgba(0,0,0,0.14);
}

/* Shine */
.pgw-wrapper .pgw-card::before {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: var(--pgw-radius);
    background: linear-gradient(135deg, rgba(255,255,255,0.1) 0%, transparent 55%);
    opacity: 0;
    transition: opacity 0.3s ease;
    pointer-events: none;
    z-index: 1;
}
.pgw-wrapper .pgw-card:hover::before { opacity: 1; }

/* ===== Card Image Wrap — يستخدم <img> دلوقتي ===== */
.pgw-wrapper .pgw-card-image-wrap {
    position: relative;
    overflow: hidden;
    border-radius: var(--pgw-radius) var(--pgw-radius) 0 0;
    height: 210px; /* fallback — بيتغير من Elementor */
    background-color: #f0f0f0;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ⬇️ الصورة دلوقتي <img> بدل background — أفضل لـ SEO والـ accessibility */
.pgw-wrapper .pgw-card-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    transform: scale(1);
    transition: transform 0.7s var(--pgw-ease-soft);
    will-change: transform;
}

.pgw-wrapper .pgw-card:hover .pgw-card-image {
    transform: scale(1.08);
}

/* Shimmer — على <img> */
.pgw-wrapper .pgw-card-image.pgw-shimmer {
    opacity: 0;
    transition: opacity 0.3s ease;
}
.pgw-wrapper .pgw-card-image:not(.pgw-shimmer) {
    opacity: 1;
}

/* Placeholder shimmer على الـ wrap لما مفيش صورة بعد ما تتحمل */
.pgw-wrapper .pgw-card-image-wrap.pgw-loading::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: linear-gradient(
        90deg,
        #ebebeb 0px,
        #f7f7f7 80px,
        #ebebeb 160px
    );
    background-size: 400px 100%;
    animation: pgw-shimmer-anim 1.6s infinite linear;
}

/* Badge */
.pgw-wrapper .pgw-cat-badge {
    position: absolute;
    bottom: 10px;
    left: 10px;
    background: rgba(255,255,255,0.88);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-radius: 50px;
    padding: 4px 11px;
    font-size: 10.5px;
    font-weight: 600;
    color: var(--pgw-green);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    opacity: 0;
    transform: translateY(7px);
    transition: opacity 0.28s ease, transform 0.32s var(--pgw-ease);
    pointer-events: none;
    z-index: 2;
}
.pgw-wrapper .pgw-card:hover .pgw-cat-badge {
    opacity: 1;
    transform: translateY(0);
}

/* ===== Card Body ===== */
.pgw-wrapper .pgw-card-body {
    padding: 14px 16px 17px;
    word-break: break-word;
}

.pgw-wrapper .pgw-product-name {
    font-size: 16px;
    font-weight: 700;
    color: #181818;
    margin: 0 0 6px;
    line-height: 1.35;
    letter-spacing: -0.01em;
    transition: color 0.22s ease;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.pgw-wrapper .pgw-card:hover .pgw-product-name {
    color: var(--pgw-green);
}

.pgw-wrapper .pgw-product-cat {
    font-size: 12.5px;
    font-weight: 500;
    color: #adadad;
    letter-spacing: 0.02em;
    display: flex;
    align-items: center;
    gap: 6px;
}
.pgw-wrapper .pgw-product-cat::before {
    content: '';
    width: 5px;
    height: 5px;
    min-width: 5px;
    border-radius: 50%;
    background: var(--pgw-green);
    opacity: 0.5;
    flex-shrink: 0;
}

/* ===== Filter / Animation States ===== */
.pgw-wrapper .pgw-card.pgw-hidden  { display: none !important; }
.pgw-wrapper .pgw-card.pgw-out     { animation: pgw-card-out   0.26s var(--pgw-ease-soft) both; pointer-events: none; }
.pgw-wrapper .pgw-card.pgw-in      { animation: pgw-card-in    0.44s var(--pgw-ease) both; }
.pgw-wrapper .pgw-card.pgw-enter   { animation: pgw-card-enter 0.58s var(--pgw-ease) both; }
.pgw-wrapper .pgw-card.pgw-reveal  { opacity: 0; transform: translateY(28px) scale(0.94); }

/* ===== Responsive ===== */
@media (max-width: 1280px) {
    .pgw-wrapper .pgw-grid { gap: 18px; }
}

@media (max-width: 1024px) {
    .pgw-wrapper .pgw-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 18px;
    }
    .pgw-wrapper .pgw-card-image-wrap { height: 190px; }
}

@media (max-width: 768px) {
    .pgw-wrapper .pgw-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 14px;
    }
    .pgw-wrapper .pgw-card-image-wrap  { height: 165px; }
    .pgw-wrapper .pgw-product-name     { font-size: 14.5px; }
    .pgw-wrapper .pgw-card-body        { padding: 12px 13px 14px; }
    .pgw-wrapper .pgw-card:hover {
        transform: translateY(-4px) scale(1.008);
        box-shadow: 0 12px 30px rgba(0,0,0,0.11);
    }
}

@media (max-width: 576px) {
    .pgw-wrapper .pgw-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px;
    }
    .pgw-wrapper .pgw-filter-bar      { gap: 8px; }
    .pgw-wrapper .pgw-filter-btn      { padding: 8px 16px; font-size: 12.5px; }
    .pgw-wrapper .pgw-card-image-wrap  { height: 150px; }
    .pgw-wrapper .pgw-product-name     { font-size: 13.5px; }
    .pgw-wrapper .pgw-cat-badge        { font-size: 9.5px; padding: 3px 9px; }
}

@media (max-width: 420px) {
    .pgw-wrapper .pgw-grid {
        grid-template-columns: 1fr;
        gap: 14px;
    }
    .pgw-wrapper .pgw-card-image-wrap  { height: 200px; }
    .pgw-wrapper .pgw-product-name     { font-size: 16px; }
    .pgw-wrapper .pgw-card-body        { padding: 14px 16px 16px; }
}

/* Touch devices */
@media (hover: none) {
    .pgw-wrapper .pgw-card:hover {
        transform: none;
        box-shadow: 0 2px 14px rgba(0,0,0,0.07);
    }
    .pgw-wrapper .pgw-card:hover .pgw-card-image { transform: scale(1); }
    .pgw-wrapper .pgw-cat-badge                  { display: none; }
    .pgw-wrapper .pgw-card:hover .pgw-product-name { color: #181818; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    .pgw-wrapper .pgw-card,
    .pgw-wrapper .pgw-card-image,
    .pgw-wrapper .pgw-filter-btn,
    .pgw-wrapper .pgw-cat-badge {
        transition: none !important;
        animation: none !important;
    }
    .pgw-wrapper .pgw-card.pgw-reveal,
    .pgw-wrapper .pgw-card.pgw-enter,
    .pgw-wrapper .pgw-card.pgw-in {
        opacity: 1 !important;
        transform: none !important;
    }
    .pgw-wrapper .pgw-card-image {
        opacity: 1 !important;
    }
}

/* =============================================
   Image Options — Overlay & Hover Effects
   ============================================= */

/* Overlay — via ::after على الـ wrap */
.pgw-wrapper .pgw-card-image-wrap::after {
    content: '';
    position: absolute;
    inset: 0;
    pointer-events: none;
    z-index: 1;
    opacity: 0;           /* default: مخفي — بيتغير من Elementor */
    background-color: transparent;
    transition: opacity 0.3s ease;
}

/* ===== Hover Effects ===== */

/* Zoom (default) — موجود بالفعل في CSS الأساسي */
.pgw-wrapper.pgw-hover-zoom .pgw-card:hover .pgw-card-image {
    transform: scale(1.08);
}

/* Fade — الصورة بتخف */
.pgw-wrapper.pgw-hover-fade .pgw-card-image {
    transition: opacity 0.4s ease, transform 0s;
}
.pgw-wrapper.pgw-hover-fade .pgw-card:hover .pgw-card-image {
    opacity: 0.6;
    transform: none;
}

/* Slide Up — الصورة بتتحرك لأعلى */
.pgw-wrapper.pgw-hover-slide-up .pgw-card-image {
    transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.pgw-wrapper.pgw-hover-slide-up .pgw-card:hover .pgw-card-image {
    transform: translateY(-8px) scale(1.02);
}

/* None — بلا تأثير */
.pgw-wrapper.pgw-hover-none .pgw-card-image {
    transition: none;
}
.pgw-wrapper.pgw-hover-none .pgw-card:hover .pgw-card-image {
    transform: none;
}

/* ===== Image padding support =====
   لو فيه padding على الـ wrap، الصورة تاخد 100% من المساحة المتبقية */
.pgw-wrapper .pgw-card-image-wrap > img.pgw-card-image {
    width: 100%;
    height: 100%;
    display: block;
}
