/* ─── Muniportales CSS ─────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;600&family=IBM+Plex+Mono:wght@400;500&display=swap');

*{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#F5F4F0;
  --surface:#FFFFFF;
  --surface2:#F0EEE8;
  --surface3:#E8E6DF;
  --border:rgba(0,0,0,.09);
  --border-s:rgba(0,0,0,.16);
  --text:#1A1916;
  --muted:#6B6A66;
  --hint:#9B9A96;
  --teal:#1D9E75;
  --teal-bg:#E1F5EE;
  --teal-t:#085041;
  --amber:#BA7517;
  --amber-bg:#FAEEDA;
  --amber-t:#633806;
  --red:#E24B4A;
  --red-bg:#FCEBEB;
  --red-t:#501313;
  --blue:#378ADD;
  --blue-bg:#E6F1FB;
  --blue-t:#042C53;
  --purple:#7F77DD;
  --purple-bg:#EEEDFE;
  --purple-t:#26215C;
  --green:#639922;
  --green-bg:#EAF3DE;
  --green-t:#173404;
  --font:'IBM Plex Sans',system-ui,sans-serif;
  --mono:'IBM Plex Mono',monospace;
  --r:10px;
  --rs:6px;
}

body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;min-height:100vh}

/* ── LAYOUT ─────────────── */
.app{display:flex;min-height:100vh}

.sidebar{
  width:230px;min-width:230px;
  background:var(--surface);
  border-right:.5px solid var(--border-s);
  display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;overflow-y:auto;
  flex-shrink:0;
}

.brand{padding:16px 16px 12px;border-bottom:.5px solid var(--border)}
.brand-name{font-size:15px;font-weight:600;letter-spacing:-.3px;color:var(--text)}
.brand-sub{font-size:10px;color:var(--muted);font-family:var(--mono);letter-spacing:.06em;margin-top:1px}

.sidenav{padding:8px;flex:1}
.sec-lbl{font-size:10px;font-weight:600;color:var(--hint);text-transform:uppercase;letter-spacing:.08em;padding:8px 8px 3px;margin-top:6px}

.ni{
  display:flex;align-items:center;gap:8px;
  padding:7px 10px;border-radius:var(--rs);
  cursor:pointer;font-size:13px;color:var(--muted);
  text-decoration:none;
  transition:background .1s,color .1s;
  margin-bottom:1px;
}
.ni:hover{background:var(--surface2);color:var(--text)}
.ni.active{background:var(--teal-bg);color:var(--teal-t);font-weight:500}
.ni-ic{font-size:13px;width:18px;text-align:center;flex-shrink:0}
.nbadge{
  margin-left:auto;background:var(--red-bg);color:var(--red-t);
  font-size:10px;font-weight:600;padding:1px 6px;border-radius:20px;
  font-family:var(--mono);
}

.main{flex:1;overflow-x:hidden;min-width:0}
.topbar{
  background:var(--surface);border-bottom:.5px solid var(--border);
  padding:11px 22px;display:flex;align-items:center;gap:10px;
  position:sticky;top:0;z-index:50;
}
.tb-title{font-size:15px;font-weight:600;flex:1}
.tb-date{font-size:11px;color:var(--muted);font-family:var(--mono)}

.content{padding:20px 22px}

/* ── BUTTONS ────────────── */
.btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 14px;border-radius:var(--rs);
  font-size:13px;font-weight:500;font-family:var(--font);
  cursor:pointer;border:none;text-decoration:none;
  transition:opacity .12s,background .12s;
}
.btn:hover{opacity:.85}
.btn-primary{background:var(--teal);color:#fff}
.btn-ghost{background:transparent;border:.5px solid var(--border-s);color:var(--text)}
.btn-ghost:hover{background:var(--surface2);opacity:1}
.btn-danger{background:var(--red);color:#fff}
.btn-sm{padding:4px 10px;font-size:12px}
.btn-icon{
  background:none;border:none;cursor:pointer;
  padding:4px 7px;border-radius:4px;font-size:13px;
  color:var(--muted);transition:background .1s,color .1s;
  text-decoration:none;display:inline-flex;align-items:center;
}
.btn-icon:hover{background:var(--surface2);color:var(--text)}

/* ── STATS ──────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:18px}
@media(max-width:900px){.stats-grid{grid-template-columns:repeat(2,1fr)}}
.stat{background:var(--surface);border:.5px solid var(--border);border-radius:var(--r);padding:12px 14px}
.stat-lbl{font-size:10px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px}
.stat-val{font-size:26px;font-weight:600;font-family:var(--mono);line-height:1}
.stat-sub{font-size:11px;color:var(--hint);margin-top:3px}
.s-red .stat-val{color:var(--red)}
.s-amber .stat-val{color:var(--amber)}
.s-teal .stat-val{color:var(--teal)}
.s-blue .stat-val{color:var(--blue)}

/* ── CARDS ──────────────── */
.card{background:var(--surface);border-radius:var(--r);border:.5px solid var(--border);overflow:hidden}
.card-header{padding:12px 16px;border-bottom:.5px solid var(--border);display:flex;align-items:center;gap:10px}
.card-title{font-size:13px;font-weight:600;flex:1}
.card-body{padding:14px 16px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:16px}
@media(max-width:860px){.two-col{grid-template-columns:1fr}}

/* ── TABLE ──────────────── */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{
  text-align:left;padding:7px 11px;
  font-size:10px;font-weight:600;color:var(--muted);
  text-transform:uppercase;letter-spacing:.06em;
  border-bottom:.5px solid var(--border);background:var(--bg);
  white-space:nowrap;
}
.tbl td{padding:9px 11px;border-bottom:.5px solid var(--border);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr:hover td{background:var(--bg)}
.tbl-wrap{overflow-x:auto}

/* ── BADGES ─────────────── */
.badge{
  display:inline-flex;align-items:center;
  padding:2px 8px;border-radius:20px;
  font-size:11px;font-weight:600;font-family:var(--mono);
  white-space:nowrap;
}
.badge-teal{background:var(--teal-bg);color:var(--teal-t)}
.badge-amber{background:var(--amber-bg);color:var(--amber-t)}
.badge-red{background:var(--red-bg);color:var(--red-t)}
.badge-blue{background:var(--blue-bg);color:var(--blue-t)}
.badge-purple{background:var(--purple-bg);color:var(--purple-t)}
.badge-gray{background:var(--surface2);color:var(--muted)}
.badge-green{background:var(--green-bg);color:var(--green-t)}

/* ── ALERTS ─────────────── */
.alert{border-radius:var(--r);padding:9px 14px;margin-bottom:12px;display:flex;align-items:flex-start;gap:8px;font-size:13px}
.alert-red{background:var(--red-bg);color:var(--red-t);border:.5px solid #F09595}
.alert-amber{background:var(--amber-bg);color:var(--amber-t);border:.5px solid #FAC775}
.alert-teal{background:var(--teal-bg);color:var(--teal-t);border:.5px solid #9FE1CB}
.alert-blue{background:var(--blue-bg);color:var(--blue-t);border:.5px solid #B5D4F4}

/* ── PROGRESS BAR ───────── */
.dbar{width:100%;height:5px;background:var(--border);border-radius:3px;overflow:hidden;margin-top:3px}
.dfill{height:100%;border-radius:3px}
.dlbl{display:flex;justify-content:space-between;font-size:10px;color:var(--hint);margin-top:2px}

/* ── FILTERS ────────────── */
.filters{display:flex;gap:7px;margin-bottom:14px;flex-wrap:wrap;align-items:center}
.fbtn{
  padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500;
  cursor:pointer;border:.5px solid var(--border-s);
  background:var(--surface);color:var(--muted);
  transition:all .12s;white-space:nowrap;text-decoration:none;display:inline-block;
}
.fbtn.active{background:var(--teal);color:#fff;border-color:var(--teal)}
.fbtn:hover:not(.active){background:var(--surface2)}

/* ── FORMS ──────────────── */
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:600px){.fgrid{grid-template-columns:1fr}}
.fg{display:flex;flex-direction:column;gap:4px}
.fg.full{grid-column:1/-1}
.flbl{font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.form-control{
  padding:7px 10px;border:.5px solid var(--border-s);
  border-radius:var(--rs);font-family:var(--font);font-size:13px;
  background:var(--surface);color:var(--text);width:100%;
}
.form-control:focus{outline:2px solid var(--teal);outline-offset:1px}
textarea.form-control{resize:vertical}
.readonly-field{background:var(--surface2);color:var(--muted)}

/* ── MODAL ──────────────── */
.overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.38);z-index:200;
  align-items:center;justify-content:center;padding:16px;
}
.overlay.open{display:flex}
.modal{
  background:var(--surface);border-radius:var(--r);
  border:.5px solid var(--border-s);width:600px;
  max-width:100%;max-height:92vh;overflow-y:auto;
  box-shadow:0 8px 40px rgba(0,0,0,.16);
}
.modal.wide{width:780px}
.mhead{padding:14px 18px;border-bottom:.5px solid var(--border);display:flex;align-items:center;gap:8px}
.mtitle{font-size:15px;font-weight:600;flex:1}
.mbody{padding:18px}
.mfoot{padding:12px 18px;border-top:.5px solid var(--border);display:flex;gap:8px;justify-content:flex-end}
.close-btn{background:none;border:none;font-size:20px;color:var(--muted);cursor:pointer;line-height:1;padding:0 2px}
.close-btn:hover{color:var(--text)}

/* ── TABS ───────────────── */
.tabs{display:flex;border-bottom:.5px solid var(--border)}
.tab{
  padding:9px 16px;font-size:13px;font-weight:500;
  color:var(--muted);cursor:pointer;text-decoration:none;
  border-bottom:2px solid transparent;margin-bottom:-.5px;
  transition:all .12s;display:inline-block;
}
.tab.active{color:var(--teal);border-bottom-color:var(--teal)}
.tab:hover:not(.active){color:var(--text)}
.tp{display:none;padding-top:14px}
.tp.active{display:block}

/* ── HISTORIAL ──────────── */
.hitem{display:flex;gap:10px;padding:9px 0;border-bottom:.5px solid var(--border);align-items:flex-start}
.hitem:last-child{border-bottom:none}
.hdot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}
.hd-ok{background:var(--teal)}
.hd-issue{background:var(--amber)}
.hd-crit{background:var(--red)}
.hd-info{background:var(--blue)}
.hdate{font-family:var(--mono);font-size:10px;color:var(--muted);white-space:nowrap;text-align:right;min-width:80px}
.hdesc{font-size:13px;flex:1}
.hmeta{font-size:11px;color:var(--hint);margin-top:2px}

/* ── TOGGLE ─────────────── */
.toggle{position:relative;display:inline-block;width:36px;height:20px;flex-shrink:0}
.toggle input{opacity:0;width:0;height:0}
.slider-tog{position:absolute;cursor:pointer;inset:0;background:var(--surface3);border-radius:20px;transition:.2s}
.slider-tog:before{position:absolute;content:"";height:14px;width:14px;left:3px;bottom:3px;background:white;border-radius:50%;transition:.2s}
input:checked+.slider-tog{background:var(--teal)}
input:checked+.slider-tog:before{transform:translateX(16px)}

/* ── MISC ───────────────── */
.empty{text-align:center;padding:32px 16px;color:var(--hint);font-size:13px}
.empty-ic{font-size:28px;margin-bottom:6px}
.chip{
  display:inline-flex;align-items:center;font-size:11px;
  padding:2px 7px;border-radius:4px;
  background:var(--surface2);color:var(--muted);
  border:.5px solid var(--border);font-family:var(--mono);
}
.mono{font-family:var(--mono)}
.text-muted{color:var(--muted)}
.text-hint{color:var(--hint)}
.fw-500{font-weight:500}
.fw-600{font-weight:600}
.fs-12{font-size:12px}
.fs-11{font-size:11px}

/* ── LOGIN ──────────────── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.login-box{background:var(--surface);border:.5px solid var(--border-s);border-radius:var(--r);padding:36px;width:380px;max-width:95vw}
.login-logo{text-align:center;margin-bottom:24px}
.login-logo-name{font-size:22px;font-weight:600;letter-spacing:-.5px}
.login-logo-sub{font-size:11px;color:var(--muted);font-family:var(--mono);letter-spacing:.06em}

/* ── FLASH MESSAGES ─────── */
.flash{padding:10px 14px;border-radius:var(--rs);margin-bottom:16px;font-size:13px}
.flash-error{background:var(--red-bg);color:var(--red-t);border:.5px solid #F09595}
.flash-success{background:var(--teal-bg);color:var(--teal-t);border:.5px solid #9FE1CB}

/* ── PAGINATION ─────────── */
.pagination{display:flex;gap:4px;align-items:center;margin-top:14px;justify-content:center}
.page-btn{
  padding:5px 11px;border-radius:var(--rs);font-size:12px;font-family:var(--mono);
  border:.5px solid var(--border-s);background:var(--surface);color:var(--text);
  cursor:pointer;text-decoration:none;display:inline-block;transition:background .1s;
}
.page-btn:hover{background:var(--surface2)}
.page-btn.active{background:var(--teal);color:#fff;border-color:var(--teal)}
.page-btn.disabled{color:var(--hint);cursor:default;pointer-events:none}
