/* ===============================================================
   CICLA - activos.css
   Estilos globales del sistema - paleta dorada/beige
=============================================================== */

@import url('https://fonts.googleapis.com/css2family=Syne:wght@600;700;800&family=DM+Mono:wght@300;400;500&display=swap');

/*  BASE  */
.cl-layout, .cl-layout *,
.cl-layout *::before, .cl-layout *::after { box-sizing: border-box; }

:root {
    --sidebar:    280px;
    --oro:        #b8964a;
    --oro-light:  #d4ad63;
    --oro-dim:    rgba(184,150,74,0.10);
    --fondo:      #f4efe6;
    --blanco:     #ffffff;
    --gris1:      #1a1814;
    --gris2:      #2e2b24;
    --gris3:      #9a8f78;
    --gris4:      #c8bfa8;
    --borde:      #e2dbd0;
    --radio:      10px;
}

body:has(.cl-layout),
body:has(.cl-sidebar) {
    position: static !important;
    top: auto !important;
    display: block !important;
    place-items: unset !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    height: auto !important;
    min-height: 100vh;
    margin: 0 !important;
    padding: 0 !important;
    background: var(--fondo) !important;
    font-family: "DM Mono", monospace;
    color: var(--gris1);
}

/*  LAYOUT  */
.cl-layout {
    display: flex;
    min-height: 100vh;
    padding-top: 60px;
    margin-left: var(--sidebar);
    width: calc(100% - var(--sidebar));
    box-sizing: border-box;
}

/*  SIDEBAR  */
.cl-sidebar {
    width: var(--sidebar);
    min-width: var(--sidebar);
    background: var(--gris1);
    display: flex;
    flex-direction: column;
    position: fixed;
    top: 60px;
    left: 0;
    height: calc(100vh - 60px);
    overflow-y: auto;
    flex-shrink: 0;
    z-index: 10;
    padding-top: 0;
}

.cl-nav { flex: 1; padding: 0; }
.cl-nav-seccion {
    font-size: 8px; font-weight: 500; letter-spacing: .22em;
    text-transform: uppercase; color: rgba(255,255,255,0.50);
    text-shadow: 0 1px 2px rgba(0,0,0,0.4); padding: 4px 24px 4px;
}

/* Modulos del sidebar de Cicla */
.cl-nav-item {
    display: flex; align-items: center; gap: 12px;
    padding: 10px 20px; text-decoration: none;
    border-left: 3px solid transparent; transition: all .18s;
    cursor: pointer;
}
.cl-nav-item:hover { background: rgba(255,255,255,0.04); border-left-color: rgba(184,150,74,0.4); }
.cl-nav-item.activo { border-left-color: var(--oro); background: rgba(184,150,74,0.08); }
.cl-nav-item.bloqueado { opacity: .35; cursor: not-allowed; }
.cl-nav-ini {
    width: 28px; height: 28px; border-radius: 6px;
    background: rgba(184,150,74,0.12); border: 1px solid rgba(184,150,74,0.25);
    display: flex; align-items: center; justify-content: center;
    font-family: "Syne", sans-serif; font-size: 9px; font-weight: 700;
    color: var(--oro); letter-spacing: .06em; flex-shrink: 0;
}
.cl-nav-item.activo .cl-nav-ini { background: var(--oro); color: var(--gris1); }
.cl-nav-texto {
    flex: 1; font-family: "Syne", sans-serif; font-size: 12px;
    font-weight: 700; color: rgba(255,255,255,0.80); letter-spacing: .04em;
    line-height: 1.2;
}
.cl-nav-texto small {
    display: block; font-family: "DM Mono", monospace; font-size: 9px;
    font-weight: 300; color: rgba(255,255,255,0.35); letter-spacing: .02em;
    margin-top: 2px;
}
.cl-nav-item.activo .cl-nav-texto { color: #fff; }
.cl-nav-dot {
    width: 6px; height: 6px; border-radius: 50%;
    background: var(--oro); flex-shrink: 0;
}

/* Menu de procesos/reportes dentro del modulo */
.cl-nav-titulo {
    display: block; font-family: "Syne", sans-serif; font-size: 8px;
    font-weight: 700; letter-spacing: .20em; text-transform: uppercase;
    color: var(--gris4); padding: 14px 24px 4px;
    border-top: 1px solid rgba(255,255,255,0.06);
}
.cl-nav-titulo:first-child { border-top: none; padding-top: 8px; }
.cl-nav a {
    display: block; font-size: 13px; font-weight: 400;
    color: rgba(255,255,255,0.80); text-decoration: none;
    padding: 7px 24px; letter-spacing: .02em;
    border-left: 3px solid transparent; transition: all .18s; line-height: 1.2;
}
.cl-nav a:hover {
    color: #fff; background: rgba(255,255,255,0.04);
    border-left-color: rgba(184,150,74,0.4); padding-left: 30px;
}
.cl-nav .contenedor_menus {
    border: none !important; box-shadow: none !important;
    border-radius: 0 !important; background: transparent !important; padding: 0 !important;
}
.cl-nav .contenedor_menus b {
    display: block; font-family: "Syne", sans-serif; font-size: 8px; font-weight: 700;
    letter-spacing: .20em; text-transform: uppercase; color: var(--gris4);
    padding: 14px 24px 4px; border-top: 1px solid rgba(255,255,255,0.06);
}
.cl-nav .contenedor_menus br { display: none; }
.cl-nav .contenedor_menus a {
    display: block; font-size: 13px; font-weight: 400; color: rgba(255,255,255,0.80);
    text-decoration: none; padding: 7px 24px; letter-spacing: .02em;
    border-left: 3px solid transparent; transition: all .18s;
}
.cl-nav .contenedor_menus a:hover {
    color: #fff; background: rgba(255,255,255,0.04);
    border-left-color: rgba(184,150,74,0.4); padding-left: 30px;
}

.cl-sidebar-foot {
    padding: 14px 24px; border-top: 1px solid rgba(255,255,255,0.06);
    font-size: 9px; color: rgba(255,255,255,0.15); letter-spacing: .08em;
    display: flex; align-items: center; justify-content: space-between;
}
.cl-sidebar-foot-user { display: flex; align-items: center; gap: 8px; }
.cl-sidebar-avatar {
    width: 24px; height: 24px; border-radius: 50%;
    background: rgba(184,150,74,0.15); border: 1px solid rgba(184,150,74,0.3);
    display: flex; align-items: center; justify-content: center;
    font-family: "Syne", sans-serif; font-size: 8px; font-weight: 700; color: var(--oro);
}

/*  MAIN  */
.cl-main {
    flex: 1; padding: 20px 32px 40px; min-width: 0;
    background: var(--fondo); min-height: calc(100vh - 60px);
}

/*  CABECERA  */
.cabecera {
    position: fixed !important; top: 0 !important; left: 0 !important; right: 0 !important;
    height: 60px !important; background: #ffffff !important;
    border-bottom: 2px solid #e2dbd0 !important; z-index: 1000 !important;
    display: flex !important; align-items: center !important; padding: 0 28px !important;
    gap: 0 !important; box-shadow: 0 1px 12px rgba(0,0,0,0.07) !important;
}
.cab-logo {
    display: flex; align-items: center; text-decoration: none;
    flex-shrink: 0; margin-right: 24px; background: #ffffff; padding: 0 16px; height: 60px;
}
.cab-div { width: 1px; height: 36px; background: #e2dbd0; flex-shrink: 0; margin-right: 20px; }
.cab-empresa { flex: 1; min-width: 0; }
.cab-empresa-nombre {
    font-family: "Syne", sans-serif; font-size: 13px; font-weight: 700; color: #1a1814;
    letter-spacing: .05em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; line-height: 1.1;
}
.cab-empresa-sub {
    font-family: "DM Mono", monospace; font-size: 9px; font-weight: 300;
    color: #9a8f78; margin-top: 2px; letter-spacing: .04em;
}
.cab-empresa-pagina {
    font-family: "DM Mono", monospace; font-size: 10px; font-weight: 500;
    color: #b8964a; margin-top: 2px; letter-spacing: .03em;
}
.cab-acciones { display: flex; align-items: center; gap: 12px; flex-shrink: 0; margin-left: 20px; }
.cab-supervisor {
    display: flex; align-items: center; gap: 7px; background: #1a1814;
    border: 1px solid rgba(184,150,74,0.30); border-radius: 7px; padding: 5px 10px;
    text-decoration: none; transition: border-color .18s, background .18s;
}
.cab-supervisor:hover { background: #2e2b24; border-color: #b8964a; }
.cab-supervisor-punto {
    width: 6px; height: 6px; border-radius: 50%; background: #b8964a;
    box-shadow: 0 0 5px rgba(184,150,74,0.5); flex-shrink: 0;
}
.cab-supervisor-texto {
    font-family: "Syne", sans-serif; font-size: 9px; font-weight: 700;
    letter-spacing: .14em; text-transform: uppercase; color: #b8964a;
}
.cab-avatar {
    width: 30px; height: 30px; border-radius: 50%; background: #f4efe6;
    border: 1.5px solid #e2dbd0; display: flex; align-items: center; justify-content: center;
    font-family: "Syne", sans-serif; font-size: 10px; font-weight: 700;
    color: #9a8f78; letter-spacing: .04em; flex-shrink: 0;
}
.cab-salir {
    padding: 5px 14px; background: transparent; border: 1px solid #e2dbd0; border-radius: 7px;
    font-family: "DM Mono", monospace; font-size: 10px; font-weight: 500; color: #9a8f78;
    cursor: pointer; letter-spacing: .06em; transition: border-color .18s, color .18s, background .18s;
}
.cab-salir:hover { border-color: #dc2626; color: #dc2626; background: rgba(192,57,43,0.04); }

/*  TABLAS CONTENEDOR  */
.contenedor-tablas {
    position: relative !important; top: auto !important; left: auto !important;
    max-height: 630px; overflow-y: auto; overflow-x: auto; margin: 0 auto;
    scrollbar-width: thin; scrollbar-color: #e2dbd0 transparent;
}
.contenedor-tablas::-webkit-scrollbar { width: 5px; height: 5px; }
.contenedor-tablas::-webkit-scrollbar-thumb { background: #e2dbd0; border-radius: 3px; }
.contenedor-tablas table { width: 100%; border-collapse: collapse; font-family: "DM Mono", monospace; font-size: 12px; }
.contenedor-tablas thead th {
    background: #1a1814 !important; color: #b8964a !important;
    font-family: "Syne", sans-serif; font-size: 10px; font-weight: 700;
    letter-spacing: .10em; text-transform: uppercase; padding: 10px 12px;
    border-bottom: 2px solid #b8964a; white-space: nowrap; position: sticky; top: 0; z-index: 10;
    -webkit-print-color-adjust: exact; print-color-adjust: exact;
}
.contenedor-tablas tbody tr { border-bottom: 1px solid #e2dbd0; transition: background .15s; }
.contenedor-tablas tbody tr:hover { background: rgba(184,150,74,0.06) !important; }
.contenedor-tablas tbody tr:nth-child(even) { background: #faf7f2; }
.contenedor-tablas tbody td { padding: 6px 12px; color: #2e2b24; white-space: nowrap; vertical-align: middle; font-size: 11.5px; }

/*  FILTROS CONTENEDOR  */
.kpi-wrapper { display: flex; flex-direction: column; align-items: flex-start; width: 100%; max-width: 1400px; margin: 0 auto; padding-top: 10px; }
.contenedor-filtros-tablas {
    position: relative !important; top: auto !important; left: auto !important;
    width: 100%; padding: 8px 0; background-color: #f4efe6; z-index: 100;
    text-align: center; border-bottom: 1px solid #e2dbd0; margin-bottom: 12px;
}
.contenedor-filtros-tablas a { font-family: "DM Mono", monospace; font-size: 12px; color: #9a8f78; text-decoration: none; padding: 4px 10px; border-radius: 5px; border: 1px solid #e2dbd0; transition: all .15s; }
.contenedor-filtros-tablas a:hover { background: #1a1814; color: #b8964a; border-color: #b8964a; }
.contenedor-filtros-tablas select { font-family: "DM Mono", monospace; font-size: 12px; padding: 4px 8px; border: 1px solid #e2dbd0; border-radius: 6px; background: #fff; color: #1a1814; outline: none; }
.contenedor-filtros-tablas select:focus { border-color: #b8964a; }
.contenedor-filtros-tablas button,
.contenedor-filtros-tablas input[type="submit"] { font-family: "DM Mono", monospace; font-size: 11px; padding: 5px 14px; background: #1a1814; color: #b8964a; border: 1px solid #b8964a; border-radius: 6px; cursor: pointer; letter-spacing: .04em; transition: background .15s; }
.contenedor-filtros-tablas button:hover { background: #2e2b24; }

/*  FORMULARIOS tabla.abm  */
.cl-main table.abm thead th,
.cl-main table.abm tr th { background: #1a1814 !important; color: #b8964a !important; font-family: "Syne", sans-serif; font-size: 10px; font-weight: 700; letter-spacing: .10em; text-transform: uppercase; padding: 10px 12px; border-bottom: 2px solid #b8964a; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
.cl-main table.abm tbody tr:nth-child(even) { background: #faf7f2 !important; }
.cl-main table.abm tbody tr:nth-child(odd)  { background: #fff !important; }
.cl-main table.abm td, .cl-main table.abm th { padding: 7px 12px !important; border-bottom: 1px solid #e2dbd0; color: #2e2b24; vertical-align: middle; }
.cl-main table.abm tbody tr:hover { background: rgba(184,150,74,0.06) !important; }

/* Inputs globales cl-main */
.cl-main input[type="text"],
.cl-main input[type="number"],
.cl-main input[type="date"],
.cl-main input[type="email"],
.cl-main input[type="password"],
.cl-main select,
.cl-main textarea { font-family: "DM Mono", monospace; font-size: 12px; padding: 6px 10px; border: 1.5px solid #e2dbd0; border-radius: 6px; background: #fff; color: #1a1814; outline: none; transition: border-color .18s; }
.cl-main input:focus, .cl-main select:focus, .cl-main textarea:focus { border-color: #b8964a; }
.cl-main input[type="submit"],
.cl-main button[type="submit"],
.cl-main button:not(.kpi-btn-grafico) { font-family: "DM Mono", monospace; font-size: 11px; padding: 6px 16px; background: #1a1814; color: #b8964a; border: 1px solid #b8964a; border-radius: 6px; cursor: pointer; letter-spacing: .04em; transition: background .15s; }
.cl-main input[type="submit"]:hover,
.cl-main button[type="submit"]:hover { background: #2e2b24; }

/*  IMPRESIN BASE  */
@media print {
    .cl-sidebar, .cabecera, .cl-sidebar-foot, .contenedor-filtros-tablas { display: none !important; }
    .cl-layout { display: block !important; margin-left: 0 !important; }
    .cl-main { padding: 10px !important; }
    .contenedor-tablas { max-height: none !important; overflow: visible !important; }
    @page { margin: 15mm; size: landscape; }
}

/* ===============================================================
   ABM - clases compartidas (abm-*)
=============================================================== */

.abm-filtros { display:flex; align-items:center; gap:10px; background:#fff; border:1.5px solid var(--borde); border-radius:10px; padding:12px 16px; margin-bottom:16px; flex-wrap:wrap; }
.abm-filtros input[type="text"],
.abm-filtros input[type="date"],
.abm-filtros select { font-family:"DM Mono",monospace; font-size:12px; padding:6px 10px; border:1.5px solid var(--borde); border-radius:6px; background:var(--fondo); color:var(--gris1); outline:none; transition:border-color .18s; }
.abm-filtros input:focus, .abm-filtros select:focus { border-color:var(--oro); }
.abm-filtros button, .abm-filtros input[type="submit"] { font-family:"DM Mono",monospace; font-size:11px; padding:6px 14px; background:var(--gris1); color:var(--oro); border:1px solid var(--oro); border-radius:6px; cursor:pointer; transition:background .15s; }
.abm-filtros button:hover { background:var(--gris2); }
.abm-filtros-label { font-family:"DM Mono",monospace; font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--gris3); }

.abm-toolbar { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.abm-toolbar-titulo { font-family:"Syne",sans-serif; font-size:1rem; font-weight:700; color:var(--gris1); letter-spacing:.04em; }
.abm-toolbar-titulo span { color:var(--oro); }
.abm-btn-print { display:inline-flex; align-items:center; gap:6px; font-family:"DM Mono",monospace; font-size:10px; font-weight:700; letter-spacing:.07em; text-transform:uppercase; padding:6px 14px; background:var(--gris1); color:var(--oro); border:1.5px solid var(--oro); border-radius:6px; cursor:pointer; transition:background .15s,color .15s; }
.abm-btn-print:hover { background:var(--oro); color:#fff; }
.abm-btn-nuevo { display:inline-flex; align-items:center; gap:6px; font-family:"DM Mono",monospace; font-size:11px; font-weight:700; letter-spacing:.07em; text-transform:uppercase; padding:6px 14px; background:var(--gris1); color:var(--oro); border:1.5px solid var(--oro); border-radius:6px; text-decoration:none; transition:background .15s; }
.abm-btn-nuevo:hover { background:var(--oro); color:#fff; }

.abm-tabla-wrap { background:#fff; border:1.5px solid var(--borde); border-radius:10px; overflow:hidden; overflow-x:auto; box-shadow:0 2px 8px rgba(0,0,0,0.05); }
.abm-tabla { width:100%; border-collapse:collapse; font-family:"DM Mono",monospace; font-size:12px; }
.abm-tabla thead th { background:var(--gris1); color:var(--oro); font-family:"Syne",sans-serif; font-size:10px; font-weight:700; letter-spacing:.10em; text-transform:uppercase; padding:10px 14px; border-bottom:2px solid var(--oro); text-align:left; white-space:nowrap; position:sticky; top:0; z-index:5; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.abm-tabla tbody tr { border-bottom:1px solid var(--borde); height:30px; transition:background .15s; }
.abm-tabla tbody tr:hover { background:rgba(184,150,74,0.06); }
.abm-tabla tbody tr:nth-child(even) { background:#faf7f2; }
.abm-tabla tbody tr:nth-child(even):hover { background:rgba(184,150,74,0.06); }
.abm-tabla tbody td { padding:0 14px; color:var(--gris2); vertical-align:middle; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; line-height:30px; height:30px; }
.abm-tabla tbody td.num { text-align:right; font-variant-numeric:tabular-nums; }
.abm-col-acc { white-space:nowrap; text-align:center; padding:0 6px !important; }
.abm-tabla .fila-total td { background:var(--gris1)!important; color:var(--oro)!important; font-family:"Syne",sans-serif; font-size:11px; font-weight:700; padding:8px 10px; border-top:2px solid var(--oro); -webkit-print-color-adjust:exact; print-color-adjust:exact; }

.abm-acc { display:inline-flex; align-items:center; justify-content:center; width:26px; height:26px; border-radius:6px; color:var(--gris3); text-decoration:none; transition:all .15s; border:1px solid transparent; vertical-align:middle; }
.abm-acc:hover      { background:var(--fondo); border-color:var(--borde); color:var(--gris1); }
.abm-acc.ver:hover  { color:#3b82f6; border-color:#3b82f6; background:rgba(59,130,246,0.06); }
.abm-acc.add:hover  { color:#22c55e; border-color:#22c55e; background:rgba(34,197,94,0.06); }
.abm-acc.edit:hover { color:var(--oro); border-color:var(--oro); background:var(--oro-dim); }
.abm-acc.del:hover  { color:#ef4444; border-color:#ef4444; background:rgba(239,68,68,0.06); }
.abm-acc.pdf:hover  { color:var(--oro); border-color:var(--oro); background:var(--oro-dim); }

.abm-panel-td { padding:8px 12px !important; background:var(--fondo) !important; }
.abm-panel { background:#fff; border:1.5px solid var(--borde); border-left:3px solid var(--oro); border-radius:8px; overflow:hidden; display:inline-block; min-width:460px; max-width:100%; margin:4px 0 4px 8px; }
.abm-panel-head { display:flex; align-items:center; gap:10px; padding:10px 16px; background:var(--gris1); border-bottom:1px solid var(--oro); }
.abm-panel-titulo { font-family:"Syne",sans-serif; font-size:11px; font-weight:700; color:var(--oro); letter-spacing:.08em; text-transform:uppercase; }
.abm-panel-body { padding:14px 20px; }
.abm-campo { display:flex; align-items:flex-start; gap:12px; margin-bottom:9px; border-bottom:1px solid var(--fondo); padding-bottom:7px; }
.abm-campo:last-child { border-bottom:none; margin-bottom:0; }
.abm-campo-label { font-family:"Syne",sans-serif; font-size:9px; font-weight:700; letter-spacing:.10em; text-transform:uppercase; color:var(--gris3); min-width:160px; flex-shrink:0; padding-top:2px; }
.abm-campo-valor { font-family:"DM Mono",monospace; font-size:12px; color:var(--gris1); flex:1; }
.abm-campo input[type="text"],
.abm-campo input[type="date"],
.abm-campo input[type="number"],
.abm-campo textarea,
.abm-campo select { font-family:"DM Mono",monospace; font-size:12px; padding:5px 9px; border:1.5px solid var(--borde); border-radius:6px; background:var(--fondo); color:var(--gris1); outline:none; transition:border-color .18s; min-width:280px; max-width:600px; box-sizing:border-box; }
.abm-campo input:focus, .abm-campo textarea:focus, .abm-campo select:focus { border-color:var(--oro); }
.abm-campo input[readonly], .abm-campo textarea[readonly] { background:#ede8e0; color:var(--gris3); cursor:not-allowed; }
.abm-campo select { min-width:280px; }
.abm-panel-footer { display:flex; align-items:center; justify-content:flex-end; gap:10px; padding:12px 20px; border-top:1px solid var(--fondo); background:#faf7f2; }

.abm-btn-accion { font-family:"DM Mono",monospace; font-size:11px; padding:6px 16px; background:var(--gris1); color:var(--oro); border:1px solid var(--oro); border-radius:6px; cursor:pointer; letter-spacing:.05em; transition:background .18s; }
.abm-btn-accion:hover { background:var(--gris2); }
.abm-btn-accion.danger { background:transparent; color:#ef4444; border-color:#ef4444; }
.abm-btn-accion.danger:hover { background:rgba(239,68,68,0.08); }
.abm-btn-cancelar { font-family:"DM Mono",monospace; font-size:11px; color:var(--gris3); text-decoration:none; padding:6px 12px; border-radius:6px; transition:all .15s; }
.abm-cancelar { font-family:"DM Mono",monospace; font-size:11px; color:var(--gris3); text-decoration:none; padding:6px 12px; border-radius:6px; transition:all .15s; margin-left:auto; }
.abm-btn-cancelar:hover, .abm-cancelar:hover { background:var(--fondo); color:var(--gris1); }
.abm-seccion-titulo { font-family:"Syne",sans-serif; font-size:8px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:#fff; background:var(--gris1); padding:6px 14px; margin-bottom:8px; border-radius:4px; }

.abm-vacio { text-align:center; padding:48px 0; font-family:"DM Mono",monospace; font-size:12px; color:var(--gris3); }
.abm-vacio-sym { font-family:"Syne",sans-serif; font-size:2.5rem; color:var(--borde); margin-bottom:10px; line-height:1; }
.abm-vacio p { margin:0 0 16px; }
.abm-print-header { display:none; font-family:"Syne",sans-serif; font-size:14px; font-weight:700; color:var(--gris1); margin-bottom:10px; padding-bottom:6px; border-bottom:2px solid var(--gris1); }
.abm-print-header span { color:var(--oro); }
.abm-print-fecha { font-family:"DM Mono",monospace; font-size:9px; color:var(--gris3); margin-top:2px; }

@media print {
    .abm-filtros, .abm-panel, .abm-acc, .abm-toolbar, .abm-btn-print, .abm-vacio { display:none !important; }
    .abm-tabla-wrap { box-shadow:none !important; border:1px solid #ccc !important; border-radius:0 !important; overflow:visible !important; }
    .abm-tabla { font-size:10px; }
    .abm-tabla thead th { font-size:8px; padding:5px 6px; background:var(--gris1)!important; color:var(--oro)!important; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
    .abm-tabla tbody td { padding:3px 6px; }
    .abm-print-header { display:block !important; }
}

/* ===============================================================
   REPORTES - clases compartidas (rp-, bs-, imp-, vig-)
=============================================================== */

.rp-toolbar { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; flex-wrap:wrap; gap:8px; }
.rp-toolbar-titulo, .rp-titulo { font-family:"Syne",sans-serif; font-size:1rem; font-weight:700; color:var(--gris1); letter-spacing:.04em; }
.rp-toolbar-titulo span, .rp-titulo span { color:var(--oro); }
.rp-btn-print { display:inline-flex; align-items:center; gap:6px; font-family:"DM Mono",monospace; font-size:10px; font-weight:700; letter-spacing:.07em; text-transform:uppercase; padding:6px 14px; background:var(--gris1); color:var(--oro); border:1.5px solid var(--oro); border-radius:6px; cursor:pointer; transition:background .15s,color .15s; }
.rp-btn-print:hover { background:var(--oro); color:#fff; }

.rp-filtros { background:#fff; border:1.5px solid var(--borde); border-radius:10px; padding:16px 20px; margin-bottom:18px; }
.rp-filtros-fila { display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-bottom:10px; }
.rp-filtros-fila:last-child { margin-bottom:0; }
.rp-label { font-family:"Syne",sans-serif; font-size:9px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--gris3); min-width:160px; flex-shrink:0; }
.rp-filtros select, .rp-select { font-family:"DM Mono",monospace; font-size:12px; padding:5px 10px; border:1.5px solid var(--borde); border-radius:6px; background:var(--fondo); color:var(--gris1); outline:none; transition:border-color .18s; flex:1; min-width:200px; }
.rp-filtros select:focus, .rp-select:focus { border-color:var(--oro); }
.rp-filtros input[type="date"],
.rp-filtros input[type="text"] { font-family:"DM Mono",monospace; font-size:12px; padding:5px 10px; border:1.5px solid var(--borde); border-radius:6px; background:var(--fondo); color:var(--gris1); outline:none; transition:border-color .18s; }
.rp-filtros input:focus { border-color:var(--oro); }
.rp-check-grupo { display:flex; align-items:center; gap:14px; flex-wrap:wrap; font-family:"DM Mono",monospace; font-size:12px; color:var(--gris2); }
.rp-check-grupo label { display:flex; align-items:center; gap:5px; cursor:pointer; }
.rp-check-grupo input[type="checkbox"] { accent-color:var(--oro); width:14px; height:14px; cursor:pointer; }
.rp-btn-mostrar { font-family:"DM Mono",monospace; font-size:11px; padding:7px 20px; background:var(--gris1); color:var(--oro); border:1px solid var(--oro); border-radius:6px; cursor:pointer; letter-spacing:.05em; transition:background .18s; }
.rp-btn-mostrar:hover { background:var(--gris2); }
.rp-separador { height:1px; background:var(--borde); margin:10px 0; }

.rp-tabla-wrap { background:#fff; border:1.5px solid var(--borde); border-radius:8px; overflow:hidden; overflow-x:auto; margin-bottom:6px; box-shadow:0 2px 8px rgba(0,0,0,0.05); }
.rp-tabla, .imp-tabla { width:100%; border-collapse:collapse; font-family:"DM Mono",monospace; font-size:11px; }
.rp-tabla thead th, .imp-tabla thead th { background:var(--gris1); color:var(--oro); font-family:"Syne",sans-serif; font-size:9px; font-weight:700; letter-spacing:.10em; text-transform:uppercase; padding:7px 10px; border-bottom:2px solid var(--oro); text-align:left; white-space:nowrap; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.rp-tabla tbody tr, .imp-tabla tbody tr { border-bottom:1px solid var(--fondo); transition:background .15s; }
.rp-tabla tbody tr:hover, .imp-tabla tbody tr:hover { background:rgba(184,150,74,0.06); }
.rp-tabla tbody tr:nth-child(even), .imp-tabla tbody tr:nth-child(even) { background:#faf7f2; }
.rp-tabla tbody td, .imp-tabla tbody td { padding:5px 10px; color:var(--gris2); vertical-align:middle; white-space:nowrap; }
.rp-tabla .fila-total td { background:var(--gris1)!important; color:var(--oro)!important; font-weight:700; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.rp-tabla tfoot td { background:var(--gris1); color:var(--oro); font-family:"Syne",sans-serif; font-size:10px; font-weight:700; padding:10px 14px; border-top:2px solid var(--oro); -webkit-print-color-adjust:exact; print-color-adjust:exact; }

.imp-wrap { max-width:960px; margin:0 auto; padding:8px 0 48px; }
.imp-titulo-pag { font-family:"Syne",sans-serif; font-size:1.2rem; font-weight:700; color:var(--gris1); letter-spacing:.05em; margin-bottom:4px; }
.imp-titulo-pag span { color:var(--oro); }
.imp-subtitulo { font-family:"DM Mono",monospace; font-size:10px; color:var(--gris3); letter-spacing:.06em; margin-bottom:20px; padding-bottom:14px; border-bottom:1px solid var(--borde); }
.imp-filtros { display:flex; align-items:center; gap:10px; background:#fff; border:1.5px solid var(--borde); border-radius:10px; padding:12px 16px; margin-bottom:20px; flex-wrap:wrap; }
.imp-filtros label { font-family:"DM Mono",monospace; font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--gris3); display:flex; flex-direction:column; gap:4px; }
.imp-filtros input[type="text"] { font-family:"DM Mono",monospace; font-size:12px; padding:5px 10px; border:1.5px solid var(--borde); border-radius:6px; background:var(--fondo); color:var(--gris1); outline:none; min-width:180px; }
.imp-filtros input[type="text"]:focus { border-color:var(--oro); }
.imp-btn { font-family:"DM Mono",monospace; font-size:11px; padding:7px 18px; background:var(--gris1); color:var(--oro); border:1px solid var(--oro); border-radius:6px; cursor:pointer; margin-top:auto; }
.imp-btn-pdf { font-family:"DM Mono",monospace; font-size:11px; padding:7px 18px; background:transparent; color:var(--oro); border:1px solid var(--oro); border-radius:6px; cursor:pointer; margin-top:auto; margin-left:6px; }
.imp-tabla-wrap { background:#fff; border:1.5px solid var(--borde); border-radius:10px; overflow:hidden; box-shadow:0 2px 8px rgba(0,0,0,0.05); }
.imp-tabla tbody td.agrupador { font-family:"Syne",sans-serif; font-size:10px; font-weight:700; color:var(--oro); white-space:nowrap; }
.imp-tabla tbody td.descripcion { font-weight:600; color:var(--gris1); }
.imp-tabla tbody td.dato { color:#6b6456; font-size:10px; }
.imp-vacio { text-align:center; padding:48px; font-family:"DM Mono",monospace; font-size:12px; color:var(--gris3); font-style:italic; }

/*  VIGILANCIA  */
.vig-inicio { max-width:860px; margin:0 auto; padding:8px 0 48px; }
.vig-inicio-titulo { font-family:"Syne",sans-serif; font-size:1.1rem; font-weight:700; color:var(--gris1); letter-spacing:.05em; margin-bottom:4px; }
.vig-inicio-titulo span { color:var(--oro); }
.vig-inicio-subtitulo { font-family:"DM Mono",monospace; font-size:10px; color:var(--gris3); letter-spacing:.06em; margin-bottom:20px; padding-bottom:12px; border-bottom:1px solid var(--borde); }
.vig-menu { width:100%; border-collapse:collapse; font-family:"Syne",sans-serif; font-size:13px; background:#fff; border:1.5px solid var(--borde); border-radius:8px; overflow:hidden; }
.vig-menu th { background:var(--gris1); color:var(--oro); font-family:"DM Mono",monospace; font-size:10px; letter-spacing:.08em; text-transform:uppercase; padding:10px 14px; text-align:left; border-bottom:2px solid var(--oro); }
.vig-menu td { padding:9px 14px; border-bottom:1px solid var(--borde); vertical-align:middle; color:var(--gris1); }
.vig-menu tr:last-child td { border-bottom:none; }
.vig-menu tr:hover td { background:#faf7f2; }
.vig-menu a { display:flex; align-items:center; gap:8px; color:var(--gris1); text-decoration:none; font-weight:600; }
.vig-menu a:hover { color:var(--oro); }
.vig-num { font-family:"DM Mono",monospace; font-size:9px; color:var(--gris3); letter-spacing:.06em; width:28px; text-align:right; }
.vig-sin-acceso { font-family:"DM Mono",monospace; font-size:11px; color:var(--gris3); font-style:italic; padding:24px 0; text-align:center; }
.vig-sin-usuario { font-family:"DM Mono",monospace; font-size:11px; color:var(--gris3); font-style:italic; text-align:center; padding:40px 0; }
.vig-usr-selector { display:flex; align-items:center; gap:16px; background:#fff; border:1.5px solid var(--borde); border-radius:10px; padding:16px 20px; margin-bottom:24px; }
.vig-usr-selector label { font-family:"DM Mono",monospace; font-size:9px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--gris3); }
.vig-usr-selector select { font-family:"DM Mono",monospace; font-size:13px; padding:8px 14px; border:1.5px solid var(--borde); border-radius:6px; background:var(--fondo); color:var(--gris1); outline:none; min-width:260px; }
.vig-usr-selector select:focus { border-color:var(--oro); }
.vig-btn { font-family:"DM Mono",monospace; font-size:11px; padding:8px 20px; background:var(--gris1); color:var(--oro); border:1px solid var(--oro); border-radius:6px; cursor:pointer; }
.vig-btn-guardar { background:var(--oro); color:var(--gris1); font-weight:700; }
.vig-btn-guardar:hover { background:var(--oro-light); }
.vig-msg-ok  { font-family:"DM Mono",monospace; font-size:11px; color:#16a34a; margin-bottom:16px; padding:10px 14px; background:rgba(22,163,74,0.08); border:1px solid rgba(22,163,74,0.2); border-radius:6px; }
.vig-msg-err { font-family:"DM Mono",monospace; font-size:11px; color:#dc2626; margin-bottom:16px; padding:10px 14px; background:rgba(220,38,38,0.08); border:1px solid rgba(220,38,38,0.2); border-radius:6px; }
.vig-tabla { width:100%; border-collapse:collapse; background:#fff; border:1.5px solid var(--borde); border-radius:8px; overflow:hidden; margin-bottom:20px; }
.vig-tabla th { background:var(--gris1); color:var(--oro); font-family:"DM Mono",monospace; font-size:10px; letter-spacing:.08em; text-transform:uppercase; padding:10px 14px; text-align:left; border-bottom:2px solid var(--oro); }
.vig-tabla th.vig-th-check { text-align:center; width:80px; }
.vig-tabla td { padding:8px 14px; border-bottom:1px solid var(--borde); vertical-align:middle; }
.vig-tabla tr:last-child td { border-bottom:none; }
.vig-tabla tr:hover td { background:#faf7f2; }
.vig-archivo { font-family:"DM Mono",monospace; font-size:11px; color:var(--gris3); }
.vig-archivo-nombre { font-family:"Syne",sans-serif; font-size:12px; font-weight:600; color:var(--gris1); }
.vig-td-check { text-align:center; }
.vig-td-check input[type="checkbox"] { width:16px; height:16px; accent-color:var(--oro); cursor:pointer; }
.vig-seccion-head td { font-family:"DM Mono",monospace; font-size:8px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:rgba(26,24,20,0.50); padding:8px 14px !important; background:var(--fondo); border-bottom:1px solid var(--borde); }

/*  UTILIDADES  */
.num { text-align:right!important; font-variant-numeric:tabular-nums; }
.color-azul { color:#1d4ed8; }
.color-rojo  { color:#ef4444; }

/*  PRINT GLOBAL  */
.rp-print-header, .abm-print-header, .imp-print-header { display:none; }
@media print {
    .cl-sidebar, .cabecera, .cl-sidebar-foot,
    .rp-toolbar, .rp-filtros, .imp-filtros,
    .abm-toolbar, .abm-filtros,
    .contenedor-filtros-tablas { display:none !important; }
    .cl-layout { display:block !important; margin-left:0 !important; }
    .cl-main { padding:10px !important; }
    body { background:#fff !important; }
    .rp-tabla-wrap, .imp-tabla-wrap { box-shadow:none !important; border-radius:0 !important; overflow:visible !important; }
    .rp-tabla thead th, .imp-tabla thead th { background:var(--gris1)!important; color:var(--oro)!important; -webkit-print-color-adjust:exact; print-color-adjust:exact; font-size:8px; padding:5px 6px; }
    .rp-print-header, .abm-print-header, .imp-print-header { display:block !important; }
    .contenedor-tablas { max-height:none !important; overflow:visible !important; }
    @page { margin:10mm; size:A4 landscape; }
}

/*  ALIAS de iconos de accion (usados sin prefijo abm-)  */
.ver  { display:inline-flex; align-items:center; justify-content:center; width:26px; height:26px; border-radius:6px; color:var(--gris3); text-decoration:none; transition:all .15s; border:1px solid transparent; vertical-align:middle; }
.add  { display:inline-flex; align-items:center; justify-content:center; width:26px; height:26px; border-radius:6px; color:var(--gris3); text-decoration:none; transition:all .15s; border:1px solid transparent; vertical-align:middle; }
.edit { display:inline-flex; align-items:center; justify-content:center; width:26px; height:26px; border-radius:6px; color:var(--gris3); text-decoration:none; transition:all .15s; border:1px solid transparent; vertical-align:middle; }
.del  { display:inline-flex; align-items:center; justify-content:center; width:26px; height:26px; border-radius:6px; color:var(--gris3); text-decoration:none; transition:all .15s; border:1px solid transparent; vertical-align:middle; }
.ver:hover  { color:#3b82f6; border-color:#3b82f6; background:rgba(59,130,246,0.06); }
.add:hover  { color:#22c55e; border-color:#22c55e; background:rgba(34,197,94,0.06); }
.edit:hover { color:var(--oro); border-color:var(--oro); background:var(--oro-dim); }
.del:hover  { color:#ef4444; border-color:#ef4444; background:rgba(239,68,68,0.06); }

/*  ABM extras (diario)  */
.abm-btn { font-family:"DM Mono",monospace; font-size:11px; padding:6px 16px; background:var(--gris1); color:var(--oro); border:1px solid var(--oro); border-radius:6px; cursor:pointer; letter-spacing:.05em; transition:background .18s; }
.abm-btn:hover { background:var(--gris2); }
.abm-btn.danger { background:transparent; color:#ef4444; border-color:#ef4444; }
.abm-btn.danger:hover { background:rgba(239,68,68,0.08); }
.abm-sec { grid-column:1/-1; font-family:"Syne",sans-serif; font-size:9px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; padding:6px 10px; border-radius:4px; color:#fff; margin:10px 0 6px; background:var(--gris1); }
.abm-subtotal td { background:var(--fondo)!important; font-weight:700; border-top:1px solid var(--borde); font-size:11px; color:var(--gris1); }

/*  VU (vigilancia usuarios)  */
.vu-titulo { font-family:"Syne",sans-serif; font-size:1.1rem; font-weight:700; color:var(--gris1); letter-spacing:.05em; margin-bottom:4px; }
.vu-titulo span { color:var(--oro); }
.vu-subtitulo { font-family:"DM Mono",monospace; font-size:10px; color:var(--gris3); letter-spacing:.06em; margin-bottom:20px; padding-bottom:12px; border-bottom:1px solid var(--borde); }
.vu-activo { color:#4aaa6a; font-weight:600; }
.vu-admin  { color:var(--oro); font-weight:700; }
.btn-nuevo { display:inline-flex; align-items:center; gap:6px; margin-bottom:16px; padding:7px 16px; background:var(--oro-dim); color:var(--oro); border:1px solid rgba(184,150,74,0.3); border-radius:6px; text-decoration:none; font-family:"DM Mono",monospace; font-size:11px; transition:background .15s; }
.btn-nuevo:hover { background:rgba(184,150,74,0.18); }

/*  VIG extras  */
.vig-seccion-head td { font-family:"DM Mono",monospace; font-size:8px; font-weight:700; letter-spacing:.22em; text-transform:uppercase; color:rgba(26,24,20,0.50); padding:8px 14px !important; background:var(--fondo); border-bottom:1px solid var(--borde); }

/*  MIG (migracion)  */
.mig-wrap { max-width:820px; margin:0 auto; padding:8px 0 48px; }
.mig-titulo-pag { font-family:"Syne",sans-serif; font-size:1.2rem; font-weight:700; color:var(--gris1); letter-spacing:.05em; margin-bottom:4px; }
.mig-titulo-pag span { color:var(--oro); }
.mig-subtitulo { font-family:"DM Mono",monospace; font-size:10px; color:var(--gris3); letter-spacing:.06em; margin-bottom:24px; padding-bottom:14px; border-bottom:1px solid var(--borde); }
.mig-card { background:#fff; border:1.5px solid var(--borde); border-radius:10px; overflow:hidden; margin-bottom:16px; box-shadow:0 2px 8px rgba(0,0,0,0.04); }
.mig-card-head { background:var(--gris1); border-bottom:2px solid var(--oro); padding:10px 16px; }
.mig-card-titulo { font-family:"Syne",sans-serif; font-size:10px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--oro); }
.mig-card-body { padding:20px 24px; }
.mig-nota { background:#fdf9f3; border-left:3px solid var(--oro); border-radius:0 6px 6px 0; padding:10px 14px; font-family:"DM Mono",monospace; font-size:11px; color:#6b6456; margin-bottom:20px; line-height:1.6; }
.mig-centros { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.mig-centro { font-family:"DM Mono",monospace; font-size:11px; background:var(--fondo); border:1px solid var(--borde); border-radius:5px; padding:4px 10px; color:var(--gris2); white-space:nowrap; }
.mig-filtros { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.mig-filtros label { font-family:"DM Mono",monospace; font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--gris3); display:flex; flex-direction:column; gap:4px; }
.mig-filtros select { font-family:"DM Mono",monospace; font-size:12px; padding:6px 10px; border:1.5px solid var(--borde); border-radius:6px; background:var(--fondo); color:var(--gris1); outline:none; min-width:130px; }
.mig-filtros select:focus { border-color:var(--oro); }
.mig-btn { font-family:"DM Mono",monospace; font-size:11px; padding:7px 18px; background:var(--gris1); color:var(--oro); border:1px solid var(--oro); border-radius:6px; cursor:pointer; margin-top:2px; transition:background .15s; }
.mig-btn:hover { background:var(--gris2); }
.mig-log { background:var(--gris1); border-radius:8px; padding:16px 20px; margin-top:16px; font-family:"DM Mono",monospace; font-size:11px; color:var(--oro); line-height:1.8; max-height:400px; overflow-y:auto; }
.mig-log-linea { color:var(--oro-light); border-bottom:1px solid rgba(184,150,74,0.1); padding:3px 0; }
.mig-log-linea:last-child { border-bottom:none; }
.mig-ok { background:#f0fdf4; border:1.5px solid #86efac; border-radius:8px; padding:12px 16px; font-family:"DM Mono",monospace; font-size:12px; color:#166534; margin-top:16px; display:flex; align-items:center; gap:10px; }

/*  INFO (datos automaticos)  */
.info-wrap { max-width:820px; margin:0 auto; padding:8px 0 48px; }
.info-titulo-pag { font-family:"Syne",sans-serif; font-size:1.2rem; font-weight:700; color:var(--gris1); letter-spacing:.05em; margin-bottom:4px; }
.info-titulo-pag span { color:var(--oro); }
.info-subtitulo { font-family:"DM Mono",monospace; font-size:10px; color:var(--gris3); letter-spacing:.06em; margin-bottom:24px; padding-bottom:14px; border-bottom:1px solid var(--borde); }
.info-card { background:#fff; border:1.5px solid var(--borde); border-radius:10px; overflow:hidden; margin-bottom:16px; box-shadow:0 2px 8px rgba(0,0,0,0.04); }
.info-card-head { background:var(--gris1); border-bottom:2px solid var(--oro); padding:10px 16px; }
.info-card-titulo { font-family:"Syne",sans-serif; font-size:10px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--oro); }
.info-card-body { padding:16px 20px; font-family:"DM Mono",monospace; font-size:12px; color:#4a4540; line-height:1.7; }
.info-campos { display:flex; flex-wrap:wrap; gap:6px; margin-top:8px; }
.info-campo { font-family:"DM Mono",monospace; font-size:11px; background:var(--fondo); border:1px solid var(--borde); border-radius:5px; padding:4px 10px; color:var(--gris2); white-space:nowrap; }
.info-nota { background:#fdf9f3; border-left:3px solid var(--oro); border-radius:0 6px 6px 0; padding:10px 14px; font-family:"DM Mono",monospace; font-size:11px; color:#6b6456; margin-bottom:12px; line-height:1.6; }
.info-ejemplo { font-family:"DM Mono",monospace; font-size:11px; color:var(--gris3); background:var(--fondo); border-radius:5px; padding:8px 12px; margin-top:8px; }
.abm-subtotal { background:var(--fondo); font-weight:700; border-top:1px solid var(--borde); }
.vig-seccion-head { background:var(--fondo); border-bottom:1px solid var(--borde); }

/* ===============================================================
   GRFICOS DE TENDENCIAS (graf-*)
=============================================================== */
.graf-wrap { max-width:960px; margin:0 auto; padding:8px 0 32px; }
.graf-titulo { font-family:"Syne",sans-serif; font-size:1.2rem; font-weight:700; color:var(--gris1); letter-spacing:.05em; margin-bottom:4px; }
.graf-titulo span { color:var(--oro); }
.graf-subtitulo { font-family:"DM Mono",monospace; font-size:10px; color:var(--gris3); letter-spacing:.06em; margin-bottom:20px; padding-bottom:14px; border-bottom:1px solid var(--borde); }
.graf-filtros { display:flex; flex-wrap:wrap; align-items:center; gap:12px; background:#fff; border:1.5px solid var(--borde); border-radius:10px; padding:14px 18px; margin-bottom:24px; }
.graf-filtros label { font-family:"DM Mono",monospace; font-size:10px; font-weight:500; letter-spacing:.10em; text-transform:uppercase; color:var(--gris3); display:flex; flex-direction:column; gap:4px; }
.graf-filtros select { font-family:"DM Mono",monospace; font-size:12px; padding:5px 10px; border:1.5px solid var(--borde); border-radius:6px; background:var(--fondo); color:var(--gris1); outline:none; transition:border-color .18s; min-width:120px; }
.graf-filtros select:focus { border-color:var(--oro); }
.graf-check-wrap { display:flex; align-items:center; gap:7px; font-family:"DM Mono",monospace; font-size:11px; color:#6b6456; cursor:pointer; user-select:none; padding:6px 12px; border:1.5px solid var(--borde); border-radius:6px; transition:all .18s; }
.graf-check-wrap:has(input:checked) { background:var(--oro-dim); border-color:var(--oro); color:var(--oro); }
.graf-check-wrap input[type="checkbox"] { width:14px; height:14px; accent-color:var(--oro); cursor:pointer; }
.graf-btn { font-family:"DM Mono",monospace; font-size:11px; padding:7px 18px; background:var(--gris1); color:var(--oro); border:1px solid var(--oro); border-radius:6px; cursor:pointer; letter-spacing:.06em; transition:background .18s; margin-left:auto; }
.graf-btn:hover { background:var(--gris2); }
.graf-panel { background:#fff; border:1.5px solid var(--borde); border-radius:12px; overflow:hidden; box-shadow:0 2px 12px rgba(0,0,0,0.05); }
.graf-panel-head { display:flex; align-items:center; justify-content:space-between; padding:14px 20px; background:var(--gris1); border-bottom:2px solid var(--oro); }
.graf-panel-nombre { font-family:"Syne",sans-serif; font-size:12px; font-weight:700; color:#fff; letter-spacing:.08em; text-transform:uppercase; }
.graf-panel-rango { font-family:"DM Mono",monospace; font-size:10px; color:rgba(184,150,74,0.7); letter-spacing:.04em; }
.graf-canvas-wrap { padding:24px 20px 16px; position:relative; height:420px; }
.graf-vacio { text-align:center; padding:60px 0; font-family:"DM Mono",monospace; font-size:12px; color:var(--gris3); font-style:italic; }
.graf-leyenda-wrap { display:flex; justify-content:space-between; gap:16px; padding:16px 20px 20px; border-top:1px solid var(--borde); }
.graf-leyenda-col { display:flex; flex-direction:column; gap:6px; flex:1; }
.graf-leyenda-titulo { font-family:"Syne",sans-serif; font-size:9px; font-weight:700; letter-spacing:.10em; text-transform:uppercase; color:var(--gris3); margin-bottom:4px; }
.graf-leyenda-item { display:flex; align-items:center; gap:8px; cursor:pointer; padding:4px 8px; border-radius:5px; transition:background .15s; user-select:none; }
.graf-leyenda-item:hover { background:var(--oro-dim); }
.graf-leyenda-item.hidden { opacity:0.35; }
.graf-leyenda-dot { width:12px; height:12px; border-radius:3px; flex-shrink:0; }
.graf-leyenda-label { font-family:"DM Mono",monospace; font-size:10px; color:#4a4540; }

/* ===============================================================
   CORTES CONTRACTUALES (ct-*)
=============================================================== */
.ct-wrap { max-width:100%; margin:0 auto; padding:8px 0 48px; }
.ct-titulo-pag { font-family:"Syne",sans-serif; font-size:1.2rem; font-weight:700; color:var(--gris1); letter-spacing:.05em; margin-bottom:4px; }
.ct-titulo-pag span { color:var(--oro); }
.ct-subtitulo { font-family:"DM Mono",monospace; font-size:10px; color:var(--gris3); letter-spacing:.06em; margin-bottom:20px; padding-bottom:14px; border-bottom:1px solid var(--borde); }
.ct-filtros { display:flex; align-items:center; gap:10px; background:#fff; border:1.5px solid var(--borde); border-radius:10px; padding:12px 16px; margin-bottom:20px; flex-wrap:wrap; }
.ct-filtros label { font-family:"DM Mono",monospace; font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--gris3); display:flex; flex-direction:column; gap:4px; }
.ct-filtros select { font-family:"DM Mono",monospace; font-size:12px; padding:5px 10px; border:1.5px solid var(--borde); border-radius:6px; background:var(--fondo); color:var(--gris1); outline:none; transition:border-color .18s; min-width:120px; }
.ct-filtros select:focus { border-color:var(--oro); }
.ct-btn { font-family:"DM Mono",monospace; font-size:11px; padding:7px 18px; background:var(--gris1); color:var(--oro); border:1px solid var(--oro); border-radius:6px; cursor:pointer; letter-spacing:.06em; transition:background .18s; margin-left:auto; }
.ct-btn:hover { background:var(--gris2); }
.ct-tabla-wrap { background:#fff; border:1.5px solid var(--borde); border-radius:10px; overflow-x:auto; overflow-y:auto; max-height:680px; box-shadow:0 2px 8px rgba(0,0,0,0.05); }
.ct-tabla { width:100%; border-collapse:collapse; font-family:"DM Mono",monospace; font-size:11px; }
.ct-tabla thead th { background:var(--gris1); color:var(--oro); font-family:"Syne",sans-serif; font-size:9px; font-weight:700; letter-spacing:.10em; text-transform:uppercase; padding:10px 12px; border-bottom:2px solid var(--oro); text-align:left; white-space:nowrap; position:sticky; top:0; z-index:10; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.ct-tabla thead th.centro { text-align:center; }
.ct-tabla tbody tr { border-bottom:1px solid var(--borde); transition:background .15s; }
.ct-tabla tbody tr:hover { background:rgba(184,150,74,0.06); }
.ct-tabla tbody tr.ct-ciclo-inicio td { border-top:2px solid var(--oro); }
.ct-tabla tbody td { padding:7px 12px; color:var(--gris2); vertical-align:middle; }
.ct-tabla tbody td.ct-ciclo { font-family:"Syne",sans-serif; font-size:10px; font-weight:700; color:var(--gris1); white-space:nowrap; }
.ct-tabla tbody td.ct-linea { color:#6b6456; }
.ct-tabla tbody td.ct-contrato { text-align:center; font-variant-numeric:tabular-nums; white-space:nowrap; }
.ct-tabla tbody td.ct-pendiente { text-align:center; color:var(--gris4); font-style:italic; font-size:10px; }
.ct-vacio { text-align:center; padding:48px; font-family:"DM Mono",monospace; font-size:12px; color:var(--gris3); font-style:italic; }
.ct-print-wrap { display:none; }
.ct-print-tabla { width:100%; border-collapse:collapse; font-family:"DM Mono",monospace; font-size:11px; }
.ct-print-tabla thead th { background:var(--gris1); color:var(--oro); font-family:"Syne",sans-serif; font-size:9px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:8px 10px; border-bottom:2px solid var(--oro); text-align:center; white-space:nowrap; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.ct-print-tabla thead th.ct-ph-centro { text-align:left; }
.ct-print-tabla thead tr.ct-ph-ciclo th { background:var(--gris2); color:var(--oro-light); font-size:8px; padding:4px 10px; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.ct-print-tabla tbody tr { border-bottom:1px solid var(--borde); }
.ct-print-tabla tbody td { padding:5px 10px; color:var(--gris2); vertical-align:middle; text-align:center; white-space:nowrap; }
.ct-print-tabla tbody td.ct-ph-centro { text-align:left; font-family:"Syne",sans-serif; font-size:9px; font-weight:700; color:var(--gris1); }
.ct-print-tabla tbody tr:nth-child(even) { background:#faf7f2; }
.centro { text-align:center; }

/* ===============================================================
   CORTES ESTADSTICOS (est-*)
=============================================================== */
.est-wrap { max-width:100%; margin:0 auto; padding:8px 0 48px; }
.est-titulo-pag { font-family:"Syne",sans-serif; font-size:1.2rem; font-weight:700; color:var(--gris1); letter-spacing:.05em; margin-bottom:4px; }
.est-titulo-pag span { color:var(--oro); }
.est-subtitulo { font-family:"DM Mono",monospace; font-size:10px; color:var(--gris3); letter-spacing:.06em; margin-bottom:20px; padding-bottom:14px; border-bottom:1px solid var(--borde); }
.est-filtros { display:flex; align-items:center; gap:10px; background:#fff; border:1.5px solid var(--borde); border-radius:10px; padding:12px 16px; margin-bottom:24px; flex-wrap:wrap; }
.est-filtros label { font-family:"DM Mono",monospace; font-size:9px; letter-spacing:.12em; text-transform:uppercase; color:var(--gris3); display:flex; flex-direction:column; gap:4px; }
.est-filtros select { font-family:"DM Mono",monospace; font-size:12px; padding:5px 10px; border:1.5px solid var(--borde); border-radius:6px; background:var(--fondo); color:var(--gris1); outline:none; transition:border-color .18s; min-width:120px; }
.est-filtros select:focus { border-color:var(--oro); }
.est-btn { font-family:"DM Mono",monospace; font-size:11px; padding:7px 18px; background:var(--gris1); color:var(--oro); border:1px solid var(--oro); border-radius:6px; cursor:pointer; letter-spacing:.06em; transition:background .18s; margin-left:auto; }
.est-btn:hover { background:var(--gris2); }
.est-grid { display:flex; gap:20px; overflow-x:auto; padding-bottom:8px; }
.est-ciclo-col { min-width:280px; flex-shrink:0; }
.est-ciclo-head { background:var(--gris1); border-radius:10px 10px 0 0; border-bottom:2px solid var(--oro); padding:12px 16px; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.est-ciclo-titulo { font-family:"Syne",sans-serif; font-size:13px; font-weight:700; color:#fff; letter-spacing:.08em; }
.est-seccion { border:1.5px solid var(--borde); border-top:none; background:#fff; }
.est-seccion:last-child { border-radius:0 0 10px 10px; overflow:hidden; }
.est-sec-head { padding:6px 14px; font-family:"Syne",sans-serif; font-size:9px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:#fff; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.est-sec-fila { display:flex; justify-content:space-between; align-items:center; padding:6px 14px; border-bottom:1px solid var(--fondo); }
.est-sec-fila:last-child { border-bottom:none; }
.est-sec-label { font-family:"DM Mono",monospace; font-size:10px; color:#6b6456; }
.est-sec-valor { font-family:"DM Mono",monospace; font-size:11px; color:var(--gris1); font-variant-numeric:tabular-nums; font-weight:600; }
.est-sec-valor.neg, .neg { color:#ef4444; }
.est-vacio { text-align:center; padding:60px; font-family:"DM Mono",monospace; font-size:12px; color:var(--gris3); font-style:italic; background:#fff; border:1.5px solid var(--borde); border-radius:10px; }
.est-print-wrap { display:none; }
.est-print-tabla { width:100%; border-collapse:collapse; font-family:"DM Mono",monospace; font-size:9px; }
.est-print-tabla thead tr.est-ph-ciclos th { background:var(--gris1); color:var(--oro); font-family:"Syne",sans-serif; font-size:8px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; padding:6px 8px; border-bottom:2px solid var(--oro); text-align:center; white-space:nowrap; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.est-print-tabla thead tr.est-ph-ciclos th.est-ph-label { text-align:left; }
.est-print-tabla tbody tr { border-bottom:1px solid var(--borde); }
.est-print-tabla tbody tr:nth-child(even) { background:#faf7f2; }
.est-print-tabla tbody td { padding:3px 8px; color:var(--gris2); vertical-align:middle; text-align:right; white-space:nowrap; font-size:8px; }
.est-print-tabla tbody td.est-ph-sec { font-family:"Syne",sans-serif; font-size:7px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:#fff; padding:4px 8px; text-align:left; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.est-print-tabla tbody td.est-ph-label { text-align:left; color:#6b6456; padding-left:16px; }

/* ===============================================================
   CONCEPTOS / TRMINOS (conc-*)
=============================================================== */
.conc-wrap { max-width:800px; margin:0 auto; padding:24px 0 40px; }
.conc-titulo { font-family:"Syne",sans-serif; font-size:1.2rem; font-weight:700; color:var(--gris1); letter-spacing:.05em; margin-bottom:4px; }
.conc-titulo span { color:var(--oro); }
.conc-subtitulo { font-family:"DM Mono",monospace; font-size:10px; color:var(--gris3); letter-spacing:.06em; margin-bottom:24px; padding-bottom:14px; border-bottom:1px solid var(--borde); }
.conc-lista { display:flex; flex-direction:column; gap:12px; }
.conc-item { background:#fff; border:1.5px solid var(--borde); border-left:4px solid var(--oro); border-radius:8px; padding:14px 20px; display:flex; gap:16px; align-items:flex-start; }
.conc-term { font-family:"Syne",sans-serif; font-size:11px; font-weight:700; letter-spacing:.10em; text-transform:uppercase; color:var(--oro); min-width:160px; flex-shrink:0; padding-top:1px; }
.conc-def { font-family:"DM Mono",monospace; font-size:12px; color:var(--gris2); line-height:1.65; }

/* ===============================================================
   CUADROS BALANCES / FUENTES Y USOS (bal-*, fu-*)
=============================================================== */
.bal-wrap, .fu-wrap { max-width:100%; margin:0 auto; padding:8px 0 48px; }
.bal-titulo-pag, .fu-titulo-pag { font-family:"Syne",sans-serif; font-size:1.2rem; font-weight:700; color:var(--gris1); letter-spacing:.05em; margin-bottom:4px; }
.bal-titulo-pag span, .fu-titulo-pag span { color:var(--oro); }
.bal-subtitulo, .fu-subtitulo { font-family:"DM Mono",monospace; font-size:10px; color:var(--gris3); letter-spacing:.06em; margin-bottom:20px; padding-bottom:14px; border-bottom:1px solid var(--borde); }
.bal-controles, .fu-controles { display:flex; align-items:center; gap:10px; background:#fff; border:1.5px solid var(--borde); border-radius:10px; padding:12px 16px; margin-bottom:20px; flex-wrap:wrap; }
.bal-select, .fu-select { font-family:"DM Mono",monospace; font-size:12px; padding:5px 10px; border:1.5px solid var(--borde); border-radius:6px; background:var(--fondo); color:var(--gris1); outline:none; transition:border-color .18s; min-width:130px; }
.bal-select:focus, .fu-select:focus { border-color:var(--oro); }
.bal-btn, .fu-btn { font-family:"DM Mono",monospace; font-size:11px; padding:7px 18px; background:var(--gris1); color:var(--oro); border:1px solid var(--oro); border-radius:6px; cursor:pointer; letter-spacing:.06em; transition:background .18s; }
.bal-btn:hover, .fu-btn:hover { background:var(--gris2); }
.bal-moneda, .fu-moneda { font-family:"DM Mono",monospace; font-size:10px; color:var(--gris3); }
.bal-rango-links, .fu-rango-links { display:flex; gap:6px; flex-wrap:wrap; }
.bal-tabla-wrap, .fu-tabla-wrap { background:#fff; border:1.5px solid var(--borde); border-radius:10px; overflow-x:auto; box-shadow:0 2px 8px rgba(0,0,0,0.05); margin-bottom:16px; }
.bal-tabla, .fu-tabla { width:100%; border-collapse:collapse; font-family:"DM Mono",monospace; font-size:11px; }
.bal-seccion, .fu-seccion { background:var(--gris1); color:var(--oro); font-family:"Syne",sans-serif; font-size:9px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; padding:7px 14px; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.bal-badge, .fu-badge { display:inline-block; font-family:"DM Mono",monospace; font-size:9px; padding:2px 8px; border-radius:100px; letter-spacing:.06em; }
.bal-balanceo, .fu-balanceo { font-family:"DM Mono",monospace; font-size:10px; color:var(--gris3); text-align:right; padding:8px 14px; border-top:1px solid var(--borde); }
.bal-salto-pagina { page-break-before:always; }
.bal-concepto-head, .fu-concepto-head { display:flex; align-items:center; gap:8px; padding:10px 14px; background:var(--fondo); border-bottom:1px solid var(--borde); cursor:pointer; }
.bal-concepto-titulo, .fu-concepto-titulo { font-family:"Syne",sans-serif; font-size:10px; font-weight:700; color:var(--gris1); letter-spacing:.06em; flex:1; }
.bal-concepto-link, .fu-concepto-link { font-family:"DM Mono",monospace; font-size:10px; color:var(--oro); text-decoration:none; }
.bal-concepto-texto, .fu-concepto-texto { font-family:"DM Mono",monospace; font-size:11px; color:var(--gris2); padding:10px 14px 14px; line-height:1.65; display:none; }
.fu-totales { background:var(--gris2); color:#fff; font-family:"Syne",sans-serif; font-size:9px; font-weight:700; padding:7px 14px; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.fuente { color:#3b82f6; font-variant-numeric:tabular-nums; }
.uso    { color:#ef4444; font-variant-numeric:tabular-nums; }
.pct    { color:var(--gris3); font-size:10px; }

/* ===============================================================
   CUADROS KPI (kpi-*, en-linea)
=============================================================== */
.kpi-concepto-head { display:flex; align-items:center; gap:8px; padding:10px 14px; background:var(--fondo); border-bottom:1px solid var(--borde); cursor:pointer; }
.kpi-concepto-titulo { font-family:"Syne",sans-serif; font-size:10px; font-weight:700; color:var(--gris1); letter-spacing:.06em; flex:1; }
.kpi-concepto-link { font-family:"DM Mono",monospace; font-size:10px; color:var(--oro); text-decoration:none; }
.kpi-concepto-texto { font-family:"DM Mono",monospace; font-size:11px; color:var(--gris2); padding:10px 14px 14px; line-height:1.65; display:none; }
.kpi-btn-grafico { font-family:"DM Mono",monospace; font-size:10px; padding:4px 10px; background:transparent; color:var(--oro); border:1px solid var(--oro); border-radius:5px; cursor:pointer; transition:background .15s; }
.kpi-btn-grafico:hover { background:var(--oro-dim); }
.en-linea { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }

/* ===============================================================
   PRINT GLOBAL REPORTES
=============================================================== */
@media print {
    .graf-filtros, .ct-filtros, .est-filtros, .bal-controles, .fu-controles { display:none !important; }
    .graf-wrap, .ct-wrap, .est-wrap, .bal-wrap, .fu-wrap, .conc-wrap { padding:0 !important; max-width:100% !important; }
    .graf-panel, .bal-tabla-wrap, .fu-tabla-wrap { box-shadow:none !important; border:1px solid #ccc !important; }
    .ct-tabla-wrap { overflow:visible !important; max-height:none !important; }
    .ct-print-wrap { display:block !important; }
    .ct-tabla-wrap { display:none !important; }
    .est-grid { display:none !important; }
    .est-print-wrap { display:block !important; }
}

/* dic-* ya definidas arriba via activos.css base - alias para conceptos empresariales */
/* ct-ph-ciclo y est-ph-ciclos - filas de cabecera de tablas de impresion */
.ct-ph-ciclo th { background:var(--gris2); color:var(--oro-light); font-size:8px; padding:4px 10px; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.ct-ph-ciclo { background:var(--gris2); }
.est-ph-ciclos { background:var(--gris1); }
.est-ph-ciclos th { background:var(--gris1); color:var(--oro); -webkit-print-color-adjust:exact; print-color-adjust:exact; }

/*  CONCEPTOS FUNDAMENTALES MARKETING (fund-*)  */
.fund-wrap { max-width:960px; margin:0 auto; padding:8px 0 48px; }
.fund-titulo-pag { font-family:"Syne",sans-serif; font-size:1.2rem; font-weight:700; color:var(--gris1); letter-spacing:.05em; margin-bottom:4px; }
.fund-titulo-pag span { color:var(--oro); }
.fund-subtitulo { font-family:"DM Mono",monospace; font-size:10px; color:var(--gris3); letter-spacing:.06em; margin-bottom:24px; padding-bottom:14px; border-bottom:1px solid var(--borde); }
.fund-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px; }
.fund-card { background:#fff; border:1.5px solid var(--borde); border-radius:10px; overflow:hidden; }
.fund-card-head { background:var(--gris1); padding:12px 16px; display:flex; align-items:center; gap:10px; border-bottom:2px solid var(--oro); -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.fund-card-num { font-family:"Syne",sans-serif; font-size:10px; font-weight:700; color:var(--oro); letter-spacing:.10em; flex-shrink:0; }
.fund-card-titulo { font-family:"Syne",sans-serif; font-size:11px; font-weight:700; color:#fff; letter-spacing:.06em; flex:1; }
.fund-card-svg { flex-shrink:0; color:var(--oro); }

/*  FILTROS CON DIVISOR (graf-filtros-div)  */
.graf-filtros-div { width:1px; height:36px; background:var(--borde); flex-shrink:0; }

/* ===============================================================
   SUSTENTABILIDAD - CONCEPTOS (sust-*)
=============================================================== */
.sust-wrap { max-width:860px; margin:0 auto; padding:8px 0 48px; }
.sust-titulo-pag { font-family:"Syne",sans-serif; font-size:1.2rem; font-weight:700; color:var(--gris1); letter-spacing:.05em; margin-bottom:4px; }
.sust-titulo-pag span { color:var(--oro); }
.sust-subtitulo { font-family:"DM Mono",monospace; font-size:10px; color:var(--gris3); letter-spacing:.06em; margin-bottom:28px; padding-bottom:14px; border-bottom:1px solid var(--borde); }
.sust-bloque { background:#fff; border:1.5px solid var(--borde); border-radius:12px; overflow:hidden; box-shadow:0 2px 12px rgba(0,0,0,0.05); margin-bottom:24px; }
.sust-bloque-head { padding:14px 20px; background:var(--gris1); border-bottom:2px solid var(--oro); display:flex; align-items:center; gap:12px; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.sust-bloque-badge { font-family:"DM Mono",monospace; font-size:9px; color:rgba(184,150,74,0.6); letter-spacing:.10em; text-transform:uppercase; flex-shrink:0; }
.sust-bloque-titulo { font-family:"Syne",sans-serif; font-size:13px; font-weight:700; color:#fff; letter-spacing:.07em; text-transform:uppercase; }
.sust-bloque-titulo span { color:var(--oro); }
.sust-bloque-body { padding:20px 24px; }
.sust-bloque-body p { font-family:"DM Mono",monospace; font-size:12px; color:#4a4540; line-height:1.7; margin:0 0 10px; }
.sust-bloque-body p:last-child { margin-bottom:0; }
.sust-bloque-body strong { font-family:"Syne",sans-serif; color:var(--oro); }
.sust-bloque-svg { width:100%; background:var(--fondo); padding:28px 24px; border-top:1px solid var(--borde); box-sizing:border-box; display:flex; justify-content:center; }
.sust-bloque-svg svg { width:100%; max-width:680px; height:auto; display:block; }
.sust-reglas { background:#fff; border:1.5px solid var(--borde); border-radius:12px; overflow:hidden; box-shadow:0 2px 12px rgba(0,0,0,0.05); }
.sust-reglas-head { padding:14px 20px; background:var(--gris1); border-bottom:2px solid var(--oro); -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.sust-reglas-titulo { font-family:"Syne",sans-serif; font-size:12px; font-weight:700; color:#fff; letter-spacing:.07em; text-transform:uppercase; }
.sust-reglas-fuente { font-family:"DM Mono",monospace; font-size:9px; color:rgba(184,150,74,0.7); letter-spacing:.05em; margin-top:3px; }
.sust-reglas-intro { padding:16px 24px 0; font-family:"DM Mono",monospace; font-size:12px; color:#4a4540; line-height:1.6; }
.sust-reglas-intro strong { font-family:"Syne",sans-serif; color:var(--oro); letter-spacing:.04em; }
.sust-reglas-lista { list-style:none; margin:0; padding:16px 24px 20px; counter-reset:reglas; }
.sust-reglas-lista li { counter-increment:reglas; display:flex; align-items:baseline; gap:14px; padding:9px 0; border-bottom:1px solid var(--fondo); font-family:"DM Mono",monospace; font-size:12px; color:var(--gris2); line-height:1.5; }
.sust-reglas-lista li:last-child { border-bottom:none; }
.sust-reglas-lista li::before { content:counter(reglas,decimal-leading-zero); font-family:"Syne",sans-serif; font-size:11px; font-weight:700; color:var(--oro); flex-shrink:0; min-width:24px; }

/* ===============================================================
   SUSTENTABILIDAD - INVERSORES (inv-*)
=============================================================== */
.inv-wrap { max-width:900px; margin:0 auto; padding:8px 0 48px; }
.inv-titulo-pag { font-family:"Syne",sans-serif; font-size:1.2rem; font-weight:700; color:var(--gris1); letter-spacing:.05em; margin-bottom:4px; }
.inv-titulo-pag span { color:var(--oro); }
.inv-subtitulo { font-family:"DM Mono",monospace; font-size:10px; color:var(--gris3); letter-spacing:.06em; margin-bottom:28px; padding-bottom:14px; border-bottom:1px solid var(--borde); }
.inv-bloque { background:#fff; border:1.5px solid var(--borde); border-radius:12px; overflow:hidden; box-shadow:0 2px 12px rgba(0,0,0,0.05); margin-bottom:20px; }
.inv-bloque-head { padding:12px 20px; background:var(--gris1); border-bottom:2px solid var(--oro); display:flex; align-items:center; gap:10px; -webkit-print-color-adjust:exact; print-color-adjust:exact; }
.inv-bloque-badge { font-family:"DM Mono",monospace; font-size:9px; color:rgba(184,150,74,0.6); letter-spacing:.10em; text-transform:uppercase; flex-shrink:0; }
.inv-bloque-titulo { font-family:"Syne",sans-serif; font-size:12px; font-weight:700; color:#fff; letter-spacing:.07em; text-transform:uppercase; }
.inv-bloque-titulo span { color:var(--oro); }
.inv-lista { list-style:none; margin:0; padding:14px 20px; counter-reset:items; }
.inv-lista li { counter-increment:items; display:flex; align-items:baseline; gap:12px; padding:8px 0; border-bottom:1px solid var(--fondo); font-family:"DM Mono",monospace; font-size:12px; color:var(--gris2); line-height:1.5; }
.inv-lista li:last-child { border-bottom:none; }
.inv-lista li::before { content:counter(items,decimal-leading-zero); font-family:"Syne",sans-serif; font-size:10px; font-weight:700; color:var(--oro); flex-shrink:0; min-width:22px; }
.inv-tabla { width:100%; border-collapse:collapse; }
.inv-tabla tr { border-bottom:1px solid var(--fondo); }
.inv-tabla tr:last-child { border-bottom:none; }
.inv-tabla tr:hover { background:rgba(184,150,74,0.04); }
.inv-tabla td { padding:9px 14px; font-family:"DM Mono",monospace; font-size:11px; color:var(--gris2); vertical-align:top; }
.inv-tabla td:first-child { white-space:nowrap; width:52px; }
.inv-sigla { display:inline-block; font-family:"Syne",sans-serif; font-size:11px; font-weight:700; color:var(--oro); letter-spacing:.04em; min-width:52px; }
.inv-nombre { font-family:"Syne",sans-serif; font-size:10px; font-weight:600; color:#6b6456; letter-spacing:.04em; display:block; margin-bottom:2px; }
.inv-formula { font-size:10px; color:var(--gris3); font-style:italic; }

/* ===============================================================
   SUBMEN DE MDULO (cl-submenu-*)
=============================================================== */
.cl-submenu { display:flex; flex-direction:column; gap:2px; margin-bottom:28px; }
.cl-submenu-seccion { font-family:"DM Mono",monospace; font-size:8px; font-weight:700; letter-spacing:.20em; text-transform:uppercase; color:var(--gris3); padding:14px 0 6px; border-bottom:1px solid var(--borde); margin-bottom:4px; }
.cl-submenu-item { display:flex; align-items:center; gap:10px; padding:7px 10px; border-radius:6px; text-decoration:none; font-family:"DM Mono",monospace; font-size:11px; color:var(--gris2); transition:all .15s; }
.cl-submenu-item:hover { background:var(--oro-dim); color:var(--gris1); }
.cl-submenu-item.activo { background:var(--oro-dim); color:var(--oro); font-weight:600; }
.cl-submenu-dot { width:5px; height:5px; border-radius:50%; background:var(--gris4); flex-shrink:0; transition:background .15s; }
.cl-submenu-item:hover .cl-submenu-dot { background:var(--oro); }
.cl-submenu-item.activo .cl-submenu-dot { background:var(--oro); }

/* ===============================================================
   INDEX - PANEL DE MDULO (cl-panel-*, cl-bienvenida)
=============================================================== */
.cl-panel { max-width:860px; margin:0 auto; padding:8px 0 48px; }
.cl-panel-head { display:flex; align-items:center; gap:16px; padding:20px 24px; background:var(--gris1); border-radius:12px 12px 0 0; border-bottom:2px solid var(--oro); }
.cl-panel-ini { font-family:"Syne",sans-serif; font-size:1.4rem; font-weight:800; color:var(--oro); letter-spacing:.12em; min-width:40px; }
.cl-panel-head-texto { display:flex; flex-direction:column; gap:3px; }
.cl-panel-head-nombre { font-family:"Syne",sans-serif; font-size:1rem; font-weight:700; color:#fff; letter-spacing:.06em; text-transform:uppercase; }
.cl-panel-head-desc { font-family:"DM Mono",monospace; font-size:10px; color:rgba(184,150,74,0.60); letter-spacing:.08em; }
.cl-panel-body { background:#fff; border:1.5px solid var(--borde); border-top:none; border-radius:0 0 12px 12px; padding:24px 28px; box-shadow:0 4px 16px rgba(0,0,0,0.05); }

/* Submenu dentro del panel */
.cl-submenu { display:flex; flex-direction:column; gap:2px; }
.cl-submenu-seccion { font-family:"DM Mono",monospace; font-size:8px; font-weight:700; letter-spacing:.20em; text-transform:uppercase; color:var(--gris3); padding:14px 0 6px; border-bottom:1px solid var(--borde); margin-bottom:4px; }
.cl-submenu-seccion:first-child { padding-top:0; }
.cl-submenu-item { display:flex; align-items:center; gap:10px; padding:7px 10px; border-radius:6px; text-decoration:none; font-family:"DM Mono",monospace; font-size:12px; color:var(--gris2); transition:all .15s; }
.cl-submenu-item:hover { background:var(--oro-dim); color:var(--gris1); }
.cl-submenu-item.activo { background:var(--oro-dim); color:var(--oro); font-weight:600; }
.cl-submenu-dot { width:5px; height:5px; border-radius:50%; background:var(--gris4); flex-shrink:0; transition:background .15s; }
.cl-submenu-item:hover .cl-submenu-dot,
.cl-submenu-item.activo .cl-submenu-dot { background:var(--oro); }

/* Bienvenida sin modulo */
.cl-bienvenida { display:flex; flex-direction:column; align-items:center; justify-content:center; min-height:340px; text-align:center; color:var(--gris3); }
.cl-bienvenida-sym { font-size:2rem; color:var(--oro); margin-bottom:16px; opacity:.5; }
.cl-bienvenida h2 { font-family:"Syne",sans-serif; font-size:1.1rem; font-weight:700; color:var(--gris1); letter-spacing:.06em; margin:0 0 8px; }
.cl-bienvenida p { font-family:"DM Mono",monospace; font-size:11px; color:var(--gris3); margin:0; }
