.swal2-container {
    z-index: 10000;
}

h1:focus {
    outline: none;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50300;
}

.validation-message {
    color: #e50300;
}

.blazor-error-boundary {
    background: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNTYiIGhlaWdodD0iNDkiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIG92ZXJmbG93PSJoaWRkZW4iPjxkZWZzPjxjbGlwUGF0aCBpZD0iY2xpcDAiPjxyZWN0IHg9IjIzNSIgeT0iNTEiIHdpZHRoPSI1NiIgaGVpZ2h0PSI0OSIvPjwvY2xpcFBhdGg+PC9kZWZzPjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMCkiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0yMzUgLTUxKSI+PHBhdGggZD0iTTI2My41MDYgNTFDMjY0LjcxNyA1MSAyNjUuODEzIDUxLjQ4MzcgMjY2LjYwNiA1Mi4yNjU4TDI2Ny4wNTIgNTIuNzk4NyAyNjcuNTM5IDUzLjYyODMgMjkwLjE4NSA5Mi4xODMxIDI5MC41NDUgOTIuNzk1IDI5MC42NTYgOTIuOTk2QzI5MC44NzcgOTMuNTEzIDI5MSA5NC4wODE1IDI5MSA5NC42NzgyIDI5MSA5Ny4wNjUxIDI4OS4wMzggOTkgMjg2LjYxNyA5OUwyNDAuMzgzIDk5QzIzNy45NjMgOTkgMjM2IDk3LjA2NTEgMjM2IDk0LjY3ODIgMjM2IDk0LjM3OTkgMjM2LjAzMSA5NC4wODg2IDIzNi4wODkgOTMuODA3MkwyMzYuMzM4IDkzLjAxNjIgMjM2Ljg1OCA5Mi4xMzE0IDI1OS40NzMgNTMuNjI5NCAyNTkuOTYxIDUyLjc5ODUgMjYwLjQwNyA1Mi4yNjU4QzI2MS4yIDUxLjQ4MzcgMjYyLjI5NiA1MSAyNjMuNTA2IDUxWk0yNjMuNTg2IDY2LjAxODNDMjYwLjczNyA2Ni4wMTgzIDI1OS4zMTMgNjcuMTI0NSAyNTkuMzEzIDY5LjMzNyAyNTkuMzEzIDY5LjYxMDIgMjU5LjMzMiA2OS44NjA4IDI1OS4zNzEgNzAuMDg4N0wyNjEuNzk1IDg0LjAxNjEgMjY1LjM4IDg0LjAxNjEgMjY3LjgyMSA2OS43NDc1QzI2Ny44NiA2OS43MzA5IDI2Ny44NzkgNjkuNTg3NyAyNjcuODc5IDY5LjMxNzkgMjY3Ljg3OSA2Ny4xMTgyIDI2Ni40NDggNjYuMDE4MyAyNjMuNTg2IDY2LjAxODNaTTI2My41NzYgODYuMDU0N0MyNjEuMDQ5IDg2LjA1NDcgMjU5Ljc4NiA4Ny4zMDA1IDI1OS43ODYgODkuNzkyMSAyNTkuNzg2IDkyLjI4MzcgMjYxLjA0OSA5My41Mjk1IDI2My41NzYgOTMuNTI5NSAyNjYuMTE2IDkzLjUyOTUgMjY3LjM4NyA5Mi4yODM3IDI2Ny4zODcgODkuNzkyMSAyNjcuMzg3IDg3LjMwMDUgMjY2LjExNiA4Ni4wNTQ3IDI2My41NzYgODYuMDU0N1oiIGZpbGw9IiNGRkU1MDAiIGZpbGwtcnVsZT0iZXZlbm9kZCIvPjwvZz48L3N2Zz4=) no-repeat 1rem/1.8rem, #b32121;
    padding: 1rem 1rem 1rem 3.7rem;
    color: white;
}

    .blazor-error-boundary::after {
        content: "An error has occurred."
    }


.show-lower-border {
    border-end-start-radius: 0;
}

/* Autocomplete starts here */


.input-container {
    position: relative;
}

    .input-container input {
        border-start-end-radius: 0px;
        border-end-end-radius: 0px;
        border-start-start-radius: var(--input-border-radius);
        border-end-start-radius: var(--input-border-radius);
        padding-right:24px;
    }

    .input-container input.show-lower-border {        
        border-end-start-radius: 0;
    }

        .input-container input:disabled {
            background-color: #f5f5f5;
            color: #9e9e9e;
        }

    .input-container button.clear-value {
        position: absolute;
        right: 4px;
        top:0;
        height: 100%;
        border: none;
        color: #d3d3d3;
        padding: 4px;
        background-color: transparent;
    }

    .input-container ul {
        position: absolute;
        z-index: 1000; /* Ensures it appears above other elements */
        background-color: white;
        width: 100%; /* Match the width of the input */
        max-height: 300px; /* Optional: Limit the height and make it scrollable */
        overflow-y: auto;
        list-style-type: none;
        padding: 0;
        margin: 0;
        border: var(--border-stroke) solid var(--border-color);
        border-top: none;
        border-end-start-radius: var(--input-border-radius);
        border-end-end-radius: var(--input-border-radius);
    }

        .input-container ul li {
            border-bottom: var(--border-stroke) solid var(--border-color);
            background-color: white;
            padding-top: 4px;
            padding-bottom: 4px;
            cursor: pointer;
            user-select: none;
            padding-left: 8px;
            padding-right: 8px;
        }

            .input-container ul li:first-child {
                border-top: 0;
            }

            .input-container ul li:last-child {
                border-bottom: 0;
            }

            .input-container ul li:hover {
                background-color: #e2e6ea;
            }


.show-options {
    
}

    .show-options span.rotate-show {
        animation: rotate-combobox-button-show 0.5s forwards;
    }

    .show-options span.rotate-hide {
        animation: rotate-combobox-button-hide 0.5s forwards;
    }



div.autocomplete-input {
    display: flex;
    flex-direction: row;
    width: 100%;
}

    div.autocomplete-input button {
        border-start-end-radius: var(--input-border-radius);
        border-end-end-radius: var(--input-border-radius);
        border: var(--border-stroke) solid var(--border-color);
        border-left: 0;
        display: flex;
        align-items: center;
    }


.dropdown-box-container {
    display: flex;
    flex-direction: row;
    --dropdown-border-stroke: 1px;
    --button-radius: 4px;
    --dropdown-border-color: #d3d3d3;
}

    .dropdown-box-container input {
        border-start-end-radius: 0px;
        border-end-end-radius: 0px;
        cursor: pointer;
    }

        .dropdown-box-container input.show-lower-border {
            border-end-start-radius: 0;
        }

    .dropdown-box-container ul {
        position: absolute;
        z-index: 1000; /* Ensures it appears above other elements */
        background-color: white;
        width: 100%; /* Match the width of the input */
        max-height: 300px; /* Optional: Limit the height and make it scrollable */
        overflow-y: auto;
        list-style-type: none;
        padding: 0;
        margin: 0;
        border: var(--dropdown-border-stroke) solid var(--dropdown-border-color);
        border-top: none;
        border-end-start-radius: var(--button-radius);
        border-end-end-radius: var(--button-radius);
    }

        .dropdown-box-container ul li {
            border-bottom: var(--dropdown-border-stroke) solid var(--dropdown-border-color);
            cursor: pointer;
            user-select: none;
            padding: 5px 10px 5px 10px;
        }

            .dropdown-box-container ul li:first-child {
                border-top: 0;
            }

            .dropdown-box-container ul li:last-child {
                border-bottom: 0;
            }

            .dropdown-box-container ul li:hover {
                background-color: #e2e6ea;
            }

.dropdown-checkbox {
    display: flex;
    position: relative;
    flex-direction: row;
    align-items: center;
    padding-left: 24px;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

    .dropdown-checkbox label {
        margin-left: 6px;
    }

    /* Hide the browser's default checkbox */
    .dropdown-checkbox input {
        position: absolute;
        opacity: 0;
        cursor: pointer;
        height: 0;
        width: 0;
    }

    /* On mouse-over, add a grey background color */
    .dropdown-checkbox:hover input ~ span {
        background-color: #ccc;
    }

    /* When the checkbox is checked, add a blue background */
    .dropdown-checkbox input:checked ~ span {
        background-color: #2196F3;
    }

        /* Show the checkmark when checked */
        .dropdown-checkbox input:checked ~ span:after {
            display: block;
        }

    /* Style the checkmark/indicator */
    .dropdown-checkbox span:after {
        left: 0.56em;
        top: 0.125em;
        width: 0.45em;
        height: 0.93em;
        border: solid white;
        -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
        transform: rotate(45deg);
        border-width: 0 var(--dropdown-border-stroke) var(--dropdown-border-stroke) 0;
    }

    /* Style the checkmark/indicator */
    .dropdown-checkbox span {
        position: absolute;
        top: 0;
        left: 0;
        height: 1.5em;
        width: 1.5em;
        background-color: #eee;
    }

        /* Create the checkmark/indicator (hidden when not checked) */
        .dropdown-checkbox span:after {
            content: "";
            position: absolute;
            display: none;
        }

.form-control.form-control-small-size {
    height: 2rem;
    min-height: 2rem;
}

@keyframes rotate-combobox-button-show {
    0% {
        -webkit-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        transform: rotate(0deg);
    }

    100% {
        -webkit-transform: rotate(180deg);
        -ms-transform: rotate(180deg);
        transform: rotate(180deg);
    }
}

@keyframes rotate-combobox-button-hide {
    0% {
        -webkit-transform: rotate(180deg);
        -ms-transform: rotate(180deg);
        transform: rotate(180deg);
    }

    100% {
        -webkit-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        transform: rotate(0deg);
    }
}

/* Autocomplete ends here */

.dropdown {
    /*the container must be positioned relative:*/
    position: relative;
    display: inline-block;
    z-index: 20;
    top: 0.5rem;
}

    .dropdown:focus-within {
        border-color: blue;
    }

.dropdown-items {
    position: absolute;
    top: 0rem;
    border: var(--border-stroke) solid #d4d4d4;
    border-bottom: none;
    border-top: none;
    z-index: 30;
    overflow-y: auto;
    max-height: 50vh;
    max-width: 15vw;
    margin-top: 1vh;
}

    .dropdown-items div {
        width: 100%;
        padding: 10px;
        cursor: pointer;
        background-color: #fff;
        border-bottom: var(--border-stroke) solid #d4d4d4;
    }

    .dropdown-items label {
        margin-left: 4px;
    }

.content-fit {
    min-height: calc(100vh - 3.5rem);
    max-height: calc(100vh - 3.5rem);
}

@media (min-width: 641px) {
    .content-fit {
        max-width: calc(100vw - 275px);
    }
}

.main-container {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 3.5rem);
}

@media (min-width: 641px) {
    .main-container {
        max-width: calc(100vw - 275px);
        height: calc(100vh - 7rem);
    }
}

.main-container {
    display: flex;
    flex-direction: column;
    height: calc(100vh - 3.5rem);
}

@media (min-width: 641px) {
    .main-container {
        max-width: calc(100vw - 275px);
        height: calc(100vh - 7rem);
    }
}

.main-container .title {
    display: flex;
    flex-direction: row;
    /*flex: 0;*/
}

.main-container .header {
    display: flex;
    flex-direction: column;
    /*flex: 0;*/
}

.main-container .main-body {
    flex: 1 1 auto;
    overflow: auto;
}

.main-container .footer {
    display: flex;
    flex-direction: column;
}

/* Start custom checkbox */

/* The container for checkbox */
.checkbox-v1 {
    display: flex;
    position: relative;
    flex-direction: row;
    align-items: center;
    padding-left: 24px;
    margin-bottom: 8px;
    height: 24px;
    cursor: pointer;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

    .checkbox-v1 label {
        margin-left: 6px;
    }

    /* Hide the browser's default checkbox */
    .checkbox-v1 input {
        position: absolute;
        opacity: 0;
        cursor: pointer;
        height: 0;
        width: 0;
    }

    /* On mouse-over, add a grey background color */
    .checkbox-v1:hover input ~ span {
        background-color: #ccc;
    }

    /* When the checkbox is checked, add a blue background */
    .checkbox-v1 input:checked ~ span {
        background-color: #2196F3;
    }

        /* Show the checkmark when checked */
        .checkbox-v1 input:checked ~ span:after {
            display: block;
        }

    /* Style the checkmark/indicator */
    .checkbox-v1 span:after {
        left: 9px;
        top: 2px;
        width: 7.5px;
        height: 15px;
        border: solid white;
        border-width: 0 var(--border-stroke-strong) var(--border-stroke-strong) 0;
        -webkit-transform: rotate(45deg);
        -ms-transform: rotate(45deg);
        transform: rotate(45deg);
    }

    /* Style the checkmark/indicator */
    .checkbox-v1 span {
        position: absolute;
        top: 0;
        left: 0;
        height: 24px;
        width: 24px;
        background-color: #eee;
    }

        /* Create the checkmark/indicator (hidden when not checked) */
        .checkbox-v1 span:after {
            content: "";
            position: absolute;
            display: none;
        }

/* End custom checkbox */

/* Start dropdown check */
.dropdown-check-list {
    display: inline-block;
    position: relative;
}

    .dropdown-check-list .anchor {
        position: relative;
        cursor: pointer;
        user-select: none;
        display: inline-block;
        padding: 5px 50px 5px 10px;
        border: var(--border-stroke) solid var(--border-color);
        border-radius: var(--input-border-radius);
    }

        .dropdown-check-list .anchor:after {
            position: absolute;
            content: "";
            border-left: var(--border-stroke-strong) solid var(--border-color);
            border-top: var(--border-stroke-strong) solid var(--border-color);
            padding: 5px;
            right: 15px;
            top: 20%;
            -moz-transform: rotate(-135deg);
            -ms-transform: rotate(-135deg);
            -o-transform: rotate(-135deg);
            -webkit-transform: rotate(-135deg);
            transform: rotate(-135deg);
        }

        .dropdown-check-list .anchor:active:after {
            right: 8px;
            top: 21%;
        }


    .dropdown-check-list .anchor-white {
        position: relative;
        cursor: pointer;
        user-select: none;
        display: inline-block;
        padding: 5px 50px 5px 10px;
        border: var(--border-stroke) solid var(--border-color);
    }

        .dropdown-check-list .anchor-white:after {
            position: absolute;
            content: "";
            border-left: var(--border-stroke-strong) solid white;
            border-top: var(--border-stroke-strong) solid white;
            padding: 5px;
            right: 10px;
            top: 20%;
            -moz-transform: rotate(-135deg);
            -ms-transform: rotate(-135deg);
            -o-transform: rotate(-135deg);
            -webkit-transform: rotate(-135deg);
            transform: rotate(-135deg);
        }

        .dropdown-check-list .anchor-white:active:after {
            right: 8px;
            top: 21%;
        }


    .dropdown-check-list ul.items {
        position: absolute;
        display: none;
        top: 30px;
        padding: 0px;
        margin: 0;
        border: var(--border-stroke) solid var(--border-color);
        border-top: none;
        text-align: left;
        background-color: white;
        border-radius: var(--input-border-radius);
    }

        .dropdown-check-list ul.items li {
            padding: 0.25rem;
            list-style: none;
            user-select: none;
        }

            .dropdown-check-list ul.items li:first-child {
                margin-top: 8px;
            }

            /* The container for checkbox */
            .dropdown-check-list ul.items li div {
                display: block;
                position: relative;
                padding-left: 24px;
                margin-bottom: 8px;
                cursor: pointer;
                -webkit-user-select: none;
                -moz-user-select: none;
                -ms-user-select: none;
                user-select: none;
            }

                /* Hide the browser's default checkbox */
                .dropdown-check-list ul.items li div input {
                    position: absolute;
                    opacity: 0;
                    cursor: pointer;
                    height: 0;
                    width: 0;
                }

                /* On mouse-over, add a grey background color */
                .dropdown-check-list ul.items li div:hover input ~ span {
                    background-color: #ccc;
                }

                /* When the checkbox is checked, add a blue background */
                .dropdown-check-list ul.items li div input:checked ~ span {
                    background-color: #2196F3;
                }

                    /* Show the checkmark when checked */
                    .dropdown-check-list ul.items li div input:checked ~ span:after {
                        display: block;
                    }

                /* Style the checkmark/indicator */
                .dropdown-check-list ul.items li div span:after {
                    left: 6px;
                    top: 2px;
                    width: 5px;
                    height: 10px;
                    border: solid white;
                    border-width: 0 var(--border-stroke-strong) var(--border-stroke-strong) 0;
                    -webkit-transform: rotate(45deg);
                    -ms-transform: rotate(45deg);
                    transform: rotate(45deg);
                }

                /* Style the checkmark/indicator */
                .dropdown-check-list ul.items li div span {
                    position: absolute;
                    top: 0;
                    left: 0;
                    height: 16px;
                    width: 16px;
                    background-color: #eee;
                }

                    /* Create the checkmark/indicator (hidden when not checked) */
                    .dropdown-check-list ul.items li div span:after {
                        content: "";
                        position: absolute;
                        display: none;
                    }

            .dropdown-check-list ul.items li span {
                user-select: contain;
            }

    .dropdown-check-list.visible .anchor {
        color: #0094ff;
    }

    .dropdown-check-list.visible .items {
        display: block;
    }

/* End dropdown check */

/* Start table */

.table-app-container {
    overflow: unset;
    flex: 1 1 auto;
    overflow: auto;
}

.table-app {
    border-collapse: separate;
    border-spacing: 0;
    font-size: 0.85rem;
    border: var(--table-border-stroke) solid var(--table-border-color);
}

    .table-app thead {
        position: sticky;
        top: 0;
        z-index: 6;
    }

        .table-app thead tr {
            top: 0;
            text-align: center;
            text-overflow: ellipsis;
            overflow: hidden;
            word-wrap: break-word;
        }

            .table-app thead tr:not(:first-child) th {
                border-top: none;
            }

            .table-app thead tr th {
                text-align: center;
                font-weight: 500;
                user-select: none;
                vertical-align: middle;
                border: var(--table-border-stroke) solid var(--table-border-color);
                white-space: normal;
                word-wrap: break-word;
                background-color: var(--app-sub-color);
                padding: 6px;
            }

            .table-app thead tr:not(.filter-row) th {
                /*resize: horizontal;
                overflow: auto;*/
                color: white;
            }
            /*
                .table-app thead tr th div {
                    text-overflow: ellipsis;
                    white-space: nowrap;
                    overflow: hidden;
                }
                */

            .table-app thead tr:nth-child(2):not(.filter-row) {
                font-size: 0.8rem;
            }

            .table-app thead tr:nth-child(n+3):not(.filter-row) {
                font-size: 0.75rem;
            }

            .table-app thead tr th.row-1 {
                background-color: #7CB342;
            }

            .table-app thead tr th.row-2 {
                background-color: #FB8C00;
            }

            .table-app thead tr.filter-row th {
                background-color: white;
                text-align: center;
            }

                .table-app thead tr.filter-row th input[type="text"],
                .table-app thead tr.filter-row th select {
                    padding: 5px;
                    border: var(--border-stroke) solid var(--border-color);
                    border-radius: var(--border-radius);
                    width: 100%;
                    box-sizing: border-box;
                }

    .table-app tbody tr td {
        background-color: #ffffff;
    }

    .table-app tbody tr:nth-child(even) td {
        background-color: #f5f5f5;
    }

    .table-app tbody tr td.row-1 {
        background-color: #98FF98;
    }

    .table-app tbody tr:nth-child(even) td.row-1 {
        background-color: #7FFF7F;
    }

    .table-app tbody tr td.row-2 {
        background-color: #FFDAB9;
    }

    .table-app tbody tr:nth-child(even) td.row-2 {
        background-color: #FFB07F;
    }

    .table-app tbody tr td {
        text-overflow: ellipsis;
        overflow: hidden;
        word-wrap: break-word;
        white-space: nowrap;
        max-width: 10vw;
        border-bottom: var(--table-border-stroke) solid var(--table-border-color);
        border-right: var(--table-border-stroke) solid var(--table-border-color);
        padding: 4px;
    }

        .table-app tbody tr td:first-child {
            border-left: var(--table-border-stroke) solid var(--table-border-color);
        }

        .table-app tbody tr td input,
        .table-app tbody tr td select {
            padding: 5px;
            border: var(--table-input-border-stroke) solid var(--table-input-border-color);
            border-radius: var(--table-input-border-radius);
            width: 100%;
            box-sizing: border-box;
        }

        .table-app tbody tr td .dropdown-box-container {
            --dropdown-border-stroke: var(--table-input-border-stroke);
            --button-radius: var(--table-input-border-radius);
            --dropdown-border-color: var(--table-input-border-color);
        }

    .table-app tbody tr.filter-row {
        text-align: center;
        font-size: 0.65rem;
        position: sticky;
        top: 0;
        left: 0;
        z-index: 1;
    }

        .table-app tbody tr.filter-row td input[type="text"] {
            width: 90%;
        }

/* End table */

.button-container {
    background-color: transparent;
}

    .button-container button:not(:first-child) {
        margin-left: 12px;
    }

.button-cancel, .button-action, button-info, .button-save, .button-cancel-sm, .button-action-sm, button-info-sm, .button-save-sm {
    border: thin;
    border-radius: 8px;
    border-color: #BDBDBD;
    color: white;
}

.button-cancel, .button-info, .button-action, .button-save {
    min-height: 48px;
    min-width: 96px;
}

.button-cancel-sm, .button-info-sm, .button-action-sm, .button-save-sm {
    min-height: 24px;
    min-width: 48px;
}

.button-cancel, .button-cancel-sm {
    background-color: red;
}

    .button-cancel:hover, .button-cancel-sm:hover {
        background-color: darkred;
    }

.button-info, .button-info-sm {
    background-color: yellow;
}

    .button-info:hover, .button-info:hover {
        background-color: yellowgreen;
    }

.button-action, .button-action-sm {
    background-color: #2196F3;
}

    .button-action:hover, .button-action-sm:hover {
        background-color: #1976D2;
    }

.button-save, .button-save-sm {
    background-color: #8BC34A;
}

    .button-save:hover, .button-save-sm:hover {
        background-color: #689F38;
    }

.opacitiy-show {
    opacity: 0.2;
}

/* Cell edits start */

.text-changed:focus input {
    color: black;
    background-color: white;
}

.text-changed input {
    background-color: #FFEB3B;
    color: red;
}


.nav-overflow-wrapper {
    overflow-x: auto;
    white-space: nowrap;
}

    .nav-overflow-wrapper .nav-tabs {
        flex-wrap: nowrap;
    }

/* Cell edits end */
/* Pictures here */
.bi {
    display: inline-block;
    width: 1.25rem;
    height: 1.25rem;
    background-size: cover;
    cursor: pointer;
}

    .bi.small {
        width: 1rem;
        height: 1rem;
    }

    .bi-small {
        width: 1rem;
        height: 1rem;
    }

    .bi.large {
        width: 2rem;
        height: 2rem;
    }

        .bi.large:hover {
            background-color: #e2e6ea;
            border-radius: 4px;
        }


.green-bill {
    background-color: #81C784FF;
}

.yellow-bill {
    background-color: #FFF176FF;
}


.quickgrid-sticky-header thead th {
    position: sticky;
    top: 0;
}

.quickgrid {
    color: white;
}