﻿.form-control,
.form-select,
textarea.form-control {
    border: 1px solid var(--border-color);
    border-radius: .75rem;
    background-color: var(--input-bg, var(--main-bg));
    color: var(--text-primary);
    font-size: .875rem;
    padding: .625rem 1rem;
    min-height: 42px;
    transition: border-color .2s cubic-bezier(.4,0,.2,1), background-color .2s cubic-bezier(.4,0,.2,1), box-shadow .2s cubic-bezier(.4,0,.2,1);
    box-shadow: 0 1px 2px rgba(0,0,0,.05);
}

    .form-control:focus,
    .form-select:focus,
    textarea.form-control:focus {
        border-color: var(--primary-color, #3b82f6);
        background-color: var(--input-focus-bg, var(--main-bg));
        box-shadow: 0 0 0 3px rgba(59,130,246,.1), 0 2px 8px rgba(59,130,246,.08);
        outline: none;
    }

    .form-control:hover:not(:disabled):not(:focus),
    .form-select:hover:not(:disabled):not(:focus),
    textarea.form-control:hover:not(:disabled):not(:focus) {
        border-color: var(--border-hover-color, var(--border-color));
        background-color: var(--input-hover-bg, var(--input-bg, var(--main-bg)));
    }

.form-label {
    font-weight: 600;
    font-size: .875rem;
    color: var(--text-primary);
    margin-bottom: .375rem;
    display: flex;
    align-items: center;
    gap: .25rem;
}

    .form-label .required {
        color: #ef4444;
        font-size: 1.2em;
        line-height: 1;
    }

.form-select {
    background-repeat: no-repeat;
    background-position: right 1rem center;
    background-size: 1rem;
    padding-right: 2.5rem;
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");
}

    .form-select:focus {
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%233b82f6' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");
    }

    .form-select option {
        background-color: var(--main-bg);
        color: var(--text-primary);
    }

textarea.form-control {
    min-height: 100px;
    resize: vertical;
    line-height: 1.5;
    padding-top: .75rem;
}

.form-check {
    margin-bottom: .75rem;
    min-height: 1.5rem;
    padding-left: 1.75rem;
}

.form-check-input {
    width: 1.25rem;
    height: 1.25rem;
    margin-top: .125rem;
    margin-left: -1.75rem;
    border: 2px solid var(--border-color);
    background-color: var(--input-bg, var(--main-bg));
    cursor: pointer;
    transition: border-color .2s ease, background-color .2s ease, box-shadow .2s ease;
}

    .form-check-input[type="checkbox"] {
        border-radius: .375rem;
    }

    .form-check-input[type="radio"] {
        border-radius: 50%;
    }

    .form-check-input:checked {
        background-color: var(--primary-color, #3b82f6);
        border-color: var(--primary-color, #3b82f6);
    }

    .form-check-input[type="checkbox"]:checked {
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='white'%3E%3Cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3E%3C/svg%3E");
        background-size: 1rem;
        background-position: center;
        background-repeat: no-repeat;
    }

    .form-check-input:focus {
        box-shadow: 0 0 0 3px rgba(59,130,246,.1);
        border-color: var(--primary-color, #3b82f6);
    }

.form-check-label {
    cursor: pointer;
    font-size: .875rem;
    color: var(--text-primary);
    user-select: none;
    line-height: 1.25rem;
}

.form-check-inline {
    display: inline-flex;
    align-items: center;
    margin-right: 1rem;
}

.tc-ms-wrapper {
    position: relative;
}

.tc-ms-btn {
    width: 100%;
    min-height: 42px;
    padding: .625rem 1rem;
    border: 1px solid var(--border-color);
    border-radius: .75rem;
    background-color: var(--input-bg, var(--main-bg));
    color: var(--text-primary);
    font-size: .875rem;
    text-align: left;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .5rem;
    transition: border-color .2s cubic-bezier(.4,0,.2,1), background-color .2s cubic-bezier(.4,0,.2,1), box-shadow .2s cubic-bezier(.4,0,.2,1);
    box-shadow: 0 1px 2px rgba(0,0,0,.05);
    cursor: pointer;
}

    .tc-ms-btn:hover:not(:disabled) {
        border-color: var(--border-hover-color, var(--border-color));
        background-color: var(--input-hover-bg, var(--input-bg, var(--main-bg)));
    }

    .tc-ms-btn:focus,
    .tc-ms-btn.show {
        border-color: var(--primary-color, #3b82f6);
        box-shadow: 0 0 0 3px rgba(59,130,246,.1), 0 2px 8px rgba(59,130,246,.08);
        outline: none;
    }

.tc-ms-text {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex-grow: 1;
}

    .tc-ms-text.dd-placeholder {
        color: var(--text-muted, var(--text-secondary, #64748b));
        opacity: .7;
    }

.tc-ms-btn.dropdown-toggle::after {
    border: none;
    width: 1rem;
    height: 1rem;
    background-repeat: no-repeat;
    background-position: center;
    transition: transform .2s ease;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%239ca3af' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");
}

.tc-ms-btn.show.dropdown-toggle::after {
    transform: rotate(180deg);
}

.tc-ms-menu {
    border: 1px solid var(--border-color);
    border-radius: .75rem;
    background-color: var(--main-bg);
    padding: .5rem;
    margin-top: .25rem;
    box-shadow: 0 4px 20px rgba(0,0,0,.15), 0 0 0 1px rgba(0,0,0,.05);
    max-height: 280px;
    overflow-y: auto;
    animation: dropdownSlideIn .1s ease;
    scrollbar-width: thin;
    scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
}

@keyframes dropdownSlideIn {
    from {
        opacity: 0;
        transform: translateY(-8px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.tc-ms-menu .dropdown-item {
    padding: .5rem .75rem;
    border-radius: .75rem;
    margin-bottom: .125rem;
    color: var(--text-primary);
    display: flex;
    align-items: center;
    gap: .5rem;
    transition: background-color .15s ease, transform .15s ease;
    cursor: pointer;
}

    .tc-ms-menu .dropdown-item:hover {
        background-color: var(--dropdown-hover-bg, rgba(59,130,246,.08));
        transform: translateX(2px);
    }

    .tc-ms-menu .dropdown-item:active {
        background-color: var(--dropdown-active-bg, rgba(59,130,246,.12));
    }

.tc-ms-menu .form-check {
    margin: 0;
    padding: 0;
    min-height: auto;
}

.tc-ms-menu .form-check-input {
    margin: 0 1rem 0 0;
    flex-shrink: 0;
}

.tc-ms-menu .form-check-label {
    flex-grow: 1;
    padding: .125rem 0;
}

.tc-ms-menu::-webkit-scrollbar,
.ua-box-scroll::-webkit-scrollbar {
    width: 6px;
}

.tc-ms-menu::-webkit-scrollbar-track,
.ua-box-scroll::-webkit-scrollbar-track {
    background: var(--scrollbar-track);
    border-radius: 3px;
}

.tc-ms-menu::-webkit-scrollbar-thumb,
.ua-box-scroll::-webkit-scrollbar-thumb {
    background: var(--scrollbar-thumb);
    border-radius: 3px;
}

    .tc-ms-menu::-webkit-scrollbar-thumb:hover,
    .ua-box-scroll::-webkit-scrollbar-thumb:hover {
        background: var(--scrollbar-thumb-hover);
    }

input[type="file"].form-control {
    padding: .35rem;
    cursor: pointer;
}

    input[type="file"].form-control::file-selector-button {
        padding: .65rem 1rem;
        margin-right: 1rem;
        border: none;
        background-color: var(--button-bg, rgba(15,23,42,.06));
        color: var(--text-primary);
        font-size: .875rem;
        cursor: pointer;
        transition: background-color .2s ease;
    }

        input[type="file"].form-control::file-selector-button:hover {
            background-color: var(--button-hover-bg, rgba(15,23,42,.10));
        }

input[type="range"].form-control {
    height: .375rem;
    padding: 0;
    background-color: var(--border-color);
    border: none;
    border-radius: .75rem;
}

    input[type="range"].form-control::-webkit-slider-thumb {
        width: 1.25rem;
        height: 1.25rem;
        border-radius: 50%;
        background-color: var(--primary-color, #3b82f6);
        border: 2px solid var(--main-bg);
        cursor: pointer;
        box-shadow: 0 2px 6px rgba(0,0,0,.2);
    }

.form-control.is-valid,
.form-select.is-valid,
.was-validated .form-control:valid {
    border-color: #10b981;
    background-repeat: no-repeat;
    background-position: right calc(.375em + .75rem) center;
    background-size: 1rem;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%2310b981'%3E%3Cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3E%3C/svg%3E");
}

.form-control.is-invalid,
.form-select.is-invalid,
.was-validated .form-control:invalid {
    border-color: #ef4444;
    background-repeat: no-repeat;
    background-position: right calc(.375em + .75rem) center;
    background-size: 1rem;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23ef4444'%3E%3Cpath d='M8 15A7 7 0 1 1 8 1a7 7 0 0 1 0 14zm0-1A6 6 0 1 0 8 2a6 6 0 0 0 0 12zm-.93-5.78l1.14-1.14a.5.5 0 0 1 .707.707L7.778 8.93l1.14 1.14a.5.5 0 0 1-.707.707L7.07 9.636l-1.14 1.14a.5.5 0 0 1-.707-.707l1.14-1.14-1.14-1.14a.5.5 0 0 1 .707-.707l1.14 1.14z'/%3E%3C/svg%3E");
}

.invalid-feedback,
.valid-feedback {
    font-size: .75rem;
    margin-top: .25rem;
    padding-left: .25rem;
}

.invalid-feedback {
    color: #ef4444;
}

.valid-feedback {
    color: #10b981;
}

.form-control:disabled,
.form-select:disabled,
.form-check-input:disabled,
.tc-ms-btn:disabled {
    opacity: .6;
    cursor: not-allowed;
    background-color: var(--input-disabled-bg, var(--input-bg, var(--main-bg)));
}

    .form-check-input:disabled ~ .form-check-label {
        opacity: .6;
        cursor: not-allowed;
    }

.tc-card .form-control,
.tc-card .form-select,
.tc-card textarea.form-control,
.tc-card .tc-ms-btn {
    background-color: var(--card-input-bg, var(--input-bg, var(--main-bg)));
}

:root[data-bs-theme="dark"] {
    --input-bg: #2a2a2e;
    --input-hover-bg: #323236;
    --input-focus-bg: #2a2a2e;
    --input-disabled-bg: #3a3a3f;
    --card-input-bg: #2a2a2e;
    --border-hover-color: #5a5a5f;
    --button-bg: #3a3a3f;
    --button-hover-bg: #424246;
    --dropdown-hover-bg: rgba(255,255,255,.08);
    --dropdown-active-bg: rgba(255,255,255,.12);
    --scrollbar-track: #2a2a2e;
    --scrollbar-thumb: #4a4a4f;
    --scrollbar-thumb-hover: #5a5a5f;
}

    :root[data-bs-theme="dark"] .form-control::placeholder,
    :root[data-bs-theme="dark"] .form-select::placeholder {
        color: #9ca3af;
    }

    :root[data-bs-theme="dark"] .form-control:focus,
    :root[data-bs-theme="dark"] .form-select:focus,
    :root[data-bs-theme="dark"] textarea.form-control:focus,
    :root[data-bs-theme="dark"] .tc-ms-btn:focus {
        border-color: #60a5fa;
        box-shadow: 0 0 0 3px rgba(96,165,250,.1), 0 2px 8px rgba(96,165,250,.08);
    }

    :root[data-bs-theme="dark"] .form-select:focus {
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%2360a5fa' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");
    }

    :root[data-bs-theme="dark"] .form-check-input:checked {
        background-color: #60a5fa;
        border-color: #60a5fa;
    }

@media (max-width: 768px) {
    .form-control,
    .form-select,
    textarea.form-control,
    .tc-ms-btn {
        font-size: 1rem;
        min-height: 48px;
        padding: .75rem 1rem;
    }

    .form-check-input {
        width: 1.5rem;
        height: 1.5rem;
    }

    .form-check {
        padding-left: 2rem;
    }
}

.form-text {
    font-size: .75rem;
    color: var(--text-muted, var(--text-secondary, #64748b));
    margin-top: .25rem;
    display: flex;
    align-items: center;
    gap: .25rem;
}

.input-group {
    border-radius: .75rem;
    overflow: hidden;
}

    .input-group .form-control {
        border-radius: .75rem;
    }

    .input-group .input-group-text {
        background-color: var(--input-bg, var(--main-bg));
        border-color: var(--border-color);
        color: var(--text-muted, var(--text-secondary, #64748b));
        padding: .625rem 1rem;
    }

.form-floating > .form-control,
.form-floating > .form-select {
    height: calc(3.5rem + 2px);
    padding: 1rem .75rem;
}

.form-floating > label {
    padding: 1rem .75rem;
    color: var(--text-muted, var(--text-secondary, #64748b));
}

.form-floating > .form-control:focus ~ label,
.form-floating > .form-control:not(:placeholder-shown) ~ label,
.form-floating > .form-select ~ label {
    color: var(--primary-color, #3b82f6);
    transform: scale(.85) translateY(-.5rem) translateX(.15rem);
}

input[type="date"],
input[type="datetime-local"] {
    position: relative;
    padding-right: 2.5rem;
    background-repeat: no-repeat;
    background-position: right .75rem center;
    background-size: 1rem;
    color-scheme: light;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E");
}

    input[type="date"]::-webkit-calendar-picker-indicator,
    input[type="datetime-local"]::-webkit-calendar-picker-indicator {
        opacity: 0;
        position: absolute;
        right: .5rem;
        width: 1.25rem;
        height: 100%;
        cursor: pointer;
    }

:root[data-bs-theme="dark"] input[type="date"],
:root[data-bs-theme="dark"] input[type="datetime-local"] {
    color-scheme: dark;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23e5e7eb' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='4' width='18' height='18' rx='2' ry='2'/%3E%3Cline x1='16' y1='2' x2='16' y2='6'/%3E%3Cline x1='8' y1='2' x2='8' y2='6'/%3E%3Cline x1='3' y1='10' x2='21' y2='10'/%3E%3C/svg%3E");
}

input:-webkit-autofill,
textarea:-webkit-autofill,
select:-webkit-autofill,
input:-webkit-autofill:hover,
textarea:-webkit-autofill:hover,
select:-webkit-autofill:hover,
input:-webkit-autofill:focus,
textarea:-webkit-autofill:focus,
select:-webkit-autofill:focus {
    -webkit-text-fill-color: var(--text-primary) !important;
    caret-color: var(--text-primary) !important;
    -webkit-box-shadow: 0 0 0 1000px var(--input-bg, var(--main-bg)) inset !important;
    box-shadow: 0 0 0 1000px var(--input-bg, var(--main-bg)) inset !important;
    border-color: var(--border-color) !important;
    transition: background-color 999999s ease-in-out 0s, color 999999s ease-in-out 0s;
}

input:-webkit-autofill,
textarea:-webkit-autofill,
select:-webkit-autofill {
    -webkit-background-clip: text !important;
}

.autocomplete-menu {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 1050;
    margin-top: .35rem;
    background-color: #ffffff;
    border: 1px solid var(--border-color);
    border-radius: .75rem;
    box-shadow: 0 .5rem 1rem rgba(0,0,0,.12);
    max-height: 350px;
    overflow: auto;
}

    .autocomplete-menu .dropdown-item {
        width: 100%;
        text-align: left;
        border: 0;
        background: transparent;
        color: #212529;
    }

        .autocomplete-menu .dropdown-item:hover,
        .autocomplete-menu .dropdown-item:focus {
            background-color: rgba(0,0,0,.05);
        }

:root[data-bs-theme="dark"] .autocomplete-menu {
    background-color: var(--sidebar-bg);
    border-color: var(--border-color);
    box-shadow: 0 .5rem 1rem rgba(0,0,0,.35);
}

    :root[data-bs-theme="dark"] .autocomplete-menu .dropdown-item {
        color: var(--text-primary);
    }
        .autocomplete-menu .dropdown-item:focus,
        .autocomplete-menu .dropdown-item:hover,
        .autocomplete-menu .dropdown-item.is-focused {
            background-color: rgba(59, 130, 246, 0.10);
        }
        :root[data-bs-theme="dark"] .autocomplete-menu .dropdown-item:hover,
        :root[data-bs-theme="dark"] .autocomplete-menu .dropdown-item:focus,
        :root[data-bs-theme="dark"] .autocomplete-menu .dropdown-item.is-focused {
            background-color: rgba(255,255,255,.1);
        }
:root[data-bs-theme="dark"] input.form-control::placeholder,
:root[data-bs-theme="dark"] textarea.form-control::placeholder,
:root[data-bs-theme="dark"] select.form-select::placeholder {
    color: var(--text-secondary);
}
:root[data-bs-theme="dark"] input.form-control,
:root[data-bs-theme="dark"] textarea.form-control,
:root[data-bs-theme="dark"] select.form-select,
:root[data-bs-theme="dark"] .tc-ms-btn {
    color: var(--text-primary) !important;
}
.datepicker-dropdown {
    z-index: 2000 !important;
}

body.dark-theme .datepicker-picker {
    background: var(--menu-dd-bg) !important;
    border: 1px solid var(--menu-dd-border) !important;
    box-shadow: var(--menu-dd-shadow) !important;
}

body.dark-theme .datepicker-header,
body.dark-theme .datepicker-main,
body.dark-theme .datepicker-footer,
body.dark-theme .datepicker-view,
body.dark-theme .datepicker-grid {
    background: transparent !important;
}

body.dark-theme .datepicker-controls {
    background: transparent !important;
    border-bottom: 1px solid rgba(255,255,255,.10) !important;
}

body.dark-theme .datepicker-footer {
    border-top: 1px solid rgba(255,255,255,.10) !important;
}

body.dark-theme .datepicker .datepicker-controls .button {
    background: transparent !important;
    border: 0 !important;
    color: var(--text-primary) !important;
}

    body.dark-theme .datepicker .datepicker-controls .button:hover {
        background: var(--menu-dd-hover) !important;
        color: var(--text-primary) !important;
    }

    body.dark-theme .datepicker .datepicker-controls .button:focus {
        box-shadow: none !important;
        outline: 0 !important;
    }

body.dark-theme .datepicker .datepicker-switch,
body.dark-theme .datepicker .prev,
body.dark-theme .datepicker .next,
body.dark-theme .datepicker .dow,
body.dark-theme .datepicker .week,
body.dark-theme .datepicker .day,
body.dark-theme .datepicker .month,
body.dark-theme .datepicker .year,
body.dark-theme .datepicker .decade,
body.dark-theme .datepicker .century {
    color: var(--text-primary) !important;
}

    body.dark-theme .datepicker .day:hover,
    body.dark-theme .datepicker .month:hover,
    body.dark-theme .datepicker .year:hover,
    body.dark-theme .datepicker .decade:hover,
    body.dark-theme .datepicker .century:hover,
    body.dark-theme .datepicker .datepicker-switch:hover,
    body.dark-theme .datepicker .prev:hover,
    body.dark-theme .datepicker .next:hover {
        background: var(--menu-dd-hover) !important;
        color: var(--text-primary) !important;
    }

    body.dark-theme .datepicker .day.old,
    body.dark-theme .datepicker .day.new {
        color: rgba(255,255,255,.45) !important;
    }

    body.dark-theme .datepicker .day.disabled,
    body.dark-theme .datepicker .day.disabled:hover,
    body.dark-theme .datepicker .month.disabled,
    body.dark-theme .datepicker .month.disabled:hover,
    body.dark-theme .datepicker .year.disabled,
    body.dark-theme .datepicker .year.disabled:hover,
    body.dark-theme .datepicker .decade.disabled,
    body.dark-theme .datepicker .decade.disabled:hover,
    body.dark-theme .datepicker .century.disabled,
    body.dark-theme .datepicker .century.disabled:hover {
        color: rgba(255,255,255,.25) !important;
        background: transparent !important;
    }

    body.dark-theme .datepicker .day.today:not(.selected),
    body.dark-theme .datepicker .day.today:hover:not(.selected) {
        background: rgba(59,130,246,.18) !important;
        color: var(--text-primary) !important;
    }

body.dark-theme .datepicker .selected,
body.dark-theme .datepicker .selected:hover {
    background: var(--accent-primary, #3b82f6) !important;
    color: #fff !important;
}

body.dark-theme .datepicker .focused:not(.selected),
body.dark-theme .datepicker .focused:hover:not(.selected) {
    background: rgba(255,255,255,.08) !important;
    color: var(--text-primary) !important;
}

body.dark-theme .datepicker .datepicker-cell {
    border-radius: .55rem;
}

    body.dark-theme .datepicker .datepicker-cell.today:not(.selected) {
        border: 1px solid rgba(59,130,246,.55) !important;
    }

body.dark-theme .datepicker .datepicker-controls {
    padding: .25rem .35rem !important;
}

body.dark-theme .datepicker .datepicker-switch {
    font-weight: 600 !important;
    opacity: 1 !important;
}

body.dark-theme .datepicker .datepicker-controls .button.prev-btn,
body.dark-theme .datepicker .datepicker-controls .button.next-btn {
    opacity: 1 !important;
}

body.dark-theme .datepicker .datepicker-switch,
body.dark-theme .datepicker .prev,
body.dark-theme .datepicker .next {
    background: rgba(255,255,255,.06) !important;
    border-radius: .55rem !important;
}

    body.dark-theme .datepicker .datepicker-switch:hover,
    body.dark-theme .datepicker .prev:hover,
    body.dark-theme .datepicker .next:hover {
        background: var(--menu-dd-hover) !important;
    }

body.dark-theme input.form-control[type="text"] {
    background: var(--main-bg) !important;
    color: var(--text-primary) !important;
    border-color: var(--border-color) !important;
}

    body.dark-theme input.form-control[type="text"]::placeholder {
        color: rgba(255,255,255,.45) !important;
    }

    body.dark-theme input.form-control[type="text"]:focus {
        box-shadow: 0 0 0 .2rem rgba(59,130,246,.20) !important;
        border-color: rgba(59,130,246,.45) !important;
    }

body:not(.dark-theme) .form-check-input:disabled {
    opacity: 1;
    background-color: rgba(148,163,184,.55);
    border-color: rgba(148,163,184,.9);
}

    body:not(.dark-theme) .form-check-input:disabled:checked {
        background-color: rgba(59,130,246,.75);
        border-color: rgba(59,130,246,.95);
    }

        body:not(.dark-theme) .form-check-input:disabled:checked[type="checkbox"] {
            background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23ffffff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='M6 10l3 3 6-7'/%3e%3c/svg%3e");
            background-position: center;
            background-repeat: no-repeat;
        }
html[data-bs-theme="dark"] .pac-container {
    background: #333 !important;
    color: #eaeaea !important;
    border: 1px solid rgba(255,255,255,.15) !important;
    box-shadow: 0 10px 30px rgba(0,0,0,.45) !important;
}

html[data-bs-theme="dark"] .pac-item {
    background: transparent !important;
    color: #eaeaea !important;
    border-top: 1px solid rgba(255,255,255,.08) !important;
}

    html[data-bs-theme="dark"] .pac-item:hover,
    html[data-bs-theme="dark"] .pac-item-selected {
        background: rgba(255,255,255,.08) !important;
    }

html[data-bs-theme="dark"] .pac-item-query {
    color: #ffffff !important;
}

html[data-bs-theme="dark"] .pac-matched {
    color: #9ad1ff !important;
}

html[data-bs-theme="dark"] .pac-icon {
    filter: invert(1) grayscale(1) brightness(1.2);
}