﻿/* =============================================================
   TMIS FORMS
   Responsibility:
   - Inputs
   - Labels
   - Help text
   - File uploads
   - Validation
   - Dark-mode safe
   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;
}


/* =============================================================
   DARK MODE SAFETY
   ============================================================= */

html.dark-mode .tmis-form .form-control,
html.dark-mode .tmis-form .form-select,
html.dark-mode .tmis-form textarea {
    background: var(--tmis-surface);
    color: var(--tmis-text);
    border-color: rgba(255, 255, 255, 0.15);
}

html.dark-mode .tmis-form input[type="file"]::file-selector-button {
    background: var(--tmis-surface-muted);
    color: var(--tmis-text);
    border-color: var(--tmis-border);
}
/* =============================================================
   DARK MODE — GLOBAL FORM FALLBACK
   Applies when .tmis-form wrapper is missing
   ============================================================= */

html.dark-mode .form-control,
html.dark-mode .form-select,
html.dark-mode textarea {
    background: var(--tmis-surface);
    color: var(--tmis-text);
    border-color: rgba(255, 255, 255, 0.15);
}

    html.dark-mode .form-control::placeholder,
    html.dark-mode textarea::placeholder {
        color: var(--tmis-text-muted);
    }

html.dark-mode .form-check-label {
    color: var(--tmis-text);
}

html.dark-mode input[type="file"] {
    background: var(--tmis-surface);
    color: var(--tmis-text);
    border-color: var(--tmis-border);
}

    html.dark-mode input[type="file"]::file-selector-button {
        background: var(--tmis-surface-muted);
        color: var(--tmis-text);
        border-color: var(--tmis-border);
    }
/* =========================================================
   DARK MODE — FORM / ASSIGNMENT CARDS
   Fixes:
   - Primary Department & Role
   - Additional Department Assignments
   - Widget Permissions
   ========================================================= */

html.dark-mode .card,
html.dark-mode .form-section,
html.dark-mode .assignment-card,
html.dark-mode .widget-permissions-card {
    background: var(--tmis-surface);
    border: 1px solid var(--tmis-border);
    color: var(--tmis-text);
}

    /* Headings inside those cards */
    html.dark-mode .card h2,
    html.dark-mode .card h3,
    html.dark-mode .form-section h2,
    html.dark-mode .form-section h3 {
        color: var(--tmis-text-strong);
    }

    /* Descriptions / helper text */
    html.dark-mode .card p,
    html.dark-mode .form-section p {
        color: var(--tmis-text-muted);
    }

/* Table headers inside assignments */
html.dark-mode table thead th {
    background: var(--tmis-surface-muted);
    color: var(--tmis-text-strong);
    border-color: var(--tmis-border);
}

/* Table rows */
html.dark-mode table tbody td {
    background: transparent;
    color: var(--tmis-text);
    border-color: var(--tmis-border);
}

/* Selects & inputs */
html.dark-mode select,
html.dark-mode input,
html.dark-mode textarea {
    background: var(--tmis-input-bg);
    color: var(--tmis-text);
    border-color: var(--tmis-border);
}

/* Buttons inside cards */
html.dark-mode .card .btn-outline-primary {
    color: var(--tmis-primary);
    border-color: var(--tmis-primary);
}

    html.dark-mode .card .btn-outline-primary:hover {
        background: var(--tmis-primary);
        color: #fff;
    }

/* =============================================================
   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;
    }

    /* Future-ready state hooks */
    .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;
}



