﻿/**
 * Theme layer — NPA v2.
 *
 * Cascade (orden real de carga):
 *   1) tokens.css → style.css → theme-layer.css (estático en index.html)
 *   2) Al navegar el SPA, router.js puede cargar CSS de página después de este archivo.
 * Prefer var(--*) from tokens.css; avoid duplicating large blocks from style.css.
 *
 */

/* -----------------------------
   Base wrappers
------------------------------ */
#layout-wrapper {
    background: var(--background);
    color: var(--foreground);
}

    #layout-wrapper .content {
        padding: 15px 15px 40px 15px !important;
    }

    #layout-wrapper > #wrapper > .content[data-child="hpanel"] {
        padding-top: 10px !important;
    }

    #layout-wrapper .content,
    #layout-wrapper #wrapper {
        background: transparent;
    }

    #layout-wrapper #wrapper {
        border: none;
    }

#account-wrapper,
#external-survey-wrapper,
#legal-wrapper,
#default-wrapper {
    color: var(--foreground);
}

/* -----------------------------
 Sidebar (aligned with partial menu/menu.html + menu.js MetisMenu)
------------------------------ */
/* Beat style.css #menu { background-color: … !important } with full shorthand */
#layout-wrapper #logo {
    padding: 14px 10px 14px 14px;
}

#layout-wrapper #menu {
    background: linear-gradient( 180deg, var(--sidebar) 0%, color-mix(in oklab, var(--sidebar) 82%, var(--brand-navy-deep)) 100% ) !important;
}

    /* Flex column: brand block fixed height, #side-menu-container scrolls */
    #layout-wrapper #menu .npa-sidebar-root {
        display: flex;
        flex-direction: column;
        height: 100%;
        min-height: 0;
        background: transparent;
    }

    /* Platform header: bloque apilado — logo (tarjeta blanca, ~72px alto) y tipo debajo */
    #layout-wrapper #menu .npa-sidebar-brand {
        flex: 0 0 auto;
        margin: 0;
        padding: 0;
        border-radius: 0;
        background: var(--sidebar);
        border: none;
        border-bottom: 1px solid var(--sidebar-border);
        width: 100%;
        box-sizing: border-box;
    }

    #layout-wrapper #menu .npa-sidebar-brand__logo-link {
        display: block;
        width: 100%;
        padding: 14px 16px 8px;
        text-align: center;
        cursor: pointer;
        box-sizing: border-box;
    }

        /* Relación 1:1 — anula #Menu_PlatformImage en style.css (115×130) */
        #layout-wrapper #menu .npa-sidebar-brand__logo-link img,
        #layout-wrapper #menu #Menu_PlatformImage {
            display: inline-block;
            vertical-align: middle;
            width: 120px !important;
            height: auto !important;
            max-width: min(100%, 120px) !important;
            aspect-ratio: 1 / 1 !important;
            margin: 0 auto;
            padding: 8px;
            object-fit: contain;
            background: var(--color-white);
            border-radius: var(--radius);
            border: 1px solid var(--sidebar-border);
            box-sizing: border-box;
        }

    #layout-wrapper #menu .npa-sidebar-brand__title {
        margin: 0;
        padding: 6px 16px 16px;
        text-align: center;
        line-height: 1.3;
    }

        #layout-wrapper #menu .npa-sidebar-brand__title span {
            color: var(--color-white) !important;
            font-weight: 500 !important;
            font-size: 14px;
            letter-spacing: 0.01em;
            display: block;
        }

    #layout-wrapper #menu #side-menu-container {
        flex: 1 1 auto;
        min-height: 0;
        overflow-x: hidden;
        overflow-y: auto;
        scrollbar-width: thin;
        scrollbar-color: color-mix(in oklab, var(--sidebar-foreground) 35%, transparent) transparent;
    }

        #layout-wrapper #menu #side-menu-container::-webkit-scrollbar {
            width: 6px;
        }

        #layout-wrapper #menu #side-menu-container::-webkit-scrollbar-thumb {
            background: color-mix(in oklab, var(--sidebar-foreground) 30%, transparent);
            border-radius: 6px;
        }

#layout-wrapper #side-menu {
    background: transparent;
    padding: 0;
    margin: 0;
}

    #layout-wrapper #side-menu .menu-item menu-item-selected {
        outline: none !important;
        box-shadow: none !important;
    }

    /* Tabler Icons + generic menu icons (IconClass from API, e.g. ti ti-leaf) */
    #layout-wrapper #side-menu a .npa-menu-icon {
        flex-shrink: 0;
        font-size: 1.7rem;
        line-height: 1;
        width: 1.5rem;
        text-align: center;
        color: inherit;
        opacity: 0.6;
        align-self: center;
    }

i.ti:before {
    font-weight: 300 !important;
}

#layout-wrapper #side-menu a .npa-menu-icon.ti {
    font-size: 1.75rem;
    width: 1.75rem;
}

#layout-wrapper #side-menu a .nav-label {
    flex: 1 1 auto;
    min-width: 0;
    display: block;
    line-height: initial;
}

#layout-wrapper #side-menu a .npa-menu-lock {
    margin-left: auto;
    flex-shrink: 0;
    float: none !important;
    font-size: 1rem;
    opacity: 0.9;
}

#layout-wrapper #side-menu > li > a .pe-7s-lock,
#layout-wrapper #side-menu > li > a .npa-menu-lock {
    color: color-mix(in oklab, var(--sidebar-foreground) 65%, var(--warning));
}

/* Top-level items — full width; azul solo en .menu-item-selected (hoja) */
#layout-wrapper #side-menu > li > a {
    display: flex;
    align-items: center;
    gap: var(--sidebar-icon-gap);
    min-height: var(--sidebar-item-min-height);
    margin: 0;
    padding: 10px var(--sidebar-top-link-pad-x) !important;
    border-radius: 0;
    color: var(--color-white);
    font-weight: 500 !important;
    font-size: 13px;
    background: transparent;
    transition: background-color 0.15s ease, color 0.15s ease;
}

    #layout-wrapper #side-menu > li > a [class^="pe-7s-"]:not(.npa-menu-lock),
    #layout-wrapper #side-menu > li > a .fa:not(.arrow) {
        flex-shrink: 0;
        font-size: 1.25rem;
        opacity: 0.92;
        width: 1.35rem;
        text-align: center;
    }

    #layout-wrapper #side-menu > li > a .fa.arrow {
        margin-left: auto;
        opacity: 0.75;
        font-size: 11px;
    }

    #layout-wrapper #side-menu > li > a:hover,
    #layout-wrapper #side-menu > li > a:focus {
        background: color-mix(in oklab, var(--sidebar-accent) 55%, transparent) !important;
        color: var(--color-white) !important;
    }

/* Rama de módulo expandida: caja con margen lateral; sin padding horizontal en el li
 (evita doble hueco con el padding del <a> y desalinea el padre respecto a hermanos). */
#layout-wrapper #side-menu > li.active {
    background: color-mix(in oklab, var(--sidebar-accent) 55%, transparent) !important;
}



#layout-wrapper #side-menu li.active > ul {
    margin-top: 2px;
}

    #layout-wrapper #side-menu li.active > ul li {
        margin-top: 2px;
        background: transparent;
    }

#layout-wrapper #side-menu li a {
    background: transparent;
}
/* Padre del módulo: sin azul sólido; el resaltado fuerte es solo el hijo seleccionado */
#layout-wrapper #side-menu > li.active > a:not(.menu-item-selected) {
    background: transparent !important;
    color: var(--color-white) !important;
    font-weight: 600 !important;
    box-shadow: none;
}

    #layout-wrapper #side-menu > li.active > a:not(.menu-item-selected):hover,
    #layout-wrapper #side-menu > li.active > a:not(.menu-item-selected):focus {
        background: color-mix(in oklab, var(--sidebar-accent) 35%, transparent) !important;
        color: var(--color-white) !important;
    }

/* Página actual (hoja): azul con ligero inset dentro de la caja del módulo */
#layout-wrapper #side-menu a.menu-item.menu-item-selected {
    background: var(--brand-blue) !important;
    color: var(--color-white) !important;
    font-weight: 600 !important;
    box-shadow: none !important;
}

/* Nested lists (MetisMenu) */
#layout-wrapper #side-menu ul {
    margin-left: 0;
    padding-left: 0;
    border-left: none;
    background: transparent !important;
}

#layout-wrapper #side-menu .nav-second-level,
#layout-wrapper #side-menu .nav-third-level {
    margin: 0;
    padding: 0;
    border-left: none;
}

    #layout-wrapper #side-menu .nav-second-level li a,
    #layout-wrapper #side-menu .nav-third-level li a {
        display: flex;
        align-items: center;
        gap: var(--sidebar-icon-gap);
        margin: 0;
        padding: 9px 14px 9px var(--sidebar-child-indent-2) !important;
        border-radius: 0;
        color: var(--color-white);
        font-weight: 500 !important;
        font-size: 13px;
    }

    #layout-wrapper #side-menu .nav-third-level li a {
        padding-left: var(--sidebar-child-indent-3) !important;
    }

#layout-wrapper #side-menu .nav-four-level li a {
    padding-left: var(--sidebar-child-indent-3) !important;
}

/* Carpetas intermedias en submenús: sin azul; solo .menu-item-selected lleva brand-blue */
#layout-wrapper #side-menu .nav-second-level li.active > a:not(.menu-item-selected),
#layout-wrapper #side-menu .nav-third-level li.active > a:not(.menu-item-selected),
#layout-wrapper #side-menu .nav-four-level li.active > a:not(.menu-item-selected) {
    background: transparent !important;
    color: var(--color-white) !important;
    font-weight: 500 !important;
    box-shadow: none;
}

#layout-wrapper #side-menu .nav-second-level li a:hover,
#layout-wrapper #side-menu .nav-third-level li a:hover {
    background: color-mix(in oklab, var(--sidebar-accent) 50%, transparent) !important;
    color: var(--color-white) !important;
}

#layout-wrapper #side-menu.metismenu > li > a {
    transition: background-color 0.18s ease, color 0.18s ease, box-shadow 0.18s ease;
}

/* light-skin: Homer hides .profile-picture; keep nav readable on dark bar */
body.light-skin #layout-wrapper #menu {
    background: var(--sidebar) !important;
}

body.light-skin #layout-wrapper #side-menu > li > a {
    color: var(--sidebar-foreground);
}

    body.light-skin #layout-wrapper #side-menu > li > a:hover,
    body.light-skin #layout-wrapper #side-menu > li > a:focus {
        color: var(--sidebar-primary-foreground) !important;
    }

/* -----------------------------
 Header / top chrome
------------------------------ */
#layout-wrapper #header {
    background: var(--card);
}

    #layout-wrapper #header .navbar,
    #layout-wrapper #header .navbar-static-top {
        background: transparent;
    }

#layout-wrapper .navbar-right > li > a {
    color: var(--foreground);
}

    #layout-wrapper .navbar-right > li > a:hover,
    #layout-wrapper .navbar-right > li > a:focus {
        color: var(--brand-blue);
    }

/* Barra superior del header: flex; los nodos con display:none (p. ej. .small-logo en desktop,
   .navbar-toggle ≥768px) no son ítems flex y no cuentan para space-between — solo quedan .navbar-left y .navbar-right. */
#layout-wrapper #header .npa-header-topnav {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem 1rem;
    margin-top: 1.2rem;
    padding: 0 2rem;
    box-sizing: border-box;
    min-height: 2.75rem;
}

#layout-wrapper #header .navbar-left,
#layout-wrapper #header .navbar-right {
    float: none !important;
}

#layout-wrapper #header .navbar-right {
    margin-right: 1rem;
}

#layout-wrapper #header .small-logo {
    float: none !important;
    flex: 0 0 auto;
}

#layout-wrapper #header .mobile-menu {
    float: none !important;
    flex: 0 0 auto;
}

#layout-wrapper #header .npa-header-workspace {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    min-width: 0;
    flex: 1 1 auto;
    justify-content: flex-start;
}

#layout-wrapper #header .npa-header-actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    flex: 0 0 auto;
    min-width: 0;
}

#layout-wrapper #header .navbar-left > .btn.dropdown,
#layout-wrapper #header .navbar-right > .btn.dropdown {
    position: relative;
    display: inline-flex;
    align-items: center;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--card);
    padding: 0;
    margin: 0;
    min-height: 2.75rem;
    box-shadow: none;
    vertical-align: middle;
}

    #layout-wrapper #header .navbar-left > .btn.dropdown > .dropdown-toggle,
    #layout-wrapper #header .navbar-right > .btn.dropdown > .dropdown-toggle {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex: 1 1 auto;
        min-height: 2.75rem;
        padding: 8px 14px;
        margin: 0;
        color: inherit;
        text-decoration: none !important;
        border-radius: inherit;
    }

    #layout-wrapper #header .navbar-left > .btn.dropdown:hover,
    #layout-wrapper #header .navbar-left > .btn.dropdown:focus,
    #layout-wrapper #header .navbar-right > .btn.dropdown:hover,
    #layout-wrapper #header .navbar-right > .btn.dropdown:focus {
        background: var(--secondary);
        border-color: var(--border);
    }

#layout-wrapper #header .navbar-left .npa-header-chip,
#layout-wrapper #header .navbar-right .npa-header-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    line-height: 1.2;
    vertical-align: middle;
}

#layout-wrapper #header .navbar-left .npa-header-chip__icon,
#layout-wrapper #header .navbar-right .npa-header-chip__icon {
    flex-shrink: 0;
    font-size: 1.75rem;
    line-height: 1;
    color: var(--brand-blue);
}

#layout-wrapper #header .navbar-left > .btn.dropdown:hover .npa-header-chip__icon,
#layout-wrapper #header .navbar-left > .btn.dropdown:focus .npa-header-chip__icon,
#layout-wrapper #header .navbar-right > .btn.dropdown:hover .npa-header-chip__icon,
#layout-wrapper #header .navbar-right > .btn.dropdown:focus .npa-header-chip__icon {
    color: color-mix(in oklab, var(--brand-blue) 82%, var(--brand-navy-deep));
}

#layout-wrapper #header .navbar-left .npa-header-chip__label,
#layout-wrapper #header .navbar-right .npa-header-chip__label {
    max-width: 11rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    margin: 0;
    color: var(--foreground);
    font-weight: 500;
    font-size: 13px;
}

#layout-wrapper #header .navbar-left .npa-header-chip__caret,
#layout-wrapper #header .navbar-right .npa-header-chip__caret {
    flex-shrink: 0;
    font-size: 1rem;
    line-height: 1;
    opacity: 0.55;
    color: var(--muted-foreground);
}

#layout-wrapper #header .npa-header-dropdown {
    margin-top: 4px;
}

#layout-wrapper #header .navbar-left .npa-header-dropdown {
    left: 0 !important;
    right: auto !important;
}

#layout-wrapper #header .navbar-right .dropdown-menu.dropdown-menu-right {
    left: auto !important;
    right: 0 !important;
}

/* Móvil: varios ítems visibles a la vez; evitar space-between que separa demasiado el bloque */
@media (max-width: 767px) {
    #layout-wrapper #header .npa-header-topnav {
        justify-content: flex-start;
        align-items: center;
    }
}

/* -----------------------------
 Ribbon / module tabs
------------------------------ */
/* Defined in style.css: #breadCrumRibbon + .npa-tabs-pill (index.html). */

#layout-wrapper #breadCrumRibbon > li:focus,
#layout-wrapper #breadCrumRibbon > li:focus-visible {
    outline: none;
    box-shadow: none;
}

#layout-wrapper #breadCrumRibbon > li > a:focus,
#layout-wrapper #breadCrumRibbon > li > a:focus-visible {
    outline: none !important;
    outline-offset: 0;
    box-shadow: none !important;
}

#layout-wrapper #breadCrumRibbon > li > a {
    display: inline-flex;
    align-items: center;
    gap: 0.4rem;
}

#layout-wrapper #breadCrumRibbon .npa-menu-icon {
    flex-shrink: 0;
    font-size: 1.25em;
    line-height: 1;
    opacity: 0.9;
}

#layout-wrapper #breadCrumRibbon > li.active > a .npa-menu-icon {
    color: inherit;
    opacity: 1;
}

#layout-wrapper .small-header .hpanel {
    background: transparent;
    border: none;
    box-shadow: none;
}

    #layout-wrapper .small-header .hpanel .panel-body {
        background: var(--card);
        border: 1px solid var(--border);
        border-radius: var(--radius);
        box-shadow: var(--shadow-card);
    }

/* -----------------------------
 Panels / cards
------------------------------ */
#layout-wrapper .hpanel > .panel-heading,
#layout-wrapper .hpanel .panel-heading {
    background: var(--card);
    border-color: var(--border);
    color: var(--foreground);
}

#layout-wrapper .hpanel .panel-body {
    background: var(--card);
    border-color: var(--border);
}



#layout-wrapper .panel,
#layout-wrapper .panel-default {
    border-color: var(--border);
}

#layout-wrapper .panel-heading-npa {
    border-radius: var(--radius) var(--radius) 0 0;
}

#layout-wrapper .npa-card-table,
#layout-wrapper .card-border {
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--card);
    box-shadow: var(--shadow-card);
}

/* -----------------------------
 Typography / badges / helper text
------------------------------ */
#layout-wrapper .text-muted {
    color: var(--muted-foreground) !important;
}

#layout-wrapper .text-npa,
#layout-wrapper .title-chart,
#layout-wrapper .span-total-grid {
    color: var(--brand-navy) !important;
}

#layout-wrapper .badge {
    border-radius: calc(var(--radius) - 2px);
    font-weight: 600;
}

#layout-wrapper .badge-npa-light {
    background: var(--muted) !important;
    color: var(--foreground) !important;
}

#layout-wrapper .badge-success {
    background: color-mix(in oklab, var(--success) 28%, var(--card)) !important;
    color: color-mix(in oklab, var(--foreground) 15%, var(--success)) !important;
}

#layout-wrapper .badge-warning {
    background: color-mix(in oklab, var(--warning) 35%, var(--card)) !important;
    color: var(--brand-navy) !important;
}

#layout-wrapper .badge-danger {
    background: color-mix(in oklab, var(--destructive) 22%, var(--card)) !important;
    color: var(--destructive) !important;
}

/* -----------------------------
 Buttons
------------------------------ */
.btn {
    border-radius: calc(var(--radius) - 2px);
    transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
    font-size: 13px;
    font-weight: 500;
}

    .btn i {
        font-weight: normal;
    }

#layout-wrapper .btn span {
    font-weight: 500;
}

.btn:focus,
.btn:active:focus {
    outline: none;
    box-shadow: 0 0 0 2px color-mix(in oklab, var(--ring) 24%, transparent);
}

.btn-default {
    background: var(--card);
    border-color: var(--border);
    color: var(--foreground);
}

    .btn-default:hover {
        background: var(--secondary);
        border-color: var(--border);
        color: var(--foreground);
    }

.btn-primary {
    background: var(--brand-navy);
    border-color: var(--brand-navy);
    color: var(--color-white);
}

    .btn-primary:hover,
    .btn-primary:focus {
        background: var(--brand-navy-deep);
        border-color: var(--brand-navy-deep);
    }

.btn-info {
    background: var(--brand-blue);
    border-color: var(--brand-blue);
    color: var(--color-white);
}

    .btn-info:hover,
    .btn-info:focus {
        background: color-mix(in oklab, var(--brand-blue) 85%, var(--brand-navy));
        border-color: color-mix(in oklab, var(--brand-blue) 85%, var(--brand-navy));
    }

.btn-success {
    background: var(--success);
    border-color: var(--success);
    color: var(--color-white);
}

.btn-warning {
    background: var(--warning);
    border-color: var(--warning);
    color: var(--brand-navy);
}

.btn-danger {
    background: var(--destructive);
    border-color: var(--destructive);
    color: var(--destructive-foreground);
}

/* -----------------------------
   NPA UI primitives (clases cortas reutilizables; Bootstrap 3 + tokens)
------------------------------ */

#layout-wrapper .npa-chip {
    display: inline-flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    border-radius: var(--radius);
    border: 1px solid color-mix(in oklab, var(--border) 88%, transparent);
    background: color-mix(in oklab, var(--muted) 35%, var(--card));
    color: var(--foreground);
    font-size: 13px;
    font-weight: 500;
    line-height: 1.25;
    max-width: 100%;
    flex: 0 1 auto;
    box-sizing: border-box;
}

    #layout-wrapper .npa-chip #DDQuestionnaireDetailForm_TargetBadgeText {
        min-width: 0;
        word-break: break-word;
    }

#layout-wrapper .npa-chip__icon {
    flex-shrink: 0;
    opacity: 0.75;
    font-size: 14px;
    line-height: 1;
}

/* Tarjeta-paso con índice circular (wizard / pestañas tipo DD Questionnaire) */
#layout-wrapper .npa-step-tab {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-start;
    gap: 14px;
    width: 100%;
    box-sizing: border-box;
    margin: 0;
    padding: 14px 16px;
    text-align: left;
    cursor: pointer;
    font-family: inherit;
    line-height: 1.3;
    border-radius: calc(var(--radius, 4px) + 4px);
    border: 1px solid color-mix(in oklab, var(--border) 82%, var(--brand-blue));
    background: color-mix(in oklab, var(--brand-blue) 5%, var(--card));
    color: var(--foreground);
    transition: background-color 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

    #layout-wrapper .npa-step-tab:hover:not(:disabled) {
        border-color: color-mix(in oklab, var(--brand-blue) 55%, var(--border));
        background: color-mix(in oklab, var(--brand-blue) 9%, var(--card));
    }

    #layout-wrapper .npa-step-tab:focus {
        outline: none;
    }

    #layout-wrapper .npa-step-tab:focus-visible {
        outline: 2px solid var(--brand-blue);
        outline-offset: 2px;
    }

    #layout-wrapper .npa-step-tab:disabled {
        cursor: not-allowed;
        opacity: 0.55;
    }

#layout-wrapper .npa-step-tab--active {
    border-color: color-mix(in oklab, var(--brand-blue) 72%, var(--border));
    background: color-mix(in oklab, var(--brand-blue) 12%, var(--card));
    box-shadow: 0 0 0 1px color-mix(in oklab, var(--brand-blue) 18%, transparent);
}

#layout-wrapper .npa-step-tab__index {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 50%;
    font-size: 15px;
    font-weight: 700;
    line-height: 1;
    background: var(--brand-blue);
    color: var(--color-white);
}

    #layout-wrapper .npa-step-tab__index .ti {
        line-height: 1;
    }

#layout-wrapper .npa-step-tab__index--done {
    background: var(--brand-blue);
}

#layout-wrapper .npa-step-tab__body {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: 2px;
    min-width: 0;
    flex: 1 1 auto;
}

#layout-wrapper .npa-step-tab__title {
    font-size: 15px;
    font-weight: 500;
    line-height: 1.25;
    color: var(--brand-navy-deep, var(--foreground));
}

#layout-wrapper .npa-step-tab__desc {
    font-size: 13px;
    font-weight: 400;
    line-height: 1.35;
    color: var(--muted-foreground);
}

/* Modal Nuevo usuario (Recipients): fila email + Continuar, centrado vertical */
#layout-wrapper .npa-dd-recipients-user-modal__verify-row {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
}

    #layout-wrapper .npa-dd-recipients-user-modal__verify-row > [class*="col-"] {
        float: none;
    }

#layout-wrapper .npa-dd-recipients-user-modal__verify-actions {
    display: flex;
    justify-content: flex-end;
    align-items: center;
}

@media (max-width: 767px) {
    #layout-wrapper .npa-dd-recipients-user-modal__verify-actions {
        justify-content: flex-start;
        margin-top: 0.5rem;
    }
}

/* Píldora de estado (listados, tablas, filtros); variantes semánticas reutilizables */
#layout-wrapper .npa-badge-status {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 4px 12px;
    border-radius: var(--radius);
    font-size: 13px;
    font-weight: 600;
    line-height: 1.25;
    white-space: nowrap;
    box-sizing: border-box;
}

#layout-wrapper .npa-badge-status__icon {
    flex-shrink: 0;
    font-size: 14px;
    line-height: 1;
}

#layout-wrapper .npa-badge-status__dot {
    flex-shrink: 0;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: currentColor;
    opacity: 0.85;
}

#layout-wrapper .npa-badge-status__label {
    min-width: 0;
}

#layout-wrapper .npa-badge-status--finished {
    background: color-mix(in oklab, var(--success) 20%, var(--card));
    color: color-mix(in oklab, var(--foreground) 10%, var(--success));
}

#layout-wrapper .npa-badge-status--progress {
    background: color-mix(in oklab, var(--warning) 22%, var(--card));
    color: color-mix(in oklab, var(--foreground) 88%, var(--warning));
}

#layout-wrapper .npa-badge-status--created {
    background: color-mix(in oklab, var(--brand-blue) 14%, var(--card));
    color: color-mix(in oklab, var(--brand-navy-deep) 75%, var(--foreground));
}

#layout-wrapper .npa-badge-status--notstarted {
    background: color-mix(in oklab, var(--muted) 28%, var(--card));
    color: var(--muted-foreground);
}

#layout-wrapper .npa-badge-status--error {
    background: color-mix(in oklab, var(--danger) 28%, var(--card));
    color: var(--muted-foreground);
}

#layout-wrapper .npa-badge-status-finished {
    background: color-mix(in oklab, var(--success) 20%, var(--card));
    color: color-mix(in oklab, var(--foreground) 10%, var(--success));
    border: solid 1px color-mix(in oklab, var(--foreground) 10%, var(--success) 5%);
}

#layout-wrapper .npa-badge-status-progress {
    background: color-mix(in oklab, var(--warning) 22%, var(--card));
    color: color-mix(in oklab, var(--foreground) 88%, var(--warning));
    border: solid 1px color-mix(in oklab, var(--foreground) 88%, var(--warning) 5%);
}

#layout-wrapper .npa-badge-status-created {
    background: color-mix(in oklab, var(--brand-blue) 14%, var(--card));
    color: color-mix(in oklab, var(--brand-navy-deep) 75%, var(--foreground));
    border: solid 1px color-mix(in oklab, var(--brand-navy-deep) 75%, var(--foreground) 5%);
}

#layout-wrapper .npa-badge-status-notstarted {
    background: color-mix(in oklab, var(--muted) 28%, var(--card));
    color: var(--muted-foreground);
    border: solid 1px color-mix(in oklab, var(--muted) 48%, var(--card));
}

#layout-wrapper .npa-badge-status-error {
    background: color-mix(in oklab, var(--destructive) 8%, var(--card));
    color: color-mix(in oklab, var(--foreground) 10%, var(--destructive));
    border: solid 1px color-mix(in oklab, var(--foreground) 10%, var(--destructive) 5%);
}

#layout-wrapper .btn.npa-btn--toolbar-sm {
    min-height: 2.25rem;
    padding: 0.375rem 10px;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.2;
    box-sizing: border-box;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: var(--radius);
}

#layout-wrapper .btn.btn-link.npa-link-back,
#layout-wrapper .btn.npa-link-back {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 0;
    margin: 0 0 10px;
    font-size: 14px;
    font-weight: 500;
    color: var(--muted-foreground);
    text-decoration: none !important;
    border: none;
    box-shadow: none;
    background: transparent !important;
    min-height: 0;
}

    #layout-wrapper .btn.btn-link.npa-link-back:hover,
    #layout-wrapper .btn.btn-link.npa-link-back:focus,
    #layout-wrapper .btn.npa-link-back:hover,
    #layout-wrapper .btn.npa-link-back:focus {
        color: var(--brand-blue);
    }

    #layout-wrapper .btn.btn-link.npa-link-back .fa-angle-left,
    #layout-wrapper .btn.npa-link-back .fa-angle-left {
        font-size: 16px;
        line-height: 1;
        margin-right: 2px;
    }

/* DD KPI config / recipients: lista + botones de navegación (antes anclados solo en questionnaire.css) */
#layout-wrapper .dd-qconf-kpi-nav {
    list-style: none;
    padding: 0;
    margin: 0;
}

#layout-wrapper .dd-qconf-nav-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 2.125rem;
    padding: 6px 14px;
    line-height: 1.2;
    box-sizing: border-box;
}

#layout-wrapper .dd-qconf-nav-btn__inner {
    display: inline-flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
    gap: 8px;
    line-height: 1.2;
}

    #layout-wrapper .dd-qconf-nav-btn__inner > .fa {
        flex-shrink: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 1em;
        height: 1em;
        margin: 0;
        padding: 0;
        font-size: 12px;
        line-height: 1;
        vertical-align: middle;
    }

        #layout-wrapper .dd-qconf-nav-btn__inner > .fa::before {
            display: block;
            line-height: 1;
        }

/* Fila genérica de filtros (opcional en markup); misma intención que toolbar KPI */
#layout-wrapper .npa-filter-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 14px 16px;
}

/* Barra de acciones encima de tabla (DataTables, treetable, etc.) */
#layout-wrapper .npa-table-toolbar {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    padding: 0 0 10px;
    margin: 0;
    box-sizing: border-box;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

#layout-wrapper .npa-toolbar-actions {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    box-sizing: border-box;
}

/* -----------------------------
   Tablas: columna Actions, celdas KPI y grupos de iconos (npa-*; convive con filas treetable dd-custom-fw-row--*)
------------------------------ */
#layout-wrapper table tbody tr.dd-custom-fw-row--headline td.npa-table-td-actions {
    display: table-cell;
    text-align: right;
    vertical-align: middle;
}

#layout-wrapper table tbody tr.dd-custom-fw-row--kpi td.npa-table-td-actions {
    display: table-cell;
    vertical-align: middle;
    text-align: center;
}

#layout-wrapper table .npa-kpi-cell {
    display: flex;
    align-items: center;
    box-sizing: border-box;
    min-height: 2.75rem;
    padding: 8px;
}

#layout-wrapper table .npa-kpi-cell--topic {
    justify-content: flex-start;
}

#layout-wrapper table .npa-kpi-cell--type {
    justify-content: flex-start;
}

#layout-wrapper table .npa-kpi-cell--actions {
    justify-content: center;
}

#layout-wrapper table .npa-kpi-cell .btn-grid > i {
    padding: 0 !important;
    line-height: 1;
    vertical-align: middle;
}

#layout-wrapper table .npa-table-actions {
    display: inline-flex;
    align-items: center;
    gap: calc(var(--spacing)*2);
    flex-wrap: nowrap;
    flex-shrink: 0;
    min-height: 28px;
    min-width: 0;
    white-space: nowrap;
}

#layout-wrapper table .npa-table-actions--end {
    width: 100%;
    justify-content: flex-end;
    margin-left: 0;
}

#layout-wrapper table td:has(.btn-grid) {
    display: flex;
    gap: calc(var(--spacing) * 2);
    justify-content: center;
}

#layout-wrapper table .btn-grid {
    flex-shrink: 0;
    padding: 3px;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    align-content: center;
    flex-wrap: wrap;
    min-width: 32px;
    margin: 0 !important;
}

#layout-wrapper table td.npa-table-td-actions,
#layout-wrapper table th.npa-table-th-actions {
    white-space: nowrap;
}

#layout-wrapper table .btn-grid i {
    font-size: 16px;
    align-self: center;
    display: block;
    margin: 0;
    top: 0 !important;
    padding: 0 !important;
}
/* -----------------------------
 Forms / inputs / search
------------------------------ */
#layout-wrapper .form-control,
#layout-wrapper .custom-select,
#layout-wrapper textarea.form-control {
    border: 1px solid var(--input);
    border-radius: var(--radius);
    color: var(--foreground);
    background: var(--card);
    box-shadow: none;
    padding: 0 18px 3px 6px !important;
}

    #layout-wrapper .form-control:focus,
    #layout-wrapper .custom-select:focus,
    #layout-wrapper textarea.form-control:focus {
        outline: none;
    }

#layout-wrapper .input-group-addon {
    border-color: var(--border);
    background: var(--muted);
    color: var(--muted-foreground);
}

    #layout-wrapper .input-group-addon .ti {
        font-size: 1rem;
        line-height: 1;
        vertical-align: -0.1em;
    }

/* Input group: alineación NPA + radios en el encaje control ↔ addon (Bootstrap 3) */
#layout-wrapper .input-group {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: stretch;
    width: 100%;
    position: relative;
}

    #layout-wrapper .input-group > .form-control {
        flex: 1 1 auto;
        min-width: 0;
        width: 1%;
    }

        /* [ control ][ addon ] */
        #layout-wrapper .input-group > .form-control:first-child:not(:last-child) {
            border-top-right-radius: 0;
            border-bottom-right-radius: 0;
            border-right-width: 0;
        }

    #layout-wrapper .input-group > .input-group-addon:last-child {
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
        min-width: 2.5rem;
        padding: 0 10px;
    }

        #layout-wrapper .input-group > .input-group-addon:last-child[role="button"] {
            cursor: pointer;
        }

    /* [ addon ][ control ] */
    #layout-wrapper .input-group > .input-group-addon:first-child:not(:last-child) {
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
        border-right-width: 0;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        flex-shrink: 0;
    }

    #layout-wrapper .input-group > .form-control:last-child:not(:only-child) {
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
    }

    #layout-wrapper .input-group:focus-within > .form-control {
        z-index: 2;
    }



#layout-wrapper .npa-search .form-control,
#layout-wrapper .dataTables_filter input {
    border-radius: var(--radius);
}

/* -----------------------------
 DataTables
------------------------------ */

table thead th, table thead tr th, .table thead th, .table thead tr th {
    background: var(--brand-navy-deep);
    color: var(--color-white);
    font-weight: 500 !important;
    font-size: 13px !important;
    padding: 12px 15px !important;
    border: none !important;
    vertical-align: middle !important;
}

#layout-wrapper table.dataTable {
    border-color: var(--border);
    margin: 0 !important;
}

    #layout-wrapper table.dataTable thead > tr > th,
    #layout-wrapper table.dataTable thead > tr > td {
        background: var(--brand-navy);
        color: var(--color-white);
        border-bottom: 1px solid color-mix(in oklab, var(--brand-navy) 70%, var(--foreground));
        font-weight: 600;
    }

    #layout-wrapper table.dataTable tbody tr {
        background: var(--card);
    }

    #layout-wrapper table.dataTable.stripe tbody tr.odd,
    #layout-wrapper table.dataTable.display tbody tr.odd {
        background: color-mix(in oklab, var(--muted) 45%, var(--card));
    }

    #layout-wrapper table.dataTable.hover tbody tr:hover,
    #layout-wrapper table.dataTable.display tbody tr:hover {
        background: color-mix(in oklab, var(--brand-blue-soft) 58%, var(--card)) !important;
    }

#layout-wrapper .dataTables_wrapper .dataTables_info,
#layout-wrapper .dataTables_wrapper .dataTables_length,
#layout-wrapper .dataTables_wrapper .dataTables_filter,
#layout-wrapper .dataTables_wrapper .dataTables_paginate {
    color: var(--muted-foreground);
}

#layout-wrapper .dataTables_wrapper .pagination > li > a,
#layout-wrapper .dataTables_wrapper .pagination > li > span {
    color: var(--foreground);
    border-color: var(--border);
    background: var(--card);
}

    #layout-wrapper .dataTables_wrapper .pagination > li > a:hover {
        background: var(--secondary);
    }

#layout-wrapper .dataTables_wrapper .pagination > .active > a,
#layout-wrapper .dataTables_wrapper .pagination > .active > span {
    color: var(--color-white);
    background: var(--brand-blue);
    border-color: var(--brand-blue);
}

/* -----------------------------
 Select2 / datepicker / summernote
 (single: altura/padding/sombra/foco alineados a filtros NPA — aplica en toda la app bajo #layout-wrapper)
------------------------------ */
#layout-wrapper .select2-container {
    min-width: 0;
}

#layout-wrapper .select2-container--default .select2-selection--single {
    min-height: 0;
    padding: 8px 12px 8px 4px;
    box-sizing: border-box;
    border: 1px solid color-mix(in oklab, var(--border) 92%, var(--muted-foreground)) !important;
    border-radius: var(--radius) !important;
    background: var(--card);
    box-shadow: 0 1px 2px color-mix(in oklab, var(--foreground) 4%, transparent);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

    #layout-wrapper .select2-container--default .select2-selection--single .select2-selection__rendered {
        padding-left: 8px;
        padding-right: 2.25rem;
        color: var(--foreground);
        font-size: 14px;
        line-height: 1 !important;
    }

#layout-wrapper .select2-selection--single .select2-selection__clear {
    display: none !important;
}


/* Misma flecha que el select nativo NPA (chevron SVG), no el triángulo por defecto de Select2 */
#layout-wrapper .select2-container--default .select2-selection--single .select2-selection__arrow {
    top: 1px;
    bottom: 1px;
    right: 10px;
    width: 22px;
    height: auto;
    display: flex;
    align-items: center;
    justify-content: center;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 16px 16px;
}

    #layout-wrapper .select2-container--default .select2-selection--single .select2-selection__arrow b {
        display: none;
    }

#layout-wrapper .select2-container--default.select2-container--focus .select2-selection--single,
#layout-wrapper .select2-container--default.select2-container--open .select2-selection--single {
    border-color: color-mix(in oklab, var(--brand-blue) 55%, var(--border)) !important;
    box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand-blue) 18%, transparent), 0 1px 2px color-mix(in oklab, var(--foreground) 5%, transparent);
}

#layout-wrapper .select2-container--default.select2-container--disabled .select2-selection--single {
    opacity: 0.72;
    cursor: not-allowed !important;
    background: color-mix(in oklab, var(--muted) 38%, var(--card)) !important;
    box-shadow: none !important;
}

#layout-wrapper .select2-selection--multiple {
    border: 1px solid var(--input) !important;
    border-radius: var(--radius) !important;
    background: var(--card);
}

#layout-wrapper .npa-result-kpi__filter-cell .select2-container {
    width: 100% !important;
}

#layout-wrapper .select2-dropdown {
    border-color: var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-card);
}

#layout-wrapper .select2-container--default .select2-results__option--highlighted[aria-selected] {
    background: var(--brand-blue);
    color: var(--color-white);
}

/* Select nativo: misma línea visual que .select2-selection--single (los que llevan .select2 usan Select2 arriba) */
#layout-wrapper select:not(.select2):not(.select2-hidden-accessible):not([multiple]) {
    min-height: 2.25rem;
    padding: 8px 2.25rem 8px 12px !important;
    font-size: 14px;
    line-height: 1 !important;
    box-sizing: border-box;
    color: var(--foreground);
    background-color: var(--card);
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 16px 16px;
    border: 1px solid color-mix(in oklab, var(--border) 92%, var(--muted-foreground)) !important;
    border-radius: var(--radius);
    box-shadow: 0 1px 2px color-mix(in oklab, var(--foreground) 4%, transparent);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    cursor: pointer;
}

    #layout-wrapper select:not(.select2):not(.select2-hidden-accessible):not([multiple]):hover {
        border-color: color-mix(in oklab, var(--border) 70%, var(--muted-foreground)) !important;
    }

    #layout-wrapper select:not(.select2):not(.select2-hidden-accessible):not([multiple]):focus {
        outline: none;
        border-color: color-mix(in oklab, var(--brand-blue) 55%, var(--border)) !important;
        box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand-blue) 18%, transparent), 0 1px 2px color-mix(in oklab, var(--foreground) 5%, transparent);
    }

    #layout-wrapper select:not(.select2):not(.select2-hidden-accessible):not([multiple]):disabled {
        opacity: 0.72;
        cursor: not-allowed !important;
        background-color: color-mix(in oklab, var(--muted) 38%, var(--card)) !important;
        box-shadow: none !important;
    }

#layout-wrapper select:not(.select2):not(.select2-hidden-accessible)[multiple] {
    min-height: 2.25rem;
    padding: 8px 12px !important;
    font-size: 14px;
    line-height: 1.4 !important;
    box-sizing: border-box;
    color: var(--foreground);
    background: var(--card);
    border: 1px solid color-mix(in oklab, var(--border) 92%, var(--muted-foreground)) !important;
    border-radius: var(--radius);
    box-shadow: 0 1px 2px color-mix(in oklab, var(--foreground) 4%, transparent);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

    #layout-wrapper select:not(.select2):not(.select2-hidden-accessible)[multiple]:hover {
        border-color: color-mix(in oklab, var(--border) 70%, var(--muted-foreground)) !important;
    }

    #layout-wrapper select:not(.select2):not(.select2-hidden-accessible)[multiple]:focus {
        outline: none;
        border-color: color-mix(in oklab, var(--brand-blue) 55%, var(--border)) !important;
        box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand-blue) 18%, transparent), 0 1px 2px color-mix(in oklab, var(--foreground) 5%, transparent);
    }

    #layout-wrapper select:not(.select2):not(.select2-hidden-accessible)[multiple]:disabled {
        opacity: 0.72;
        cursor: not-allowed !important;
        background: color-mix(in oklab, var(--muted) 38%, var(--card)) !important;
        box-shadow: none !important;
    }

#layout-wrapper .note-editor,
#layout-wrapper .note-editor.note-frame {
    border: 1px solid var(--border);
    border-radius: var(--radius);
}

    #layout-wrapper .note-editor .note-toolbar {
        border-bottom: 1px solid var(--border);
        background: var(--muted);
    }

#layout-wrapper .datepicker.dropdown-menu {
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-card);
}

#layout-wrapper .datepicker table tr td.active,
#layout-wrapper .datepicker table tr td.active:hover {
    background: var(--brand-blue);
    color: var(--color-white);
}

/* -----------------------------
 Trees / list panels
------------------------------ */
#layout-wrapper .jstree-anchor {
    border-radius: calc(var(--radius) - 2px);
    color: var(--foreground);
}

    #layout-wrapper .jstree-anchor:hover {
        background: var(--muted);
    }

#layout-wrapper .jstree-clicked {
    background: color-mix(in oklab, var(--brand-blue) 14%, var(--card)) !important;
    color: var(--brand-blue) !important;
}

/* -----------------------------
 Switches / checkboxes
------------------------------ */
#layout-wrapper input[type="checkbox"].icheck-native {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: calc(var(--spacing) * 8);
    height: calc(var(--spacing) * 8);
    border: 1px solid var(--brand-navy);
    border-radius: calc(var(--radius) * 0.5);
    background-color: var(--card);
    cursor: pointer;
    display: inline-block;
    vertical-align: middle;
    transition: all .2s ease-in-out;
    position: relative;
}

input[type="checkbox"].icheck-native:focus {
    outline: 0 !important;
    outline-offset: 0 !important;
}

input[type="checkbox"].icheck-native:checked::after {
    content: "";
    position: absolute;
    left: calc(var(--spacing) * 2.25);
    top: calc(var(--spacing) * 1);
    width: calc(var(--spacing) * 3);
    height: calc(var(--spacing) * 4);
    border: solid var(--color-white);
    border-width: 0 3px 3px 0;
    transform: rotate(45deg);
}

#layout-wrapper input[type="checkbox"].icheck-native:hover {
    border-color: var(--brand-navy);
}

#layout-wrapper input[type="checkbox"].icheck-native:checked {
    border-color: var(--brand-navy);
    background: var(--brand-navy);
}

#layout-wrapper .slider-npa {
    background-color: var(--muted-foreground);
}

#layout-wrapper input:checked + .slider-npa {
    background-color: var(--brand-navy);
}

/* -----------------------------
 Alerts / notices / loaders
------------------------------ */
#layout-wrapper .alert-info {
    color: var(--foreground);
    background: color-mix(in oklab, var(--brand-blue-soft) 65%, var(--card));
    border-color: var(--border);
}

#layout-wrapper .alert-success {
    color: color-mix(in oklab, var(--success) 65%, var(--foreground));
    background: color-mix(in oklab, var(--success) 10%, var(--card));
    border-color: color-mix(in oklab, var(--success) 35%, transparent);
}

#layout-wrapper .alert-danger,
#layout-wrapper .alert-error {
    color: color-mix(in oklab, var(--destructive) 70%, var(--foreground));
    background: color-mix(in oklab, var(--destructive) 10%, var(--card));
    border-color: color-mix(in oklab, var(--destructive) 35%, transparent);
}

#layout-wrapper .questionnaire-scroll-arrow {
    background: var(--brand-navy);
    color: var(--color-white);
    box-shadow: var(--shadow-card);
}

    #layout-wrapper .questionnaire-scroll-arrow:hover {
        background: var(--brand-navy-deep);
    }

#layout-wrapper .LockOn {
    background-color: color-mix(in oklab, var(--background) 72%, transparent);
}

/* -----------------------------
 Modals
------------------------------ */
#layout-wrapper .modal-content {
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-card);
}

#layout-wrapper .modal-header {
    border-bottom: 1px solid var(--border);
}

#layout-wrapper .modal-footer {
    border-top: 1px solid var(--border);
}

/* -----------------------------
 Footer
------------------------------ */
#layout-wrapper .footer {
    border-top: 1px solid var(--border);
    background: var(--card);
    color: var(--muted-foreground);
}

    #layout-wrapper .footer a {
        color: var(--brand-blue) !important;
    }

        #layout-wrapper .footer a:hover {
            color: var(--brand-navy) !important;
            text-decoration: underline;
        }

    #layout-wrapper .footer .text-danger {
        color: var(--destructive) !important;
    }

/* -----------------------------
 Account / login styles (main.css pages)
------------------------------ */
#account-wrapper .wrap-login100 {
    background: color-mix(in oklab, var(--card) 80%, transparent);
    border: 1px solid var(--border);
    border-radius: calc(var(--radius) + 4px);
    box-shadow: var(--shadow-card);
}

#account-wrapper .wrap-input100 {
    border-bottom: 1px solid var(--brand-blue);
}

#account-wrapper .input100 {
    color: var(--foreground);
}

    #account-wrapper .input100::placeholder {
        color: var(--muted-foreground) !important;
    }

#account-wrapper .login-btn {
    background: var(--brand-blue);
    color: var(--color-white);
    border-radius: calc(var(--radius) - 2px);
}

    #account-wrapper .login-btn:hover {
        background: var(--brand-navy);
    }

#account-wrapper .label-checkbox100::before {
    border: 1px solid var(--border);
}

/* -----------------------------
 Utility classes for new pages
------------------------------ */
#layout-wrapper .theme-surface {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-card);
}

#layout-wrapper .theme-title {
    color: var(--brand-navy);
    font-weight: 600;
}

#layout-wrapper .theme-muted {
    color: var(--muted-foreground);
}

#layout-wrapper .page-header-light .hpanel .panel-body h2 {
    font-weight: 600;
}

#layout-wrapper .panel_filter .form-group label, .form-group label {
    font-size: 12px !important;
    color: var(--primary) !important;
    margin-bottom: var(--label-spacing) !important;
    font-weight: 600 !important;
}


#layout-wrapper .dd-custom-fw-tab.npa-result-kpi .dd-custom-fw-tab__toolbar-rows,
#layout-wrapper .npa-dd-questionnaire-list.dd-custom-fw-tab.npa-result-kpi .dd-custom-fw-tab__toolbar-rows {
    display: flex;
    flex-direction: column;
    gap: 14px;
    width: 100%;
}

#layout-wrapper .dd-custom-fw-tab.npa-result-kpi .dd-custom-fw-tab__toolbar-row.npa-result-kpi__toolbar-filters,
#layout-wrapper .npa-dd-questionnaire-list.dd-custom-fw-tab.npa-result-kpi .dd-custom-fw-tab__toolbar-row.npa-result-kpi__toolbar-filters {
    width: 100%;
}

#layout-wrapper .dd-custom-fw-tab.npa-result-kpi .dd-custom-fw-tab__toolbar-row--secondary,
#layout-wrapper .npa-dd-questionnaire-list.dd-custom-fw-tab.npa-result-kpi .dd-custom-fw-tab__toolbar-row--secondary {
    flex-wrap: wrap;
}

#layout-wrapper .dd-custom-fw-tab.npa-result-kpi .dd-custom-fw-tab__filter-cell--search-grow,
#layout-wrapper .npa-dd-questionnaire-list.dd-custom-fw-tab.npa-result-kpi .dd-custom-fw-tab__filter-cell--search-grow {
    flex: 1 1 220px;
    min-width: 180px;
    max-width: 100%;
}

#layout-wrapper .dd-custom-fw-tab.npa-result-kpi .dd-custom-fw-tab__filter-cell--save,
#layout-wrapper .npa-dd-questionnaire-list.dd-custom-fw-tab.npa-result-kpi .dd-custom-fw-tab__filter-cell--save {
    flex: 0 0 auto;
    margin-left: auto;
}

#layout-wrapper .dd-custom-fw-tab.npa-result-kpi .dd-custom-fw-tab__filter-cell--btn,
#layout-wrapper .npa-dd-questionnaire-list.dd-custom-fw-tab.npa-result-kpi .dd-custom-fw-tab__filter-cell--btn {
    flex: 0 0 auto;
}

#layout-wrapper .dd-custom-fw-tab.npa-result-kpi .dd-custom-fw-tab__filter-label-spacer,
#layout-wrapper .npa-dd-questionnaire-list.dd-custom-fw-tab.npa-result-kpi .dd-custom-fw-tab__filter-label-spacer {
    display: block;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 0.02em;
    line-height: 1.2;
    margin-bottom: var(--label-spacing) !important;
    min-height: calc(12px * 1.2);
    color: transparent;
    visibility: hidden;
    overflow: hidden;
    user-select: none;
}

#layout-wrapper .dd-custom-fw-tab.npa-result-kpi .npa-result-kpi__toolbar .npa-result-kpi__filter-group,
#layout-wrapper .npa-dd-questionnaire-list.dd-custom-fw-tab.npa-result-kpi .npa-result-kpi__toolbar .npa-result-kpi__filter-group {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
}

#layout-wrapper .dd-custom-fw-tab.npa-result-kpi .npa-result-kpi__toolbar-filters,
#layout-wrapper .npa-dd-questionnaire-list.dd-custom-fw-tab.npa-result-kpi .npa-result-kpi__toolbar-filters {
    align-items: flex-end;
}

    #layout-wrapper .dd-custom-fw-tab.npa-result-kpi .npa-result-kpi__toolbar-filters .dd-custom-fw-tab__toolbar-btn.btn.btn-primary,
    #layout-wrapper .npa-dd-questionnaire-list.dd-custom-fw-tab.npa-result-kpi .npa-result-kpi__toolbar-filters .dd-custom-fw-tab__toolbar-btn.btn.btn-primary {
        min-height: 2.25rem;
        padding: calc(var(--spacing) * 3) 12px;
        box-sizing: border-box;
        display: inline-flex;
        flex-direction: row;
        flex-wrap: nowrap;
        align-items: center;
        justify-content: center;
        line-height: 1.25;
        font-weight: 500;
    }

    #layout-wrapper .dd-custom-fw-tab.npa-result-kpi .npa-result-kpi__toolbar-filters .dd-custom-fw-tab__toolbar-btn.btn.btn-default,
    #layout-wrapper .npa-dd-questionnaire-list.dd-custom-fw-tab.npa-result-kpi .npa-result-kpi__toolbar-filters .dd-custom-fw-tab__toolbar-btn.btn.btn-default {
        min-height: 2.25rem;
        padding: calc(var(--spacing) * 3) 12px;
        box-sizing: border-box;
        display: inline-flex;
        flex-direction: row;
        flex-wrap: nowrap;
        align-items: center;
        justify-content: center;
        gap: 0.4em;
        line-height: 1.25;
    }

        #layout-wrapper .dd-custom-fw-tab.npa-result-kpi .npa-result-kpi__toolbar-filters .dd-custom-fw-tab__toolbar-btn.btn.btn-default > i.fa,
        #layout-wrapper .npa-dd-questionnaire-list.dd-custom-fw-tab.npa-result-kpi .npa-result-kpi__toolbar-filters .dd-custom-fw-tab__toolbar-btn.btn.btn-default > i.fa {
            flex-shrink: 0;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            width: 1em;
            height: 1em;
            margin: 0;
            padding: 0;
            font-size: 13px;
            line-height: 1;
            vertical-align: middle;
        }

            #layout-wrapper .dd-custom-fw-tab.npa-result-kpi .npa-result-kpi__toolbar-filters .dd-custom-fw-tab__toolbar-btn.btn.btn-default > i.fa::before,
            #layout-wrapper .npa-dd-questionnaire-list.dd-custom-fw-tab.npa-result-kpi .npa-result-kpi__toolbar-filters .dd-custom-fw-tab__toolbar-btn.btn.btn-default > i.fa::before {
                line-height: 1;
                display: block;
            }

        #layout-wrapper .dd-custom-fw-tab.npa-result-kpi .npa-result-kpi__toolbar-filters .dd-custom-fw-tab__toolbar-btn.btn.btn-default > span,
        #layout-wrapper .npa-dd-questionnaire-list.dd-custom-fw-tab.npa-result-kpi .npa-result-kpi__toolbar-filters .dd-custom-fw-tab__toolbar-btn.btn.btn-default > span {
            display: inline-flex;
            align-items: center;
            line-height: 1.2;
            margin: 0;
            padding: 0;
        }

#layout-wrapper .dd-custom-fw-tab.npa-result-kpi .dd-custom-fw-tab__toolbar-row--secondary.npa-result-kpi__toolbar-filters,
#layout-wrapper .npa-dd-questionnaire-list.dd-custom-fw-tab.npa-result-kpi .dd-custom-fw-tab__toolbar-row--secondary.npa-result-kpi__toolbar-filters {
    justify-content: flex-start;
    align-items: flex-end;
}

/* -----------------------------
   DD Results & KPIs (dueDiligence/resultKpi)
------------------------------ */
#layout-wrapper .npa-result-kpi__hero {
    align-items: flex-start;
}

#layout-wrapper .npa-result-kpi__subtitle {
    font-size: 14px;
    line-height: 1.5;
}

#layout-wrapper .npa-result-kpi__btn-export {
    border: 1px solid var(--border);
    border-radius: var(--radius);
    background: var(--card);
    padding: 8px 14px;
    font-weight: 500;
    margin-top: 4px;
}

    #layout-wrapper .npa-result-kpi__btn-export:hover,
    #layout-wrapper .npa-result-kpi__btn-export:focus {
        background: var(--secondary);
        border-color: var(--border);
    }

#layout-wrapper .npa-result-kpi__toolbar {
    border: 1px solid var(--border);
    border-radius: calc(var(--radius) + 4px);
    box-shadow: none;
    margin-bottom: 1rem;
}

    #layout-wrapper .npa-result-kpi__toolbar .panel-body {
        background: color-mix(in oklab, var(--muted) 55%, var(--card));
        border-radius: calc(var(--radius) + 4px);
        padding: 14px 16px;
    }

#layout-wrapper .npa-result-kpi__empty-state {
    border: 1px solid var(--border);
    border-radius: calc(var(--radius) + 4px);
    box-shadow: none;
    margin-bottom: 1rem;
}

    #layout-wrapper .npa-result-kpi__empty-state .panel-body {
        background: var(--card);
        border-radius: calc(var(--radius) + 4px);
        padding: 2rem 1.25rem;
    }

#layout-wrapper .npa-result-kpi__empty-state-inner {
    text-align: center;
}

#layout-wrapper .npa-result-kpi__empty-state-text {
    font-size: 15px;
    color: var(--muted-foreground);
}

#layout-wrapper .npa-result-kpi__toolbar-filters {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 14px 20px;
}

#layout-wrapper .npa-result-kpi__filter-cell {
    flex: 1 1 auto;
    min-width: 0;
}

#layout-wrapper .npa-result-kpi__filter-cell--search {
    flex: 1 1 220px;
    min-width: 180px;
}

#layout-wrapper .npa-result-kpi__filter-cell--report,
#layout-wrapper .npa-result-kpi__filter-cell--company,
#layout-wrapper .npa-result-kpi__filter-cell--topic {
    flex: 1 1 160px;
    min-width: 140px;
    max-width: 260px;
}

#layout-wrapper .npa-result-kpi__filter-cell--stats {
    flex: 0 1 auto;
    margin-left: auto;
    text-align: right;
    min-width: min(100%, 12.5rem);
    display: flex;
    flex-direction: column;
}

#layout-wrapper .npa-result-kpi__filter-group label {
    letter-spacing: 0.02em;
}

/* Altura alineada entre input, select (nativo / Select2) y botones en la fila de filtros KPI */
#layout-wrapper .npa-result-kpi__toolbar-filters .btn,
#layout-wrapper .npa-result-kpi__toolbar-filters .form-control {
    min-height: 2.25rem;
    box-sizing: border-box;
}

#layout-wrapper .npa-result-kpi__toolbar-filters .select2-container--default .select2-selection--single {
    min-height: 2.25rem;
    display: flex;
    align-items: center;
}

#layout-wrapper .npa-filter-row .btn,
#layout-wrapper .npa-filter-row .form-control,
#layout-wrapper .npa-filter-row .select2-container--default .select2-selection--single {
    min-height: 2.25rem;
    box-sizing: border-box;
}

#layout-wrapper .npa-filter-row .select2-container--default .select2-selection--single {
    display: flex;
    align-items: center;
}

#layout-wrapper .npa-result-kpi__search-input,
#layout-wrapper .npa-result-kpi__select {
    border-radius: var(--radius);
    border-color: var(--border);
}

/* Toolbar: solo el input de búsqueda (los selects van con Select2 + estilos globales arriba) */
#layout-wrapper .npa-result-kpi__toolbar .npa-result-kpi__search-input {
    min-height: 2.25rem;
    padding: 0.5rem 14px;
    font-size: 14px;
    line-height: 1.4;
    box-sizing: border-box;
    background: var(--card);
    border: 1px solid color-mix(in oklab, var(--border) 92%, var(--muted-foreground));
    box-shadow: 0 1px 2px color-mix(in oklab, var(--foreground) 4%, transparent);
    transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

    #layout-wrapper .npa-result-kpi__toolbar .npa-result-kpi__search-input:hover {
        border-color: color-mix(in oklab, var(--border) 70%, var(--muted-foreground));
    }

    #layout-wrapper .npa-result-kpi__toolbar .npa-result-kpi__search-input:focus {
        outline: none;
        border-color: color-mix(in oklab, var(--brand-blue) 55%, var(--border));
        box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand-blue) 18%, transparent), 0 1px 2px color-mix(in oklab, var(--foreground) 5%, transparent);
    }

#layout-wrapper .npa-result-kpi__stats {
    line-height: 1.25;
}

#layout-wrapper .npa-result-kpi__stats--badges {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
}

#layout-wrapper .npa-result-kpi__filter-stat-badge {
    background: color-mix(in oklab, var(--muted) 65%, var(--card)) !important;
    color: var(--foreground) !important;
    font-weight: 600;
    font-size: 13px;
    padding: 7px 12px;
    border-radius: var(--radius);
    border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
}

/* -----------------------------
   NPA surface card, KV rows, inline summary (reutilizable; p. ej. DD Report Setup)
------------------------------ */
#layout-wrapper .npa-surface-card {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: calc(var(--radius) + 4px);
    box-shadow: var(--shadow-card);
    display: flex;
    flex-direction: column;
    min-height: 0;
    height: 100%;
}

#layout-wrapper .npa-surface-card--auto-height {
    height: auto;
}

#layout-wrapper .npa-surface-card__head {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    gap: 10px;
    padding: 14px 18px 12px;
}

#layout-wrapper .npa-surface-card__head--stack {
    align-items: flex-start;
}

#layout-wrapper .npa-surface-card__head-text {
    flex: 1 1 auto;
    min-width: 0;
}

#layout-wrapper .npa-surface-card__head-icon.ti {
    flex: 0 0 auto;
    font-size: 1.75rem;
    line-height: 1;
    color: var(--brand-blue);
}

#layout-wrapper .npa-surface-card__title {
    margin: 0;
    padding: 0;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.4;
    color: var(--foreground);
}

#layout-wrapper .npa-surface-card__title--brand {
    color: var(--brand-blue);
    font-weight: 600;
}

#layout-wrapper .npa-surface-card__title--emphasis {
    font-weight: 700;
}

#layout-wrapper .npa-surface-card__title-lead {
    font-weight: 700;
}

#layout-wrapper .npa-surface-card__title-count {
    font-weight: 600;
    color: var(--muted-foreground);
}

#layout-wrapper .npa-surface-card__subtitle {
    margin: 6px 0 0;
    padding: 0;
    font-size: 13px;
    line-height: 1.45;
    font-weight: 400;
    color: var(--muted-foreground);
}

#layout-wrapper .npa-surface-card__body {
    padding: 12px 18px 16px;
    flex: 1 1 auto;
}

#layout-wrapper .npa-surface-card__body--flush {
    padding: 0;
}

#layout-wrapper .npa-surface-card--ranked .npa-surface-card__head {
    padding: 14px 16px 12px;
}

#layout-wrapper .npa-surface-card--ranked .npa-surface-card__foot {
    padding: 8px 16px;
    font-size: 11px;
    background: var(--card);
}

#layout-wrapper .npa-surface-card__foot {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: auto;
    padding: 8px 18px;
    font-size: 12px;
    line-height: 1.35;
    color: var(--muted-foreground);
    background: color-mix(in oklab, var(--muted) 35%, var(--card));
    border-top: 1px solid var(--border);
    border-radius: 0 0 calc(var(--radius) + 4px) calc(var(--radius) + 4px);
}

    #layout-wrapper .npa-surface-card__foot .fa {
        opacity: 0.85;
    }

#layout-wrapper .npa-surface-card__loader {
    margin: 0 0 12px;
    font-size: 13px;
    color: var(--muted-foreground);
}

/* Lista ordenada con ranking (top N) — filas con divisor, sin fondo por ítem */
#layout-wrapper .npa-ranked-list {
    counter-reset: npa-rank;
    list-style: none;
    margin: 0;
    padding: 0;
}

    #layout-wrapper .npa-ranked-list > li {
        counter-increment: npa-rank;
        display: flex;
        align-items: flex-start;
        gap: 8px;
        margin: 0;
        padding: 11px 16px;
        border: none;
        border-bottom: 1px solid var(--border);
        border-radius: 0;
        background: transparent;
        font-size: 14px;
        font-weight: 400;
        line-height: 1.45;
        color: var(--foreground);
    }

        #layout-wrapper .npa-ranked-list > li:last-child {
            border-bottom: none;
        }

        #layout-wrapper .npa-ranked-list > li::before {
            content: counter(npa-rank) ".";
            flex: 0 0 auto;
            min-width: 1.35em;
            font-size: 13px;
            font-weight: 400;
            line-height: 1.45;
            text-align: left;
            color: var(--muted-foreground);
        }

#layout-wrapper .npa-surface-card--ranked .npa-surface-card__loader {
    margin: 0;
    padding: 12px 16px;
}

#layout-wrapper .npa-kv {
    display: grid;
    grid-template-columns: minmax(6.5rem, 32%) 1fr;
    gap: 8px 12px;
    align-items: baseline;
    padding: 8px 0;
    border-bottom: 1px solid color-mix(in oklab, var(--border) 85%, transparent);
    font-size: 14px;
}

    #layout-wrapper .npa-kv:last-child {
        border-bottom: none;
        padding-bottom: 0;
    }

#layout-wrapper .npa-kv__k {
    color: var(--muted-foreground);
    font-weight: 500;
}

#layout-wrapper .npa-kv__v {
    color: var(--foreground);
    font-weight: 500;
    word-break: break-word;
}

#layout-wrapper .npa-inline-summary {
    list-style: none;
    margin: 0;
    padding: 0;
}

#layout-wrapper .npa-inline-summary__item {
    display: grid;
    grid-template-columns: 1fr minmax(0, auto);
    gap: 12px 16px;
    align-items: baseline;
    padding: 10px 0;
    border-bottom: 1px solid color-mix(in oklab, var(--border) 88%, transparent);
    font-size: 12px;
}

    #layout-wrapper .npa-inline-summary__item:last-child {
        border-bottom: none;
        padding-bottom: 0;
    }

#layout-wrapper .npa-inline-summary__primary {
    font-weight: 600;
    color: var(--foreground);
    min-width: 0;
}

#layout-wrapper .npa-inline-summary__secondary {
    font-size: 13px;
    font-weight: 400;
    color: var(--muted-foreground);
    text-align: right;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Fila Bootstrap 3: columnas misma altura desde md (992px) */
@media (min-width: 992px) {
    #layout-wrapper .npa-row-equal-cols.row {
        display: flex;
        flex-wrap: nowrap;
    }

        #layout-wrapper .npa-row-equal-cols.row:before,
        #layout-wrapper .npa-row-equal-cols.row:after {
            display: none !important;
            content: none !important;
        }

        #layout-wrapper .npa-row-equal-cols.row > [class*="col-md-6"] {
            float: none;
            width: 50%;
            flex: 0 0 50%;
            max-width: 50%;
            display: flex;
            flex-direction: column;
        }

            #layout-wrapper .npa-row-equal-cols.row > [class*="col-md-6"] > .npa-surface-card,
            #layout-wrapper .npa-row-equal-cols.row > [class*="col-md-6"] > .npa-surface-card.npa-distribution-panel {
                flex: 1 1 auto;
                width: 100%;
                min-height: 0;
            }

    #layout-wrapper .npa-row-equal-cols--thirds.row {
        gap: 16px;
    }

        #layout-wrapper .npa-row-equal-cols--thirds.row > [class*="col-md-4"] {
            float: none;
            width: calc((100% - 32px) / 3);
            flex: 0 0 calc((100% - 32px) / 3);
            max-width: calc((100% - 32px) / 3);
            display: flex;
            flex-direction: column;
        }

            #layout-wrapper .npa-row-equal-cols--thirds.row > [class*="col-md-4"] > .npa-surface-card {
                flex: 1 1 auto;
                width: 100%;
                min-height: 0;
            }
}

#layout-wrapper .npa-row-equal-cols--thirds.row {
    margin-left: 0;
    margin-right: 0;
}

    #layout-wrapper .npa-row-equal-cols--thirds.row > [class*="col-"] {
        margin-bottom: 16px;
        padding-left: 8px;
        padding-right: 8px;
    }

@media (min-width: 992px) {
    #layout-wrapper .npa-row-equal-cols--thirds.row > [class*="col-"] {
        margin-bottom: 0;
        padding-left: 0;
        padding-right: 0;
    }
}

/* Due diligence — resumen (KPI + distribución) */
#layout-wrapper .npa-dd-summary__dashboard > .npa-dd-summary__row {
    margin-bottom: 12px;
}

    #layout-wrapper .npa-dd-summary__dashboard > .npa-dd-summary__row:last-of-type {
        margin-bottom: 0;
    }

#layout-wrapper .npa-field-label {
    display: block;
    margin-bottom: 6px;
    font-size: 13px;
    font-weight: 500;
    color: var(--foreground);
}

#layout-wrapper .npa-field-label--placeholder {
    visibility: hidden;
    margin-bottom: 6px;
    line-height: 1.35;
}

#layout-wrapper .npa-form-actions-end {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 10px;
    padding-top: 4px;
}

#layout-wrapper .npa-btn-primary-inline {
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 2.5rem;
    padding-left: 18px;
    padding-right: 18px;
    font-weight: 500;
    border-radius: var(--radius);
}

    #layout-wrapper .npa-btn-primary-inline .ti {
        font-size: 1.125rem;
        line-height: 1;
    }

/* Navegación entre pasos (atrás / siguiente) */
#layout-wrapper .npa-step-nav {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: 20px;
    padding-top: 8px;
}

    #layout-wrapper .npa-step-nav .btn {
        display: inline-flex;
        flex-direction: row;
        align-items: center;
        justify-content: center;
        gap: 8px;
        min-height: 2.25rem;
        font-weight: 500;
        border-radius: var(--radius);
    }

        #layout-wrapper .npa-step-nav .btn .ti {
            font-size: 1.1rem;
            line-height: 1;
        }

/* Grupo de botones en toolbar de filtros (reutilizable fuera de questionnaire.css) */
#layout-wrapper .npa-toolbar-btn-group {
    display: inline-flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    width: 100%;
    box-sizing: border-box;
}

/* Tarjetas métricas compactas (resúmenes numéricos) */
#layout-wrapper .npa-stat-tile {
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 14px 16px;
    text-align: center;
    height: 100%;
    box-sizing: border-box;
}

#layout-wrapper .npa-stat-tile__label {
    margin: 0 0 8px;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--muted-foreground);
    line-height: 1.3;
}

#layout-wrapper .npa-stat-tile__value {
    margin: 0;
    font-size: 1.75rem;
    font-weight: 700;
    line-height: 1.1;
    color: var(--foreground);
    font-variant-numeric: tabular-nums;
}

#layout-wrapper .npa-stat-tile__value--accent {
    color: var(--brand-blue);
}

/* Barras de progreso Bootstrap 3 — variantes alineadas a tokens (primary / info / success / warning; + danger por convención BS3) */
#layout-wrapper .progress {
    background-color: color-mix(in oklab, var(--muted) 52%, var(--card));
    border-radius: var(--radius);
    box-shadow: inset 0 1px 2px color-mix(in oklab, var(--foreground) 5%, transparent);
}

    #layout-wrapper .progress.progress-small,
    #layout-wrapper .progress.progress-small .progress-bar {
        height: 10px;
    }

        #layout-wrapper .progress.progress-small .progress-bar {
            line-height: 10px;
            font-size: 0;
            padding-right: 0;
            text-align: left;
        }

    #layout-wrapper .progress.full .progress-bar-primary {
        background-color: var(--brand-navy);
        border-right-color: color-mix(in oklab, var(--brand-navy-deep) 55%, var(--brand-navy));
        color: var(--destructive-foreground);
    }

    #layout-wrapper .progress.full .progress-bar-info {
        background-color: var(--info);
        border-right-color: color-mix(in oklab, var(--info) 72%, var(--foreground));
        color: var(--destructive-foreground);
    }

    #layout-wrapper .progress.full .progress-bar-success {
        background-color: var(--success);
        border-right-color: color-mix(in oklab, var(--success) 75%, var(--foreground));
        color: var(--destructive-foreground);
    }

    #layout-wrapper .progress.full .progress-bar-warning {
        background-color: var(--warning);
        border-right-color: color-mix(in oklab, var(--warning) 78%, var(--foreground));
        color: color-mix(in oklab, var(--foreground) 82%, var(--card));
    }

    #layout-wrapper .progress.full .progress-bar-danger {
        background-color: var(--destructive);
        border-right-color: color-mix(in oklab, var(--destructive) 75%, var(--foreground));
        color: var(--destructive-foreground);
    }

    /* Misma paleta cuando la barra no usa contenedor `.full` (relleno + borde derecho tipo “marcador”) */
    #layout-wrapper .progress:not(.full) .progress-bar-primary {
        background-color: color-mix(in oklab, var(--brand-navy) 88%, var(--muted));
        border-right-color: var(--brand-navy-deep);
    }

    #layout-wrapper .progress:not(.full) .progress-bar-info {
        background-color: color-mix(in oklab, var(--info) 88%, var(--muted));
        border-right-color: var(--info);
    }

    #layout-wrapper .progress:not(.full) .progress-bar-success {
        background-color: color-mix(in oklab, var(--success) 88%, var(--muted));
        border-right-color: var(--success);
    }

    #layout-wrapper .progress:not(.full) .progress-bar-warning {
        background-color: color-mix(in oklab, var(--warning) 88%, var(--muted));
        border-right-color: var(--warning);
    }

    #layout-wrapper .progress:not(.full) .progress-bar-danger {
        background-color: color-mix(in oklab, var(--destructive) 88%, var(--muted));
        border-right-color: var(--destructive);
    }

/* Dropzone.js — contenedor + variante `npa-dropzone` (fondo suave, borde discontinuo, mensaje centrado) */
#layout-wrapper .npa-dropzone-shell {
    width: 100%;
    box-sizing: border-box;
}

#layout-wrapper .dropzone.npa-dropzone {
    min-height: 11rem;
    padding: 2.5rem 1.25rem;
    border: 2px dashed color-mix(in oklab, var(--border) 50%, var(--brand-blue));
    border-radius: var(--radius);
    background: color-mix(in oklab, var(--brand-blue) 7%, var(--card));
    transition: border-color 0.15s ease, background-color 0.15s ease, box-shadow 0.15s ease;
}

    #layout-wrapper .dropzone.npa-dropzone.dz-drag-hover {
        border-style: dashed;
        border-color: color-mix(in oklab, var(--brand-blue) 55%, var(--border));
        background: color-mix(in oklab, var(--brand-blue) 12%, var(--card));
        box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand-blue) 14%, transparent);
    }

    #layout-wrapper .dropzone.npa-dropzone .dz-message {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 0.35rem;
        margin: 0;
        text-align: center;
    }

    #layout-wrapper .dropzone.npa-dropzone .npa-dropzone-msg {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 0.5rem;
        max-width: 26rem;
        margin: 0 auto;
    }

    #layout-wrapper .dropzone.npa-dropzone .npa-dropzone-msg__icon {
        font-size: 2.25rem;
        line-height: 1;
        color: var(--brand-navy);
    }

    #layout-wrapper .dropzone.npa-dropzone .npa-dropzone-msg__title {
        font-weight: 600;
        line-height: 1.35;
        color: var(--brand-navy);
    }

    #layout-wrapper .dropzone.npa-dropzone .npa-dropzone-msg__hint {
        font-size: 1.25rem;
        line-height: 1.4;
        font-weight: 400;
        color: var(--muted-foreground);
    }

    #layout-wrapper .dropzone.npa-dropzone.dz-started {
        min-height: 0;
        padding: 0.75rem 1rem;
    }

        /* Fila de archivo seleccionado: solo nombre (+ enlace quitar que añade Dropzone); sin miniatura tipo tarjeta */
        #layout-wrapper .dropzone.npa-dropzone.dz-started .dz-preview.npa-dropzone-file-row {
            display: flex;
            flex-direction: row;
            flex-wrap: wrap;
            align-items: center;
            justify-content: space-between;
            gap: 12px;
            margin: 0;
            min-height: 0;
            width: 100%;
            max-width: 100%;
            padding: 10px 12px;
            border-radius: var(--radius);
            border: 1px solid var(--border);
            background: var(--card);
            box-sizing: border-box;
        }

    #layout-wrapper .dropzone.npa-dropzone .npa-dropzone-file-image-hidden {
        display: none !important;
    }

    #layout-wrapper .dropzone.npa-dropzone .npa-dropzone-file-meta-hidden {
        display: none !important;
    }

    #layout-wrapper .dropzone.npa-dropzone.dz-started .dz-preview.npa-dropzone-file-row .dz-details {
        opacity: 1;
        position: static;
        padding: 0;
        margin: 0;
        text-align: left;
        flex: 1 1 auto;
        min-width: 0;
    }

    #layout-wrapper .dropzone.npa-dropzone.dz-started .dz-preview.npa-dropzone-file-row .dz-filename {
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        max-width: 100%;
    }

        #layout-wrapper .dropzone.npa-dropzone.dz-started .dz-preview.npa-dropzone-file-row .dz-filename span {
            font-size: 0.9375rem;
            font-weight: 600;
            color: var(--foreground);
        }

    #layout-wrapper .dropzone.npa-dropzone.dz-started .dz-preview.npa-dropzone-file-row .dz-error-message {
        flex: 1 1 100%;
        order: 10;
        margin-top: 6px;
        font-size: 0.8125rem;
        color: var(--destructive);
    }

    #layout-wrapper .dropzone.npa-dropzone.dz-started .dz-preview.npa-dropzone-file-row .dz-remove {
        flex-shrink: 0;
        margin: 0;
        padding: 4px 8px;
        font-size: 0.8125rem;
        border-radius: var(--radius);
    }


#layout-wrapper .modal-footer.npa-modal-footer-actions {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
}

/* Panel de distribución: usa la misma cáscara que npa-surface-card (cabecera + body como Setup DD) */
#layout-wrapper .npa-surface-card.npa-distribution-panel {
    min-height: 0;
    height: 100%;
}

#layout-wrapper ul.npa-distribution-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

#layout-wrapper .npa-distribution-item + .npa-distribution-item {
    margin-top: 18px;
}

#layout-wrapper .npa-distribution-item__top {
    display: flex;
    flex-direction: row;
    align-items: baseline;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: var(--spacing);
}

#layout-wrapper .npa-distribution-item__label {
    font-size: 14px;
    font-weight: 400;
    line-height: 1.4;
    color: var(--foreground);
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

#layout-wrapper .npa-distribution-item__value {
    font-size: 15px;
    font-weight: 400;
    line-height: 1.3;
    color: var(--foreground);
    flex-shrink: 0;
    font-variant-numeric: tabular-nums;
}

#layout-wrapper .npa-distribution-item__track {
    height: 6px;
    border-radius: 999px;
    background: color-mix(in oklab, var(--muted) 55%, var(--card));
    overflow: hidden;
}

#layout-wrapper .npa-distribution-item__fill {
    height: 100%;
    border-radius: inherit;
    background: var(--info);
    min-width: 2px;
    transition: width 0.25s ease;
}

/* Callout de estado (tipografía alineada a surface card; icono centrado al bloque título + texto) */
#layout-wrapper .npa-callout {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    gap: 16px;
    padding: 18px 20px;
    border-radius: calc(var(--radius) + 4px);
    border: 1px solid var(--border);
    background: var(--card);
    box-shadow: var(--shadow-card);
    box-sizing: border-box;
}

#layout-wrapper .npa-callout--success {
    border-color: color-mix(in oklab, var(--success) 38%, var(--border));
    background: color-mix(in oklab, var(--success) 9%, var(--card));
}

#layout-wrapper .npa-callout__icon-wrap {
    flex: 0 0 auto;
    align-self: center;
    width: 2.75rem;
    height: 2.75rem;
    border-radius: 999px;
    background: var(--success);
    color: var(--destructive-foreground, #fff);
    display: flex;
    align-items: center;
    justify-content: center;
}

    #layout-wrapper .npa-callout__icon-wrap .ti {
        font-size: 1.5rem;
        line-height: 1;
    }

#layout-wrapper .npa-callout__body {
    flex: 1 1 auto;
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 0;
}

#layout-wrapper .npa-callout__title {
    margin: 0 0 6px;
    font-size: 16px;
    font-weight: 600;
    line-height: 1.35;
    color: var(--foreground);
}

#layout-wrapper .npa-callout__text {
    margin: 0;
    font-size: 14px;
    line-height: 1.5;
    font-weight: 400;
    color: var(--muted-foreground);
}


/* Línea de estado con icono (éxito / info) */
#layout-wrapper .npa-status-line {
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    gap: 8px;
    margin-top: 14px;
    font-size: 14px;
    font-weight: 500;
    color: var(--success);
}

    #layout-wrapper .npa-status-line .ti {
        font-size: 1.25rem;
        line-height: 1;
        flex-shrink: 0;
    }

#layout-wrapper .npa-table-shell {
    margin-top: 18px;
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--card);
}

    #layout-wrapper .npa-table-shell .dataTables_wrapper {
        padding: 0;
    }

#layout-wrapper .npa-result-kpi__panels .panel.npa-result-kpi__panel {
    border: 1px solid var(--border);
    border-radius: calc(var(--radius) + 4px);
    box-shadow: var(--shadow-card);
    overflow: hidden;
    margin-bottom: 12px;
}

#layout-wrapper .npa-result-kpi__panel-heading {
    background: var(--card);
    border-bottom: 1px solid var(--border);
    padding: 12px 16px;
}

#layout-wrapper .npa-result-kpi__panel-title {
    margin: 0;
    font-size: 1rem;
    font-weight: 600;
}

#layout-wrapper .npa-result-kpi__toggle {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--foreground);
    text-decoration: none !important;
    cursor: pointer;
}

    #layout-wrapper .npa-result-kpi__toggle:hover,
    #layout-wrapper .npa-result-kpi__toggle:focus,
    #layout-wrapper .npa-result-kpi__toggle:active {
        color: var(--brand-blue);
    }

    #layout-wrapper .npa-result-kpi__toggle:focus,
    #layout-wrapper .npa-result-kpi__toggle:active {
        outline: none !important;
        box-shadow: none !important;
    }

#layout-wrapper .npa-result-kpi__chev {
    width: 1.1rem;
    text-align: center;
    color: var(--muted-foreground);
    transition: transform 0.15s ease;
}

/* Headline del panel: más grande que cabeceras de columna (~15px) */
#layout-wrapper .npa-result-kpi__toggle .npa-result-kpi__headline-name {
    flex: 1 1 auto;
    min-width: 0;
    font-size: 1.75rem;
    line-height: 1.3;
    font-weight: 600;
    text-transform: capitalize;
}

#layout-wrapper .npa-result-kpi__badge, .badge-soft-info {
    background: color-mix(in oklab, var(--muted) 70%, var(--card)) !important;
    color: var(--foreground) !important;
    font-weight: 600;
    border-radius: var(--radius);
    padding: 5px 12px;
    font-size: 14px;
}

#layout-wrapper .badge.npa-result-kpi__badge.npa-result-kpi__badge--compact {
    flex-shrink: 0;
    align-self: center;
    font-size: 12px;
    font-weight: 600;
    padding: 3px 9px;
    border-radius: var(--radius);
    line-height: 1.2;
    margin: 0 !important;
    background: color-mix(in oklab, var(--muted) 40%, var(--card)) !important;
    color: var(--foreground) !important;
}

#layout-wrapper .npa-result-kpi__panel-body {
    padding: 0;
    background: var(--card);
}

#layout-wrapper .npa-result-kpi__table {
    border: none;
    font-size: 14px;
}

    #layout-wrapper .npa-result-kpi__table thead tr {
        background: transparent;
    }

    #layout-wrapper .npa-result-kpi__table thead th {
        border-bottom: 1px solid var(--border);
        color: var(--foreground);
        font-weight: 600;
        font-size: 15px;
        padding: 12px 16px;
    }

        #layout-wrapper .npa-result-kpi__table thead th.npa-result-kpi__th-kpi {
            background: color-mix(in oklab, var(--muted) 38%, var(--card));
        }

        #layout-wrapper .npa-result-kpi__table thead th.npa-result-kpi__th-response {
            border-left: 1px solid color-mix(in oklab, var(--border) 85%, transparent);
            background: var(--card);
        }

    #layout-wrapper .npa-result-kpi__table tbody td {
        border-top: 1px solid color-mix(in oklab, var(--border) 80%, transparent);
        padding: 12px 16px;
        vertical-align: middle;
        font-size: 14px;
    }

    #layout-wrapper .npa-result-kpi__table tbody tr:hover td.npa-result-kpi__col-kpi {
        background: color-mix(in oklab, var(--brand-blue) 8%, var(--card));
    }

    #layout-wrapper .npa-result-kpi__table tbody tr:hover td.npa-result-kpi__col-answer {
        background: color-mix(in oklab, var(--brand-blue) 5%, var(--card));
    }

#layout-wrapper .npa-result-kpi__col-kpi {
    font-weight: 600;
    color: var(--foreground);
    width: 46%;
    background: color-mix(in oklab, var(--muted) 22%, var(--card));
}

#layout-wrapper .npa-result-kpi__col-answer {
    color: var(--foreground);
    background: var(--card);
    border-left: 1px solid color-mix(in oklab, var(--border) 75%, transparent);
}

@media (max-width: 767px) {
    #layout-wrapper .npa-result-kpi__hero-actions {
        text-align: left !important;
        margin-top: 10px;
    }

    #layout-wrapper .npa-result-kpi__stats-wrap {
        margin-left: 0 !important;
        text-align: left !important;
        width: 100%;
        padding-top: 4px;
    }

    #layout-wrapper .npa-result-kpi__stats {
        justify-content: flex-start;
    }
}
/* -----------------------------
   DD Digital AI Analysis (dueDiligence/analysis)
   Tokens heatmap: tokens.css (--dd-analysis-heatmap-*)
------------------------------ */
#layout-wrapper .npa-dd-analysis-page-header {
    border-bottom: 1px solid var(--border);
    padding: 12px 16px 14px;
    margin-bottom: 0;
}

#layout-wrapper .npa-dd-analysis-page-header__title {
    margin: 0 0 6px;
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--foreground);
    line-height: 1.25;
}

#layout-wrapper .npa-dd-analysis-page-header__desc {
    margin: 0;
    font-size: 14px;
    line-height: 1.5;
}

#layout-wrapper .npa-dd-analysis-page-header__row {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    row-gap: 12px;
}

#layout-wrapper .npa-dd-analysis-page-header__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    width: 100%;
}

@media (max-width: 991px) {
    #layout-wrapper .npa-dd-analysis-page-header__actions {
        justify-content: flex-start;
    }
}

#layout-wrapper .npa-dd-analysis-page-header__report-select {
    max-width: 260px;
    min-width: 200px;
    flex: 1 1 220px;
}

#layout-wrapper .npa-dd-analysis-target .panel-body {
    padding: 16px 18px 18px;
}

#layout-wrapper .npa-dd-analysis-target__eyebrow {
    font-size: 11px;
    letter-spacing: 0.1em;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--muted-foreground);
    margin-bottom: 10px;
}

#layout-wrapper .npa-dd-analysis-target__company {
    margin: 0;
    font-size: 1.25rem;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--brand-navy);
    line-height: 1.3;
}

#layout-wrapper .npa-dd-analysis-target__actions-wrap {
    display: flex;
    justify-content: flex-end;
}

@media (max-width: 991px) {
    #layout-wrapper .npa-dd-analysis-target__actions-wrap {
        justify-content: flex-start;
        margin-top: 12px;
    }
}

#layout-wrapper .npa-dd-analysis-target__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
}

#layout-wrapper .npa-dd-analysis-target__meta {
    margin: 12px 0 0;
    font-size: 13px;
    line-height: 1.4;
}

#layout-wrapper .npa-dd-analysis-tabs-panel {
    margin-bottom: 10px !important;
}

    #layout-wrapper .npa-dd-analysis-tabs-panel .panel-body {
        padding: 12px 14px 14px;
    }

#layout-wrapper .npa-dd-analysis-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    width: 100%;
}

#layout-wrapper .npa-dd-analysis-tabs__btn {
    flex: 1 1 140px;
    min-height: 2.5rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 8px 12px;
    border-radius: var(--radius);
    font-weight: 500;
    transition: background-color 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

#layout-wrapper .npa-dd-analysis-tabs__label {
    margin: 0;
    font-size: 13px;
    font-weight: 600;
    line-height: 1.2;
    pointer-events: none;
}

#layout-wrapper .npa-dd-analysis-tabs__btn.btn-primary .npa-dd-analysis-tabs__label {
    color: var(--color-white);
}

#layout-wrapper .npa-dd-analysis-topic-tab {
    margin-top: 4px;
}

#layout-wrapper .npa-dd-analysis-topic-tab__title {
    margin: 0 0 14px;
    font-size: 16px;
    font-weight: 600;
    color: var(--brand-navy);
    line-height: 1.35;
}

#layout-wrapper .npa-dd-analysis-topic-tab__toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    gap: 12px 16px;
    margin-bottom: 14px;
}

#layout-wrapper .npa-dd-analysis-topic-tab__toolbar-start {
    flex: 0 0 auto;
}

#layout-wrapper .npa-dd-analysis-topic-tab__toolbar-end {
    flex: 1 1 200px;
    display: flex;
    justify-content: flex-end;
    align-items: flex-end;
    min-width: 0;
}

    #layout-wrapper .npa-dd-analysis-topic-tab__toolbar-end .dataTables_filter {
        float: none !important;
        margin: 0 !important;
        text-align: right;
    }

        #layout-wrapper .npa-dd-analysis-topic-tab__toolbar-end .dataTables_filter label {
            display: flex;
            align-items: center;
            justify-content: flex-end;
            flex-wrap: wrap;
            gap: 8px;
            margin: 0;
            font-weight: 500;
            color: var(--muted-foreground);
        }

#layout-wrapper .npa-dd-analysis-topic-tab__table-wrap {
    border: 1px solid var(--border);
    border-radius: calc(var(--radius) + 2px);
    overflow: hidden;
    margin-bottom: 20px;
    background: var(--card);
}

#layout-wrapper .npa-dd-analysis-datatable__head {
    white-space: normal;
    word-wrap: break-word;
    word-break: normal;
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 2.5rem;
    text-align: center;
    font-weight: 600;
    line-height: 1.25;
}

#layout-wrapper table.npa-dd-analysis-datatable tbody td.npa-dd-analysis-heatmap-cell {
    text-align: center;
    vertical-align: middle !important;
}

#layout-wrapper .npa-dd-analysis-heatmap__label {
    font-size: 10px;
    text-transform: uppercase;
    font-weight: 600;
    line-height: 1.2;
}

#layout-wrapper table.npa-dd-analysis-datatable tbody td.npa-dd-analysis-heatmap-cell--not-mentioned {
    background-color: var(--dd-analysis-heatmap-bg-not-mentioned) !important;
    color: var(--dd-analysis-heatmap-fg-not-mentioned) !important;
}

#layout-wrapper table.npa-dd-analysis-datatable tbody td.npa-dd-analysis-heatmap-cell--low {
    background-color: var(--dd-analysis-heatmap-bg-low) !important;
    color: var(--dd-analysis-heatmap-fg-low) !important;
}

#layout-wrapper table.npa-dd-analysis-datatable tbody td.npa-dd-analysis-heatmap-cell--medium {
    background-color: var(--dd-analysis-heatmap-bg-medium) !important;
    color: var(--dd-analysis-heatmap-fg-medium) !important;
}

#layout-wrapper table.npa-dd-analysis-datatable tbody td.npa-dd-analysis-heatmap-cell--high {
    background-color: var(--dd-analysis-heatmap-bg-high) !important;
    color: var(--dd-analysis-heatmap-fg-high) !important;
}

#layout-wrapper table.npa-dd-analysis-datatable tbody td.npa-dd-analysis-heatmap-cell .npa-dd-analysis-heatmap__label {
    color: inherit !important;
}

#layout-wrapper table.dataTable.npa-dd-analysis-datatable.hover tbody tr:hover > td.npa-dd-analysis-heatmap-cell--not-mentioned,
#layout-wrapper table.dataTable.npa-dd-analysis-datatable.display tbody tr:hover > td.npa-dd-analysis-heatmap-cell--not-mentioned {
    background-color: var(--dd-analysis-heatmap-bg-not-mentioned) !important;
}

#layout-wrapper table.dataTable.npa-dd-analysis-datatable.hover tbody tr:hover > td.npa-dd-analysis-heatmap-cell--low,
#layout-wrapper table.dataTable.npa-dd-analysis-datatable.display tbody tr:hover > td.npa-dd-analysis-heatmap-cell--low {
    background-color: var(--dd-analysis-heatmap-bg-low) !important;
}

#layout-wrapper table.dataTable.npa-dd-analysis-datatable.hover tbody tr:hover > td.npa-dd-analysis-heatmap-cell--medium,
#layout-wrapper table.dataTable.npa-dd-analysis-datatable.display tbody tr:hover > td.npa-dd-analysis-heatmap-cell--medium {
    background-color: var(--dd-analysis-heatmap-bg-medium) !important;
}

#layout-wrapper table.dataTable.npa-dd-analysis-datatable.hover tbody tr:hover > td.npa-dd-analysis-heatmap-cell--high,
#layout-wrapper table.dataTable.npa-dd-analysis-datatable.display tbody tr:hover > td.npa-dd-analysis-heatmap-cell--high {
    background-color: var(--dd-analysis-heatmap-bg-high) !important;
}

#layout-wrapper .npa-dd-analysis-sections {
    padding-top: 0 !important;
}

/* -----------------------------
   Popovers 
------------------------------ */
#layout-wrapper .popover,
body > .popover {
    max-width: min(32rem, 92vw);
    padding: 0;
    background: var(--card, #fff);
    border: 1px solid color-mix(in oklab, var(--border, #dee2e6) 88%, var(--foreground, #0e1e3b));
    border-radius: calc(var(--radius, 4px) + 2px);
    box-shadow: 0 4px 20px color-mix(in oklab, var(--foreground, #0e1e3b) 10%, transparent), 0 1px 3px color-mix(in oklab, var(--foreground, #0e1e3b) 6%, transparent);
    overflow: hidden;
}

    #layout-wrapper .popover .popover-title,
    body > .popover .popover-title {
        margin: 0;
        padding: 16px 18px 8px;
        font-size: 15px;
        font-weight: 500;
        line-height: 1.35;
        color: var(--foreground, #1a1a1a);
        background: var(--card, #fff);
        border: none;
    }

    #layout-wrapper .popover .popover-content,
    body > .popover .popover-content {
        margin: 0;
        padding: 0 18px 18px;
        font-size: 14px;
        font-weight: 400;
        line-height: 1.5;
        color: var(--muted-foreground, #595959);
        background: var(--card, #fff);
    }

    #layout-wrapper .popover .popover-title + .popover-content,
    body > .popover .popover-title + .popover-content {
        padding-top: 0;
    }

    #layout-wrapper .popover .popover-title:empty,
    body > .popover .popover-title:empty {
        display: none;
    }

        #layout-wrapper .popover .popover-title:empty + .popover-content,
        body > .popover .popover-title:empty + .popover-content {
            padding-top: 18px;
        }

    #layout-wrapper .popover.top > .arrow,
    body > .popover.top > .arrow {
        border-top-color: color-mix(in oklab, var(--border, #dee2e6) 88%, var(--foreground, #0e1e3b));
    }

        #layout-wrapper .popover.top > .arrow:after,
        body > .popover.top > .arrow:after {
            border-top-color: var(--card, #fff);
        }

    #layout-wrapper .popover.bottom > .arrow,
    body > .popover.bottom > .arrow {
        border-bottom-color: color-mix(in oklab, var(--border, #dee2e6) 88%, var(--foreground, #0e1e3b));
    }

        #layout-wrapper .popover.bottom > .arrow:after,
        body > .popover.bottom > .arrow:after {
            border-bottom-color: var(--card, #fff);
        }

    #layout-wrapper .popover.left > .arrow,
    body > .popover.left > .arrow {
        border-left-color: color-mix(in oklab, var(--border, #dee2e6) 88%, var(--foreground, #0e1e3b));
    }

        #layout-wrapper .popover.left > .arrow:after,
        body > .popover.left > .arrow:after {
            border-left-color: var(--card, #fff);
        }

    #layout-wrapper .popover.right > .arrow,
    body > .popover.right > .arrow {
        border-right-color: color-mix(in oklab, var(--border, #dee2e6) 88%, var(--foreground, #0e1e3b));
    }

        #layout-wrapper .popover.right > .arrow:after,
        body > .popover.right > .arrow:after {
            border-right-color: var(--card, #fff);
        }


[class^="ti-"],
[class*=" ti-"] {
    line-height: 1 !important;
    flex-shrink: 0;
    position: relative;
    /* ajuste previo, revisar top: 1.5px;*/
    top: 0 !important;
}


#layout-wrapper .text-success {
    color: var(--success) !important;
}

#layout-wrapper .text-warning {
    color: var(--warning) !important;
}

#layout-wrapper .text-danger {
    color: var(--destructive) !important;
}

#layout-wrapper .text-primary {
    color: var(--primary) !important;
}

#layout-wrapper .text-secondary {
    color: var(--secondary) !important;
}

#layout-wrapper .text-info {
    color: var(--info) !important;
}

#layout-wrapper .text-muted {
    color: var(--muted-foreground) !important;
}

#layout-wrapper .text-white {
    color: var(--color-white) !important;
}

#layout-wrapper .text-dark {
    color: var(--brand-navy) !important;
}

.treetable .indenter a {
    position: relative;
    width: 16px;
    height: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    font-size: 0;
}

.treetable .collapsed .indenter a::before {
    font-family: "tabler-icons" !important;
    content: "\ea61" !important; /* chevron-right */

    font-size: 16px !important;
    line-height: 1;
    color: var(--brand-navy) !important;
}

.treetable .expanded .indenter a::before {
    font-family: "tabler-icons" !important;
    content: "\ea5f" !important; /* chevron-down */

    font-size: 16px !important;
    line-height: 1;
    color: var(--brand-navy) !important;
}

.treetable .indenter a {
    background-image: none !important;
}
/* -----------------------------
   Home / selector de plataformas (tarjetas sobre npa-surface-card)
------------------------------ */
#layout-wrapper .npa-home {
    padding: 8px 0 24px;
}

#layout-wrapper .npa-home__hero {
    margin-bottom: calc(var(--spacing) * 16);
}

#layout-wrapper .npa-home__title {
    text-align: center;
    margin: 0;
    font-size: 3rem;
    line-height: 1.25;
    color: var(--foreground);
    margin-bottom: calc(var(--spacing) * 2);
}

#layout-wrapper .npa-home__col {
    margin-bottom: 20px;
}

#layout-wrapper .npa-home__col {
    max-width: 300px;
}

@media (max-width: 768px) {
    #layout-wrapper .npa-home__col {
        max-width: unset;
    }
}

#layout-wrapper .npa-platform-card.npa-surface-card {
    height: 100%;
}

#layout-wrapper .npa-platform-card .npa-surface-card__body {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: 22px 18px 20px;
}

#layout-wrapper .npa-home__grid {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: calc(var(--spacing) * 6);
    flex-wrap: wrap;
}

#layout-wrapper .npa-platform-card__media {
    width: 100%;
    max-height: 220px;
    padding: calc(var(--spacing) * 8);
    border-radius: 0;
    overflow: hidden;
    margin: 0 0 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    background: var(--accent-foreground);
    border: 1px solid var(--border);
    border-radius: var(--radius);
}

    #layout-wrapper .npa-platform-card__media img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

#layout-wrapper .npa-platform-card__media--empty .ti {
    font-size: 2.5rem;
    line-height: 1;
    color: var(--muted-foreground);
}

#layout-wrapper .npa-platform-card__title {
    margin: 0 0 8px;
    font-size: 1.75rem;
    font-weight: 500;
    line-height: 1.35;
    color: var(--foreground);
    word-break: break-word;
    max-width: 100%;
}

#layout-wrapper .npa-platform-card__desc {
    margin: 0 0 18px;
    flex: 1 1 auto;
    font-size: 14px;
    line-height: 1.5;
    color: var(--muted-foreground);
    word-break: break-word;
    max-width: 100%;
}

#layout-wrapper .npa-platform-card__actions {
    margin-top: auto;
    width: 100%;
    display: flex;
    justify-content: center;
}

    #layout-wrapper .npa-platform-card__actions .btn {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
        min-height: 2.25rem;
        font-weight: 500;
        border-radius: var(--radius);
    }

        #layout-wrapper .npa-platform-card__actions .btn .ti {
            font-size: 1.1rem;
            line-height: 1;
        }
/* -----------------------------
 Tabla compacta reutilizable (.table-npa-compact)
 Sobrescribe cabeceras DataTables / .table globales cuando se combina con .dataTable
------------------------------ */
#layout-wrapper .table-npa-compact {
    width: 100% !important;
    margin: 0 !important;
    border-collapse: collapse;
    border: none !important;
    font-size: 13px;
}

    #layout-wrapper .table-npa-compact thead th,
    #layout-wrapper table.dataTable.table-npa-compact thead > tr > th,
    #layout-wrapper table.dataTable.table-npa-compact thead > tr > td {
        background: transparent !important;
        color: var(--brand-navy) !important;
        font-weight: 600 !important;
        font-size: 13px !important;
        padding: 10px 12px !important;
        border: none !important;
        border-bottom: 1px solid var(--border) !important;
        vertical-align: bottom !important;
    }

    #layout-wrapper .table-npa-compact tbody td,
    #layout-wrapper table.dataTable.table-npa-compact tbody > tr > td {
        padding: 8px 12px !important;
        border: none !important;
        border-bottom: 1px solid color-mix(in oklab, var(--border) 88%, transparent) !important;
        vertical-align: middle !important;
        background: var(--card);
    }

    #layout-wrapper .table-npa-compact.table-hover tbody tr:hover td,
    #layout-wrapper table.dataTable.table-npa-compact.hover tbody tr:hover > td,
    #layout-wrapper table.dataTable.table-npa-compact.display tbody tr:hover > td {
        background: color-mix(in oklab, var(--muted) 35%, var(--card)) !important;
    }

    #layout-wrapper .table-npa-compact tbody tr:last-child td,
    #layout-wrapper table.dataTable.table-npa-compact tbody tr:last-child > td {
        border-bottom: none !important;
    }

/* Contenido opcional dentro de <th> (títulos enriquecidos, columna “target”, etc.) */
#layout-wrapper .table-npa-compact__th {
    display: block;
    text-align: left;
    font-weight: 600;
    line-height: 1.25;
}

#layout-wrapper .table-npa-compact__th--target {
    text-align: left;
    display: flex;
    align-items: center;
}

#layout-wrapper .table-npa-compact__target-name {
    color: var(--brand-blue);
    font-weight: 600;
}

#layout-wrapper .table-npa-compact__target-mark {
    display: inline-block;
    margin-left: 4px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: var(--brand-blue);
    vertical-align: middle;
}

/* Celdas de cuerpo (clases en <td> desde el grid) */
#layout-wrapper .table-npa-compact__cell-muted {
    color: var(--muted-foreground);
    font-weight: 400;
    white-space: nowrap;
}

#layout-wrapper .table-npa-compact__cell-strong {
    color: var(--foreground);
    font-weight: 500;
}

#layout-wrapper .table-npa-compact__cell-start {
    text-align: left;
}

#layout-wrapper .comparison-cell {
    max-width: 150px;
}

/* DataTables: sin pie (info / paginación / toolbar footer) cuando la tabla es compacta */
#layout-wrapper .dataTables_wrapper:has(table.table-npa-compact) .dataTables_info,
#layout-wrapper .dataTables_wrapper:has(table.table-npa-compact) .dataTables_paginate,
#layout-wrapper .dataTables_wrapper:has(table.table-npa-compact) .dt-toolbar-footer {
    display: none !important;
}

/* Badges heatmap (colores desde tokens.css --dd-analysis-heatmap-*) */
#layout-wrapper .npa-heatmap-badge {
    display: inline-flex;
    max-width: 100%;
    padding: 4px 10px;
    border-radius: var(--radius);
    font-size: 11px;
    font-weight: 600;
    line-height: 1.2;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

#layout-wrapper .npa-heatmap-badge--muted {
    background: color-mix(in oklab, var(--muted) 55%, var(--card));
    color: var(--dd-analysis-heatmap-fg-not-mentioned);
}

#layout-wrapper .npa-heatmap-badge--low {
    background: var(--dd-analysis-heatmap-bg-low);
    color: var(--dd-analysis-heatmap-fg-low);
}

#layout-wrapper .npa-heatmap-badge--medium {
    background: var(--dd-analysis-heatmap-bg-medium);
    color: var(--dd-analysis-heatmap-fg-medium);
}

#layout-wrapper .npa-heatmap-badge--high {
    background: var(--dd-analysis-heatmap-bg-high);
    color: var(--dd-analysis-heatmap-fg-high);
}


/* Tabs secundarios tipo segment (Financial / Sustainability, etc.) */
#layout-wrapper .npa-segment-tabs {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px;
    padding: 4px;
    border-radius: var(--radius);
    background: color-mix(in oklab, var(--muted) 55%, var(--card));
    box-shadow: var(--shadow-card);
}

#layout-wrapper .npa-segment-tabs__btn {
    margin: 0;
    padding: 6px 14px;
    border: none;
    border-radius: calc(var(--radius) - 2px);
    background: transparent;
    color: var(--muted-foreground);
    font-size: 14px;
    font-weight: 500;
    line-height: 1.25;
    cursor: pointer;
    transition: background-color 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

    #layout-wrapper .npa-segment-tabs__btn:hover {
        color: var(--foreground);
    }

    #layout-wrapper .npa-segment-tabs__btn:focus {
        outline: none;
    }

    #layout-wrapper .npa-segment-tabs__btn:focus-visible {
        outline: 2px solid var(--brand-blue);
        outline-offset: 2px;
    }

#layout-wrapper .npa-segment-tabs__btn--active {
    color: var(--foreground);
    font-weight: 600;
    box-shadow: 0 1px 2px color-mix(in oklab, var(--foreground) 18%, transparent);
}

#layout-wrapper .npa-exposure-badge {
    display: inline-flex;
    max-width: 100%;
    padding: 4px 10px;
    border-radius: var(--radius);
    font-size: 11px;
    font-weight: 600;
    line-height: 1.2;
    text-transform: uppercase;
    letter-spacing: 0.02em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-top: calc(var(--spacing) * 2);
}



#layout-wrapper .npa-exposure-badge--muted {
    background: color-mix(in oklab, var(--muted) 55%, var(--card));
    color: var(--dd-analysis-heatmap-fg-not-mentioned);
}

#layout-wrapper .npa-exposure-badge--low {
    background: var(--dd-analysis-heatmap-bg-low);
    color: var(--dd-analysis-heatmap-fg-low);
}

#layout-wrapper .npa-exposure-badge--medium {
    background: var(--dd-analysis-heatmap-bg-medium);
    color: var(--dd-analysis-heatmap-fg-medium);
}

#layout-wrapper .npa-exposure-badge--high {
    background: var(--dd-analysis-heatmap-bg-high);
    color: var(--dd-analysis-heatmap-fg-high);
}
/* Tarjeta insight: meta + bloque AI summary (listados DD Analysis, etc.) */
#layout-wrapper .npa-insight-card-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

#layout-wrapper .npa-insight-card {
    display: grid;
    grid-template-columns: minmax(0, 34%) minmax(0, 1fr);
    gap: 0;
    background: var(--card);
    border: 1px solid var(--border);
    border-radius: calc(var(--radius) + 4px);
    box-shadow: var(--shadow-card);
    overflow: hidden;
}

#layout-wrapper .npa-insight-card__meta {
    padding: 16px 18px;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
    min-width: 0;
}

#layout-wrapper .npa-insight-card__title {
    margin: 0;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.35;
    color: var(--foreground);
}

#layout-wrapper .npa-insight-card__category {
    margin: 0;
    font-size: 11px;
    line-height: 1.4;
    color: var(--muted-foreground);
}

#layout-wrapper .npa-insight-card__summary {
    padding: 16px 18px;
    min-width: 0;
}

#layout-wrapper .npa-insight-card__summary-eyebrow {
    display: flex;
    align-items: center;
    gap: 6px;
    margin: 0 0 10px;
    font-size: 11px;
    font-weight: 300;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--muted-foreground);
    line-height: 1.3;
}

    #layout-wrapper .npa-insight-card__summary-eyebrow .fa {
        font-size: 12px;
        opacity: 0.95;
        color: var(--brand-blue);
    }

#layout-wrapper .npa-insight-card__summary-body {
    margin: 0;
    font-size: 13px;
    line-height: 1.55;
    color: var(--foreground);
}

#layout-wrapper .npa-insight-card-list__empty,
#layout-wrapper .npa-insight-card-list__loader {
    margin: 0;
    padding: 24px 16px;
    text-align: center;
    font-size: 14px;
    color: var(--muted-foreground);
    background: var(--card);
    border: 1px dashed var(--border);
    border-radius: calc(var(--radius) + 4px);
}

@media (max-width: 767px) {
    #layout-wrapper .npa-insight-card {
        grid-template-columns: 1fr;
    }

    #layout-wrapper .npa-insight-card__meta {
        border-right: none;
        border-bottom: 1px solid var(--border);
    }
}

#layout-wrapper .npa-dd-analysis-topic-tab__toolbar--with-segment .npa-dd-analysis-topic-tab__toolbar-start {
    flex: 1 1 auto;
}

#layout-wrapper .npa-dd-analysis-topic-tab__toolbar--with-segment .npa-dd-analysis-topic-tab__toolbar-end {
    flex: 0 0 auto;
    justify-content: flex-end;
}
