.image-upload-container{max-width:1200px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;position:relative;min-height:calc(100vh - 40px)}.upload-section{margin-bottom:15px}.terminal-selector,.upload-section{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.terminal-selector{margin-bottom:30px;-webkit-box-align:center;-ms-flex-align:center;align-items:center;padding:15px;background-color:#f8f9fa;border-radius:8px}.upload-card{width:100%;max-width:400px;border:2px dashed #dcdfe6;border-radius:12px;padding:40px 20px;text-align:center;cursor:pointer;-webkit-transition:all .3s ease;transition:all .3s ease;background-color:#fafafa}.upload-card:hover{border-color:#409eff;background-color:#f0f9ff;-webkit-transform:translateY(-2px);transform:translateY(-2px);-webkit-box-shadow:0 4px 12px rgba(64,158,255,.15);box-shadow:0 4px 12px rgba(64,158,255,.15)}.upload-icon{font-size:48px;color:#c0c4cc;margin-bottom:16px;-webkit-transition:color .3s ease;transition:color .3s ease}.upload-card:hover .upload-icon{color:#409eff}.upload-title{font-size:16px;font-weight:500;color:#303133;margin-bottom:8px}.upload-desc{font-size:14px;color:#909399;line-height:1.5}.upload-btn{display:none}.crop-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.7);-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;z-index:2000;-webkit-animation:fadeIn .3s ease;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.crop-modal,.modal-content{display:-webkit-box;display:-ms-flexbox;display:flex}.modal-content{background-color:#fff;border-radius:12px;width:90%;max-width:1000px;max-height:90vh;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-shadow:0 10px 40px rgba(0,0,0,.35);box-shadow:0 10px 40px rgba(0,0,0,.35);overflow:hidden;-webkit-animation:slideIn .3s ease;animation:slideIn .3s ease}@-webkit-keyframes slideIn{0%{opacity:0;-webkit-transform:translateY(-20px) scale(.95);transform:translateY(-20px) scale(.95)}to{opacity:1;-webkit-transform:translateY(0) scale(1);transform:translateY(0) scale(1)}}@keyframes slideIn{0%{opacity:0;-webkit-transform:translateY(-20px) scale(.95);transform:translateY(-20px) scale(.95)}to{opacity:1;-webkit-transform:translateY(0) scale(1);transform:translateY(0) scale(1)}}.modal-header{padding:20px 24px;border-bottom:1px solid #e4e7ed;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:center;-ms-flex-align:center;align-items:center;background-color:#fff}.modal-header h3{margin:0;color:#303133;font-size:18px;font-weight:600}.modal-header .close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#909399;-webkit-transition:all .3s;transition:all .3s;padding:0;line-height:1;width:32px;height:32px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;border-radius:50%}.modal-header .close-btn:hover{color:#303133;background-color:#f5f5f5}.modal-body{padding:24px;overflow-y:auto;-webkit-box-flex:1;-ms-flex:1;flex:1}.modal-footer{padding:16px 24px;border-top:1px solid #e4e7ed;-webkit-box-pack:end;-ms-flex-pack:end;justify-content:flex-end;background-color:#fff;gap:12px}.modal-footer,.ratio-controls{display:-webkit-box;display:-ms-flexbox;display:flex}.ratio-controls{margin-bottom:24px;-webkit-box-align:center;-ms-flex-align:center;align-items:center;background-color:#f8f9fa;padding:16px;border-radius:8px}.ratio-controls label{margin-right:16px;font-weight:500;color:#606266;font-size:14px;min-width:80px}.ratio-controls select{padding:8px 16px;border-radius:6px;border:1px solid #dcdfe6;outline:none;-webkit-transition:all .3s;transition:all .3s;background-color:#fff;font-size:14px;cursor:pointer}.ratio-controls select:focus{border-color:#409eff;-webkit-box-shadow:0 0 0 2px rgba(64,158,255,.2);box-shadow:0 0 0 2px rgba(64,158,255,.2)}.cropper-wrapper{width:100%;height:450px;margin:20px 0;position:relative;border:1px solid #e4e7ed;background-color:#f8f9fa;overflow:hidden;border-radius:8px;-webkit-box-shadow:inset 0 0 0 1px rgba(0,0,0,.05);box-shadow:inset 0 0 0 1px rgba(0,0,0,.05)}.preview-container{margin-top:20px;text-align:center}.preview-title{margin-bottom:10px;font-weight:700;color:#666}.preview{border:1px solid #ddd;-webkit-box-shadow:0 0 5px rgba(0,0,0,.1);box-shadow:0 0 5px rgba(0,0,0,.1);background-color:#fff}.modal-footer button{padding:10px 24px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;-webkit-transition:all .3s ease;transition:all .3s ease;min-width:80px;height:36px;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-shadow:0 2px 4px rgba(0,0,0,.05);box-shadow:0 2px 4px rgba(0,0,0,.05)}.cancel-btn{background-color:#f5f7fa;color:#606266;border:1px solid #dcdfe6}.cancel-btn:hover{background-color:#e4e7ed;color:#303133}.confirm-btn{background-color:#409eff;color:#fff}.confirm-btn:hover{background-color:#66b1ff;-webkit-box-shadow:0 2px 8px rgba(64,158,255,.3);box-shadow:0 2px 8px rgba(64,158,255,.3)}.image-list-header{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:center;-ms-flex-align:center;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #ebeef5}.image-list-header h3{margin:0;color:#303133;font-size:18px;font-weight:600}.image-count{font-size:14px;color:#909399;margin-left:12px}.source-tabs{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.terminal-tabs{border-radius:4px}.image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.image-item{border:1px solid #ebeef5;border-radius:6px;overflow:hidden;position:relative;background-color:#fff;-webkit-transition:all .3s ease;transition:all .3s ease}.image-item:hover{-webkit-transform:translateY(-2px);transform:translateY(-2px);-webkit-box-shadow:0 6px 16px rgba(0,0,0,.1);box-shadow:0 6px 16px rgba(0,0,0,.1);border-color:#409eff}.image-preview{position:relative;aspect-ratio:16/9;overflow:hidden}.image-item img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;cursor:pointer;display:block}.image-actions{padding:10px 12px;-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;background-color:#fff;border-top:1px solid #f2f6fc}.image-actions,.image-actions-left{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.image-actions-left{gap:8px}.image-actions-right{-webkit-box-align:center;-ms-flex-align:center;align-items:center;gap:4px}.image-actions-right,.pagination{display:-webkit-box;display:-ms-flexbox;display:flex}.pagination{margin-top:32px;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;padding:16px 0}.preview-modal{width:100%;height:100%;-webkit-animation:fadeIn .3s ease;animation:fadeIn .3s ease}.preview-content{max-width:90%;max-height:90%;-webkit-animation:zoomIn .3s ease;animation:zoomIn .3s ease}.preview-content img{max-width:100%;max-height:100%;border-radius:8px;-webkit-box-shadow:0 10px 30px rgba(0,0,0,.5);box-shadow:0 10px 30px rgba(0,0,0,.5)}@-webkit-keyframes zoomIn{0%{opacity:0;-webkit-transform:scale(.8);transform:scale(.8)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}@keyframes zoomIn{0%{opacity:0;-webkit-transform:scale(.8);transform:scale(.8)}to{opacity:1;-webkit-transform:scale(1);transform:scale(1)}}.loading-overlay{width:100%;height:100%;background-color:hsla(0,0%,100%,.7);z-index:1000}.empty-state{text-align:center;padding:60px 20px;color:#909399}.empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-text{font-size:14px;margin-bottom:8px}.empty-tip{font-size:12px;opacity:.7}.delete-btn{padding:4px 8px;background-color:#f5f7fa;color:#909399;border:1px solid #dcdfe6;border-radius:3px;cursor:pointer;font-size:11px;-webkit-transition:all .3s;transition:all .3s}.delete-btn:hover{background-color:#f56c6c;color:#fff;border-color:#f56c6c}.preview-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.8);z-index:2000;overflow:auto}.preview-modal,.preview-modal .modal-content{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center}.preview-modal .modal-content{position:relative;max-width:90vw;max-height:90vh}.preview-modal .modal-content img{max-width:100%;max-height:80vh;width:auto;height:auto;-o-object-fit:contain;object-fit:contain;border-radius:4px;-webkit-box-shadow:0 0 20px rgba(0,0,0,.5);box-shadow:0 0 20px rgba(0,0,0,.5)}.preview-modal .close-btn{position:absolute;top:-40px;right:-40px;width:30px;height:30px;background-color:hsla(0,0%,100%,.2);color:#fff;border:none;border-radius:50%;font-size:20px;cursor:pointer;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-transition:all .3s;transition:all .3s}.preview-modal .close-btn:hover{background-color:hsla(0,0%,100%,.4)}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.5);display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-ms-flex-direction:column;flex-direction:column;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;z-index:3000}.loading-spinner{width:50px;height:50px;border:5px solid #f3f3f3;border-top:5px solid #409eff;border-radius:50%;-webkit-animation:spin 1s linear infinite;animation:spin 1s linear infinite}.loading-text{margin-top:15px;color:#fff;font-size:16px}@-webkit-keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@keyframes spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}to{-webkit-transform:rotate(1turn);transform:rotate(1turn)}}@-webkit-keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}