    /*^ --------------------------------- Form ---------------------------------- */
    .formInput {
        position: relative;
    }
    fieldset.formInput {
        border: 1px solid grey;
        margin: 0;
    }

    ::-webkit-input-placeholder {color: rgba(0, 0, 0, 0) !important}
    :-ms-input-placeholder {color: rgba(0, 0, 0, 0) !important}
    ::-ms-input-placeholder {color: rgba(0, 0, 0, 0) !important}
    ::placeholder {color: rgba(0, 0, 0, 0) !important;opacity:0}
    input, textarea, select {outline: none}
    input:required{box-shadow:none}
    select::-ms-expand {
        display: none;
    }
    button,
    .button {
        padding: 0.31rem;
        margin: calc(1rem + 1px) 1px 1px 1px;
        transition: all 0.5s cubic-bezier(0.77,0.2,0.05,1.0);
    }
    input:not([type=checkbox]):not([type=radio]),
    textarea,
    select {
        margin: calc(1.5rem + 1px) 1px 1px 1px;
        padding: 0.31rem;
        display: block;
        width: calc(100% - 1px);
        border: 1px solid grey;
        cursor: text;
        transition: all 0.5s cubic-bezier(0.77,0.2,0.05,1.0);
    }

    input:not([type=checkbox]):not([type=radio])[type=color] {
        padding: 0rem;
        -moz-appearance: none!important;
        -webkit-appearance: none!important;
        appearance: none!important;
        cursor: pointer;
    }
    input:not([type=checkbox]):not([type=radio])[type="color"]::-webkit-color-swatch-wrapper {
        padding: 0;
    }
    input:not([type=checkbox]):not([type=radio])[type="color"]::-webkit-color-swatch {
        border: none;
        border-radius: 0;
    }
    input:not([type=checkbox]):not([type=radio])[type="color"]::-moz-color-swatch {
        border: none;
        border-radius: 0;
    }
    input:not([type=checkbox]):not([type=radio])[type="color"]::-moz-focus-inner {
        border: none;
        border-radius: 0;
        padding: 0;
    }
    input:not([type=checkbox]):not([type=radio])[type=number] {
        appearance: none!important;
        -moz-appearance: textfield!important;
        padding-left: 2.3rem;
        padding-right: 2.3rem;
    }
    input::-webkit-outer-spin-button,
    input::-webkit-inner-spin-button {
        -webkit-appearance: none;
        margin: 0;
    }
    input[type=number] ~ button {
        position: absolute;
        top: 0;
        height: calc(2rem - 2px);
        width: calc(2rem - 2px);
        position: absolute;
        font-size: 1.5rem;
        transition: all 0.5s cubic-bezier(0.77,0.2,0.05,1.0);
        padding: 0 !important;
        margin: 0 !important;
    }
    input[type=number] + button {
        left: 1px;
        border-right: 1px solid grey;
    }
    input[type=number] + button + button {
        right: 1px;
        border-left: 1px solid grey;

    }
    input[type=number]:disabled ~ button {
        border-color: lightgray !important;
        color: lightgray !important;
        cursor: not-allowed !important;
    }

    select {
        appearance: none!important;
        -moz-appearance: none!important;
        -webkit-appearance: none!important;
        -o-appearance: none!important;
        -ms-appearance: none!important;
        position: relative;
        background: 0 0;
        z-index: 10;
        cursor: pointer;
        background-color: transparent;
        border-radius: 0;
    }
    select ~ span {
        position: absolute;
        color: inherit;
        top: 0.25rem;
        right: 0.5rem;
        position: absolute;
        font-size: 1.7rem;
        line-height: 1rem;
        z-index: 0;
        transition: none;
        transform-origin: center left;
        transition: all 0.5s cubic-bezier(0.77,0.2,0.05,1.0);
    }

    select:disabled ~ span {
        color: lightgray !important;
    }

    textarea {
        resize: vertical;
        aspect-ratio: 30/5;
    }
    input:not([type=checkbox]):not([type=radio]):not([type="color"]):read-only,
    input:disabled,
    textarea:disabled,
    select:disabled {
        border-color: lightgray !important;
        color: lightgray !important;
        cursor: not-allowed !important;
    }
    input:not([type=checkbox]):not([type=radio]):not([type="color"]):-moz-read-only {
        border-color: lightgray !important;
        cursor: not-allowed !important;
    }
    form.submited input:invalid,
    form.submited textarea:invalid,
    form.submited select:invalid,
    form.submited  input[type=number]:invalid ~ button {
        border-color: tomato !important;
    }
    form.submited  input[type=number]:invalid ~ button {
        color: tomato !important;
    }
    select ~ label,
    input:not([type=checkbox]):not([type=radio]) ~ label,
    textarea ~ label {
        top: 0.15rem;
        left: 0.5rem;
        position: absolute;
        transition: all 0.5s cubic-bezier(0.77,0.2,0.05,1.0);
    }
    input:not([type=checkbox]):not([type=radio])[type=number] ~ label {
        left: 2.5rem;
    }
    input:not([type=checkbox]):not([type=radio]) ~ label,
    textarea ~ label {
        cursor: text;
    }

    input:not([type=checkbox]):not([type=radio]):not(:placeholder-shown) ~ label, input:not([type=checkbox]):not([type=radio]):focus ~ label,
    textarea:not(:placeholder-shown) ~ label, textarea:focus ~ label,
    select[multiple] ~ label,
    select:not([disabled]):has(option:checked:not([value])) ~ label, select:not([disabled]):has(option:checked:not([value=""])) ~ label, select:not([disabled]):active ~ label,
    select:disabled ~ label {
        top: -1.15rem;
        left: 0.3rem;
        font-size: 0.8em;
    }
    /*select:not([disabled]):has(option:checked:not([value])) ~ span, select:not([disabled]):has(option:checked:not([value=""])) ~ span, */
    select:not([disabled]):active ~ span {
        transform: rotate(90deg);
        right: 0.25rem;
    }
    form.submited input:invalid ~ label,
    form.submited textarea:invalid ~ label,
    form.submited select:invalid ~ label {
        color: tomato;
    }
    form.submited select:invalid ~ span {
        color: tomato;
    }
    input:not([type=checkbox]):not([type=file]):not([type=radio]):not([type="color"]):read-only ~ label,
    input:not([type=file]):disabled ~ label,
    textarea:disabled ~ label,
    select:disabled ~ label {
        color: lightgray !important;
        cursor: not-allowed !important;
    }
    input:not([type=checkbox]):not([type=radio]):not([type="color"]):not([type=file]):-moz-read-only ~ label {
        color: lightgray !important;
        cursor: not-allowed !important;
    }
    select ~ em,
    input:not([type=checkbox]):not([type=radio]) ~ em,
    textarea ~ em,
    input[type=checkbox] ~ em,
    input[type=radio] ~ em {
        display: block;
        font-size: 0.8em;
        margin: 0 5px;
        display: block;
        cursor: default;
    }
    input:not([type=checkbox]):not([type=radio]):not([type="color"]):read-only ~ em,
    input:disabled ~ em,
    textarea:disabled ~ em,
    select:disabled ~ em {
        color: lightgray !important;
    }
    input:not([type=checkbox]):not([type=radio]):not([type="color"]):-moz-read-only ~ em {
        color: lightgray !important;
    }

    input[type=checkbox],
    input[type=radio] {
        position: absolute !important;
        -webkit-appearance: none;
        -moz-appearance: none;
        appearance: none;
        margin: 0 8px;
        box-sizing: content-box;
        overflow: hidden;
        transform: translateY(3px);
        width: 1em;
        height: 1em;
        cursor: pointer;
        z-index: -1;
    }
    input[type=checkbox] + label,
    input[type=radio] + label {
        /*display: inline-block;*/
        position: relative;
        height: calc(1em + 4px);
        color: inherit;
        line-height: calc(1em + 4px);
        transform: translateY(-0.15em);
        transition: all 0.5s cubic-bezier(0.77,0.2,0.05,1.0);
        cursor: pointer;
    }
    input[type=checkbox] + label:hover,
    input[type=radio] + label:hover,
    input[type=checkbox]:checked + label,
    input[type=radio]:checked + label {
        color: currentColor;
    }
    input[type=checkbox] + label::before,
    input[type=radio] + label::before {
        content: '';
        display: inline-block;
        width: 1em;
        height: 1em;
        border: 1px solid currentColor;
        transition: 0.2s border-color ease;
        margin-right: 0.25em;
        transform: translateY(2px);
    }
    input[type=checkbox]:checked + label::before,
    input[type=radio]:checked + label::before {
        border-color: currentColor;
        transition: 0.5s border-color ease;
    }
    input[type=checkbox]:disabled + label::before,
    input[type=radio]:disabled + label::before {
        border-color: currentColor;
        cursor: not-allowed !important;
    }
    input[type=checkbox] + label::after,
    input[type=radio] + label::after {
        content: '';
        display: block;
        position: absolute;
        box-sizing: content-box;
        top: calc(0.4em + 2px);
        left: 0.5em;
        transform-origin: 50% 50%;
        background-color: currentColor;
        width: 0.8em;
        height: 0.8em;
        border-radius: 100vh;
        transform: translate(-50%, -50%) scale(0);
    }
    input[type=radio] + label::after {
        top: calc(0.45em + 2px);
    }
    input[type="radio"] + label::before {
        border-radius: 100vh;
    }
    input[type="radio"] + label::after {
        width: 0.7em;
        height: 0.7em;
        border-radius: 100vh;
        transform: translate(-50%, -50%) scale(0);
    }
    input[type="radio"]:checked + label::after {
        -webkit-animation: toggleOnRadio 0.2s ease forwards;
        animation: toggleOnRadio 0.2s ease forwards;
    }
    input[type="checkbox"] + label::before {
        border-radius: 4px;
    }
    input[type="checkbox"] + label::after {
        width: 0.4em;
        height: 0.8em;
        border-radius: 0;
        transform: translate(-50%, -85%) scale(0) rotate(45deg);
        background-color: transparent;
        box-shadow: 4px 4px 0px 0px currentColor;
    }
    input[type="checkbox"]:disabled + label::after {
        box-shadow: 4px 4px 0px 0px currentColor;
    }
    input[type="checkbox"]:checked + label::after {
        -webkit-animation: toggleOnCheckbox 0.2s ease forwards;
        animation: toggleOnCheckbox 0.2s ease forwards;
    }
    input[type="checkbox"].filled + label::before {
        border-radius: 4px;
        transition: 0.2s border-color ease, 0.2s background-color ease;
    }
    input[type="checkbox"].filled:checked:not(:disabled) + label::before {
        background-color: currentColor;
    }
    input[type="checkbox"].filled:not(:disabled) + label::after {
        box-shadow: 4px 4px 0px 0px white;
    }
    @-webkit-keyframes toggleOnCheckbox {
        0% {
            opacity: 0;
            transform: translate(-50%, -85%) scale(0) rotate(45deg);
        }
        70% {
            opacity: 1;
            transform: translate(-50%, -85%) scale(0.9) rotate(45deg);
        }
        100% {
            transform: translate(-50%, -85%) scale(0.8) rotate(45deg);
        }
    }
    @keyframes toggleOnCheckbox {
        0% {
            opacity: 0;
            transform: translate(-50%, -85%) scale(0) rotate(45deg);
        }
        70% {
            opacity: 1;
            transform: translate(-50%, -85%) scale(0.9) rotate(45deg);
        }
        100% {
            transform: translate(-50%, -85%) scale(0.8) rotate(45deg);
        }
    }
    @-webkit-keyframes toggleOnRadio {
        0% {
            opacity: 0;
            transform: translate(-50%, -50%) scale(0);
        }
        70% {
            opacity: 1;
            transform: translate(-50%, -50%) scale(0.9);
        }
        100% {
            transform: translate(-50%, -50%) scale(0.8);
        }
    }
    @keyframes toggleOnRadio {
        0% {
            opacity: 0;
            transform: translate(-50%, -50%) scale(0);
        }
        70% {
            opacity: 1;
            transform: translate(-50%, -50%) scale(0.9);
        }
        100% {
            transform: translate(-50%, -50%) scale(0.8);
        }
    }
