:root{--bg-0: #08090d;--bg-1: #0e1017;--bg-2: #151820;--bg-3: #1c1f2a;--bg-4: #252836;--bg-hover: #2e3244;--bg-active: #1a2440;--border: #252836;--border-accent: #4a7cff;--border-hover: #3a3f52;--text-1: #eaecf2;--text-2: #8890a4;--text-3: #5a6178;--accent: #4a7cff;--accent-dim: rgba(74, 124, 255, .12);--accent-glow: rgba(74, 124, 255, .2);--red: #ff4757;--red-dim: rgba(255, 71, 87, .12);--green: #2ed573;--orange: #ffa502;--r-sm: 6px;--r-md: 10px;--r-lg: 14px;--font: "DM Sans", -apple-system, sans-serif;--mono: "JetBrains Mono", monospace}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font);background:var(--bg-0);color:var(--text-1);line-height:1.5;-webkit-font-smoothing:antialiased;height:100vh;overflow:hidden}#root{height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-0);position:relative}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 30% 20%,rgba(74,124,255,.06) 0%,transparent 60%),radial-gradient(ellipse at 70% 80%,rgba(255,71,87,.04) 0%,transparent 60%);pointer-events:none}.login-card{position:relative;background:var(--bg-2);border:1px solid var(--border);border-radius:20px;padding:48px 40px;max-width:420px;width:90%;text-align:center;box-shadow:0 24px 64px #00000080;animation:slideUp .5s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.login-logo{font-size:48px;margin-bottom:20px}.login-card h1{font-size:24px;font-weight:700;margin-bottom:8px;letter-spacing:-.5px}.login-card p{color:var(--text-2);font-size:15px;margin-bottom:32px}.login-error{background:var(--red-dim);border:1px solid rgba(255,71,87,.3);border-radius:var(--r-md);padding:12px;color:var(--red);font-size:14px;margin-bottom:20px}.discord-btn{display:inline-flex;align-items:center;gap:12px;background:#5865f2;color:#fff;border:none;border-radius:var(--r-md);padding:14px 32px;font-size:16px;font-weight:600;font-family:var(--font);cursor:pointer;text-decoration:none;transition:all .2s;box-shadow:0 4px 16px #5865f24d}.discord-btn:hover{background:#4752c4;transform:translateY(-1px)}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:52px;background:var(--bg-1);border-bottom:1px solid var(--border);flex-shrink:0;z-index:100}.header-left{display:flex;align-items:center;gap:14px}.header-logo{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:700;letter-spacing:-.3px}.header-logo span{font-size:20px}.header-stats{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-3)}.header-stats .sep{opacity:.4}.role-badge{padding:3px 10px;border-radius:16px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.8px}.role-badge.admin{background:var(--accent-dim);color:var(--accent);border:1px solid rgba(74,124,255,.25)}.role-badge.viewer{background:#8b90a014;color:var(--text-2);border:1px solid var(--border)}.header-right{display:flex;align-items:center;gap:12px}.user-info{display:flex;align-items:center;gap:8px}.user-avatar{width:28px;height:28px;border-radius:50%;border:2px solid var(--border)}.user-name{font-size:13px;font-weight:600;color:var(--text-2)}.btn-logout{background:transparent;color:var(--red);border:1px solid rgba(255,71,87,.25);border-radius:var(--r-sm);padding:5px 12px;font-size:12px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all .2s}.btn-logout:hover{background:var(--red-dim);border-color:var(--red)}.dash{display:flex;flex:1;overflow:hidden;height:calc(100vh - 92px)}.lib-panel{width:420px;min-width:380px;background:var(--bg-1);border-right:1px solid var(--border);display:flex;flex-direction:column;transition:border-color .2s;position:relative}.lib-panel.lib-dragover{border-color:var(--accent);box-shadow:inset 0 0 30px var(--accent-dim)}.lib-head{padding:18px 18px 0}.lib-head h2{font-size:16px;font-weight:700;letter-spacing:-.3px}.lib-count{font-size:12px;color:var(--text-3)}.lib-upload{margin:14px 16px;border:2px dashed var(--border);border-radius:var(--r-lg);padding:18px 16px;text-align:center;cursor:pointer;transition:all .2s;background:var(--bg-0);flex-shrink:0}.lib-upload:hover{border-color:var(--border-hover);background:var(--bg-2)}.lib-upload.active{border-color:var(--accent);background:var(--accent-dim)}.lib-upload-icon{display:block;font-size:24px;margin-bottom:4px}.lib-upload-text{display:block;font-size:14px;font-weight:600;color:var(--text-1)}.lib-upload-hint{display:block;font-size:11px;color:var(--text-3);margin-top:2px;font-family:var(--mono)}.lib-drop-hint{background:var(--accent-dim);border:1px solid var(--accent);border-radius:var(--r-md);margin:0 16px 12px;padding:10px;text-align:center;font-size:13px;font-weight:600;color:var(--accent);animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.lib-grid{flex:1;overflow-y:auto;padding:8px 16px 16px;display:flex;flex-wrap:wrap;gap:10px;align-content:flex-start}.lib-empty{width:100%;text-align:center;color:var(--text-3);font-size:13px;padding:40px 20px;line-height:1.7}.img-thumb{position:relative;width:120px;height:90px;border-radius:var(--r-md);overflow:hidden;border:2px solid var(--border);cursor:grab;flex-shrink:0;transition:all .2s;background:var(--bg-0)}.img-thumb:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.img-thumb.dragging{opacity:.4;transform:scale(.95);border-color:var(--accent)}.img-thumb.small{width:100px;height:75px}.img-thumb img{width:100%;height:100%;object-fit:cover}.img-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000000e6);padding:24px 6px 5px;pointer-events:none}.img-name{font-size:10px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.img-uploader{font-size:9px;color:#fff9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;opacity:0;transition:opacity .15s}.img-thumb:hover .img-uploader{opacity:1}.img-delete{position:absolute;top:4px;right:4px;background:var(--red);color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;z-index:2}.img-thumb:hover .img-delete{opacity:1}.drag-grip{position:absolute;top:4px;left:4px;font-size:12px;color:#ffffff80;pointer-events:none;opacity:0;transition:opacity .15s}.img-thumb:hover .drag-grip{opacity:1}.cats-panel{flex:1;display:flex;flex-direction:column;overflow:hidden}.cats-head{padding:18px 24px 0}.cats-head h2{font-size:16px;font-weight:700;letter-spacing:-.3px}.cats-add{display:flex;gap:8px;padding:14px 24px}.cats-input{flex:1;background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-sm);padding:9px 12px;color:var(--text-1);font-size:13px;font-family:var(--font);outline:none;transition:border-color .2s}.cats-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.cats-input::placeholder{color:var(--text-3)}.cats-btn{background:var(--accent);color:#fff;border:none;border-radius:var(--r-sm);width:36px;height:36px;font-size:20px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s}.cats-btn:hover{background:#5d8bff}.cats-scroll{flex:1;overflow-y:auto;padding:0 24px 24px}.cats-empty{color:var(--text-3);text-align:center;padding:40px 16px;font-size:14px}.cat-zone{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--r-lg);margin-bottom:12px;transition:all .2s;position:relative;overflow:hidden}.cat-zone:hover{border-color:var(--border-hover)}.cat-zone.drop-hover{border-color:var(--accent)!important;box-shadow:0 0 24px var(--accent-dim),inset 0 0 20px var(--accent-dim)}.cat-zone-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border)}.cat-zone-left{display:flex;align-items:center;gap:8px;cursor:pointer;min-width:0;flex:1}.arrow{font-size:10px;color:var(--text-3);transition:transform .2s;flex-shrink:0}.arrow.open{transform:rotate(90deg)}.cat-zone-head h3{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cat-zone-badge{background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:1px 7px;border-radius:10px;flex-shrink:0}.cat-zone-btns{display:flex;gap:2px;flex-shrink:0}.zbtn{background:transparent;border:none;font-size:14px;cursor:pointer;padding:4px 6px;border-radius:var(--r-sm);transition:background .15s;color:var(--text-2)}.zbtn:hover{background:var(--bg-4)}.zbtn.del:hover{background:var(--red-dim);color:var(--red)}.cat-zone-body{padding:12px 14px}.cat-zone-empty{color:var(--text-3);font-size:13px;text-align:center;padding:16px 8px;border:2px dashed var(--border);border-radius:var(--r-md);background:var(--bg-0)}.cat-zone-grid{display:flex;flex-wrap:wrap;gap:8px}.drop-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--accent-dim);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--accent);pointer-events:none;animation:pulse 1.5s infinite;border-radius:var(--r-lg);z-index:5}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-3);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px 28px;max-width:520px;width:92%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0009;animation:modalIn .2s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal h3{font-size:17px;font-weight:700;margin-bottom:8px}.modal-text{color:var(--text-2);font-size:14px;margin-bottom:20px;line-height:1.6}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.modal-close{background:transparent;color:var(--text-3);border:none;font-size:18px;cursor:pointer;padding:4px 8px;border-radius:var(--r-sm)}.modal-close:hover{background:var(--bg-hover);color:var(--text-1)}.modal-actions{display:flex;gap:10px;justify-content:flex-end}.btn-secondary{background:var(--bg-4);color:var(--text-1);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px 20px;font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer}.btn-secondary:hover{background:var(--bg-hover)}.btn-danger{background:var(--red);color:#fff;border:none;border-radius:var(--r-sm);padding:10px 20px;font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer}.btn-danger:hover{background:#ff6b7a}.list-container{display:flex;flex-direction:column;gap:4px}.list-item{display:flex;align-items:center;gap:14px;padding:9px 12px;background:var(--bg-0);border-radius:var(--r-sm);border:1px solid var(--border)}.list-index{color:var(--accent);font-weight:700;font-size:12px;font-family:var(--mono);min-width:28px}.list-name{font-size:14px;font-weight:500}.img-thumb.selected{border-color:var(--accent)!important;box-shadow:0 0 0 2px var(--accent),0 0 16px var(--accent-dim)}.img-check{position:absolute;top:4px;left:4px;background:var(--accent);color:#fff;width:20px;height:20px;border-radius:50%;font-size:11px;font-weight:800;display:flex;align-items:center;justify-content:center;z-index:3;box-shadow:0 2px 6px #0000004d}.bulk-bar{display:flex;align-items:center;justify-content:space-between;padding:8px 20px;background:var(--bg-active);border-bottom:1px solid var(--accent);flex-shrink:0;z-index:100;gap:12px;animation:slideDown .2s ease;flex-wrap:wrap}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.bulk-left{display:flex;align-items:center;gap:12px;flex-shrink:0}.bulk-count{font-size:13px;font-weight:700;color:var(--accent)}.bulk-clear{background:transparent;color:var(--text-2);border:1px solid var(--border);border-radius:var(--r-sm);padding:4px 10px;font-size:11px;font-family:var(--font);cursor:pointer;transition:all .15s}.bulk-clear:hover{background:var(--bg-hover);color:var(--text-1)}.bulk-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.bulk-label{font-size:12px;color:var(--text-3);margin-right:4px}.bulk-cat-btn{background:var(--bg-3);color:var(--text-1);border:1px solid var(--border);border-radius:var(--r-sm);padding:5px 12px;font-size:12px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all .15s;white-space:nowrap}.bulk-cat-btn:hover{border-color:var(--accent);background:var(--accent-dim)}.bulk-lib-btn{background:var(--bg-3);color:var(--accent);border:1px solid rgba(74,124,255,.3);border-radius:var(--r-sm);padding:5px 12px;font-size:12px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all .15s}.bulk-lib-btn:hover{background:var(--accent-dim)}.bulk-del-btn{background:var(--red-dim);color:var(--red);border:1px solid rgba(255,71,87,.3);border-radius:var(--r-sm);padding:5px 12px;font-size:12px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all .15s}.bulk-del-btn:hover{background:#ff475733;border-color:var(--red)}.online-bar{display:flex;align-items:center;gap:16px;padding:8px 20px;background:var(--bg-1);border-top:1px solid var(--border);flex-shrink:0;z-index:100;min-height:40px}.online-bar-left{display:flex;align-items:center;gap:8px;flex-shrink:0}.online-dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 6px #2ed57380;animation:dotPulse 2s infinite}@keyframes dotPulse{0%,to{box-shadow:0 0 6px #2ed57380}50%{box-shadow:0 0 12px #2ed573cc}}.online-label{font-size:12px;font-weight:600;color:var(--text-2);white-space:nowrap}.online-bar-users{display:flex;align-items:center;gap:12px;overflow-x:auto;flex:1}.online-bar-users::-webkit-scrollbar{height:0}.online-user{display:flex;align-items:center;gap:6px;padding:4px 10px;background:var(--bg-2);border:1px solid var(--border);border-radius:20px;flex-shrink:0;transition:border-color .15s}.online-user:hover{border-color:var(--border-hover)}.online-avatar{width:20px;height:20px;border-radius:50%;border:1px solid var(--border)}.online-name{font-size:12px;font-weight:600;color:var(--text-1);white-space:nowrap}.online-admin-badge{font-size:10px}.toast{position:fixed;bottom:20px;right:20px;color:#fff;padding:12px 20px;border-radius:var(--r-md);font-size:14px;font-weight:600;z-index:9999;box-shadow:0 8px 24px #0006;animation:toastIn .3s ease;max-width:380px}.toast.success{background:var(--green)}.toast.error{background:var(--red)}@keyframes toastIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.loading-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px}.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.public-page{min-height:100vh;background:var(--bg-0);overflow-y:auto}.public-container{max-width:700px;margin:0 auto;padding:60px 24px}.public-container.wide{max-width:1200px}.public-header{text-align:center;margin-bottom:48px}.public-logo{font-size:56px;margin-bottom:16px}.public-header h1{font-size:28px;font-weight:800;letter-spacing:-.5px;margin-bottom:8px}.public-header p{color:var(--text-2);font-size:16px}.public-empty{text-align:center;color:var(--text-3);padding:48px 20px;font-size:15px}.public-cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.public-cat-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px 20px;text-align:center;text-decoration:none;color:var(--text-1);transition:all .2s}.public-cat-card:hover{border-color:var(--accent);transform:translateY(-3px);box-shadow:0 12px 32px #0000004d,0 0 20px var(--accent-dim)}.public-cat-icon{font-size:36px;margin-bottom:12px}.public-cat-card h3{font-size:16px;font-weight:700;margin-bottom:6px}.public-cat-count{font-size:13px;color:var(--text-3)}.public-footer{text-align:center;margin-top:48px;padding-top:24px;border-top:1px solid var(--border)}.public-login-link{color:var(--text-3);text-decoration:none;font-size:13px;transition:color .2s}.public-login-link:hover{color:var(--accent)}.public-back-btn{display:inline-block;margin-top:20px;color:var(--accent);text-decoration:none;font-weight:600;font-size:15px}.public-back-btn:hover{text-decoration:underline}.public-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:24px;font-size:14px}.public-breadcrumb a{color:var(--accent);text-decoration:none}.public-breadcrumb a:hover{text-decoration:underline}.bc-sep{color:var(--text-3)}.public-breadcrumb span:last-child{color:var(--text-2)}.gallery-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;gap:16px;flex-wrap:wrap}.gallery-title{font-size:26px;font-weight:800;letter-spacing:-.5px;margin-bottom:4px}.gallery-subtitle{color:var(--text-2);font-size:14px}.gallery-btn{background:var(--accent);color:#fff;border:none;border-radius:var(--r-sm);padding:10px 20px;font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;transition:background .2s}.gallery-btn:hover{background:#5d8bff}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.gallery-card{background:var(--bg-2);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;cursor:pointer;transition:all .2s}.gallery-card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.gallery-img-wrap{width:100%;height:170px;overflow:hidden;background:var(--bg-0)}.gallery-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .3s}.gallery-card:hover .gallery-img-wrap img{transform:scale(1.05)}.gallery-card-info{padding:10px 14px}.gallery-card-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s}.lightbox-close{position:absolute;top:20px;right:24px;background:#ffffff1a;color:#fff;border:none;width:44px;height:44px;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:10}.lightbox-close:hover{background:#fff3}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff14;color:#fff;border:none;width:52px;height:52px;border-radius:50%;font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:10}.lightbox-nav:hover{background:#ffffff26}.lightbox-nav.prev{left:20px}.lightbox-nav.next{right:20px}.lightbox-content{max-width:90vw;max-height:85vh;display:flex;flex-direction:column;align-items:center}.lightbox-content img{max-width:100%;max-height:78vh;object-fit:contain;border-radius:var(--r-md);box-shadow:0 16px 48px #00000080}.lightbox-caption{margin-top:14px;color:#ffffffb3;font-size:15px;font-weight:600}@media(max-width:900px){.dash{flex-direction:column}.lib-panel{width:100%;min-width:0;height:45vh;border-right:none;border-bottom:1px solid var(--border)}.cats-panel{height:55vh}.lib-grid{padding:8px 12px}.cats-scroll{padding:0 12px 12px}}
