.navbar-light .navbar-nav .nav-link {
    color: black;
}

/*Configure Authenticator App page*/
.qrCode {
    border: 4px solid white; /* White border */
    border-radius: 10px; /* Rounded corners */
    padding: 10px; /* Inner spacing */
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.2); /* Subtle shadow for depth */
}

/*Edit Page*/
.no-sort::after {
    display: none !important;
}

.no-sort::before {
    display: none !important;
}

.no-sort {
    pointer-events: none !important;
    cursor: default !important;
}

/*PSD Page*/
.nav-centered {
    float: none;
    position: absolute;
    top: 50%;
    left: 40%;
}

.table th, .table td {
    padding: 5px !important;
}

.td-padding {
    padding-left: 30px !important;
}

.vertAlign {
    vertical-align: middle !important;
    align-content: center !important;
    align-items: center !important;
}

.tabNoClick {
    pointer-events: none;
}

table.dataTable tbody th, table.dataTable tbody td {
    padding: 1px 1px !important;
}

.tdAlignment {
    vertical-align: middle !important;
}

.chk-edit {
    text-align: center !important;
}

.td-idx-c0 { /*Permission*/
    vertical-align: middle !important;
    text-align: center !important;
}

.td-idx-c1 { /*AppName*/
    vertical-align: middle !important;
}

.td-idx-c2 { /*Function*/
    vertical-align: middle !important;
}

.td-idx-c3 { /*Description*/
    vertical-align: middle !important;
    text-align: center !important;
}

.btn-idx-size {
    width: 135px !important;
    height: 31px !important;
}

.sr-only {
    color: black !important;
    background-color: white !important;
}

.numInput {
    color: black !important;
    background-color: white !important;
}

.flatpickr-monthDropdown-months {
    color: black !important;
    background-color: white !important;
}

.flatpickr-monthDropdown-month {
    color: black !important;
    background-color: white !important;
}

.banner-main {
    text-align: center;
    background-color: #046b99;
    background-image: url("https://www.transparenttextures.com/patterns/60-lines.png");
    /* This is mostly intended for prototyping; please download the pattern and re-host for production environments. Thank you! */
    color: #fff;
    width: 100%;
    padding: 15px 0 20px 0;
    position: relative;
    background-position: center;
    text-shadow: -1px 0 black, 0 1px black, 1px 0 black, 0 -1px black;
    /*background-repeat: no-repeat;*/
    /*background-image: url('../images/background-primary-neutral.jpg');*/
    /*background-size: cover;*/
}

.first-level-link > span {
    color: #9fc7da;
    display: block;
    font-size: 32px;
}

.et_font_icon li[class^=""]::before, .et_font_icon li[class*=""]::before {
    font-family: 'CaGov' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.banner-main-index {
    text-align: center;
    color: #fff;
    width: 100%;
    padding: 15px 0 20px 0;
    position: relative;
    background-position: center;
}

.home-logo {
    position: relative;
    top: 5px;
    right: 10px;
}

.nav-pills > li > a {
    border: unset;
}

.field-validation-valid {
    display: none;
}

@media only screen and (max-width: 40em) {
    #appsSection {
        padding-left: unset !important;
        padding-right: unset !important;
        margin-left: unset !important;
        margin-right: unset !important;
    }

    #appsContainer {
        padding-left: unset !important;
        padding-right: unset !important;
        margin-left: unset !important;
        margin-right: unset !important;
    }

    .first-level-link > span {
        display: none;
    }

    thead th:not(:first-child) {
        display: none;
    }

    td, th {
        display: block;
    }

        td[data-th]:before {
            content: attr(data-th);
        }
}

@keyframes donut-spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

.donut {
    display: none;
    margin: 0 auto;
    border: 4px solid rgba(0, 0, 0, 0.1);
    border-left-color: #7983ff;
    border-radius: 50%;
    width: 50px;
    height: 50px;
    animation: donut-spin 1.2s linear infinite;
}

.modal-backdrop {
    opacity: 0.8 !important;
}

.modal-confirm {
    color: #636363;
}

    .modal-confirm .modal-content {
        padding: 20px;
        border-radius: 5px;
        border: none;
    }

    .modal-confirm .modal-header {
        border-bottom: none;
        position: relative;
    }

    .modal-confirm h4 {
        text-align: center;
        font-size: 26px;
        margin: 30px 0 -15px;
    }

    .modal-confirm .form-control, .modal-confirm .btn {
        min-height: 40px;
        border-radius: 3px;
    }

    .modal-confirm .close {
        position: absolute;
        top: -5px;
        right: -5px;
    }

    .modal-confirm .modal-footer {
        border: none;
        text-align: center;
        border-radius: 5px;
        font-size: 13px;
    }

    .modal-confirm .icon-box {
        color: #fff;
        position: absolute;
        margin: 0 auto;
        left: 0;
        right: 0;
        top: -70px;
        width: 95px;
        height: 95px;
        border-radius: 50%;
        z-index: 9;
        background: #82ce34;
        padding: 15px;
        text-align: center;
        box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.1);
    }

        .modal-confirm .icon-box i {
            font-size: 58px;
            position: relative;
            top: 3px;
        }

    .modal-confirm.modal-dialog {
        margin-top: 80px;
    }

    .modal-confirm .btn {
        color: #fff;
        border-radius: 4px;
        background: #82ce34;
        text-decoration: none;
        transition: all 0.4s;
        line-height: normal;
        border: none;
    }

        .modal-confirm .btn:hover, .modal-confirm .btn:focus {
            background: #6fb32b;
            outline: none;
        }

.btn-size-index {
    height: 31px !important;
    width: 107px !important;
}

.only-csv-allowed {
    font-weight: bold;
    font-size: 2em;
}

.disabled-link {
    pointer-events: none;
    opacity: 0.6;
    cursor: not-allowed;
    text-decoration: none;
}

.loader {
    border: 8px solid #f3f3f3; /* Light grey */
    border-top: 8px solid #3498db; /* Blue */
    border-radius: 50%;
    width: 40px;
    height: 40px;
    animation: spin 2s linear infinite;
    transition: opacity 0.5s ease-in;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}