/* ═══════════════════════════════════════════════════
   ASSET MANAGER — Layout, Sidebar, Library Tabs,
   Toolbar, Cards, Table, Modals, Reference Library
═══════════════════════════════════════════════════ */

/* ── Bölüm 1: Layout / Sidebar / Stats / Library Tabs ── */
/* LAYOUT */
.layout{display:flex;flex:1;min-height:0;overflow:hidden}
.sidebar{width:240px;flex-shrink:0;background:var(--surface2);border-right:1px solid var(--border);padding:20px 16px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}
.main{flex:1;overflow-y:auto;overflow-x:hidden;padding:24px;display:flex;flex-direction:column}

/* SIDEBAR */
.sb-section{display:flex;flex-direction:column;gap:6px}
.sb-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:4px;padding:0 8px}
.sb-item{padding:8px 12px;border-radius:8px;font-size:13px;color:var(--muted2);cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:all .15s;border:1px solid transparent}
.sb-item:hover{background:var(--surface2);color:var(--text)}
.sb-item.active{background:rgba(232,0,125,.12);border-color:rgba(232,0,125,.3);color:var(--accent3)}
.sb-count{font-size:11px;background:var(--surface3);border-radius:10px;padding:2px 7px;color:var(--muted)}
.sb-item.active .sb-count{background:rgba(232,0,125,.2);color:var(--accent3)}
.sb-divider{height:1px;background:var(--border);margin:4px 0}
.sb-sub-item{padding:5px 12px 5px 24px;border-radius:6px;font-size:12px;color:var(--muted);cursor:pointer;display:flex;align-items:center;transition:all .15s}
.sb-sub-item:hover{background:var(--surface2);color:var(--text)}
.sb-sub-item.active{color:var(--accent);background:rgba(232,0,125,.07)}

/* STATS */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:22px}
.stat{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 18px}
.stat-l{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px}
.stat-v{font-size:26px;font-weight:700;color:var(--text)}
.stat-sub{font-size:11px;color:var(--muted);margin-top:2px}
/* SIDEBAR COMPACT STATS */
.sb-stats{margin-top:auto;border-top:1px solid var(--border);padding-top:12px;display:flex;flex-direction:column;gap:2px}
.sb-stats-row{display:flex;justify-content:space-between;align-items:center;padding:4px 8px;font-size:11px;border-radius:6px}
.sb-stats-l{color:var(--muted);text-transform:uppercase;letter-spacing:.6px;font-weight:600}
.sb-stats-v{color:var(--text);font-weight:700;font-variant-numeric:tabular-nums}
/* LIBRARY TABS */
.lib-tabs{display:flex;gap:6px;margin-bottom:20px;flex-wrap:wrap}
.path-wrap{display:flex;align-items:flex-start;gap:8px}
.path-wrap .mono{flex:1;margin:0}
.copy-btn{padding:6px 10px;border-radius:7px;border:1px solid var(--border);background:var(--surface3);color:var(--muted2);cursor:pointer;font-size:11px;white-space:nowrap;transition:all .15s;flex-shrink:0}
.copy-btn:hover{border-color:var(--green);color:var(--green)}
.copy-btn.copied{border-color:var(--green);color:var(--green)}
.lib-tab{padding:8px 18px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--muted2);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}
.lib-tab:hover{border-color:var(--accent);color:var(--text)}
.lib-tab.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:700}
.lib-tab.lib-dragging{opacity:.4}
.lib-tab.lib-drop-before{box-shadow:-3px 0 0 var(--accent)}
.lib-tab.lib-drop-after {box-shadow: 3px 0 0 var(--accent)}
.lib-add-btn{border-style:dashed;color:var(--muted2);margin-left:6px}
.lib-add-btn:hover{border-color:var(--accent);color:var(--accent);background:transparent}
.lib-add-btn.deleting{color:#e55;border-color:#e55}
/* Add Library Dialog */
.addlib-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1000;align-items:center;justify-content:center}
.addlib-overlay.open{display:flex}


/* ── Bölüm 2: Toolbar, Cards, Modals, Reference ── */
/* TOOLBAR */
.toolbar{display:flex;gap:8px;margin-bottom:18px;align-items:center;flex-wrap:wrap}
.search-wrap{flex:1;min-width:200px;position:relative}
.search-wrap svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);opacity:.4;pointer-events:none}
.search{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:9px 13px 9px 35px;color:var(--text);font-size:13px;outline:none}
.search:focus{border-color:var(--accent)}
.search::placeholder{color:var(--muted)}
select{background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:9px 13px;color:var(--text);font-size:13px;outline:none;cursor:pointer;min-width:140px}
select:focus{border-color:var(--accent)}
.view-btns{display:flex;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:4px}
.vbtn{width:30px;height:30px;border:none;background:transparent;color:var(--muted);cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.vbtn.active{background:var(--surface3);color:var(--text)}

/* CARDS */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;align-items:start}
.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s;position:relative}
.card:hover{border-color:rgba(232,0,125,.4);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.5),0 0 0 1px rgba(232,0,125,.12)}
.card-thumb{width:100%;aspect-ratio:16/10;background:var(--surface2);position:relative;overflow:hidden}
.card-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.card:hover .card-thumb img{transform:scale(1.05)}
.card-thumb-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--muted);font-size:22px;gap:6px;opacity:.5}
.card-thumb-placeholder span{font-size:10px;font-family:-apple-system,sans-serif;letter-spacing:.5px;text-transform:uppercase}
.card-body{padding:12px}
.card-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-badges{display:flex;gap:5px;flex-wrap:wrap}
.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.3px}
.b-cat{background:rgba(232,0,125,.18);color:#ff6eb8;border:1px solid rgba(232,0,125,.3)}
.b-sub{background:rgba(240,134,26,.15);color:#f9a857;border:1px solid rgba(240,134,26,.3)}
.b-producer{background:rgba(99,102,241,.18);color:#a5b4fc;border:1px solid rgba(99,102,241,.3)}
.b-type{background:rgba(245,240,232,.08);color:var(--muted2);border:1px solid rgba(245,240,232,.15)}
.card-footer{padding:8px 12px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.card-id{font-size:10px;color:var(--muted);font-family:monospace}

/* TABLE VIEW */
.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden}
table{width:100%;border-collapse:collapse}
thead{background:var(--surface2)}
th{padding:10px 14px;text-align:left;font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid var(--border)}
td{padding:11px 14px;font-size:13px;border-bottom:1px solid var(--border);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(255,255,255,.02);cursor:pointer}
.thumb-sm{width:44px;height:32px;border-radius:6px;object-fit:cover;background:var(--surface2);display:block}
.name-cell{font-weight:600;max-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* PAGER */
.pager{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-top:1px solid var(--border);font-size:12px;color:var(--muted)}
.pager-btns{display:flex;gap:6px}
.pbtn{height:30px;padding:0 10px;border-radius:7px;border:1px solid var(--border);background:transparent;color:var(--text);cursor:pointer;font-size:12px;transition:all .15s}
.pbtn:hover{border-color:var(--accent)}.pbtn:disabled{opacity:.3;cursor:not-allowed}

/* ASSET DETAIL MODAL */
.img-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);display:flex;align-items:center;justify-content:center;z-index:9998;opacity:0;pointer-events:none;transition:opacity .2s;cursor:zoom-out}
.img-lightbox.open{opacity:1;pointer-events:all}
.img-lightbox img{max-width:92vw;max-height:90vh;object-fit:contain;border-radius:8px;box-shadow:0 8px 40px rgba(0,0,0,.6)}
#lbContent{display:none}
#lbContent iframe,#lbContent video{max-width:92vw;max-height:90vh;border-radius:8px;box-shadow:0 8px 40px rgba(0,0,0,.6)}
.img-lightbox .lb-name{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);color:#fff;font-size:13px;background:rgba(0,0,0,.6);padding:6px 16px;border-radius:8px;backdrop-filter:blur(8px)}
.asset-modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);align-items:center;justify-content:center;z-index:200;padding:20px}
.asset-modal-overlay.open{display:flex}
.asset-modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:960px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;transform:translateY(16px) scale(.98);transition:transform .25s cubic-bezier(.4,0,.2,1);box-shadow:0 32px 80px rgba(0,0,0,.6)}
.asset-modal-overlay.open .asset-modal{transform:translateY(0) scale(1)}
.asset-modal-head{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;flex-shrink:0}
.asset-modal-title{font-size:18px;font-weight:700;line-height:1.3;padding-right:12px}
.asset-modal-gid{font-size:11px;color:var(--muted);font-family:monospace;margin-top:3px}
.asset-modal-body{display:grid;grid-template-columns:440px 1fr;gap:0;flex:1}
.asset-modal-left{padding:20px 20px 20px 24px;display:flex;flex-direction:column;gap:16px;border-right:1px solid var(--border)}
.asset-modal-thumb{width:100%;aspect-ratio:16/10;background:var(--surface2);border-radius:10px;overflow:hidden;flex-shrink:0}
.asset-modal-thumb img{width:100%;height:100%;object-fit:cover}
.asset-modal-thumb-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:64px;opacity:.15}
.asset-modal-actions{display:flex;flex-direction:column;gap:8px}
.asset-modal-actions-title{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:2px}
.import-btn{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:9px;border:1px solid var(--border);background:var(--surface2);color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s;width:100%;text-align:left}
.import-btn:hover{border-color:var(--accent);background:rgba(232,0,125,.08);color:var(--accent3)}
.import-btn .ib-icon{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.ib-blender{background:rgba(240,134,26,.18);color:var(--accent2)}
.ib-ae{background:rgba(96,165,250,.18);color:#60a5fa}
.ib-nuke{background:rgba(52,211,153,.18);color:var(--green)}
.import-btn .ib-label{flex:1}
.import-btn .ib-sub{font-size:10px;color:var(--muted);font-weight:400;margin-top:1px}
.asset-modal-right{padding:20px 24px;display:flex;flex-direction:column;gap:14px;overflow-y:auto}
.detail-row{display:flex;flex-direction:column;gap:5px}
.detail-row-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px}
.detail-row-val{font-size:13px;color:var(--text);line-height:1.5}
.detail-row-val.mono{font-family:monospace;font-size:12px;color:var(--muted2);background:var(--surface2);padding:8px 10px;border-radius:7px;word-break:break-all}
.detail-row-val.desc{color:var(--muted2);font-size:13px}

/* ---- Meta cards (Description / Tags / Notes / Projects) ---- */
.meta-card{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:10px;transition:border-color .15s}
.meta-card:hover{border-color:rgba(245,240,232,0.14)}
.meta-card-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.meta-card-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px}
.meta-card-edit{background:transparent;border:1px solid rgba(232,0,125,.35);color:var(--accent3);padding:4px 10px;font-size:11px;font-weight:600;border-radius:6px;cursor:pointer;font-family:'Outfit',sans-serif;transition:background .12s;display:inline-flex;align-items:center;gap:4px;line-height:1}
.meta-card-edit:hover{background:rgba(232,0,125,.1)}
.meta-card-body{font-size:13px;color:var(--text);line-height:1.5;min-height:18px;white-space:pre-wrap;word-break:break-word}
.meta-card-body.is-empty{color:var(--muted);font-style:italic;font-size:12px}

/* Inline edit mode */
.inline-edit-wrap{display:flex;flex-direction:column;gap:6px}
.inline-edit-wrap textarea,
.inline-edit-wrap input{background:var(--surface);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:8px 10px;font-size:13px;font-family:inherit;width:100%;box-sizing:border-box;outline:none;transition:border-color .12s}
.inline-edit-wrap textarea{resize:vertical;min-height:60px}
.inline-edit-wrap textarea:focus,
.inline-edit-wrap input:focus{border-color:var(--accent3)}
.inline-edit-actions{display:flex;gap:6px;justify-content:flex-end;margin-top:2px}
.inline-edit-actions button{padding:6px 14px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;font-family:'Outfit',sans-serif}
.inline-edit-cancel{background:var(--surface2);border:1px solid var(--border);color:var(--text)}
.inline-edit-save{background:var(--accent3);border:none;color:#fff}
.detail-badges{display:flex;gap:6px;flex-wrap:wrap}

/* IMAGE PACKAGE (subcategory) — paket kartı 2x2 mosaic + popup */
.pkg-card .card-thumb{position:relative;background:#000;padding:0}
.pkg-mosaic{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:2px;width:100%;height:100%;background:#000}
.pkg-tile{background:#0a0a0a;overflow:hidden;display:flex;align-items:center;justify-content:center}
.pkg-tile img{width:100%;height:100%;object-fit:cover}
.pkg-tile-empty{background:linear-gradient(135deg,#0a0a0a,#1a1a1a)}
.pkg-stack-badge{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.7);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.18);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:10px;letter-spacing:.4px;display:flex;align-items:center;gap:4px}
.pkg-stack-badge::before{content:"";width:7px;height:7px;background:var(--accent3);border-radius:50%;box-shadow:0 0 6px var(--accent3)}

.pkg-popup-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.78);z-index:300;align-items:center;justify-content:center;padding:32px}
.pkg-popup-overlay.open{display:flex}
.pkg-popup{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:100%;max-width:1200px;max-height:88vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 32px 80px rgba(0,0,0,.6);transform:scale(.97);transition:transform .2s}
.pkg-popup-overlay.open .pkg-popup{transform:scale(1)}
.pkg-popup-head{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-shrink:0}
.pkg-popup-title{font-size:18px;font-weight:700;line-height:1.2}
.pkg-popup-sub{font-size:11px;color:var(--muted);margin-top:3px;font-family:monospace;letter-spacing:.3px}
.pkg-popup-close{background:transparent;border:none;color:var(--muted);font-size:24px;cursor:pointer;padding:2px 12px;border-radius:6px;line-height:1}
.pkg-popup-close:hover{background:var(--surface2);color:#fff}
.pkg-popup-body{padding:18px 22px;overflow-y:auto}
.pkg-popup-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}
.pkg-popup-card{cursor:pointer;border-radius:10px;overflow:hidden;background:var(--surface2);border:1px solid var(--border);transition:transform .15s,border-color .15s}
.pkg-popup-card:hover{transform:translateY(-2px);border-color:var(--accent3)}
.pkg-popup-thumb{aspect-ratio:1;background:#0a0a0a;overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:32px;color:rgba(255,255,255,.15)}
.pkg-popup-thumb img{width:100%;height:100%;object-fit:cover}
.pkg-popup-name{padding:8px 10px;font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* FILE LIST SECTION */
.asset-modal-files{border-top:1px solid var(--border);padding:20px 24px}
.files-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.files-title{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px}
.files-count{font-size:11px;color:var(--muted);background:var(--surface2);padding:2px 8px;border-radius:10px;margin-left:8px}
.open-folder-btn{display:flex;align-items:center;gap:6px;padding:7px 12px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--muted2);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s}
.open-folder-btn:hover{border-color:var(--accent2);color:var(--accent2)}
.file-list{display:flex;flex-direction:column;gap:6px;max-height:240px;overflow-y:auto}
.file-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;background:var(--surface2);border:1px solid var(--border);transition:border-color .15s}
.file-item:hover{border-color:rgba(232,0,125,.3)}
.file-ext{font-size:10px;font-weight:700;padding:2px 7px;border-radius:5px;background:var(--surface3);color:var(--muted2);text-transform:uppercase;min-width:36px;text-align:center;flex-shrink:0}
.file-name{flex:1;font-size:12px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.file-size{font-size:11px;color:var(--muted);white-space:nowrap;flex-shrink:0;margin-right:4px}
.file-actions{display:flex;gap:5px;flex-shrink:0}
.fbtn{padding:5px 10px;border-radius:6px;border:1px solid var(--border);background:var(--surface3);color:var(--muted2);font-size:11px;font-weight:700;cursor:pointer;transition:all .15s}
.fbtn:hover{border-color:var(--accent);color:var(--accent3);background:rgba(232,0,125,.1)}
.fbtn.fbtn-nuke:hover{border-color:var(--green);color:var(--green);background:rgba(52,211,153,.1)}
.files-loading{text-align:center;padding:20px;color:var(--muted);font-size:13px}
.files-empty{text-align:center;padding:20px;color:var(--muted);font-size:13px}

/* QUICK ACCESS */
.asset-modal-qa{padding:14px 16px}
.qa-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.qa-title-wrap{display:flex;align-items:center;gap:10px}
.qa-title{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px}
.qa-badge{font-size:10px;font-weight:700;background:rgba(232,0,125,.18);color:var(--accent3);border:1px solid rgba(232,0,125,.3);padding:2px 8px;border-radius:10px}
.qa-header-btns{display:flex;gap:8px;align-items:center}
.qa-add-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;border:1px solid rgba(232,0,125,.4);background:rgba(232,0,125,.08);color:var(--accent3);font-size:12px;font-weight:700;cursor:pointer;transition:all .15s}
.qa-add-btn:hover{background:rgba(232,0,125,.18);border-color:var(--accent)}
.qa-clear-btn{padding:7px 12px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--muted);font-size:12px;cursor:pointer;transition:all .15s;display:none}
.qa-clear-btn:hover{border-color:var(--red);color:var(--red)}
.qa-empty{text-align:center;padding:24px 16px;border:1.5px dashed rgba(245,240,232,.12);border-radius:10px;color:var(--muted);font-size:13px;line-height:1.6}
.qa-empty-icon{font-size:28px;margin-bottom:8px;opacity:.4}
.qa-empty-hint{font-size:11px;color:var(--muted);margin-top:4px;opacity:.7}
.qa-list{display:flex;flex-direction:column;gap:6px;max-height:220px;overflow-y:auto}
.fbtn-blend:hover{border-color:var(--accent2);color:var(--accent2);background:rgba(240,134,26,.1)}
.fbtn-remove{border-color:transparent;color:var(--muted);opacity:.6}
.fbtn-remove:hover{border-color:var(--red)!important;color:var(--red)!important;background:rgba(248,113,113,.1)!important;opacity:1}

/* DOSYALAR — tam genislik alt bolum */
.am-files-section{border-top:1px solid var(--border);padding:18px 24px;display:none}
.am-files-section.has-files{display:block}
.am-files-label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.am-files-label span{font-size:11px;background:var(--surface2);border-radius:10px;padding:2px 8px;color:var(--muted);font-weight:400;text-transform:none;letter-spacing:0}
/* QA bottom (3D layout) */
.am-qa-bottom{display:none;border-top:1px solid var(--border);padding:18px 24px}
.am-qa-bottom.active{display:block}

/* VIDEO FILE CARDS (popup 2-col grid) */
.vfile-card{background:var(--surface2);border:1px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color .15s}
.vfile-card:hover{border-color:rgba(232,0,125,.4)}
.vfile-thumb-wrap{position:relative;aspect-ratio:16/9;background:#111;overflow:hidden;cursor:pointer}
.vfile-thumb-wrap img{width:100%;height:100%;object-fit:cover;display:block}
.vfile-icon-wrap{width:100%;height:100%;display:flex;align-items:center;justify-content:center;opacity:.2}
.vfile-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.75) 0%,rgba(0,0,0,.2) 55%,transparent 100%);opacity:0;transition:opacity .18s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}
.vfile-card:hover .vfile-overlay{opacity:1}
.vfile-play-btn{width:38px;height:38px;background:rgba(255,255,255,.85);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;padding-left:3px;flex-shrink:0;pointer-events:none}
.vfile-act-row{display:flex;gap:6px;position:absolute;bottom:8px;left:0;right:0;justify-content:center}
.vfile-actbar{display:flex;gap:4px;flex-wrap:nowrap;align-items:center;justify-content:center;padding:6px 6px;background:var(--surface2);border-top:1px solid rgba(245,240,232,.04);overflow:hidden}
.vfc-btn{padding:4px 12px;border-radius:6px;border:1px solid rgba(255,255,255,.25);background:rgba(0,0,0,.55);color:rgba(255,255,255,.9);font-size:11px;font-weight:700;cursor:pointer;transition:all .15s;font-family:'Outfit',sans-serif;backdrop-filter:blur(4px)}
.vfc-btn:hover{background:rgba(232,0,125,.85);border-color:var(--accent);color:#fff}
.vfc-btn.vfc-nuke:hover{background:rgba(52,211,153,.85);border-color:var(--green);color:#fff}
.vfc-btn.vfc-blend:hover{background:rgba(240,134,26,.85);border-color:var(--accent2);color:#fff}
.vfile-actbar .vfc-btn{background:rgba(245,240,232,.06);border-color:rgba(245,240,232,.18);color:var(--text);backdrop-filter:none;padding:3px 7px;font-size:10px;flex-shrink:1;min-width:0}
.vfile-actbar .vfc-btn:hover{background:rgba(232,0,125,.18);border-color:var(--accent);color:#fff}
.vfile-actbar .vfc-btn.vfc-nuke:hover{background:rgba(52,211,153,.22);border-color:var(--green);color:#fff}
.vfile-actbar .vfc-btn.vfc-blend:hover{background:rgba(240,134,26,.22);border-color:var(--accent2);color:#fff}
.vfile-info{padding:8px 10px;background:var(--surface2)}
.vfile-name{font-size:11px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}
.vfile-meta{display:flex;gap:4px;flex-wrap:wrap;align-items:center;min-height:18px}
.vfile-pseudo-fs{position:fixed !important;top:0 !important;left:0 !important;right:0 !important;bottom:0 !important;width:100vw !important;height:100vh !important;aspect-ratio:auto !important;z-index:99999 !important;background:#000 !important;border-radius:0 !important;margin:0 !important}
.vfile-pseudo-fs > video{width:100% !important;height:100% !important;object-fit:contain !important}
.qa-path-note{font-size:10px;color:var(--muted);opacity:.6;margin-top:2px;font-family:monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:260px}

/* ADD MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:300;opacity:0;pointer-events:none;transition:opacity .2s}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:560px;max-width:95vw;max-height:90vh;overflow-y:auto;padding:26px;transform:translateY(12px);transition:transform .2s}
.modal-overlay.open .modal{transform:translateY(0)}
.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.modal-title{font-size:17px;font-weight:700}
.xbtn{background:none;border:none;color:var(--muted);font-size:20px;cursor:pointer;padding:4px}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fg{display:flex;flex-direction:column;gap:5px}.fg.full{grid-column:1/-1}
label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.fi{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:9px 12px;color:var(--text);font-size:13px;outline:none;width:100%}
.fi:focus{border-color:var(--accent)}
textarea.fi{resize:vertical;min-height:80px;font-family:inherit}
.faction{display:flex;gap:10px;justify-content:flex-end;margin-top:18px;padding-top:16px;border-top:1px solid var(--border)}

/* EMPTY / TOAST */
.empty{text-align:center;padding:60px;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:12px}
.empty-icon{font-size:40px;opacity:.3}
.spin{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:sp .6s linear infinite;display:inline-block;vertical-align:middle}
@keyframes sp{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.6}}

/* REFERENCE LIBRARY */
.ref-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.ref-add-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:10px;border:1px solid rgba(232,0,125,.4);background:rgba(232,0,125,.08);color:var(--accent3);font-size:14px;font-weight:700;cursor:pointer;transition:all .15s}
.ref-add-btn:hover{background:rgba(232,0,125,.18);border-color:var(--accent)}
.ref-search{background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:9px 14px;color:var(--text);font-size:13px;outline:none;min-width:220px}
.ref-search:focus{border-color:var(--accent)}
.ref-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s;position:relative}
.ref-card:hover{border-color:rgba(232,0,125,.4);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.5)}
.ref-card-thumb{width:100%;aspect-ratio:16/10;background:var(--surface2);overflow:hidden;display:flex;align-items:center;justify-content:center}
.ref-card-thumb img{width:100%;height:100%;object-fit:cover}
.ref-card-body{padding:12px}
.ref-card-name{font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ref-card-desc{font-size:11px;color:var(--muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:8px}
.ref-tags{display:flex;gap:4px;flex-wrap:wrap}
.ref-tag{display:inline-block;padding:2px 8px;border-radius:12px;font-size:10px;font-weight:600;background:rgba(96,165,250,.15);color:#60a5fa;border:1px solid rgba(96,165,250,.25)}
.ref-card-footer{padding:8px 12px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.ref-card-count{font-size:10px;color:var(--muted)}
.ref-card-del{background:none;border:none;color:var(--muted);font-size:14px;cursor:pointer;opacity:.4;padding:2px 4px;transition:all .15s}
.ref-card-del:hover{opacity:1;color:var(--red)}
.ref-empty{text-align:center;padding:80px 20px;color:var(--muted)}
.custom-item-card:hover{border-color:rgba(232,0,125,.4);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.5)}
.custom-item-card:hover .custom-thumb-upload-btn{opacity:1 !important}
.custom-item-card:hover .custom-play-overlay{opacity:1 !important}
.custom-col-item:hover{opacity:.9}
.ref-empty-icon{font-size:48px;opacity:.3;margin-bottom:12px}

/* REF DETAIL POPUP */
.ref-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);display:flex;align-items:center;justify-content:center;z-index:200;opacity:0;pointer-events:none;transition:opacity .2s;padding:20px}
.ref-modal-overlay.open{opacity:1;pointer-events:all}
.ref-modal{background:var(--surface);border:1px solid var(--border);border-radius:16px;width:100%;max-width:800px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;transform:translateY(16px) scale(.98);transition:transform .25s cubic-bezier(.4,0,.2,1);box-shadow:0 32px 80px rgba(0,0,0,.6)}
.ref-modal-overlay.open .ref-modal{transform:translateY(0) scale(1)}
.ref-form-row{display:flex;flex-direction:column;gap:5px}
.ref-form-row label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.ref-form-row input,.ref-form-row textarea{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:9px 12px;font-size:13px;width:100%;box-sizing:border-box;font-family:inherit}
.ref-form-row input:focus,.ref-form-row textarea:focus{outline:none;border-color:var(--accent)}
.ref-att-card{background:var(--surface2);border:1px solid var(--border);border-radius:10px;overflow:hidden;cursor:pointer;transition:border-color .15s;position:relative}
.ref-att-card:hover{border-color:rgba(232,0,125,.3)}
.ref-att-thumb{width:100%;aspect-ratio:16/10;background:var(--surface3);display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.ref-att-thumb img{width:100%;height:100%;object-fit:cover}
.ref-att-label{padding:8px 10px;font-size:11px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ref-att-del{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,.7);border:none;color:#fff;font-size:12px;cursor:pointer;display:none;align-items:center;justify-content:center}
.ref-att-card:hover .ref-att-del{display:flex}
.ref-att-card:hover button[title="Klasore git"]{display:flex!important}

/* ── Settings Modal — tabbed layout ─────────────────────────────────────── */
.gs-modal-body{display:flex;flex:1;overflow:hidden}
.gs-sidebar{width:200px;background:var(--surface);border-right:1px solid var(--border);padding:10px 0;overflow-y:auto;flex-shrink:0}
.gs-tab-group-title{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;padding:12px 16px 5px}
.gs-tab{display:flex;align-items:center;gap:9px;padding:9px 16px;cursor:pointer;color:var(--muted2);font-size:12px;font-weight:500;border-left:3px solid transparent;transition:background .12s,color .12s,border-left-color .12s;user-select:none}
.gs-tab:hover{background:var(--surface2);color:var(--text)}
.gs-tab.active{background:var(--surface2);color:var(--text);border-left-color:var(--accent);font-weight:600}
.gs-content{flex:1;overflow-y:auto;padding:22px 26px}
.gs-section{display:none}
.gs-section.active{display:block}
.gs-section h2{margin:0 0 3px;font-size:16px;font-weight:700;color:var(--text)}
.gs-section .gs-desc{color:var(--muted);font-size:12px;margin-bottom:18px;line-height:1.5}
.gs-row{display:flex;align-items:center;gap:8px;padding:6px 10px;background:var(--surface3);border-radius:8px;margin-bottom:6px;cursor:grab;user-select:none;transition:transform .12s,opacity .12s,box-shadow .12s}
.gs-addform{display:flex;gap:7px;align-items:center;margin-top:6px;flex-wrap:wrap}
.gs-addform input[type="text"]{background:var(--surface3);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:7px 10px;font-size:12px;font-family:'Outfit',sans-serif;outline:none}
.gs-addform input[type="text"]:focus{border-color:var(--accent3)}
.gs-addform input[type="color"]{width:34px;height:32px;border:1px solid var(--border);border-radius:8px;background:var(--surface3);cursor:pointer;padding:2px}
.gs-addform .gs-btn{padding:7px 14px;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:12px;font-family:'Outfit',sans-serif;font-weight:600}
.gs-addform .gs-btn:hover{filter:brightness(1.1)}
.gs-note{margin-top:14px;font-size:11px;color:var(--muted);padding:9px 12px;background:var(--surface3);border-left:3px solid var(--accent3);border-radius:4px;line-height:1.5}
.gs-empty{font-size:12px;color:var(--muted);padding:10px;text-align:center;background:var(--surface3);border:1px dashed var(--border);border-radius:8px;margin-bottom:6px}
