body {
    background: var(--tblr-white);
}

.back-to-top {
    position: fixed;
    bottom: 20px;
    right: 12px;
    opacity: 0;
    pointer-events: none;
    transition: opacity .3s ease;
    z-index: 9999;
}

.back-to-top.show {
    opacity: 1;
    pointer-events: auto;
}

.breadcrumb li,
.breadcrumb li a {
    font-size: 12px;
    opacity: .8 !important;
}

.page {
    min-height: 100vh !important;
}

/* =========================
   Preloader
========================= */
#preloader {
    position: fixed;
    inset: 0;
    background: var(--tblr-body-bg);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: opacity .4s ease, visibility .4s ease;
}

#preloader.hidden {
    opacity: 0;
    visibility: hidden;
}

.preloader-inner {
    text-align: center;
}

.preloader-inner img {
    width: 150px;
}


/* ======================
   Light Theme
====================== */
:root,
[data-bs-theme=light] {
    --theme-primary: #1BAA9B;
    --theme-primary-rgb: 27, 170, 155;

    --theme-cyan: #00ACC1;
    --theme-cyan-rgb: 0, 172, 193;
    --theme-cyan-dark: #00838F;
    --theme-cyan-dark-rgb: 0, 131, 143;
    --theme-cyan-darker: #005970;
    --theme-cyan-darker-rgb: 0, 89, 112;

    --theme-purple: #7279AF;
    --theme-purple-rgb: 114, 121, 175;

    --theme-border-color-translucent: rgba(27, 170, 155, 0.14);
    --theme-box-shadow-input: 0 1px 1px rgba(var(--theme-body-color-rgb), 0.06);

    --theme-body-color: #1a2c2a;
    --theme-body-color-rgb: 26, 44, 42;

    --theme-pagination-active-bg: rgba(var(--theme-primary-rgb), .1);
    --theme-pagination-active-border-color: var(--theme-primary);

    --theme-box-shadow: rgba(var(--theme-cyan-rgb), 0.04) 0 2px 4px 0;

    --tblr-primary: #0054a6;
    --tblr-secondary: #666666;
    --tblr-success: #2fb344;
    --tblr-info: #4299e1;
    --tblr-warning: #f76707;
    --tblr-danger: #d63939;
    --tblr-light: #f7f7f7;
    --tblr-dark: #182433;
    --tblr-muted: #667382;

    --tblr-primary-rgb: 0, 84, 166;
    --tblr-secondary-rgb: 102, 102, 102;
    --tblr-success-rgb: 47, 179, 68;
    --tblr-info-rgb: 66, 153, 225;
    --tblr-warning-rgb: 247, 103, 7;
    --tblr-danger-rgb: 214, 57, 57;
    --tblr-light-rgb: 252, 253, 254;
    --tblr-dark-rgb: 24, 36, 51;
    --tblr-muted-rgb: 102, 115, 130;
    --tblr-blue-rgb: 0, 84, 166;
    --tblr-azure-rgb: 66, 153, 225;
    --tblr-indigo-rgb: 66, 99, 235;
    --tblr-purple-rgb: 174, 62, 201;
    --tblr-pink-rgb: 214, 51, 108;
    --tblr-red-rgb: 214, 57, 57;
    --tblr-orange-rgb: 247, 103, 7;
    --tblr-yellow-rgb: 245, 159, 0;
    --tblr-lime-rgb: 116, 184, 22;
    --tblr-green-rgb: 47, 179, 68;
    --tblr-teal-rgb: 12, 166, 120;
    --tblr-cyan-rgb: 23, 162, 184;
    --tblr-facebook-rgb: 24, 119, 242;
    --tblr-twitter-rgb: 29, 161, 242;
    --tblr-linkedin-rgb: 10, 102, 194;
    --tblr-google-rgb: 220, 78, 65;
    --tblr-youtube-rgb: 255, 0, 0;
    --tblr-vimeo-rgb: 26, 183, 234;
    --tblr-dribbble-rgb: 234, 76, 137;
    --tblr-github-rgb: 24, 23, 23;
    --tblr-instagram-rgb: 228, 64, 95;
    --tblr-pinterest-rgb: 189, 8, 28;
    --tblr-vk-rgb: 99, 131, 168;
    --tblr-rss-rgb: 255, 165, 0;
    --tblr-flickr-rgb: 0, 99, 220;
    --tblr-bitbucket-rgb: 0, 82, 204;
    --tblr-tabler-rgb: 0, 84, 166;
    --tblr-primary-text-emphasis: #002242;
    --tblr-secondary-text-emphasis: #292e34;
    --tblr-success-text-emphasis: #13481b;
    --tblr-info-text-emphasis: #1a3d5a;
    --tblr-warning-text-emphasis: #632903;
    --tblr-danger-text-emphasis: #561717;
    --tblr-light-text-emphasis: #3a4859;
    --tblr-dark-text-emphasis: #3a4859;
    --tblr-primary-bg-subtle: #ccdded;
    --tblr-secondary-bg-subtle: #e0e3e6;
    --tblr-success-bg-subtle: #d5f0da;
    --tblr-info-bg-subtle: #d9ebf9;
    --tblr-warning-bg-subtle: #fde1cd;
    --tblr-danger-bg-subtle: #f7d7d7;
    --tblr-light-bg-subtle: #fbfcfd;
    --tblr-dark-bg-subtle: #bbc3cd;
    --tblr-primary-border-subtle: #99bbdb;
    --tblr-secondary-border-subtle: #c2c7cd;
    --tblr-success-border-subtle: #ace1b4;
    --tblr-info-border-subtle: #b3d6f3;
    --tblr-warning-border-subtle: #fcc29c;
    --tblr-danger-border-subtle: #efb0b0;
    --tblr-light-border-subtle: #eef1f4;
    --tblr-dark-border-subtle: #929dab;
    --tblr-white-rgb: 255, 255, 255;
    --tblr-black-rgb: 0, 0, 0;
    --tblr-font-sans-serif: -apple-system, BlinkMacSystemFont, San Francisco, Segoe UI, Roboto, Helvetica Neue, sans-serif;
    --tblr-font-monospace: Menlo, Monaco, Consolas, Liberation Mono, Courier New, monospace;
    --tblr-gradient: linear-gradient(180deg, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0));
    --tblr-body-font-family: var(--tblr-font-sans-serif);
    --tblr-body-font-size: 0.875rem;
    --tblr-body-font-weight: 400;
    --tblr-body-line-height: 1.4285714286;
    --tblr-body-color: #182433;
    --tblr-body-color-rgb: 24, 36, 51;
    --tblr-body-bg: #f6f8fb;
    --tblr-body-bg-rgb: 246, 248, 251;
    --tblr-emphasis-color: #182433;
    --tblr-emphasis-color-rgb: 24, 36, 51;
    --tblr-secondary-color: rgba(24, 36, 51, 0.75);
    --tblr-secondary-color-rgb: 24, 36, 51;
    --tblr-secondary-bg: #eef1f4;
    --tblr-secondary-bg-rgb: 238, 241, 244;
    --tblr-tertiary-color: rgba(24, 36, 51, 0.5);
    --tblr-tertiary-color-rgb: 24, 36, 51;
    --tblr-tertiary-bg: #f6f8fb;
    --tblr-tertiary-bg-rgb: 246, 248, 251;
    --tblr-heading-color: inherit;
    --tblr-link-color: #0054a6;
    --tblr-link-color-rgb: 0, 84, 166;
    --tblr-link-decoration: none;
    --tblr-link-hover-color: #004385;
    --tblr-link-hover-color-rgb: 0, 67, 133;
    --tblr-link-hover-decoration: underline;
    --tblr-code-color: var(--tblr-gray-600);
    --tblr-highlight-bg: #fdeccc;
    --tblr-border-width: 1px;
    --tblr-border-style: solid;
    --tblr-border-color: #dadfe5;
    --tblr-border-color-translucent: rgba(4, 32, 69, 0.14);
    --tblr-border-radius: 4px;
    --tblr-border-radius-sm: 2px;
    --tblr-border-radius-lg: 8px;
    --tblr-border-radius-xl: 1rem;
    --tblr-border-radius-xxl: 2rem;
    --tblr-border-radius-2xl: var(--tblr-border-radius-xxl);
    --tblr-border-radius-pill: 100rem;
    --tblr-box-shadow: rgba(var(--tblr-body-color-rgb), 0.04) 0 2px 4px 0;
    --tblr-box-shadow-sm: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
    --tblr-box-shadow-lg: 0 1rem 3rem rgba(0, 0, 0, 0.175);
    --tblr-box-shadow-inset: 0 0 transparent;
    --tblr-focus-ring-width: 0.25rem;
    --tblr-focus-ring-opacity: 0.25;
    --tblr-focus-ring-color: rgba(var(--tblr-primary-rgb), 0.25);
    --tblr-form-valid-color: #2fb344;
    --tblr-form-valid-border-color: #2fb344;
    --tblr-form-invalid-color: #d63939;
    --tblr-form-invalid-border-color: #d63939;
}

.bg-primary {
    background-color: var(--theme-primary) !important;
}

.bg-cyan-darker {
    background-color: var(--theme-cyan-darker) !important;
}


.text-primary {
    color: var(--theme-primary) !important;
}

.text-cyan {
    color: var(--theme-cyan) !important;
}

.text-cyan-dark {
    color: var(--theme-cyan-dark) !important;
}

/* ======================
   Dark Theme
====================== */
:root[data-bs-theme="dark"] {}



/* ====================
Font Style 
====================*/
h1,
h2,
h3,
h4,
h5,
h6,
p {
    margin-bottom: 0;
}

p {
    color: var(--tblr-dark);
}


/* ====================
Font Size 
====================*/
a {
    font-size: .8rem;
}

.small-8 {
    font-size: .8rem;
}

.small-7 {
    font-size: .7rem;
}

.small-65 {
    font-size: .65rem;
}

.small-6 {
    font-size: .6rem;
}

/* ====================
Login
====================*/
.login-bg {
    background: #11665D;
    background: linear-gradient(180deg, rgba(17, 102, 93, 1) 0%, rgba(28, 167, 153, 1) 100%);
}

/* ====================
Button
====================*/
.btn-primary {
    --tblr-btn-color: var(--tblr-primary-fg);
    --tblr-btn-bg: var(--theme-primary);
    --tblr-btn-hover-color: var(--tblr-primary-fg);
    --tblr-btn-hover-bg: rgba(var(--theme-primary-rgb), .8);
    --tblr-btn-active-color: var(--tblr-primary-fg);
    --tblr-btn-active-bg: rgba(var(--theme-primary-rgb), .8);
    --tblr-btn-disabled-bg: var(--theme-primary);
    --tblr-btn-disabled-color: var(--tblr-primary-fg);
    --tblr-btn-box-shadow: var(--tblr-box-shadow-input);
}

.btn-inverse-primary {
    --tblr-btn-color: var(--theme-primary);
    --tblr-btn-bg: rgba(var(--theme-primary-rgb), .1);
    --tblr-btn-hover-color: var(--theme-primary);
    --tblr-btn-hover-bg: rgba(var(--theme-primary-rgb), .15);
    --tblr-btn-active-color: var(--theme-primary);
    --tblr-btn-active-bg: rgba(var(--theme-primary-rgb), .15);
    --tblr-btn-disabled-bg: rgba(var(--theme-primary-rgb), .1);
    --tblr-btn-disabled-color: var(--theme-primary);
    --tblr-btn-box-shadow: rgba(var(--theme-primary-rgb), .15);
    border: 0;
}

.btn-inverse-secondary {
    --tblr-btn-color: var(--tblr-secondary);
    --tblr-btn-bg: rgba(var(--tblr-secondary-rgb), .1);
    --tblr-btn-hover-color: var(--tblr-secondary);
    --tblr-btn-hover-bg: rgba(var(--tblr-secondary-rgb), .15);
    --tblr-btn-active-color: var(--tblr-secondary);
    --tblr-btn-active-bg: rgba(var(--tblr-secondary-rgb), .15);
    --tblr-btn-disabled-bg: rgba(var(--tblr-secondary-rgb), .1);
    --tblr-btn-disabled-color: var(--tblr-secondary);
    --tblr-btn-box-shadow: rgba(var(--tblr-secondary-rgb), .15);
    border: 0;
}


.btn-inverse-light {
    --tblr-btn-color: var(--theme-primary);
    --tblr-btn-bg: var(--tblr-white);
    --tblr-btn-hover-color: var(--theme-primary);
    --tblr-btn-hover-bg: rgba(var(--tblr-light-rgb), .95);
    --tblr-btn-active-color: var(--theme-primary);
    --tblr-btn-active-bg: var(--tblr-secondary-bg);
    --tblr-btn-disabled-bg: var(--tblr-white);
    --tblr-btn-disabled-color: rgba(var(--theme-primary-rgb), .50);
    --tblr-btn-box-shadow: rgba(var(--theme-primary-rgb), .15);
    border: 0;
}

/* ====================
Background Style
====================*/
.card.title-bg {
    background-image: url(../img/background/title-bg.png);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    min-height: 100px;
    height: 100%;
    border: none;
    border-radius: 8px;
    color: white;
    overflow: hidden;
}

.card.title-bg p {
    color: white !important;
}

.card.title-bg .card-body {
    position: relative;
    z-index: 1;
}

/* ====================
Form
====================*/
.form-label {
    margin-bottom: .5rem;
    font-size: .8rem;
}

.form-control {
    font-size: .8rem;
}

.form-check-input:checked {
    background-color: var(--theme-primary);
    border-color: var(--theme-border-color-translucent);
}

.form-check-input:focus,
.form-control:focus,
.input-group-flat:focus-within {
    box-shadow: 0 0 0 .25rem rgba(var(--theme-primary-rgb), .25);
}

.form-control[readonly] {
    background-color: var(--tblr-light);
    opacity: 1;
}

/* ====================
Icon style
====================*/
.icon-wrap {
    width: 40px;
    height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.icon-wrap img {
    width: 20px;
    height: 20px;
    object-fit: contain;
}

/* SHAPES */
.icon-wrap.round {
    border-radius: 50%;
}

.icon-wrap.square {
    border-radius: 10px;
}

/* ====================
Navbar style
====================*/
.navbar-expand-md .nav-item.active:after {
    border-bottom-width: 0px;
}

.navbar-expand-md .nav-item.active {
    color: rgba(27, 170, 155, 1);
}

@media (min-width: 768px) {
    .navbar-nav.nav-pill {
        background-color: var(--tblr-gray-200);
        border-radius: 999px;
    }
}


/* ====================
Map style
====================*/
.map-wrapper {
    height: 85vh;
}

/* Map */
#map {
    height: 100%;
    width: 100%;
    border-radius: .8rem;
}

.map-info {
    position: absolute;
    top: 10px;
    right: 10px;
    bottom: 10px;
    width: calc(22% - 10px);
    height: calc(100% - 30px);
    border-radius: 0.8rem;
    z-index: 800;
    color: white;
}

@media (max-width: 1399.98px) {
    .map-info {
        width: calc(30% - 10px);
    }
}

@media (max-width: 991.98px) {
    .map-wrapper {
        height: 85vh;
    }

    .map-info {
        width: 100%;
        height: 40%;
        bottom: 0;
        top: auto;
        right: 0;
        border-radius: .8rem;
    }

    .leaflet-bottom.leaflet-left {
        bottom: 40%;
    }

}

.map-info .card-body {
    height: 100%;
}

.map-info.card {
    background: rgba(var(--tblr-dark-rgb), 0.4);
    backdrop-filter: blur(3px);
    -webkit-backdrop-filter: blur(8px);
}

.map-info .card {
    border-radius: .8rem;
}

.marker-with-fa {
    display: flex;
    align-items: center;
    flex-direction: row;
}

.marker-with-fa .marker-label {
    background: var(--theme-cyan-darker);
    color: white;
    padding: 2px 10px 2px 15px;
    border-radius: 0 8px 8px 0;
    font-size: 12px;
    margin-left: -12px;
    white-space: nowrap;
}

.marker-with-fa .fasa-label {
    background: var(--theme-purple);
    color: white;
    padding: 2px 10px 2px 15px;
    border-radius: 0 8px 8px 0;
    font-size: 12px;
    margin-left: -12px;
    white-space: nowrap;
}

.leaflet-marker-icon {
    z-index: 500 !important;
}

.leaflet-overlay-pane svg {
    z-index: 200;
}

#mapBackBtn {
    position: absolute;
    top: 16px;
    left: 16px;
    z-index: 1000;
    background: rgba(255, 255, 255, 0.75);
    color: #1d1d1d;
    border: none;
    border-radius: 50%;
    width: 30px;
    height: 30px;
    font-size: 13px;
    cursor: pointer;
}

#mapBackBtn:hover {
    background: rgba(255, 255, 255, 0.9);
}

.leaflet-top.leaflet-left {
    top: 50px;
    left: 5px
}

.leaflet-coords {
    display: flex;
    align-items: center;
    gap: 6px;
    background: rgba(255, 255, 255, .95);
    padding: 6px 8px;
    font-size: 12px;
    border-radius: 6px;
    box-shadow: 0 2px 6px rgba(0, 0, 0, .15);
}

.coord-text {
    line-height: 1.2;
}

.coord-copy {
    border: none;
    background: transparent;
    cursor: pointer;
    font-size: 14px;
    padding: 2px;
}

.coord-copy:hover {
    opacity: .7;
}


/* ====================
Card Style
====================*/
.card.card-opacity-70 {
    background-color: rgb(255, 255, 255, .7);
}

/* ====================
Settings
====================*/
.border-settings {
    border: 3px solid rgba(8, 125, 141, 0.6);
    width: 60px;
    border-radius: 1rem;
    transition: all .4s;
}

.bg-settings:hover>.border-settings {
    border: 3px solid rgba(114, 121, 175, 1);
    width: 90px;
}

.bg-settings {
    position: relative;
    background-color: var(--tblr-dark);
    overflow: hidden;
}

.bg-settings::before {
    content: "";
    position: absolute;
    top: 70%;
    left: 10%;
    width: 150px;
    height: 8px;
    background: var(--theme-primary);
    border-radius: 1rem;
    transform: translate(-50%, -50%) scale(50);
    transition: transform .3s cubic-bezier(.4, 0, .2, 1);
    z-index: 0;
}

.bg-settings:hover::before {
    transform: translate(-50%, -50%) scale(.0);
}

.bg-settings>* {
    position: relative;
    z-index: 1;
}

.settings-icon {
    position: absolute;
    top: 30%;
    right: 10px;
    width: 80px;
    height: 100px;
    background-size: cover;
    background-repeat: no-repeat;
    z-index: 2;
    transform: scale(2);
    transition: all .3s;
}

.bg-settings:hover>.settings-icon {
    transform: scale(3);
}

.bg-settings-1 .settings-icon {
    background-image: url(../img/icons/settings-1.png);
}

.bg-settings-2 .settings-icon {
    background-image: url(../img/icons/settings-2.png);
}

.bg-settings-3 .settings-icon {
    background-image: url(../img/icons/settings-3.png);
}

.table th {
    text-transform: capitalize !important;
}

.table td {
    text-wrap: nowrap;
    font-size: smaller;
}

/* ====================
Data Table
====================*/
#userTable_wrapper .custom-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.2rem;
    margin-top: 2rem;
}

.active>.page-link,
.page-link.active {
    z-index: 3;
    color: var(--theme-primary);
    background-color: var(--theme-pagination-active-bg);
    border: 1px solid var(--theme-pagination-active-border-color);
}

.page-link:focus {
    box-shadow: 0 0 0 .25rem rgba(var(--theme-primary-rgb), .0);
}

#userTable_wrapper .dataTables_paginate .page-item.active .page-link {
    background-color: rgb(27, 170, 155, .2);
    /* Tabler / Bootstrap 主色 */
    border-color: #1BAA9B;
    color: #fff;
}

#userTable_wrapper .dataTables_paginate .page-item .page-link:hover {
    background-color: #0b5ed7;
    color: #fff;
    border-color: #0b5ed7;
}


table.dataTable thead span.dt-column-order::before,
table.dataTable thead span.dt-column-order::after {
    opacity: 0 !important;
}

table.dataTable th .dt-column-order {
    display: inline-block;
    width: 16px;
    height: 16px;
    background: url('/assets/img/tabler-icons/outline/arrows-sort.svg') no-repeat center center;
    background-size: contain;
}

table.dataTable th.dt-ordering-asc .dt-column-order {
    background: url('/assets/img/tabler-icons/outline/chevron-up.svg') no-repeat center center;
    background-size: contain;
}

table.dataTable th.dt-ordering-desc .dt-column-order {
    background: url('/assets/img/tabler-icons/outline/chevron-down.svg') no-repeat center center;
    background-size: contain;
}

th.no-sort span.dt-column-order {
    display: none !important;
}

table.dataTable thead th .dt-column-header {
    display: flex;
    align-items: center;
    justify-content: flex-start;
}

table.dataTable thead th .dt-column-header span.dt-column-order {
    order: -1;
}

table.dataTable thead>tr>th.dt-orderable-asc:hover,
table.dataTable thead>tr>th.dt-orderable-desc:hover,
table.dataTable thead>tr>td.dt-orderable-asc:hover,
table.dataTable thead>tr>td.dt-orderable-desc:hover,
table.dataTable thead>tr>th:focus,
table.dataTable thead>tr>td:focus {
    outline: none !important;
    outline-offset: 0 !important;
    box-shadow: none !important;
}