.rich-image-library .image-upload-container{width:100%;position:relative}.rich-image-library .image-preview{background:#f9fafb;border:2px solid #e5e7eb;border-radius:8px;width:100%;max-width:400px;position:relative;overflow:hidden}.rich-image-library .image-preview img{object-fit:cover;width:100%;height:200px;display:block}.rich-image-library .image-preview .remove-image-btn,.rich-image-library .image-preview .browse-library-btn{color:#fff;cursor:pointer;z-index:2;background:#000000b3;border:none;border-radius:4px;padding:6px;transition:background-color .2s;position:absolute;top:8px}.rich-image-library .image-preview .remove-image-btn:hover,.rich-image-library .image-preview .browse-library-btn:hover{background:#000000e6}.rich-image-library .image-preview .remove-image-btn:disabled,.rich-image-library .image-preview .browse-library-btn:disabled{opacity:.5;cursor:not-allowed}.rich-image-library .image-preview .remove-image-btn{right:8px}.rich-image-library .image-preview .browse-library-btn{right:44px}.rich-image-library .image-preview .upload-overlay{color:#374151;background:#ffffffe6;flex-direction:column;justify-content:center;align-items:center;gap:8px;font-size:14px;display:flex;position:absolute;inset:0}.rich-image-library .upload-area{flex-direction:column;gap:16px;display:flex}.rich-image-library .upload-dropzone{text-align:center;cursor:pointer;background:#fafafa;border:2px dashed #d1d5db;border-radius:8px;padding:32px 16px;transition:all .2s}.rich-image-library .upload-dropzone:hover{background:#f8faff;border-color:#3b82f6}.rich-image-library .upload-dropzone.drag-over{background:#dbeafe;border-color:#3b82f6}.rich-image-library .upload-dropzone.error{background:#fef2f2;border-color:#ef4444}.rich-image-library .upload-dropzone .upload-content{flex-direction:column;align-items:center;gap:12px;display:flex}.rich-image-library .upload-dropzone .upload-content .upload-icon{justify-content:center;align-items:center;display:flex}.rich-image-library .upload-dropzone .upload-content .upload-text{color:#374151;margin:0;font-size:16px;font-weight:500}.rich-image-library .upload-dropzone .upload-content .upload-hint{color:#6b7280;margin:0;font-size:14px}.rich-image-library .library-access{justify-content:center;display:flex}.rich-image-library .library-access .browse-library-button{color:#374151;cursor:pointer;background:#f3f4f6;border:1px solid #d1d5db;border-radius:6px;align-items:center;gap:8px;padding:12px 24px;font-size:14px;font-weight:500;transition:all .2s;display:flex}.rich-image-library .library-access .browse-library-button:hover{background:#e5e7eb;border-color:#9ca3af}.rich-image-library .library-access .browse-library-button:disabled{opacity:.5;cursor:not-allowed}.rich-image-library .upload-help{text-align:center;color:#6b7280;font-size:12px}.rich-image-library .error-message-container{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;align-items:center;gap:8px;margin-top:8px;padding:8px 12px;display:flex}.rich-image-library .error-message-container .error-message{color:#dc2626;font-size:14px}.rich-image-library .spinner{border:2px solid #e5e7eb;border-top-color:#3b82f6;border-radius:50%;width:20px;height:20px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.image-library-modal{z-index:1000;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.image-library-modal .modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;position:absolute;inset:0}.image-library-modal .modal-content{background:#fff;border-radius:12px;flex-direction:column;width:1000px;max-width:90vw;max-height:90vh;display:flex;position:relative;overflow:hidden;box-shadow:0 25px 50px -12px #00000040}.image-library-modal .modal-header{background:#f9fafb;border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.image-library-modal .modal-header h3{color:#111827;margin:0;font-size:18px;font-weight:600}.image-library-modal .modal-header .header-controls{align-items:center;gap:12px;display:flex}.image-library-modal .modal-header .view-controls{background:#f3f4f6;border-radius:6px;padding:2px;display:flex}.image-library-modal .modal-header .view-controls .view-btn{cursor:pointer;color:#6b7280;background:0 0;border:none;border-radius:4px;padding:6px 8px;transition:all .2s}.image-library-modal .modal-header .view-controls .view-btn:hover{color:#374151}.image-library-modal .modal-header .view-controls .view-btn.active{color:#3b82f6;background:#fff;box-shadow:0 1px 2px #0000000d}.image-library-modal .modal-header .close-modal-btn{cursor:pointer;color:#6b7280;background:0 0;border:none;border-radius:6px;padding:8px;transition:all .2s}.image-library-modal .modal-header .close-modal-btn:hover{color:#374151;background:#f3f4f6}.image-library-modal .modal-filters{background:#fff;border-bottom:1px solid #e5e7eb;padding:16px 24px}.image-library-modal .modal-filters .filter-row{align-items:center;gap:16px;display:flex}.image-library-modal .modal-filters .search-box{flex:1;max-width:300px;position:relative}.image-library-modal .modal-filters .search-box svg{color:#9ca3af;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.image-library-modal .modal-filters .search-box input{border:1px solid #d1d5db;border-radius:6px;width:100%;padding:8px 12px 8px 36px;font-size:14px}.image-library-modal .modal-filters .search-box input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.image-library-modal .modal-filters .context-filter{cursor:pointer;background:#fff;border:1px solid #d1d5db;border-radius:6px;padding:8px 12px;font-size:14px}.image-library-modal .modal-filters .context-filter:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.image-library-modal .modal-body{flex:1;padding:24px;overflow-y:auto}.image-library-modal .modal-body .loading-state,.image-library-modal .modal-body .empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.image-library-modal .modal-body .loading-state .spinner,.image-library-modal .modal-body .empty-state .spinner{width:32px;height:32px;margin-bottom:16px}.image-library-modal .modal-body .loading-state h4,.image-library-modal .modal-body .empty-state h4{color:#374151;margin:16px 0 8px;font-size:18px;font-weight:600}.image-library-modal .modal-body .loading-state p,.image-library-modal .modal-body .empty-state p{color:#6b7280;margin:0;font-size:14px}.image-library-modal .modal-body .folders-container{flex-direction:column;gap:32px;display:flex}.image-library-modal .modal-body .folder-section .folder-header{border-bottom:2px solid #f3f4f6;align-items:center;gap:8px;margin-bottom:16px;padding-bottom:8px;display:flex}.image-library-modal .modal-body .folder-section .folder-header h4{color:#374151;margin:0;font-size:16px;font-weight:600}.image-library-modal .modal-body .folder-section .folder-header .image-count{color:#6b7280;font-size:14px;font-weight:400}.image-library-modal .modal-body .folder-section .images-grid.grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.image-library-modal .modal-body .folder-section .images-grid.list{flex-direction:column;gap:8px;display:flex}.image-library-modal .modal-body .folder-section .images-grid .image-item{cursor:pointer;background:#fff;border:1px solid #e5e7eb;border-radius:8px;transition:all .2s;overflow:hidden}.image-library-modal .modal-body .folder-section .images-grid .image-item:hover{border-color:#3b82f6;transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.image-library-modal .modal-body .folder-section .images-grid .image-item .image-thumbnail{position:relative;overflow:hidden}.image-library-modal .modal-body .folder-section .images-grid .image-item .image-thumbnail img{object-fit:cover;width:100%;height:150px;transition:transform .2s}.image-library-modal .modal-body .folder-section .images-grid .image-item .image-thumbnail:hover img{transform:scale(1.05)}.image-library-modal .modal-body .folder-section .images-grid .image-item .image-thumbnail .image-overlay{opacity:0;background:#00000080;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:absolute;inset:0}.image-library-modal .modal-body .folder-section .images-grid .image-item .image-thumbnail .image-overlay .delete-btn{color:#fff;cursor:pointer;background:#ef4444e6;border:none;border-radius:4px;padding:8px;transition:background .2s}.image-library-modal .modal-body .folder-section .images-grid .image-item .image-thumbnail .image-overlay .delete-btn:hover{background:#ef4444}.image-library-modal .modal-body .folder-section .images-grid .image-item .image-thumbnail:hover .image-overlay{opacity:1}.image-library-modal .modal-body .folder-section .images-grid .image-item .image-info{padding:12px}.image-library-modal .modal-body .folder-section .images-grid .image-item .image-info .image-name{color:#374151;white-space:nowrap;text-overflow:ellipsis;margin:0 0 8px;font-size:14px;font-weight:500;overflow:hidden}.image-library-modal .modal-body .folder-section .images-grid .image-item .image-info .image-meta{color:#6b7280;gap:8px;font-size:12px;display:flex}.image-library-modal .modal-body .folder-section .images-grid .image-item .image-info .image-meta span{white-space:nowrap}.image-library-modal .modal-body .folder-section .images-grid.list .image-item{align-items:center;display:flex}.image-library-modal .modal-body .folder-section .images-grid.list .image-item .image-thumbnail{flex-shrink:0;width:80px}.image-library-modal .modal-body .folder-section .images-grid.list .image-item .image-thumbnail img{height:60px}.image-library-modal .modal-body .folder-section .images-grid.list .image-item .image-info{flex:1;justify-content:space-between;align-items:center;display:flex}.image-library-modal .modal-body .folder-section .images-grid.list .image-item .image-info .image-meta{margin-left:auto}@media (max-width:768px){.image-library-modal{padding:10px}.image-library-modal .modal-content{width:100%;max-height:95vh}.image-library-modal .modal-filters .filter-row{flex-direction:column;gap:12px}.image-library-modal .modal-filters .filter-row .search-box{max-width:none}.image-library-modal .modal-body .folders-container .folder-section .images-grid.grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}}
