﻿/* =============================================================
   TMIS FORMS
   Responsibility:
   - Inputs
   - Labels
   - Help text
   - File uploads
   - Validation
   NO layout
   NO page-specific styling
   ============================================================= */


/* =============================================================
   LABELS
   ============================================================= */

.tmis-form label {
    color: var(--tmis-text-strong);
    font-weight: 600;
}


/* =============================================================
   INPUTS / SELECTS / TEXTAREAS
   ============================================================= */

.tmis-form .form-control,
.tmis-form .form-select,
.tmis-form textarea {
    background: var(--tmis-surface);
    color: var(--tmis-text);
    border: 1px solid var(--tmis-border);
    border-radius: 0;
}

    .tmis-form .form-control:focus,
    .tmis-form .form-select:focus,
    .tmis-form textarea:focus {
        border-color: var(--tmis-primary);
        box-shadow: 0 0 0 0.15rem rgba(13, 110, 253, 0.25);
        background: var(--tmis-surface);
        color: var(--tmis-text);
    }


/* =============================================================
   CHECKBOXES & RADIOS
   ============================================================= */

.tmis-form .form-check-input {
    background-color: var(--tmis-surface);
    border: 1px solid var(--tmis-border);
}

    .tmis-form .form-check-input:checked {
        background-color: var(--tmis-primary);
        border-color: var(--tmis-primary);
    }

.tmis-form .form-check-label {
    color: var(--tmis-text);
}


/* =============================================================
   FILE INPUTS
   ============================================================= */

.tmis-form input[type="file"] {
    background: var(--tmis-surface);
    color: var(--tmis-text);
    border: 1px solid var(--tmis-border);
}

    .tmis-form input[type="file"]::file-selector-button {
        background: var(--tmis-surface-muted);
        color: var(--tmis-text);
        border: 1px solid var(--tmis-border);
    }


/* =============================================================
   HELP / HINT TEXT
   ============================================================= */

.tmis-form .form-text {
    color: var(--tmis-text-muted);
    font-size: 0.8rem;
}


/* =============================================================
   DISABLED STATES
   ============================================================= */

.tmis-form .form-control:disabled,
.tmis-form .form-select:disabled,
.tmis-form textarea:disabled {
    background: var(--tmis-surface-muted);
    color: var(--tmis-text-muted);
    cursor: not-allowed;
}


/* =============================================================
   VALIDATION STATES
   ============================================================= */

.tmis-form .is-invalid {
    border-color: var(--tmis-danger);
}

.tmis-form .invalid-feedback {
    color: var(--tmis-danger);
    font-size: 0.8rem;
}


/* =============================================================
   TMIS QUESTION BLOCKS
   ============================================================= */

.tmis-question {
    background: var(--tmis-surface);
    padding: 0.75rem;
    border: 1px solid var(--tmis-border-muted);
}

    .tmis-question label {
        font-weight: 600;
        margin-bottom: 0.25rem;
    }

    .tmis-question.is-unanswered {
        border-left: 3px solid var(--tmis-border-muted);
    }

    .tmis-question.is-answered {
        border-left: 3px solid var(--tmis-primary);
    }

/* Remove number spinners (safe) */
.no-spinner::-webkit-inner-spin-button,
.no-spinner::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.no-spinner {
    -moz-appearance: textfield;
}
