:root{
  --bg:#0C1712; --panel:#101E18; --panel2:#16281F; --raise:#1B3227;
  --line:#243c30; --line2:#2e4a3b;
  --ink:#E9F1EB; --muted:#93ab9d; --faint:#5f7a6b;
  --green:#37C57F; --green-dim:#1f5f43;
  --amber:#E7A23A; --red:#E45B47; --gold:#F4CF6B;
  --blue:#5aa9e6;
  --mono:ui-monospace,"SF Mono","JetBrains Mono","Cascadia Code",Menlo,Consolas,monospace;
  --sans:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{background:radial-gradient(1200px 600px at 12% -10%,#14261d 0%,transparent 55%),var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}
button{font:inherit;cursor:pointer}
input,select,textarea{font:inherit}
a{color:var(--green)}

/* layout */
.app{display:grid;grid-template-columns:220px 1fr;min-height:100vh}
@media(max-width:760px){.app{grid-template-columns:1fr}.side{position:fixed;z-index:50;left:-240px;transition:.2s;height:100%}.side.open{left:0}}
.side{background:linear-gradient(180deg,#0e1c16,#0b150f);border-right:1px solid var(--line);padding:18px 14px;display:flex;flex-direction:column;gap:6px}
.brand{padding:6px 8px 16px}
.brand .t{font-weight:700;font-size:16px}
.brand .s{color:var(--faint);font-size:11px;letter-spacing:.12em;text-transform:uppercase;margin-top:3px}
.navbtn{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:none;border:1px solid transparent;color:var(--muted);text-align:left;width:100%;font-size:14px}
.navbtn:hover{background:var(--panel2);color:var(--ink)}
.navbtn.active{background:var(--raise);border-color:var(--line2);color:var(--ink);font-weight:600}
.navbtn .badge{margin-left:auto;background:var(--red);color:#fff;font-size:11px;border-radius:20px;padding:1px 7px;font-family:var(--mono)}
.side .foot{margin-top:auto;color:var(--faint);font-size:11px;padding:8px}

.main{padding:20px clamp(14px,3vw,32px) 60px;min-width:0}
.topbar{display:flex;flex-wrap:wrap;align-items:center;gap:14px;justify-content:space-between;margin-bottom:18px}
.topbar .cyc{color:var(--muted);font-size:13px}
.topbar .cyc b{color:var(--green)}
.topmetrics{display:flex;gap:10px;flex-wrap:wrap}
.tm{background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:8px 13px}
.tm .k{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}
.tm .v{font-family:var(--mono);font-size:19px;font-weight:600}
.hbtn{background:var(--panel);border:1px solid var(--line);color:var(--muted);border-radius:9px;padding:8px 12px;font-size:13px}
.hbtn:hover{border-color:var(--line2);color:var(--ink)}
.menu-toggle{display:none}
@media(max-width:760px){.menu-toggle{display:inline-flex}}

h1.view{font-size:20px;margin:0 0 14px;font-weight:700}
.card{background:linear-gradient(180deg,var(--panel),#0e1c16);border:1px solid var(--line);border-radius:14px;padding:16px;margin-bottom:16px}
.card h2{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin:0 0 12px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:820px){.grid2{grid-template-columns:1fr}}

/* dashboard summary */
.summary{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:16px}
@media(max-width:820px){.summary{grid-template-columns:repeat(2,1fr)}}
.sumcard{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:13px}
.sumcard .n{font-family:var(--mono);font-size:26px;font-weight:700}
.sumcard .l{font-size:11.5px;color:var(--muted);margin-top:3px}
.sumcard.hot{border-color:#7a3730}.sumcard.hot .n{color:var(--red)}
.sumcard.warn{border-color:#7a5f24}.sumcard.warn .n{color:var(--amber)}
.sumcard.ok .n{color:var(--green)}

.alist{display:flex;flex-direction:column;gap:8px}
.arow{display:flex;align-items:center;gap:12px;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:13px}
.arow .nm{font-weight:600}
.arow .meta{color:var(--muted);font-size:12px}
.arow .spacer{margin-left:auto}
.countdown{font-family:var(--mono);font-weight:600;font-size:14px;padding:3px 9px;border-radius:8px;background:var(--green-dim);color:#bfe9d3}
.countdown.warn{background:#4a3a17;color:#f0d59a}
.countdown.crit{background:#4a2320;color:#f0b3aa}
.pill{font-size:11px;padding:2px 8px;border-radius:20px;border:1px solid var(--line2);color:var(--muted)}
.pill.rec{border-color:var(--green-dim);color:var(--green)}

/* gauges */
.gauge{margin-bottom:12px}
.gauge .gt{display:flex;justify-content:space-between;font-size:13px;margin-bottom:5px}
.gauge .gt .gv{font-family:var(--mono)}
.track{height:8px;border-radius:6px;background:var(--panel2);border:1px solid var(--line);overflow:hidden}
.fill{height:100%;width:0}
.fill.g{background:linear-gradient(90deg,#2c9d66,var(--green))}
.fill.a{background:linear-gradient(90deg,#b57f26,var(--amber))}
.fill.r{background:linear-gradient(90deg,#b33f30,var(--red))}

/* table */
.tablewrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;color:var(--faint);font-weight:600;font-size:11px;letter-spacing:.06em;text-transform:uppercase;padding:8px 10px;border-bottom:1px solid var(--line)}
td{padding:9px 10px;border-bottom:1px solid var(--line);vertical-align:middle}
tr:hover td{background:rgba(255,255,255,.015)}
.tag{font-size:11px;padding:2px 8px;border-radius:20px;font-weight:600}
.tag.cag{background:#3a2f14;color:var(--gold)}
.tag.reg{background:var(--panel2);color:var(--muted)}
.st{font-size:11px;padding:2px 9px;border-radius:20px;font-weight:600;white-space:nowrap}
.st.prospecto{background:var(--panel2);color:var(--muted)}
.st.solicitante{background:#173a4a;color:#9fd4e6}
.st.admitido{background:#2f2a4a;color:#c3b8e6}
.st.inscrito{background:var(--green-dim);color:#bfe9d3}
.st.descartado{background:#3a2320;color:#e0a59d}
.convenio{font-size:11px;padding:2px 8px;border-radius:20px;background:var(--green-dim);color:#bfe9d3}
.no-convenio{font-size:11px;color:var(--faint)}
.cohorte{font-family:var(--mono);font-size:12px}
.cohorte.ready{color:var(--green)} .cohorte.near{color:var(--amber)}

.rowbtns{display:flex;gap:5px;flex-wrap:wrap}
.mini{background:var(--panel2);border:1px solid var(--line);color:var(--muted);border-radius:8px;padding:4px 9px;font-size:12px}
.mini:hover{border-color:var(--line2);color:var(--ink)}
.mini.g:hover{border-color:var(--green);color:var(--green)}
.mini.gold:hover{border-color:var(--gold);color:var(--gold)}

.btn{background:var(--green);border:1px solid var(--green);color:#06140d;border-radius:10px;padding:9px 15px;font-weight:600;font-size:13px}
.btn:hover{filter:brightness(1.08)}
.btn.ghost{background:var(--panel2);border-color:var(--line);color:var(--ink)}
.btn.ghost:hover{border-color:var(--line2)}
.btn.danger{background:none;border-color:#5a2a24;color:var(--red)}

.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:14px}
.toolbar .sp{margin-left:auto}
select,input[type=text],input[type=date],input[type=tel],input[type=email],textarea{background:var(--panel2);border:1px solid var(--line);color:var(--ink);border-radius:9px;padding:8px 10px;font-size:13px}
select:focus,input:focus,textarea:focus{outline:none;border-color:var(--green)}
label.fld{display:flex;flex-direction:column;gap:5px;font-size:12px;color:var(--muted)}
label.fld input,label.fld select,label.fld textarea{color:var(--ink)}

/* modal */
.modal{position:fixed;inset:0;background:rgba(4,10,7,.74);display:grid;place-items:center;z-index:60;padding:18px}
.modal[hidden]{display:none}
.sheet{background:var(--panel);border:1px solid var(--line2);border-radius:16px;max-width:560px;width:100%;max-height:88vh;overflow:auto;padding:20px}
.sheet h3{margin:0 0 14px;font-size:17px}
.formgrid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.formgrid .full{grid-column:1/-1}
.sheetbtns{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}
.hist{margin-top:8px;display:flex;flex-direction:column;gap:6px;max-height:220px;overflow:auto}
.hist .h{background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:8px 10px;font-size:12px}
.hist .h .ht{font-family:var(--mono);color:var(--faint);font-size:11px}

/* login */
.login{position:fixed;inset:0;background:var(--bg);display:grid;place-items:center;z-index:100}
.loginbox{background:var(--panel);border:1px solid var(--line2);border-radius:16px;padding:28px;width:340px;text-align:center}
.loginbox h1{font-size:19px;margin:0 0 4px}
.loginbox p{color:var(--muted);font-size:13px;margin:0 0 18px}
.loginbox input{width:100%;text-align:center;margin-bottom:12px;padding:11px}
.loginbox .btn{width:100%}
.err{color:var(--red);font-size:12px;min-height:16px;margin-top:8px}

.empty{color:var(--faint);font-size:13px;padding:14px;text-align:center}
.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(20px);background:var(--raise);border:1px solid var(--line2);color:var(--ink);padding:11px 18px;border-radius:11px;font-size:13px;opacity:0;pointer-events:none;transition:.25s;z-index:120}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.bad{border-color:#7a3730}
:focus-visible{outline:2px solid var(--green);outline-offset:2px}
