:root {
  --bg:#faf6ee; --card:#fff; --tinta:#352f24; --suave:#867a64;
  --acento:#d9881d; --acento2:#f0a52f; --borde:#ece1cf; --ok:#1c9b57; --err:#c33a2a; --amarillo:#f4b740;
}
* { box-sizing:border-box; }
body { margin:0; font-family:"Segoe UI",system-ui,-apple-system,Roboto,sans-serif;
  background:var(--bg); color:var(--tinta); line-height:1.5; }
.topbar { background:var(--card); border-bottom:1px solid var(--borde); }
.topbar-in { max-width:920px; margin:0 auto; padding:12px 16px; display:flex; align-items:center; gap:10px; }
.brand { font-weight:800; color:var(--acento); font-size:1.15rem; display:inline-flex; align-items:center; gap:8px; }
.logo { height:42px; width:auto; max-width:150px; object-fit:contain; }
.wrap { max-width:920px; margin:0 auto; padding:22px 16px 60px; }
h1 { font-size:1.5rem; color:var(--tinta); margin:6px 0 16px; }
h2 { font-size:1.15rem; margin:0 0 10px; }
.card { background:var(--card); border:1px solid var(--borde); border-radius:14px; padding:20px; margin-bottom:16px;
  box-shadow:0 2px 12px rgba(20,60,70,.05); }
label { display:block; font-size:.85rem; color:var(--suave); font-weight:700; margin:10px 0 4px; }
input, select, textarea { width:100%; padding:11px 13px; font-size:1rem; background:#fff; color:var(--tinta);
  border:2px solid var(--borde); border-radius:10px; }
input:focus, select:focus, textarea:focus { outline:none; border-color:var(--acento2); }
button { padding:12px 18px; font-size:1rem; font-weight:700; border:0; border-radius:10px;
  background:var(--acento); color:#fff; cursor:pointer; }
button:hover { background:var(--acento2); }
button.sec { background:#e6eef0; color:#1d4b54; }
button.ok { background:var(--ok); } button.danger { background:var(--err); }
button:disabled { opacity:.5; cursor:default; }
.row { display:flex; gap:10px; flex-wrap:wrap; }
.row > div { flex:1 1 200px; }
.muted { color:var(--suave); font-size:.9rem; }
.msg { margin:10px 0; font-size:.95rem; }
.msg.ok { color:var(--ok); } .msg.err { color:var(--err); }
.badge { display:inline-block; padding:2px 10px; border-radius:20px; font-size:.8rem; font-weight:700; }
.b-pendiente{ background:#fdeedd; color:#9a5a1a; } .b-aprobado{ background:#e6f0ea; color:#1c7d4d; }
.b-rechazado,.b-suspendido{ background:#fbe3dd; color:#b4533a; }
.oculto { display:none; }
/* Videollamada estilo WhatsApp: el remoto ocupa casi toda la pantalla,
   tu propia cámara va en un recuadro chico (PiP) abajo a la derecha. */
.llamada { position:relative; width:100%; height:min(72vh,600px); background:#0b1c22;
  border-radius:14px; overflow:hidden; margin-top:12px; }
.llamada .remoto { position:absolute; inset:0; }
.llamada .remoto video { width:100%; height:100%; object-fit:cover; }
.llamada .remoto:empty::after { content:"Esperando video…"; position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center; color:#7f96a0; font-size:.95rem; }
.llamada .local { position:absolute; bottom:14px; right:14px; width:30%; max-width:150px;
  aspect-ratio:3/4; border-radius:12px; overflow:hidden; z-index:2; background:#10242b;
  border:2px solid rgba(255,255,255,.85); box-shadow:0 4px 16px rgba(0,0,0,.4); }
.llamada .local video { width:100%; height:100%; object-fit:cover; }
.llamada .etq { position:absolute; top:10px; left:12px; color:#fff; font-size:.82rem;
  background:rgba(0,0,0,.45); padding:3px 10px; border-radius:8px; z-index:2; }
.llamada .cron { position:absolute; top:10px; right:12px; color:#fff; font-size:.95rem; font-weight:700;
  background:rgba(0,0,0,.55); padding:4px 12px; border-radius:8px; z-index:2;
  font-variant-numeric:tabular-nums; letter-spacing:.5px; }
.llamada .cron.warn { background:rgba(195,58,42,.92); animation:cronlatido 1s ease-in-out infinite; }
@keyframes cronlatido { 0%,100%{opacity:1} 50%{opacity:.55} }
table { width:100%; border-collapse:collapse; font-size:.92rem; }
th,td { text-align:left; padding:8px 6px; border-bottom:1px solid var(--borde); vertical-align:top; }
a { color:var(--acento); }
