    .login-bg {
        height: 500px;
    }

    .logo img {
        height: 24px;
    }

    .login-header img {
        width: 120px;
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        left: 20px;
    }

    .login-img {
        width: 80%;
        height: 450px;
        object-fit: contain;
        object-position: left;
    }

    .login-slider {
        position: relative;
        overflow-x: hidden;
    }

    .login-slider .login-container {
        position: absolute;
        display: flex;
        flex-wrap: nowrap;
        height: 100%;
        transition: .5s all ease;
    }

    #otp-box .form-control {
        width: 40px;
        height: 40px;
        line-height: 40px;
        text-align: center;
    }

    .login-item {
        height: 260px;
    }

    li {
        list-style: none;
    }

    button {
        border: 0;
        background-color: transparent;
        padding: 0;
    }

    .object-cover {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .object-contain {
        width: 100%;
        height: 100%;
        object-fit: contain;
    }

    .h-300 {
        height: 300px;
    }

    .fs-16 {
        font-size: 16px;
    }

    input:focus,
    button:focus,
    select:focus {
        outline: none;
    }

    ::selection {
        background-color: var(--bs-primary);
        color: var(--bs-white);
    }

    ::-webkit-scrollbar {
        width: 6px;
        height: 6px;
    }

    ::-webkit-scrollbar-thumb:hover {
        background: #aaa;
    }

    ::-webkit-scrollbar-thumb {
        background: #0001;
        border-radius: 4px;
    }

    header {
        height: 56px;
        border-bottom: 1px solid var(--bs-gray-300);
    }

    footer {
        border-top: 1px solid var(--bs-gray-300);
    }

    .sidebar {
        position: fixed;
        left: 0;
        top: 0;
        z-index: 1030;
        border-right: 1px solid var(--bs-gray-300);
        overflow: hidden auto;
    }

    .h-100vh {
        height: 100vh;
    }

    .tableRow {
        cursor: pointer;
    }

    @media screen and (min-width:992px) {
        .h-100vh-md {
            height: 100vh;
        }
    }

    .navbar,
    .main-content {
        height: calc(100vh - 56px);
    }

    .navbar,
    .main-content {
        overflow: hidden auto;
    }

    .main-content {
        overflow: hidden;
    }

    .login-page {
        overflow: hidden auto;
    }

    .navbar .nav-item {
        position: relative;
    }

    .navbar .nav-link {
        padding: 0;
        font-weight: 500;
        display: flex;
        align-items: center;
        height: 40px;
        overflow: hidden;
    }

    .navbar .nav-link .nav-icon {
        width: 40px;
        height: 100%;
        text-align: center;
        line-height: 40px;
        color: var(--bs-gray-600);
    }

    .navbar .nav-link .nav-text {
        white-space: nowrap;
        width: calc(100% - 40px);
    }

    .navbar .nav-link.active>*,
    .navbar .nav-link:hover>* {
        color: var(--bs-indigo);
    }

    .navbar .nav-link.active {
        background-color: var(--bs-lightblue);
    }

    .icon-fa {
        width: 32px;
        height: 32px;
        line-height: 32px;
        user-select: none;
    }

    ::placeholder {
        font-size: 12px;
        color: var(--bs-gray-200);
    }

    .btn {
        text-transform: capitalize;
    }

    .btn-sm {
        padding: 0;
        height: 28px;
        line-height: 28px;
        display: inline-flex;
        font-size: 13px;
        overflow: hidden;
    }

    .btn-sm span {
        height: 100%;
        display: block;
        line-height: 28px;
    }

    .btn-sm i {
        display: inline-flex;
        width: 24px;
        height: 100%;
        align-items: center;
        justify-content: center;
    }

    .btn-danger i,
    .btn-success i,
    .btn-primary i,
    .btn-indigo i,
    .btn-light i,
    .btn-secondary i,
    .btn-info i {
        background-color: #0002;
    }

    input[type=number]::-webkit-inner-spin-button {
        appearance: none;
    }

    .cursor-pointer {
        cursor: pointer;
    }

    table tr th {
        white-space: nowrap;
        text-transform: capitalize;
        font-weight: 500;
    }

    .side-panel-container {
        position: fixed;
        bottom: 0;
        right: -100%;
        width: 100%;
        height: calc(100vh - 56px);
        background: rgba(var(--bs-indigo-rgb), .2);
        display: flex;
        justify-content: flex-end;
        z-index: 1000;
        opacity: 0;
        transition: all ease .5s;
    }

    .side-panel-container.active {
        opacity: 1;
        right: 0;
    }

    .side-panel {
        min-width: 360px;
        max-width: 500px;
        height: fit-content;
        position: relative;
        overflow-y: auto;
        max-height: 100%;
    }

    .side-panel-lg {
        width: calc(100% - 50%);
    }

    .h-36 {
        height: 36px;
    }

    .btn-group input[type=radio]:checked+label {
        color: var(--bs-white);
        background-color: var(--bs-indigo);
    }

    .form-check-input:checked+label {
        color: var(--bs-indigo);
    }

    .card-header>* {
        padding: 8px;
    }

    .serial-no {
        min-width: 30px;
    }

    .min-width-25 {
        min-width: 25%;
    }

    .card-pagination {
        display: inline-flex;
        align-items: center;
        user-select: none;
    }

    .card-pagination button,
    .card-pagination .dots {
        min-width: 28px;
        height: 28px;
        padding: 0 4px;
        text-align: center;
        line-height: 27px;
        margin: 0 2px;
    }

    .card-pagination button {
        border-radius: 3px;
    }

    .card-pagination button:not(:disabled):hover,
    .card-pagination button.active {
        color: var(--bs-white);
        background-color: var(--bs-indigo);
    }

    .assets-img {
        width: 150px;
        height: 100px;
        object-fit: cover;
    }

    .assets-img-vertical {
        width: 100%;
        height: 140px;
        object-fit: contain;
    }

    .asset-right {
        position: fixed;
        right: -100%;
        z-index: 2;
        transition: all ease .5s;
    }

    .asset-panel.active .asset-right {
        right: 0;
    }

    .asset-view-page .assets-img-vertical {
        width: 100%;
        height: 270px;
        object-fit: cover;
    }

    .list li {
        list-style-type: disc;
    }

    .accord-item-btn {
        width: 100%;
        padding: 8px 32px 8px 8px;
        border-top: 1px solid var(--bs-gray-200);
        border-bottom: 1px solid transparent;
        background-color: var(--bs-gray-100);
        position: relative;
        text-align: left;
        cursor: pointer;
        user-select: none;
    }

    .myAccord .accord-item.active .accord-item-btn {
        border-color: var(--bs-white);
        background-color: var(--bs-indigo);
        color: white;
    }

    .myAccord .accord-item:first-child .accord-item-btn {
        border-top: none;
    }

    .accord-item-btn i {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        right: 10px;
    }

    .accord-item-content {
        display: none;
    }

    .accord-item.active .accord-item-content {
        display: block;
        box-shadow: 0 0.15rem 0.25rem rgb(0 0 0 / 7%) !important;
    }

    .table-bordered tr td,
    .table-bordered tr th {
        border: 1px solid var(--bs-gray-400);
    }

    .border-top-dashed {
        border-top: 1px dashed var(--bs-gray-400);
    }

    .asset-left {
        overflow: hidden;
    }

    .asset-view-page .asset-left,
    .asset-input-row {
        overflow: hidden auto;
    }

    .gap8 {
        gap: 8px;
    }

    #additional-detail {
        display: none;
    }

    .table-editable td:focus-visible {
        outline: none;
    }

    #user-management-container {
        overflow: auto;
    }

    /* .card-btns {
        opacity: 0;
        transform: translateX(-20px);
        transition: all ease .5s;
    } */

    .survey-card:hover .card-btns {
        opacity: 1;
        transform: translateX(0px);
    }

    .survey-card:hover .card-footer {
        animation: bg .5s linear;
    }

    #enumerator-table>thead tr {
        position: sticky;
        top: -1px;
        z-index: 1;
    }

    .scrollBarHeight {
        overflow: hidden auto;
    }

    .survey-grid-img {
        width: 100%;
        height: 100%;
        max-height: 250px;
        object-fit: contain;
    }

    .footer {
        display: none;
    }

    #map {
        width: 100%;
        height: calc(100vh - 93px);
    }

    .map-filter-panel {
        position: fixed;
        top: 55px;
        right: -400px;
        width: 400px;
        z-index: 1000;
        height: auto;
        transition: all ease .5s;
    }

    .map-filter-panel.active {
        right: 0;
    }

    .map-modal {
        position: fixed;
        bottom: 32px;
        right: -100%;
        z-index: 1000;
        height: auto;
        transition: all ease .5s;
    }

    .map-modal.active {
        right: 0;
    }

    .leaflet-marker-shadow {
        display: none;
    }

    .tag-col {
        display: inline-flex;
        align-items: center;
        flex-wrap: wrap;
        gap: 4px;
        padding: 4px;
    }

    .tag-item {
        display: inline-flex;
        align-items: center;
        gap: 4px;
        font-size: 11px;
        user-select: none;
        background: var(--bs-lightblue);
        font-weight: 500;
    }

    .tag-item i.tag-close-btn {
        width: 20px;
        height: 20px;
        line-height: 20px;
        text-align: center;
        cursor: pointer;
        color: white;
        background: #f44336;
    }

    .datepickr-clear {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        right: 0;
        font-size: 10px;
        width: 30px;
        height: 100%;
        text-align: center;
        line-height: 30px;
        display: none;
    }

    .flatpickr-input:not(:placeholder-shown)+.datepickr-clear {
        display: block;
    }

    .map-page,
    .grid-page {
        display: none;
    }

    .map-page.active,
    .grid-page.active {
        display: block;
    }

    .sub-row {
        visibility: collapse;
    }

    .sub-row.active {
        visibility: visible;
    }

    .table-icon {
        display: inline-block;
        width: 24px;
    }

    .text-red {
        color: red;
    }

    .idam-loader {
        display: none;
        justify-content: center;
        align-items: center;
        background-color: rgba(var(--bs-indigo-rgb), .1);
        height: 100vh;
        width: 100%;
        position: fixed;
        top: 0;
        left: 0;
        z-index: 9999;
    }

    .idam-loader.active {
        display: flex;
    }

    .label-group {
        padding: 4px;
        position: relative;
        background-color: var(--bs-gray-200);
        border-radius: 4px;
    }

    .label-container {
        z-index: 2;
    }

    .label-item {
        position: relative;
        flex: 1;
        border-radius: 4px;
    }

    .label-container .label-item:not(:first-child)::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        width: 1px;
        height: 100%;
        background-color: var(--bs-gray-400);
        transition: all ease .5s;
    }

    .label-container .label-item.active::before,
    .label-container .label-item.active+.label-item::before {
        background-color: transparent;
    }

    .label-group .label-btn {
        font-size: 12px;
        margin-bottom: 0;
        cursor: pointer;
        padding: 3px 8px;
        text-align: center;
        white-space: nowrap;
        /* text-transform: uppercase; */
        display: block;
    }

    .label-group .slider {
        position: absolute;
        top: 4px;
        left: 4px;
        height: calc(100% - 8px);
        width: calc(50% - 4px);
        background-color: var(--bs-indigo);
        border-radius: 4px;
        z-index: 0;
        transition: all ease .5s;
        box-shadow: 0 0 2px 0 var(--bs-gray-400);
        width: 0;
    }

    .label-group input {
        display: none;
        user-select: none;
    }

    /* validation */
    /* 
.was-validated .label-group:has(input[type='radio']:invalid)+.invalid-feedback {
    display: block;
}

.was-validated .dropzone+.invalid-feedback {
    display: block;
}

.was-validated .dropzone.dz-max-files-reached+.invalid-feedback {
    display: none;
}

.was-validated .dropzone {
    border-color: var(--bs-danger);
}

.was-validated .dropzone.dz-max-files-reached {
    border-color: var(--bs-success);
} */

    .dashboard-container {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
    }

    .dashboard-item {
        flex: 1;
        text-align: center;
    }

    .locat-marker {
        position: relative;
        height: 40px;
        width: 30px;
        text-align: center;
        line-height: 32px;
        color: white;
    }

    .locat-marker::before {
        content: "\f041";
        position: absolute;
        font: var(--fa-font-sharp-solid);
        font-size: 40px !important;
        left: 0;
        top: 0;
        z-index: -1;
        color: var(--bs-indigo);
    }

    #small-map {
        width: 100%;
        height: 50%;
    }

    @keyframes bg {
        0% {
            background: rgba(var(--bs-indigo-rgb), .1);
        }

        100% {
            background: var(--bs-light);
        }
    }

    .top-8 {
        top: -8px;
    }

    .dependedField {
        display: none;
    }

    .dependedField.active {
        display: block;
    }

    .icon {
        width: 40px;
        height: 40px;
        color: red;
        background-color: #fff0f0;
        text-align: center;
        line-height: 40px;
        border-radius: 50%;
    }

    .AD-form {
        display: none;
        position: relative;
    }

    .AD-form.active {
        display: block;
    }

    .AD-Form-close {
        position: absolute;
        top: 0;
        right: 0;
        width: 24px;
        height: 24px;
        line-height: 24px;
        text-align: center;
        border-radius: 50%;
        background-color: var(--bs-danger);
        color: white;
    }

    #filter label,
    #filter .label {
        font-size: 13px;
    }

    .hiddenField {
        display: none;
    }

    .hiddenField.active {
        display: block;
    }

    .label-item.active .label-btn {
        color: white;
    }

    @media screen and (min-width:768px) {
        .br-md-x {
            border-left: 1px dashed var(--bs-gray-400);
            border-right: 1px dashed var(--bs-gray-400);
        }

        .br-md-end {
            border-right: 1px dashed var(--bs-gray-400);
        }
    }

    @media screen and (min-width:991px) {
        #tag-container {
            width: calc(100% - 258px);
        }

        .top-bar-btns {
            width: 250px;
        }

        .asset-panel.active .asset-left {
            width: 50%;
            transition: all ease .5s;
        }

        .asset-panel.active .asset-left .asset-input-col {
            width: calc((100% - 8px)/2);
        }

        .asset-panel .asset-left .asset-input-col {
            width: calc((100% - 24px)/4);
        }

        .right-side-body,
        .map-modal {
            width: calc(100% - 70px);
            margin-left: 70px;
        }

        .panel.active .right-side-body,
        .panel.active .map-modal {
            width: calc(100% - 270px);
            margin-left: 270px;
        }

        .sidebar {
            width: 70px;
        }

        .panel.active .sidebar {
            width: 270px;
        }

        .panel:not(.active) .sidebar header {
            justify-content: center;
        }

        .navbar .small,
        .panel.active .navbar .small::before {
            font-size: 0;
        }

        .panel.active .navbar .small,
        .navbar .small::before {
            font-size: 12px;
        }

        .navbar .small::before {
            content: '---';
            color: var(--bs-gray-600);
            text-align: center;
            display: block;
        }

        .logo img:nth-child(1) {
            display: none;
        }

        .panel.active .logo img:nth-child(1) {
            display: block;
        }

        .panel.active .logo img:nth-child(2),
        .close-side-bar {
            display: none;
        }

        .left-side {
            width: calc(75% - 4px);
        }

        .right-side {
            width: calc(25% - 4px);
            height: 100%;
            position: sticky;
            top: 0;
        }
    }

    @media screen and (max-width:991px) {
        #expand-map {
            display: none;
        }

        .sidebar {
            width: 270px;
            left: -270px;
            z-index: 2000;
        }

        .panel.active .sidebar {
            left: 0px;
        }

        .panel .sidebar header {
            justify-content: space-between;
        }

        .side-panel.side-panel-lg {
            width: 100%;
        }

        .right-side-body,
        .map-modal {
            width: 100%;
        }

        .navbar .small {
            font-size: 12px;
        }

        .logo img:nth-child(1) {
            width: 120px;
        }

        .logo img:nth-child(2) {
            display: none;
        }
    }

    .icon-color {
        width: 40px;
        height: 40px;
        color: #3430d8;
        background-color: #efeefd;
        text-align: center;
        line-height: 40px;
        border-radius: 50%;
    }

    .idam-loader {
        display: none;
        position: fixed;
        left: 0px;
        top: 0px;
        width: 100%;
        height: 100vh;
        z-index: 9999;
        background-color: #0b0b0bb8;
    }

    .loader-wrapper {
        display: flex;
        height: 100%;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        color: #fff;
        font-size: 40px;
    }

    .idam-loader.active {
        display: block;
    }

    #map .fa-gopuram,
    #map .fa-place-of-worship {
        color: #ff4d00 !important;
    }

    #map .fa-church {
        color: blue !important;
    }

    #map .fa-mosque,
    #map .fa-star-and-crescent,
    #map .fa-fort {
        color: green !important;
    }

    .fa-person-booth,
    .fa-hospital,
    .fa-mosque,
    .fa-shield-plus,
    .fa-building-columns,
    .fa-handshake,
    .fa-chart-user,
    .fa-list-alt,
    .fa-landmark,
    .fa-building {
        color: #ff4d00 !important;
    }

    .fa-school,
    .fa-gopuram,
    .fa-fort,
    .fa-cross,
    .fa-building-columns,
    .fa-wifi,
    .fa-people,
    .fa-area-chart,
    .fa-users,
    .fa-people-carry-box {
        color: blue !important;
    }

    .fa-building-columns,
    .fa-church,
    .fa-star-and-crescent,
    .fa-not-equal,
    .fa-place-of-,
    .fa-truck-field,
    .fa-,
    .fa-user-hard-hat,
    .fa-hand-holding-droplet,
    .fa-house-leave,
    .fa-expand,
    .fa-gavel {
        color: green !important;
    }

    /*responsive*/
    @media (max-width: 600px) {

        label,
        .label {
            font-size: 16px;
        }

        .form-control-sm {
            line-height: 1.5;
            /* padding: 0.7rem 0.75rem; */
            padding: 0.9rem 0.95rem;
            font-size: 1rem;
            border-radius: 0.2rem;
        }

        .select2-container--default .select2-selection--single .select2-selection__arrow {
            height: 52px;
        }

        .select2-container .select2-selection--single {
            height: 52px;
        }

        .select2-container--default .select2-selection--single .select2-selection__rendered {
            line-height: 52px;
        }

        .select2-container--default .select2-selection--single .select2-selection__clear {
            height: 52px;

        }

        .select2-container .select2-selection--single .select2-selection__clear {
            font-size: 1.3em;
        }

        input::placeholder {
            font-size: 15px;
        }

        .select2-container--default .select2-selection--single .select2-selection__placeholder {
            font-size: 15px;
        }

        .text-capitalize {
            text-transform: capitalize !important;
            font-size: 16px;
        }

        .survey-form-footer {
            padding-bottom: 15px;
        }

        #tag-container {
            display: none !important;
        }

        .label-group {
            padding: 12px 4px;
        }

        .label-group .label-btn {
            padding: 1px 5px;
        }


        .input-group-text {
            display: flex;
            align-items: center;
            font-size: 18px;
            padding: 0 0px;
            height: 100%;
            justify-content: center;
        }

        .card-pagination {
            margin: auto;
        }

        #excel_download_grid {
            display: none;
        }

        #excel_download_summary {
            display: none;
        }

        #user_list_table_paginate,
        #dt_business_companies_paginate {
            margin: auto;
            margin-top: 4px;
        }

        .back-btn {
            display: none !important;
        }

        .btn-sm {
            height: 40px;
            line-height: 40px;
        }

        .btn-sm i {
            width: 40px;
        }

        .btn-sm span {
            line-height: 40px;
        }

        .card-pagination button,
        .card-pagination .dots {
            min-width: 32px;
            height: 32px;
            line-height: 32px;
        }

        .icon-color {
            line-height: 48px;
        }

        .close-side-bar {
            font-size: 20px;
        }

        .dropdown .icon-fa {
            width: 38px;
            height: 38px;
            line-height: 42px;
        }

        .dropdown .icon-fa .fa-regular {
            font-size: 18px;
        }

        .dropdown-menu .dropdown-item {
            font-size: 18px;
            padding: 0.3rem 0.6rem;
        }

        .side-bar-toggler .fa-bars {
            font-size: 20px;
            margin-left: 10px;
        }

        #m_location_type_id span {
            padding: 18px !important;
        }

        #m_location_type_id span i {
            font-size: 25px;
        }

        .selected-label {
            background: red !important;

        }

        .navbar .nav-link {
            height: 48px
        }

        .navbar .nav-link .nav-icon {
            line-height: 46px;
        }

        #summary_map {
            height: 100% !important;
        }

        #summary_maps {
            height: 70vh !important;
        }



        .mark_btn,
        .satellite_view,
        .street_view {
            height: 50px;
            display: flex;
            justify-content: center;
            align-items: center;
        }

        .mark_btn i {
            background-color: #198754 !important;
            font-size: 13px;
        }

        .icon-color i {
            font-size: 21px;
        }

        .map-styled {
            position: relative;
            height: 85% !important;
        }

        #lock_map_btn {
            position: absolute;
            top: 10px;
            right: 10px;
            z-index: 1000;
        }
    }

    #m_location_type_id span {
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        background: #f7f7f7;
        padding: 5px;
    }

    #m_location_type_id span i {
        font-size: 30px;
        margin-top: 6px;
    }

    .invalid-feedback-location {
        color: #dc3545;
        width: 100%;
        margin-top: 0.25rem;
        font-size: 0.875em;
    }

    table.dataTable thead th {
        white-space: nowrap !important;
    }

    @media (max-width: 600px) {

        .select2-search__field {
            display: none;
        }

        .select2-container--open .select2-dropdown--below,
        .select2-container--open .select2-dropdown--above {
            position: fixed !important;
            left: 0 !important;
            width: 100% !important;
            z-index: 9999 !important;
            border: 2px solid #ced4da;
            box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
            height: 90vh;
            background-color: #e9ecef;
        }

        .select2-results__option {

            background-color: white;
            margin: 12px;
            font-size: 14px;
            padding: 12px;
        }

        .entries,
        .option_value,
        .card-pagination button {
            font-weight: 500 !important;
            font-size: 14px;
        }

        .option_value {
            display: none !important;
        }

        .footer {
            flex-direction: column;
        }
    }

    .locat-marker i {
        color: white !important;
    }

    .submit_btn_summary {
        position: fixed;
        bottom: 0;
        z-index: 1000;
        background: white;
        text-align: right !important;
        right: 0;

    }

    .submit_btn_summary button {
        margin: 5px;
    }

    .custom-margin {
        margin-right: 15px; 
    }
    .custome{
        width: 100%;
        justify-content: end;
    }
    @media (min-width: 767px) {
        .custome {
        width: 50%;
        }
    }