.inputfile {
    width: 0.1px;
    height: 0.1px;
    opacity: 0;
    overflow: hidden;
    position: absolute;
    z-index: -1;
}
.inputfile + label {
    display: inline-block;
    padding: 0.625rem 1.25rem;
    max-width: 80%;
    background-color: #72c02c;
    color: #fff;
    font-size: 1.25rem;
    font-weight: 700;
    text-overflow: ellipsis;
    white-space: nowrap;
    cursor: pointer;
    overflow: hidden;
}
.inputfile + label > span {
    color: #fff !important;
}
.inputfile + label > svg {
    width: 1em;
    height: 1em;
    vertical-align: middle;
    fill: currentColor;
    margin-top: -0.25em;
    margin-right: 0.25em;
}
.inputfile:focus + label,
.inputfile + label:hover {
    background-color: #5fb611;
}
.inputfile + label + em.invalid {
    display: block;
    color: #ee9393;
    padding: 0 1px;
    font-size: 11px;
    margin: 6px 0;
    line-height: 15px;
    font-style: normal;
}