/* ============================================================
   VisionCore · 17 Prompt Library
   "Select Pose"-style asset browser (PromptLibraryModal.js).
   Centered modal on desktop, full-screen sheet on mobile.
   Sits above the Studio generation panel (z-modal + 20).
   Brand-token only — no legacy selectors, namespaced under .pl-*.
   ============================================================ */

/* ── overlay ── */
.pl-overlay {
    position: fixed;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(0, 0, 0, .62);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    z-index: calc(var(--vc-z-modal) + 20);
    opacity: 0;
    transition: opacity var(--vc-base);
}
.pl-overlay.visible { opacity: 1; }
.pl-overlay.hidden { display: none; }

/* ── panel ── */
.pl-panel {
    position: relative;
    display: flex;
    flex-direction: column;
    width: min(960px, 94vw);
    height: min(840px, 88vh);
    background: var(--vc-card);
    border: 1px solid var(--vc-line);
    border-radius: var(--vc-r-lg);
    box-shadow: 0 24px 80px rgba(0, 0, 0, .55);
    overflow: hidden;
    transform: translateY(8px) scale(.985);
    transition: transform var(--vc-base);
}
.pl-overlay.visible .pl-panel { transform: translateY(0) scale(1); }

/* ── header ── */
.pl-header {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 22px;
    border-bottom: 1px solid var(--vc-line);
}
.pl-header-title { display: inline-flex; align-items: center; gap: 10px; }
.pl-header h2 {
    margin: 0;
    font-family: var(--vc-font-display);
    font-size: var(--vc-text-lg);
    font-weight: 700;
    letter-spacing: -.01em;
    color: var(--vc-ink);
}
.pl-mock-badge {
    font-size: var(--vc-text-xs);
    font-weight: 600;
    color: var(--vc-warn-soft);
    background: var(--vc-warn-bg);
    border: 1px solid rgba(240, 152, 25, .3);
    border-radius: var(--vc-r-pill);
    padding: 2px 8px;
    text-transform: uppercase;
    letter-spacing: .04em;
}
.pl-close {
    width: 32px; height: 32px;
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--vc-ink-3);
    background: transparent;
    border: 0;
    border-radius: var(--vc-r-sm);
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
    transition: background var(--vc-fast), color var(--vc-fast);
}
.pl-close:hover { background: rgba(255, 255, 255, .05); color: var(--vc-ink); }

/* ── asset-type chips ── */
.pl-types {
    flex: 0 0 auto;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 12px 22px;
    border-bottom: 1px solid var(--vc-line);
}
.pl-type {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 7px 14px;
    background: var(--vc-raise);
    border: 1px solid var(--vc-line);
    border-radius: var(--vc-r-pill);
    color: var(--vc-ink-3);
    font-family: var(--vc-font-sans);
    font-size: var(--vc-text-sm);
    font-weight: 600;
    cursor: pointer;
    transition: all var(--vc-fast);
}
.pl-type:hover { color: var(--vc-ink); border-color: var(--vc-ink-5); }
.pl-type.active {
    color: #fff;
    background: var(--vc-brand-bg);
    border-color: var(--vc-brand-line);
    box-shadow: inset 0 0 0 1px var(--vc-brand-line);
}
.pl-type.active .pl-type-glyph { color: var(--vc-brand-soft); }
.pl-type-glyph { font-size: 13px; line-height: 1; color: var(--vc-ink-4); }
.pl-type--preset.active { background: var(--vc-brand); border-color: var(--vc-brand); }
.pl-type--preset.active .pl-type-glyph { color: #fff; }

/* ── toolbar (search · rating · insert-mode) ── */
.pl-toolbar {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 22px;
}
.pl-search { position: relative; flex: 1 1 auto; min-width: 0; }
.pl-search-icon {
    position: absolute;
    left: 11px; top: 50%;
    transform: translateY(-50%);
    color: var(--vc-ink-4);
    font-size: 14px;
    pointer-events: none;
}
.pl-search-input {
    width: 100%;
    padding: 9px 12px 9px 32px;
    background: var(--vc-raise);
    border: 1px solid var(--vc-line);
    border-radius: var(--vc-r-md);
    color: var(--vc-ink);
    font-family: var(--vc-font-sans);
    font-size: var(--vc-text-base);
    outline: none;
    transition: border-color var(--vc-fast);
}
.pl-search-input:focus { border-color: var(--vc-brand-line); }
.pl-search-input::placeholder { color: var(--vc-ink-4); }

.pl-nsfw { display: inline-flex; align-items: center; gap: 6px; flex: 0 0 auto; }
.pl-nsfw-label { font-size: var(--vc-text-xs); color: var(--vc-ink-4); text-transform: uppercase; letter-spacing: .04em; }
.pl-nsfw-select {
    padding: 8px 10px;
    background: var(--vc-raise);
    border: 1px solid var(--vc-line);
    border-radius: var(--vc-r-md);
    color: var(--vc-ink-2);
    font-family: var(--vc-font-sans);
    font-size: var(--vc-text-sm);
    cursor: pointer;
    outline: none;
}
.pl-nsfw-select:focus { border-color: var(--vc-brand-line); }

.pl-insert-mode {
    display: inline-flex;
    flex: 0 0 auto;
    background: var(--vc-raise);
    border: 1px solid var(--vc-line);
    border-radius: var(--vc-r-md);
    padding: 2px;
    gap: 2px;
}
.pl-mode-btn {
    padding: 6px 12px;
    background: transparent;
    border: 0;
    border-radius: var(--vc-r-sm);
    color: var(--vc-ink-3);
    font-family: var(--vc-font-sans);
    font-size: var(--vc-text-sm);
    font-weight: 600;
    cursor: pointer;
    transition: all var(--vc-fast);
}
.pl-mode-btn:hover { color: var(--vc-ink); }
.pl-mode-btn.active { color: #fff; background: var(--vc-brand); }

/* ── category tabs ── */
.pl-cats {
    flex: 0 0 auto;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 0 22px 12px;
}
.pl-cat {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 5px 11px;
    background: transparent;
    border: 1px solid var(--vc-line);
    border-radius: var(--vc-r-pill);
    color: var(--vc-ink-3);
    font-family: var(--vc-font-sans);
    font-size: var(--vc-text-xs);
    font-weight: 600;
    cursor: pointer;
    transition: all var(--vc-fast);
}
.pl-cat:hover { color: var(--vc-ink); border-color: var(--vc-ink-5); }
.pl-cat.active { color: var(--vc-ink); background: rgba(255, 255, 255, .06); border-color: var(--vc-ink-4); }
.pl-cat-n {
    font-size: 10px;
    color: var(--vc-ink-4);
    background: rgba(255, 255, 255, .05);
    border-radius: var(--vc-r-pill);
    padding: 1px 6px;
}
.pl-cat.active .pl-cat-n { color: var(--vc-ink-2); }

/* ── body / grid ── */
.pl-body { flex: 1 1 auto; position: relative; overflow-y: auto; }
.pl-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(148px, 1fr));
    gap: 12px;
    padding: 16px 22px 24px;
}

.pl-card {
    display: flex;
    flex-direction: column;
    padding: 0;
    background: var(--vc-raise);
    border: 1px solid var(--vc-line);
    border-radius: var(--vc-r-md);
    overflow: hidden;
    cursor: pointer;
    text-align: left;
    transition: transform var(--vc-fast), border-color var(--vc-fast), box-shadow var(--vc-fast);
}
.pl-card:hover {
    transform: translateY(-2px);
    border-color: var(--vc-brand-line);
    box-shadow: 0 8px 24px rgba(0, 0, 0, .4);
}
.pl-card:active { transform: translateY(0); }
.pl-card--inserted { border-color: var(--vc-success); box-shadow: var(--vc-glow-success); }

.pl-thumb {
    position: relative;
    aspect-ratio: 3 / 4;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background: linear-gradient(135deg, #202024 0%, #161618 100%);
}
.pl-thumb.is-placeholder { background: linear-gradient(135deg, #232327 0%, #15151a 100%); }
.pl-thumb-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.pl-thumb-glyph { font-size: 40px; color: rgba(255, 255, 255, .12); }
.pl-card--preset .pl-thumb-glyph { color: var(--vc-brand-soft); opacity: .35; }

.pl-badge {
    position: absolute;
    font-size: 9.5px;
    font-weight: 700;
    letter-spacing: .03em;
    border-radius: var(--vc-r-xs);
    padding: 2px 6px;
    text-transform: uppercase;
}
.pl-badge-nsfw { top: 6px; right: 6px; }
.pl-badge-nsfw.is-sfw { color: var(--vc-success-soft); background: var(--vc-success-bg); border: 1px solid rgba(0, 230, 118, .3); }
.pl-badge-nsfw.is-r15 { color: var(--vc-warn-soft); background: var(--vc-warn-bg); border: 1px solid rgba(240, 152, 25, .3); }
.pl-badge-nsfw.is-nsfw { color: var(--vc-danger-soft); background: var(--vc-danger-bg); border: 1px solid rgba(255, 68, 68, .35); }

.pl-card-meta {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 9px 10px 11px;
}
.pl-card-name {
    font-size: var(--vc-text-sm);
    font-weight: 600;
    color: var(--vc-ink);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.pl-card-uses { font-size: var(--vc-text-xs); color: var(--vc-ink-4); }

/* ── empty / loading ── */
/* The `hidden` attribute must win over the `display:flex` below. Author rules
   beat the UA `[hidden]{display:none}` at equal specificity, so re-assert it —
   otherwise these absolute overlays stay painted over the grid and (for
   .pl-loading) swallow every card click. */
.pl-empty[hidden],
.pl-loading[hidden] { display: none; }
.pl-empty {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--vc-ink-4);
    font-size: var(--vc-text-base);
}
.pl-loading {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    color: var(--vc-ink-3);
    font-size: var(--vc-text-base);
    background: rgba(28, 28, 28, .6);
    backdrop-filter: blur(2px);
}
.pl-spinner {
    width: 16px; height: 16px;
    border: 2px solid var(--vc-line);
    border-top-color: var(--vc-brand);
    border-radius: 50%;
    animation: pl-spin .7s linear infinite;
}
@keyframes pl-spin { to { transform: rotate(360deg); } }

/* ── footer ── */
.pl-footer {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 11px 22px;
    border-top: 1px solid var(--vc-line);
    background: var(--vc-panel);
}
.pl-count { font-size: var(--vc-text-sm); color: var(--vc-ink-2); font-weight: 600; }
.pl-hint { font-size: var(--vc-text-xs); color: var(--vc-ink-4); }

/* ── insert toast ── */
.pl-toast {
    position: absolute;
    bottom: 60px;
    left: 50%;
    transform: translate(-50%, 8px);
    background: var(--vc-success-bg);
    border: 1px solid rgba(0, 230, 118, .4);
    color: var(--vc-success-soft);
    font-size: var(--vc-text-sm);
    font-weight: 600;
    padding: 8px 16px;
    border-radius: var(--vc-r-pill);
    box-shadow: 0 8px 24px rgba(0, 0, 0, .4);
    opacity: 0;
    pointer-events: none;
    transition: opacity var(--vc-base), transform var(--vc-base);
    z-index: 2;
}
.pl-toast.show { opacity: 1; transform: translate(-50%, 0); }

/* ── the trigger button mounted into the generation form ── */
.pl-open-btn {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    margin-top: 8px;
    padding: 9px 14px;
    width: 100%;
    justify-content: center;
    background: var(--vc-raise);
    border: 1px dashed var(--vc-line);
    border-radius: var(--vc-r-md);
    color: var(--vc-ink-2);
    font-family: var(--vc-font-sans);
    font-size: var(--vc-text-sm);
    font-weight: 600;
    cursor: pointer;
    transition: all var(--vc-fast);
}
.pl-open-btn:hover {
    color: #fff;
    border-color: var(--vc-brand-line);
    background: var(--vc-brand-bg);
}
.pl-open-btn-glyph { font-size: 14px; }

/* ── mobile: full-screen sheet ── */
@media (max-width: 640px) {
    .pl-overlay { padding: 0; }
    .pl-panel {
        width: 100vw;
        height: 100vh;
        height: 100dvh;
        max-width: none;
        border: 0;
        border-radius: 0;
    }
    .pl-header { padding: 14px 16px; }
    .pl-types, .pl-toolbar, .pl-cats { padding-left: 16px; padding-right: 16px; }
    .pl-types {
        flex-wrap: nowrap;
        overflow-x: auto;
        scrollbar-width: none;
    }
    .pl-types::-webkit-scrollbar { display: none; }
    .pl-type { flex: 0 0 auto; }
    .pl-toolbar { flex-wrap: wrap; }
    .pl-search { flex: 1 1 100%; order: -1; }
    .pl-cats {
        flex-wrap: nowrap;
        overflow-x: auto;
        scrollbar-width: none;
    }
    .pl-cats::-webkit-scrollbar { display: none; }
    .pl-cat { flex: 0 0 auto; }
    .pl-grid {
        grid-template-columns: repeat(auto-fill, minmax(118px, 1fr));
        gap: 10px;
        padding: 14px 16px 24px;
    }
    .pl-hint { display: none; }
}

/* ============================================================
   Presets — build (compose) bar, source toggle, manage, form
   ============================================================ */

/* compose-mode toggle in the toolbar */
.pl-compose-toggle {
    flex: 0 0 auto;
    padding: 8px 12px;
    background: var(--vc-raise);
    border: 1px solid var(--vc-line);
    border-radius: var(--vc-r-md);
    color: var(--vc-ink-2);
    font-family: var(--vc-font-sans);
    font-size: var(--vc-text-sm);
    font-weight: 600;
    cursor: pointer;
    transition: all var(--vc-fast);
}
.pl-compose-toggle:hover { color: var(--vc-ink); border-color: var(--vc-ink-5); }
.pl-compose-toggle.active {
    color: #fff;
    background: var(--vc-brand-bg);
    border-color: var(--vc-brand-line);
    box-shadow: inset 0 0 0 1px var(--vc-brand-line);
}

/* "＋" hint that appears on asset thumbs while composing */
.pl-card-add {
    position: absolute;
    top: 6px; left: 6px;
    width: 22px; height: 22px;
    display: none;
    align-items: center;
    justify-content: center;
    border-radius: var(--vc-r-sm);
    background: var(--vc-brand);
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    box-shadow: 0 2px 8px rgba(0, 0, 0, .4);
}
.pl-overlay.is-compose .pl-card-add { display: inline-flex; }
.pl-overlay.is-compose .pl-card:hover .pl-card-add { transform: scale(1.1); }

/* compose draft bar */
/* the `hidden` attribute must beat the display:flex below (author > UA cascade),
   else the empty draft bar stays painted at all times. */
.pl-compose[hidden] { display: none; }
.pl-compose {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 22px;
    border-top: 1px solid var(--vc-brand-line);
    background: var(--vc-brand-bg);
}
.pl-compose-label {
    flex: 0 0 auto;
    font-size: var(--vc-text-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--vc-brand-soft);
}
.pl-compose-chips {
    flex: 1 1 auto;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    min-width: 0;
    overflow: hidden;
}
.pl-compose-empty { font-size: var(--vc-text-sm); color: var(--vc-ink-4); }
.pl-compose-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 3px 4px 3px 9px;
    background: var(--vc-card);
    border: 1px solid var(--vc-line);
    border-radius: var(--vc-r-pill);
    font-size: var(--vc-text-xs);
    color: var(--vc-ink-2);
    white-space: nowrap;
}
.pl-compose-chip b { color: var(--vc-brand-soft); text-transform: capitalize; font-weight: 700; }
.pl-compose-rm {
    width: 16px; height: 16px;
    display: inline-flex; align-items: center; justify-content: center;
    border: 0; border-radius: 50%;
    background: rgba(255, 255, 255, .06);
    color: var(--vc-ink-3);
    font-size: 10px;
    cursor: pointer;
}
.pl-compose-rm:hover { background: var(--vc-danger-bg); color: var(--vc-danger-soft); }
.pl-compose-save {
    flex: 0 0 auto;
    padding: 7px 14px;
    background: var(--vc-brand);
    border: 0;
    border-radius: var(--vc-r-md);
    color: #fff;
    font-family: var(--vc-font-sans);
    font-size: var(--vc-text-sm);
    font-weight: 600;
    cursor: pointer;
}
.pl-compose-save:disabled { opacity: .45; cursor: not-allowed; }
.pl-compose-clear {
    flex: 0 0 auto;
    width: 28px; height: 28px;
    display: inline-flex; align-items: center; justify-content: center;
    background: transparent;
    border: 1px solid var(--vc-line);
    border-radius: var(--vc-r-sm);
    color: var(--vc-ink-3);
    cursor: pointer;
}
.pl-compose-clear:hover { color: var(--vc-ink); border-color: var(--vc-ink-5); }

/* My Presets / Community source toggle (rendered in the category row) */
.pl-src-toggle {
    display: inline-flex;
    background: var(--vc-raise);
    border: 1px solid var(--vc-line);
    border-radius: var(--vc-r-md);
    padding: 2px;
    gap: 2px;
}
.pl-src {
    padding: 6px 14px;
    background: transparent;
    border: 0;
    border-radius: var(--vc-r-sm);
    color: var(--vc-ink-3);
    font-family: var(--vc-font-sans);
    font-size: var(--vc-text-sm);
    font-weight: 600;
    cursor: pointer;
    transition: all var(--vc-fast);
}
.pl-src:hover { color: var(--vc-ink); }
.pl-src.active { color: #fff; background: var(--vc-brand); }

/* preset card wrapper + manage buttons (siblings, not nested in the card button) */
.pl-card-wrap { position: relative; display: flex; }
.pl-card-wrap .pl-card { width: 100%; }
.pl-preset-actions {
    position: absolute;
    top: 6px; left: 6px;
    display: flex;
    gap: 4px;
    opacity: 0;
    transition: opacity var(--vc-fast);
}
.pl-card-wrap:hover .pl-preset-actions,
.pl-preset-actions:focus-within { opacity: 1; }
.pl-preset-edit,
.pl-preset-del {
    width: 24px; height: 24px;
    display: inline-flex; align-items: center; justify-content: center;
    border: 0;
    border-radius: var(--vc-r-sm);
    background: rgba(0, 0, 0, .65);
    color: var(--vc-ink-2);
    font-size: 12px;
    cursor: pointer;
    backdrop-filter: blur(2px);
}
.pl-preset-edit:hover { background: var(--vc-brand); color: #fff; }
.pl-preset-del:hover { background: var(--vc-danger); color: #fff; }

/* composition slot chips on preset cards */
.pl-preset-slots {
    display: flex;
    flex-wrap: wrap;
    gap: 3px;
    margin-top: 4px;
}
.pl-slot {
    font-size: 9.5px;
    text-transform: capitalize;
    color: var(--vc-ink-3);
    background: rgba(255, 255, 255, .05);
    border-radius: var(--vc-r-xs);
    padding: 1px 5px;
}

/* create / edit form overlay (covers the panel) */
.pl-form-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    background: rgba(0, 0, 0, .55);
    backdrop-filter: blur(3px);
    z-index: 3;
}
.pl-form-overlay[hidden] { display: none; }
.pl-form {
    width: min(420px, 100%);
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 22px;
    background: var(--vc-card);
    border: 1px solid var(--vc-line);
    border-radius: var(--vc-r-lg);
    box-shadow: 0 24px 60px rgba(0, 0, 0, .6);
}
.pl-form-title {
    margin: 0;
    font-family: var(--vc-font-display);
    font-size: var(--vc-text-lg);
    font-weight: 700;
    color: var(--vc-ink);
}
.pl-form-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
    font-size: var(--vc-text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: var(--vc-ink-4);
}
.pl-form-opt { text-transform: none; letter-spacing: 0; color: var(--vc-ink-5); font-weight: 500; }
.pl-form-name,
.pl-form-cat {
    padding: 9px 12px;
    background: var(--vc-raise);
    border: 1px solid var(--vc-line);
    border-radius: var(--vc-r-md);
    color: var(--vc-ink);
    font-family: var(--vc-font-sans);
    font-size: var(--vc-text-base);
    font-weight: 400;
    text-transform: none;
    letter-spacing: 0;
    outline: none;
}
.pl-form-name:focus,
.pl-form-cat:focus { border-color: var(--vc-brand-line); }
.pl-form-compo {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    min-height: 24px;
    align-items: center;
}
.pl-form-error {
    margin: 0;
    min-height: 16px;
    font-size: var(--vc-text-sm);
    font-weight: 500;
    text-transform: none;
    letter-spacing: 0;
    color: var(--vc-danger-soft);
}
.pl-form-actions { display: flex; justify-content: flex-end; gap: 8px; }
.pl-form-cancel,
.pl-form-save {
    padding: 9px 18px;
    border-radius: var(--vc-r-md);
    font-family: var(--vc-font-sans);
    font-size: var(--vc-text-sm);
    font-weight: 600;
    cursor: pointer;
}
.pl-form-cancel {
    background: transparent;
    border: 1px solid var(--vc-line);
    color: var(--vc-ink-2);
}
.pl-form-cancel:hover { border-color: var(--vc-ink-5); color: var(--vc-ink); }
.pl-form-save {
    background: var(--vc-brand);
    border: 1px solid var(--vc-brand);
    color: #fff;
}
.pl-form-save:disabled { opacity: .5; cursor: not-allowed; }

@media (max-width: 640px) {
    .pl-compose { flex-wrap: wrap; padding: 10px 16px; }
    .pl-compose-chips { order: 3; flex: 1 1 100%; }
    .pl-preset-actions { opacity: 1; }
    .pl-compose-toggle { font-size: var(--vc-text-xs); padding: 8px 10px; }
}

/* ============================================================
   Two-pane composer — left browse · right "Your prompt" slots
   ============================================================ */
.pl-panel { width: min(1120px, 96vw); }

.pl-workspace {
    flex: 1 1 auto;
    display: flex;
    min-height: 0;
    overflow: hidden;
}
.pl-main {
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    min-width: 0;
    min-height: 0;
}

/* right pane */
.pl-side {
    flex: 0 0 304px;
    display: flex;
    flex-direction: column;
    min-height: 0;
    border-left: 1px solid var(--vc-line);
    background: var(--vc-panel);
}
.pl-side-head {
    flex: 0 0 auto;
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    padding: 14px 16px 10px;
    border-bottom: 1px solid var(--vc-line);
}
.pl-side-title { font-family: var(--vc-font-display); font-weight: 700; font-size: var(--vc-text-md); color: var(--vc-ink); }
.pl-side-count { font-size: var(--vc-text-xs); color: var(--vc-brand-soft); font-weight: 600; }

.pl-slots {
    flex: 1 1 auto;
    overflow-y: auto;
    padding: 8px 10px;
    display: flex;
    flex-direction: column;
    gap: 3px;
}
.pl-slot-row {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 7px 9px;
    border-radius: var(--vc-r-md);
    border: 1px solid transparent;
}
.pl-slot-row.is-filled { background: var(--vc-brand-bg); border-color: var(--vc-brand-line); }
.pl-slot-row.is-empty { opacity: .5; }
.pl-slot-glyph { flex: 0 0 auto; width: 16px; text-align: center; color: var(--vc-ink-4); font-size: 12px; }
.pl-slot-row.is-filled .pl-slot-glyph { color: var(--vc-brand-soft); }
.pl-slot-label {
    flex: 0 0 76px;
    font-size: var(--vc-text-xs);
    font-weight: 600;
    color: var(--vc-ink-3);
    text-transform: capitalize;
}
.pl-slot-val {
    flex: 1 1 auto;
    min-width: 0;
    font-size: var(--vc-text-sm);
    color: var(--vc-ink);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.pl-slot-val.pl-slot-empty { color: var(--vc-ink-5); }
.pl-slot-rm {
    flex: 0 0 auto;
    width: 18px; height: 18px;
    display: inline-flex; align-items: center; justify-content: center;
    border: 0; border-radius: 50%;
    background: rgba(255, 255, 255, .06);
    color: var(--vc-ink-3); font-size: 10px; cursor: pointer;
}
.pl-slot-rm:hover { background: var(--vc-danger-bg); color: var(--vc-danger-soft); }

.pl-side-preview-wrap {
    flex: 0 0 auto;
    border-top: 1px solid var(--vc-line);
    padding: 10px 14px;
}
.pl-side-preview-label {
    font-size: var(--vc-text-xs); text-transform: uppercase; letter-spacing: .04em;
    color: var(--vc-ink-4); margin-bottom: 6px;
}
.pl-side-preview {
    max-height: 96px; overflow-y: auto;
    font-size: var(--vc-text-sm); line-height: 1.5; color: var(--vc-ink-2);
    background: var(--vc-raise); border: 1px solid var(--vc-line);
    border-radius: var(--vc-r-md); padding: 8px 10px;
    word-break: break-word;
}
.pl-side-preview.is-empty { color: var(--vc-ink-5); }

.pl-side-actions {
    flex: 0 0 auto;
    display: flex; gap: 8px;
    padding: 10px 14px 14px;
    border-top: 1px solid var(--vc-line);
}
.pl-side-save {
    flex: 1 1 auto;
    padding: 9px 12px;
    background: var(--vc-brand); border: 0; border-radius: var(--vc-r-md);
    color: #fff; font-family: var(--vc-font-sans); font-size: var(--vc-text-sm); font-weight: 600; cursor: pointer;
}
.pl-side-save:disabled { opacity: .45; cursor: not-allowed; }
.pl-side-clear {
    flex: 0 0 auto;
    padding: 9px 14px;
    background: transparent; border: 1px solid var(--vc-line); border-radius: var(--vc-r-md);
    color: var(--vc-ink-2); font-size: var(--vc-text-sm); font-weight: 600; cursor: pointer;
}
.pl-side-clear:hover:not(:disabled) { border-color: var(--vc-ink-5); color: var(--vc-ink); }
.pl-side-clear:disabled { opacity: .45; cursor: not-allowed; }

/* picked asset card highlight (reflects right-pane selection) */
.pl-card.is-picked { border-color: var(--vc-brand); box-shadow: inset 0 0 0 1px var(--vc-brand); }
.pl-pick-tick {
    position: absolute; top: 6px; left: 6px;
    width: 20px; height: 20px;
    display: none; align-items: center; justify-content: center;
    background: var(--vc-brand); color: #fff; border-radius: 50%;
    font-size: 11px; font-weight: 700;
}
.pl-card.is-picked .pl-pick-tick { display: inline-flex; }

/* stack the panes on narrow screens */
@media (max-width: 760px) {
    .pl-workspace { flex-direction: column; }
    .pl-side { flex: 0 0 auto; max-height: 42vh; border-left: 0; border-top: 1px solid var(--vc-line); }
    .pl-slots { max-height: 22vh; }
}

/* ── Base (free-text) slot — captured from #prompt, always first ── */
.pl-base {
    flex: 0 0 auto;
    padding: 8px 12px 6px;
    border-bottom: 1px solid var(--vc-line);
}
.pl-base-head { display: flex; align-items: center; gap: 8px; margin-bottom: 5px; }
.pl-base-head .pl-slot-glyph { flex: 0 0 auto; width: 16px; text-align: center; color: var(--vc-ink-4); font-size: 12px; }
.pl-base-head .pl-slot-label { flex: 1 1 auto; font-size: var(--vc-text-xs); font-weight: 600; color: var(--vc-ink-3); }
.pl-base-clear {
    flex: 0 0 auto; width: 18px; height: 18px;
    display: inline-flex; align-items: center; justify-content: center;
    border: 0; border-radius: 50%; background: rgba(255, 255, 255, .06);
    color: var(--vc-ink-3); font-size: 10px; cursor: pointer;
}
.pl-base-clear:hover:not(:disabled) { background: var(--vc-danger-bg); color: var(--vc-danger-soft); }
.pl-base-clear:disabled { opacity: .35; cursor: not-allowed; }
.pl-base-input {
    width: 100%; resize: vertical; min-height: 38px; max-height: 120px;
    background: var(--vc-raise); border: 1px solid var(--vc-line); border-radius: var(--vc-r-md);
    color: var(--vc-ink); font-family: var(--vc-font-sans); font-size: var(--vc-text-sm); line-height: 1.45;
    padding: 7px 9px; outline: none;
}
.pl-base-input:focus { border-color: var(--vc-brand-line); }
.pl-base-input::placeholder { color: var(--vc-ink-5); }
