.jwa-root { --jwa-sidebar: 25%; }
.jwa-wrap { display: flex; gap: 24px; align-items: flex-start; }
.jwa-sidebar { flex: 0 0 var(--jwa-sidebar); max-width: var(--jwa-sidebar); position: sticky; top: 20px; }
.jwa-main { flex: 1 1 auto; min-width: 0; }

.jwa-search-wrap { margin-bottom: 12px; }
.jwa-search {
    width: 100%; padding: 10px 12px; border: 1px solid #ddd;
    border-radius: 6px; font-size: 14px; box-sizing: border-box;
}
.jwa-search:focus { outline: none; border-color: #555; }

.jwa-cats { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.jwa-cat {
    width: 100%; display: flex; justify-content: space-between; align-items: center;
    padding: 8px 12px; background: transparent; border: 0; cursor: pointer;
    text-align: left; border-radius: 6px; font: inherit; color: inherit;
    transition: background .15s ease;
}
.jwa-cat:hover { background: #f3f3f3; }
.jwa-cat.is-active { background: #111; color: #fff; }
.jwa-cat__count { opacity: .7; margin-left: 8px; font-variant-numeric: tabular-nums; }

.jwa-mobile-toggle { display: none; }

.jwa-toolbar { display: flex; justify-content: flex-end; margin-bottom: 12px; }
.jwa-count { font-size: 14px; opacity: .75; }

.jwa-results { position: relative; min-height: 120px; }
.jwa-results.is-loading::before {
    content: ""; position: absolute; inset: 0;
    background: rgba(255,255,255,.55); z-index: 2;
    backdrop-filter: blur(1px);
    transition: opacity .15s ease;
}
.jwa-results.is-loading::after {
    content: ""; position: absolute; top: 50%; left: 50%;
    width: 32px; height: 32px; margin: -16px 0 0 -16px; z-index: 3;
    border: 3px solid rgba(0,0,0,.12);
    border-top-color: #111;
    border-radius: 50%;
    animation: jwa-spin .6s linear infinite;
}
@keyframes jwa-spin { to { transform: rotate(360deg); } }
.jwa-loading { padding: 30px; text-align: center; opacity: .6; }
.jwa-empty { padding: 30px; text-align: center; opacity: .7; }

/* subtle stagger fade-up on product cards */
@keyframes jwa-in {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: none; }
}
.jwa-grid .jwa-card {
    opacity: 0;
    animation: jwa-in .28s cubic-bezier(.2,.7,.3,1) forwards;
}
@media (prefers-reduced-motion: reduce) {
    .jwa-grid .jwa-card { animation: none; opacity: 1; }
}

.jwa-grid {
    display: grid; gap: 24px;
    grid-template-columns: repeat(var(--jwa-cols, 3), minmax(0, 1fr));
}

.jwa-card {
    display: flex; flex-direction: column; background: #fff;
    border: 1px solid #eee; border-radius: 8px; overflow: hidden;
    transition: transform .15s ease, box-shadow .15s ease;
    background: linear-gradient(57.8deg, #C88A6120 50%, #FFF 50%) !important;
    border-radius: 25px;
}
.jwa-card:hover { transform: translateY(-2px); box-shadow: 0 6px 18px rgba(0,0,0,.06); }
.jwa-card__img { display: block; padding: 15px 15px 0;}
.jwa-card__img img { 
    width: 100%; 
    height: 250px; 
    object-fit: contain;
    object-position: center;
    display: block; 
}
.jwa-card__body { display: flex; flex-direction: column; gap: 8px; padding: 14px; }
.jwa-card__title { font-weight: 600; text-decoration: none; color: inherit; line-height: 1.3; }
.jwa-card__price { font-weight: 700; }
.jwa-card__price del { opacity: .5; margin-right: 6px; font-weight: 400; }
.jwa-root .jwa-card .jwa-card__btn,
.jwa-root .jwa-card a.jwa-card__btn {
    display: inline-flex !important;
    align-items: center; justify-content: center;
    margin: 0 14px 14px; padding: 10px 14px; border: 0; border-radius: 6px;
    color: #fff !important; text-decoration: none !important;
    cursor: pointer;
    font-weight: 600; font-size: 14px; line-height: 1.4;
    transition: background .15s ease, color .15s ease, filter .15s ease;
    align-self: stretch;
    text-indent: 0; visibility: visible; opacity: 1;
    width: auto; height: auto; min-height: 0;
}
/* Default gradient — applied via class so Elementor controls (lower spec) can override */
.jwa-card__btn { background-image: linear-gradient(90deg, rgb(229,178,79) 0%, rgb(195,140,33) 100%);     margin: auto 15px 15px!important;}
.jwa-root .jwa-card .jwa-card__btn:hover { filter: brightness(0.92); color: #fff !important; }
.jwa-root .jwa-card .jwa-card__btn::before,
.jwa-root .jwa-card .jwa-card__btn::after { content: none !important; display: none !important; }
.jwa-root .jwa-card .jwa-card__btn.added { display: inline-flex !important; }

/* Beat global theme rule: a.button.product_type_simple.add_to_cart_button.ajax_add_to_cart */
.jwa-root a.jwa-card__btn.product_type_simple.add_to_cart_button.ajax_add_to_cart,
.jwa-root a.jwa-card__btn.add_to_cart_button {
    font-size: 14px !important;
    line-height: 1.4 !important;
}
.jwa-root a.jwa-card__btn.product_type_simple.add_to_cart_button.ajax_add_to_cart::before,
.jwa-root a.jwa-card__btn.product_type_simple.add_to_cart_button.ajax_add_to_cart::after,
.jwa-root a.jwa-card__btn.add_to_cart_button::before,
.jwa-root a.jwa-card__btn.add_to_cart_button::after {
    content: none !important;
    display: none !important;
}

/* Loading spinner — match full theme-chain spec so ::before:none doesn't kill it */
.jwa-root a.jwa-card__btn.jwa-is-loading,
.jwa-root a.jwa-card__btn.add_to_cart_button.jwa-is-loading,
.jwa-root a.jwa-card__btn.product_type_simple.add_to_cart_button.ajax_add_to_cart.jwa-is-loading {
    pointer-events: none; opacity: 0.85;
}
.jwa-root a.jwa-card__btn.jwa-is-loading::before,
.jwa-root a.jwa-card__btn.add_to_cart_button.jwa-is-loading::before,
.jwa-root a.jwa-card__btn.product_type_simple.add_to_cart_button.ajax_add_to_cart.jwa-is-loading::before {
    content: "" !important;
    display: inline-block !important;
    width: 14px; height: 14px; margin-right: 8px;
    border: 2px solid currentColor; border-top-color: transparent;
    border-radius: 50%;
    animation: jwa-spin .6s linear infinite;
    vertical-align: middle;
}

/* View Cart link — inherits .jwa-card__btn styling (gradient, padding, radius, etc) via shared class */
.jwa-card .jwa-view-cart {
    margin-top: 6px;
    opacity: 0;
    transform: translateY(-4px);
    animation: jwa-vc-in .25s cubic-bezier(.2,.7,.3,1) forwards;
}
@keyframes jwa-vc-in {
    to { opacity: 1; transform: none; }
}

.jwa-pagination { display: flex; gap: 4px; justify-content: center; margin-top: 24px; flex-wrap: wrap; }
.jwa-pg {
    min-width: 36px; height: 36px; padding: 0 10px;
    border: 1px solid #ddd; background: #fff; cursor: pointer;
    border-radius: 6px; font: inherit;
}
.jwa-pg:hover:not(:disabled):not(.jwa-pg--active) { background: #f3f3f3; }
.jwa-pg--active { background: #111; color: #fff; border-color: #111; }
.jwa-pg:disabled { opacity: .4; cursor: not-allowed; }
.jwa-pg--gap { border: 0; background: transparent; cursor: default; }

.jwa-hide-count-d .jwa-count { display: none; }

/* sidebar removed — main takes full width, search lives in toolbar */
.jwa-no-sidebar .jwa-main { flex: 1 1 100%; max-width: 100%; width: 100%; }
.jwa-no-sidebar .jwa-toolbar {
    display: flex; align-items: center; gap: 16px;
    justify-content: space-between!important; margin-bottom: 16px;
}
.jwa-no-sidebar .jwa-toolbar .jwa-search-wrap {
    flex: 0 1 360px; margin-bottom: 0;
}
.jwa-no-sidebar .jwa-toolbar .jwa-search { width: 100%; }

/* categories list hidden, sidebar keeps only search */
.jwa-no-cats .jwa-cats,
.jwa-no-cats .jwa-mobile-toggle { display: none !important; }

/* mobile */
@media (max-width: 767px) {
    .jwa-wrap { flex-direction: column; }
    .jwa-sidebar { position: static; flex: 1 1 auto; max-width: 100%; width: 100%; }
    .jwa-search-wrap { display: block; width: 100%; }

    .jwa-mobile-toggle {
        display: flex; width: 100%; justify-content: space-between; align-items: center;
        padding: 10px 12px; background: #f5f5f5; border: 1px solid #ddd;
        border-radius: 6px; cursor: pointer; font: inherit; margin-bottom: 0;
    }
    .jwa-mobile-toggle__arrow { transition: transform .2s ease; }
    .jwa-mobile-toggle[aria-expanded="true"] .jwa-mobile-toggle__arrow { transform: rotate(180deg); }

    .jwa-cats {
        display: none; margin-top: 6px; padding: 6px;
        border: 1px solid #eee; border-radius: 6px; background: #fff;
        max-height: 320px; overflow: auto;
    }
    .jwa-cats.is-open { display: flex; }

    .jwa-hide-count-m .jwa-count { display: none; }

    .jwa-no-sidebar .jwa-toolbar { flex-direction: column; align-items: stretch; gap: 10px; }
    .jwa-no-sidebar .jwa-toolbar .jwa-search-wrap { flex: 1 1 100%; }
}
