/* Nutri Events – Frontend QR Scanner (auto check-in + histórico servidor)
   Paleta: primario #0b3557, secundario #007b9e, ok #22c55e, error #ef4444, warn #f59e0b
*/
.nutri-scanf{--c1:#0b3557;--c2:#007b9e;--ok:#22c55e;--err:#ef4444;--warn:#f59e0b;--bd:#e5e7eb;--muted:#667085;--soft:#f6f8fb}
.nutri-scanf__title{font-size:1.8rem;margin:0 0 6px;color:var(--c1)}
.nutri-scanf__subtitle{color:var(--muted);margin:0 0 14px}
.nutri-scanf__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:18px}

.nutri-card{background:#fff;border:1px solid var(--bd);border-radius:14px;padding:16px;box-shadow:0 6px 18px rgba(11,53,87,.06)}
.nutri-card__title{margin:0 0 10px;color:var(--c1);font-size:1.05rem}
.nutri-card__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}

.nutri-cam{position:relative;border-radius:12px;overflow:hidden;background:#000}
.nutri-cam video{display:block;width:100%;height:auto;background:#000}

/* Overlay centrado y legible, nunca cortado */
.nutri-cam__overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.45);z-index:2}
.nutri-cam__overlay[hidden]{display:none!important}

.nutri-live{background:#ffffff;border-radius:16px;padding:18px 20px;max-width:95%;width:auto;max-height:90%;overflow:auto;box-shadow:0 12px 36px rgba(0,0,0,.28);border:3px solid transparent}
.nutri-live.is-ok{border-color:rgba(34,197,94,.7);box-shadow:0 0 0 6px rgba(34,197,94,.20)}
.nutri-live.is-error{border-color:rgba(239,68,68,.7);box-shadow:0 0 0 6px rgba(239,68,68,.20)}
.nutri-live.is-flash{animation:nutriFlash .9s ease-out 1}

@keyframes nutriFlash{
  0%{transform:scale(.98);box-shadow:0 0 0 0 rgba(34,197,94,.25)}
  50%{transform:scale(1);box-shadow:0 0 0 8px rgba(34,197,94,.12)}
  100%{transform:scale(1);box-shadow:0 0 0 0 rgba(34,197,94,.0)}
}

.nutri-live__status{font-weight:900;font-size:1.35rem;margin-bottom:8px;color:#0b3557;line-height:1.2;word-break:break-word}
.nutri-live__details{display:grid;gap:6px;color:#0b3557;font-size:1.05rem;line-height:1.45;word-break:break-word}
.nutri-line code{background:#f4f6f8;border:1px solid #e5e7eb;border-radius:6px;padding:2px 6px}

.nutri-live__actions{display:flex;justify-content:center;margin-top:12px}
.nutri-btn--ghost{background:#fff;border:1px solid var(--bd);color:var(--c1);border-radius:12px;padding:10px 14px;font-weight:700}
.nutri-btn--ghost[hidden]{display:none!important}

.nutri-actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.nutri-btn{appearance:none;border:none;border-radius:12px;padding:10px 14px;cursor:pointer;font-weight:700;box-shadow:0 4px 14px rgba(0,0,0,.06)}
.nutri-btn--primary{background:var(--c2);color:#fff}
.nutri-btn:disabled{opacity:.6;cursor:not-allowed}

.nutri-help{color:var(--muted);font-size:.92rem;margin:8px 0 0}
.nutri-empty{color:var(--muted);background:#f0f7fa;border-left:3px solid var(--c2);padding:8px 10px;border-radius:8px}

.nutri-form{display:grid;gap:10px}
.nutri-label{font-weight:600;color:#0b3557}
.nutri-input{border:1px solid var(--bd);border-radius:12px;padding:10px 12px;font-size:1rem}

.nutri-banner{padding:10px 12px;border-radius:10px;border:1px solid transparent;margin-top:10px;font-weight:600}
.nutri-banner--ok{background:#ecfdf5;border-color:#bbf7d0;color:#065f46}
.nutri-banner--error{background:#fef2f2;border-color:#fecaca;color:#991b1b}

.nutri-ticket{display:grid;gap:8px;border:1px solid var(--bd);border-radius:12px;padding:12px;background:#fff}
.nutri-ticket__row{display:flex;gap:8px;align-items:baseline}
.nutri-badge{display:inline-flex;align-items:center;border:1px solid var(--bd);background:#f8f8fb;border-radius:999px;padding:2px 8px;font-size:.8rem}

/* ===== Histórico ===== */
.nutri-card--history{margin-top:18px}
.nutri-hist-wrap{overflow:auto;border:1px solid var(--bd);border-radius:12px}
.nutri-hist{width:100%;border-collapse:separate;border-spacing:0;background:#fff}
.nutri-hist th, .nutri-hist td{padding:10px 12px;border-bottom:1px solid #eef2f6;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;max-width:320px}
.nutri-hist thead th{position:sticky;top:0;background:#f8fafc;border-bottom:1px solid #e5e7eb;color:#0b3557;font-weight:700}
.nutri-hist tbody tr:last-child td{border-bottom:none}
.nutri-hist tbody tr.is-ok{background:linear-gradient(0deg, rgba(34,197,94,.07), rgba(34,197,94,.07))}
.nutri-hist tbody tr.is-error{background:linear-gradient(0deg, rgba(239,68,68,.08), rgba(239,68,68,.08))}
.nutri-hist tbody tr.is-warn{background:linear-gradient(0deg, rgba(245,158,11,.10), rgba(245,158,11,.10))}
.nutri-hist .c-time{min-width:120px}
.nutri-hist .c-res{min-width:140px}
.nutri-hist .c-event{min-width:240px}
.nutri-hist .c-name{min-width:200px}
.nutri-hist .c-email{min-width:220px}
.nutri-hist .c-code{min-width:180px}

@media (max-width: 640px){
  .nutri-hist th, .nutri-hist td{padding:8px 10px;max-width:220px}
}

/* Pequeñas mejoras UX */
body.nutri-busy{cursor:progress}


/* Ajustes overlay para estado "Inicializando…" */
.nutri-cam__overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.45);z-index:2}
.nutri-cam__overlay[hidden]{display:none!important}

.nutri-live{background:#ffffff;border-radius:16px;padding:18px 20px;max-width:95%;width:auto;max-height:90%;overflow:auto;box-shadow:0 12px 36px rgba(0,0,0,.28);border:3px solid transparent}
.nutri-live__status{font-weight:900;font-size:1.35rem;margin-bottom:8px;color:#0b3557;line-height:1.2;word-break:break-word}
.nutri-live__details{display:grid;gap:6px;color:#0b3557;font-size:1.05rem;line-height:1.45;word-break:break-word}


