.media-upload-modal{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-overlay{position:absolute;inset:0;background:#00000080;backdrop-filter:blur(4px);z-index:1}.modal-content{position:relative;z-index:2;width:90%;max-width:700px;max-height:85vh;background:#fff;border-radius:16px;box-shadow:0 24px 48px #0003;display:flex;flex-direction:column;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:2px solid #e5e7eb}.modal-header h2{margin:0;font-size:1.5rem;font-weight:700;color:#0f172a}.modal-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:none;background:transparent;color:#64748b;cursor:pointer;transition:all .2s}.modal-close:hover{background:#f1f5f9;color:#0f172a}.modal-body{flex:1;padding:1.5rem;overflow-y:auto}.upload-zone{position:relative;border:3px dashed #cbd5e1;border-radius:12px;padding:3rem 2rem;text-align:center;background:#f8fafc;transition:all .2s;cursor:pointer}.upload-zone:hover{border-color:#007ec5;background:#f0f9ff}.upload-zone.is-dragover{border-color:#007ec5;background:#e0f2fe;transform:scale(1.02)}.upload-zone__content{pointer-events:none}.upload-icon{margin:0 auto 1rem;color:#64748b}.upload-zone h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:600;color:#0f172a}.upload-zone p{margin:0 0 1rem;color:#64748b}.upload-zone__info{display:flex;flex-direction:column;gap:.25rem;font-size:.875rem;color:#94a3b8}.upload-zone__input{position:absolute;inset:0;opacity:0;cursor:pointer}.upload-queue{margin-top:1.5rem}.upload-queue__title{margin:0 0 1rem;font-size:1rem;font-weight:600;color:#0f172a}.upload-queue__items{display:flex;flex-direction:column;gap:.75rem;max-height:300px;overflow-y:auto}.upload-item{display:flex;align-items:center;gap:1rem;padding:.75rem;background:#f8fafc;border-radius:8px;border:1px solid #e5e7eb}.upload-item__thumbnail{flex-shrink:0;width:60px;height:60px;border-radius:6px;overflow:hidden;background:#e5e7eb}.upload-item__thumbnail img{width:100%;height:100%;object-fit:cover}.upload-item__info{flex:1;min-width:0}.upload-item__name{margin:0 0 .25rem;font-size:.875rem;font-weight:600;color:#0f172a;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-item__size{margin:0 0 .5rem;font-size:.75rem;color:#64748b}.upload-item__progress{position:relative;width:100%;height:6px;background:#e5e7eb;border-radius:3px;overflow:hidden}.upload-item__progress-bar{position:absolute;left:0;top:0;height:100%;background:#007ec5;border-radius:3px;transition:width .3s ease}.upload-item__status{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%}.upload-item__status.is-pending{color:#64748b}.upload-item__status.is-uploading{color:#007ec5}.upload-item__status.is-success{background:#dcfce7;color:#16a34a}.upload-item__status.is-error{background:#fee2e2;color:#dc2626}.upload-item__remove{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;border:none;background:transparent;color:#64748b;cursor:pointer;transition:all .2s}.upload-item__remove:hover{background:#fee2e2;color:#dc2626}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding:1.5rem;border-top:2px solid #e5e7eb}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;border:none}.btn--secondary{background:#f1f5f9;color:#475569}.btn--secondary:hover{background:#e2e8f0}.btn--primary{background:#007ec5;color:#fff}.btn--primary:hover{background:#006aa3}.btn--primary:disabled{background:#cbd5e1;color:#94a3b8;cursor:not-allowed}.spinner{display:inline-block;width:16px;height:16px;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){.modal-content{width:95%;max-height:90vh}.upload-zone{padding:2rem 1rem}.upload-item{flex-wrap:wrap}.upload-item__info{flex-basis:100%}}
