/* ══════════════════════════════════════════════════════════════════════
   BEP – Bulk Edit Products for WooCommerce
   Custom Design System — Zero @wordpress/components dependency
   ══════════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

/* ── Variables ─────────────────────────────────────────────────────── */
:root {
    --bep-font: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;
    --bep-bg: #F8FAFC;
    --bep-surface: #FFFFFF;
    --bep-border: #E2E8F0;
    --bep-border-focus: #6366F1;

    --bep-text-primary: #0F172A;
    --bep-text-secondary: #475569;
    --bep-text-muted: #94A3B8;

    --bep-primary: #6366F1;
    --bep-primary-hover: #4F46E5;
    --bep-primary-light: #EEF2FF;
    --bep-primary-text: #FFFFFF;

    --bep-success: #10B981;
    --bep-success-bg: #ECFDF5;
    --bep-warning: #F59E0B;
    --bep-warning-bg: #FFFBEB;
    --bep-danger: #EF4444;
    --bep-danger-hover: #DC2626;
    --bep-danger-bg: #FEF2F2;
    --bep-info-bg: #EFF6FF;

    --bep-support: #0EA5E9;
    --bep-support-hover: #0284C7;

    --bep-modified: #FFF7ED;
    --bep-modified-border: #FDBA74;
    --bep-modified-dot: #F97316;

    --bep-radius-sm: 6px;
    --bep-radius: 8px;
    --bep-radius-lg: 12px;
    --bep-radius-xl: 16px;

    --bep-shadow-sm: 0 1px 3px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04);
    --bep-shadow: 0 4px 16px rgba(15,23,42,.08), 0 2px 4px rgba(15,23,42,.04);
    --bep-shadow-lg: 0 20px 60px rgba(15,23,42,.14), 0 8px 24px rgba(15,23,42,.08);

    --bep-transition: 150ms cubic-bezier(.4,0,.2,1);
}

/* ── Reset / Scope ─────────────────────────────────────────────────── */
.bep-app, .bep-modal-backdrop {
    font-family: var(--bep-font);
    font-size: 13px;
    color: var(--bep-text-primary);
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}

.bep-app *, .bep-modal-backdrop * { box-sizing: border-box; }

/* ── App Shell ─────────────────────────────────────────────────────── */
/*
  LAYOUT:
    .bep-app          = full-height flex column (fills WP admin content area)
    .bep-header       = sticky top toolbar
    .bep-notice       = sticky just below header (when visible)
    .bep-topbar       = sticky pagination + selection bar (just below header)
    .bep-content      = flex:1, overflow-y:auto → only this scrolls
    .bep-table thead  = sticky inside scroll container
*/
.bep-app {
    background: var(--bep-bg);
    display: flex;
    flex-direction: column;
    position: relative;
    z-index: 99;
    height: 100%;
}

/* ── Header ────────────────────────────────────────────────────────── */
.bep-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 12px 20px;
    background: var(--bep-surface);
    border-bottom: 1px solid var(--bep-border);
    box-shadow: var(--bep-shadow-sm);
    flex-shrink: 0; /* never shrink */
    flex-wrap: wrap;
    z-index: 100;
}

.bep-header__brand {
    display: flex;
    align-items: center;
    gap: 10px;
}

.bep-header__logo {
    width: 36px;
    height: 36px;
    border-radius: var(--bep-radius);
    background: var(--bep-primary-light);
    color: var(--bep-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.bep-header__title {
    font-size: 15px;
    font-weight: 700;
    color: var(--bep-text-primary);
    margin: 0;
    line-height: 1.2;
}

.bep-header__sub {
    font-size: 11px;
    color: var(--bep-text-muted);
    font-weight: 500;
    display: block;
}

/* ── Toolbar ───────────────────────────────────────────────────────── */
.bep-toolbar {
    display: flex;
    align-items: center;
    gap: 4px;
    flex-wrap: wrap;
}

.bep-toolbar__divider {
    width: 1px;
    height: 20px;
    background: var(--bep-border);
    margin: 0 6px;
}

/* ── Buttons ───────────────────────────────────────────────────────── */
.bep-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--bep-font);
    font-size: 12.5px;
    font-weight: 600;
    line-height: 1;
    border: none;
    border-radius: var(--bep-radius);
    cursor: pointer;
    transition: background var(--bep-transition), box-shadow var(--bep-transition), transform var(--bep-transition), opacity var(--bep-transition);
    white-space: nowrap;
    padding: 7px 13px;
    gap: 4px;
    text-decoration: none;
}

.bep-btn:focus-visible { outline: 2px solid var(--bep-border-focus); outline-offset: 2px; }
.bep-btn:active:not(:disabled) { transform: scale(.97); }

.bep-btn--md { padding: 7px 13px; font-size: 12.5px; }
.bep-btn--sm { padding: 5px 10px; font-size: 11.5px; }
.bep-btn--lg { padding: 10px 18px; font-size: 13.5px; }

/* Primary */
.bep-btn--primary { background: var(--bep-primary); color: #fff; box-shadow: 0 1px 3px rgba(99,102,241,.3); }
.bep-btn--primary:hover:not(:disabled) { background: var(--bep-primary-hover); box-shadow: 0 4px 12px rgba(99,102,241,.35); }

/* Ghost */
.bep-btn--ghost { background: transparent; color: var(--bep-text-secondary); border: 1px solid var(--bep-border); }
.bep-btn--ghost:hover:not(:disabled) { background: var(--bep-bg); color: var(--bep-text-primary); border-color: #CBD5E1; }

/* Danger */
.bep-btn--danger { background: var(--bep-danger-bg); color: var(--bep-danger); border: 1px solid #FECACA; }
.bep-btn--danger:hover:not(:disabled) { background: var(--bep-danger); color: #fff; border-color: var(--bep-danger); }

/* Support */
.bep-btn--support { background: var(--bep-support); color: #fff; }
.bep-btn--support:hover:not(:disabled) { background: var(--bep-support-hover); }

.bep-btn--disabled { opacity: .45; cursor: not-allowed; transform: none !important; }

/* ── Badge ─────────────────────────────────────────────────────────── */
.bep-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 16px;
    height: 16px;
    padding: 0 4px;
    border-radius: 99px;
    background: rgba(255,255,255,.28);
    color: inherit;
    font-size: 10px;
    font-weight: 700;
    margin-left: 4px;
    border: 1px solid rgba(255,255,255,.35);
    line-height: 1;
}
.bep-btn--ghost .bep-badge { background: var(--bep-primary-light); color: var(--bep-primary); border-color: transparent; }

/* ── Spinner ───────────────────────────────────────────────────────── */
.bep-spinner {
    display: inline-block;
    border-radius: 50%;
    border: 2px solid rgba(99,102,241,.2);
    border-top-color: var(--bep-primary);
    animation: bep-spin .6s linear infinite;
    flex-shrink: 0;
}
@keyframes bep-spin { to { transform: rotate(360deg); } }

/* ── Notice ────────────────────────────────────────────────────────── */
.bep-notice {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 9px 20px;
    font-size: 13px;
    font-weight: 500;
    flex-shrink: 0;
    animation: bep-slideDown .2s ease;
}
@keyframes bep-slideDown { from { opacity:0; transform:translateY(-6px); } to { opacity:1; transform:none; } }
.bep-notice--success { background: var(--bep-success-bg); color: #065F46; border-bottom: 2px solid var(--bep-success); }
.bep-notice--error   { background: var(--bep-danger-bg);  color: #991B1B; border-bottom: 2px solid var(--bep-danger); }
.bep-notice--info    { background: var(--bep-info-bg);    color: #1E40AF; border-bottom: 2px solid #3B82F6; }

/* ── Content Area (ONLY scrolling zone — thead stays sticky inside) ── */
.bep-content {
    flex: 1 1 0%;
    min-height: 0;
    min-width: 0;
    padding: 0;
    scrollbar-width: auto;
    scrollbar-color: #94A3B8 #F1F5F9;
    overflow-y: scroll;
    overflow-x: scroll;
}
.bep-content::-webkit-scrollbar { width: 10px; height: 10px; }
.bep-content::-webkit-scrollbar-track { background: #F1F5F9; }
.bep-content::-webkit-scrollbar-thumb { background: #94A3B8; border-radius: 99px; border: 2px solid #F1F5F9; }
.bep-content::-webkit-scrollbar-thumb:hover { background: #64748B; }
.bep-content::-webkit-scrollbar-corner { background: #F1F5F9; }

/* ── Loading State ─────────────────────────────────────────────────── */
.bep-loading-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 80px 20px;
    color: var(--bep-text-muted);
    font-size: 13px;
}

/* ── Empty State ───────────────────────────────────────────────────── */
.bep-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 80px 20px;
    color: var(--bep-text-muted);
    font-size: 14px;
}

/* ── Top bar (pagination + selection) — sticky below header ─────────── */
.bep-topbar {
    display: flex;
    align-items: center;
    gap: 0;
    flex-shrink: 0;
    border-bottom: 1px solid var(--bep-border);
    background: var(--bep-surface);
    box-shadow: 0 1px 4px rgba(15,23,42,.04);
}

/* ── Pagination ────────────────────────────────────────────────────── */
.bep-pagination {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 8px 16px;
    background: var(--bep-surface);
    gap: 10px;
    flex-shrink: 0;
    border-right: 1px solid var(--bep-border);
    flex-wrap: wrap;
}

.bep-pagination__info {
    font-size: 12.5px;
    color: var(--bep-text-muted);
}

.bep-pagination__info strong {
    color: var(--bep-text-secondary);
    font-weight: 600;
}

.bep-pagination__controls {
    display: flex;
    align-items: center;
    gap: 4px;
}

.bep-page-btn {
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 500;
    font-family: var(--bep-font);
    border: 1px solid var(--bep-border);
    border-radius: var(--bep-radius-sm);
    background: transparent;
    color: var(--bep-text-secondary);
    cursor: pointer;
    transition: all var(--bep-transition);
}
.bep-page-btn:hover { background: var(--bep-bg); border-color: #CBD5E1; }
.bep-page-btn--active { background: var(--bep-primary); color: #fff; border-color: var(--bep-primary); font-weight: 700; }

/* ── Table ─────────────────────────────────────────────────────────── */
.bep-table-wrapper {
    display: inline-block; /* shrink-wraps to table width, wider than 100% when needed */
    min-width: 100%;
    vertical-align: top;
}

.bep-table {
    width: max-content;   /* exactly as wide as all columns need */
    min-width: 100%;
    border-collapse: collapse;
    font-size: 12.5px;
    table-layout: auto;
}

.bep-table thead {
    position: sticky;
    top: 0;
    z-index: 20; /* above cell content */
}

.bep-table th {
    padding: 9px 12px;
    text-align: left;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .04em;
    text-transform: uppercase;
    color: var(--bep-text-muted);
    background: #F1F5F9;
    border-bottom: 2px solid var(--bep-border);
    white-space: nowrap;
    user-select: none;
}

.bep-table th span { display: block; }

.bep-td {
    padding: 0;
    border-bottom: 1px solid var(--bep-border);
    border-right: 1px solid #F1F5F9;
    vertical-align: middle;
    position: relative;
    transition: background var(--bep-transition);
}

.bep-tr--odd .bep-td { background: var(--bep-surface); }
.bep-tr--even .bep-td { background: #FAFBFC; }

.bep-table tr:hover .bep-td { background: #F0F4FF !important; }

.bep-td--modified { background: var(--bep-modified) !important; border-bottom-color: var(--bep-modified-border); }

.bep-modified-dot {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: var(--bep-modified-dot);
    z-index: 1;
}

/* ── Cell Inputs ───────────────────────────────────────────────────── */
.bep-cell-input {
    width: 100%;
    padding: 7px 10px;
    border: none;
    background: transparent;
    font-family: var(--bep-font);
    font-size: 12.5px;
    color: var(--bep-text-primary);
    display: block;
}
.bep-cell-input:focus {
    outline: none;
    background: #fff;
    box-shadow: inset 0 0 0 2px var(--bep-primary);
}

.bep-cell-select-wrap { position: relative; }
.bep-cell-select {
    width: 100%;
    padding: 7px 24px 7px 10px;
    border: none;
    background: transparent;
    font-family: var(--bep-font);
    font-size: 12.5px;
    color: var(--bep-text-primary);
    cursor: pointer;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}
.bep-cell-select:focus { outline: none; background: #fff; box-shadow: inset 0 0 0 2px var(--bep-primary); }

/* Toggle switch in cells */
.bep-cell-toggle {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 6px;
    cursor: pointer;
}
.bep-cell-toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
.bep-toggle-track {
    width: 32px;
    height: 18px;
    border-radius: 99px;
    background: #CBD5E1;
    position: relative;
    transition: background var(--bep-transition);
    display: block;
}
.bep-cell-toggle input:checked + .bep-toggle-track,
.bep-filter-toggle input:checked + .bep-toggle-track { background: var(--bep-primary); }
.bep-toggle-thumb {
    position: absolute;
    top: 2px; left: 2px;
    width: 14px; height: 14px;
    border-radius: 50%;
    background: #fff;
    box-shadow: 0 1px 3px rgba(0,0,0,.2);
    transition: transform var(--bep-transition);
    display: block;
}
.bep-cell-toggle input:checked ~ .bep-toggle-track .bep-toggle-thumb,
.bep-filter-toggle input:checked + .bep-toggle-track .bep-toggle-thumb { transform: translateX(14px); }

/* Edit buttons in cells */
.bep-edit-btn {
    display: inline-flex;
    align-items: center;
    font-family: var(--bep-font);
    font-size: 11.5px;
    font-weight: 600;
    color: var(--bep-primary);
    background: var(--bep-primary-light);
    border: none;
    border-radius: var(--bep-radius-sm);
    padding: 4px 9px;
    cursor: pointer;
    transition: all var(--bep-transition);
    margin: 4px;
    white-space: nowrap;
}
.bep-edit-btn:hover { background: var(--bep-primary); color: #fff; }
.bep-edit-count {
    margin-left: 5px;
    background: rgba(99,102,241,.2);
    border-radius: 99px;
    padding: 0 5px;
    font-size: 10px;
}
.bep-edit-btn:hover .bep-edit-count { background: rgba(255,255,255,.25); color: #fff; }

/* ID cell */
.bep-id-cell {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 6px;
}
.bep-id-badge {
    font-size: 11px;
    font-weight: 700;
    color: var(--bep-text-muted);
    background: #F1F5F9;
    border-radius: 4px;
    padding: 2px 6px;
    min-width: 28px;
    text-align: center;
    display: inline-block;
}

/* Action icon buttons */
.bep-action-btns { display: flex; gap: 1px; }
.bep-icon-btn {
    width: 22px; height: 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--bep-radius-sm);
    color: var(--bep-text-muted);
    transition: all var(--bep-transition);
    text-decoration: none;
    cursor: pointer;
    background: transparent;
    border: none;
}
.bep-icon-btn:hover { background: var(--bep-bg); }
.bep-icon-btn--edit:hover { color: var(--bep-primary); background: var(--bep-primary-light); }
.bep-icon-btn--view:hover { color: var(--bep-success); background: var(--bep-success-bg); }
.bep-icon-btn--delete:hover { color: var(--bep-danger); background: var(--bep-danger-bg); }

/* Image / gallery cells */
.bep-image-cell {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 4px;
    cursor: pointer;
}
.bep-thumb {
    width: 36px; height: 36px;
    object-fit: cover;
    border-radius: var(--bep-radius-sm);
    border: 2px solid var(--bep-border);
    display: block;
    transition: transform var(--bep-transition);
}
.bep-image-cell:hover .bep-thumb { transform: scale(1.08); border-color: var(--bep-primary); }
.bep-thumb-placeholder {
    width: 36px; height: 36px;
    background: #F1F5F9;
    border-radius: var(--bep-radius-sm);
    border: 2px dashed var(--bep-border);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--bep-text-muted);
    transition: all var(--bep-transition);
}
.bep-image-cell:hover .bep-thumb-placeholder { border-color: var(--bep-primary); color: var(--bep-primary); }

.bep-cell-text { padding: 7px 10px; display: block; color: var(--bep-text-secondary); }
.bep-na { display: flex; align-items: center; justify-content: center; padding: 4px; color: #CBD5E1; font-size: 16px; }

/* ── Modal ─────────────────────────────────────────────────────────── */
.bep-modal-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(15,23,42,.5);
    backdrop-filter: blur(4px);
    z-index: 99999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 20px;
    animation: bep-fadeIn .15s ease;
}
@keyframes bep-fadeIn { from { opacity:0; } to { opacity:1; } }

.bep-modal {
    background: var(--bep-surface);
    border-radius: var(--bep-radius-xl);
    box-shadow: var(--bep-shadow-lg);
    width: 100%;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    animation: bep-modalIn .18s cubic-bezier(.34,1.56,.64,1);
    overflow: hidden;
}
@keyframes bep-modalIn { from { opacity:0; transform:scale(.94) translateY(8px); } to { opacity:1; transform:none; } }

.bep-modal__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 22px 16px;
    border-bottom: 1px solid var(--bep-border);
    flex-shrink: 0;
}

.bep-modal__title {
    font-size: 15px;
    font-weight: 700;
    color: var(--bep-text-primary);
    margin: 0;
}

.bep-modal__close {
    width: 28px; height: 28px;
    border-radius: var(--bep-radius-sm);
    background: transparent;
    border: 1px solid var(--bep-border);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--bep-text-muted);
    transition: all var(--bep-transition);
}
.bep-modal__close:hover { background: var(--bep-danger-bg); color: var(--bep-danger); border-color: #FECACA; }

.bep-modal__body {
    overflow-y: auto;
    flex: 1;
    padding: 20px 22px;
    scrollbar-width: thin;
    scrollbar-color: #CBD5E1 transparent;
}

/* ── Modal Footer ──────────────────────────────────────────────────── */
.bep-modal-footer {
    display: flex;
    align-items: center;
    gap: 8px;
    padding-top: 20px;
    margin-top: 20px;
    border-top: 1px solid var(--bep-border);
}

/* ── Modal Edit Content ────────────────────────────────────────────── */
.bep-modal-edit { display: flex; flex-direction: column; gap: 0; }
.bep-textarea {
    width: 100%;
    border: 1px solid var(--bep-border);
    border-radius: var(--bep-radius);
    padding: 12px;
    font-family: var(--bep-font);
    font-size: 13px;
    color: var(--bep-text-primary);
    resize: vertical;
    transition: border var(--bep-transition), box-shadow var(--bep-transition);
    display: block;
    background: #FAFBFC;
}
.bep-textarea:focus { outline: none; border-color: var(--bep-border-focus); box-shadow: 0 0 0 3px rgba(99,102,241,.12); background: #fff; }

/* Checkbox grid in modal */
.bep-checkbox-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 6px;
    padding: 4px;
}
.bep-checkbox-option {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 7px 10px;
    border-radius: var(--bep-radius-sm);
    border: 1px solid var(--bep-border);
    cursor: pointer;
    font-size: 12.5px;
    transition: all var(--bep-transition);
    user-select: none;
    background: var(--bep-surface);
}
.bep-checkbox-option:hover { border-color: var(--bep-primary); background: var(--bep-primary-light); }
.bep-checkbox-option--checked { border-color: var(--bep-primary); background: var(--bep-primary-light); color: var(--bep-primary); font-weight: 600; }
.bep-checkbox-option input { display: none; }

/* ── Scrollable ────────────────────────────────────────────────────── */
.bep-scrollable {
    overflow-y: auto;
    scrollbar-width: thin;
    scrollbar-color: #CBD5E1 transparent;
}
.bep-scrollable::-webkit-scrollbar { width: 4px; }
.bep-scrollable::-webkit-scrollbar-thumb { background: #CBD5E1; border-radius: 99px; }

/* ── Form Controls ─────────────────────────────────────────────────── */
.bep-control { display: flex; flex-direction: column; gap: 5px; }

.bep-control__label {
    font-size: 11.5px;
    font-weight: 600;
    color: var(--bep-text-secondary);
    letter-spacing: .02em;
}

.bep-input {
    height: 34px;
    padding: 0 10px;
    border: 1px solid var(--bep-border);
    border-radius: var(--bep-radius-sm);
    font-family: var(--bep-font);
    font-size: 12.5px;
    color: var(--bep-text-primary);
    background: var(--bep-surface);
    transition: border var(--bep-transition), box-shadow var(--bep-transition);
    display: block;
    width: 100%;
}
.bep-input:focus { outline: none; border-color: var(--bep-border-focus); box-shadow: 0 0 0 3px rgba(99,102,241,.12); }

.bep-select-wrapper { position: relative; }
.bep-select {
    height: 34px;
    padding: 0 28px 0 10px;
    border: 1px solid var(--bep-border);
    border-radius: var(--bep-radius-sm);
    font-family: var(--bep-font);
    font-size: 12.5px;
    color: var(--bep-text-primary);
    background: var(--bep-surface);
    cursor: pointer;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 100%;
    transition: border var(--bep-transition), box-shadow var(--bep-transition);
}
.bep-select:focus { outline: none; border-color: var(--bep-border-focus); box-shadow: 0 0 0 3px rgba(99,102,241,.12); }
.bep-select__arrow {
    position: absolute;
    right: 8px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    color: var(--bep-text-muted);
}

/* ── Checkbox Control ──────────────────────────────────────────────── */
.bep-checkbox {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    user-select: none;
}
.bep-checkbox__box { position: relative; }
.bep-checkbox__box input { position: absolute; opacity: 0; width: 0; height: 0; }
.bep-checkbox__mark {
    width: 16px; height: 16px;
    border: 2px solid var(--bep-border);
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--bep-transition);
    background: var(--bep-surface);
}
.bep-checkbox__box input:checked + .bep-checkbox__mark { background: var(--bep-primary); border-color: var(--bep-primary); }
.bep-checkbox__label { font-size: 12.5px; color: var(--bep-text-secondary); }

/* ── Token Field ───────────────────────────────────────────────────── */
.bep-token-field {
    min-height: 36px;
    border: 1px solid var(--bep-border);
    border-radius: var(--bep-radius-sm);
    padding: 4px 8px;
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    align-items: center;
    cursor: text;
    background: var(--bep-surface);
    transition: border var(--bep-transition), box-shadow var(--bep-transition);
}
.bep-token-field:focus-within { border-color: var(--bep-border-focus); box-shadow: 0 0 0 3px rgba(99,102,241,.12); }
.bep-token {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: var(--bep-primary-light);
    color: var(--bep-primary);
    border-radius: 4px;
    padding: 2px 6px;
    font-size: 11.5px;
    font-weight: 600;
}
.bep-token__remove {
    background: none;
    border: none;
    cursor: pointer;
    color: inherit;
    font-size: 14px;
    line-height: 1;
    padding: 0;
    opacity: .7;
}
.bep-token__remove:hover { opacity: 1; }
.bep-token-input {
    border: none;
    outline: none;
    font-family: var(--bep-font);
    font-size: 12.5px;
    min-width: 80px;
    flex: 1;
    background: transparent;
    color: var(--bep-text-primary);
}
.bep-token-suggestions {
    position: absolute;
    left: 0; right: 0;
    top: calc(100% + 2px);
    z-index: 1000;
    background: var(--bep-surface);
    border: 1px solid var(--bep-border);
    border-radius: var(--bep-radius);
    box-shadow: var(--bep-shadow);
    list-style: none;
    margin: 0;
    padding: 4px;
    max-height: 200px;
    overflow-y: auto;
}
.bep-token-suggestion {
    padding: 7px 10px;
    border-radius: var(--bep-radius-sm);
    font-size: 12.5px;
    cursor: pointer;
    color: var(--bep-text-secondary);
    transition: all var(--bep-transition);
}
.bep-token-suggestion:hover { background: var(--bep-primary-light); color: var(--bep-primary); }
.bep-control { position: relative; }

/* ── Tab Panel ─────────────────────────────────────────────────────── */
.bep-tabpanel__tabs {
    display: flex;
    gap: 2px;
    border-bottom: 2px solid var(--bep-border);
    overflow-x: auto;
    scrollbar-width: none;
    padding-bottom: 0;
    flex-wrap: nowrap;
}
.bep-tabpanel__tabs::-webkit-scrollbar { display: none; }

.bep-tab {
    padding: 8px 16px;
    font-family: var(--bep-font);
    font-size: 12.5px;
    font-weight: 600;
    color: var(--bep-text-muted);
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    margin-bottom: -2px;
    cursor: pointer;
    transition: all var(--bep-transition);
    white-space: nowrap;
    border-radius: var(--bep-radius-sm) var(--bep-radius-sm) 0 0;
}
.bep-tab:hover { color: var(--bep-text-secondary); background: var(--bep-bg); }
.bep-tab--active { color: var(--bep-primary); border-bottom-color: var(--bep-primary); background: var(--bep-primary-light); }

.bep-tabpanel__content { padding-top: 16px; }

/* ── Filter Modal ──────────────────────────────────────────────────── */
.bep-filter-active-bar {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 8px 12px;
    background: var(--bep-primary-light);
    border-radius: var(--bep-radius);
    color: var(--bep-primary);
    font-size: 12.5px;
    font-weight: 600;
    margin-bottom: 16px;
}
.bep-filter-clear-inline {
    margin-left: auto;
    background: none;
    border: none;
    color: var(--bep-primary);
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    text-decoration: underline;
    font-family: var(--bep-font);
    opacity: .75;
}
.bep-filter-clear-inline:hover { opacity: 1; }

.bep-filter-fields { display: flex; flex-direction: column; gap: 10px; }

.bep-filter-row {
    display: grid;
    grid-template-columns: 140px 1fr;
    gap: 12px;
    align-items: start;
    padding: 10px 12px;
    border-radius: var(--bep-radius);
    transition: background var(--bep-transition);
}
.bep-filter-row:hover { background: var(--bep-bg); }

.bep-filter-label {
    padding-top: 8px;
    font-size: 12.5px;
    font-weight: 600;
    color: var(--bep-text-secondary);
}

.bep-filter-controls { display: flex; gap: 8px; align-items: flex-start; flex: 1; }
.bep-filter-op { flex-shrink: 0; min-width: 110px; }
.bep-filter-value { flex: 1; }
.bep-filter-between { display: flex; gap: 8px; flex-wrap: wrap; }
.bep-filter-between .bep-control { flex: 1; min-width: 120px; }

.bep-filter-toggle {
    display: flex;
    align-items: center;
    cursor: pointer;
    user-select: none;
    padding-top: 6px;
}
.bep-filter-toggle input { position: absolute; opacity: 0; }

/* ── Settings Modal ────────────────────────────────────────────────── */
.bep-settings-form { display: flex; flex-direction: column; gap: 0; }
.bep-settings-section {
    display: flex;
    gap: 14px;
    padding: 18px 0;
    border-bottom: 1px solid var(--bep-border);
}
.bep-settings-section:last-of-type { border-bottom: none; }
.bep-settings-section__icon {
    width: 34px; height: 34px;
    flex-shrink: 0;
    border-radius: var(--bep-radius);
    background: var(--bep-primary-light);
    color: var(--bep-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 2px;
}
.bep-settings-section__content { flex: 1; display: flex; flex-direction: column; gap: 12px; }
.bep-settings-section__title { font-size: 13px; font-weight: 700; color: var(--bep-text-primary); margin: 0 0 4px; }

/* ── Column Settings Modal ─────────────────────────────────────────── */
.bep-column-modal { display: flex; flex-direction: column; gap: 0; }
.bep-column-modal__hint { font-size: 12.5px; color: var(--bep-text-muted); margin: 0 0 16px; }

.bep-column-group { display: flex; flex-direction: column; gap: 14px; }
.bep-column-group__header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    background: var(--bep-bg);
    border-radius: var(--bep-radius);
    border: 1px solid var(--bep-border);
}
.bep-column-group__icon { color: var(--bep-primary); display: flex; }
.bep-column-group__name { font-size: 13px; font-weight: 700; color: var(--bep-text-primary); }
.bep-column-group__count { font-size: 11px; color: var(--bep-text-muted); margin-left: 2px; }
.bep-column-group__toggle-all { margin-left: auto; }
.bep-toggle-all-btn {
    font-family: var(--bep-font);
    font-size: 11.5px;
    font-weight: 600;
    color: var(--bep-primary);
    background: none;
    border: 1px solid var(--bep-primary);
    border-radius: var(--bep-radius-sm);
    padding: 3px 10px;
    cursor: pointer;
    transition: all var(--bep-transition);
}
.bep-toggle-all-btn:hover { background: var(--bep-primary); color: #fff; }

.bep-column-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: 6px;
}

.bep-col-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 10px;
    border-radius: var(--bep-radius-sm);
    border: 1px solid var(--bep-border);
    cursor: pointer;
    font-size: 12.5px;
    color: var(--bep-text-secondary);
    transition: all var(--bep-transition);
    user-select: none;
    background: var(--bep-surface);
}
.bep-col-item:hover { border-color: var(--bep-primary); color: var(--bep-primary); background: var(--bep-primary-light); }
.bep-col-item--on { border-color: #C7D2FE; background: var(--bep-primary-light); color: var(--bep-primary); }
.bep-col-item input { display: none; }
.bep-col-item__check { flex-shrink: 0; }
.bep-col-item__checkmark {
    width: 16px; height: 16px;
    border-radius: 4px;
    border: 2px solid currentColor;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: .35;
    transition: all var(--bep-transition);
}
.bep-col-item--on .bep-col-item__checkmark { background: var(--bep-primary); border-color: var(--bep-primary); opacity: 1; color: #fff; }
.bep-col-item__name { font-size: 12px; line-height: 1.3; }

/* ── Responsive ────────────────────────────────────────────────────── */
@media (max-width: 768px) {
    .bep-header { padding: 10px 12px; }
    .bep-toolbar { gap: 3px; }
    .bep-toolbar__divider { display: none; }
    .bep-filter-row { grid-template-columns: 1fr; }
    .bep-column-grid { grid-template-columns: repeat(auto-fill, minmax(130px, 1fr)); }
}

/* ── WordPress Admin Overrides ─────────────────────────────────────── */
/*
  WP admin structure (simplified):
    body.wp-admin
      #wpcontent
        #wpbody
          #wpbody-content  ← has padding-top:32px for admin bar
            .wrap           ← has padding: 2px 20px
              #gmbpu-admin-root
                .bep-app

  Goal: lock every ancestor so ONLY .bep-content scrolls.
*/

/* 1. html/body height chain */
html:has(#gmbpu-admin-root),
body.wp-admin:has(#gmbpu-admin-root) {
    height: 100%;
}

/* 2. WP content wrappers — fill height */
body.wp-admin:has(#gmbpu-admin-root) #wpcontent,
body.wp-admin:has(#gmbpu-admin-root) #wpbody,
body.wp-admin:has(#gmbpu-admin-root) #wpbody-content {
    height: calc(100vh - 32px) !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

/* 3. .wrap — remove padding, fill height */
.wrap:has(#gmbpu-admin-root) {
    padding: 0 !important;
    margin: 0 !important;
    height: 100% !important;
    max-width: none !important;
}

/* 4. Root mount point */
#gmbpu-admin-root {
    height: 100%;
    margin: 0 !important;
    padding: 0 !important;
    z-index: 999999999999999999;
    position: relative;
}

/* 5. .bep-app */


.bep-table td > .components-spinner,
.bep-table td > .wp-components-spinner { display: none; }

/* ══════════════════════════════════════════════════════════════════════
   NEW FEATURES — Bulk Ops, Find/Replace, Context Menu, Row Select,
                  Sort, Undo, Export, Duplicate, Layout
   ══════════════════════════════════════════════════════════════════════ */

/* ── Full-screen right drawer (Bulk Ops) ─────────────────────────── */
.bep-drawer-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(15,23,42,.35);
    z-index: 99990;
    animation: bep-fadeIn .15s ease;
}
.bep-drawer {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: 380px;
    max-width: 95vw;
    z-index: 99991;
    box-shadow: -8px 0 40px rgba(15,23,42,.18);
    animation: bep-drawerIn .22s cubic-bezier(.34,1.2,.64,1);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}
@keyframes bep-drawerIn {
    from { opacity:0; transform:translateX(40px); }
    to   { opacity:1; transform:none; }
}
/* Drawer fills full screen height */
.bep-drawer .bep-bulk-panel {
    width: 100%;
    height: 100%;
    flex: 1;
    border-left: none;
    overflow-y: auto;
}

/* ── Selection bar (inline in topbar) ────────────────────────────── */
.bep-selection-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    background: var(--bep-primary-light);
    font-size: 12.5px;
    font-weight: 500;
    color: var(--bep-primary);
    border-left: 3px solid var(--bep-primary);
    flex: 1;
    min-width: 0;
}
.bep-selection-bar strong { font-weight: 700; }
.bep-selection-bar__bulk {
    font-family: var(--bep-font);
    font-size: 12px;
    font-weight: 700;
    background: var(--bep-primary);
    color: #fff;
    border: none;
    border-radius: var(--bep-radius-sm);
    padding: 4px 10px;
    cursor: pointer;
    transition: background var(--bep-transition);
}
.bep-selection-bar__bulk:hover { background: var(--bep-primary-hover); }
.bep-selection-bar__clear {
    margin-left: auto;
    font-family: var(--bep-font);
    font-size: 12px;
    background: none;
    border: none;
    color: var(--bep-primary);
    cursor: pointer;
    opacity: .7;
    font-weight: 600;
}
.bep-selection-bar__clear:hover { opacity: 1; }

/* ── Table row checkboxes ─────────────────────────────────────────── */
.bep-th-check, .bep-td-check {
    width: 36px !important;
    padding: 0 !important;
    text-align: center;
    background: #F8FAFC !important;
    border-right: 1px solid var(--bep-border) !important;
}
.bep-table-check {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    min-height: 36px;
    cursor: pointer;
    padding: 4px;
}
.bep-table-check input { position: absolute; opacity: 0; width: 0; height: 0; }
.bep-table-check__mark {
    width: 15px; height: 15px;
    border: 2px solid #CBD5E1;
    border-radius: 3px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--bep-transition);
    background: #fff;
    flex-shrink: 0;
    position: relative;
}
.bep-table-check input:checked + .bep-table-check__mark {
    background: var(--bep-primary);
    border-color: var(--bep-primary);
    color: #fff;
}
.bep-table-check__dash {
    width: 7px; height: 2px;
    background: var(--bep-primary);
    border-radius: 1px;
}
.bep-tr--selected .bep-td { background: #EEF2FF !important; }
.bep-tr--selected .bep-table-check__mark { background: var(--bep-primary); border-color: var(--bep-primary); color: #fff; }

/* ── Column sort headers ───────────────────────────────────────────── */
.bep-th { cursor: pointer; user-select: none; }
.bep-th:hover { background: #E8EDF5 !important; }
.bep-th-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
}
.bep-sort-icon { flex-shrink: 0; opacity: .35; transition: opacity var(--bep-transition); }
.bep-th:hover .bep-sort-icon { opacity: .7; }
.bep-sort-icon--active { opacity: 1 !important; color: var(--bep-primary); }

/* ── Duplicate icon button ─────────────────────────────────────────── */
.bep-icon-btn--duplicate:hover { color: var(--bep-primary); background: var(--bep-primary-light); }

/* ── Badge ghost variant ───────────────────────────────────────────── */
.bep-badge--ghost { background: #E2E8F0; color: var(--bep-text-secondary); border-color: transparent; }

/* ── Context Menu ─────────────────────────────────────────────────── */
.bep-ctx-menu {
    background: var(--bep-surface);
    border: 1px solid var(--bep-border);
    border-radius: var(--bep-radius);
    box-shadow: var(--bep-shadow-lg);
    min-width: 200px;
    padding: 4px;
    animation: bep-fadeIn .1s ease;
}
.bep-ctx-item {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 7px 10px;
    font-family: var(--bep-font);
    font-size: 12.5px;
    color: var(--bep-text-secondary);
    background: none;
    border: none;
    border-radius: var(--bep-radius-sm);
    cursor: pointer;
    text-align: left;
    transition: all var(--bep-transition);
}
.bep-ctx-item:hover { background: var(--bep-primary-light); color: var(--bep-primary); }
.bep-ctx-item--danger { color: var(--bep-danger); }
.bep-ctx-item--danger:hover { background: var(--bep-danger-bg); color: var(--bep-danger); }
.bep-ctx-icon { color: var(--bep-text-muted); flex-shrink: 0; display: flex; }
.bep-ctx-item:hover .bep-ctx-icon { color: inherit; }
.bep-ctx-shortcut { margin-left: auto; font-size: 10.5px; color: var(--bep-text-muted); opacity: .7; }
.bep-ctx-divider { height: 1px; background: var(--bep-border); margin: 3px 4px; }

/* ── Bulk Ops Panel (inside .bep-drawer) ─────────────────────────── */
.bep-bulk-panel {
    background: var(--bep-surface);
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    height: 100%;
    scrollbar-width: thin;
    scrollbar-color: #CBD5E1 transparent;
}

.bep-bulk-panel__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px 12px;
    border-bottom: 1px solid var(--bep-border);
    position: sticky;
    top: 0;
    background: var(--bep-surface);
    z-index: 5;
}
.bep-bulk-panel__title {
    display: flex;
    align-items: center;
    font-size: 13px;
    font-weight: 700;
    color: var(--bep-text-primary);
}
.bep-bulk-panel__close {
    width: 24px; height: 24px;
    border-radius: var(--bep-radius-sm);
    border: 1px solid var(--bep-border);
    background: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--bep-text-muted);
    transition: all var(--bep-transition);
}
.bep-bulk-panel__close:hover { background: var(--bep-danger-bg); color: var(--bep-danger); border-color: #FECACA; }

.bep-bulk-panel__scope {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 8px 16px;
    background: var(--bep-primary-light);
    font-size: 12px;
    color: var(--bep-primary);
    font-weight: 500;
}
.bep-bulk-panel__scope strong { font-weight: 800; }
.bep-bulk-panel__scope-all { opacity: .7; }

.bep-bulk-panel__body {
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.bep-bulk-panel__actions { padding-top: 4px; }
.bep-bulk-panel__actions .bep-btn { width: 100%; justify-content: center; }

.bep-bulk-panel__shortcut {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 6px 10px;
    background: var(--bep-bg);
    border-radius: var(--bep-radius-sm);
    border: 1px solid var(--bep-border);
}
.bep-bulk-panel__shortcut-label { font-size: 11px; color: var(--bep-text-muted); font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.bep-shortcut-btn {
    font-family: var(--bep-font);
    font-size: 11.5px;
    font-weight: 600;
    color: var(--bep-primary);
    background: none;
    border: none;
    cursor: pointer;
    text-decoration: underline;
    padding: 0;
}

.bep-bulk-panel__presets {
    padding: 12px 16px 16px;
    border-top: 1px solid var(--bep-border);
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.bep-bulk-panel__presets-title {
    font-size: 10.5px;
    font-weight: 700;
    color: var(--bep-text-muted);
    text-transform: uppercase;
    letter-spacing: .06em;
    margin-bottom: 4px;
}
.bep-preset-btn {
    font-family: var(--bep-font);
    font-size: 12px;
    padding: 6px 10px;
    text-align: left;
    border: 1px solid var(--bep-border);
    border-radius: var(--bep-radius-sm);
    background: var(--bep-surface);
    color: var(--bep-text-secondary);
    cursor: pointer;
    transition: all var(--bep-transition);
    font-weight: 500;
}
.bep-preset-btn:hover { background: var(--bep-primary-light); border-color: #C7D2FE; color: var(--bep-primary); }

/* ── Find & Replace ───────────────────────────────────────────────── */
.bep-find-replace { display: flex; flex-direction: column; gap: 0; }
.bep-find-replace__inputs { display: flex; flex-direction: column; gap: 14px; }

.bep-find-replace__preview {
    margin-top: 16px;
    border: 1px solid var(--bep-border);
    border-radius: var(--bep-radius);
    overflow: hidden;
}
.bep-find-replace__preview-header {
    padding: 9px 14px;
    background: var(--bep-bg);
    border-bottom: 1px solid var(--bep-border);
    font-size: 12.5px;
    font-weight: 600;
    color: var(--bep-text-secondary);
}
.bep-find-replace__no-match { color: var(--bep-text-muted); font-weight: 400; }

.bep-find-replace__preview-list {
    max-height: 260px;
    overflow-y: auto;
    scrollbar-width: thin;
}
.bep-find-replace__preview-item {
    display: grid;
    grid-template-columns: 1fr 80px 1fr;
    align-items: center;
    gap: 8px;
    padding: 8px 14px;
    border-bottom: 1px solid #F1F5F9;
    font-size: 12px;
}
.bep-find-replace__preview-item:last-child { border-bottom: none; }
.bep-preview-product { color: var(--bep-text-primary); font-weight: 600; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bep-preview-field { font-size: 11px; color: var(--bep-text-muted); font-weight: 600; text-transform: uppercase; letter-spacing: .04em; }
.bep-preview-change { display: flex; align-items: center; gap: 6px; color: var(--bep-text-muted); }
.bep-preview-old { color: var(--bep-danger); background: var(--bep-danger-bg); padding: 1px 5px; border-radius: 3px; font-family: monospace; font-size: 11px; }
.bep-preview-new { color: var(--bep-success); background: var(--bep-success-bg); padding: 1px 5px; border-radius: 3px; font-family: monospace; font-size: 11px; }
.bep-find-replace__more { padding: 8px 14px; font-size: 12px; color: var(--bep-text-muted); font-style: italic; }

/* ── Pagination selected indicator ───────────────────────────────── */
.bep-pagination__sel {
    color: var(--bep-primary);
    font-weight: 600;
    font-size: 12px;
}

