.material .form-elements {

}

.material .form-wrapper {
    position: relative;
    padding-top: 26px;
}

.material .form-label {
    position: absolute;
    visibility: visible;
    bottom: 0;
    color: rgba(0, 0, 0, .26);
    font-size: 16px;
    left: 0;
    right: 0;
    pointer-events: none;
    display: block;
    top: 6px;
    width: 100%;
    overflow: hidden;
    white-space: nowrap;
    text-align: left;
    transition-duration: .2s;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    padding: 0 15px 0 0;
}

.material .form-label > label {
    color: rgba(0, 0, 0, .54);
    font-size: 0.85em;
    visibility: visible;
}

.material .form-element {
    display: inline-block;
    position: relative;
    padding-top: 6px;
}

form.global_.material .form-element {
    min-width: 250px;
}

.material .form-element input[type=text],
.material .form-element input[type=email],
.material .form-element input[type=time],
.material .form-element input[type=date],
.material .form-element input[type=number],
.material .form-element input[type=password],
.material .form-element input.text,
.material .form-element textarea,
.material .form-element select {
    font-family: "Source Sans Pro", sans-serif;
    font-size: 13px;
    width: 100%;
    height: 30px;
    max-width: 100%;
    outline: none;
    border-width: 1px;
    border-color: #ccc;
    padding: 6px 10px;
    position: relative;
    border-radius: 3px;
}

.material .form-element select {
    font-family: "Source Sans Pro", sans-serif;
    font-size: 13px;
    padding: 4px 20px 4px 10px;
    width: 100%;
    height: 30px;
    border-radius: 3px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: linear-gradient(45deg, transparent 50%, gray 50%),
    linear-gradient(135deg, gray 50%, transparent 50%);
    background-position: calc(100% - 10px) 1em,
    calc(100% - 5px) 1em;
    background-size: 5px 5px,
    5px 5px;
    background-repeat: no-repeat;
}

.material .form-element input[type="text"]:focus,
.material .form-element input[type="password"]:focus,
.material .form-element input[type="datetime"]:focus,
.material .form-element input[type="datetime-local"]:focus,
.material .form-element input[type="date"]:focus,
.material .form-element input[type="month"]:focus,
.material .form-element input[type="time"]:focus,
.material .form-element input[type="week"]:focus,
.material .form-element input[type="number"]:focus,
.material .form-element input[type="email"]:focus,
.material .form-element input[type="url"]:focus,
.material .form-element input[type="search"]:focus,
.material .form-element input[type="tel"]:focus,
.material .form-element input[type="color"]:focus {
    border-color: #ccc !important;
    box-shadow: none;
    outline: none;
}

.material .form-element input ~ span.form-element-bottom-line,
.material .form-element textarea ~ span.form-element-bottom-line,
.material .form-element select ~ span.form-element-bottom-line {
    background-color: #6a1b9a;
    top: 34px;
    content: '';
    height: 2px;
    left: 45%;
    position: absolute;
    transition-duration: .2s;
    transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    visibility: hidden;
    width: 10px;
}

.material .form-element input[type="text"]:focus ~ span.form-element-bottom-line,
.material .form-element input[type="password"]:focus ~ span.form-element-bottom-line,
.material .form-element input[type="number"]:focus ~ span.form-element-bottom-line,
.material .form-element input[type="email"]:focus ~ span.form-element-bottom-line,
.material .form-element input[type="url"]:focus ~ span.form-element-bottom-line,
.material .form-element input[type="tel"]:focus ~ span.form-element-bottom-line,
.material .form-element input[type="search"]:focus ~ span.form-element-bottom-line,
.material .form-element textarea:focus ~ span.form-element-bottom-line,
.material .form-element select:focus ~ span.form-element-bottom-line {
    left: 0;
    visibility: visible;
    width: 100%;
}

/* CHECKBOX AND RADIO */
.material .form-element input[type="radio"] + label,
.material .form-element input[type="checkbox"] + label {
    padding-left: 22px;
    margin-bottom: 10px;
    position: relative;
}

.material .form-element input[type="radio"],
.material .form-element input[type="checkbox"] {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    opacity: 0;
    position: absolute;
    margin: 0;
    z-index: -1;
    width: 0;
    height: 0;
    overflow: hidden;
    left: 0;
    pointer-events: none;
}

.material .form-element input[type="radio"]:focus {
    outline: none;
}

.material .form-element input[type="radio"] + label:before,
.material .form-element input[type="radio"] + label:after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    top: 1px;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    -webkit-transition: 240ms;
    -o-transition: 240ms;
    transition: 240ms;
}

.material .form-element input[type="radio"] + label:before {
    left: 0;
    top: 1px;
}

.material .form-element input[type="radio"] + label:before {
    background-color: #6a1b9a;
    -webkit-transform: scale(0);
    -ms-transform: scale(0);
    -o-transform: scale(0);
    transform: scale(0);
}

.material .form-element input[type="radio"] + label:after {
    top: 1px;
    border: 2px solid #999999;
    z-index: 1;
}

.material .form-element input[type="radio"]:checked + label:before {
    -webkit-transform: scale(0.6);
    -ms-transform: scale(0.6);
    -o-transform: scale(0.6);
    transform: scale(0.6);
}

.material .form-element input[type="radio"]:disabled:checked + label:before {
    background-color: #bbbbbb;
}

.material .form-element input[type="radio"]:checked + label:after {
    border-color: #6a1b9a;
}

.material .form-element input[type="radio"]:disabled + label:after,
.material .form-element input[type="radio"]:disabled:checked + label:after {
    border-color: #bbbbbb;
}

.material .form-element input[type="checkbox"]:focus {
    outline: none;
}

.material .form-element input[type="checkbox"]:focus + label:after {
    border-color: #6a1b9a;
}

.material .form-element input[type="checkbox"] + label:after {
    content: "";
    position: absolute;
    top: 3px;
    left: 0;
    display: block;
    width: 16px;
    height: 16px;
    margin-top: -2px;
    margin-right: 5px;
    border: 2px solid #999999;
    border-radius: 2px;
    -webkit-transition: 240ms;
    -o-transition: 240ms;
    transition: 240ms;
}

.material .form-element input[type="checkbox"]:checked + label:before {
    content: "";
    position: absolute;
    top: 3px;
    left: 6px;
    display: table;
    width: 5px;
    height: 10px;
    border: 2px solid #fff;
    border-top-width: 0;
    border-left-width: 0;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    -o-transform: rotate(45deg);
    transform: rotate(45deg);
    z-index: 1;
}

.material .form-element input[type="checkbox"]:checked + label:after {
    background-color: #6a1b9a;
    border-color: #6a1b9a;
}

.material .form-element input[type="checkbox"]:disabled + label:after {
    border-color: #bbbbbb;
}

.material .form-element input[type="checkbox"]:disabled:checked + label:after {
    background-color: #bbbbbb;
    border-color: transparent;
}

/* location */
.material .form-element input + a.location_icon {
    position: absolute;
    top: 5px;
    right: 0;
    font-size: 20px;
    color: #6a1b9a;
}

/* submit buttons */
/* Commented out because of too many various forms and button combinations in SE! */
/*.material .form-wrapper fieldset.form_submit_buttons,*/
/*.material .form-wrapper fieldset#fieldset-form_submit_buttons {*/
/*  display: flex;*/
/*  justify-content: space-between;*/
/*  align-items: center;*/
/*}*/