:root{
  --navy:#1f3864; --navy2:#2e5496; --ink:#222; --mut:#666; --line:#d7dce5;
  --soft:#f5f7fb; --bg:#ffffff;
  --r:#c62828; --rbg:#fdecec; --v:#2e7d32; --vbg:#e7f4e8; --a:#b26a00; --abg:#fff3e0;
}
*{box-sizing:border-box}
body{margin:0;background:#e7ecf3;color:var(--ink);
  font:15px/1.55 "Segoe UI",Roboto,Helvetica,Arial,sans-serif;}

/* ---- login ---- */
.loginbg{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#eef2fa,#dde6f5);}
.loginbox{background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:0 10px 30px rgba(20,40,80,.12);
  padding:30px 32px;width:360px;max-width:92vw;}
.loginbox h1{color:var(--navy);font-size:20px;margin:0 0 2px}
.loginbox .sub{color:var(--mut);font-size:13px;margin:0 0 18px}
.loginbox label{display:block;font-size:12.5px;color:var(--mut);margin:12px 0 4px}
.loginbox input{width:100%;padding:9px;border:1px solid var(--line);border-radius:8px;font-size:14px}
.loginbox button{margin-top:18px;width:100%;background:var(--navy);color:#fff;border:0;border-radius:8px;
  padding:11px;font-size:15px;font-weight:600;cursor:pointer}
.loginbox .hint{font-size:11.5px;color:var(--mut);margin-top:14px}
.alert{background:var(--rbg);border:1px solid #f3c0c0;color:#8e1c1c;border-radius:8px;padding:9px 12px;font-size:13px;margin-bottom:6px}

/* ---- topbar (estilo documento MAGEP) ---- */
.topbar{background:linear-gradient(135deg,#fff 0%,#eef2fa 100%);border-bottom:3px solid var(--navy);
  padding:26px 22px 18px;display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:14px}
.topbar h1{margin:0;color:var(--navy);font-size:25px;letter-spacing:.3px}
.topbar .sub{color:var(--navy2);font-size:15px;font-style:italic;margin-top:4px}
.topbar .meta{margin-top:10px;font-size:13.5px;color:var(--mut)}
.topbar .meta b{color:var(--ink)}
.userbox{font-size:13px;color:var(--mut);display:flex;align-items:center;gap:14px;flex-wrap:wrap;flex:0 0 auto}
.topbar>div:first-child{flex:1 1 420px;min-width:0}
.btnlink{background:var(--navy);color:#fff;text-decoration:none;border-radius:18px;padding:6px 14px;font-size:13px}

/* ---- navegación (estilo toc MAGEP) ---- */
.appnav{position:sticky;top:0;z-index:30;display:flex;flex-wrap:wrap;align-items:center;gap:6px;
  padding:10px 16px;background:linear-gradient(180deg,#ffffff,#f5f7fb);
  border-bottom:1px solid var(--line);box-shadow:0 2px 10px rgba(20,40,80,.06)}
.appnav a{text-decoration:none;color:var(--navy);background:#fff;border:1px solid var(--line);
  border-radius:999px;padding:7px 15px;font-size:13px;font-weight:600;line-height:1;transition:all .15s}
.appnav a:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.appnav a.magep{margin-left:auto;background:var(--navy);color:#fff;border-color:var(--navy);
  font-weight:700;box-shadow:0 2px 8px rgba(31,56,100,.25)}
.appnav a.magep:hover{background:var(--navy2);border-color:var(--navy2)}

/* ---- layout (estilo hoja MAGEP) ---- */
.wrap{max-width:1120px;margin:0 auto;padding:14px 14px 60px;counter-reset:hoja}
.card{background:#fff;border:1px solid #dfe5ee;border-radius:12px;box-shadow:0 6px 22px rgba(20,40,80,.08);
  padding:30px 38px 36px;margin:22px auto;scroll-margin-top:70px;position:relative;counter-increment:hoja;overflow:hidden}
.card::after{content:counter(hoja);position:absolute;top:0;right:0;background:var(--navy);color:#fff;
  font-size:11px;font-weight:700;padding:4px 12px;border-bottom-left-radius:10px;letter-spacing:.3px;min-width:26px;text-align:center}
.card h2{color:var(--navy);font-size:20px;border-bottom:2px solid var(--navy2);padding-bottom:6px;margin:0 0 6px}
.card h3{color:var(--navy2);font-size:16.5px;margin:16px 0 6px}
.muted{color:var(--mut);font-size:12.5px;margin:6px 0 14px}
.lead{background:var(--soft);border-left:4px solid var(--navy2);padding:10px 14px;border-radius:0 8px 8px 0;margin:8px 0 14px}

.row{display:grid;grid-template-columns:200px 1fr;gap:12px;align-items:center;padding:5px 0}
.row label{font-size:13.5px;color:var(--mut)}
select,input[type=text]{padding:7px;border:1px solid var(--line);border-radius:7px;font-size:13.5px;background:#fff;width:100%}
.jueces{margin-top:8px}

.grpsel{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:2px 0 16px}
.grpsel button{background:#fff;color:var(--navy);border:1.5px solid var(--navy2);border-radius:20px;
  padding:7px 18px;font-size:13.5px;font-weight:700;cursor:pointer}
.grpsel button.on{background:var(--navy);color:#fff}
.permnote{font-size:12px;color:var(--mut);margin-left:auto}

.roleblock{margin:6px 0 16px}
.rolerow{display:grid;grid-template-columns:1fr 280px;gap:12px;align-items:center;padding:7px 0;border-bottom:1px dashed var(--line)}
.rolerow span{font-size:13.5px}
.rolesel.dup{border-color:var(--r);background:var(--rbg)}
.rolesel:disabled{background:#f3f4f7;color:#888}
.badge{display:inline-block;font-size:10.5px;font-weight:700;padding:1px 7px;border-radius:9px;margin-left:4px;vertical-align:middle}
.bs-lego{background:#e3eefc;color:#1c4587}
.bs-experto{background:#e9d9f7;color:#5e2b97}
.bs-imputado{background:#fde2e2;color:#a02020}

.intlist{display:grid;grid-template-columns:1fr 1fr;gap:8px}
@media(max-width:680px){.intlist{grid-template-columns:1fr}.rolerow{grid-template-columns:1fr}.row{grid-template-columns:1fr}.card{padding:22px 18px 26px}.topbar h1{font-size:21px}}
.introw{display:flex;gap:6px;align-items:center}
.introw .intname{flex:1}
.mini{border:1px solid var(--line);background:#fff;border-radius:7px;padding:6px 9px;font-size:12px;cursor:pointer}
.mini.guardar{border-color:var(--navy2);color:var(--navy)}
.mini.del{border-color:#e0a0a0;color:var(--r)}
.addrow{display:flex;gap:8px;margin-top:12px}
.addrow input{flex:1}
.addrow button{background:var(--navy);color:#fff;border:0;border-radius:8px;padding:8px 16px;cursor:pointer}

table{border-collapse:collapse;width:100%;font-size:13px;margin:4px 0 8px}
th,td{border:1px solid var(--line);padding:7px 9px;text-align:left;vertical-align:top}
thead th{background:var(--navy);color:#fff;font-weight:600}
#summary h4{color:var(--navy);margin:12px 0 4px;font-size:14px}

.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%) translateY(40px);
  background:var(--navy);color:#fff;padding:9px 18px;border-radius:22px;font-size:13px;opacity:0;
  transition:all .25s;pointer-events:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.err{background:var(--r)}

/* ---- testigos ---- */
.btsand{background:var(--navy2)!important;color:#fff!important;border-color:var(--navy2)!important}
.trow,.prow{border:1px solid var(--line);border-radius:9px;margin:8px 0;overflow:hidden}
.thead,.phead{display:flex;justify-content:space-between;align-items:center;gap:8px;
  padding:8px 12px;background:var(--soft);flex-wrap:wrap}
.tlabel,.plabel{font-size:14px}
.tctrl,.pctrl{display:flex;gap:5px;align-items:center;flex-wrap:wrap}
.tdet,.pdet{padding:8px 14px;font-size:13px}
.tdet p,.pdet p{margin:4px 0}
.nvb{display:inline-block;font-size:10.5px;font-weight:700;padding:1px 8px;border-radius:9px;margin-left:4px}
.nv-fuerte{background:var(--vbg);color:var(--v)}
.nv-medio{background:#fff3e0;color:var(--a)}
.nv-debil{background:#eee;color:#777}
.tniv{padding:4px;font-size:12.5px;width:auto}
.edita label{display:block;font-size:11.5px;color:var(--mut);margin:8px 0 2px}
.edita input,.edita textarea{width:100%;padding:6px;border:1px solid var(--line);border-radius:6px;font-size:12.5px}
.edita textarea{min-height:54px;resize:vertical}
.pobs .po,.tdet .vc{color:#8a3324}

/* ---- pruebas ---- */
.tipob{display:inline-block;font-size:10.5px;font-weight:700;padding:1px 8px;border-radius:9px;color:#fff}
.tb-material{background:#962828}.tb-pericial{background:#5e2b97}
.tb-documental{background:#1c4587}.tb-testimonial{background:#0b5f4c}
.pimg{margin-top:8px}
.pimg img{max-width:100%;border:1px solid var(--line);border-radius:6px;display:block;margin-bottom:6px}
#zipAll{color:var(--navy2);font-weight:700}

/* ---- impresión ---- */
@media print{
  body{background:#fff}
  .appnav,.userbox,.addrow,.mini,.grpsel button{display:none}
  .card{box-shadow:none;border:1px solid #ccc;border-radius:0;margin:0 0 12px;page-break-inside:avoid}
  .card::after{color:var(--navy);background:none}
  .topbar{border-bottom:2px solid var(--navy)}
}
