:root{--principal: #1e3a5f;--principal-claro: #2c5282;--acento: #2b6cb0;--fondo: #f1f4f8;--fondo-suave: #f8fafc;--tarjeta: #ffffff;--campo-fondo: #ffffff;--texto: #1a202c;--texto-suave: #718096;--borde: #e2e8f0;--verde: #2f855a;--verde-fondo: #f0fff4;--verde-borde: #c6f6d5;--rojo: #c53030;--rojo-fondo: #fff5f5;--rojo-borde: #fed7d7;--naranja: #c05621;--naranja-fondo: #fffaf0;--azul-estado: #2b6cb0;--azul-fondo: #ebf8ff;--morado: #6b46c1;--morado-fondo: #faf5ff;--verde-estado: #2f855a;--verde-estado-fondo: #f0fff4;--radio: 10px;--radio-sm: 6px;--sombra: 0 1px 2px rgba(0,0,0,.06), 0 1px 3px rgba(0,0,0,.04);--sombra-md: 0 4px 6px rgba(0,0,0,.05), 0 2px 4px rgba(0,0,0,.04)}html[data-tema=oscuro]{color-scheme:dark;--principal: #16273d;--principal-claro: #1e3a5f;--acento: #4a90d9;--fondo: #0f1620;--fondo-suave: #141d2a;--tarjeta: #1a2330;--campo-fondo: #0f1620;--texto: #e8edf4;--texto-suave: #94a3b8;--borde: #2d3a4d;--verde: #4caf7f;--verde-fondo: #16271f;--verde-borde: #2a4636;--rojo: #f06868;--rojo-fondo: #2a1818;--rojo-borde: #4a2828;--naranja: #e09140;--naranja-fondo: #2a2014;--azul-estado: #4a90d9;--azul-fondo: #14202e;--morado: #a78bda;--morado-fondo: #221c30}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--fondo);color:var(--texto);line-height:1.5;font-size:15px}.contenedor{max-width:1080px;margin:0 auto;padding:0 20px 48px}.barra-superior{background:var(--principal);color:#fff;padding:16px 0;margin-bottom:28px}.barra-superior .contenedor{padding-bottom:0;display:flex;align-items:center;flex-wrap:wrap;gap:16px}.marca{font-size:18px;font-weight:600;letter-spacing:.2px}.marca small{display:block;font-size:12px;font-weight:400;opacity:.8;letter-spacing:0}.nav-tabs{display:flex;gap:4px;align-items:center;flex:1 1 auto}.nav-tabs button{border:none;background:transparent;color:#ffffffd9;padding:8px 16px;border-radius:var(--radio-sm);cursor:pointer;font-size:14px;transition:all .15s}.nav-tabs button:hover{background:#ffffff1f;color:#fff}.nav-tabs button.activo{background:#ffffff2e;color:#fff;font-weight:500}.barra-acciones{display:flex;align-items:center;gap:6px;flex-shrink:0}.titulo-seccion{font-size:22px;font-weight:650;margin-bottom:4px}.subtitulo{color:var(--texto-suave);font-size:14px;margin-bottom:22px}.btn{border:none;border-radius:var(--radio-sm);padding:9px 16px;font-size:14px;cursor:pointer;transition:all .15s;font-weight:500;font-family:inherit;display:inline-flex;align-items:center;gap:6px}.btn-principal{background:var(--acento);color:#fff}.btn-principal:hover{background:var(--principal-claro)}.btn-secundario{background:var(--tarjeta);color:var(--texto);border:1px solid var(--borde)}.btn-secundario:hover{border-color:var(--acento);color:var(--acento)}.btn-verde{background:var(--verde);color:#fff}.btn-verde:hover{filter:brightness(.93)}.btn-rojo{background:var(--rojo);color:#fff}.btn-rojo:hover{filter:brightness(.93)}.btn-peligro{background:var(--tarjeta);color:var(--rojo);border:1px solid var(--rojo-borde)}.btn-peligro:hover{background:var(--rojo-fondo)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:6px 12px;font-size:13px}.filtros{display:flex;gap:8px;margin-bottom:20px;align-items:center;flex-wrap:wrap}.chip{border:1px solid var(--borde);background:var(--tarjeta);padding:7px 16px;border-radius:999px;cursor:pointer;font-size:13px;color:var(--texto);transition:all .15s;font-family:inherit}.chip:hover{border-color:var(--acento)}.chip.activo{background:var(--principal);color:#fff;border-color:var(--principal)}.tabla-proyectos{background:var(--tarjeta);border:1px solid var(--borde);border-radius:var(--radio);overflow:hidden;box-shadow:var(--sombra)}.encabezado-tabla,.fila-proyecto{display:grid;grid-template-columns:2.4fr 1.3fr 1.2fr 1fr auto;gap:16px;align-items:center;padding:14px 18px}.encabezado-tabla{background:var(--fondo-suave);border-bottom:1px solid var(--borde);font-size:12px;text-transform:uppercase;letter-spacing:.4px;color:var(--texto-suave);font-weight:600}.fila-proyecto{border-bottom:1px solid var(--borde);cursor:pointer;transition:background .12s}.fila-proyecto:last-child{border-bottom:none}.fila-proyecto:hover{background:var(--fondo-suave)}.proy-nombre{font-weight:600;display:flex;align-items:center;gap:9px}.proy-cliente{font-size:13px;color:var(--texto-suave);margin-top:1px}.proy-tipo{font-size:13px;color:var(--texto)}.proy-monto{font-weight:600}@media(max-width:760px){.encabezado-tabla{display:none}.fila-proyecto{grid-template-columns:1fr auto;gap:8px}.col-ocultable{display:none}}.luz{width:9px;height:9px;border-radius:50%;flex-shrink:0}.etiqueta{font-size:12px;padding:3px 11px;border-radius:999px;white-space:nowrap;font-weight:500;display:inline-block}.volver{background:var(--tarjeta);border:1px solid var(--borde);color:var(--texto-suave);cursor:pointer;font-size:14px;margin-bottom:16px;display:inline-flex;align-items:center;gap:6px;font-family:inherit;padding:8px 14px;border-radius:var(--radio-sm);transition:all .15s}.volver:hover{color:var(--texto);border-color:var(--acento)}.barra-busqueda-filtros{display:flex;gap:14px;align-items:center;flex-wrap:wrap;margin-bottom:18px}.barra-busqueda-filtros .buscador{margin-bottom:0;flex:1 1 240px}.filtros-estado{display:flex;gap:8px;flex-wrap:wrap}.filtro-estado{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--borde);background:var(--tarjeta);color:var(--texto);padding:7px 14px;border-radius:999px;cursor:pointer;font-size:13px;font-family:inherit;transition:all .15s}.filtro-estado:hover{border-color:var(--acento)}.filtro-estado.activo{border-color:var(--acento);background:var(--azul-fondo);color:var(--acento);font-weight:500}.buscador{position:relative;margin-bottom:18px;max-width:360px}.buscador input{padding-left:36px}.buscador .icono{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--texto-suave);pointer-events:none}.tema-selector{position:relative}.tema-disparador{border:none;background:#ffffff1a;color:#ffffffe6;width:38px;height:38px;border-radius:var(--radio-sm);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:20px;transition:all .15s}.tema-disparador:hover{background:#fff3;color:#fff}.tema-menu{position:absolute;right:0;top:calc(100% + 6px);z-index:60;background:var(--tarjeta);border:1px solid var(--borde);border-radius:var(--radio-sm);box-shadow:var(--sombra-md);padding:4px;min-width:150px;display:flex;flex-direction:column;gap:2px}.tema-menu button{border:none;background:transparent;color:var(--texto);padding:8px 10px;border-radius:5px;cursor:pointer;font-size:13px;font-family:inherit;display:inline-flex;align-items:center;gap:8px;text-align:left;transition:background .12s}.tema-menu button:hover{background:var(--fondo-suave);color:var(--texto)}.tema-menu button.activo{background:var(--azul-fondo);color:var(--acento);font-weight:500}.tema-menu button.activo:hover{color:var(--acento)}.tema-menu button i{width:16px;text-align:center}.cabecera-detalle{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:18px}.datos-generales{background:var(--tarjeta);border:1px solid var(--borde);border-radius:var(--radio);padding:18px 20px;box-shadow:var(--sombra);margin-bottom:20px}.grid-datos{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}.dato .etq{font-size:12px;color:var(--texto-suave);text-transform:uppercase;letter-spacing:.3px}.dato .val{font-size:15px;font-weight:600;margin-top:3px}.selector-estado{display:inline-flex;align-items:center;gap:8px;margin-top:14px;flex-wrap:wrap}.selector-estado label{font-size:13px;color:var(--texto-suave)}.financiero{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:20px}@media(max-width:820px){.financiero{grid-template-columns:1fr}}.seccion-fin{border-radius:var(--radio);border:1px solid var(--borde);overflow:hidden;box-shadow:var(--sombra);background:var(--tarjeta)}.seccion-fin .cabeza{padding:14px 18px;font-weight:600;font-size:15px;display:flex;align-items:center;gap:8px}.cabeza-verde{background:var(--verde-fondo);color:var(--verde);border-bottom:1px solid var(--verde-borde)}.cabeza-roja{background:var(--rojo-fondo);color:var(--rojo);border-bottom:1px solid var(--rojo-borde)}.cuerpo-fin{padding:14px 18px}.registro{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;padding:10px 0;border-bottom:1px solid var(--borde);font-size:14px}.registro:last-of-type{border-bottom:none}.registro .info{min-width:0}.registro .info .princ{font-weight:500}.registro .info .sec{font-size:12px;color:var(--texto-suave);margin-top:1px}.registro .monto-lado{display:flex;align-items:center;gap:10px;white-space:nowrap}.borrar{background:none;border:none;cursor:pointer;color:var(--texto-suave);font-size:15px;line-height:1;padding:2px}.borrar:hover{color:var(--rojo)}.editar{background:none;border:none;cursor:pointer;color:var(--texto-suave);font-size:16px;line-height:1;padding:4px;border-radius:var(--radio-sm);transition:all .15s}.editar:hover{color:var(--acento);background:var(--fondo-suave)}.editor-registro{display:grid;gap:8px;padding:12px;margin:8px 0;border:1px solid var(--acento);border-radius:var(--radio-sm);background:var(--fondo-suave)}.editor-registro .fila-campos{display:flex;gap:8px;flex-wrap:wrap}.editor-registro .fila-campos>*{flex:1;min-width:90px}.acciones-editor{display:flex;gap:8px;align-items:center}.form-registro{margin-top:14px;padding-top:14px;border-top:1px dashed var(--borde);display:grid;gap:8px}.form-registro .fila-campos{display:flex;gap:8px;flex-wrap:wrap}.form-registro .fila-campos>*{flex:1;min-width:90px}input,select,textarea{padding:9px 11px;border:1px solid var(--borde);border-radius:var(--radio-sm);font-size:14px;font-family:inherit;width:100%;background:var(--campo-fondo);color:var(--texto)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--acento);box-shadow:0 0 0 3px #2b6cb01f}.campo-error{border-color:var(--rojo)}.texto-error{color:var(--rojo);font-size:12.5px;margin-top:4px}.totales-fin{margin-top:14px;padding-top:14px;border-top:1px solid var(--borde)}.totales-fin .linea{display:flex;justify-content:space-between;font-size:14px;padding:3px 0}.totales-fin .grande{font-size:19px;font-weight:700}.saldo-caja{background:var(--azul-fondo);color:var(--texto);border:1px solid var(--borde);border-radius:var(--radio);padding:16px 20px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}.saldo-caja .etq{font-size:13px;color:var(--texto-suave)}.saldo-caja .monto{font-size:26px;font-weight:700;color:var(--principal)}html[data-tema=oscuro] .saldo-caja{background:var(--principal);color:#fff;border-color:transparent}html[data-tema=oscuro] .saldo-caja .etq{color:#ffffffd9}html[data-tema=oscuro] .saldo-caja .monto{color:#fff}.modal-fondo{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;padding:20px;z-index:50}.modal{background:var(--tarjeta);border-radius:var(--radio);padding:24px;width:100%;max-width:460px;max-height:90vh;overflow-y:auto;box-shadow:var(--sombra-md)}.modal h2{font-size:18px;margin-bottom:18px}.campo{margin-bottom:14px}.campo label{display:block;font-size:13px;color:var(--texto-suave);margin-bottom:6px}.modal-acciones{display:flex;gap:10px;margin-top:20px}.modal-acciones .btn{flex:1;justify-content:center}.tabla-scroll{max-height:380px;overflow-y:auto;border:1px solid var(--borde);border-radius:var(--radio);margin-bottom:22px;box-shadow:var(--sombra)}.tabla-scroll .tabla-datos{border:none;border-radius:0;box-shadow:none;margin-bottom:0}.tabla-scroll thead th{position:sticky;top:0;z-index:1}.tabla-scroll::-webkit-scrollbar{width:8px}.tabla-scroll::-webkit-scrollbar-thumb{background:var(--borde);border-radius:999px}.tabla-scroll{scrollbar-width:thin;scrollbar-color:var(--borde) transparent}.tabla-datos{width:100%;border-collapse:collapse;background:var(--tarjeta);border:1px solid var(--borde);border-radius:var(--radio);overflow:hidden;box-shadow:var(--sombra);margin-bottom:22px}.tabla-datos th{background:var(--fondo-suave);text-align:left;padding:11px 16px;font-size:12px;text-transform:uppercase;letter-spacing:.3px;color:var(--texto-suave);border-bottom:1px solid var(--borde)}.tabla-datos td{padding:11px 16px;border-bottom:1px solid var(--borde);font-size:14px}.tabla-datos tr:last-child td{border-bottom:none}.tabla-datos .num{text-align:right;font-variant-numeric:tabular-nums}.pos{color:var(--verde);font-weight:600}.neg{color:var(--rojo);font-weight:600}.grafico{background:var(--tarjeta);border:1px solid var(--borde);border-radius:var(--radio);padding:18px 20px;box-shadow:var(--sombra);margin-bottom:22px}.grafico h3{font-size:15px;margin-bottom:16px}.grafico-scroll{max-height:360px;overflow-y:auto;padding-right:6px}.barra-fila{display:grid;grid-template-columns:200px 1fr;gap:12px;align-items:center;margin:9px 0}.barra-fila .etiq{font-size:13px;line-height:1.25;word-break:break-word}.barra-pista{background:var(--fondo-suave);border-radius:var(--radio-sm);height:30px;overflow:hidden;position:relative}.barra-relleno{height:100%;border-radius:var(--radio-sm);display:flex;align-items:center;padding:0 10px;color:#fff;font-size:12px;font-weight:600;min-width:fit-content}.barra-fila.clicable{cursor:pointer;border-radius:var(--radio-sm);transition:opacity .15s}.barra-fila.clicable:hover{opacity:.85}.barra-fila.atenuada{opacity:.35}.enlace-limpiar{background:none;border:none;color:var(--acento);cursor:pointer;font:inherit;padding:0;text-decoration:underline}.grupo-cabecera{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:12px}.grafico-controles{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.buscador-mini{display:flex;align-items:center;gap:6px;background:var(--campo-fondo);border:1px solid var(--borde);border-radius:999px;padding:4px 12px}.buscador-mini .icono{color:var(--texto-suave);font-size:15px}.buscador-mini input{border:none;background:none;outline:none;color:var(--texto);font-size:13px;width:150px}.orden-mini{display:inline-flex;border:1px solid var(--borde);border-radius:999px;overflow:hidden}.orden-mini button{background:var(--campo-fondo);border:none;color:var(--texto-suave);cursor:pointer;font-size:12.5px;padding:5px 12px}.orden-mini button:first-child{border-right:1px solid var(--borde)}.orden-mini button.activo{background:var(--acento);color:#fff}.th-ordenable{cursor:pointer;-webkit-user-select:none;user-select:none}.th-ordenable:hover{color:var(--texto)}.metricas{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:22px}.metrica{background:var(--tarjeta);border:1px solid var(--borde);border-radius:var(--radio);padding:18px;box-shadow:var(--sombra)}.metrica .etq{font-size:13px;color:var(--texto-suave)}.metrica .val{font-size:24px;font-weight:700;margin-top:6px}.resumen-auto{background:var(--azul-fondo);border:1px solid var(--borde);border-radius:var(--radio);padding:18px 20px;margin-bottom:22px}.resumen-auto h3{font-size:15px;margin-bottom:10px;color:var(--acento)}.resumen-auto>ul{list-style:none}.resumen-auto>ul>li{font-size:14px;padding:4px 0 4px 20px;position:relative;color:var(--texto)}.resumen-auto>ul>li:before{content:"›";position:absolute;left:4px;color:var(--acento);font-weight:700}.enlace-desplegar{background:var(--azul-fondo);border:1px solid var(--borde);color:var(--acento);cursor:pointer;font-size:12px;font-weight:600;padding:2px 10px;border-radius:999px}.enlace-desplegar:hover{background:var(--acento);color:#fff}.sublista-perdida{list-style:disc;margin:6px 0 4px 30px}.sublista-perdida li{font-size:13.5px;padding:2px 0;color:var(--texto)}.analisis-grupo{font-size:15px;margin-bottom:12px}.lista-cancelados{max-height:220px;overflow-y:auto;border:1px solid var(--borde);border-radius:var(--radio);margin-bottom:22px;background:color-mix(in srgb,var(--acento) 4%,transparent)}.fila-cancelado{display:flex;justify-content:space-between;gap:12px;padding:8px 14px;font-size:13.5px;border-bottom:1px solid var(--borde)}.fila-cancelado:last-child{border-bottom:none}.fila-cancelado:nth-child(odd){background:color-mix(in srgb,var(--acento) 4%,transparent)}.fila-cancelado .nombre{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.fila-cancelado .num{font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap}.grafico-scroll::-webkit-scrollbar,.lista-cancelados::-webkit-scrollbar{width:8px}.grafico-scroll::-webkit-scrollbar-thumb,.lista-cancelados::-webkit-scrollbar-thumb{background:var(--borde);border-radius:999px}.grafico-scroll,.lista-cancelados{scrollbar-width:thin;scrollbar-color:var(--borde) transparent}.vacio{text-align:center;padding:48px 20px;color:var(--texto-suave);background:var(--tarjeta);border:1px dashed var(--borde);border-radius:var(--radio)}.bloque-final{background:var(--tarjeta);border:1px solid var(--borde);border-radius:var(--radio);padding:18px 20px;box-shadow:var(--sombra)}.acciones-detalle{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}.texto-ok{color:var(--verde);font-size:14px;margin:4px 0 8px}.login-fondo{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--fondo)}.login-caja{background:var(--tarjeta);border:1px solid var(--borde);border-radius:var(--radio);box-shadow:var(--sombra-md);padding:30px 28px;width:100%;max-width:380px}.login-marca{font-size:20px;font-weight:600;color:var(--texto);margin-bottom:22px}.login-marca small{display:block;font-size:12px;font-weight:400;color:var(--texto-suave);margin-top:2px}.login-caja h2{font-size:17px;margin-bottom:18px}.login-boton{width:100%;justify-content:center;margin-top:8px}.usuario-menu{position:relative}.usuario-disparador{border:none;background:transparent;cursor:pointer;padding:0}.usuario-avatar{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;font-size:15px;font-weight:600;background:#ffffff2e;color:#fff;transition:background .15s}.usuario-disparador:hover .usuario-avatar{background:#ffffff4d}.usuario-panel{position:absolute;right:0;top:calc(100% + 8px);z-index:60;min-width:200px;background:var(--tarjeta);border:1px solid var(--borde);border-radius:var(--radio-sm);box-shadow:var(--sombra-md);padding:6px;display:flex;flex-direction:column;gap:2px}.usuario-info{padding:8px 10px 10px;border-bottom:1px solid var(--borde);margin-bottom:4px}.usuario-nombre{font-weight:600;font-size:14px;color:var(--texto)}.usuario-rol{font-size:12px;color:var(--texto-suave);margin-top:1px}.usuario-panel button{border:none;background:transparent;color:var(--texto);padding:9px 10px;border-radius:5px;cursor:pointer;font-size:13px;font-family:inherit;display:inline-flex;align-items:center;gap:9px;text-align:left;transition:background .12s}.usuario-panel button:hover{background:var(--fondo-suave);color:var(--texto)}.usuario-panel button.salir,.usuario-panel button.salir:hover{color:var(--rojo)}.usuario-panel button i{width:16px;text-align:center}.etiqueta-yo{font-size:12px;color:var(--texto-suave);font-weight:400}@media(max-width:720px){.barra-superior{margin-bottom:20px}.barra-superior .contenedor{gap:10px}.marca{flex:1 1 auto;font-size:16px}.barra-acciones{order:1}.nav-tabs{order:2;flex-basis:100%;overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;padding-bottom:4px}.nav-tabs button{flex-shrink:0;white-space:nowrap;padding:8px 13px}.nav-tabs::-webkit-scrollbar{height:0}.contenedor{padding:0 14px 36px}.titulo-seccion{font-size:19px}.saldo-caja .monto{font-size:22px}.metrica .val{font-size:21px}.tabla-datos{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}.tabla-scroll .tabla-datos{display:table;white-space:normal}.tabla-scroll{overflow-x:auto}.barra-fila{grid-template-columns:96px 1fr;gap:8px}.modal{padding:18px}}@media(max-width:420px){body{font-size:14px}.titulo-seccion{font-size:18px}.acciones-detalle .btn,.modal-acciones .btn{font-size:13px}}
