/* css/components/_forms.css */

/* Form Inputs & Labels */
.form-input, input[type="text"], input[type="email"], input[type="password"], input[type="url"], input[type="search"], select, textarea, input[type="date"] {
    width: 100%;
    padding: 0.625rem var(--spacing-md);
    margin-bottom: var(--spacing-md);
    border: 1px solid var(--border-color-medium);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
    transition: border-color 0.2s ease, box-shadow 0.2s ease;
    background-color: var(--text-color-white);
    color: var(--text-color-dark);
}
.form-input:focus, input[type="text"]:focus, input[type="email"]:focus, input[type="password"]:focus, input[type="url"]:focus, input[type="search"]:focus, select:focus, textarea:focus, input[type="date"]:focus {
    border-color: var(--color-primary-base);
    outline: none;
    box-shadow: 0 0 0 2px var(--color-primary-focus-ring);
}
.form-input-sm {
    padding: var(--spacing-sm) 0.75rem;
    font-size: var(--font-size-sm);
}
input[type="color"].form-input-sm {
    height: 2.25rem;
}
.form-checkbox {
    height: 1.25rem;
    width: 1.25rem;
    color: var(--color-primary-base);
    background-color: var(--color-gray-600);
    border-color: var(--color-gray-500);
    border-radius: var(--radius-sm);
}
.form-checkbox:focus {
    --ring-color: var(--color-primary-base);
    box-shadow: 0 0 0 2px var(--ring-color);
}

.admin-input-light,
#accountAddUserFormContainer input,
#accountAddUserFormContainer select,
#grantProjectAccessForm select,
#addClassificationForm_Admin input[type="text"],
#addClassificationForm_Admin input[type="color"] {
    background-color: var(--text-color-white) !important;
    color: var(--text-color-dark) !important;
    border-color: var(--border-color-medium) !important;
}
.admin-input-light:focus,
#accountAddUserFormContainer input:focus,
#accountAddUserFormContainer select:focus,
#addClassificationForm_Admin input[type="text"]:focus,
#addClassificationForm_Admin input[type="color"]:focus {
    border-color: var(--color-primary-base) !important;
    box-shadow: 0 0 0 2px var(--color-primary-focus-ring) !important;
}


.form-label {
    display: block;
    margin-bottom: var(--spacing-xs);
    font-weight: var(--font-medium);
    color: var(--color-gray-700);
    font-size: var(--font-size-sm);
}
.form-label-sm { font-size: var(--font-size-sm); }
.form-label-xs { font-size: var(--font-size-xs); }


.form-group {
    margin-bottom: var(--spacing-md);
}
.form-group-grid {
    display: grid;
    grid-template-columns: repeat(1, minmax(0, 1fr));
    gap: var(--spacing-md);
}
@media (min-width: 768px) {
    .form-group-grid.md-cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .form-group-grid.md-cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

.form-input-sm {
    padding: var(--spacing-xs) var(--spacing-sm);
    font-size: var(--font-size-sm);
    line-height: 1.25rem;
}
select.form-input-sm {
    height: calc(1.25rem + var(--spacing-xs) * 2 + 2px);
}

/* General form control styles from old style.css */
.form-control, .form-select {
    width: 100%;
    padding: 10px;
    border: 1px solid #ccc;
    border-radius: 5px;
    box-sizing: border-box; /* Include padding in width */
    font-size: 1rem;
}

.form-control:focus, .form-select:focus {
    border-color: #3498db;
    outline: none;
    box-shadow: 0 0 0 2px rgba(52, 152, 219, 0.25);
}

.form-check {
    display: flex;
    align-items: center;
    margin-bottom: 10px;
}

.form-check-input {
    margin-right: 10px;
}
