:root{--bg: #f4f5f7;--surface: #ffffff;--border: #e4e7ec;--text: #101828;--text-2: #667085;--text-3: #98a2b3;--accent: #2563eb;--accent-hover: #1d4ed8;--accent-subtle: #eff6ff;--danger: #d92d20;--danger-subtle: #fff1f0;--success: #22c55e;--success-subtle: #f0fdf4;--topbar-bg: #0f172a;--radius: 12px;--shadow-sm: 0 1px 3px rgba(16, 24, 40, .06), 0 1px 2px rgba(16, 24, 40, .04);--shadow-md: 0 4px 16px rgba(16, 24, 40, .1);font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Helvetica,Arial,sans-serif;font-size:14px;color:var(--text);-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh;background:var(--bg)}.topbar{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0 24px;height:56px;background:var(--topbar-bg)}.topbar-logo{font-size:15px;font-weight:600;letter-spacing:.03em;color:#f8fafc;white-space:nowrap}.topbar-right{display:flex;align-items:center;gap:10px;flex:1;justify-content:flex-end;max-width:560px}.search-wrap{position:relative;flex:1;max-width:320px}.search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:#64748b;pointer-events:none}.search-input{width:100%;padding:8px 10px 8px 32px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#f1f5f9;font:inherit;font-size:13px;outline:none;transition:border-color .15s,background .15s}.search-input::placeholder{color:#475569}.search-input:focus{background:#ffffff1f;border-color:#ffffff38}.btn-primary{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;background:var(--accent);color:#fff;border:none;border-radius:8px;font:inherit;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;transition:background .15s;text-decoration:none}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.btn-primary:disabled{opacity:.45;cursor:default}.upload-panel{background:var(--surface);border-bottom:1px solid var(--border);padding:20px 24px;animation:slide-down .18s ease}@keyframes slide-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.upload-form{display:flex;flex-direction:column;gap:10px;max-width:780px}.drop-zone{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;min-height:64px;border:1.5px dashed var(--border);border-radius:var(--radius);cursor:pointer;padding:12px 20px;text-align:center;transition:border-color .15s,background .15s;-webkit-user-select:none;user-select:none}.drop-zone:hover,.drop-zone.dragging{border-color:var(--accent);background:var(--accent-subtle)}.drop-zone.has-file{border-color:var(--success);background:var(--success-subtle);border-style:solid}.drop-icon{font-size:18px;line-height:1;flex-shrink:0}.drop-label{font-size:12.5px;font-weight:500;color:var(--text)}.drop-sub{font-size:11px;color:var(--text-2);margin-left:4px}.input{flex:1;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font:inherit;font-size:13px;color:var(--text);outline:none;background:var(--surface);transition:border-color .15s,box-shadow .15s;align-self:stretch}.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1a}.input::placeholder{color:var(--text-3)}.main{flex:1;padding:24px;min-width:0}.status-text,.empty-state{text-align:center;padding:80px 0;color:var(--text-2);font-size:14px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.grid--portrait{grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow .2s,transform .2s}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-thumb{position:relative;aspect-ratio:4 / 3;background:#f1f3f6;overflow:hidden;display:block;text-decoration:none}.card-thumb--portrait{aspect-ratio:9 / 18;background:#f8fafc;padding:30px}.card-thumb.card-thumb--portrait img{object-fit:contain}.card:hover .card-thumb--portrait img{transform:none}.card-thumb img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s}.card:hover .card-thumb img{transform:scale(1.04)}.card-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a61;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.card:hover .card-overlay{opacity:1}.overlay-btn{padding:7px 18px;background:#fffffff2;color:var(--text);border-radius:8px;font-size:12.5px;font-weight:500;text-decoration:none;transition:background .1s}.overlay-btn:hover{background:#fff}.card-body{padding:12px 14px 14px}.card-title{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px;text-decoration:none;display:block}a.card-title:hover{color:var(--primary)}.card-meta{font-size:11.5px;color:var(--text-2);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.5}.card-actions{display:flex;gap:6px;align-items:center;margin-top:10px}.format-select{flex:1;min-width:0;padding:6px 8px;border:1px solid var(--border);border-radius:7px;font:inherit;font-size:12px;color:var(--text);background:var(--surface);cursor:pointer;outline:none;transition:border-color .15s}.format-select:focus{border-color:var(--accent)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:7px;border:1px solid var(--border);background:var(--surface);cursor:pointer;flex-shrink:0;transition:background .15s,border-color .15s,color .15s;text-decoration:none}.btn-icon svg{width:15px;height:15px}.btn-download{color:var(--accent)}.btn-download:hover{background:var(--accent-subtle);border-color:var(--accent)}.btn-update{color:#0891b2}.btn-update:hover{background:#ecfeff;border-color:#0891b2}.btn-delete{color:var(--danger)}.btn-delete:hover{background:var(--danger-subtle);border-color:var(--danger)}.version-badge{position:absolute;top:8px;right:8px;padding:2px 7px;background:#0f172ab8;color:#f1f5f9;font-size:11px;font-weight:600;border-radius:6px;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.update-form{display:flex;align-items:center;gap:8px;margin:8px 0 4px;padding:8px;background:#f0f9ff;border:1px dashed #0891b2;border-radius:8px}.update-form input[type=file]{flex:1;font-size:11.5px;color:var(--text);min-width:0}.update-cancel{font:inherit;font-size:12px;color:var(--text-2);background:none;border:none;cursor:pointer;white-space:nowrap;padding:2px 4px}.update-cancel:hover{color:var(--text)}.version-history{margin:6px 0 4px;font-size:11.5px;color:var(--text-2)}.version-history summary{cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--text-2);list-style:none}.version-history summary::-webkit-details-marker{display:none}.version-history summary:before{content:"▶ ";font-size:9px}details[open].version-history summary:before{content:"▼ "}.version-history ul{margin:4px 0 0 10px;padding:0;list-style:none;display:flex;flex-direction:column;gap:2px}.version-history li{font-size:11px;color:var(--text-3)}.card-checkbox{position:absolute;top:8px;left:8px;z-index:3;width:22px;height:22px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;cursor:pointer}.card:hover .card-checkbox,.card.selected .card-checkbox{opacity:1}.card-checkbox input[type=checkbox]{width:17px;height:17px;cursor:pointer;accent-color:var(--accent);border-radius:4px}.card.selected{border-color:var(--accent);box-shadow:0 0 0 2px #2563eb2e}.card.selected .card-thumb:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#2563eb14;pointer-events:none}.wizard-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:300;display:flex;align-items:center;justify-content:center;animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.wizard-modal{background:var(--surface);border-radius:16px;box-shadow:var(--shadow-md);width:90vw;max-width:900px;max-height:85vh;display:flex;flex-direction:column;overflow:hidden}.wizard-header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border)}.wizard-header h2{font-size:16px;font-weight:600}.wizard-grid{overflow-y:auto;padding:16px 24px;display:flex;flex-direction:column;gap:12px}.wizard-card{display:flex;align-items:center;gap:14px;padding:10px 12px;border:1px solid var(--border);border-radius:10px;background:var(--bg)}.wizard-card-thumb{width:64px;height:64px;border-radius:6px;overflow:hidden;flex-shrink:0;background:#fff}.wizard-card-thumb img{width:100%;height:100%;object-fit:contain}.wizard-card-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.wizard-card-filename{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wizard-card-sku{font-size:12px;color:var(--text-2)}.wizard-card-actions{display:flex;gap:6px;flex-shrink:0}.wizard-pl-btn{padding:6px 14px;border:1px solid var(--border);border-radius:7px;background:var(--surface);font:inherit;font-size:12.5px;cursor:pointer;transition:all .12s;white-space:nowrap}.wizard-pl-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}.wizard-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:12px}.wizard-comment{width:100%}.wizard-footer-actions{display:flex;gap:8px;justify-content:flex-end}.btn-secondary{padding:8px 18px;border:1px solid var(--border);border-radius:8px;background:var(--surface);font:inherit;font-size:13px;cursor:pointer;transition:background .12s}.wizard-modal--sm{max-width:520px}.delivery-info{font-size:13px;color:var(--text-2)}.delivery-info--sent{color:var(--success);font-weight:500}.delivery-link-row{display:flex;gap:8px}.delivery-link-input{flex:1;font-size:12px;font-family:monospace}.bulk-bar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;padding:10px 16px;background:#0f172a;border:1px solid rgba(255,255,255,.08);border-radius:12px;box-shadow:0 8px 32px #00000059;z-index:200;white-space:nowrap;animation:slide-up .2s ease}@keyframes slide-up{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.bulk-count{font-size:13px;font-weight:500;color:#e2e8f0;padding-right:6px;border-right:1px solid rgba(255,255,255,.12)}.bulk-select{padding:6px 10px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:7px;color:#e2e8f0;font:inherit;font-size:12.5px;cursor:pointer;outline:none}.bulk-btn-download{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:var(--accent);color:#fff;border:none;border-radius:7px;font:inherit;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.bulk-btn-download:hover:not(:disabled){background:var(--accent-hover)}.bulk-btn-download:disabled{opacity:.5;cursor:default}.bulk-btn-clear{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;background:transparent;border:1px solid rgba(255,255,255,.12);border-radius:7px;color:#94a3b8;cursor:pointer;transition:background .15s,color .15s}.bulk-btn-clear:hover{background:#ffffff14;color:#e2e8f0}.filter-pills{display:flex;gap:6px;flex-wrap:wrap}.filter-pill{padding:5px 14px;border:1px solid var(--border);border-radius:20px;background:var(--surface);color:var(--text-2);font:inherit;font-size:12.5px;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.filter-pill:hover{border-color:var(--accent);color:var(--accent)}.filter-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}.type-icon{position:absolute;top:8px;right:8px;padding:2px 7px;background:#0f172ab8;color:#f1f5f9;font-size:11px;font-weight:700;border-radius:6px;pointer-events:none;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);letter-spacing:.02em}.detail-video{max-width:100%;max-height:100%;border-radius:6px}.detail-pdf{width:100%;height:100%;border:none;border-radius:4px;background:#fff}.card-thumb-link{display:block;text-decoration:none;color:inherit}.detail-layout{display:grid;grid-template-columns:1fr 400px;min-height:calc(100vh - 56px)}.detail-preview{position:sticky;top:56px;height:calc(100vh - 56px);background:#0f172a;display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;padding:24px}.detail-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:6px}.compare-view{display:flex;align-items:stretch;gap:0;width:100%;height:100%}.compare-panel{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;overflow:hidden;padding:12px}.compare-panel img{max-width:100%;max-height:calc(100% - 48px);object-fit:contain;border-radius:4px}.compare-divider{width:1px;background:#ffffff1f;flex-shrink:0}.compare-label{display:flex;flex-direction:column;align-items:center;gap:4px}.compare-badge{padding:3px 10px;background:#ffffff1f;color:#e2e8f0;font-size:12px;font-weight:600;border-radius:6px}.compare-comment{font-size:11px;color:#94a3b8;font-style:italic;text-align:center}.compare-close{position:absolute;bottom:16px;left:50%;transform:translate(-50%);padding:6px 14px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);border-radius:8px;color:#e2e8f0;font:inherit;font-size:12px;cursor:pointer;transition:background .15s}.compare-close:hover{background:#ffffff2e}.detail-panel{border-left:1px solid var(--border);overflow-y:auto;background:var(--surface)}.detail-section{padding:20px 24px;border-bottom:1px solid var(--border)}.section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);margin-bottom:12px}.title-row{display:flex;align-items:flex-start;gap:8px;margin-bottom:4px}.detail-title{font-size:18px;font-weight:700;color:var(--text);line-height:1.3;flex:1}.detail-filename{font-size:12px;color:var(--text-2)}.title-edit-row{display:flex;gap:8px;align-items:center;margin-bottom:4px}.title-input{flex:1;font-size:16px;font-weight:600}.btn-edit{padding:6px;background:none;border:1px solid var(--border);border-radius:6px;color:var(--text-2);cursor:pointer;display:flex;align-items:center;transition:background .15s,color .15s}.btn-edit:hover{background:var(--bg);color:var(--text)}.meta-grid{display:grid;grid-template-columns:auto 1fr;gap:6px 16px}.meta-label{font-size:12px;color:var(--text-2);white-space:nowrap}.meta-value{font-size:12px;color:var(--text);font-weight:500}.download-row{display:flex;gap:8px}.download-row .format-select{flex:1}.topbar-back{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#e2e8f0;font:inherit;font-size:13px;cursor:pointer;transition:background .15s;white-space:nowrap}.topbar-back:hover{background:#ffffff24}.btn-danger-outline{padding:7px 14px;background:transparent;border:1px solid rgba(239,68,68,.5);border-radius:8px;color:#fca5a5;font:inherit;font-size:13px;cursor:pointer;transition:background .15s,border-color .15s}.btn-danger-outline:hover{background:#ef44441f;border-color:#f87171}.version-list{display:flex;flex-direction:column;gap:10px}.version-item{border:1px solid var(--border);border-radius:10px;padding:12px;background:var(--bg)}.version-item-header{display:flex;align-items:baseline;gap:8px;margin-bottom:4px}.version-num{font-size:12px;font-weight:700;color:var(--accent);background:var(--accent-subtle);padding:1px 7px;border-radius:5px}.version-meta{font-size:11.5px;color:var(--text-2)}.version-comment{font-size:12px;color:var(--text-2);font-style:italic;margin:4px 0 8px}.version-actions{display:flex;gap:6px;flex-wrap:wrap}.ver-btn{padding:5px 10px;font:inherit;font-size:12px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);cursor:pointer;transition:background .15s,border-color .15s}.ver-btn:hover{background:var(--bg);border-color:var(--border-hover)}.ver-btn-danger{color:var(--danger)}.ver-btn-danger:hover{background:var(--danger-subtle);border-color:var(--danger)}.body-layout{display:flex;min-height:calc(100vh - 56px)}.body-layout--no-sidebar .main{padding:24px 32px}.sidebar{width:220px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);position:sticky;top:56px;height:calc(100vh - 56px);overflow-y:auto;padding:16px 0}.sidebar-nav{display:flex;flex-direction:column;gap:2px;padding:0 8px}.sidebar-section-label{font-size:10.5px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);padding:12px 8px 4px}.sidebar-item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;border:none;border-radius:8px;background:none;color:var(--text-2);font:inherit;font-size:13px;cursor:pointer;text-align:left;transition:background .15s,color .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-item:hover{background:var(--bg);color:var(--text)}.sidebar-item.active{background:var(--accent-subtle);color:var(--accent);font-weight:600}.sidebar-dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0;opacity:.5}.sidebar-item.active .sidebar-dot{opacity:1}.sidebar-dot--unassigned{background:var(--text-3)}.upload-row{display:flex;gap:8px;flex-wrap:wrap;flex:1}.upload-row .input{flex:1;min-width:120px}.upload-row-label{font-size:12px;color:var(--text-2);white-space:nowrap;align-self:center}.card-tag{font-size:11px;font-weight:500;color:var(--accent);background:var(--accent-subtle);border-radius:4px;padding:1px 6px;display:inline-block;margin-bottom:3px;text-transform:capitalize}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-header .section-title{margin-bottom:0}.meta-edit-block{display:flex;flex-direction:column;gap:6px}.meta-edit-label{font-size:11.5px;font-weight:500;color:var(--text-2);margin-top:4px}.meta-edit-actions{display:flex;gap:8px;margin-top:4px;align-items:center}.card-tags{display:flex;flex-wrap:wrap;gap:3px;margin-bottom:3px}.asset-tag{display:inline-block;font-size:10.5px;font-weight:500;padding:1px 6px;border-radius:4px;background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;white-space:nowrap}.sidebar-tag-cloud{display:flex;flex-wrap:wrap;gap:4px;padding:4px 8px 10px}.sidebar-tag{padding:3px 8px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text-2);font:inherit;font-size:11.5px;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.sidebar-tag:hover{border-color:var(--accent);color:var(--accent)}.sidebar-tag.active{background:var(--accent);border-color:var(--accent);color:#fff}.topbar-nav{display:flex;align-items:center;gap:2px;margin-left:16px}.topbar-nav-link{padding:6px 12px;border-radius:7px;color:#94a3b8;font:inherit;font-size:13px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;white-space:nowrap}.topbar-nav-link:hover{background:#ffffff14;color:#e2e8f0}.topbar-nav-link.active{background:#ffffff1a;color:#f1f5f9}.sidebar-lang-pills{display:flex;flex-wrap:wrap;gap:4px;padding:4px 8px 8px}.lang-pill{padding:3px 8px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text-2);font:inherit;font-size:11.5px;font-weight:600;cursor:pointer;letter-spacing:.03em;transition:background .15s,border-color .15s,color .15s}.lang-pill:hover{border-color:var(--accent);color:var(--accent)}.lang-pill.active{background:var(--accent);border-color:var(--accent);color:#fff}.doc-list{display:flex;flex-direction:column;gap:8px}.doc-row{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;box-shadow:var(--shadow-sm);transition:box-shadow .15s}.doc-row:hover{box-shadow:var(--shadow-md)}.doc-thumb-cell{width:52px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.doc-thumb{width:52px;height:68px;object-fit:cover;border-radius:4px;border:1px solid var(--border);background:#fff;display:block}.doc-pdf-icon{display:block}.doc-content{flex:1;min-width:0}.doc-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:5px}.doc-title{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:400px}.doc-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.doc-meta-text{font-size:12px;color:var(--text-3)}.doc-type-badge{font-size:11px;font-weight:600;padding:2px 7px;border-radius:5px;white-space:nowrap;background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.doc-type-badge--folder{background:#fef9c3;color:#854d0e;border-color:#fef08a}.doc-type-badge--katalog{background:#dbeafe;color:#1e40af;border-color:#bfdbfe}.doc-type-badge--software{background:#d1fae5;color:#065f46;border-color:#a7f3d0}.doc-type-badge--verkabelungsplan{background:#ede9fe;color:#5b21b6;border-color:#ddd6fe}.doc-type-badge--montageanleitung{background:#ffedd5;color:#9a3412;border-color:#fed7aa}.doc-type-badge--infoblatt{background:#e0f2fe;color:#0c4a6e;border-color:#bae6fd}.doc-type-badge--technische-zeichnung{background:#f0fdf4;color:#166534;border-color:#bbf7d0}.doc-type-badge--ausschreibungstext{background:#fce7f3;color:#9d174d;border-color:#fbcfe8}.doc-type-badge--bedienungsanleitung{background:#fff7ed;color:#c2410c;border-color:#fed7aa}.doc-type-badge--zertifikat{background:#ecfdf5;color:#065f46;border-color:#6ee7b7}.doc-type-badge--sicherheitshinweise{background:#fef2f2;color:#991b1b;border-color:#fecaca}.lang-badge{font-size:10.5px;font-weight:700;letter-spacing:.05em;padding:2px 6px;border-radius:4px;background:#f8fafc;color:#64748b;border:1px solid var(--border);white-space:nowrap}.doc-actions{display:flex;gap:6px;align-items:center;flex-shrink:0}.doc-edit-form{display:flex;flex-direction:column;gap:6px}.doc-edit-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.doc-edit-input{flex:1;min-width:120px}.doc-edit-select{min-width:130px}.topbar-settings-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:8px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);color:#94a3b8;text-decoration:none;flex-shrink:0;transition:background .15s,color .15s}.topbar-settings-btn:hover{background:#ffffff24;color:#e2e8f0}.sidebar-family-group{display:flex;flex-direction:column}.sidebar-item--family{display:flex;align-items:center;gap:4px;padding:7px 10px 7px 6px;border:none;border-radius:8px;background:none;color:var(--text-2);font:inherit;font-size:13px;cursor:default;text-align:left;transition:background .15s,color .15s;white-space:nowrap;overflow:hidden}.sidebar-item--family:hover{background:var(--bg);color:var(--text)}.sidebar-item--family.active{background:var(--accent-subtle);color:var(--accent);font-weight:600}.sidebar-item-label{flex:1;cursor:pointer;overflow:hidden;text-overflow:ellipsis}.sidebar-expand-btn{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border:none;background:none;padding:0;cursor:pointer;color:inherit;flex-shrink:0;border-radius:4px}.sidebar-expand-btn:hover{background:#0000000f}.sidebar-chevron{font-size:9px;display:inline-block;transition:transform .15s;color:var(--text-3)}.sidebar-chevron.open{transform:rotate(90deg)}.sidebar-item--model{padding-left:28px;font-size:12.5px}.sidebar-tree-indent{font-size:10px;color:var(--text-3);flex-shrink:0}.settings-layout{display:flex;justify-content:center;padding:40px 24px;min-height:calc(100vh - 56px);background:var(--bg)}.settings-page{width:100%;max-width:640px}.settings-heading{font-size:22px;font-weight:700;color:var(--text);margin-bottom:4px}.settings-subheading{font-size:14px;font-weight:600;color:var(--text-2);margin-bottom:24px}.settings-error{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;background:var(--danger-subtle);border:1px solid rgba(217,45,32,.2);border-radius:8px;color:var(--danger);font-size:13px;margin-bottom:16px}.settings-error button{background:none;border:none;color:var(--danger);cursor:pointer;font-size:14px;line-height:1;padding:0;flex-shrink:0}.settings-add-row{display:flex;gap:10px;margin-bottom:24px}.settings-input{flex:1}.settings-tree{display:flex;flex-direction:column;gap:12px}.settings-empty{color:var(--text-3);font-size:13px;padding:24px 0}.settings-family{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}.settings-row{display:flex;align-items:center;gap:8px;padding:10px 14px}.settings-row--family{border-bottom:1px solid var(--border);background:var(--bg)}.settings-row--family:last-child{border-bottom:none}.settings-row--model{border-top:1px solid var(--border)}.settings-row--add-model{border-top:1px solid var(--border);background:var(--accent-subtle)}.settings-children{display:flex;flex-direction:column}.settings-name{flex:1;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-name--family{font-weight:600;color:var(--text);font-size:14px}.settings-name--model{color:var(--text-2)}.settings-tree-line{color:var(--text-3);font-size:12px;flex-shrink:0}.settings-btn{padding:5px 10px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text-2);font:inherit;font-size:12px;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .15s,border-color .15s,color .15s}.settings-btn:hover{background:var(--bg);color:var(--text)}.settings-btn--danger{color:var(--danger);border-color:#d92d2040}.settings-btn--danger:hover{background:var(--danger-subtle);border-color:var(--danger)}.settings-btn--save{background:var(--accent);color:#fff;border-color:var(--accent)}.settings-btn--save:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.settings-btn--save:disabled{opacity:.4;cursor:default}.settings-btn--cancel{color:var(--text-3)}.settings-rename-input{flex:1;min-width:0;padding:6px 10px;font-size:13px}.settings-sku-input{width:90px;padding:4px 8px;font-size:12px;color:var(--text-2);border:1px solid var(--border);border-radius:4px;text-align:center;font-family:monospace}.settings-add-model-btn{display:block;width:100%;padding:8px 14px;border:none;background:none;color:var(--accent);font:inherit;font-size:12.5px;cursor:pointer;text-align:left;transition:background .15s;border-top:1px solid var(--border)}.settings-add-model-btn:hover{background:var(--accent-subtle)}.settings-hint{font-size:11px;color:var(--text-3);font-family:monospace;flex-shrink:0;margin-right:4px}.pending-banner{background:#fffbeb;border:1px solid #f59e0b;border-radius:var(--radius);padding:14px 16px;display:flex;flex-direction:column;gap:12px}.pending-banner-header{display:flex;align-items:center;gap:8px;color:#92400e;font-weight:600;font-size:13.5px}.pending-banner-title{flex:1}.pending-banner-info{display:grid;grid-template-columns:100px 1fr;gap:4px 12px;font-size:13px}.pending-banner-actions{display:flex;gap:8px;flex-wrap:wrap}.pending-badge{display:inline-flex;align-items:center;padding:2px 7px;background:#fffbeb;border:1px solid #f59e0b;border-radius:4px;color:#92400e;font-size:11px;font-weight:500;white-space:nowrap}.pending-blocked-hint{font-size:13px;color:var(--text-3);padding:10px 0}a.doc-title{color:var(--text);text-decoration:none}a.doc-title:hover{color:var(--accent);text-decoration:underline}@media (max-width: 900px){.sidebar{width:180px}}@media (max-width: 640px){.topbar{padding:0 16px}.sidebar{display:none}.main{padding:14px}.upload-panel{padding:16px}.drop-zone{width:100%}.grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}}.main-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.view-mode-toggle{display:flex;gap:4px;flex-shrink:0}.view-mode-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text-2);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.view-mode-btn:hover{background:var(--bg);color:var(--text)}.view-mode-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.upload-queue{display:flex;flex-direction:column;gap:6px;margin:8px 0;max-height:280px;overflow-y:auto;padding:2px}.upload-queue-item{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:8px 10px}.upload-queue-filename{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:13px;color:var(--text);display:flex;align-items:center;gap:8px}.upload-queue-size{font-size:11px;color:var(--text-2);flex-shrink:0}.upload-queue-viewtype{width:140px;flex-shrink:0;font-size:12px;padding:4px 8px}.upload-queue-skn{width:90px;flex-shrink:0;font-size:12px;padding:4px 8px}.upload-queue-group{border:1px solid var(--border);border-radius:8px;overflow:hidden}.upload-queue-group-header{display:flex;align-items:center;gap:10px;padding:6px 10px;background:var(--bg);border-bottom:1px solid var(--border)}.upload-queue-sku{font-size:12px;font-weight:600;color:var(--accent)}.upload-queue-sku-count{font-size:11px;color:var(--text-2)}.upload-queue-group .upload-queue-item{border:none;border-bottom:1px solid var(--border);border-radius:0}.upload-queue-group .upload-queue-item:last-child{border-bottom:none}.upload-progress-text{font-size:13px;color:var(--accent);text-align:center}.view-badge{position:absolute;bottom:6px;left:6px;background:#000000a6;color:#fff;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:2px 6px;border-radius:4px;pointer-events:none}.sku-groups{display:flex;flex-direction:column;gap:16px}.sku-group{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}.sku-group-header{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);background:var(--bg)}.sku-group-title{font-size:14px;font-weight:600;color:var(--text)}.sku-group-count{font-size:12px;color:var(--text-2);flex:1}.btn-pm{padding:5px 14px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.btn-pm:hover{background:var(--accent-hover)}.sku-group-assets{display:flex;flex-wrap:wrap;gap:10px;padding:12px 16px}.sku-asset-thumb{position:relative;width:100px;height:100px;border-radius:8px;overflow:hidden;border:1px solid var(--border);display:block}.sku-asset-thumb img{width:100%;height:100%;object-fit:cover}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px}.delivery-modal{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-md);width:100%;max-width:460px;padding:28px;display:flex;flex-direction:column;gap:14px}.delivery-modal-title{font-size:16px;font-weight:700;color:var(--text);padding-bottom:8px;border-bottom:1px solid var(--border)}.delivery-modal-info{display:flex;align-items:flex-start;gap:12px;font-size:13px}.delivery-modal-label{width:80px;flex-shrink:0;color:var(--text-2);font-weight:500}.delivery-modal-value{color:var(--text);flex:1}.delivery-modal-email{color:var(--text-2);font-style:italic}.delivery-modal-note{resize:vertical;min-height:60px}.delivery-modal-error{font-size:13px;color:var(--danger);background:var(--danger-subtle);border-radius:8px;padding:8px 12px}.delivery-modal-success{font-size:13px;color:#16a34a;background:var(--success-subtle);border-radius:8px;padding:8px 12px}.delivery-modal-link-wrap{display:flex;flex-direction:column;gap:4px;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px 12px}.delivery-modal-link-label{font-size:11px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.05em}.delivery-modal-link{font-size:12px;color:var(--accent);word-break:break-all}.delivery-modal-actions{display:flex;gap:10px;justify-content:flex-end;padding-top:4px}.btn-secondary{padding:7px 16px;background:transparent;color:var(--text);border:1px solid var(--border);border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.btn-secondary:hover{background:var(--bg)}.mpaket-new-form{display:flex;gap:6px;margin-bottom:8px}.mpaket-new-input{flex:1;min-width:0;font-size:13px;padding:6px 8px;height:32px}.mpaket-new-btn{padding:0 12px;height:32px;font-size:18px;line-height:1;flex-shrink:0}.mpaket-sidebar-empty{font-size:12px;color:var(--text-3);padding:8px 4px}.mpaket-list-item{display:flex;align-items:center;gap:6px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:background .12s;-webkit-user-select:none;user-select:none}.mpaket-list-item:hover{background:var(--bg)}.mpaket-list-item.active{background:var(--accent-subtle);color:var(--accent)}.mpaket-list-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.mpaket-list-item-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mpaket-list-item-count{font-size:11px;color:var(--text-3)}.mpaket-list-delete{opacity:0;transition:opacity .12s;flex-shrink:0}.mpaket-list-item:hover .mpaket-list-delete{opacity:1}.mpaket-detail{display:flex;flex-direction:column;gap:28px;padding:4px 0}.mpaket-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.mpaket-title-row{display:flex;align-items:center;gap:8px}.mpaket-name{font-size:20px;font-weight:600;color:var(--text);line-height:1.2}.mpaket-name-input{font-size:18px;font-weight:600;width:260px}.mpaket-download-row{display:flex;align-items:center;gap:8px;flex-shrink:0}.mpaket-download-row .input{width:120px;font-size:13px;padding:6px 8px;height:34px}.mpaket-download-row .btn-primary{display:flex;align-items:center;gap:6px;white-space:nowrap}.mpaket-section{display:flex;flex-direction:column;gap:12px}.mpaket-section-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.mpaket-section-title{font-size:15px;font-weight:600;color:var(--text)}.mpaket-cat-group{margin-bottom:8px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.mpaket-cat-header{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;background:#f8fafc;border:none;cursor:pointer;text-align:left;font-size:13px;font-weight:600;color:var(--text-1)}.mpaket-cat-header:hover{background:#f1f3f6}.mpaket-cat-chevron{font-size:9px;color:var(--text-3);transition:transform .2s;transform:rotate(0)}.mpaket-cat-chevron.open{transform:rotate(90deg)}.mpaket-cat-label{flex:1}.mpaket-cat-count{font-size:11px;font-weight:500;color:var(--text-3);background:var(--border);border-radius:10px;padding:1px 7px}.mpaket-cat-group .mpaket-assets-grid{padding:12px;border-top:1px solid var(--border)}.mpaket-empty{font-size:13px;color:var(--text-3);padding:12px 0}.mpaket-assets-grid{display:flex;flex-wrap:wrap;gap:10px}.mpaket-asset-card{position:relative;width:120px;background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;display:flex;flex-direction:column}.mpaket-asset-thumb{width:100%;height:90px;object-fit:cover;display:block}.mpaket-asset-thumb--portrait{height:140px;object-fit:contain;background:#f8fafc;padding:8px}.mpaket-asset-info{padding:6px 8px;display:flex;flex-direction:column;gap:2px}.mpaket-asset-title{font-size:11px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mpaket-asset-category{font-size:10px;color:var(--text-3)}.mpaket-remove-btn{position:absolute;top:4px;right:4px;background:#0000008c!important;border-radius:50%!important;width:22px!important;height:22px!important;opacity:0;transition:opacity .12s;color:#fff!important;display:flex;align-items:center;justify-content:center}.mpaket-asset-card:hover .mpaket-remove-btn{opacity:1}.mpaket-doc-list{display:flex;flex-direction:column;gap:6px}.mpaket-doc-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:8px}.mpaket-doc-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.mpaket-doc-title{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mpaket-doc-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}.modal{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-md);width:100%;max-width:860px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.modal--docs{max-width:640px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-title{font-size:15px;font-weight:600}.modal-filters{padding:12px 20px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:10px;flex-shrink:0}.modal-search-row{display:flex;gap:8px;align-items:center}.modal-search-row .input{flex:1;height:34px;font-size:13px}.modal-body{flex:1;overflow-y:auto;padding:16px 20px}.modal-footer{display:flex;align-items:center;gap:10px;padding:14px 20px;border-top:1px solid var(--border);flex-shrink:0}.modal-count{flex:1;font-size:13px;color:var(--text-2)}.picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:10px}.picker-item{position:relative;border-radius:8px;border:2px solid var(--border);overflow:hidden;cursor:pointer;transition:border-color .12s;display:flex;flex-direction:column}.picker-item:hover{border-color:var(--accent)}.picker-item.selected{border-color:var(--accent);background:var(--accent-subtle)}.picker-thumb{width:100%;height:80px;object-fit:cover;display:block}.picker-checkmark{position:absolute;top:5px;right:5px;width:20px;height:20px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center}.picker-item-title{font-size:10px;color:var(--text-2);padding:4px 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.picker-doc-list{display:flex;flex-direction:column;gap:6px}.picker-doc-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:background .12s,border-color .12s}.picker-doc-item:hover{background:var(--bg)}.picker-doc-item.selected{background:var(--accent-subtle);border-color:var(--accent)}.picker-doc-check{width:18px;height:18px;border-radius:4px;border:1.5px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center}.picker-doc-check--on{background:var(--accent);border-color:var(--accent)}.picker-doc-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.picker-doc-title{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.picker-doc-meta{display:flex;align-items:center;gap:6px}.filter-pill-count{display:inline-flex;align-items:center;justify-content:center;background:currentColor;color:#fff;border-radius:10px;font-size:10px;font-weight:600;min-width:16px;height:16px;padding:0 4px;margin-left:4px;opacity:.75}.filter-pill.active .filter-pill-count{background:#fff;color:var(--accent);opacity:1}.appb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.appb-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}.appb-card-thumbs{display:grid;grid-template-columns:1fr 1fr;gap:0}.appb-thumb-wrap{position:relative;background:#f8fafc;display:flex;flex-direction:column;align-items:center}.appb-thumb-wrap+.appb-thumb-wrap{border-left:1px solid var(--border)}.appb-thumb{width:100%;height:200px;object-fit:contain;display:block;padding:8px}.appb-thumb-footer{display:flex;align-items:center;justify-content:space-between;width:100%;padding:4px 8px 8px}.appb-label{font-size:10px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em}.appb-thumb-pending{height:200px;justify-content:center}.appb-pending-text{font-size:11px;color:var(--text-3);text-align:center;padding:8px}.appb-card-footer{display:flex;flex-wrap:wrap;align-items:center;gap:6px;padding:10px 14px;border-top:1px solid var(--border)}.appb-card-title{font-size:12px;font-weight:500;color:var(--text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%;min-width:0;text-decoration:none}.appb-card-title:hover{color:var(--primary)}.appb-card-meta{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg)}.login-form{display:flex;flex-direction:column;gap:12px;width:100%;max-width:360px;padding:40px 32px;background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-md)}.login-title{font-size:24px;font-weight:700;text-align:center;margin:0 0 8px;color:var(--text)}.login-error{padding:8px 12px;background:var(--danger-subtle);color:var(--danger);border-radius:8px;font-size:13px}.login-btn{margin-top:4px;padding:10px 0}.topbar-logout-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:none;color:#fff9;cursor:pointer;border-radius:6px;transition:color .15s,background .15s}.topbar-logout-btn:hover{color:#fff;background:#ffffff1a}
