.table > tbody > tr > td, .table > tbody > tr > th, .table > tfoot > tr > td, .table > tfoot > tr > th, .table > thead > tr > td, .table > thead > tr > th {
    vertical-align: middle;
}

.pac-container {
    z-index: 10000 !important;
}

.main-footer {
    padding: 5px 15px;
}

.install-section {
    margin-top: 16px;
}

.install-command-block {
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 8px;
    padding: 12px;
    margin-bottom: 12px;
}

.install-command-label {
    font-weight: 600;
    margin-bottom: 8px;
}

.install-command {
    background: rgba(0, 0, 0, 0.2);
    border-radius: 6px;
    padding: 10px;
    margin-bottom: 10px;
    white-space: pre-wrap;
    word-break: break-word;
    overflow-wrap: anywhere;
    max-width: 100%;
}

.install-copy {
    width: 100%;
}

.install-steps {
    margin-bottom: 12px;
}

@media (max-width: 768px) {
    .modal-footer {
        display: flex;
        flex-direction: column;
        gap: 10px;
        align-items: stretch;
    }
}

.text-dark {
    color: #444;
}

.callout-gray {
    background-color: #EEE;
    border-left: 5px solid #DDD;
}

.callout-gray a {
    color: #333;
}

.callout-gray a:hover {
    color: #444;
}

@media (min-width: 767px) {
    .modal-dialog {
        width: 760px;
    }
}

.notopborder { border-top: 0px !important; }

.whitetext { color: #FFF; }

.dt-margin {
    margin-left: 0px !important;
    margin-right: 0px !important;
}

.todo-list {
    min-height: 40px;
}

.no-sort::after { display: none !important; }
.no-sort { pointer-events: none !important; cursor: default !important; }

.timeline-item {
    background-color: var(--bs-body-bg, #fff) !important;
    border: 1px solid var(--bs-border-color, #f1f1f1) !important;
    box-shadow: 0 1px 1px rgba(0, 0, 0, 0.1);
}

.timeline-image {
    left: 16px;
    position: absolute;
    top: 0;
}

.chart-legend ul {
    list-style-type: none;
}

.chart-legend li span {
    display: inline-block;
    width: 10px;
    height: 10px;
    margin-top: 4px;
    margin-right: 5px;
    border-radius: 50%;
}

.fullboby-bg {
    background: url(../assets/bg2.jpg) no-repeat center center fixed;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}

.fullboby-bg a {
    color: #FFF;
}

.fullboby-bg .login-logo {
    color: #FFF;
}

.roles h4 {
    padding-top: 12px;
    padding-bottom: 0px;
    margin-bottom: 0px;
}

.dt-buttons {
    margin-left: -15px;
}

.dt-buttons .btn-default {
    background-color: var(--bs-body-bg, #FFF);
    padding: 3px 6px;
    font-size: 12px;
    border-radius: 0px;
}

table.dataTable {
    max-width: none;
}

canvas {
    z-index: 999999;
}

.chart {
    overflow: visible;
    overflow-x: visible;
    overflow-y: visible;
}

.fileinput {
    padding-top: 5px;
    padding-bottom: 5px;
}

.datepicker {
    z-index: 9999 !important;
}

td .btn-group {
    display: flex;
}

.label-lite-blue {
    background-color: var(--bs-body-bg, #FFF);
    color: #0073b7;
    border: 1px solid #0073b7;
}

.label-lite-green {
    background-color: var(--bs-body-bg, #FFF);
    color: #00a65a;
    border: 1px solid #00a65a;
}

.label-lite-yellow {
    background-color: var(--bs-body-bg, #FFF);
    color: #f39c12;
    border: 1px solid #f39c12;
}

.progress-circle {
    --percent: 0;
    --size: 26px;
    --thickness: 4px;
    --progress-color: #87CEEB;
    --track-color: #eeeeee;
    --center-color: var(--bs-body-bg, #fff);
    width: var(--size);
    height: var(--size);
    border-radius: 50%;
    background: conic-gradient(var(--progress-color) calc(var(--percent) * 1%), var(--track-color) 0);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    position: relative;
    vertical-align: middle;
}

.progress-circle::after {
    content: "";
    width: calc(var(--size) - (var(--thickness) * 2));
    height: calc(var(--size) - (var(--thickness) * 2));
    background: var(--center-color);
    border-radius: 50%;
    display: block;
}

.progress-circle--sm {
    --size: 20px;
    --thickness: 3px;
}

.label-lite-purple {
    background-color: var(--bs-body-bg, #FFF);
    color: #605ca8;
    border: 1px solid #605ca8;
}

/* ===== Modals dark mode ===== */
[data-bs-theme="dark"] #myModal .modal-content,
[data-bs-theme="dark"] .modal-dark {
    --modal-dark-bg: #1f262e;
    --modal-dark-surface: #111821;
    --modal-dark-elevated: #1b222b;
    --modal-dark-border: #2f3a45;
    --modal-dark-border-strong: #4b5b6b;
    --modal-dark-text: #e9ecef;
    --modal-dark-muted: #9aa4b2;
    --modal-dark-accent: #2f81f7;
}

[data-bs-theme="dark"] .modal-content {
    background-color: var(--modal-dark-bg);
    color: var(--modal-dark-text);
    border-color: var(--modal-dark-border);
}

[data-bs-theme="dark"] .modal-header,
[data-bs-theme="dark"] .modal-footer {
    border-color: var(--modal-dark-border);
}

[data-bs-theme="dark"] .modal-content .form-label,
[data-bs-theme="dark"] .modal-content .modal-dark-label {
    color: var(--modal-dark-text);
}

[data-bs-theme="dark"] .modal-content .form-control,
[data-bs-theme="dark"] .modal-content .form-select,
[data-bs-theme="dark"] .modal-content textarea,
[data-bs-theme="dark"] .modal-content select {
    background-color: var(--modal-dark-surface);
    color: var(--modal-dark-text);
    border-color: var(--modal-dark-border);
}

[data-bs-theme="dark"] .modal-content .form-control::placeholder {
    color: var(--modal-dark-muted);
}

[data-bs-theme="dark"] .modal-content .form-control:focus,
[data-bs-theme="dark"] .modal-content .form-select:focus,
[data-bs-theme="dark"] .modal-content textarea:focus,
[data-bs-theme="dark"] .modal-content select:focus {
    border-color: var(--modal-dark-border-strong);
    box-shadow: 0 0 0 0.2rem rgba(47, 129, 247, 0.25);
}

[data-bs-theme="dark"] .modal-content .select2-container--default .select2-selection--single,
[data-bs-theme="dark"] .modal-content .select2-container--default .select2-selection--multiple,
[data-bs-theme="dark"] .select2-container--default .select2-selection--single,
[data-bs-theme="dark"] .select2-container--default .select2-selection--multiple {
    background-color: var(--modal-dark-surface) !important;
    border-color: var(--modal-dark-border) !important;
    color: var(--modal-dark-text) !important;
}

[data-bs-theme="dark"] .modal-content .select2-container--default .select2-selection--single .select2-selection__rendered,
[data-bs-theme="dark"] .select2-container--default .select2-selection--single .select2-selection__rendered,
[data-bs-theme="dark"] .modal-content .select2-container--default .select2-selection--single .select2-selection__placeholder,
[data-bs-theme="dark"] .select2-container--default .select2-selection--single .select2-selection__placeholder,
[data-bs-theme="dark"] .modal-content .select2-container--default .select2-selection--multiple .select2-selection__rendered,
[data-bs-theme="dark"] .select2-container--default .select2-selection--multiple .select2-selection__rendered {
    color: var(--modal-dark-text) !important;
}

[data-bs-theme="dark"] .select2-container--default .select2-selection--single .select2-selection__arrow b {
    border-color: #ffffff transparent transparent transparent !important;
}

[data-bs-theme="dark"] .modal-content .select2-container--default .select2-selection--multiple .select2-selection__choice,
[data-bs-theme="dark"] .select2-container--default .select2-selection--multiple .select2-selection__choice {
    background-color: var(--modal-dark-elevated) !important;
    border-color: var(--modal-dark-border) !important;
    color: var(--modal-dark-text) !important;
}

[data-bs-theme="dark"] .modal-content .select2-container--default .select2-selection--multiple .select2-selection__choice__remove,
[data-bs-theme="dark"] .select2-container--default .select2-selection--multiple .select2-selection__choice__remove {
    color: var(--modal-dark-muted) !important;
}

[data-bs-theme="dark"] .modal-content .select2-container--default .select2-selection--multiple .select2-selection__choice__remove:hover,
[data-bs-theme="dark"] .select2-container--default .select2-selection--multiple .select2-selection__choice__remove:hover {
    color: var(--modal-dark-text) !important;
}

[data-bs-theme="dark"] .modal-content .select2-container--default .select2-search--inline .select2-search__field,
[data-bs-theme="dark"] .select2-container--default .select2-search--inline .select2-search__field,
[data-bs-theme="dark"] .modal-content .select2-container--default .select2-search--dropdown .select2-search__field,
[data-bs-theme="dark"] .select2-container--default .select2-search--dropdown .select2-search__field {
    color: var(--modal-dark-text) !important;
    background-color: var(--modal-dark-surface) !important;
    border-color: var(--modal-dark-border) !important;
}

[data-bs-theme="dark"] .select2-container--default .select2-dropdown,
[data-bs-theme="dark"] .select2-container--default .select2-results__option,
[data-bs-theme="dark"] .select2-container--default .select2-search--dropdown .select2-search__field {
    background-color: var(--modal-dark-surface) !important;
    color: var(--modal-dark-text);
    border-color: var(--modal-dark-border);
}

[data-bs-theme="dark"] .select2-container--default .select2-results__option--highlighted[aria-selected],
[data-bs-theme="dark"] .select2-container--default .select2-results__option--highlighted {
    background-color: var(--modal-dark-accent) !important;
    color: #fff !important;
}

[data-bs-theme="dark"] .select2-container--default .select2-results__option[aria-selected="true"] {
    background-color: rgba(47, 129, 247, 0.2) !important;
    color: var(--modal-dark-text) !important;
}

[data-bs-theme="dark"] .modal-content .note-editor.note-frame {
    border-color: var(--modal-dark-border);
}

[data-bs-theme="dark"] .modal-content .note-toolbar,
[data-bs-theme="dark"] .modal-content .note-statusbar {
    background-color: var(--modal-dark-elevated);
    border-color: var(--modal-dark-border);
}

[data-bs-theme="dark"] .modal-content .note-toolbar .note-btn {
    background-color: var(--modal-dark-surface);
    border-color: var(--modal-dark-border);
    color: var(--modal-dark-text);
}

[data-bs-theme="dark"] .modal-content .note-toolbar .note-btn:hover,
[data-bs-theme="dark"] .modal-content .note-toolbar .note-btn:focus {
    background-color: var(--modal-dark-elevated);
    border-color: var(--modal-dark-border-strong);
    color: var(--modal-dark-text);
}

[data-bs-theme="dark"] .modal-content .note-editable {
    background-color: var(--modal-dark-surface);
    color: var(--modal-dark-text);
}

.label-lite-red {
    background-color: var(--bs-body-bg, #FFF);
    color: #dd4b39;
    border: 1px solid #dd4b39;
}

.label-lite-gray {
    background-color: var(--bs-body-bg, #FFF);
    color: var(--bs-body-color, #000);
    border: 1px solid #d2d6de;
}

.spacer { margin: 0; padding: 0; height: 50px; }

.callout.callout-ok {
    border: 1px solid #00733e;
    background-color: #003a1f !important;
    color: #fff;
}

.callout.callout-ok h4 {
    margin-bottom: 3px;
}

.callout.callout-ok p,
.callout.callout-ok .lead,
.callout.callout-ok span,
.callout.callout-ok i {
    color: #FFF !important;
}

.callout.callout-ok .text-green {
    color: #00a65a !important;
}

/* =====================================================
   APP SHELL — Variables de tema
   :root        = modo claro (default)
   [data-bs-theme="dark"] = modo oscuro
   ===================================================== */
:root {
    --app-bg: #f8fafc;
    --app-surface: #ffffff;
    --app-surface-alt: #f1f5f9;
    --app-border: rgba(15, 23, 42, 0.12);
    --app-muted: #64748b;
    --app-text: #0f172a;
    --app-card-bg: #ffffff;
    --app-card-border: rgba(15, 23, 42, 0.10);
    --app-accent: #0ea5e9;
}

[data-bs-theme="dark"] {
    --app-bg: #0f141b;
    --app-surface: #141b24;
    --app-surface-alt: #1b2430;
    --app-border: rgba(148, 163, 184, 0.2);
    --app-muted: rgba(226, 232, 240, 0.65);
    --app-text: #e2e8f0;
    --app-card-bg: #141b24;
    --app-card-border: rgba(148, 163, 184, 0.2);
    --app-accent: #22d3ee;
}

.app-body {
    background: var(--app-bg);
    color: var(--app-text);
    min-height: 100vh;
    font-family: "Inter", "Source Sans Pro", system-ui, -apple-system, sans-serif;
}

.app-shell {
    display: flex;
    min-height: 100vh;
}

.app-sidebar {
    width: 280px;
    background: var(--app-surface);
    border-right: 1px solid var(--app-border);
}

.app-sidebar .offcanvas-lg {
    width: 280px;
}

.sidebar-user {
    background: var(--app-surface-alt);
    border-radius: 16px;
    padding: 12px 16px;
}

.sidebar-search .form-control,
.sidebar-search .input-group-text {
    color: var(--app-text);
}

.sidebar-nav .nav-link,
.sidebar-toggle-btn {
    display: flex;
    align-items: center;
    gap: 12px;
    color: var(--app-muted);
    border-radius: 12px;
    padding: 10px 12px;
    margin: 2px 0;
    background: transparent;
    border: none;
    width: 100%;
    text-align: left;
}

.sidebar-nav .nav-link:hover,
.sidebar-toggle-btn:hover {
    background: rgba(14, 165, 233, 0.12);
    color: var(--app-text);
}

[data-bs-theme="dark"] .sidebar-nav .nav-link:hover,
[data-bs-theme="dark"] .sidebar-toggle-btn:hover {
    background: rgba(34, 211, 238, 0.12);
    color: #ffffff;
}

.sidebar-nav .nav-link.active,
.sidebar-toggle-btn.active {
    background: rgba(14, 165, 233, 0.15);
    color: var(--app-text);
}

[data-bs-theme="dark"] .sidebar-nav .nav-link.active,
[data-bs-theme="dark"] .sidebar-toggle-btn.active {
    background: rgba(34, 211, 238, 0.2);
    color: #ffffff;
}

.sidebar-section {
    padding: 8px 12px;
}

.app-main {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
}

.app-topbar {
    background: var(--app-surface);
    border-bottom: 1px solid var(--app-border);
    padding: 12px 0;
    position: sticky;
    top: 0;
    z-index: 1020;
}

.app-topbar .nav-link {
    color: var(--app-muted);
}

.app-topbar .nav-link:hover {
    color: var(--app-text);
}

[data-bs-theme="dark"] .app-topbar .nav-link:hover {
    color: #ffffff;
}

.app-content {
    flex: 1;
    padding: 24px;
    background: var(--app-bg);
    color: var(--app-text);
}

.app-content a {
    color: var(--app-accent);
    text-decoration: none;
}

.app-content a:hover,
.app-content a:focus-visible {
    color: var(--app-text);
    text-decoration: underline;
}

[data-bs-theme="dark"] .app-content a:hover,
[data-bs-theme="dark"] .app-content a:focus-visible {
    color: #ffffff;
}

.app-footer {
    padding: 16px 0;
    border-top: 1px solid var(--app-border);
    background: var(--app-surface);
}

.app-dropdown-menu {
    min-width: 320px;
    background: var(--app-surface);
    border: 1px solid var(--app-border);
    color: var(--app-text);
}

.app-dropdown-menu .dropdown-header {
    font-size: 0.85rem;
    font-weight: 600;
    padding: 12px 16px;
    border-bottom: 1px solid var(--app-border);
}

.app-dropdown-menu .list-group-item {
    background: transparent;
    border-color: var(--app-border);
    color: var(--app-text);
}

.app-user-menu {
    background: var(--app-surface);
    border: 1px solid var(--app-border);
}

.app-user-menu .dropdown-item {
    color: var(--app-text);
}

.app-user-menu .dropdown-item:hover {
    background: rgba(14, 165, 233, 0.12);
}

[data-bs-theme="dark"] .app-user-menu .dropdown-item:hover {
    background: rgba(34, 211, 238, 0.12);
}

.right-side {
    padding: 0;
}

.content-header {
    margin-bottom: 24px;
}

.content-header h1 {
    font-size: 1.5rem;
    font-weight: 600;
    margin-bottom: 8px;
    color: var(--app-text);
}

.content {
    padding: 0;
}

.breadcrumb {
    background: transparent;
    padding: 0;
    margin-bottom: 0;
    color: var(--app-muted);
}

.breadcrumb a {
    color: var(--app-accent);
    text-decoration: none;
}

.breadcrumb a:hover,
.breadcrumb a:focus-visible {
    color: var(--app-text);
    text-decoration: underline;
}

[data-bs-theme="dark"] .breadcrumb a:hover,
[data-bs-theme="dark"] .breadcrumb a:focus-visible {
    color: #ffffff;
}

.table {
    color: var(--app-text);
}

.table thead th {
    border-bottom-color: var(--app-border);
}

.table tbody tr:hover {
    background: rgba(14, 165, 233, 0.08);
}

[data-bs-theme="dark"] .table tbody tr:hover {
    background: rgba(34, 211, 238, 0.08);
}

@media (max-width: 991.98px) {
    .app-sidebar {
        width: 0;
    }

    .app-content {
        padding: 16px;
    }

    .card-body,
    .card-footer {
        padding: 16px;
    }
}

@media (min-width: 992px) {
    .app-shell.is-topbar-hidden .app-topbar {
        display: none;
    }

    .app-shell.is-topbar-hidden .app-content {
        padding-top: 24px;
    }
}

@media (max-width: 575.98px) {
    .app-topbar .navbar-nav {
        flex-wrap: nowrap;
        gap: 4px;
    }

    .app-topbar .nav-link {
        padding: 5px 7px;
    }

    .app-topbar .nav-link img {
        width: 28px;
        height: 28px;
    }

    .app-topbar .nav-link .d-none.d-lg-inline {
        display: none !important;
    }

    .app-topbar .dropdown-menu {
        width: min(100vw - 2rem, 360px);
    }

    .app-content {
        padding: 12px;
    }

    .card-body,
    .card-footer {
        padding: 12px;
    }

    .content-header {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
        margin-bottom: 16px;
    }

    .content-header .pull-left {
        float: none !important;
    }

    .content-header .float-end {
        float: none !important;
    }

    .content-header h1 {
        font-size: 1.2rem;
    }

    .tab-content {
        padding: 12px;
    }

    .nav-tabs-custom .nav-tabs {
        padding: 0 8px;
        overflow-x: auto;
        flex-wrap: nowrap;
        -webkit-overflow-scrolling: touch;
    }

    .nav-tabs-custom .nav-tabs .nav-link {
        white-space: nowrap;
        padding: 10px 12px;
    }
}

.offcanvas-lg,
.offcanvas {
    background: var(--app-surface);
    color: var(--app-text);
}

.card {
    border-radius: 18px;
    border: 1px solid var(--app-card-border);
    background: var(--app-card-bg);
    box-shadow: 0 10px 28px rgba(15, 23, 42, 0.25);
    margin-bottom: 24px;
    overflow: hidden;
}

.card-header {
    background: var(--app-card-bg);
    padding: 16px 20px;
    border-bottom: 1px solid var(--app-border);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.card-title {
    font-size: 1rem;
    font-weight: 600;
    margin: 0;
    color: var(--app-text);
}

.card-body,
.card-footer {
    padding: 20px;
    color: var(--app-text);
}

.small-card-footer {
    color: var(--app-accent);
    text-decoration: none;
    font-weight: 500;
}

.small-card-footer:hover,
.small-card-footer:focus-visible {
    color: var(--app-text);
    text-decoration: underline;
}

/* stat-card: adapta a ambos modos */
.stat-card {
    background: var(--app-card-bg);
    border: 1px solid var(--app-card-border);
    border-radius: 16px;
    padding: 18px 20px;
    display: flex;
    flex-direction: column;
    gap: 18px;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
    height: 100%;
}

[data-bs-theme="dark"] .stat-card {
    border-color: rgba(72, 149, 255, 0.45);
}

.stat-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 30px rgba(15, 23, 42, 0.35);
}

.stat-card-body {
    display: flex;
    align-items: center;
    gap: 16px;
}

.stat-icon {
    width: 56px;
    height: 56px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.75rem;
    background: rgba(14, 165, 233, 0.12);
}

[data-bs-theme="dark"] .stat-icon {
    background: rgba(255, 255, 255, 0.08);
}

.stat-value {
    font-size: 2.1rem;
    font-weight: 700;
    color: var(--app-text);
    line-height: 1.1;
}

.stat-label {
    font-size: 0.95rem;
    color: var(--app-muted);
    margin-top: 4px;
}

.nav-tabs-custom {
    border-radius: 16px;
    overflow: hidden;
    background: var(--app-card-bg);
    border: 1px solid var(--app-card-border);
}

.nav-tabs-custom .nav-tabs {
    border-bottom: 1px solid var(--app-border);
    padding: 0 16px;
}

.nav-tabs-custom .nav-tabs .nav-link {
    color: var(--app-muted);
    padding: 12px 16px;
    display: inline-block;
}

.nav-tabs-custom .nav-tabs .nav-link.active {
    color: var(--app-text);
    border-bottom: 2px solid var(--app-accent);
}

.tab-content {
    padding: 20px;
}

.pull-right {
    float: right !important;
}

.pull-left {
    float: left !important;
}

.btn-default {
    background: transparent;
    border-color: var(--app-border);
    color: var(--app-text);
}

.btn-default:hover {
    background: rgba(14, 165, 233, 0.08);
    color: var(--app-text);
}

[data-bs-theme="dark"] .btn-default:hover {
    background: rgba(255, 255, 255, 0.08);
    color: #ffffff;
}

.btn-block {
    display: block;
    width: 100%;
}

.alert {
    border-radius: 14px;
    border-color: transparent;
}

.table-responsive {
    border-radius: 16px;
    border: 1px solid var(--app-border);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

/* Auth pages */
.app-auth {
    background: radial-gradient(circle at top, rgba(14, 165, 233, 0.12), transparent 55%), var(--app-bg);
    color: var(--app-text);
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px 16px;
}

.auth-card {
    width: 100%;
    max-width: 420px;
    background: var(--app-card-bg);
    border: 1px solid var(--app-card-border);
    border-radius: 20px;
    padding: 32px;
    box-shadow: 0 20px 40px rgba(15, 23, 42, 0.4);
}

.auth-logo {
    font-size: 1.5rem;
    font-weight: 600;
    text-align: center;
    margin-bottom: 24px;
    color: var(--app-text);
}

.auth-message {
    color: var(--app-muted);
    text-align: center;
    margin-bottom: 20px;
}

.img-responsive {
    max-width: 100%;
    height: auto;
}

.label {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 0.2rem 0.55rem;
    border-radius: 999px;
    font-size: 0.75rem;
    font-weight: 600;
    background: rgba(14, 165, 233, 0.12);
    color: var(--app-text);
}

[data-bs-theme="dark"] .label {
    background: rgba(255, 255, 255, 0.12);
    color: #ffffff;
}

.label-success { background: rgba(34, 197, 94, 0.2);  color: #16a34a; }
.label-warning { background: rgba(250, 204, 21, 0.2);  color: #b45309; }
.label-danger  { background: rgba(248, 113, 113, 0.2); color: #dc2626; }
.label-primary { background: rgba(56, 189, 248, 0.2);  color: #0284c7; }

[data-bs-theme="dark"] .label-success { color: #86efac; }
[data-bs-theme="dark"] .label-warning { color: #fde68a; }
[data-bs-theme="dark"] .label-danger  { color: #fecaca; }
[data-bs-theme="dark"] .label-primary { color: #bae6fd; }

.text-green  { color: #16a34a !important; }
.text-yellow { color: #d97706 !important; }
.text-red    { color: #dc2626 !important; }
.text-gray   { color: #64748b !important; }

[data-bs-theme="dark"] .text-green  { color: #22c55e !important; }
[data-bs-theme="dark"] .text-yellow { color: #facc15 !important; }
[data-bs-theme="dark"] .text-red    { color: #f87171 !important; }
[data-bs-theme="dark"] .text-gray   { color: #94a3b8 !important; }

.app-public .public-content {
    padding: 32px 0;
}

/* Public page theme selector (next to Auto Refresh) */
.public-theme-select {
    width: auto;
    min-width: 145px;
}

/* Public page footer links (Monitor / itecsa) — discreto, respeta light/dark via variable */
.app-footer .footer-link {
    color: var(--app-accent);
    text-decoration: none;
}
.app-footer .footer-link:hover,
.app-footer .footer-link:focus {
    text-decoration: underline;
}
.app-footer .footer-render {
    opacity: .7;
    margin-left: .25rem;
}

/* Public page footer — layout + logos de branding (compacto, controlado).
   Selector prefijado con footer.app-footer para ganar especificidad sin !important. */
footer.app-footer .public-footer {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: flex-end;
    gap: .75rem;
}
footer.app-footer .public-footer-company,
footer.app-footer .public-footer-brand {
    min-width: 0;
    line-height: 1.3;
}
footer.app-footer .public-footer-brand {
    text-align: right;
}
footer.app-footer .public-footer-itecsa-logo,
footer.app-footer .public-footer-monitor-logo {
    display: block;
    width: auto;
    max-width: 100%;
    object-fit: contain;
}
footer.app-footer .public-footer-itecsa-logo {
    max-height: 24px;
    max-width: 120px;
    margin-top: .35rem;
}
footer.app-footer .public-footer-monitor-logo {
    max-height: 28px;
    max-width: 130px;
    margin-left: auto; /* alinea el logo a la derecha en desktop */
    margin-bottom: .25rem;
}
@media (max-width: 768px) {
    footer.app-footer .public-footer {
        align-items: flex-start;
    }
    footer.app-footer .public-footer-brand {
        text-align: left;
    }
    footer.app-footer .public-footer-monitor-logo {
        margin-left: 0;
    }
}
