.form.--slim {
    max-width: 300px;
}

.form.--normal {
    max-width: 540px;
}

.form.--fat {
    max-width: 620px;
}

.form__lb {
    display: inline-block;
    line-height: 22px;
    font-size: 17px;
    font-weight: 700;
}

.form__txt {
    font-size: 16px;
    height: 36px;
    line-height: 34px;
    padding: 0 14px;
    border: solid #9e9e9e 1px;
    border-radius: 4px;
    outline: transparent none;
    background: #fff;
    transition: outline-color 200ms,
    outline-width 200ms,
    border-bottom-color 200ms,
    border-top-color 200ms,
    border-left-color 200ms,
    border-right-color 200ms;
}

select.form__txt {
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAwBAMAAAClLOS0AAAAD1BMVEX///8AAAAAAAAAAAAAAABRO2rwAAAABHRSTlMAd3+ApzL+VgAAADZJREFUeF5jGLlgFIi4gIEThgQjREIBmxaIBuxaFBiwABGwBuxaFBiwAhEnBuyA2YBhJINRAACIEAhPkYd1iwAAAABJRU5ErkJggg==');
    background-position: right center;
    background-repeat: no-repeat;
    background-size: 24px 24px;
    padding-right: 24px;
}

.form__txt:active,
.form__txt:focus {
    border-color: #1976d2;
    outline: solid rgba(37, 149, 190, 0.2) 5px;
}

.form__txt:focus:invalid {
    border-color: red;
}


.form__btn,
a.form__btn {
    color: rgba(0, 0, 0, 0.925);
    font-size: 14px;
    font-weight: 500;
    text-transform: uppercase;
    background: #28ff52;
    border-radius: 4px;
    display: inline-block;
    text-align: center;
    min-width: 80px;
    height: 36px;
    line-height: 36px;
    padding: 0 14px;
    border: none;
    cursor: pointer;
    outline: transparent none;
    -moz-user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
    transition: outline-color 200ms,
    outline-width 200ms,
    background-color 200ms;
    text-decoration: none;
}

.form__btn:hover,
.form__btn:focus,
a.form__btn:hover,
a.form__btn:focus {
    color: rgba(0, 0, 0, 0.925);
    background: #7eff97;
    outline: solid rgba(0, 0, 0, 0.1) 5px;
}

.form__btn:active,
a.form__btn:active {
    color: rgba(0, 0, 0, 0.925);
    background: #7eff97;
    outline: solid rgba(37, 149, 190, 0.2) 7px;
}

.form__btn.--iconic {
    min-width: 50px;
    font-size: 0;
    padding: 0;
}

.form__btn.--iconic .mtico {
    margin-top: 7px;
}

.form__btn.--danger,
.form__btn.--error {
    color: rgba(255, 255, 255, 0.94);
    background: #f44336;
}

.form__btn.--danger:hover,
.form__btn.--danger:focus,
.form__btn.--error:hover,
.form__btn.--error:focus {
    background: #c62828;
}

.form__btn.--danger:active,
.form__btn.--error:active {
    background: #ff1744;
}

.form__btn.--warning {
    color: #000000;
    background: #ffb300;
}

.form__btn.--warning:hover,
.form__btn.--warning:focus {
    background: #ff8f00;
}

.form__btn.--warning:active {
    background: #ffab00;
}

.form__btn:disabled {
    background: #9e9e9e !important;
    color: #fff !important;
    outline: none !important;
    opacity: 0.85;
    cursor: auto !important;
}

.form__lb__checkbox {
    display: grid;
    grid-template-columns: 15px auto;
    gap: 15px;
    cursor: pointer;
    -moz-user-select: none;
    -webkit-user-select: none;
    -ms-user-select: none;
    user-select: none;
    line-height: 1.21em;
}

.form__checkbox {

    /* Hide native checkbox input */
    -webkit-appearance: none;
    appearance: none;
    margin: 0;

    /* Unchecked style */
    font: inherit;
    color: black;
    width: 21px;
    height: 21px;
    border: solid #bdbdbd 2px;
    border-radius: 2px;
    background: #FEFEFEFF center no-repeat;
    background-size: 10px auto;
    cursor: pointer;
    outline: transparent none;
    transition: background-color 200ms,
    border-bottom-color 200ms,
    border-top-color 200ms,
    border-left-color 200ms,
    border-right-color 200ms,
    outline-color 160ms,
    outline-width 160ms;

}

.form__checkbox:checked {
    background: #f8f8ff url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAJCAMAAAAxZj1mAAAAM1BMVEX///8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAADxgEwMAAAAEHRSTlMABa2o6lJL+K6qWCMuLfq3pd5NcQAAADhJREFUeF5FylcOACAMAtAu97z/aY22qXy9AODBUr9psztvQsCm/TWwDDfEJF0/N2HKMr/NrBubD0IHAS4boRlXAAAAAElFTkSuQmCC) center no-repeat;
    border: solid #9fa8da 2px;
}

.form__checkbox:hover,
.form__checkbox:focus {
    outline: solid rgba(0, 0, 0, 0.08) 4px;
}

.form__group {
    margin-bottom: 14px;
}

.form__ctrl {
    margin-top: 22px;
}

.form__group:after,
.form__ctrl:after {
    content: "";
    display: table;
    clear: both;
}

.form__group .form__lb {
    display: block;
    margin-bottom: 5px;
}

.form__group .form__txt {
    display: block;
    width: 100%;
}

.form__fieldset {
    border: solid rgba(0, 0, 0, 0.1) 1px;
    border-radius: 4px;
    padding: 12px 16px;
}

.form__fieldset legend {
    padding: 0 8px;
    font-weight: 500;
}

.form__msg {
    background: #f5f5f5;
    border: solid #e0e0e0 1px;
    border-radius: 4px;
    padding: 8px 12px;
    margin: 0 0 5px;
}

.form__msg--error {
    border-color: #e53935;
    background: #e57373;
    color: rgba(255, 255, 255, 0.95);
}

.form__progress {
    height: 36px;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
}

/* Container/Background */
.form__progress,
.form__progress[value]::-webkit-progress-bar {
    background-color: #e0e0e0;
    border-radius: 4px;
}

/* Value webkit */
.form__progress[value]::-webkit-progress-value {
    background: #5c6bc0;
    border-radius: 4px;
}

/* Value firefox */
.form__progress[value]::-moz-progress-bar {
    background: #5c6bc0;
    border-radius: 4px;
}

.form__group .form__progress {
    width: 100%;
}
