/* =========================
   1) Tokens de marca + tema
   ========================= */
:root {
    /* Marca */
    --azul-primario: #1546d8; /* confiança/clareza */
    --azul-fundo-login: #0b2a7a;
    /* Botões (sistema nd-btn) */
    --nd-radius: 10px;
    --nd-ring: .24rem;
    --nd-c-primary: #1546d8;
    --nd-c-primary-rgb: 21,70,216;
    --nd-c-cyan: #0ea5e9;
    --nd-c-cyan-bd: #0891b2;
    --nd-c-cyan-rgb: 14,165,233;
    --nd-c-gray: #64748b;
    --nd-c-gray-rgb: 100,116,139;
    --nd-c-danger: #dc3545;
    --nd-c-danger-rgb: 220,53,69;
}

    /* Paleta base por tema (alinha com Bootstrap 5.3) */
    :root,
    :root[data-bs-theme="light"] {
        --bs-body-bg: #f6f7fb;
        --bs-body-color: #1e1f23;
        --bs-border-color: #d8dbe2;
        --bs-tertiary-bg: #eef1f6;
        --nd-card-bg: #ffffff;
        --nd-card-border: var(--bs-border-color);
        --bs-table-color: var(--bs-body-color);
        --bs-table-bg: transparent;
        --bs-table-striped-bg: rgba(0,0,0,.03);
        --bs-table-striped-color: var(--bs-body-color);
        --bs-table-hover-bg: rgba(0,0,0,.06);
        --bs-table-hover-color: var(--bs-body-color);
        --nd-input-bg: #fff;
        --nd-input-border: var(--bs-border-color);
        --nd-modal-bg: #ffffff;
        color-scheme: light;
    }

        :root[data-bs-theme="dark"] {
            --bs-body-bg: #0f1115;
            --bs-body-color: #e5e7eb;
            --bs-border-color: #2a2f3a;
            --bs-tertiary-bg: #161a22;
            --nd-card-bg: #12151c;
            --nd-card-border: var(--bs-border-color);
            --bs-table-color: var(--bs-body-color);
            --bs-table-bg: transparent;
            --bs-table-striped-bg: rgba(255,255,255,.03);
            --bs-table-striped-color: var(--bs-body-color);
            --bs-table-hover-bg: rgba(255,255,255,.06);
            --bs-table-hover-color: var(--bs-body-color);
            --nd-input-bg: #0f131a;
            --nd-input-border: var(--bs-border-color);
            --nd-modal-bg: #141821;
            color-scheme: dark;
        }

/* Transição suave ao alternar tema */
[data-bs-theme] * {
    transition: background-color .18s linear, color .18s linear, border-color .18s linear;
}

/* =============
   2) Base/reset
   ============= */
* {
    box-sizing: border-box;
}

html, body {
    height: 100%;
}

body {
    margin: 0;
    font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
}

a {
    color: var(--bs-link-color, #0d6efd);
}

:root[data-bs-theme="dark"] a {
    --bs-link-color: #7ab0ff;
}

/* ============================
   3) Área pública (Login)
   ============================ */
body.auth {
    background: var(--azul-fundo-login);
}

main.auth-container {
    min-height: 100vh;
}

.card-login {
    max-width: 460px;
    width: 100%;
    border: 0;
    border-radius: 16px;
    box-shadow: 0 12px 28px rgba(0,0,0,.25);
    background: #fff;
}

.subtitulo {
    color: #6b7280;
    font-size: .95rem;
}

.input-group-text {
    background: #f8fafc;
}

.form-control::placeholder {
    color: #9aa4b2;
}

.btn-entrar {
    background: linear-gradient(180deg, #2a55e8 0%, #2449c7 100%);
    border: none;
    font-weight: 600;
    color: #fff;
}

    .btn-entrar:hover {
        filter: brightness(1.05);
    }

/* ============================
   4) Área autenticada (App)
   ============================ */
/* Grid principal do app: sidebar | topbar | conteúdo */
.layout-app {
    display: grid;
    grid-template-columns: 260px 1fr;
    grid-template-rows: 64px calc(100vh - 64px);
    grid-template-areas:
        "sidebar topbar"
        "sidebar conteudo";
    height: 100vh;
}

/* Sidebar */
.sidebar {
    grid-area: sidebar;
    background: var(--nd-card-bg);
    border-right: 1px solid var(--nd-card-border);
}

.marca {
    height: 64px;
    display: flex;
    align-items: center;
    gap: .6rem;
    padding: 0 1rem;
    border-bottom: 1px solid var(--nd-card-border);
    font-weight: 700;
}

.marca-icone {
    width: 28px;
    height: 28px;
    border-radius: 8px;
    display: grid;
    place-items: center;
    background: var(--bs-tertiary-bg);
}

    .marca-icone i {
        color: #4b68ff;
        font-size: 18px;
        line-height: 1;
    }

.nav-lateral {
    padding: 12px;
}

    .nav-lateral .nav-link {
        display: flex;
        align-items: center;
        gap: .6rem;
        color: var(--bs-body-color);
        border-radius: .6rem;
        padding: .6rem .8rem;
        text-decoration: none;
    }

        .nav-lateral .nav-link:hover,
        .nav-lateral .nav-link.active {
            background: #eef1f6;
            color: var(--azul-primario);
        }

:root[data-bs-theme="dark"] .nav-lateral .nav-link:hover,
:root[data-bs-theme="dark"] .nav-lateral .nav-link.active {
    background: #1e2430;
    color: #98b3ff;
}

.nav-lateral .bi {
    font-size: 1.1rem;
}

/* Topbar */
.topbar {
    grid-area: topbar;
    background: var(--nd-card-bg);
    border-bottom: 1px solid var(--nd-card-border);
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: .75rem;
    padding: 0 1rem;
}

/* Conteúdo */
.conteudo {
    grid-area: conteudo;
    padding: 1.25rem 1.25rem 2rem;
    overflow: auto;
}

.titulo-pagina {
    font-weight: 700;
}

/* Painel central (faixa branca) */
.faixa {
    background: var(--nd-card-bg);
    border: 1px solid var(--nd-card-border);
    box-shadow: 0 12px 24px rgba(17,24,39,.06);
    border-radius: 16px;
    padding: 1.25rem;
}

/* ==============================
   5) Cards/KPIs/Blocos genéricos
   ============================== */
.cards {
    display: grid;
    grid-template-columns: repeat(6,1fr);
    gap: 1rem;
}

@media (max-width:1400px) {
    .cards {
        grid-template-columns: repeat(3,1fr);
    }
}

@media (max-width:768px) {
    .cards {
        grid-template-columns: repeat(2,1fr);
    }
}

.card-kpi {
    background: var(--nd-card-bg);
    border: 1px solid var(--nd-card-border);
    border-radius: .85rem;
    padding: 1rem;
    display: flex;
    align-items: center;
    gap: .8rem;
    box-shadow: 0 8px 16px rgba(17,24,39,.05);
}

.icone-redondo {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    font-size: 1.1rem;
}

.kpi-titulo {
    color: #6b7280;
    font-size: .9rem;
    margin: 0;
}

:root[data-bs-theme="dark"] .kpi-titulo {
    color: #9aa4b2 !important;
}

.kpi-valor {
    font-weight: 800;
    font-size: 1.2rem;
    margin: 0;
}

.kpi-destaque {
    color: var(--azul-primario);
    font-weight: 800;
}

.bloco {
    background: var(--nd-card-bg);
    border: 1px solid var(--nd-card-border);
    border-radius: .85rem;
    padding: 1rem 1rem 0;
    box-shadow: 0 8px 16px rgba(17,24,39,.04);
}

.bloco-titulo {
    font-weight: 700;
    margin-bottom: .6rem;
}

.vazio {
    color: #6b7280;
    border: 2px dashed var(--nd-card-border);
    border-radius: .75rem;
    padding: 1.25rem;
    text-align: center;
    background: #fafafa;
}

:root[data-bs-theme="dark"] .vazio {
    background: #0f131a;
    color: #9aa4b2;
    border-color: var(--nd-card-border);
}

/* =================================
   6) Formulários / Tabelas / Modal
   ================================= */
.form-control, .form-select, .input-group-text {
    background-color: var(--nd-input-bg);
    color: var(--bs-body-color);
    border-color: var(--nd-input-border);
}

    .form-control:focus, .form-select:focus {
        border-color: var(--bs-primary, #0d6efd);
        box-shadow: 0 0 0 .2rem rgba(13,110,253,.15);
    }

.table {
    border-color: var(--bs-border-color);
    color: var(--bs-table-color);
}

    .table thead th {
        background: var(--bs-tertiary-bg);
        color: var(--bs-body-color);
        border-bottom-color: var(--bs-border-color);
    }

.table-striped > tbody > tr:nth-of-type(odd) > * {
    background: var(--bs-table-striped-bg);
    color: var(--bs-table-striped-color);
}

.table-hover > tbody > tr:hover > * {
    background: var(--bs-table-hover-bg);
    color: var(--bs-table-hover-color);
}

.modal-content {
    background: var(--nd-modal-bg);
    color: var(--bs-body-color);
    border-color: var(--bs-border-color);
}

.modal-header, .modal-footer {
    border-color: var(--bs-border-color);
}

.modal .form-control, .modal .form-select {
    background-color: var(--bs-body-bg);
    color: var(--bs-body-color);
    border-color: var(--bs-border-color);
}

    .modal .form-control::placeholder {
        color: var(--bs-secondary-color);
    }

/* =========================
   7) FAB Ajuda + Marca
   ========================= */
.ajuda-fab {
    position: fixed;
    right: 16px;
    bottom: 16px;
    z-index: 1000;
    display: inline-flex;
    gap: .5rem;
    align-items: center;
    background: var(--bs-primary, #0d6efd);
    color: #fff;
    border-radius: 999px;
    padding: .6rem .9rem;
    text-decoration: none;
    box-shadow: 0 6px 14px rgba(0,0,0,.2);
}

.ajuda-fab__icon {
    width: 20px;
    height: 20px;
    display: grid;
    place-items: center;
    background: rgba(255,255,255,.15);
    border-radius: 999px;
}

.brand-logo {
    text-decoration: none;
    color: inherit;
    font-weight: 700;
}

.brand-icon {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    display: grid;
    place-items: center;
    background: linear-gradient(135deg,#6366f1 0%,#22d3ee 100%);
    color: #fff;
    box-shadow: 0 2px 8px rgba(99,102,241,.35);
}

:root[data-bs-theme="dark"] .brand-icon {
    box-shadow: 0 2px 8px rgba(99,102,241,.55);
}

/* Espaços do logo no App/Portal */
.layout-app .sidebar .brand-logo {
    padding-left: 20px;
    padding-top: 12px;
    display: inline-flex;
}

@media (max-width: 576px) {
    .layout-app .sidebar .brand-logo {
        padding-left: 12px;
        padding-top: 6px;
    }
}

.layout-portal .topbar > .d-flex {
    padding-left: 16px;
    padding-top: 8px;
}

.layout-portal .brand-logo {
    display: inline-flex;
    align-items: center;
    gap: .65rem;
    text-decoration: none;
}

    .layout-portal .brand-logo .brand-icon,
    .layout-portal .marca-icone {
        width: 34px;
        height: 34px;
        border-radius: 12px;
        display: grid;
        place-items: center;
        color: #fff;
        background: linear-gradient(135deg, #6C7BFF 0%, #22D3EE 100%);
        box-shadow: 0 8px 24px rgba(34, 211, 238, .25), 0 0 0 8px rgba(34, 211, 238, .08);
        font-size: 18px;
    }

    .layout-portal .brand-logo .brand-text {
        font-weight: 800;
        font-size: 1.125rem;
        letter-spacing: .2px;
        color: var(--bs-body-color);
    }

:root[data-bs-theme="dark"] .layout-portal .brand-logo .brand-icon,
:root[data-bs-theme="dark"] .layout-portal .marca-icone {
    box-shadow: 0 8px 24px rgba(99, 102, 241, .30), 0 0 0 8px rgba(99, 102, 241, .10);
}

@media (max-width: 576px) {
    .layout-portal .topbar > .d-flex {
        padding-left: 12px;
        padding-top: 6px;
    }

    .layout-portal .brand-logo .brand-icon,
    .layout-portal .marca-icone {
        width: 32px;
        height: 32px;
        border-radius: 11px;
        font-size: 17px;
    }
}

/* ===============================
   8) Avaliação por estrelas (UI)
   =============================== */
.avaliacao-estrelas {
    display: inline-flex;
    gap: .25rem;
    align-items: center;
}



.nd-star {
    background: none;
    border: 0;
    padding: 0;
    cursor: pointer;
    line-height: 1;
}

    .nd-star svg {
        display: block;
    }

        .nd-star svg path {
            fill: var(--bs-secondary-color, #9aa4b2);
            transition: fill .12s ease;
        }

    .nd-star.on svg path {
        fill: var(--bs-warning, #f59e0b);
    }

    .nd-star:hover svg path {
        filter: brightness(1.05);
    }

/* =====================================
   9) Badges – Status e Prioridade
   ===================================== */
/* Status (INTENSAS) */
.badge.nx-aberto {
    background: rgba(14,165,233,.32) !important;
    color: #0284c7 !important;
    border: 1px solid rgba(14,165,233,.70) !important;
    font-weight: 600;
}

.badge.nx-andamento {
    background: rgba(245,158,11,.32) !important;
    color: #b45309 !important;
    border: 1px solid rgba(245,158,11,.70) !important;
    font-weight: 600;
}

.badge.nx-pausa {
    background: rgba(107,114,128,.30) !important;
    color: #4b5563 !important;
    border: 1px solid rgba(107,114,128,.65) !important;
    font-weight: 600;
}

.badge.nx-fechado {
    background: rgba(16,185,129,.32) !important;
    color: #059669 !important;
    border: 1px solid rgba(16,185,129,.70) !important;
    font-weight: 600;
}

.badge.nx-erro {
    background: rgba(220,53,69,.34) !important;
    color: #b4232f !important;
    border: 1px solid rgba(220,53,69,.75) !important;
    font-weight: 600;
}
/* Status – Dark Mode */
[data-bs-theme="dark"] .badge.nx-aberto {
    background: rgba(14,165,233,.40) !important;
    color: #7dd3fc !important;
    border-color: rgba(14,165,233,.85) !important;
}

[data-bs-theme="dark"] .badge.nx-andamento {
    background: rgba(245,158,11,.42) !important;
    color: #ffce6a !important;
    border-color: rgba(245,158,11,.85) !important;
}

[data-bs-theme="dark"] .badge.nx-pausa {
    background: rgba(107,114,128,.40) !important;
    color: #d1d5db !important;
    border-color: rgba(107,114,128,.80) !important;
}

[data-bs-theme="dark"] .badge.nx-fechado {
    background: rgba(16,185,129,.40) !important;
    color: #86efac !important;
    border-color: rgba(16,185,129,.85) !important;
}

[data-bs-theme="dark"] .badge.nx-erro {
    background: rgba(220,53,69,.42) !important;
    color: #ff9aa6 !important;
    border-color: rgba(220,53,69,.90) !important;
}

/* Prioridade (mantém classes do seu HTML) */
.badge.bg-success {
    background-color: #16a34a !important;
    border: 1px solid #15803d !important;
    color: #fff !important;
    font-weight: 600;
}

.badge.bg-info.text-dark {
    background-color: #06b6d4 !important;
    border: 1px solid #0891b2 !important;
    color: #0b0f14 !important;
    font-weight: 600;
}

.badge.bg-danger {
    background-color: #e11d48 !important;
    border: 1px solid #be123c !important;
    color: #fff !important;
    font-weight: 600;
}

.badge.bg-dark {
    background-color: #111827 !important;
    border: 1px solid #0b1220 !important;
    color: #e5e7eb !important;
    font-weight: 600;
}

/* ===================================
   10) Sistema único de botões (nd-btn)
   =================================== */
/* Base */
.nd-btn {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .45rem .9rem;
    border-radius: var(--nd-radius);
    border: 1px solid transparent;
    font-weight: 700;
    line-height: 1.25;
    text-decoration: none;
    transition: background-color .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease, transform .05s ease;
}

    .nd-btn .bi {
        margin-right: .125rem;
    }

.nd-sm {
    padding: .375rem .6rem;
    font-size: .875rem;
    border-radius: .6rem;
}

/* Tons */
.tone-primary {
    --nd-bg: var(--nd-c-primary);
    --nd-rgb: var(--nd-c-primary-rgb);
    --nd-ol: var(--nd-c-primary);
}

.tone-cyan {
    --nd-bg: var(--nd-c-cyan);
    --nd-rgb: var(--nd-c-cyan-rgb);
    --nd-ol: var(--nd-c-cyan-bd);
}

.tone-gray {
    --nd-bg: var(--nd-c-gray);
    --nd-rgb: var(--nd-c-gray-rgb);
    --nd-ol: var(--nd-c-gray);
}

.tone-danger {
    --nd-bg: var(--nd-c-danger);
    --nd-rgb: var(--nd-c-danger-rgb);
    --nd-ol: var(--nd-c-danger);
}

/* Variante preenchida */
.nd-fill {
    background: var(--nd-bg);
    color: #fff;
    border-color: var(--nd-bg);
    box-shadow: 0 2px 8px rgba(var(--nd-rgb), .25);
}

    .nd-fill:hover, .nd-fill:focus {
        color: #fff;
        box-shadow: 0 0 0 var(--nd-ring) rgba(255,255,255,.85), 0 6px 18px rgba(var(--nd-rgb), .45);
    }

[data-bs-theme="dark"] .nd-fill:hover,
[data-bs-theme="dark"] .nd-fill:focus {
    box-shadow: 0 0 0 var(--nd-ring) rgba(255,255,255,.55), 0 6px 18px rgba(var(--nd-rgb), .60);
}

.nd-fill:active {
    transform: translateY(1px);
}

/* Variante contornada (preenche no hover) */
.nd-outline {
    background: transparent;
    color: var(--nd-ol);
    border-color: var(--nd-ol);
}

    .nd-outline:hover, .nd-outline:focus {
        background: var(--nd-ol);
        color: #fff;
        box-shadow: 0 0 0 var(--nd-ring) rgba(255,255,255,.75);
    }

[data-bs-theme="dark"] .nd-outline:hover,
[data-bs-theme="dark"] .nd-outline:focus {
    box-shadow: 0 0 0 var(--nd-ring) rgba(255,255,255,.55);
}

.nd-outline:active {
    transform: translateY(1px);
}

/* ================================
   11) Aliases (compatibilidade)
   ================================ */
/* Primário azul antigo */
.btn-primario,
.btn-voltar.btn-tone-primario {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .45rem .9rem;
    border-radius: var(--nd-radius);
    font-weight: 700;
    line-height: 1.25;
    text-decoration: none;
    background: var(--nd-c-primary);
    color: #fff;
    border: 1px solid var(--nd-c-primary);
    box-shadow: 0 2px 8px rgba(var(--nd-c-primary-rgb),.25);
}

    .btn-primario:hover, .btn-primario:focus,
    .btn-voltar.btn-tone-primario:hover, .btn-voltar.btn-tone-primario:focus {
        color: #fff;
        box-shadow: 0 0 0 var(--nd-ring) rgba(255,255,255,.85), 0 6px 18px rgba(var(--nd-c-primary-rgb),.45);
    }

[data-bs-theme="dark"] .btn-primario:hover, [data-bs-theme="dark"] .btn-primario:focus,
[data-bs-theme="dark"] .btn-voltar.btn-tone-primario:hover, [data-bs-theme="dark"] .btn-voltar.btn-tone-primario:focus {
    box-shadow: 0 0 0 var(--nd-ring) rgba(255,255,255,.55), 0 6px 18px rgba(var(--nd-c-primary-rgb),.60);
}

/* CTA ciano (Aplicar/Buscar/Adicionar) */
.btn-acao,
.relatorios-page .btn-aplicar,
.pesquisa-page .btn-aplicar {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .45rem .9rem;
    border-radius: var(--nd-radius);
    font-weight: 700;
    line-height: 1.25;
    text-decoration: none;
    background: var(--nd-c-cyan);
    color: #fff;
    border: 1px solid var(--nd-c-cyan-bd);
    box-shadow: 0 2px 8px rgba(var(--nd-c-cyan-rgb),.25);
}

    .btn-acao:hover, .btn-acao:focus,
    .relatorios-page .btn-aplicar:hover, .relatorios-page .btn-aplicar:focus,
    .pesquisa-page .btn-aplicar:hover, .pesquisa-page .btn-aplicar:focus {
        color: #fff;
        box-shadow: 0 0 0 var(--nd-ring) rgba(255,255,255,.85), 0 6px 18px rgba(var(--nd-c-cyan-rgb),.45);
    }

[data-bs-theme="dark"] .btn-acao:hover, [data-bs-theme="dark"] .btn-acao:focus,
[data-bs-theme="dark"] .relatorios-page .btn-aplicar:hover, [data-bs-theme="dark"] .relatorios-page .btn-aplicar:focus,
[data-bs-theme="dark"] .pesquisa-page .btn-aplicar:hover, [data-bs-theme="dark"] .pesquisa-page .btn-aplicar:focus {
    box-shadow: 0 0 0 var(--nd-ring) rgba(255,255,255,.55), 0 6px 18px rgba(var(--nd-c-cyan-rgb),.60);
}

/* Neutros (Limpar/Voltar/Cancelar) */
.btn-sec, .btn-limpar, .btn-secundario, .btn-voltar, .btn.btn-voltar, .btn-voltar.btn-tone-cinza {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .45rem .9rem;
    border-radius: var(--nd-radius);
    font-weight: 600;
    line-height: 1.25;
    text-decoration: none;
    background: transparent;
    color: var(--nd-c-gray);
    border: 1px solid var(--nd-c-gray);
}

    .btn-sec:hover, .btn-sec:focus,
    .btn-limpar:hover, .btn-limpar:focus,
    .btn-secundario:hover, .btn-secundario:focus,
    .btn-voltar:hover, .btn-voltar:focus,
    .btn.btn-voltar:hover, .btn.btn-voltar:focus,
    .btn-voltar.btn-tone-cinza:hover, .btn-voltar.btn-tone-cinza:focus {
        background: var(--nd-c-gray);
        color: #fff;
        box-shadow: 0 0 0 var(--nd-ring) rgba(255,255,255,.75);
    }

[data-bs-theme="dark"] .btn-sec:hover, [data-bs-theme="dark"] .btn-sec:focus,
[data-bs-theme="dark"] .btn-limpar:hover, [data-bs-theme="dark"] .btn-limpar:focus,
[data-bs-theme="dark"] .btn-secundario:hover, [data-bs-theme="dark"] .btn-secundario:focus,
[data-bs-theme="dark"] .btn-voltar:hover, [data-bs-theme="dark"] .btn-voltar:focus,
[data-bs-theme="dark"] .btn.btn-voltar:hover, [data-bs-theme="dark"] .btn.btn-voltar:focus,
[data-bs-theme="dark"] .btn-voltar.btn-tone-cinza:hover, [data-bs-theme="dark"] .btn-voltar.btn-tone-cinza:focus {
    box-shadow: 0 0 0 var(--nd-ring) rgba(255,255,255,.55);
}

/* Tamanho pequeno legado */
.btn-pequeno {
    padding: .375rem .6rem;
    font-size: .875rem;
    border-radius: .6rem;
}

/* =====================================
   12) Página – Base de Conhecimento
   ===================================== */
.kb-page .bloco {
    border-radius: 14px;
    box-shadow: 0 10px 20px rgba(17,24,39,.06);
    border: 1px solid var(--nd-card-border);
    background: var(--nd-card-bg);
}

.kb-page .form-grid {
    display: grid;
    gap: 12px;
}

.kb-page .h42 {
    height: 42px;
}

.kb-page .btn-peq, .kb-page .btn-peq.btn {
    padding: .375rem .6rem;
    font-size: .875rem;
    border-radius: .6rem;
}

/* Badges de categoria */
.kb-page .badge {
    font-weight: 600;
    border: 1px solid transparent;
}

.kb-page .pill-rede {
    background: rgba(14,165,233,.16);
    color: #0ea5e9;
    border-color: rgba(14,165,233,.5);
}

.kb-page .pill-software {
    background: rgba(99,102,241,.16);
    color: #6366f1;
    border-color: rgba(99,102,241,.5);
}

.kb-page .pill-hardware {
    background: rgba(107,114,128,.16);
    color: #6b7280;
    border-color: rgba(107,114,128,.5);
}

.kb-page .pill-email {
    background: rgba(59,130,246,.16);
    color: #3b82f6;
    border-color: rgba(59,130,246,.5);
}

.kb-page .pill-impressora {
    background: rgba(245,158,11,.18);
    color: #d97706;
    border-color: rgba(245,158,11,.55);
}

.kb-page .pill-proc {
    background: rgba(20,184,166,.18);
    color: #0f766e;
    border-color: rgba(20,184,166,.55);
}

.kb-page .pill-outros {
    background: rgba(100,116,139,.16);
    color: #475569;
    border-color: rgba(100,116,139,.5);
}

/* Listas (busca/recentes) */
.kb-page .item {
    transition: background .15s ease;
}

    .kb-page .item:hover {
        background: var(--bs-tertiary-bg);
    }

.kb-page .line-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Modal KB */
.kb-modal pre {
    white-space: pre-wrap;
    background: var(--bs-tertiary-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 10px;
    padding: .75rem;
    margin: 0;
}

/* ==================================
   13) Página – Pesquisa de Chamados
   ================================== */
.pesquisa-page .bloco {
    border-radius: 14px;
    box-shadow: 0 10px 20px rgba(17,24,39,.06);
    border: 1px solid var(--nd-card-border);
    background: var(--nd-card-bg);
}
/* Grid dos filtros: ID | Categoria | Status | Ações */
.pesquisa-page .filters {
    display: grid;
    grid-template-columns: 1fr 2fr 1fr auto;
    gap: 12px;
    align-items: end;
}

@media (max-width: 992px) {
    .pesquisa-page .filters {
        grid-template-columns: 1fr;
    }
}
/* Alturas */
.pesquisa-page .filters .form-control,
.pesquisa-page .filters .form-select,
.pesquisa-page .filters .btn {
    height: 42px;
}
/* Ações */
.pesquisa-page .filters .actions {
    display: flex;
    gap: 10px;
    justify-content: flex-end;
}
/* Tabela e vazio */
.pesquisa-page table thead th {
    background: var(--bs-tertiary-bg);
    border-bottom-color: var(--bs-border-color);
    font-weight: 700;
}

.pesquisa-page .empty {
    color: var(--bs-secondary-color);
}

/* ===============================
   14) Página – Relatórios
   =============================== */
.relatorios-page .bloco {
    border-radius: 14px;
    box-shadow: 0 10px 20px rgba(17,24,39,.06);
    border: 1px solid var(--nd-card-border);
    background: var(--nd-card-bg);
}
/* Filtros (De|Até|Status|Ações) */
.relatorios-page .filters {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr auto;
    gap: 12px;
    align-items: end;
}

    .relatorios-page .filters .actions {
        display: flex;
        gap: 10px;
        justify-content: flex-end;
    }

    .relatorios-page .filters .form-control,
    .relatorios-page .filters .form-select {
        height: 42px;
    }

    .relatorios-page .filters .actions .btn {
        height: 42px;
        border-radius: var(--nd-radius);
    }

/* KPIs */
.relatorios-page .kpi-grid .kpi {
    position: relative;
    overflow: hidden;
}

    .relatorios-page .kpi-grid .kpi::before {
        content: "";
        position: absolute;
        inset: 0 0 auto 0;
        height: 4px;
        background: var(--bs-tertiary-bg);
    }

.relatorios-page .kpi .label {
    color: var(--bs-secondary-color,#6b7280);
    font-size: .875rem;
}

.relatorios-page .kpi .value {
    font-weight: 800;
    font-size: 1.25rem;
    margin: 0;
}

.relatorios-page .kpi--total {
    background: var(--nd-card-bg);
}

.relatorios-page .kpi--abertos {
    background: rgba(14,165,233,.10);
    border-color: rgba(14,165,233,.35);
}

    .relatorios-page .kpi--abertos::before {
        background: rgba(14,165,233,.55);
    }

    .relatorios-page .kpi--abertos .value {
        color: #0ea5e9;
    }

.relatorios-page .kpi--andamento {
    background: rgba(245,158,11,.12);
    border-color: rgba(245,158,11,.40);
}

    .relatorios-page .kpi--andamento::before {
        background: rgba(245,158,11,.65);
    }

    .relatorios-page .kpi--andamento .value {
        color: #d97706;
    }

.relatorios-page .kpi--pausa {
    background: rgba(107,114,128,.10);
    border-color: rgba(107,114,128,.35);
}

    .relatorios-page .kpi--pausa::before {
        background: rgba(107,114,128,.55);
    }

    .relatorios-page .kpi--pausa .value {
        color: #6b7280;
    }

.relatorios-page .kpi--fechados {
    background: rgba(16,185,129,.12);
    border-color: rgba(16,185,129,.35);
}

    .relatorios-page .kpi--fechados::before {
        background: rgba(16,185,129,.65);
    }

    .relatorios-page .kpi--fechados .value {
        color: #10b981;
    }

/* Tabela/Status/Charts */
.relatorios-page h6 {
    font-weight: 700;
}

.relatorios-page .status-card .table th,
.relatorios-page .status-card .table td {
    padding: .4rem .5rem;
}

.relatorios-page .status-card .table {
    font-size: .925rem;
}

.relatorios-page .status-grid {
    max-height: 240px;
    overflow: auto;
}

.relatorios-page .text-truncate {
    max-width: 260px;
}
/* Base dos botões preenchidos (Voltar/CTA secundários) */
.btn.btn-voltar {
    --btn-bg: var(--azul-primario, #1546d8);
    --btn-rgb: 21,70,216;
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    background-color: var(--btn-bg);
    border: 1.5px solid var(--btn-bg);
    color: #fff;
    font-weight: 700;
    border-radius: .5rem;
    padding: .5rem 1rem;
    line-height: 1.25;
    text-decoration: none;
    box-shadow: 0 4px 14px rgba(var(--btn-rgb), .25);
    transition: box-shadow .2s ease, transform .05s ease, color .2s ease;
}

    .btn.btn-voltar .bi {
        margin-right: .125rem;
    }

    .btn.btn-voltar:hover,
    .btn.btn-voltar:focus {
        /* mantém a cor; só adiciona anel branco + glow */
        background-color: var(--btn-bg);
        border-color: var(--btn-bg);
        color: #fff;
        box-shadow: 0 0 0 .24rem rgba(255,255,255,.85), 0 6px 18px rgba(var(--btn-rgb), .45);
        filter: none; /* impede "descorar" por filtros globais */
    }

[data-bs-theme="dark"] .btn.btn-voltar:hover,
[data-bs-theme="dark"] .btn.btn-voltar:focus {
    box-shadow: 0 0 0 .24rem rgba(255,255,255,.55), 0 6px 18px rgba(var(--btn-rgb), .60);
}

.btn.btn-voltar:focus-visible {
    outline: 0;
    box-shadow: 0 0 0 .28rem rgba(255,255,255,.80), 0 6px 18px rgba(var(--btn-rgb), .50);
}

.btn.btn-voltar:active {
    transform: translateY(1px);
}

/* Paletas reutilizáveis — aplicam cor ao .btn-voltar (cinza/primário/ciano...) */
.btn.btn-tone-primario {
    --btn-bg: var(--azul-primario, #1546d8);
    --btn-rgb: 21,70,216;
}

.btn.btn-tone-cinza {
    --btn-bg: #64748b;
    --btn-rgb: 100,116,139;
}
/* Limpar/Voltar/Cancelar */
.btn.btn-tone-ciano {
    --btn-bg: #0ea5e9;
    --btn-rgb: 14,165,233;
}

.btn.btn-tone-verde {
    --btn-bg: #16a34a;
    --btn-rgb: 22,163,74;
}

.btn.btn-tone-ambar {
    --btn-bg: #f59e0b;
    --btn-rgb: 245,158,11;
}

.btn.btn-tone-vermelho {
    --btn-bg: #e11d48;
    --btn-rgb: 225,29,72;
}
/* NOVO CHAMADO – manter preenchido no hover/focus (apenas nessa página) */
.novo-chamado-page .btn-primario:hover,
.novo-chamado-page .btn-primario:focus {
    background-color: var(--btn-bg, var(--azul-primario, #1546d8)) !important;
    border-color: var(--btn-bg, var(--azul-primario, #1546d8)) !important;
    color: #fff !important;
    filter: none !important;
    box-shadow: 0 0 0 .24rem rgba(255,255,255,.85), 0 6px 18px rgba(var(--btn-rgb, 21,70,216), .45) !important;
}

/* KB – Buscar / Adicionar Artigo / Detalhes */
.kb-page .btn-acao:hover,
.kb-page .btn-acao:focus,
.kb-modal .btn-acao:hover,
.kb-modal .btn-acao:focus {
    background-color: #0ea5e9 !important;
    border-color: #0891b2 !important;
    color: #fff !important;
    filter: none !important;
    box-shadow: 0 0 0 .24rem rgba(255,255,255,.85), 0 6px 18px rgba(14,165,233, .45) !important;
}

/* RELATÓRIOS – Aplicar */
.relatorios-page .btn-aplicar:hover,
.relatorios-page .btn-aplicar:focus {
    background-color: #0ea5e9 !important;
    border-color: #0891b2 !important;
    color: #fff !important;
    filter: none !important;
    box-shadow: 0 0 0 .24rem rgba(255,255,255,.85), 0 6px 18px rgba(14,165,233, .45) !important;
}
/* Botão de calendário – visual neutro, integrado ao input e com hover no brand */
.relatorios-page .btn-cal {
    height: 42px;
    border: 1px solid var(--bs-border-color);
    background: var(--bs-tertiary-bg);
    color: var(--bs-secondary-color);
    padding: 0 .75rem;
    border-radius: .375rem; /* igual ao input */
    box-shadow: 0 1px 2px rgba(0,0,0,.03);
}

    /* Hover/Focus com leve matiz do tema */
    .relatorios-page .btn-cal:hover,
    .relatorios-page .btn-cal:focus-visible {
        background: rgba(21,70,216,.08);
        border-color: var(--azul-primario);
        color: var(--azul-primario);
        box-shadow: 0 0 0 3px rgba(21,70,216,.15);
    }

/* Dark mode: tons mais suaves */
:root[data-bs-theme="dark"] .relatorios-page .btn-cal {
    background: rgba(255,255,255,.06);
    border-color: rgba(255,255,255,.14);
    color: #c7cfdb;
}

    :root[data-bs-theme="dark"] .relatorios-page .btn-cal:hover,
    :root[data-bs-theme="dark"] .relatorios-page .btn-cal:focus-visible {
        background: rgba(61,90,241,.16);
        border-color: #3d5af1;
        color: #e6e9ff;
        box-shadow: 0 0 0 3px rgba(61,90,241,.22);
    }

/* Integração visual com o input ao lado (sem “fatia” de borda duplicada) */
.relatorios-page .filters .input-group .form-control {
    border-right-width: 0;
}

.relatorios-page .filters .input-group .btn-cal {
    border-left-width: 0;
}

/* Ícone um pouco mais “fino” */
.relatorios-page .btn-cal .bi {
    font-size: 1rem;
    line-height: 1;
}
/* ===== MOBILE-FIRST: ocupar 100% da largura ===== */
@media (max-width: 991.98px) {
    /* Garante que nada limite a largura do conteúdo */
    .layout-app,
    .layout-app .conteudo,
    .layout-app .conteudo.container-fluid {
        width: 100% !important;
        max-width: none !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
    }

    /* Se houver containers internos, não deixa centralizar/limitar */
    .conteudo .container,
    .conteudo .container-sm,
    .conteudo .container-md,
    .conteudo .container-lg,
    .conteudo .container-xl,
    .conteudo .container-xxl {
        width: 100% !important;
        max-width: 100% !important;
        padding-left: 12px;
        padding-right: 12px;
    }

    /* Evita qualquer scroll lateral “fantasma” */
    html, body {
        overflow-x: hidden;
    }
}

/* ===== GRID só no desktop (mantém gaveta no mobile) ===== */
:root {
    --sidebar-w: 280px;
}

.offcanvas-lg.offcanvas-start {
    width: var(--sidebar-w);
}

@media (min-width: 992px) {
    .layout-app {
        display: grid;
        grid-template-columns: var(--sidebar-w) 1fr;
        min-height: 100vh;
    }

    .offcanvas-lg {
        position: static;
        transform: none !important;
        visibility: visible !important;
        background: transparent;
        border-right: 0;
    }

        .offcanvas-lg .offcanvas-header {
            display: none !important;
        }
}
/* ===== Overrides responsivos – Layout App ===== */
:root {
    --sidebar-w: 280px;
}

/* Largura do offcanvas no mobile */
#sidebarApp {
    --bs-offcanvas-width: var(--sidebar-w);
}

/* Desktop (>= lg): grid ativo e sidebar fixa */
@media (min-width: 992px) {
    .layout-app {
        display: grid;
        grid-template-columns: var(--sidebar-w) 1fr;
        min-height: 100vh;
    }

    .offcanvas-lg {
        position: static;
        transform: none !important;
        visibility: visible !important;
        background: transparent;
        border-right: 0;
    }

        .offcanvas-lg .offcanvas-header {
            display: none !important;
        }
}

/* Mobile (< lg): tudo fluido */
@media (max-width: 991.98px) {
    .layout-app {
        display: block !important;
        grid-template-columns: none !important;
        width: 100% !important;
        max-width: none !important;
        margin: 0 !important;
    }

    .topbar, .conteudo, .sidebar {
        grid-area: unset !important;
    }

        .conteudo,
        .conteudo.container-fluid {
            width: 100% !important;
            max-width: none !important;
            margin-left: 0 !important;
            margin-right: 0 !important;
            padding-left: 12px;
            padding-right: 12px;
        }

            .conteudo .container,
            .conteudo .container-sm,
            .conteudo .container-md,
            .conteudo .container-lg,
            .conteudo .container-xl,
            .conteudo .container-xxl {
                width: 100% !important;
                max-width: 100% !important;
                padding-left: 12px;
                padding-right: 12px;
                margin-left: 0 !important;
                margin-right: 0 !important;
            }

    html, body {
        overflow-x: hidden;
    }
}
@media (max-width: 575.98px) {
    .topbar {
        padding: .5rem .75rem;
    }
}
/* ========== Relatórios – layout responsivo e gráficos ========== */
.relatorios-page .bloco {
    border-radius: 14px;
    box-shadow: 0 10px 20px rgba(17,24,39,.06);
    border: 1px solid var(--nd-card-border);
    background: var(--nd-card-bg);
}

/* Filtros: grid 12 colunas (desktop) */
.relatorios-page .filters {
    display: grid;
    grid-template-columns: repeat(12,minmax(0,1fr));
    gap: 12px;
    align-items: end;
}

    .relatorios-page .filters > div {
        grid-column: span 3;
    }
    /* De | Até | Status */
    .relatorios-page .filters .actions {
        grid-column: span 3;
        display: flex;
        align-items: center;
        gap: 8px;
        flex-wrap: wrap;
    }

    .relatorios-page .filters .form-control,
    .relatorios-page .filters .form-select {
        height: 42px;
    }

    .relatorios-page .filters .input-group .btn,
    .relatorios-page .filters .actions .btn {
        height: 42px;
        border-radius: 10px;
    }

/* Botões dos filtros */
.relatorios-page .btn-aplicar {
    --aplicar-bg: #0ea5e9;
    background: var(--aplicar-bg);
    border: 1px solid #0891b2;
    color: #fff;
    font-weight: 700;
    padding: .45rem .9rem;
    box-shadow: 0 2px 8px rgba(14,165,233,.25);
}

    .relatorios-page .btn-aplicar:hover {
        filter: brightness(1.05);
        box-shadow: 0 4px 12px rgba(14,165,233,.35);
    }

    .relatorios-page .btn-aplicar:active {
        transform: translateY(1px);
    }

.relatorios-page .btn-limpar,
.relatorios-page .btn-voltar {
    background: transparent;
    color: var(--bs-body-color);
    border: 1px solid var(--bs-border-color);
    font-weight: 600;
    padding: .45rem .8rem;
}

    .relatorios-page .btn-limpar:hover,
    .relatorios-page .btn-voltar:hover {
        background: rgba(21,70,216,.10);
        border-color: var(--azul-primario);
        color: var(--azul-primario);
        box-shadow: 0 2px 8px rgba(21,70,216,.18);
    }

:root[data-bs-theme="dark"] .relatorios-page .btn-limpar:hover,
:root[data-bs-theme="dark"] .relatorios-page .btn-voltar:hover {
    background: rgba(61,90,241,.20);
    color: #cfd8ff;
    border-color: #3d5af1;
}

/* KPIs / tabelas */
.relatorios-page .kpi-grid .kpi {
    position: relative;
    overflow: hidden;
}

    .relatorios-page .kpi-grid .kpi::before {
        content: "";
        position: absolute;
        inset: 0 0 auto 0;
        height: 4px;
        background: var(--bs-tertiary-bg);
    }

.relatorios-page .kpi .label {
    color: var(--bs-secondary-color,#6b7280);
    font-size: .875rem;
}

.relatorios-page .kpi .value {
    font-weight: 800;
    font-size: 1.25rem;
    margin: 0;
}

.relatorios-page table thead th {
    background: var(--bs-tertiary-bg);
    border-bottom-color: var(--bs-border-color);
    font-weight: 700;
}

.relatorios-page .status-card .table {
    font-size: .925rem;
}

    .relatorios-page .status-card .table th,
    .relatorios-page .status-card .table td {
        padding: .4rem .5rem;
    }

.relatorios-page .status-grid {
    max-height: 240px;
    overflow: auto;
}

/* Gráficos: altura por breakpoint */
#chartStatus, #chartDia {
    width: 100% !important;
    height: 220px !important;
}

@media (min-width:576px) {
    #chartStatus, #chartDia {
        height: 260px !important;
    }
}

@media (min-width:992px) {
    #chartDia {
        height: 320px !important;
    }
}

/* Breakpoints dos filtros */
@media (max-width:991.98px) {
    .relatorios-page .filters > div {
        grid-column: span 6;
    }

    .relatorios-page .filters .actions {
        grid-column: 1 / -1;
        display: grid;
        grid-template-columns: 1fr 1fr;
    }

        .relatorios-page .filters .actions .btn {
            width: 100%;
        }
}

@media (max-width:575.98px) {
    .relatorios-page .filters {
        grid-template-columns: 1fr;
    }

        .relatorios-page .filters > div,
        .relatorios-page .filters .actions {
            grid-column: auto;
        }

        .relatorios-page .filters .actions {
            grid-template-columns: 1fr;
        }
}

/* Cores dos cartões (mantidas) */
.relatorios-page .kpi--abertos {
    background: rgba(14,165,233,.10);
    border-color: rgba(14,165,233,.35);
}

    .relatorios-page .kpi--abertos::before {
        background: rgba(14,165,233,.55);
    }

    .relatorios-page .kpi--abertos .value {
        color: #0ea5e9;
    }

.relatorios-page .kpi--andamento {
    background: rgba(245,158,11,.12);
    border-color: rgba(245,158,11,.40);
}

    .relatorios-page .kpi--andamento::before {
        background: rgba(245,158,11,.65);
    }

    .relatorios-page .kpi--andamento .value {
        color: #d97706;
    }

.relatorios-page .kpi--pausa {
    background: rgba(107,114,128,.10);
    border-color: rgba(107,114,128,.35);
}

    .relatorios-page .kpi--pausa::before {
        background: rgba(107,114,128,.55);
    }

    .relatorios-page .kpi--pausa .value {
        color: #6b7280;
    }

.relatorios-page .kpi--fechados {
    background: rgba(16,185,129,.12);
    border-color: rgba(16,185,129,.35);
}

    .relatorios-page .kpi--fechados::before {
        background: rgba(16,185,129,.65);
    }

    .relatorios-page .kpi--fechados .value {
        color: #10b981;
    }

/* Ajuste de padding da topbar em telas muito pequenas (opcional) */
@media (max-width:575.98px) {
    .topbar {
        padding: .5rem .75rem;
    }
}
