/* Input States for Hindi Interactive Lesson */

/* Default input state */
.form-control {
    width: 100%;
    padding: var(--form-spacing-sm) var(--form-spacing-md);
    font-family: var(--form-font-family);
    font-size: var(--form-font-size-md);
    line-height: var(--form-line-height);
    color: var(--form-text-color);
    background-color: var(--form-bg-color);
    border: 1px solid var(--form-border-color);
    border-radius: var(--form-border-radius-md);
    transition: border-color var(--form-transition-duration), box-shadow var(--form-transition-duration);
}

.form-control::-webkit-input-placeholder {
    color: var(--form-placeholder-color);
}

.form-control::placeholder {
    color: var(--form-placeholder-color);
}

/* Focus state */
.form-control:focus {
    border-color: var(--form-border-focus-color);
    outline: 0;
    box-shadow: 0 0 0 2px rgba(30, 58, 138, 0.25);
}

/* Disabled state */
.form-control:disabled,
.form-control[readonly] {
    background-color: var(--form-disabled-bg-color);
    color: var(--form-disabled-text-color);
    cursor: not-allowed;
    opacity: 0.7;
}

/* Invalid state */
.form-control.is-invalid {
    border-color: var(--form-error-color);
}

.form-control.is-invalid:focus {
    box-shadow: 0 0 0 2px rgba(211, 47, 47, 0.25);
}

/* Valid state */
.form-control.is-valid {
    border-color: var(--form-success-color);
}

.form-control.is-valid:focus {
    box-shadow: 0 0 0 2px rgba(56, 142, 60, 0.25);
}

/* Form feedback messages */
.form-text {
    display: block;
    margin-top: var(--form-spacing-xs);
    font-size: var(--form-font-size-sm);
}

.invalid-feedback {
    display: none;
    width: 100%;
    margin-top: var(--form-spacing-xs);
    font-size: var(--form-font-size-sm);
    color: var(--form-error-color);
}

.valid-feedback {
    display: none;
    width: 100%;
    margin-top: var(--form-spacing-xs);
    font-size: var(--form-font-size-sm);
    color: var(--form-success-color);
}

.form-control.is-invalid ~ .invalid-feedback {
    display: block;
}

.form-control.is-valid ~ .valid-feedback {
    display: block;
}

/* Form group spacing */
.form-group {
    margin-bottom: var(--form-spacing-md);
}

/* Form label */
.form-label {
    display: inline-block;
    margin-bottom: var(--form-spacing-xs);
    font-weight: 500;
}

/* Required indicator */
.form-label.required::after {
    content: "*";
    color: var(--form-required-color);
    margin-left: var(--form-spacing-xs);
}
