.upload-indicator-container {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 2000;
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.upload-item {
    display: flex;
    align-items: center;
    gap: 15px;
    background-color: white;
    padding: 10px 15px;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
    min-width: 280px;
}

.progress-circle {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    background: conic-gradient(#3b82f6 var(--progress, 0%), #e0e0e0 0);
    transition: background 0.3s;
}

    .progress-circle.completed {
        background: #28a745;
    }

    .progress-circle.failed {
        background: #dc3545;
    }

.progress-icon {
    width: 42px;
    height: 42px;
    background-color: white;
    border-radius: 50%;
    display: grid;
    place-items: center;
    font-size: 1.2rem;
    color: #3b82f6;
    font-weight: bold;
}

.progress-circle.completed .progress-icon,
.progress-circle.failed .progress-icon {
    color: white;
    font-size: 1.8rem;
}

.progress-percent {
    font-size: 0.8rem;
}


.upload-info {
    flex: 1;
}

.file-name {
    font-weight: 500;
    font-size: 0.9rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 180px;
}

.status-message {
    font-size: 0.8rem;
    color: #666;
}
