.gallery-modal{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:1rem}.gallery-modal__backdrop{position:absolute;inset:0;background:#000000b3;backdrop-filter:blur(8px);animation:fadeIn .2s ease}.gallery-modal__container{position:relative;z-index:1;width:100%;max-width:900px;max-height:calc(100vh - 2rem);background:#fff;border-radius:16px;box-shadow:0 25px 50px -12px #00000040;display:flex;flex-direction:column;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.gallery-modal__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.5rem;border-bottom:1px solid #e5e7eb}.gallery-modal__title{margin:0;font-size:1.25rem;font-weight:600;color:#111827;line-height:1.4}.gallery-modal__description{margin:.25rem 0 0;font-size:.875rem;color:#6b7280;line-height:1.5}.gallery-modal__close{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;border:none;background:transparent;color:#6b7280;cursor:pointer;transition:all .15s ease}.gallery-modal__close:hover{background:#f3f4f6;color:#111827}.gallery-modal__body{flex:1;padding:1.5rem;overflow-y:auto;min-height:300px}.gallery-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;min-height:300px}.gallery-empty__icon{width:64px;height:64px;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;border-radius:12px;background:#f3f4f6;color:#9ca3af}.gallery-empty__title{margin:0 0 .5rem;font-size:1.125rem;font-weight:600;color:#111827}.gallery-empty__text{margin:0 0 1.5rem;font-size:.875rem;color:#6b7280;max-width:320px}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,140px);gap:1rem;justify-content:start}.gallery-item{position:relative;width:140px;height:140px;border-radius:12px;overflow:hidden;background:#f9fafb;border:2px solid #e5e7eb;cursor:move;transition:all .2s ease;user-select:none}.gallery-item:hover{border-color:#d1d5db;box-shadow:0 4px 6px -1px #0000001a}.gallery-item.is-dragging{opacity:.4;transform:scale(.95);cursor:grabbing}.gallery-item.is-dragover{border-color:#007ec5;background:#eff6ff;box-shadow:0 0 0 3px #007ec51a}.gallery-item__image{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.gallery-item__badge{position:absolute;bottom:0;left:0;right:0;padding:.375rem .5rem;background:linear-gradient(to top,#007ec5f2,#007ec500);color:#fff;font-size:.6875rem;font-weight:600;text-align:center;text-transform:uppercase;letter-spacing:.05em;line-height:1}.gallery-item__delete{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;border:none;background:#fffffff2;color:#dc2626;cursor:pointer;opacity:0;transform:scale(.9);transition:all .15s ease;box-shadow:0 2px 4px #0000001a}.gallery-item:hover .gallery-item__delete{opacity:1;transform:scale(1)}.gallery-item__delete:hover{background:#dc2626;color:#fff;transform:scale(1.1)}.gallery-item__delete svg{width:14px;height:14px}.gallery-item__handle{position:absolute;top:.5rem;left:.5rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;background:#fffffff2;color:#6b7280;cursor:grab;opacity:0;transform:scale(.9);transition:all .15s ease;box-shadow:0 2px 4px #0000001a}.gallery-item:hover .gallery-item__handle{opacity:1;transform:scale(1)}.gallery-item__handle:active{cursor:grabbing}.gallery-item__handle svg{width:14px;height:14px}.gallery-modal__footer{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:1px solid #e5e7eb}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;height:40px;padding:0 1rem;border-radius:8px;font-size:.875rem;font-weight:500;line-height:1;cursor:pointer;transition:all .15s ease;border:none;white-space:nowrap}.btn svg{flex-shrink:0}.btn--primary{background:#007ec5;color:#fff}.btn--primary:hover{background:#006aa3}.btn--primary:active{background:#005885}.btn--secondary{background:#f3f4f6;color:#374151}.btn--secondary:hover{background:#e5e7eb;color:#111827}.btn--ghost{background:transparent;color:#6b7280}.btn--ghost:hover{background:#f3f4f6;color:#111827}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.is-loading{position:relative;pointer-events:none}.btn.is-loading:after{content:"";position:absolute;width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:640px){.gallery-grid{grid-template-columns:repeat(auto-fill,110px);gap:.75rem}.gallery-item{width:110px;height:110px}.gallery-modal__footer{flex-wrap:wrap}.btn{flex:1;min-width:0}.btn--ghost{flex:0 0 auto;width:100%}}
