﻿.file-container {
    display: flex;
    flex-direction: column;
    border: 1px solid #e0e0e0;
    border-radius: 0.15em;
    /*    box-shadow: 2px 2px 3px 0px #767676;    */
    margin-bottom: 0.6em;
}

.file-container--invalid {
    border-color: red;
    border-width: 3px;
    /*    box-shadow: 2px 2px 5px 0px #ff3d3d;*/
}

.file-container:last-child {
    margin-bottom: 0;
}

.file-upload__required-input {
    display: block;
    width: 100%;
    height: 0;
    overflow: hidden;
    padding: 0;
    margin: 0;
    background: none;
    outline: none;
    border: none;
}

.file-container__head {
    padding: 0.3em;
    padding-left: 0.6em;
    padding-right: 0.6em;
    background-color: #f0f0ff;
    user-select: none;
}

.file-container--invalid .file-container__head {
    background-color: #ffcccc;
}

.file-container__head--hidden {
    display: none;
}

.file-container__validation-messages {
    border-top: 1px solid red;
    border-bottom: 1px solid red;
}

.file-container__validation-messages--hidden {
    display: none;
}

.file-container__validation-message,
.file-container__base-validation-message {
    padding: 0.8em;
    padding-top: 0.3em;
    padding-bottom: 0.3em;
    background-color: red;
    color: white;
    font-size: 0.8em;
    display: flex;
    user-select: auto !important;
}

    .file-container__validation-message::before {
        content: "\f071";
        font-family: "Font Awesome 5 Free";
        font-weight: 900;
        margin-right: 0.6em;
    }

.file-container__body {
    flex-grow: 1;
    padding: 0.6em;
    user-select: none;
}

.file-container__body--hidden {
    display: none;
}

.file-container__foot {
    user-select: none;
}


.file-container__file-info {
    display: flex;
    align-items: center;
}

.file-container__mime-type {
    margin-right: 0.6em;
    color: #0fadd3;
}

.file-container--invalid .file-container__mime-type {
    color: red;
}

.file-container__mime-type-icon {
    font-size: 1.75em;
}

.file-container__file-name {
    flex-grow: 1;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    color: #348da2;
    word-break: break-word;
}

.file-container--invalid .file-container__file-name {
    color: red;
}

.file-container__remove-action {
    margin-left: 0.6em;
}

.file-container__file-categories-description {
    font-size: 0.8em;
    color: #716e6e;
    margin-bottom: 0.3em;
}

.file-container__file-categories {
    display: flex;
    flex-wrap: wrap;
    margin: -0.15em;
    margin-top: 0;
}

.file-container__file-category {
    padding: 0.15em;
}

.file-container__actions {
    display: flex;
}

.file-container__action {
    flex-grow: 1;
}

.file-container__action--hidden {
    display: none;
}

.file-container__file-input {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    cursor: pointer;
    opacity: 0;
}

.file-category {
    display: block;
}

.file-category__input {
    display: none;
}

.file-category__display-content {
    display: block;
    cursor: pointer;
    padding: 0.3em;
    padding-left: 0.6em;
    padding-right: 0.6em;
    color: #8e8d8d;
    border: 1px solid #c9c9c9;
    font-size: 0.8em;
    border-radius: 0.3em;
    transition: all 0.15s;
    transition-property: color, border, background, opacity;
    word-break: break-word;
}

.file-category__input:checked + .file-category__display-content {
    background-color: #0fadd3;
    color: white;
    border-color: #0fadd3;
}

.file-category__display-content:hover,
.file-category__display-content:focus {
    color: #0fadd3;
    border-color: #0fadd3;
}

.file-category__input:checked + .file-category__display-content:hover,
.file-category__input:checked + .file-category__display-content:focus {
    opacity: 0.7;
}


.file-container-button {
    --background-color: #ed4d4d;
    --color: white;
    display: block;
    background: none;
    border: none;
    padding: 0;
    margin: 0;
    font-size: 1em;
    outline: none;
    text-align: center;
    width: 100%;
    background-color: var(--background-color);
    color: var(--color);
    padding: 0.3em;
    padding-left: 0.6em;
    padding-right: 0.6em;
    border-radius: 0.15em;
    cursor: pointer;
    opacity: 0.7;
    transition: all 0.15s;
    transition-property: background, color, opacity, border;
    position: relative;
}

.file-container-button--big {
    font-size: 1.1em;
}

.file-container-button--border-radius-bottom {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
}

.file-container-button--success {
    --background-color: #269d21;
    --color: white;
}

.file-container-button:hover,
.file-container-button:focus {
    opacity: 1;
}

.file-upload {
    display: flex;
    flex-direction: column;
    border: 1px solid #cecece;
    box-shadow: inset 0px 0px 3px 0px #767676;
    padding: 0.6em;
    border-radius: 0.15em;
}

.file-upload--hidden {
    display: none;
}

.file-upload__info-text {
    text-align: center;
    color: #9d9d9d;
    margin-bottom: 0.6em;
    user-select: none;
}

.file-upload__info-text--hidden {
    display: none;
}

.file-upload__entries {
    flex-grow: 1;
}

.file-upload__file-container-prototype {
    display: none;
}

.file-upload__validation-message-prototypes {
    display: none;
}

.file-upload__modal-message {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 9001;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: rgba(0, 0, 0, 0.4);
}

.file-upload-modal {
    background-color: white;
    display: flex;
    flex-direction: column;
    width: calc(100% - 1em);
    max-width: 30em;
    border-radius: 0.15em;
    border: 1px solid white;
    box-shadow: 2px 2px 2px 0px #afafaf;
}

.file-upload__modal-message--hidden {
    display: none;
}

.file-upload-modal__head {
    display: flex;
    align-items: center;
    background-color: #800000;
    color: white;
    border-radius: 0.15em;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

.file-upload-modal__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.8em;
}

.file-upload-modal__icon-element {
    font-size: 1.25em;
}

.file-upload-modal__title {
    flex-grow: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 1.125em;
    padding: 0.5em;
    padding-left: 0;
    padding-right: 0;
}

.file-upload-modal__actions {
    display: flex;
    align-items: center;
    padding: 0.6em;
    margin: -0.1em;
}

.file-upload-modal__action {
    padding: 0.1em;
}

.file-upload-modal__body {
    display: flex;
    flex-direction: column;
}

.file-upload-modal__message {
    padding: 0.6em;
    white-space: pre-line;
}

.file-upload__upload-infos {
    margin-top: 0.6em;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    user-select: none;
}

.file-upload__upload-info {
    flex-grow: 1;
    text-align: center;
    padding: 0.3em;
    padding-left: 0.6em;
    padding-right: 0.6em;
    font-size: 0.8em;
    border: 1px solid #cecece;
    border-radius: 0.6em;
    margin: 0.15em;
    color: #717171;
}

.file-upload__upload-info--hidden {
    display: none;
}

.file-upload__upload-info-tag {
    color: #989898;
}

.file-upload__required-file-categories {
    margin-top: 0.6em;
    padding: 0.3em;
    color: #ed0000;
    user-select: none;
}

.file-upload__required-file-categories--hidden {
    display: none;
}

.file-upload__required-file-categories-message {
    font-size: 0.8em;
    text-align: center;
}

.file-upload__required-file-categories-list {
    display: block;
    font-weight: 600;
    margin-top: 0.3em;
    font-size: 1.05em;
}
