:root{--azul-oscuro: #1b2670;--azul: #25317e;--azul-medio: #3c53b4;--azul-claro: #5b9bf0;--azul-suave: #eaf1fc;--fondo: #f4f6fb;--blanco: #ffffff;--texto: #1d2433;--texto-suave: #5b6478;--borde: #dde3f0;--verde: #1e9e6a;--naranja: #e8912d;--rojo: #d9483b;--radius: 14px;--sombra: 0 2px 10px rgba(27, 38, 112, .08)}*{box-sizing:border-box}html,body,#root{margin:0;padding:0;min-height:100vh}body{font-family:Poppins,system-ui,-apple-system,sans-serif;background:var(--fondo);color:var(--texto);font-size:14px}h1,h2,h3{color:var(--azul-oscuro);margin:0 0 .5rem}h1{font-size:1.35rem;font-weight:700}h2{font-size:1.1rem;font-weight:600}h3{font-size:.95rem;font-weight:600}a{color:var(--azul-medio);text-decoration:none}.layout{display:flex;min-height:100vh}.sidebar{width:240px;flex-shrink:0;background:linear-gradient(180deg,var(--azul-oscuro),var(--azul));color:#fff;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar .brand{padding:1.2rem 1rem;display:flex;align-items:center;gap:.6rem;border-bottom:1px solid rgba(255,255,255,.12)}.brand-logo{width:100%;max-width:190px;display:block;margin:0 auto}.alcaldia-box{padding:.8rem 1.2rem 0}.alcaldia-box img{width:100%;opacity:.9;display:block}.sidebar nav{flex:1;padding:.8rem .6rem;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.sidebar nav a{color:#ffffffd1;padding:.6rem .8rem;border-radius:10px;font-weight:500;display:flex;align-items:center;gap:.6rem;font-size:.85rem}.sidebar nav a.active,.sidebar nav a:hover{background:#ffffff24;color:#fff}.sidebar .user-box{padding:.9rem 1rem;border-top:1px solid rgba(255,255,255,.12);font-size:.78rem}.sidebar .user-box .name{font-weight:600}.sidebar .user-box .role{opacity:.7}.sidebar .user-box button{margin-top:.5rem;width:100%;background:#ffffff1f;color:#fff;border:none;padding:.45rem;border-radius:8px;cursor:pointer;font-family:inherit;font-size:.78rem}.sidebar .user-box button:hover{background:#ffffff38}.main{flex:1;padding:1.4rem 1.6rem;min-width:0}.menu-btn{display:none}@media(max-width:860px){.layout{flex-direction:column}.sidebar{position:fixed;z-index:50;left:0;top:0;height:100vh;transform:translate(-100%);transition:transform .25s ease;width:260px}.sidebar.open{transform:translate(0);box-shadow:0 0 40px #00000059}.main{padding:4.2rem .9rem 1.2rem}.menu-btn{display:flex;position:fixed;z-index:40;top:.7rem;left:.7rem;background:var(--azul);color:#fff;border:none;border-radius:10px;width:42px;height:42px;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;box-shadow:var(--sombra)}.backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:45}}.card{background:var(--blanco);border-radius:var(--radius);box-shadow:var(--sombra);padding:1.1rem 1.2rem;margin-bottom:1rem}.grid{display:grid;gap:1rem}.grid.cols-2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.grid.stats{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}.stat{background:var(--blanco);border-radius:var(--radius);box-shadow:var(--sombra);padding:1rem 1.1rem;border-left:4px solid var(--azul-claro)}.stat .label{font-size:.72rem;color:var(--texto-suave);text-transform:uppercase;letter-spacing:.4px}.stat .value{font-size:1.3rem;font-weight:700;color:var(--azul-oscuro);margin-top:.2rem}.stat.ok{border-left-color:var(--verde)}.stat.warn{border-left-color:var(--naranja)}.stat.bad{border-left-color:var(--rojo)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.82rem}th{text-align:left;color:var(--texto-suave);font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.4px;padding:.5rem .6rem;border-bottom:2px solid var(--borde);white-space:nowrap}td{padding:.55rem .6rem;border-bottom:1px solid var(--borde);vertical-align:top}tr:hover td{background:var(--azul-suave)}td.num,th.num{text-align:right;white-space:nowrap}.btn{display:inline-flex;align-items:center;gap:.4rem;background:var(--azul);color:#fff;border:none;border-radius:10px;padding:.55rem 1rem;font-family:inherit;font-size:.82rem;font-weight:600;cursor:pointer}.btn:hover{background:var(--azul-medio)}.btn.secondary{background:var(--azul-suave);color:var(--azul)}.btn.secondary:hover{background:#dbe7fa}.btn.danger{background:#fdecea;color:var(--rojo)}.btn.danger:hover{background:#f9d7d3}.btn.small{padding:.35rem .7rem;font-size:.74rem;border-radius:8px}.btn:disabled{opacity:.55;cursor:not-allowed}label.field{display:block;margin-bottom:.7rem;font-size:.78rem;font-weight:500;color:var(--texto-suave)}label.field span{display:block;margin-bottom:.25rem}input,select,textarea{width:100%;padding:.5rem .65rem;border:1px solid var(--borde);border-radius:9px;font-family:inherit;font-size:.84rem;color:var(--texto);background:#fff}input:focus,select:focus,textarea:focus{outline:2px solid var(--azul-claro);border-color:transparent}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.3rem .9rem}.badge{display:inline-block;padding:.18rem .6rem;border-radius:999px;font-size:.68rem;font-weight:600;white-space:nowrap}.badge.azul{background:var(--azul-suave);color:var(--azul)}.badge.verde{background:#e2f5ec;color:var(--verde)}.badge.naranja{background:#fdf1de;color:#b06d13}.badge.rojo{background:#fdecea;color:var(--rojo)}.badge.gris{background:#eef0f5;color:var(--texto-suave)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#11183a80;z-index:100;display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem;overflow-y:auto}.modal{background:#fff;border-radius:var(--radius);max-width:720px;width:100%;padding:1.3rem 1.4rem;box-shadow:0 20px 60px #00000040}.modal h2{margin-bottom:1rem}.modal .actions{display:flex;justify-content:flex-end;gap:.6rem;margin-top:1rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--azul-oscuro) 0%,var(--azul) 55%,var(--azul-medio) 100%);padding:1rem}.login-card{background:#fff;border-radius:20px;padding:2.2rem 2rem;width:100%;max-width:400px;box-shadow:0 25px 80px #00000059}.login-card .logo{display:flex;align-items:center;gap:.7rem;justify-content:center;margin-bottom:1.4rem}.login-card .logo .brand-title{color:var(--azul);font-size:1.9rem}.login-card .logo .brand-sub{color:var(--azul-medio);font-size:.66rem}.error-msg{background:#fdecea;color:var(--rojo);padding:.6rem .8rem;border-radius:9px;font-size:.8rem;margin-bottom:.8rem}.ok-msg{background:#e2f5ec;color:var(--verde);padding:.6rem .8rem;border-radius:9px;font-size:.8rem;margin-bottom:.8rem}.page-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.1rem;flex-wrap:wrap}.filters{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:.9rem}.filters input,.filters select{width:auto;min-width:180px}.progress-bar{height:8px;background:var(--borde);border-radius:999px;overflow:hidden;min-width:60px}.progress-bar>div{height:100%;background:var(--azul-claro);border-radius:999px}.muted{color:var(--texto-suave);font-size:.78rem}.clickable{cursor:pointer}.section-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem;flex-wrap:wrap;gap:.5rem}.chart-box{width:100%;height:260px}.empty{text-align:center;color:var(--texto-suave);padding:1.5rem;font-size:.85rem}
