html, body {
    font-family: system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans","Liberation Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";
    overscroll-behavior: contain;
}

a, .btn-link {
    color: #006bb7;
}

.btn-primary {
    color: #fff;
    background-color: #1b6ec2;
    border-color: #1861ac;
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

.content {
    padding-top: 1.1rem;
}

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() 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;
}

.noSelect {
    -webkit-user-select: none; /* Safari */
    -moz-user-select: none; /* Firefox */
    -ms-user-select: none; /* Internet Explorer/Edge */
    user-select: none; /* Non-prefixed version, currently supported by Chrome, Opera and Safari */
    cursor: default; /* Replaces the text cursor with the default arrow cursor */
}

.blazored-typeahead {
    background-color: #fff;
}


.blazored-typeahead__input-icon {
    background-color: #fff; /* Set the background color to white */
    border: 1px solid #ccc; /* Add a border color */
    border-radius: 5px; /* Optional: add border radius for rounded corners */
    padding: 5px; /* Adjust padding as needed */
    cursor: pointer; /* Change cursor to pointer */
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: 2.5rem;
    min-width: 2.5rem;
}

.blazored-typeahead__controls {
    width: 100%;
}

.blazored-typeahead__input-mask, .blazored-typeahead__clear {
    background-color: #fff;
    color: #000;
    padding: 5px;
}

.blazored-typeahead__input-mask {
    border: 1px solid #ccc;
    border-radius: 5px;
}

.blazored-typeahead__down-arrow path {
    fill: #000;
}

.blazored-typeahead__input-icon:hover {
    background-color: #f0f0f0; /* Change background color on hover */
    border-color: #bbb; /* Change border color on hover */
}

/* Optional: Additional styling for the input field */
.blazored-typeahead__input {
    border: 1px solid #ccc; /* Add a border color to the input */
    border-radius: 5px; /* Optional: add border radius for rounded corners */
    padding: 5px; /* Adjust padding as needed */
}

.blazored-typeahead__results {
    max-height: 14rem; /* Set the maximum height of the dropdown */
    overflow-y: auto; /* Enable vertical scrolling */
}

.btq-primary {
    color: #0a3c41
}

.btq-btn-primary {
    color: white;
    background-color: #0a3c41;
    border-color: #0a3c41;
}

.btq-btn-primary:hover {
    color: black;
    background-color: #bedcd2;
    border-color: #0a3c41;
}

/* Modern scrollbar styles */
::-webkit-scrollbar {
    width: 8px;
    height: 8px;
}

::-webkit-scrollbar-thumb {
    background-color: #888;
    border-radius: 4px;
    border: 2px solid #555;
}

    ::-webkit-scrollbar-thumb:hover {
        background-color: #555;
    }

::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 4px;
}

.nav-scrollable {
    overflow-y: auto;
}

/* For Firefox */
* {
    scrollbar-width: thin;
    scrollbar-color: #888 #f1f1f1;
}

/* For other browsers */
* {
    scrollbar-width: thin;
    scrollbar-color: #888 #f1f1f1;
}

.table-tenant thead th {
    background-color: var(--primary);
    color: white;
    padding-left: 1rem;
    font-weight: 600 !important;
}

.table-hover tbody tr:hover td, .table-hover tbody tr:hover th {
    background-color: var(--primary-hover) !important;
    box-shadow: unset !important;
}

.table-tenant tbody td {
    padding-left: 1rem;
    vertical-align: middle;
}

.material-icons {
    vertical-align: middle;
}

.clickable {
    cursor: pointer !important;
}


.btn-tenant-primary {
    color: white; /* Use primary color for text */
    background-color: var(--primary); /* Use secondary color for background */
    border-color: var(--secondary); /* Use secondary color for border */
}

    .btn-tenant-primary:hover {
        color: white;
        background-color: var(--secondary-dark); /* Darker shade for hover state */
        border-color: var(--secondary-dark); /* Darker border for hover state */
    }

    .btn-tenant-primary:focus, .btn-tenant-primary.focus {
        box-shadow: 0 0 0 0.2rem rgba(33, 150, 243, 0.5); /* Custom focus ring, adjust color using variables if needed */
    }

    .btn-tenant-primary:active, .btn-tenant-primary.active {
        background-color: var(--secondary-dark); /* Active state background */
        border-color: var(--secondary-dark); /* Active state border */
    }

    .btn-tenant-primary.disabled, .btn-tenant-primary:disabled {
        color: black; /* Optional: slightly lighter text to show it's disabled */
        background-color: var(--disabled-background); /* Disabled state background */
        border-color: var(--disabled-border); /* Disabled state border */
        opacity: 0.65; /* Disabled appearance */
    }

.icon-align-middle {
    font-size: 24px;
    vertical-align: middle;
    transform: translateY(-2px);
}
/* Style to increase the size of the checkbox */
.form-check-input-custom {
 
    border: 1px solid #aaa;
    border-radius: 3px;
}


/* Style for the transfer amount button */
.transfer-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.8rem;
    /*  font-size: 0.9rem; */
    border: none;
    border-radius: 50%;
    cursor: pointer;
    transition: background-color 0.3s ease;
    width: 2px; /* Smaller width */
    height: 2px; /* Smaller height */
}

    .transfer-button.transferred {
        background-color: #28a745 !important; /* Success green */
    }

    .transfer-button span.material-symbols-outlined {
        font-size: 0.9rem; /* Smaller icon size */
    }
.amount-cell {
    display: flex;
   /* justify-content: space-between;*/
    justify-content: flex-end;  

    align-items: center;
    width: 100%;
}

.amount {
    flex-grow: 1;
    text-align: right;
    margin-right: 10px; 
}
amount-approved-input {
    text-align: right; 
}

.amount-not-set {
    flex-grow: 1;
    text-align: center;
   
}

/* Specific Select Styling */
select.form-select {
    border: 1px solid #bbb !important; /* Lighter grey */
    border-radius: 4px;
    padding: 0.375rem 0.75rem;
    box-shadow: none;
    outline: none;
    transition: border-color 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
}

    /* Focus State */
    select.form-select:focus {
        border-color: #0056b3; /* Blue border on focus */
        box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.25);
    }

    /* Hover State for Specific Select */
    select.form-select:hover {
        border-color: #666 !important; /* Medium grey border on hover */
    }

    /* Disabled State */
    select.form-select:disabled {
        background-color: #f0f0f0;
        border-color: #dcdcdc;
        cursor: not-allowed;
    }

    /* Error/Invalid State */
    select.form-select.is-invalid {
        border-color: #dc3545;
        background-color: #f8d7da;
    }

/* General Input Fields and Select with updated lighter color */
input[type="checkbox"] {
    border: 2px solid #bbb; /* Lighter grey */
    box-shadow: none;
    outline: none;
}

    input[type="checkbox"]:focus {
        border-color: #0056b3; /* Blue border on focus */
    }

/* Ensure all input types and classes are covered */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input.form-control, /* Ensure class "form-control" inputs get the styles */
select,
textarea {
    border: 1px solid #bbb; /* Lighter grey */
    border-radius: 4px; /* Smooth corners for consistency */
    padding: 0.375rem 0.75rem; /* Consistent padding for all inputs */
    box-shadow: none;
    outline: none;
    transition: border-color 0.3s ease-in-out, box-shadow 0.3s ease-in-out; /* Smooth transition for both border and shadow */
}

    /* Focus State for Inputs and Select */
    input[type="text"]:focus,
    input[type="email"]:focus,
    input[type="password"]:focus,
    input[type="number"]:focus,
    input.form-control:focus, /* Ensure "form-control" gets the focus style */
    select:focus,
    textarea:focus {
        border-color: #0056b3; /* Blue border on focus */
        box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.25); /* Subtle blue shadow when focused */
    }

    /* Disabled State for Inputs and Select */
    input[type="text"]:disabled,
    input[type="email"]:disabled,
    input[type="password"]:disabled,
    input[type="number"]:disabled,
    input.form-control:disabled, /* Apply disabled style to form-control inputs */
    select:disabled,
    textarea:disabled {
        background-color: #f0f0f0; /* Light grey background for disabled inputs */
        border-color: #dcdcdc; /* Light grey border for disabled inputs */
        cursor: not-allowed; /* Show not-allowed cursor on hover */
    }

    /* Error/Invalid State for Inputs and Select */
    input[type="text"].is-invalid,
    input[type="email"].is-invalid,
    input[type="password"].is-invalid,
    input[type="number"].is-invalid,
    input.form-control.is-invalid, /* Apply error style to form-control inputs */
    select.is-invalid,
    textarea.is-invalid {
        border-color: #dc3545; /* Red border for invalid input */
        background-color: #f8d7da; /* Light red background */
        box-shadow: none; /* Remove shadow on error */
    }

    /* Optional - Hover State for Inputs and Select */
    input[type="text"]:hover,
    input[type="email"]:hover,
    input[type="password"]:hover,
    input[type="number"]:hover,
    input.form-control:hover, /* Apply hover style to form-control inputs */
    select:hover,
    textarea:hover {
        border-color: #666; /* Medium grey border on hover */
    }

    /* General Input Fields and Select */
    textarea.form-control {
        border: 1px solid #bbb; /* Lighter grey */
        border-radius: 4px;
        padding: 0.375rem 0.75rem;
        box-shadow: none;
        outline: none;
        transition: border-color 0.3s ease-in-out, box-shadow 0.3s ease-in-out;
    }

        /* Focus State */
        textarea.form-control:focus {
            border-color: #0056b3;
            box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.25);
        }

        /* Disabled State */
        textarea.form-control:disabled {
            background-color: #f0f0f0;
            border-color: #dcdcdc;
            cursor: not-allowed;
        }

        /* Error/Invalid State */
        textarea.form-control.is-invalid {
            border-color: #dc3545;
            background-color: #f8d7da;
        }

        /* Hover State */
        textarea.form-control:hover {
            border-color: #666;
        }

.separator {
    display: inline-block;
    width: 1px;
    height: 1.25rem; /* Adjust height to align with checkboxes */
    background-color: #888; /* Optional: light grey color */
    margin-right: 1.5rem; /* Extra space after the separator */
    vertical-align: middle; /* Align the separator vertically with the checkboxes */
}

h6 {
    font-weight: 600;
}

.cursor-not-allowed {
    cursor: not-allowed;
}

.custom-accordion-border {
    border-radius: 0 !important;
    border: 1px solid #000;
}

.custom-accordion-header {
    padding: 0.5rem 1rem;
    border-bottom: 1px solid #e7e7e7;
}

   

.accordion-button {
    background: none;
    border: none;
    box-shadow: none;
}

.accordion-toggle {
    font-size: 1.25rem;
    padding: 0;
}

.accordion-chevron-button {
    background: none;
    border: none;
    box-shadow: none;
    padding: 0;
    margin: 0;
}

    .accordion-chevron-button:focus {
        outline: none;
        box-shadow: none;
    }

.form-group {
    display: flex;
    align-items: flex-start;
    margin-bottom: 1rem;
}

.form-label {
    margin-right: 1rem;
    flex-shrink: 0;
    min-width: 100px;
    line-height: 2.5;
}

.form-controls {
    flex-grow: 1;
}

.form-select,
.form-input {
    width: 100%;
    max-width: 400px;
    margin-bottom: 0.5rem;
}

.form-select {
    padding: 0.375rem 0.75rem;
    border-radius: 4px;
    border: 1px solid #ccc;
    text-align: center;
}

    .form-select.placeholder-selected {
        text-align: center;
    }

    .form-select option {
        text-align: left;
    }


.form-input {
    padding: 0.5rem;
    border-radius: 4px;
    border: 1px solid #ccc;
    margin-top: 0.5rem;
}


.form-input {
    padding: 0.5rem;
    border-radius: 4px;
    border: 1px solid #ccc;
    margin-top: 0.5rem;
}
.tooltip-wrapper {
    position: relative;
    display: inline-block;
    cursor: pointer;
}

.tooltip-text {
    visibility: hidden;
    width: 450px;
    background-color: #f9f9f9; /* Neutral background color */
    color: #333; /* Dark text color for readability */
    text-align: left; /* Align text to the left */
    border-radius: 6px;
    padding: 5px;
    position: absolute;
    z-index: 1;
    top: 50%; /* Position the tooltip vertically centered */
    left: 105%; /* Position the tooltip to the right of the element */
    margin-left: 5px; /* Add some space between the element and the tooltip */
    opacity: 0;
    transition: opacity 0.3s;
    box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1); /* Optional: Add a subtle shadow */
}

.tooltip-wrapper:hover .tooltip-text {
    visibility: visible;
    opacity: 1;
}

.tooltip-icon {
    font-size: 24px;
    color: #007bff;
    vertical-align: middle;
    transform: translateY(-2px);
}

.custom-light-green-badge {
    background-color: #66C2A5;
    color: #FFFFFF;
}

.custom-accordion:not(.collapsed) {
    background-color: var(--primary-light2) !important;
}

/* Dark amber with good contrast */
.text-degraded {
    --degraded-color: #b26a00; /* tweak to taste */
    --bs-text-opacity: 1; /* ensure no opacity dilution */
    color: var(--degraded-color) !important;
}

    /* Material Symbols inherit too */
    .text-degraded .material-symbols-outlined {
        color: var(--degraded-color) !important;
    }


.page-loading {
    min-height: 40vh;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}
    
/* Force html and body to not have margin/padding */
html {
    margin: 0 !important;
    padding: 0 !important;
}
    
body {
    margin: 0 !important;
    padding: 0 !important;
}

.flatpickr-calendar {
    width: 230px !important;
    font-size: 12px !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15) !important;
    background: white !important;
    border: 1px solid rgba(0, 0, 0, 0.1) !important;
    z-index: 9999 !important;
}

.flatpickr-months {
    display: flex !important;
    align-items: center !important;
    padding: 4px 0 !important;
    position: relative !important;
}

.flatpickr-month {
    flex: 1 !important;
    padding: 0 !important;
    display: flex !important;
    justify-content: center !important;
}

.flatpickr-current-month {
    position: static;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: auto !important;
    margin-left: 0px !important;
}

    .flatpickr-current-month .cur-month {
        margin-right: 4px !important;
        margin-left: 0px !important;
    }

    .flatpickr-current-month .numInputWrapper {
        width: 7ch !important;
    }

        .flatpickr-current-month .numInputWrapper > .numInput {
            font-weight: 700;
        }

.flatpickr-prev-month,
.flatpickr-next-month {
    padding: 0 4px !important;
    height: auto !important;
    position: relative !important;
    top: auto !important;
}

.flatpickr-next-month {
    right: 0 !important;
}

.flatpickr-clear,
.flatpickr-today {
    position: absolute !important;
    bottom: 7px !important;
    border: 1px solid #ccc !important;
    background: white !important;
    font-size: 12px !important;
    cursor: pointer;
    color: #333 !important;
    padding: 2px 6px !important;
    border-radius: 3px !important;
    margin: 0 !important;
    line-height: normal !important;
}

.flatpickr-clear {
    left: 8px !important;
}

.flatpickr-today {
    right: 8px !important;
}

    .flatpickr-clear:hover,
    .flatpickr-today:hover {
        background: #f0f0f0 !important;
        text-decoration: none !important;
    }

.flatpickr-weekdays {
    background: white !important;
    padding: 4px 0 !important;
    margin: 0 !important;
}

.flatpickr-weekday {
    font-size: 11px !important;
    color: #333 !important;
    font-weight: normal !important;
    text-transform: uppercase;
    width: 30px !important;
    padding: 0 !important;
    margin: 0 !important;
}

.flatpickr-day {
    height: 28px !important;
    line-height: 28px !important;
    font-size: 12px !important;
    border-radius: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 30px !important;
    max-width: 30px !important;
    color: #333 !important;
    border: none !important;
}

    .flatpickr-day.selected {
        background: var(--primary) !important;
        color: white !important;
    }

        .flatpickr-day.selected:hover {
            background: var(--primary) !important; /* Same as selected */
            color: white !important;
            opacity: 0.9 !important; /* Optional: slight opacity change to show hover state */
        }

    .flatpickr-day:hover {
        background: var(--primary-light) !important;
    }

    .flatpickr-day.prevMonthDay,
    .flatpickr-day.nextMonthDay {
        color: #999 !important;
    }

    .flatpickr-day.today {
        border: 1px solid var(--primary) !important; /* Add border with primary color */
        border-radius: 0 !important; /* Square corners, or use 4px for rounded */
    }

.dayContainer {
    width: 100% !important;
    min-width: 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
    padding-bottom: 40px !important;
}

.flatpickr-days {
    width: 100% !important;
    max-width: none !important;
    padding: 0 !important;
    margin: 0 !important;
}



.flatpickr-prev-month,
.flatpickr-next-month {
    color: var(--primary) !important;
    fill: var(--primary) !important;
}

    .flatpickr-prev-month svg path,
    .flatpickr-next-month svg path {
        fill: var(--primary) !important;
    }

    .flatpickr-prev-month:hover,
    .flatpickr-next-month:hover {
        color: var(--secondary-dark) !important;
        fill: var(--secondary-dark) !important;
    }

        .flatpickr-prev-month:hover svg path,
        .flatpickr-next-month:hover svg path {
            fill: var(--secondary-dark) !important;
        }

/* Add these CSS rules */
/*:.date-picker-container {
    width: 30% !important;
    display: inline-block !important;
    box-sizing: border-box !important;
}*/

.date-picker-container input[type="text"] {
    width: 96% !important;
    box-sizing: border-box !important;
    transform: translateY(-4px) !important;
    /* border: 1px solid #ced4da !important;*/
}

.flatpickr-wrapper {
    width: 100% !important;
    display: block !important;
    box-sizing: border-box !important;
}

.flatpickr-input {
    width: 100% !important;
    box-sizing: border-box !important;
}

/* Override any Bootstrap margins */
/* .form-control.me-2 {
    margin-right: 0.5rem !important;
    width: 100% !important;
}*/