:root{--azul: #1e5aa8;--azul-osc: #16447e;--gris: #f4f6f9;--borde: #dfe3e8;--texto: #1f2933;--rojo: #c0392b;--verde: #1e8449}*{box-sizing:border-box}body{margin:0;font-family:system-ui,Segoe UI,Roboto,sans-serif;color:var(--texto);background:var(--gris)}a{color:var(--azul);text-decoration:none}.centro{display:flex;align-items:center;justify-content:center;min-height:100vh}.app{display:flex;min-height:100vh}.topbar{display:none;align-items:center;gap:12px;background:var(--azul-osc);color:#fff;padding:10px 16px;position:sticky;top:0;z-index:40}.topbar-logo{font-size:18px;font-weight:600}.hamburguesa{background:none;border:none;color:#fff;font-size:22px;line-height:1;padding:2px 6px}.overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:41}.sidebar{width:230px;background:var(--azul-osc);color:#fff;display:flex;flex-direction:column;padding:18px 0}.sidebar .logo{margin:0 20px 18px;font-size:22px}.sidebar nav{display:flex;flex-direction:column;flex:1}.sidebar nav .nav-grupo{margin:14px 20px 4px;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:#8ea6c9}.sidebar nav a{color:#d9e2f1;padding:11px 20px;font-size:15px}.sidebar nav a:hover{background:#ffffff14}.sidebar nav a.active{background:#ffffff29;color:#fff;border-left:4px solid #fff;padding-left:16px}.usuario{margin:12px 20px 0;padding-top:12px;border-top:1px solid rgba(255,255,255,.2);font-size:14px}.usuario .rol{display:inline-block;margin-top:2px;font-size:11px;background:#fff3;padding:1px 7px;border-radius:10px}.contenido{flex:1;padding:26px 32px;overflow:auto}.page-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}.page-head h2{margin:0;font-size:22px}button{font:inherit;cursor:pointer}.btn{background:var(--azul);color:#fff;border:none;border-radius:6px;padding:8px 14px;font-size:14px}.btn:hover{background:var(--azul-osc)}.btn.secundario{background:#fff;color:var(--azul);border:1px solid var(--borde)}.btn.peligro{background:var(--rojo)}.btn-link{background:none;border:none;color:#fff;text-decoration:underline;padding:4px 0;font-size:13px}.btn-sm{padding:4px 9px;font-size:13px}table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #00000012}th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--borde);font-size:14px}th{background:#eef2f7;font-weight:600}tr:last-child td{border-bottom:none}td.acciones{display:flex;gap:6px}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px}.card{background:#fff;border-radius:8px;padding:16px;box-shadow:0 1px 3px #00000012}.card h3{margin:0 0 6px;font-size:14px;color:#5a6b7b;font-weight:600}.card .valor{font-size:26px;font-weight:700;color:var(--azul-osc)}.panel{background:#fff;border-radius:8px;padding:18px;box-shadow:0 1px 3px #00000012;margin-bottom:22px}.panel h3{margin:0 0 12px;font-size:16px}.panel-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}.panel-head h3{margin:0}.panel-buscar{min-width:220px;flex:0 1 320px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}label{display:flex;flex-direction:column;font-size:13px;gap:4px;color:#46566a}input,select,textarea{font:inherit;padding:8px 10px;border:1px solid var(--borde);border-radius:6px;background:#fff}input:focus,select:focus,textarea:focus{outline:2px solid var(--azul);border-color:var(--azul)}.filtros{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:16px}.filtros-toggle{display:none}.paginacion{display:flex;gap:10px;align-items:center;margin-top:14px;font-size:14px}.error{background:#fdecea;color:var(--rojo);padding:9px 12px;border-radius:6px;margin-bottom:12px;font-size:14px}.vacio{color:#6b7a8d;padding:18px;text-align:center}.modal-fondo{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:#fff;border-radius:10px;padding:22px;width:min(560px,92vw);max-height:90vh;overflow:auto}.modal.ancho{width:min(720px,94vw)}.modal h3{margin:0 0 16px}.modal-acciones{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}.modal-intro{margin:0 0 16px;color:#6b7a8d;font-size:13px}.doc-item{border:1px solid var(--borde);border-radius:8px;padding:14px 16px;margin-bottom:12px;transition:border-color .15s,background .15s}.doc-item.activo{border-color:var(--azul);background:#f6f9fd}.doc-item-head{flex-direction:row;align-items:center;gap:10px;font-size:15px;font-weight:600;color:var(--texto);cursor:pointer}.doc-item-head input[type=checkbox]{width:18px;height:18px;flex:none;cursor:pointer}.doc-item-campos{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px;padding-left:28px}@media (max-width: 560px){.doc-item-campos{grid-template-columns:1fr;padding-left:0}}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}th.sortable:hover{background:#e3e9f1}th.sortable .flecha{color:var(--azul);margin-left:4px;font-size:12px}.busqueda{position:relative;flex:1;min-width:200px;max-width:360px}.busqueda input{width:100%}.badge{display:inline-block;padding:2px 9px;border-radius:11px;font-size:12px;font-weight:600;white-space:nowrap}.badge.ok{background:#e4f5ea;color:var(--verde)}.badge.warn{background:#fff4e0;color:#a96b00}.badge.danger{background:#fdecea;color:var(--rojo)}.badge.muted{background:#eceff3;color:#6b7a8d}.doc-chips{display:flex;flex-wrap:wrap;gap:5px}.opcional{color:#9aa7b4;font-weight:400;font-size:11px}.contacto{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.contacto-num{font-variant-numeric:tabular-nums}.btn-wa{background:#25d366;color:#fff;text-decoration:none}.btn-wa:hover{background:#1da851}a.btn{display:inline-flex;align-items:center;text-decoration:none}.vacio-inline{color:#9aa7b4}.check-inline{flex-direction:row;align-items:center;gap:8px;font-size:14px}.check-inline input[type=checkbox]{width:18px;height:18px;flex:none}.hint-inline{grid-column:1 / -1;background:#fff4e0;color:#a96b00;border-radius:6px;padding:8px 12px;font-size:13px}.alerta-panel{border-left:4px solid #a96b00}.alerta-panel.vencidos{border-left-color:var(--rojo)}.login-box{background:#fff;padding:32px;border-radius:12px;box-shadow:0 4px 24px #0000001f;width:min(380px,92vw)}.login-box h1{margin:0 0 4px;color:var(--azul-osc)}.login-box p{margin:0 0 20px;color:#6b7a8d;font-size:14px}.login-box label{margin-bottom:14px}.login-box .btn{width:100%;margin-top:4px}.hint{margin-top:16px;font-size:12px;color:#6b7a8d;text-align:center}@media (max-width: 820px){.app{flex-direction:column}.topbar{display:flex}.sidebar{position:fixed;top:0;left:0;bottom:0;width:240px;transform:translate(-100%);transition:transform .25s ease;z-index:42}.sidebar.abierto{transform:translate(0)}.overlay{display:block}.contenido{padding:16px}.page-head{flex-direction:column;align-items:stretch;gap:10px}.page-head .btn{width:100%}table{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}.tabla-cards{display:block;overflow:visible;white-space:normal;background:transparent;box-shadow:none;border-radius:0}.tabla-cards thead{display:none}.tabla-cards tbody,.tabla-cards tr,.tabla-cards td{display:block;width:100%}.tabla-cards tr{background:#fff;border-radius:8px;box-shadow:0 1px 3px #00000014;margin-bottom:12px;padding:6px 2px}.tabla-cards td{display:flex;justify-content:space-between;gap:14px;text-align:right;white-space:normal;border-bottom:1px solid #f0f2f5;padding:8px 14px}.tabla-cards tr td:last-child{border-bottom:none}.tabla-cards td:before{content:attr(data-label);font-weight:600;color:#5a6b7b;text-align:left;flex:none}.tabla-cards td.acciones{justify-content:flex-start;flex-wrap:wrap}.tabla-cards td.acciones:before{content:""}.tabla-cards td.vacio{justify-content:center}.tabla-cards td.vacio:before{content:""}.filtros{flex-direction:column;align-items:stretch}.filtros label,.filtros .busqueda{max-width:none;width:100%}.form-grid{grid-template-columns:1fr}.filtros-toggle{display:inline-flex;width:100%;justify-content:center;margin-bottom:12px}.filtros.colapsado-movil{display:none}.modal{width:95vw;padding:16px}.cards{grid-template-columns:1fr 1fr}}@media (max-width: 460px){.cards{grid-template-columns:1fr}td.acciones{flex-direction:column}}
