@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--bg-primary:#0a0b0e;--bg-secondary:#12141c;--bg-tertiary:#191c26;--bg-glass:#12141cb3;--bg-glass-hover:#191c26d9;--accent-color:#a855f7;--accent-light:#c084fc;--accent-dark:#7e22ce;--accent-glow:#a855f766;--text-primary:#f8fafc;--text-secondary:#cbd5e1;--text-muted:#64748b;--border-color:#222533;--border-focus:#4b526d;--success:#10b981;--danger:#ef4444;--warning:#f59e0b;--radius-sm:6px;--radius-md:12px;--radius-lg:20px;--shadow-sm:0 2px 8px #0006;--shadow-md:0 8px 20px #0009;--shadow-lg:0 16px 40px #000c;--font-sans:"Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;font-family:var(--font-sans);--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{background:radial-gradient(circle at 50% 0,#1a102f 0%,#0a0b0e 70%) fixed;min-height:100vh;overflow-x:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}#root{flex-direction:column;min-height:100vh;display:flex}button,input,select,textarea{font-family:inherit}.app-container{flex-direction:column;min-height:100vh;display:flex}.main-header{z-index:100;background:var(--bg-glass);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:16px 40px;transition:all .3s;display:flex;position:sticky;top:0}.logo-section h1{background:linear-gradient(135deg, var(--text-primary) 0%, var(--accent-light) 100%);-webkit-text-fill-color:transparent;cursor:pointer;letter-spacing:-.5px;-webkit-background-clip:text;font-size:24px;font-weight:700}.logo-section span{color:var(--text-muted);text-transform:uppercase;letter-spacing:2px;margin-top:2px;font-size:11px;display:block}.header-actions{align-items:center;gap:16px;display:flex}.user-badge{background:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--border-color);color:var(--text-secondary);align-items:center;gap:8px;padding:6px 14px;font-size:13px;display:flex}.user-badge .role{background:var(--accent-dark);color:var(--text-primary);text-transform:uppercase;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:700}.btn{border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex}.btn-primary{background:var(--accent-color);color:var(--bg-primary)}.btn-primary:hover:not(:disabled){background:var(--accent-light);box-shadow:0 0 15px var(--accent-glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-glass-hover);border-color:var(--border-focus)}.btn-danger{color:var(--danger);background:#ef444426;border:1px solid #ef44444d}.btn-danger:hover:not(:disabled){background:var(--danger);color:var(--text-primary);box-shadow:0 0 15px #ef444466}.btn-text{color:var(--text-muted);background:0 0;padding:6px 12px}.btn-text:hover{color:var(--text-primary)}.btn:disabled{opacity:.5;cursor:not-allowed}.icon-btn{border:1px solid var(--border-color);background:var(--bg-glass);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.icon-btn:hover{background:var(--bg-glass-hover);color:var(--text-primary);border-color:var(--accent-light);transform:scale(1.05)}.icon-btn.active{background:var(--accent-color);color:var(--bg-primary);border-color:var(--accent-color)}.main-content{flex-direction:column;flex:1;gap:24px;padding:30px 40px;display:flex}.filter-bar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;display:flex}.style-chips{flex-wrap:wrap;gap:10px;display:flex}.chip{background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;border-radius:50px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.chip:hover{border-color:var(--border-focus);color:var(--text-primary)}.chip.active{background:var(--accent-color);color:var(--bg-primary);border-color:var(--accent-color);font-weight:600}.chip .count{color:inherit;background:#fff3;border-radius:10px;padding:2px 6px;font-size:10px}.chip.active .count{background:#00000026}.masonry-grid{column-count:4;column-gap:20px;width:100%}@media (width<=1200px){.masonry-grid{column-count:3}}@media (width<=880px){.masonry-grid{column-count:2}}@media (width<=550px){.masonry-grid{column-count:1}}.masonry-item{break-inside:avoid;margin-bottom:20px}.photo-card{border-radius:var(--radius-md);background:var(--bg-secondary);border:1px solid var(--border-color);cursor:pointer;transition:all .3s cubic-bezier(.25,.8,.25,1);position:relative;overflow:hidden}.photo-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-focus);transform:translateY(-4px)}.photo-card.selected{border-color:var(--accent-color);box-shadow:0 0 10px #a855f74d}.photo-card img{width:100%;height:auto;transition:transform .5s;display:block}.photo-card:hover img{transform:scale(1.02)}.card-overlay{opacity:0;pointer-events:none;background:linear-gradient(#0a0b0e00 0%,#0a0b0e66 60%,#0a0b0ee6 100%);flex-direction:column;justify-content:space-between;padding:16px;transition:opacity .25s;display:flex;position:absolute;inset:0}.photo-card:hover .card-overlay,.photo-card.selected .card-overlay{opacity:1;pointer-events:auto}.card-top{justify-content:space-between;align-items:flex-start;width:100%;display:flex}.select-checkbox{border:2px solid var(--text-muted);background:var(--bg-glass);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;width:20px;height:20px;transition:all .2s;display:flex}.photo-card.selected .select-checkbox{background:var(--accent-color);border-color:var(--accent-color)}.select-checkbox svg{color:var(--bg-primary);width:14px;height:14px}.card-actions{gap:8px;display:flex}.card-bottom{width:100%}.photo-info{flex-direction:column;gap:4px;display:flex}.photo-style{color:var(--accent-light);text-transform:uppercase;letter-spacing:1px;font-size:11px;font-weight:600}.photo-meta{color:var(--text-secondary);gap:8px;font-size:12px;display:flex}.selection-shelf{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--accent-color);z-index:1000;background:#12141ce6;border-radius:50px;align-items:center;gap:24px;padding:16px 30px;transition:transform .4s cubic-bezier(.175,.885,.32,1.275);display:flex;position:fixed;bottom:30px;left:50%;transform:translate(-50%)translateY(100px);box-shadow:0 20px 40px #0009,0 0 20px #a855f726}.selection-shelf.visible{transform:translate(-50%)translateY(0)}.shelf-info{color:var(--text-primary);font-size:14px;font-weight:500}.shelf-info span{color:var(--accent-light);margin-right:4px;font-weight:700}.shelf-actions{align-items:center;gap:12px;display:flex}.modal-backdrop{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:2000;background:#060709d9;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-container{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:1000px;max-width:95vw;max-height:90vh;box-shadow:var(--shadow-lg);flex-direction:column;animation:.3s cubic-bezier(.34,1.56,.64,1) modalEnter;display:flex;overflow:hidden}@keyframes modalEnter{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:20px 30px;display:flex}.modal-title{font-size:20px;font-weight:600}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:4px;font-size:20px;transition:all .2s;display:flex}.modal-close:hover{color:var(--text-primary);background:#ffffff0d}.modal-body{flex:1;padding:30px;overflow-y:auto}.collage-workspace{grid-template-columns:1fr 340px;gap:30px;height:100%;display:grid}@media (width<=900px){.collage-workspace{grid-template-columns:1fr}}.collage-preview-pane{background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-color);justify-content:center;align-items:center;min-height:400px;display:flex;position:relative;overflow:hidden}.collage-placeholder-text{color:var(--text-muted);text-align:center;padding:20px}.collage-result-img{object-fit:contain;max-width:100%;max-height:550px;box-shadow:var(--shadow-md);border-radius:4px}.collage-settings-pane{flex-direction:column;gap:24px;display:flex}.settings-group{flex-direction:column;gap:8px;display:flex}.settings-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:600}.input-field{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);padding:10px 14px;font-size:14px;transition:border-color .2s}.input-field:focus{border-color:var(--accent-light);outline:none;box-shadow:0 0 8px #a855f733}.grid-select-buttons{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.grid-option-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-secondary);text-align:center;border-radius:var(--radius-sm);cursor:pointer;padding:10px 0;font-weight:500;transition:all .2s}.grid-option-btn:hover{border-color:var(--border-focus)}.grid-option-btn.active{background:var(--accent-color);color:var(--bg-primary);border-color:var(--accent-color);font-weight:600}.reorder-list{flex-direction:column;gap:10px;max-height:250px;padding-right:6px;display:flex;overflow-y:auto}.reorder-item{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.reorder-img-preview{object-fit:cover;border:1px solid var(--border-color);border-radius:4px;width:44px;height:44px}.reorder-info{color:var(--text-muted);flex:1;margin-left:12px;font-size:12px}.reorder-controls{gap:4px;display:flex}.reorder-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;display:flex}.reorder-btn:hover:not(:disabled){color:var(--text-primary);background:#ffffff0d}.loading-overlay{flex-direction:column;align-items:center;gap:16px;display:flex}.spinner{border:3px solid #a855f71a;border-top-color:var(--accent-color);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.upload-workspace{flex-direction:column;gap:20px;display:flex}.dropzone{border:2px dashed var(--border-color);background:var(--bg-glass);border-radius:var(--radius-md);text-align:center;cursor:pointer;flex-direction:column;align-items:center;gap:16px;padding:50px 30px;transition:all .3s;display:flex}.dropzone:hover{border-color:var(--accent-light);background:var(--bg-glass-hover)}.dropzone svg{color:var(--accent-color)}.dropzone-title{color:var(--text-primary);font-size:16px;font-weight:600}.dropzone-desc{color:var(--text-muted);font-size:12px}.upload-file-list{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;max-height:300px;padding:10px 0;display:grid;overflow-y:auto}.upload-file-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);align-items:center;gap:12px;padding:12px;display:flex;position:relative}.file-preview{object-fit:cover;border-radius:4px;width:50px;height:50px}.file-info{flex:1;min-width:0}.file-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:500;overflow:hidden}.file-size{color:var(--text-muted);font-size:11px}.file-remove-btn{color:var(--text-muted);cursor:pointer;background:0 0;border:none;position:absolute;top:4px;right:4px}.file-remove-btn:hover{color:var(--danger)}.login-screen{flex:1;justify-content:center;align-items:center;padding:40px 20px;display:flex}.login-card{background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:400px;box-shadow:var(--shadow-lg);flex-direction:column;gap:30px;padding:40px;display:flex}.login-header{text-align:center}.login-header h2{background:linear-gradient(135deg, var(--text-primary) 0%, var(--accent-light) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:8px;font-size:28px;font-weight:700}.login-header p{color:var(--text-muted);font-size:13px}.login-form{flex-direction:column;gap:20px;display:flex}.login-error{color:var(--danger);border-radius:var(--radius-sm);background:#ef44441a;border:1px solid #ef444440;padding:10px 14px;font-size:13px}.lightbox-modal{z-index:2500;background:#050507f2;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.lightbox-content{flex-direction:column;align-items:center;max-width:90vw;max-height:85vh;display:flex;position:relative}.lightbox-img{object-fit:contain;border-radius:4px;max-width:100%;max-height:80vh}.lightbox-close{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-size:28px;position:absolute;top:-40px;right:0}.lightbox-close:hover{color:var(--text-primary)}.lightbox-meta{text-align:center;color:var(--text-secondary);margin-top:16px;font-size:14px}.toast-container{z-index:3000;flex-direction:column;gap:10px;display:flex;position:fixed;top:20px;right:20px}.toast{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);box-shadow:var(--shadow-md);border-left:4px solid var(--accent-color);align-items:center;gap:10px;padding:12px 20px;font-size:13px;font-weight:500;animation:.25s cubic-bezier(.175,.885,.32,1.25) toastEnter;display:flex}.toast.toast-success{border-left-color:var(--success)}.toast.toast-error{border-left-color:var(--danger)}@keyframes toastEnter{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}.pagination{justify-content:center;align-items:center;gap:16px;margin-top:40px;margin-bottom:20px;display:flex}.page-info{color:var(--text-secondary);font-size:14px}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;align-items:center;gap:16px;padding:100px 20px;display:flex}.empty-state svg{color:var(--border-color)}@media (width<=1024px){.main-header{padding:14px 24px}.main-content{gap:20px;padding:24px}.card-overlay{opacity:1;pointer-events:auto;background:linear-gradient(#0a0b0e33 0%,#0a0b0e26 60%,#0a0b0ebf 100%)}.photo-card:hover img{transform:none}}@media (width<=768px){.main-header{padding:12px 16px}.logo-section h1{font-size:20px}.logo-section span{letter-spacing:1px;font-size:9px}.main-content{gap:16px;padding:16px}.style-chips{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;width:100%;padding-bottom:6px;overflow-x:auto}.style-chips::-webkit-scrollbar{display:none}.chip{flex-shrink:0;padding:6px 12px;font-size:12px}.selection-shelf{border-radius:24px;justify-content:space-between;gap:12px;width:calc(100% - 32px);padding:12px 20px;bottom:16px}.shelf-info{font-size:13px}.shelf-actions{gap:8px}.shelf-actions .btn{padding:8px 14px;font-size:12px}.lightbox-close{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:20px;display:flex;top:16px;right:16px}.modal-backdrop{padding:0}.modal-container{border:none;border-radius:0;width:100vw;max-width:100vw;height:100vh;max-height:100vh}.modal-header,.modal-body{padding:16px}.collage-preview-pane{min-height:280px}.collage-result-img{max-height:360px}.dropzone{padding:30px 16px}}@media (width<=480px){.btn-text-label,.user-badge .role{display:none}.user-badge{padding:4px 8px;font-size:12px}.username-text{text-overflow:ellipsis;white-space:nowrap;max-width:70px;overflow:hidden}.header-actions{gap:8px}.btn{padding:8px 12px;font-size:12px}.icon-btn{width:32px;height:32px}.login-card{gap:20px;width:100%;padding:24px 20px}.login-header h2{font-size:22px}.grid-select-buttons{gap:6px}.grid-option-btn{padding:8px 0;font-size:12px}}
