.image-upload-wrapper{width:100%}.image-upload-label{display:block;font-size:.85rem;font-weight:500;margin-bottom:6px;color:var(--text-secondary)}.image-upload-zone{position:relative;border:2px dashed var(--border-color);border-radius:var(--radius-lg);cursor:pointer;overflow:hidden;transition:all .2s ease;background:var(--bg-secondary);min-height:140px;display:flex;align-items:center;justify-content:center}.image-upload-zone.circle{width:120px;height:120px;min-height:unset;border-radius:50%}.image-upload-zone:hover{border-color:var(--accent-primary);background:rgba(102,166,255,.03)}.image-upload-zone.drag-over{border-color:var(--accent-primary);background:rgba(102,166,255,.08);transform:scale(1.01)}.image-upload-zone.has-image{border-style:solid;border-color:var(--border-color)}.image-upload-loading{gap:8px;font-size:.8rem}.image-upload-loading,.image-upload-placeholder{display:flex;flex-direction:column;align-items:center;color:var(--text-muted)}.image-upload-placeholder{gap:6px;padding:20px}.circle .image-upload-placeholder{padding:10px}.circle .image-upload-placeholder .image-upload-hint,.circle .image-upload-placeholder .image-upload-text{display:none}.image-upload-text{font-size:.82rem;font-weight:500}.image-upload-hint{font-size:.7rem;opacity:.6}.image-upload-preview{width:100%;height:100%;position:relative}.image-upload-preview img{width:100%;height:100%;object-fit:cover;display:block}.image-upload-zone:not(.circle) .image-upload-preview img{max-height:200px}.image-upload-overlay{position:absolute;inset:0;background:rgba(0,0,0,.55);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;opacity:0;transition:opacity .2s ease}.image-upload-preview:hover .image-upload-overlay{opacity:1}.image-upload-change,.image-upload-remove{padding:4px 12px;border-radius:16px;border:none;font-size:.7rem;font-weight:600;cursor:pointer;transition:all .15s ease;white-space:nowrap}.image-upload-change{background:white;color:#333}.image-upload-change:hover{background:#f0f0f0}.image-upload-remove{background:rgba(217,107,107,.9);color:white}.image-upload-remove:hover{background:#ff4757}.image-upload-error{margin-top:6px;font-size:.75rem;color:#ff4757;font-weight:500}.image-upload-size-hint{font-size:.72rem;color:var(--text-muted);margin-bottom:6px}.image-upload-multi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));grid-gap:10px;gap:10px}.image-upload-multi-item{position:relative;aspect-ratio:4/3;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-color);background:var(--bg-tertiary)}.image-upload-multi-item img{width:100%;height:100%;object-fit:cover;display:block}.image-upload-multi-overlay{position:absolute;top:4px;right:4px;opacity:0;transition:opacity .2s ease}.image-upload-multi-item:hover .image-upload-multi-overlay{opacity:1}.image-upload-multi-remove{width:24px;height:24px;border-radius:50%;border:none;background:rgba(0,0,0,.6);color:white;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease}.image-upload-multi-remove:hover{background:#ff4757}.image-upload-multi-main{position:absolute;bottom:4px;left:4px;font-size:.6rem;font-weight:600;color:white;background:rgba(102,166,255,.85);padding:1px 6px;border-radius:10px}.image-upload-multi-add{aspect-ratio:4/3;border:2px dashed var(--border-color);border-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;transition:all .2s ease;background:var(--bg-secondary)}.image-upload-multi-add:hover{border-color:var(--accent-primary);background:rgba(102,166,255,.03)}.image-upload-multi-add.drag-over{border-color:var(--accent-primary);background:rgba(102,166,255,.08)}.crop-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;animation:cropFadeIn .2s ease}@keyframes cropFadeIn{0%{opacity:0}to{opacity:1}}.crop-modal{background:var(--bg-primary,#1a1a2e);border-radius:16px;padding:24px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.4);border:1px solid rgba(255,255,255,.08);animation:cropSlideUp .3s ease}@keyframes cropSlideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.crop-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.crop-modal-header h4{font-family:var(--font-serif,serif);font-size:1.1rem;font-weight:500;margin:0}.crop-modal-close{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:8px;transition:all .2s;display:flex;align-items:center;justify-content:center}.crop-modal-close:hover{background:rgba(255,255,255,.1);color:var(--text-primary)}.crop-modal-hint{font-size:.78rem;color:var(--text-muted);margin-bottom:16px}.crop-editor-layout{display:flex;gap:20px;align-items:flex-start}.crop-source-area{flex:1 1;min-width:0}.crop-image-container{position:relative;cursor:crosshair;border-radius:12px;overflow:hidden;border:2px solid rgba(255,255,255,.1);-moz-user-select:none;user-select:none;-webkit-user-select:none;touch-action:none}.crop-source-image{width:100%;height:auto;display:block;pointer-events:none}.crop-crosshair{pointer-events:none;z-index:2;transition:left .05s ease,top .05s ease}.crop-crosshair,.crop-crosshair-ring{position:absolute;transform:translate(-50%,-50%)}.crop-crosshair-ring{width:28px;height:28px;border:2.5px solid white;border-radius:50%;box-shadow:0 0 0 1.5px rgba(0,0,0,.4),inset 0 0 0 1.5px rgba(0,0,0,.4);top:50%;left:50%}.crop-crosshair-h,.crop-crosshair-v{position:absolute;background:white;box-shadow:0 0 2px rgba(0,0,0,.5)}.crop-crosshair-h{width:40px;height:1.5px}.crop-crosshair-h,.crop-crosshair-v{top:50%;left:50%;transform:translate(-50%,-50%)}.crop-crosshair-v{width:1.5px;height:40px}.crop-preview-area{width:130px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;gap:12px}.crop-preview-label{font-size:.75rem;color:var(--text-muted);font-weight:500;letter-spacing:.05em}.crop-preview-circle{width:100px;height:100px;border-radius:50%;overflow:hidden;border:2px solid rgba(255,255,255,.15);box-shadow:0 4px 16px rgba(0,0,0,.3)}.crop-preview-circle img{width:100%;height:100%;object-fit:cover;display:block}.crop-preview-rect{width:110px;height:70px;border-radius:8px;overflow:hidden;border:2px solid rgba(255,255,255,.15);box-shadow:0 4px 16px rgba(0,0,0,.3)}.crop-preview-rect img{width:100%;height:100%;object-fit:cover;display:block}.crop-position-value{font-size:.7rem;color:var(--text-muted);font-family:monospace;opacity:.7}.crop-modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,.06)}.crop-btn-reset{padding:8px 16px;border-radius:8px;border:1px solid rgba(255,255,255,.12);background:transparent;color:var(--text-secondary);font-size:.8rem;cursor:pointer;transition:all .2s}.crop-btn-reset:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.2)}.crop-btn-done{padding:8px 24px;border-radius:8px;border:none;background:var(--accent-primary,#66a6ff);color:white;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s}.crop-btn-done:hover{filter:brightness(1.1);transform:translateY(-1px)}@media (max-width:520px){.crop-editor-layout{flex-direction:column;align-items:stretch}.crop-preview-area{width:100%;flex-direction:row;justify-content:center;flex-wrap:wrap;gap:16px}.crop-preview-label{width:100%;text-align:center}.crop-modal{padding:16px}}