/*public/assets/css/bento
/* ========================================================================== */
/* DREAMS | EJES DE RESULTADOS ESTRATÉGICOS (institucional HUB) */
/* ========================================================================== */

/* --- Drill-down Academia (dashboard): hover + modal --- */
.academia-drill-popover {
    display: none;
    width: 320px;
    max-width: calc(100vw - 24px);
    max-height: min(320px, 70vh);
    overflow-y: auto;
    pointer-events: auto;
    background: rgba(255, 255, 255, 0.97);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(149, 124, 61, 0.28);
    border-radius: 20px;
    box-shadow: 0 24px 48px rgba(15, 52, 96, 0.14);
    padding: 0;
    font-family: 'Montserrat', sans-serif;
}

.academia-drill-popover.active {
    display: block;
}

.academia-drill-popover-inner {
    padding: 14px 16px 12px;
}

.academia-drill-popover-title {
    display: block;
    font-size: 0.58rem;
    font-weight: 800;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--accent-gold);
    margin-bottom: 10px;
}

.academia-drill-popover-hint {
    display: block;
    font-size: 0.6rem;
    font-weight: 600;
    color: rgba(15, 52, 96, 0.45);
    margin-top: 10px;
    text-align: center;
    letter-spacing: 0.04em;
}

.academia-drill-row {
    margin-bottom: 10px;
}

.academia-drill-row.is-compact {
    margin-bottom: 8px;
}

.academia-drill-row-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 8px;
    margin-bottom: 4px;
}

.academia-drill-name {
    font-size: 0.72rem;
    font-weight: 700;
    color: var(--primary-midnight);
    line-height: 1.25;
    flex: 1;
    min-width: 0;
}

.academia-drill-pct {
    font-size: 0.85rem;
    font-weight: 800;
    color: var(--accent-gold);
    flex-shrink: 0;
}

.academia-drill-bar-track {
    height: 6px;
    border-radius: 6px;
    background: rgba(15, 52, 96, 0.08);
    overflow: hidden;
}

.academia-drill-bar-fill {
    height: 100%;
    border-radius: 6px;
    background: linear-gradient(90deg, var(--primary-midnight), var(--accent-gold));
    transition: width 0.35s ease;
}

.academia-drill-meta {
    display: block;
    font-size: 0.55rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: rgba(15, 52, 96, 0.4);
    margin-top: 4px;
}

.academia-drill-section-label {
    font-size: 0.58rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--primary-midnight);
    margin: 18px 0 10px;
    padding-top: 12px;
    border-top: 1px solid rgba(15, 52, 96, 0.08);
}

.dashboard-block-tagline,
.hub-executive-summary {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    color: rgba(15, 52, 96, 0.68);
    line-height: 1.45;
    text-transform: none;
}

.hub-executive-summary {
    text-align: center;
    max-width: 640px;
    margin: 0 auto 8px;
}

.node-kpi-sub {
    font-size: 0.62rem;
    font-weight: 700;
    color: rgba(15, 52, 96, 0.45);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin-top: 6px;
    line-height: 1.35;
    max-width: 100%;
}

.axis-node:hover .node-kpi-sub {
    color: rgba(149, 124, 61, 0.85);
}

.dreams-axis-hub {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 40px;
    padding: 40px 0;
    flex-wrap: wrap;
    perspective: 1000px;
}

.dreams-axis-hub:has(.p2-dash-odoo-tile) {
    /* Igual que consultoría: repeat(auto-fill, minmax(168px, 1fr)) + gaps compactos */
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(168px, 1fr));
    gap: 12px 14px;
    align-items: stretch;
    justify-content: stretch;
    padding: 28px 0;
    perspective: none;
}

.axis-node {
    /* Paridad con landing MIEC: superficie sólida sobre marfil (menos “vidrio” difuso) */
    background: #ffffff;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    border: 1px solid rgba(149, 124, 61, 0.28);
    border-radius: 40px;
    width: 220px;
    height: 220px;
    padding: 30px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
    box-shadow:
        0 4px 6px rgba(15, 52, 96, 0.03),
        0 16px 36px rgba(15, 52, 96, 0.07);
    position: relative;
    overflow: hidden;
}

/* Efecto de Expansión institucional */
.axis-node:hover {
    width: 320px;
    height: 380px;
    background: #FFFFFF;
    border-color: var(--accent-gold); /* #957C3D */
    box-shadow: 0 30px 60px rgba(15, 52, 96, 0.12);
    transform: translateY(-10px);
}

/* Si el nodo usa la tesela tipo Consultoría, anulamos la expansión (paridad con Odoo tile) */
.axis-node.p2-dash-odoo-tile,
.axis-node.p2-dash-odoo-tile:hover {
    width: auto !important;
    height: auto !important;
    transform: translateY(-1px) !important;
}

.axis-node.p2-dash-odoo-tile:hover .node-icon {
    transform: none;
}


.node-icon {
    font-size: 3rem;
    margin-bottom: 15px;
    transition: all 0.4s ease;
    filter: drop-shadow(0 4px 8px rgba(15, 52, 96, 0.1));
}

.axis-node:hover .node-icon {
    transform: scale(0.8) translateY(-10px);
}

.node-content {
    text-align: center;
    width: 100%;
}

.node-label {
    display: block;
    font-size: 0.65rem; /* Ajuste Quirúrgico: Más pequeño para dar protagonismo al dato */
    font-weight: 800;
    color: var(--accent-gold); /* Cambio a Oro para diferenciar concepto de valor */
    text-transform: uppercase;
    letter-spacing: 2px;
    margin-bottom: 4px; /* Espaciado compacto "Data-Unit" */
    transition: all 0.4s ease;
}

/* Contenedor de Gráfica (Oculto inicialmente) */
.node-chart-container {
    width: 100%;
    height: 0; /* Quirúrgico: Altura cero para que no empuje el texto hacia arriba en reposo */
    opacity: 0;
    overflow: hidden; /* Evita que el contenido de la gráfica se asome mientras está colapsada */
    transform: translateY(20px);
    transition: all 0.5s ease 0.2s; /* Mantenemos el delay para la expansión del nodo */
    pointer-events: none;
}

.axis-node:hover .node-chart-container {
    height: 180px; /* Recupera su espacio solo cuando el nodo se expande a 380px */
    opacity: 1;
    transform: translateY(0);
    pointer-events: all;
    margin-top: 20px; /* Respiro visual entre el texto y la gráfica */
}

.node-kpi {
    font-size: 2.2rem; /* Incremento institucional para legibilidad de impacto */
    font-weight: 800;
    color: var(--primary-midnight);
    margin-top: 0; /* Eliminamos el gap excesivo */
    transition: all 0.4s cubic-bezier(0.19, 1, 0.22, 1);
    letter-spacing: -1px;
}

/* Refuerzo de alineación en Hover */
.axis-node:hover .node-label {
    color: var(--primary-midnight);
    transform: translateY(-5px);
}

.axis-node:hover .node-kpi {
    color: var(--accent-gold);
    font-size: 1.4rem;
}

/* Adaptación Móvil Quirúrgica */
@media (max-width: 768px) {
    .dreams-axis-hub { gap: 20px; }
    .axis-node { width: 100%; height: auto; min-height: 150px; border-radius: 24px; }
    .axis-node:hover { height: auto; width: 100%; transform: none; }
    .node-chart-container { display: none; } /* En móvil priorizamos el número sobre la gráfica */
}               

/* Breakpoint para Tablets y Laptops pequeñas */
@media (max-width: 1024px) {
    .bento-grid { grid-template-columns: repeat(2, 1fr); }
}

/* Breakpoint para Celulares (Suelo de Legibilidad & Simetría Tactil) */
@media (max-width: 600px) {
    /* Ajuste de Contenedor Maestro para Móvil */
    .welcome-container { padding: 20px !important; }

    /* Homologación: Forzamos columna única y respiros dinámicos */
    .bento-grid, .grid-recursos { 
        grid-template-columns: 1fr !important; 
        gap: 20px; 
        padding: 10px 0;
    }

    /* Ajuste Quirúrgico de la Regleta Sticky en Móvil */
    .sticky-shelf {
        margin: 0 -20px 30px -20px; /* Sincronizado con el nuevo padding de 20px */
        padding: 15px 20px;
    }

    /* --- OPTIMIZACIÓN DE LISTADO PARA MÓVIL (QUIRÚRGICO) --- */
    .operative-column .glass-card {
        padding: 8px 12px !important; /* Más compacto para ahorrar verticalidad */
        gap: 10px !important;
        margin-bottom: 4px;
    }

    .operative-column .glass-card .app-icon-mini {
        font-size: 1rem !important; /* Icono más discreto en móvil */
    }

    .operative-column .glass-card-info span:first-child {
        font-size: 0.75rem !important; /* Fuente optimizada para smartphones */
    }

    /* Ajuste de la zona de IA para que no genere espacios muertos */
    .ai-insights-zone {
        padding-top: 15px !important;
        margin-top: 15px !important;
    }

    /* Reset de Jerarquías para flujo vertical absoluto */
    .bento-main, .bento-wide { 
        grid-column: span 1; 
        grid-row: auto; 
    }
    
    /* Refuerzo de Alineación para el micro-copy inyectado */
    .bento-item p { margin-bottom: 15px !important; }

    /* Sincronización con el Respiro Dinámico del Blueprint (1.5rem a 3rem) */
    .bento-item, .card-recurso, .card {
        padding: var(--dynamic-padding) !important; 
        /* Ajuste de curvatura para maximizar el área útil en pantallas pequeñas */
        border-radius: 12px; 
    }

    .kpi-value { font-size: 2rem; } 

    /* Blindaje Tactil: Botones ocupan el ancho total en móvil */
    .btn-primary, .btn-gold-sm, .btn-outline-sm {
        width: 100% !important;
        padding: 18px !important; /* Facilidad de clic con el pulgar */
        display: flex;
        justify-content: center;
        align-items: center;
        box-sizing: border-box;
    }
}

/* --- ESTÉTICA DE DATOS (KPI) --- */
.kpi-value {
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--primary-midnight);
    letter-spacing: -0.03em;
}

.kpi-label {
    font-size: var(--font-size-label); /* 15px: Sincronización con Suelo institucional */
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--accent-gold);
    font-weight: 600;
}

/* --- ESTILOS DE LOBBY (HOMOLOGACIÓN institucional) --- */
.welcome-container { 
    padding: var(--dynamic-padding); /* Respiro dinámico institucional */
    max-width: var(--container-max-width); /* Alineación con ancho maestro */
    margin: 0 auto; 
}

.grid-recursos { 
    display: grid; 
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); 
    gap: var(--content-gap); /* Espaciado estandarizado */
    margin-top: var(--content-gap); 
}

.card-recurso { 
    background: var(--card-bg); 
    border-radius: 16px; /* Sincronización con el estándar .card */
    padding: var(--dynamic-padding); 
    border: 1px solid rgba(15, 52, 96, 0.04); 
    display: flex; 
    flex-direction: column;
    transition: all 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
    /* Soft Depth multicapa */
    box-shadow: 0 4px 6px rgba(15, 52, 96, 0.02), 0 15px 35px rgba(15, 52, 96, 0.05);
}

.card-recurso:hover {
    transform: translateY(-8px);
    box-shadow: 0 20px 40px rgba(15, 52, 96, 0.08);
    border-color: var(--accent-gold);
}

.card-recurso h3 { 
    font-size: var(--font-size-h3); /* 22px: Sincronización institucional con Títulos de Módulo */
    color: var(--primary-midnight);
    margin-bottom: 18px;
    font-weight: 700;
    letter-spacing: -0.01em;
}

.card-recurso p {
    font-size: var(--font-size-body); /* 17px: Sincronización institucional para legibilidad premium */
    font-weight: 400;
    line-height: 1.7; /* Incremento quirúrgico para mejorar el escaneo visual en grid */
    color: var(--text-color); /* #1A1A1A: Máximo contraste institucional */
    margin-bottom: 0;
}

/* --- DISEÑO DE BLOQUE KPI (HOMOLOGADO institucional) --- */
.bento-kpi-card {
    border-left: 4px solid var(--accent-gold); /* Autoridad visual en Oro institucional */
}

.kpi-trend {
    font-size: var(--font-size-label); /* 15px: Sincronización con Suelo institucional */
    font-weight: 700;
    margin-top: 12px;
}

.trend-up { color: var(--secondary-color); } /* Sincronización con Verde Institucional */
.trend-down { color: var(--accent-gold); }    /* Sincronización con Oro institucional (Ex-Terracotta) */

/* --- ESTILOS DE APLICACIONES (SENTINEL & institucional) --- */

/* Efecto Liquid Glass Homologado (institucional) - MODALIDAD COMPACTA ODOO-STYLE */
.glass-card {
    background: rgba(255, 255, 255, 0.75) !important;
    backdrop-filter: blur(20px) saturate(180%);
    -webkit-backdrop-filter: blur(20px) saturate(180%);
    border: 1px solid rgba(15, 52, 96, 0.08) !important;
    border-radius: 16px; 
    padding: 12px !important; /* Reducción de padding para mayor agilidad */
    box-shadow: 0 4px 6px rgba(15, 52, 96, 0.02);
    transition: all 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    min-height: 110px; /* Downsizing de altura inicial */
    min-width: 170px;  /* Estandarización de ancho para evitar burbujas gigantes */
    justify-content: center;
    overflow: hidden;
}

.glass-card:hover {
    min-height: 320px; /* Expansión suave para revelar contenido */
    padding: 25px !important;
    transform: translateY(-8px);
    box-shadow: 0 30px 60px rgba(15, 52, 96, 0.08);
    border-color: var(--accent-gold) !important;
    justify-content: space-between;
}

/* Estado Sentinel: Bloqueo por vigencia expirada */
.locked-opacity {
    opacity: 0.6;
    filter: grayscale(0.8) blur(0.5px);
    pointer-events: none; /* Blindaje: No permite clicks */
    background: rgba(15, 52, 96, 0.05) !important;
    border-style: dashed !important;
}

/* --- MICRO-ELEMENTOS TRANSICIONALES --- */
.app-icon {
    font-size: 1.8rem; /* Icono reducido en estado de reposo */
    margin-bottom: 10px;
    filter: drop-shadow(0 4px 8px rgba(15, 52, 96, 0.15));
    transition: all 0.4s ease;
}

.glass-card:hover .app-icon {
    font-size: 2.8rem; /* Recupera tamaño institucional en hover */
    margin-bottom: 15px;
}

/* Control de visibilidad de info secundaria (Descripción, Status y Botones) */
.glass-card p, 
.glass-card .status-tag, 
.glass-card .btn-gold-sm {
    opacity: 0;
    max-height: 0;
    margin: 0;
    transition: all 0.4s ease-in-out;
    pointer-events: none; /* Inactivo mientras está oculto */
}

.glass-card:hover p, 
.glass-card:hover .status-tag, 
.glass-card:hover .btn-gold-sm {
    opacity: 1;
    max-height: 200px; /* Permite el despliegue del contenido */
    margin-top: 15px;
    pointer-events: all;
}

.status-tag {
    align-self: flex-start;
    margin-top: auto;
    /* Sincronización con Suelo institucional (15px) */
    font-size: var(--font-size-label); 
    font-weight: 700;
    text-transform: uppercase;
    /* Padding equilibrado para el nuevo tamaño de fuente */
    padding: 8px 16px; 
    border-radius: 20px;
    letter-spacing: 0.05em; /* Tracking optimizado para legibilidad en 15px */
}

.status-active {
    background: rgba(46, 125, 50, 0.15);
    color: var(--secondary-color);
}

.status-expired {
    background: rgba(149, 124, 61, 0.15);
    color: var(--accent-gold);
}

/* Botón reducido para Grid (mismo ADN que .btn-primary: midnight + oro) */
/* Nombre histórico "gold-sm": conservado por compatibilidad con glass-card / apps */
.btn-gold-sm {
    background: var(--accent-cta);
    color: white;
    padding: 14px 24px;
    border-radius: 12px;
    font-size: var(--font-size-button);
    font-weight: 600;
    text-decoration: none;
    text-align: center;
    transition: all 300ms ease-out;
    border: 2px solid var(--accent-gold);
}

.btn-gold-sm:hover {
    background: var(--accent-cta-hover);
    border-color: var(--accent-gold);
    transform: translateY(-2px);
    box-shadow: 0 5px 18px rgba(15, 52, 96, 0.2), 0 0 0 2px rgba(149, 124, 61, 0.4);
}

/* --- COMPONENTES DE ACADEMIA (LOBBY FOCUS) --- */

/* Contenedor Maestro de la Tarjeta de Curso */
/* BLINDAJE QUIRÚRGICO: Anulamos el recorte de glass-card específicamente para Academia */
.card-lobby-item.glass-card {
    overflow: visible !important; /* Prioridad absoluta para dejar salir al popover */
}

/* Lobby de curso: el .glass-card genérico expande altura en hover (apps); aquí no aplica. */
.card-lobby-item.glass-card:hover {
    min-height: 160px !important;
    padding: 22px !important;
    justify-content: flex-start !important;
    align-items: stretch !important;
    text-align: left !important;
}

.card-lobby-item {
    display: flex;
    flex-direction: column;
    height: auto;
    min-height: 160px; /* Homologación: Evitamos el max-height que rompe la expansión */
    padding: 22px;
    cursor: pointer;
    border-top: 4px solid var(--accent-gold); 
    position: relative;
    transition: all 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
}

/* Solo aplicamos el recorte cuando la tarjeta NO está expandida para mantener la estética colapsada */
.card-lobby-item:not(.card-expanded) {
    overflow: hidden !important;
}

/* Si el Roadmap está activo, la tarjeta DEBE permanecer abierta y visible */
.card-lobby-item:has(.description-popover.active) {
    overflow: visible !important;
    max-height: none !important;
    z-index: 1001 !important; 
}

/* BLINDAJE: Solo ocultamos contenido cuando la tarjeta NO está activa o expandida */
.card-lobby-item:not(.card-expanded) {
    overflow: hidden;
}

/* Títulos y Etiquetas */
.card-header-app {
    margin-bottom: 15px;
}

.card-title-app {
    color: var(--primary-midnight);
    font-size: 1.1rem;
    margin: 0;
    line-height: 1.2;
    font-weight: 800;
}

/* Áreas de contenido dinámico (reveladas en Hover) */
.card-body-app, .card-footer-app {
    opacity: 0;
    transition: opacity 0.3s ease;
}

.card-body-app {
    margin-top: 10px;
}

.card-footer-app {
    padding-top: 10px;
}

/* Botón de Acción interno */
.btn-lobby-action {
    width: 100%;
    font-size: 0.75rem;
    padding: 12px;
    font-weight: 800;
}

/* --- CLASES DE ESTADO (HIDRATADAS POR JS) --- */
.card-active {
    filter: none !important;
    opacity: 1 !important;
    transform: scale(1.02) !important;
    z-index: 10;
}

.card-inactive {
    filter: blur(6px) grayscale(0.4) !important;
    opacity: 0.4 !important;
    transform: scale(0.96) !important;
    pointer-events: none;
}

.card-expanded {
    max-height: 600px !important; /* Expansión para revelar descripción y botón */
}

.card-content-visible {
    opacity: 1 !important;
}

.card-price-tag {
    font-size: 0.85rem;
    font-weight: 800;
    color: var(--accent-gold);
    margin-bottom: 12px;
}

/* ========================================================================== */
/* DREAMS DASHBOARD | LAYOUT ESPECÍFICO (institucional) */
/* ========================================================================== */

.user-identity-header {
    margin-bottom: 35px;
    animation: fadeInSlide 0.8s ease-out;
    text-align: center;
}

#user-display-name {
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    color: var(--primary-midnight);
    font-size: 2.2rem;
    letter-spacing: -0.02em;
    display: block;
}

.identity-subtitle {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.95rem;
    color: #666;
    font-weight: 300;
    line-height: 1.5;
    max-width: 38rem;
    margin-left: auto;
    margin-right: auto;
}

.user-identity-header .identity-subtitle {
    margin-top: 10px;
}

.user-identity-header .identity-subtitle + .identity-subtitle {
    margin-top: 8px;
}

/* --- Dashboard: títulos de bloque unificados (bienvenida, panel operativo, hub) --- */
.dashboard-block-title {
    font-family: 'Montserrat', sans-serif;
    font-weight: 700;
    font-size: clamp(0.98rem, 0.35vw + 0.92rem, 1.2rem);
    color: var(--primary-midnight);
    letter-spacing: 0.025em;
    line-height: 1.38;
    margin: 0 0 10px;
    text-transform: none;
}

#welcome-section .dashboard-block-title {
    text-align: center;
    max-width: 48rem;
    margin-left: auto;
    margin-right: auto;
}

.dashboard-block-title--shelf,
.dashboard-block-title--hub {
    text-align: center;
}

.dashboard-block-title--shelf {
    margin-bottom: 6px;
}

.dashboard-block-title--hub {
    margin-bottom: 12px;
}

.shelf-header-titles .dashboard-block-tagline {
    max-width: 36rem;
    margin-left: auto;
    margin-right: auto;
}

/* --- ZONA OPERATIVA: CONTROLES Y COLAPSO --- */
.sticky-shelf {
    position: sticky;
    top: var(--navbar-height);
    z-index: 998;
    background: rgba(245, 245, 240, 0.98);
    backdrop-filter: blur(20px);
    margin: 0 0 40px 0; 
    padding: 20px 0;
    border-bottom: 1.5px solid rgba(149, 124, 61, 0.2);
    box-shadow: 0 10px 30px rgba(15, 52, 96, 0.05);
    transition: all 0.5s cubic-bezier(0.19, 1, 0.22, 1);
}

.shelf-control-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 5px 15px 5px;
    border-bottom: 1px solid rgba(15, 52, 96, 0.05);
}

.shelf-header-titles {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex: 1;
    text-align: center;
    min-width: 0;
}

.btn-minimal-toggle {
    background: rgba(15, 52, 96, 0.03);
    border: 1px solid rgba(15, 52, 96, 0.1);
    width: 32px;
    height: 32px;
    border-radius: 8px;
    color: var(--primary-midnight);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.4s ease;
}

.btn-minimal-toggle:hover {
    background: var(--primary-midnight);
    color: white;
    transform: scale(1.05);
}

/* Panel operativo: control visible, alineado con midnight + oro (sin ruido visual) */
.btn-shelf-toggle {
    position: relative;
    width: auto;
    min-width: 44px;
    min-height: 44px;
    height: auto;
    padding: 10px 16px;
    gap: 10px;
    flex-shrink: 0;
    border: 1.5px solid rgba(149, 124, 61, 0.45);
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 2px 12px rgba(15, 52, 96, 0.08);
    font-family: inherit;
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--primary-midnight);
}

.btn-shelf-toggle:hover {
    background: var(--primary-midnight);
    color: #f5f5f0;
    border-color: var(--accent-gold);
    box-shadow: 0 4px 16px rgba(15, 52, 96, 0.18);
    transform: translateY(-1px);
}

.btn-shelf-toggle:focus-visible {
    outline: 2px solid var(--accent-gold);
    outline-offset: 3px;
}

.btn-shelf-toggle .shelf-toggle-label {
    white-space: nowrap;
    line-height: 1;
}

.btn-shelf-toggle .shelf-toggle-glyph {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 0.65rem;
    opacity: 0.9;
}

.btn-shelf-toggle:hover .shelf-toggle-glyph {
    opacity: 1;
}

@media (max-width: 520px) {
    .btn-shelf-toggle {
        padding: 10px 12px;
        gap: 8px;
    }

    .btn-shelf-toggle .shelf-toggle-label {
        position: absolute;
        width: 1px;
        height: 1px;
        padding: 0;
        margin: -1px;
        overflow: hidden;
        clip: rect(0, 0, 0, 0);
        white-space: nowrap;
        border: 0;
    }
}

#toggle-icon {
    font-size: 0.7rem;
    transition: transform 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.btn-shelf-toggle #toggle-icon {
    font-size: 0.72rem;
}

/* --- MECANISMO DE COLAPSO QUIRÚRGICO --- */
.shelf-content-wrapper {
    max-height: 800px; /* Suficiente para las listas actuales */
    opacity: 1;
    overflow: hidden;
    transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
    margin-top: 20px;
}

/* Estado Colapsado */
.sticky-shelf.is-collapsed { padding-bottom: 10px; }
.sticky-shelf.is-collapsed .shelf-content-wrapper {
    max-height: 0;
    opacity: 0;
    margin-top: 0;
    pointer-events: none;
}

.sticky-shelf.is-collapsed #toggle-icon { transform: rotate(-90deg); }

/* --- TÍTULOS STICKY INTERNOS --- */
.column-sticky-title {
    position: sticky;
    top: 0; /* Se clava al inicio del contenedor padre que ya es sticky */
    background: rgba(245, 245, 240, 0.98);
    z-index: 20;
    margin: 0 0 15px 0 !important;
    padding: 10px 0;
    font-size: 0.65rem !important;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    color: var(--primary-midnight);
    border-bottom: 1px solid rgba(149, 124, 61, 0.1);
}

/* Refuerzo de Proporción en Tarjetas Operativas */
.operative-column .glass-card {
    flex-direction: row !important;
    justify-content: flex-start !important;
    align-items: center !important;
    text-align: left !important;
    min-height: 50px !important; /* Proporción mínima de altura */
    width: 100% !important;      /* Se ajusta al contenedor */
    max-width: 450px;           /* Evita que se estire infinitamente en monitores grandes */
    box-sizing: border-box !important; /* Garantiza que el padding no sume al ancho */
    padding: 12px 20px !important;
    border-radius: 12px !important;
    gap: 15px;
    background: rgba(255, 255, 255, 0.6) !important;
    border: 1px solid rgba(15, 52, 96, 0.1) !important;
}

/* --- ARQUITECTURA: SPLIT-PANEL OPERATIVO (ACTIVOS VS IA) --- */
.split-operative-panel {
    display: flex;
    gap: 30px; /* Separación clara entre Gestión y Estrategia */
    width: 100%;
    align-items: flex-start;
}

.operative-column {
    flex: 1; /* Distribución 50/50 equitativa */
    display: flex;
    flex-direction: column;
}

/* Dashboard (modo panel inline): habilitar scroll dentro de cada columna
   para listados largos sin depender del scroll del body. */
.dash-panel[data-dash-panel="operativo"] .operative-column {
    max-height: calc(100vh - var(--navbar-height) - 140px);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding-right: 6px; /* evita que la barra tape contenido */
}

.dash-panel[data-dash-panel="operativo"] .operative-column::-webkit-scrollbar {
    width: 10px;
}

.dash-panel[data-dash-panel="operativo"] .operative-column::-webkit-scrollbar-thumb {
    background: rgba(15, 52, 96, 0.18);
    border-radius: 10px;
    border: 2px solid rgba(255, 255, 255, 0.6);
}

.dash-panel[data-dash-panel="operativo"] .operative-column::-webkit-scrollbar-thumb:hover {
    background: rgba(15, 52, 96, 0.28);
}

/* Panel operativo dashboard: microcopy sin competir con el hub de ejes */
.operative-column-hint {
    font-size: 0.65rem;
    color: rgba(15, 52, 96, 0.55);
    font-weight: 500;
    line-height: 1.35;
    margin: 0 0 10px 0;
    max-width: 420px;
}
.operative-hint-muted {
    color: rgba(149, 124, 61, 0.75);
}

.operative-division-label {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.58rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(15, 52, 96, 0.45);
    margin: 14px 0 6px 0;
    padding: 0 2px;
}

.operative-column .monitor-list > .operative-division-label:first-child {
    margin-top: 0;
}

.operative-column .glass-card.operative-shelf-row {
    cursor: pointer;
    border: none;
    width: 100%;
    font-family: inherit;
    text-align: left;
    -webkit-tap-highlight-color: transparent;
}

/* --- REDISEÑO QUIRÚRGICO: LISTADO MINIMALISTA (EX-BURBUJAS) --- */

/* 1. Transformación de Contenedores a Listas Verticales */
.monitor-list, .ai-recommendation-feed {
    display: flex;
    flex-direction: column; /* Apilado vertical */
    gap: 8px;               /* Espaciado compacto profesional */
    flex-wrap: nowrap;
}

/* 2. Mutación de Glass-Card a "List Item" (Solo en zona operativa) */
.operative-column .glass-card {
    flex-direction: row !important;     /* De cuadro a fila */
    justify-content: flex-start !important;
    align-items: center !important;
    text-align: left !important;
    min-height: auto !important;        /* Elimina el volumen de burbuja */
    min-width: 100% !important;         /* Ocupa todo el ancho de su columna */
    padding: 10px 18px !important;      /* Padding delgado y elegante */
    border-radius: 10px !important;     /* Curvatura más discreta */
    gap: 15px;
    background: rgba(255, 255, 255, 0.4) !important; /* Más transparente/limpio */
    transition: all 0.3s ease !important;
}

/* 3. Ajuste de Iconos e Información en Línea */
.operative-column .glass-card .app-icon-mini {
    margin: 0 !important;
    font-size: 1.2rem !important;
}

.operative-column .glass-card-info {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}

.operative-column .glass-card-info span:first-child {
    font-weight: 600;
    font-size: 0.85rem;
    color: var(--primary-midnight);
}

.operative-column .status-label {
    font-size: 0.65rem !important;
    font-weight: 800;
    letter-spacing: 1px;
}

/* 4. Neutralización de Expansión Invasiva y Micro-Feedback */
.operative-column .glass-card:hover {
    min-height: auto !important;
    transform: translateX(5px) !important; /* Desplazamiento lateral sutil en lugar de salto */
    background: #FFFFFF !important;
    border-color: var(--accent-gold) !important;
    box-shadow: 2px 4px 12px rgba(15, 52, 96, 0.05) !important;
}

/* Blindaje: Ocultar cualquier párrafo o botón que intente desplegarse en esta vista compacta */
.operative-column .glass-card p, 
.operative-column .glass-card .btn-gold-sm,
.operative-column .glass-card .status-tag {
    display: none !important;
}

/* Diferenciación Visual de la Zona de IA */
.ai-glow-text {
    color: var(--accent-gold) !important;
    text-shadow: 0 0 15px rgba(149, 124, 61, 0.2);
}

.ai-insights-zone {
    border-left: 1.5px dashed rgba(149, 124, 61, 0.3); /* Separador sutil de autoridad */
    padding-left: 30px;
}

/* ANULACIÓN QUIRÚRGICA DE EXPANSIÓN (ESTADO FIJO) */
.operative-column .glass-card:hover {
    min-height: 110px !important;
    transform: translateY(-2px) !important; /* Micro-elevación para feedback táctil solamente */
    min-width: 170px !important;
    box-shadow: 0 5px 15px rgba(15, 52, 96, 0.08) !important;
}

/* Responsividad: Apilado vertical para dispositivos móviles */
@media (max-width: 991px) {
    .split-operative-panel { flex-direction: column; gap: 40px; }
    .ai-insights-zone { border-left: none; border-top: 1.5px dashed rgba(149, 124, 61, 0.3); padding-left: 0; padding-top: 30px; }
}
.app-icon-mini { font-size: 1.5rem; }

.floating-dock { position: fixed; bottom: 40px; right: 40px; display: flex; flex-direction: column; gap: 20px; z-index: 5000; }
.family-bubble {
    width: 65px; height: 65px; background: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(15px); border: 1px solid rgba(149, 124, 61, 0.3);
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
    cursor: pointer; transition: all 0.5s cubic-bezier(0.19, 1, 0.22, 1);
    box-shadow: 0 10px 30px rgba(15, 52, 96, 0.1);
}
.family-bubble:hover { width: 180px; border-radius: 30px; background: var(--primary-midnight); border-color: var(--accent-gold); }
.bubble-icon { font-size: 1.5rem; transition: transform 0.3s ease; }
.family-bubble:hover .bubble-icon { transform: translateX(-50px); filter: brightness(0) invert(1); }
.bubble-label { position: absolute; right: 25px; opacity: 0; color: white; font-weight: 700; font-size: 0.9rem; text-transform: uppercase; letter-spacing: 1px; transition: opacity 0.3s ease; pointer-events: none; }
.family-bubble:hover .bubble-label { opacity: 1; }

@keyframes fadeInSlide { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: translateY(0); } }

/* --- CONSOLIDACIÓN DEFINITIVA: LISTADO MINIMALISTA DREAMS --- */

.monitor-list, .ai-recommendation-feed {
    display: flex;
    flex-direction: column;
    gap: 8px; /* Espaciado compacto profesional */
    width: 100%;
}

.operative-column .glass-card {
    display: flex !important;
    flex-direction: row !important; /* Formato de fila, no de burbuja */
    align-items: center !important;
    justify-content: flex-start !important;
    
    /* Neutralización Quirúrgica de Anchos Fijos */
    min-height: auto !important; 
    height: 50px !important;    /* Altura ejecutiva estándar */
    width: 100% !important;      /* Se ajusta al ancho de la columna */
    min-width: 0 !important;     /* ELIMINA EL SCROLL: Permite que la card se encoja */
    max-width: 100% !important;
    
    padding: 0 15px !important;
    margin: 0 0 8px 0 !important;
    border-radius: 10px !important;
    background: rgba(255, 255, 255, 0.4) !important;
    box-sizing: border-box !important; /* El padding no suma al ancho */
    text-align: left !important;
}

/* Hover Minimalista: Solo desplazamiento sutil */
.operative-column .glass-card:hover {
    min-height: 50px !important;
    transform: translateX(5px) !important;
    background: #FFFFFF !important;
    border-color: var(--accent-gold) !important;
    box-shadow: 2px 4px 12px rgba(15, 52, 96, 0.05) !important;
}

/* --- COMPONENTE: ROADMAP POP-OVER (REFINAMIENTO institucional) --- */
.roadmap-link {
    color: var(--accent-gold);
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 10px 0 15px 0;
    transition: all 0.3s ease;
    cursor: pointer;
}

.roadmap-link:hover {
    color: var(--primary-midnight);
    transform: translateX(3px);
}

.description-popover {
    position: absolute;
    left: 105%;
    top: 0;
    width: 320px; /* Incremento para legibilidad senior */
    max-height: 350px;
    background: rgba(255, 255, 255, 0.98) !important;
    backdrop-filter: blur(12px);
    border: 1.5px solid var(--accent-gold);
    border-radius: 24px;
    padding: 30px;
    box-shadow: 0 30px 70px rgba(15, 52, 96, 0.3);
    z-index: 5000; /* Prioridad absoluta */
    opacity: 0;
    visibility: hidden;
    transform: translateX(-10px);
    transition: all 0.5s cubic-bezier(0.19, 1, 0.22, 1);
    pointer-events: none;
    display: flex;
    flex-direction: column;
    overflow-y: auto;
    scrollbar-width: thin;
}

.description-popover.active {
    opacity: 1;
    visibility: visible;
    transform: translateX(0);
    pointer-events: all;
}

.description-popover p {
    font-size: 0.9rem !important;
    line-height: 1.6 !important;
    margin: 0;
    color: var(--text-color);
    text-align: left;
}

/* AJUSTE DE SEGURIDAD MÓVIL: Evita el encimado sobre el CTA */
@media (max-width: 1024px) {
    .description-popover {
        left: 0;
        top: auto;
        bottom: 85px; /* Elevado para dejar libre el botón de 'Solicitar' */
        width: 100%;
        max-height: 220px;
        transform: translateY(15px) scale(0.98);
        border-radius: 20px 20px 0 0;
        box-shadow: 0 -20px 40px rgba(15, 52, 96, 0.15);
    }
    
    .description-popover.active {
        transform: translateY(0) scale(1);
    }
}

/* ========================================================================== */
/* ACADEMIA | VISTA DE PILARES (#view-categories) — copy orientado al usuario */
/* ========================================================================== */

.academia-pillars-header {
    margin-bottom: 50px;
    text-align: center;
}

.academia-pillars-title {
    text-transform: uppercase;
    font-family: 'Montserrat', sans-serif;
    font-weight: 800;
    font-size: clamp(1.15rem, 2vw, 1.5rem);
    letter-spacing: 0.08em;
    color: var(--primary-midnight);
    margin: 0 0 8px;
}

.academia-pillars-intro {
    max-width: 820px;
    margin: 0 auto;
    text-align: left;
}

.academia-pillars-lead,
.academia-pillars-reflection,
.academia-pillars-cta {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.92rem;
    font-weight: 400;
    line-height: 1.65;
    color: #4a5568;
    margin: 0 0 1rem;
}

.academia-pillars-lead {
    margin-top: 18px;
}

.academia-pillars-lead strong,
.academia-pillars-reflection strong,
.academia-pillars-cta strong {
    color: var(--primary-midnight);
    font-weight: 700;
}

.academia-pillars-subhead {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--accent-gold);
    margin: 1.35rem 0 0.75rem;
    text-align: center;
}

.academia-pillars-list {
    list-style: none;
    padding: 0;
    margin: 0 0 1.15rem;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.academia-pillars-list li.academia-pillar-item:focus-within {
    outline: 2px solid rgba(149, 124, 61, 0.65);
    outline-offset: 3px;
}

.academia-pillars-list li.academia-pillar-item {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.88rem;
    line-height: 1.6;
    color: #4a5568;
    box-sizing: border-box;
    min-height: clamp(10.25rem, 28vw, 11.75rem);
    padding: 1.25rem 1.4rem 1.35rem 1.25rem;
    background: rgba(15, 52, 96, 0.04);
    border-radius: 14px;
    border-left: 4px solid var(--accent-gold);
    overflow-wrap: break-word;
    word-break: normal;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: stretch;
    cursor: pointer;
    list-style: none;
}

.academia-pillar-copy {
    text-align: justify;
    text-justify: inter-word;
    hyphens: auto;
    -webkit-hyphens: auto;
    flex: 1 1 auto;
}

.academia-pillars-list li.academia-pillar-item strong {
    color: var(--primary-midnight);
    font-weight: 700;
}

.academia-pillars-list .btn-pillar-enter {
    flex-shrink: 0;
    align-self: center;
    margin-top: 1.1rem;
    pointer-events: auto;
}

/* Apps | recuadros tipo pilares (acceso restringido) */
.academia-pillars-list li.apps-pillar-item {
    /* Replica “Odoo tile” de Consultoría (institucional Phase2): borde-acento + blanco + hover sutil */
    min-height: 52px;
    padding: 12px 14px;
    background: #fff;
    border: 1px solid rgba(15, 52, 96, 0.12);
    border-radius: 4px;
    box-shadow: 0 1px 2px rgba(15, 52, 96, 0.05);
    border-left: 4px solid var(--apps-tile-accent, var(--accent-gold));
    transition: border-color 0.15s ease, box-shadow 0.15s ease, transform 0.12s ease, filter 0.25s ease, opacity 0.25s ease;
}

.academia-pillars-list li.apps-pillar-item--locked {
    opacity: 0.94;
    filter: grayscale(0.2);
    border-left-color: rgba(149, 124, 61, 0.45);
}

.academia-pillars-list li.apps-pillar-item:hover {
    border-color: rgba(15, 52, 96, 0.22);
    box-shadow: 0 2px 8px rgba(15, 52, 96, 0.08);
    transform: translateY(-1px);
}

.academia-pillars-list li.apps-pillar-item:focus-within {
    outline: 2px solid var(--accent-gold);
    outline-offset: 2px;
}

/* Tooltip (paridad con Consultoría: data-consult-tip) */
.academia-pillars-list li.apps-pillar-item[data-app-tip] {
    position: relative;
}

.academia-pillars-list li.apps-pillar-item[data-app-tip]::after {
    content: attr(data-app-tip);
    position: absolute;
    left: 50%;
    top: calc(100% + 8px);
    transform: translateX(-50%);
    width: max-content;
    max-width: 220px;
    height: 24px;
    padding: 0 10px;
    background: rgba(15, 52, 96, 0.96);
    color: #fff;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.55rem;
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    white-space: nowrap;
    text-align: center;
    line-height: 1;
    border-radius: 8px;
    box-shadow: 0 6px 18px rgba(15, 52, 96, 0.28);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    z-index: 10002;
    transition: opacity 0.14s ease, visibility 0.14s ease, transform 0.14s ease;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    text-overflow: ellipsis;
}

.academia-pillars-list li.apps-pillar-item[data-app-tip]:hover::after,
.academia-pillars-list li.apps-pillar-item[data-app-tip]:focus-within::after {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(-2px);
}

/* Apps | acciones de contacto compactas (sustituyen el botón INGRESAR ancho) */
.apps-pillar-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    justify-content: center;
    align-items: stretch;
    width: 100%;
    margin-top: 1rem;
    box-sizing: border-box;
}

.apps-contact-btn {
    box-sizing: border-box;
    flex: 1 1 calc(50% - 10px);
    min-width: 132px;
    max-width: 200px;
    padding: 10px 12px;
    font-family: 'Montserrat', sans-serif;
    font-size: 0.68rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    text-align: center;
    text-decoration: none;
    color: #fff;
    background: var(--primary-midnight);
    border: 2px solid var(--accent-gold);
    border-radius: 10px;
    cursor: pointer;
    box-shadow: 0 4px 14px rgba(15, 52, 96, 0.18);
    transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease;
}

.apps-contact-btn:hover {
    transform: translateY(-1px);
    box-shadow: 0 6px 18px rgba(15, 52, 96, 0.22);
    color: #fff;
}

.apps-contact-btn--pending {
    opacity: 0.72;
    cursor: pointer;
}

.apps-contact-btn--schedule {
    background: #2d8cff;
    box-shadow: 0 4px 14px rgba(45, 140, 255, 0.25);
}

.apps-contact-btn--schedule:hover {
    box-shadow: 0 6px 18px rgba(45, 140, 255, 0.32);
    color: #fff;
}

.apps-pillar-open-wrap,
.apps-pillar-request-wrap {
    margin: 0.85rem 0 0;
    text-align: center;
    width: 100%;
}

.apps-open-app-link {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.78rem;
    font-weight: 700;
    color: var(--accent-gold);
    text-decoration: none;
    letter-spacing: 0.04em;
}

.apps-open-app-link:hover {
    text-decoration: underline;
}

.apps-request-access-btn {
    font-family: 'Montserrat', sans-serif;
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--primary-midnight);
    background: transparent;
    border: none;
    padding: 0;
    cursor: pointer;
    text-decoration: underline;
    text-underline-offset: 3px;
}

@media (max-width: 600px) {
    .apps-contact-btn {
        flex: 1 1 100%;
        max-width: none;
    }
}

.academia-pillars-reflection {
    margin-top: 1.1rem;
    padding-top: 0;
    border-top: none;
}

.academia-pillars-cta--before-list {
    margin-bottom: 1.1rem !important;
}

.academia-pillars-cta {
    margin-bottom: 0;
    padding: 14px 18px;
    background: rgba(149, 124, 61, 0.08);
    border-radius: 14px;
    border: 1px solid rgba(149, 124, 61, 0.22);
    text-align: center;
}

@media (max-width: 600px) {
    .academia-pillars-intro {
        padding: 0 6px;
    }

    .academia-pillars-list li.academia-pillar-item {
        font-size: 0.84rem;
        line-height: 1.62;
        min-height: clamp(11.5rem, 52vw, 14rem);
        padding: 1.15rem 1.1rem 1.25rem 1.05rem;
    }
}