/* Common Form Styles - Global */

/* Mandatory Field Indicator */
.form-group label.required::after,
label.required::after {
    content: " *";
    color: #ef4444;
    font-weight: 600;
    margin-left: 4px;
}

/* Mandatory Input Box Styling */
input[required],
textarea[required],
select[required] {
    border-left: 1px solid #fca5a5;
}

input[required]:focus,
textarea[required]:focus,
select[required]:focus {
    border-left-color: #f87171;
    outline: none;
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1);
}

/* Invalid State for Required Fields */
input[required]:invalid:not(:placeholder-shown),
textarea[required]:invalid:not(:placeholder-shown),
select[required]:invalid:not(:placeholder-shown) {
    border-left-color: #ef4444;
}

input[required]:invalid:not(:placeholder-shown):focus,
textarea[required]:invalid:not(:placeholder-shown):focus,
select[required]:invalid:not(:placeholder-shown):focus {
    box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.1);
}

/* Optional Field Styling */
input:not([required]),
textarea:not([required]),
select:not([required]) {
    border-left: 1px solid #e2e8f0;
}

/* Form Group Spacing */
.form-group {
    margin-bottom: 1.5rem;
}

/* Form Labels */
.form-group label {
    display: block;
    font-weight: 600;
    margin-bottom: 0.5rem;
    color: #1e293b;
    font-size: 0.875rem;
}

/* Input Base Styles */
input[type="text"],
input[type="password"],
input[type="email"],
input[type="number"],
input[type="tel"],
textarea,
select {
    width: 100%;
    padding: 0.75rem;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    font-size: 1rem;
    transition: all 0.2s;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

input[type="text"]:focus,
input[type="password"]:focus,
input[type="email"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
textarea:focus,
select:focus {
    border-color: #10b981;
}

/* Disabled State */
input:disabled,
textarea:disabled,
select:disabled {
    background: #f8fafc;
    cursor: not-allowed;
    opacity: 0.6;
}

/* Placeholder Styling */
input::placeholder,
textarea::placeholder {
    color: #94a3b8;
    opacity: 1;
}

/* Error Message */
.form-error {
    color: #ef4444;
    font-size: 0.75rem;
    margin-top: 0.25rem;
    display: none;
}

.form-group.error .form-error {
    display: block;
}

.form-group.error input,
.form-group.error textarea,
.form-group.error select {
    border-color: #ef4444;
    border-left-color: #ef4444;
}

/* Success State */
.form-group.success input,
.form-group.success textarea,
.form-group.success select {
    border-color: #10b981;
    border-left-color: #10b981;
}

/* Help Text */
.form-help {
    color: #64748b;
    font-size: 0.75rem;
    margin-top: 0.25rem;
}

/* Checkbox and Radio Styling */
input[type="checkbox"],
input[type="radio"] {
    width: auto;
    margin-right: 0.5rem;
    cursor: pointer;
}

.checkbox-label,
.radio-label {
    display: flex;
    align-items: center;
    cursor: pointer;
    font-weight: 400;
}

