@import url('variables.css');

/* Z-Index Scale - Complements Bootstrap */
:root {
    --z-base: 1;
    --z-dropdown: 1000;        /* Matches Bootstrap */
    --z-sticky: 1010;          /* Safe range - below Bootstrap's 1020 sticky */
    --z-fixed: 1035;           /* Safe range - above Bootstrap's 1030 navbar */
    --z-offcanvas: 1045;       /* Matches Bootstrap */
    --z-backdrop: 1050;        /* Matches Bootstrap */
    --z-modal: 1055;           /* Matches Bootstrap */
    --z-popover: 1070;         /* Matches Bootstrap */
    --z-tooltip: 1080;         /* Matches Bootstrap */
    --z-toast: 1090;           /* Matches Bootstrap */
    --z-notification: 1100;    /* Above Bootstrap components */
    --z-debug: 2147483647;     /* Critical errors/debugging */
}

h1:focus {
    outline: none;
}

.valid.modified:not([type=checkbox]) {
    outline: 1px solid #26b050;
}

.invalid {
    outline: 1px solid #e50000;
}

.validation-message {
    color: #e50000;
}

.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."
}

.darker-border-checkbox.form-check-input {
    border-color: #929292;
}

hr.theme {
    border: 2px solid var(--primary-color);
    opacity: unset
}

.nav-btn {
    background-color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: white !important;
    transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out;
}

.nav-btn:hover, .nav-btn:focus {
    background-color: var(--primary-hover-color) !important;
    border-color: var(--primary-hover-color) !important;
    color: white !important;
}

.nav-btn:active {
    background-color: var(--primary-active-color) !important;
    border-color: var(--primary-active-color) !important;
    color: white !important;
}

.nav-btn-disabled {
    background-color: var(--primary-disabled-color) !important;
    border-color: var(--primary-disabled-color) !important;
    color: #f0f0f0 !important;
    transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out;
}

/* Navigation button sizing - essential for layout */
.d-flex .btn {
    flex: 0 1 auto;
    min-width: 85px;
    max-width: 120px;
    height: auto;
    align-self: flex-start;
}

/*
    https://www.bram.us/2020/03/01/prevent-content-from-being-hidden-underneath-a-fixed-header-by-using-scroll-margin-top/
    Updated to account for sticky header + sticky nav buttons on mobile/tablet list view
*/
* {
    scroll-snap-margin-top: 7.5rem; /* Required to work in Safari browser. */
    scroll-margin-top: 7.5rem;
}

/* Ensures consistent height for nav button title area whether title is present or not */
.min-h-2 {
    min-height: 2rem !important;
}

/*
    Additional Bootstrap rules for the Kathisma table.
    https://getbootstrap.com/docs/5.3/layout/breakpoints/#available-breakpoints
*/
@media (min-width: 992px) {
    .w-lg-75 {
        width: 75% !important;
    }
}
