:root {

    --Q-form-fieldset-margin: 0 0 var(--Q-app-spacing-2) 0;
    --Q-form-fieldset-padding: var(--Q-app-spacing-2) var(--Q-app-spacing-2) 0 var(--Q-app-spacing-2);
    --Q-form-fieldset-border: 0.2rem solid var(--Q-app-background-1);
    --Q-form-fieldset-border-radius: var(--Q-app-item-border-radius);

    --Q-form-legend-margin: 0 0 var(--Q-app-spacing-2) 0;
    --Q-form-legend-padding: 0 var(--Q-app-spacing-2);

    --Q-form-input-font-size: 1.2rem;
    --Q-form-input-padding: var(--Q-app-spacing-2) var(--Q-app-spacing-3);
    --Q-form-input-border-radius: var(--Q-app-item-border-radius);
    --Q-form-input-box-shadow: 0.1rem 0.05rem 0.2rem 0.1rem var(--Q-app-box-shadow-color) inset;
    --Q-form-input-box-shadow-focused: none;
    --Q-form-input-background: var(--Q-app-background-4);
    --Q-form-input-outline-focused: 0.2rem solid #359eff;
    --Q-form-input-outline-focused-flash: 0.2rem solid #359dff86;
    --Q-form-input-outline-focused-animation: Q-form-focus-animation 3s infinite ease-in-out;
    --Q-form-input-outline-error: 0.2rem solid #ff6923;
    --Q-form-input-outline-error-flash: 0.2rem solid transparent;
    --Q-form-input-outline-error-animation: Q-form-error-animation 2s infinite ease-in-out;

    --Q-form-field-margin: 0 0 var(--Q-app-spacing-4) 0;
    --Q-form-field-label-margin: 0 0 var(--Q-app-spacing-2) var(--Q-app-spacing-2);
    --Q-form-field-label-button-margin: 0 0 0 var(--Q-app-spacing-2);
    --Q-form-field-input-button-margin: 0 0 0 var(--Q-app-spacing-2);

    --Q-form-input-color-height: 2rem;
    --Q-form-input-color-width: 4rem;

    --Q-form-input-radio-size: 1.5rem;
    --Q-form-input-radio-margin: 0 var(--Q-app-spacing-2) 0 0;
    --Q-form-input-checkbox-size: 1.5rem;
    --Q-form-input-checkbox-margin: 0 var(--Q-app-spacing-2) 0 0;
    --Q-form-switch-on-background-color: var(--Q-app-item-color-standard);
    --Q-form-switch-off-background-color: var(--Q-app-background-4);
    --Q-form-switch-knob-color: #fff;
}

/* form */

.Q-form {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
}

/* fieldset */

.Q-form fieldset {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    margin: var(--Q-form-fieldset-margin);
    padding: var(--Q-form-fieldset-padding);
    border: var(--Q-form-fieldset-border);
    border-radius: var(--Q-form-fieldset-border-radius);
}

.Q-form fieldset legend {
    margin: var(--Q-form-legend-margin);
    padding: var(--Q-form-legend-padding);
}

/* Fields */

.Q-form-field {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    width: 100%;
    margin: var(--Q-form-field-margin);
}

.Q-form-field label {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    margin: var(--Q-form-field-label-margin);
    user-select: none;
}

.Q-form-field button {
    margin: var(--Q-form-field-label-button-margin);
}

.Q-form .Q-form-field input, .Q-form .Q-form-field select, .Q-form .Q-form-field textarea {
    margin-bottom: 0;
}

.Q-form-field .Q-form-field-button {
    width: 100%;
    display: flex;
    align-items: center;
}

.Q-form-field .Q-form-field-pass button {
    margin: var(--Q-form-field-input-button-margin);
}

/* Inputs */

.Q-form input, .Q-form select, .Q-form textarea {
    color: inherit;
    margin: var(--Q-form-field-margin);
}

.Q-form textarea {
    border-bottom-right-radius: 0;
}

.Q-form input, .Q-form textarea, .Q-form select{
    border: none;
    outline: none;
    width: 100%;
}

.Q-form input:not([type=range], [type=color], [type=submit], [type=reset], [type=button], [type=checkbox], [type=radio]), textarea, select {
    padding: var(--Q-form-input-padding);
    box-shadow: var(--Q-form-input-box-shadow);
    border-radius: var(--Q-form-input-border-radius);
    background-color: var(--Q-form-input-background);
    font-size: var(--Q-form-input-font-size);
    appearance: none;
}

.Q-form input:focus:not([type=checkbox], [type=radio], [type=color], [type=range]), .Q-form textarea:focus {
    box-shadow: var(--Q-form-input-box-shadow-focused);
    outline: var(--Q-form-input-outline-focused);
    animation: var(--Q-form-input-outline-focused-animation);
}

.Q-form input[Q-form-error], .Q-form textarea[Q-form-error] {
    box-shadow: var(--Q-form-input-box-shadow-focused);
    outline: var(--Q-form-input-outline-error);
    animation: var(--Q-form-input-outline-error-animation);
}

.Q-form input[type=checkbox], .Q-form input[type=radio] {
    box-shadow: none;
}

.Q-form input[type=color] {
    height: var(--Q-form-input-color-height);
    width: var(--Q-form-input-color-width);
    background-color: transparent;
}

/* Choices (Radios, checkboxes and switches) */

.Q-form .Q-form-choices {
    display: flex;
    flex-direction: column;
    width: 100%;
}

.Q-form .Q-form-choices .Q-form-field {
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    width: 100%;
}

.Q-form .Q-form-choices .Q-form-field input[type=radio] {
    height: var(--Q-form-input-radio-size);
    width: var(--Q-form-input-radio-size);
    margin: var(--Q-form-input-radio-margin);
}

.Q-form .Q-form-choices .Q-form-field input[type=checkbox] {
    height: var(--Q-form-input-checkbox-size);
    width: var(--Q-form-input-checkbox-size);
    margin: var(--Q-form-input-checkbox-margin);
}

.Q-form .Q-form-choices .Q-form-field .Q-form-switch {
    margin: var(--Q-form-input-checkbox-margin);
}

.Q-form .Q-form-choices .Q-form-field label {
    margin: 0;
}

/* SWITCHES */

.Q-form-switch {
    position: relative;
    display: inline-block;
    width: 3.5rem;
    height: 2rem;
}
  
.Q-form-switch input {
    opacity: 0;
    width: 0;
    height: 0;
}
  
.Q-form-switch span {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: var(--Q-form-switch-off-background-color);
    transition: 0.4s;
    border-radius: 2rem;
}
  
.Q-form-switch span:before {
    position: absolute;
    content: "";
    height: 1.5rem;
    width: 1.5rem;
    left: 0.25rem;
    bottom: 0.25rem;
    background-color: var(--Q-form-switch-knob-color);
    transition: 0.4s;
    border-radius: 50%;
}
  
.Q-form-switch input:checked + span {
    background-color: var(--Q-form-switch-on-background-color);
}
  
.Q-form-switch input:checked + span:before {
    transform: translateX(1.5rem);
}

/* SWITCHES END */


/* Animations */

@keyframes Q-form-focus-animation {
    0% {outline: var(--Q-form-input-outline-focused)}
    50% {outline: var(--Q-form-input-outline-focused-flash)}
    100% {outline: var(--Q-form-input-outline-focused)}
}

@keyframes Q-form-error-animation {
    0% {outline: var(--Q-form-input-outline-error)}
    50% {outline: var(--Q-form-input-outline-error-flash)}
    100% {outline: var(--Q-form-input-outline-error)}
}