﻿.file-uploader-wrapper {
    width: 100%;
    cursor: pointer;
    user-select: none;
    border-radius: 0.40rem;
    background-color: white;
    border: 2px dashed grey;
}

.file-uploader-placeholder {
    width: 100%;
    height: 100%;
    border-radius: 0.40rem;
}

    .file-uploader-placeholder > label {
        width: 100%;
        height: 100%;
        margin: unset;
        display: flex;
        min-height: 150px;
        position: relative;
        align-items: center;
        padding: 1rem 0.75rem;
        border-radius: 0.40rem;
        flex-direction: column;
        transition-duration: 300ms;
    }

        .file-uploader-placeholder > label > * {
            font-size: 16px;
        }

        .file-uploader-placeholder > label > .upload-icon {
            flex-grow: 1;
            font-size: 30px;
            margin-bottom: 1rem;
        }

        .file-uploader-placeholder > label:hover {
            background-color: #F4F4F4;
        }

        .file-uploader-placeholder > label:active {
            background-color: #D7D7D7;
        }

        .file-uploader-placeholder > label input#select-uploader-file {
            top: 0;
            left: 0;
            opacity: 0;
            width: 100%;
            height: 100%;
            cursor: pointer;
            position: absolute;
        }

.selected-file {
    width: 100%;
    margin: 1rem 0;
    font-size: 16px;
    padding: 1rem 0.75rem;
    border-radius: 0.40rem;
    border: 2px solid grey;
}

selected-file .selected-file-left > *,
selected-file .selected-file-right > * {
    margin: unset;
}

.selected-file .selected-file-left i,
.selected-file .selected-file-right i,
.selected-file .selected-file-left svg,
.selected-file .selected-file-right svg {
    font-size: 24px;
}

.selected-file .selected-file-left i,
.selected-file .selected-file-left svg {
    margin-right: 1rem;
}

.selected-file .selected-file-left {
    flex-grow: 1;
    display: flex;
    align-items: center;
}

    .selected-file .selected-file-left > span {
        vertical-align: middle;
    }

.selected-file .selected-file-right {
    gap: 10px;
    display: flex;
    justify-content: right;
}

    .selected-file .selected-file-right > span {
        color: var(--primary);
    }
