file-input {
    display: block;
}

.file-input__native {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.file-input__zone {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0.4rem;
    padding: 1.75rem 1rem;
    border: 0.15rem dashed var(--colorTextAccent);
    border-radius: 0.6rem;
    background-color: var(--colorSelectionTransparentLight);
    color: var(--colorText);
    cursor: pointer;
    text-align: center;
    transition: background-color 120ms, border-color 120ms, transform 120ms;
}
.file-input__zone:hover {
    background-color: var(--colorSelectionTransparent);
    border-color: var(--colorText);
}
.file-input__zone:focus-within {
    outline: 2px solid var(--colorText);
    outline-offset: 2px;
}

.file-input__icon {
    font-size: 2rem;
    line-height: 1;
    opacity: 0.85;
}
.file-input__label {
    font-size: 1rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    max-width: 100%;
}
.file-input__hint {
    font-size: 0.8rem;
    opacity: 0.65;
}

.file-input--selected .file-input__zone {
    border-style: solid;
    border-color: var(--colorText);
    background-color: var(--colorSelectionTransparent);
}
.file-input--selected .file-input__icon::before {
    content: "\F26B"; /* bi-file-earmark-check */
}

.file-input--dragging .file-input__zone {
    border-color: var(--colorText);
    background-color: var(--colorSelection);
    transform: scale(1.01);
}
