*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;background:#f1f5f9;color:#0f172a;min-height:100vh}
.layout{display:flex;min-height:100vh}
/* ── Sidebar ── */
.sidebar{width:240px;background:#0f172a;display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100}
.sb-brand{padding:18px 16px;border-bottom:1px solid rgba(255,255,255,.07);display:flex;align-items:center;gap:11px}
.sb-icon{width:36px;height:36px;border-radius:9px;background:linear-gradient(135deg,#2563eb,#7c3aed);display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:800;color:#fff;flex-shrink:0}
.sb-name{font-size:.9375rem;font-weight:700;color:#fff}
.sb-sub{font-size:.7rem;color:#64748b;margin-top:1px}
.sb-nav{padding:10px 8px;flex:1;overflow-y:auto}
.nav-item{display:flex;align-items:center;gap:9px;padding:9px 12px;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;color:#94a3b8;background:none;border:none;width:100%;text-align:left;transition:background .12s,color .12s;margin-bottom:1px}
.nav-item:hover{background:rgba(255,255,255,.06);color:#e2e8f0}
.nav-item.active{background:#1d4ed8;color:#fff}
.nav-item svg{width:16px;height:16px;flex-shrink:0}
.sb-footer{padding:10px 8px;border-top:1px solid rgba(255,255,255,.07)}
.sb-user{display:flex;align-items:center;gap:9px;padding:8px 12px;margin-bottom:2px}
.sb-avatar{width:30px;height:30px;border-radius:50%;background:#1e40af;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.8125rem;font-weight:700;flex-shrink:0}
.sb-uname{font-size:.875rem;color:#94a3b8}
.btn-out{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:8px;font-size:.8125rem;font-weight:500;color:#64748b;background:none;border:none;width:100%;cursor:pointer;transition:background .12s,color .12s}
.btn-out:hover{background:rgba(255,255,255,.05);color:#94a3b8}
/* ── Main ── */
.main{margin-left:240px;flex:1;display:flex;flex-direction:column;min-width:0}
.topbar{background:#fff;border-bottom:1px solid #e2e8f0;padding:0 24px;height:56px;display:flex;align-items:center;position:sticky;top:0;z-index:50}
.page-title{font-size:.9375rem;font-weight:700;color:#0f172a}
.content{padding:20px 24px}
/* ── Stats ── */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:14px 18px;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.stat-label{font-size:.6875rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.06em}
.stat-value{font-size:1.75rem;font-weight:800;color:#0f172a;line-height:1.1;margin-top:5px}
/* ── Cards ── */
.card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:18px 20px;margin-bottom:14px;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.card-title{font-size:.9375rem;font-weight:700;color:#0f172a;margin-bottom:14px}
/* ── Filters ── */
.filters{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}
.fg{display:flex;flex-direction:column;gap:5px}
.fl{font-size:.6875rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.06em}
/* ── Inputs ── */
input,select{padding:7px 11px;border:1px solid #d1d5db;border-radius:7px;font-size:.875rem;color:#0f172a;background:#fff;outline:none;transition:border .12s,box-shadow .12s;font-family:inherit}
input:focus,select:focus{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.1)}
input[type=number]{width:110px}
/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 15px;border:none;border-radius:7px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .12s;font-family:inherit}
.btn-primary{background:#2563eb;color:#fff}
.btn-primary:hover{background:#1d4ed8}
.btn-ghost{background:#f8fafc;color:#374151;border:1px solid #e2e8f0}
.btn-ghost:hover{background:#f1f5f9}
.btn-sm{padding:5px 10px;font-size:.8125rem}
.btn-red{background:#fee2e2;color:#dc2626}
.btn-red:hover{background:#fecaca}
.btn-green{background:#dcfce7;color:#16a34a}
.btn-green:hover{background:#bbf7d0}
/* ── Table ── */
.tbl-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:.875rem}
thead{border-bottom:2px solid #f1f5f9}
th{padding:9px 12px;text-align:left;font-size:.6875rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}
td{padding:11px 12px;border-bottom:1px solid #f8fafc;color:#374151;vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:#fafafa}
/* ── Badges ── */
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:.75rem;font-weight:600;white-space:nowrap}
.bg{background:#dcfce7;color:#15803d}
.br{background:#fee2e2;color:#b91c1c}
.ba{background:#fef3c7;color:#b45309}
.bb{background:#dbeafe;color:#1d4ed8}
.bs{background:#f1f5f9;color:#475569}
/* ── Edit panel ── */
.edit-panel{background:#eff6ff;border:1.5px solid #bfdbfe;border-radius:10px;padding:18px 20px;margin-bottom:14px}
.edit-panel h3{font-size:.9rem;font-weight:700;color:#1e40af;margin-bottom:14px}
.edit-fields{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.ef{display:flex;flex-direction:column;gap:5px}
.ef label{font-size:.6875rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.06em}
.ef input{min-width:150px}
/* ── Form (horarios) ── */
.form-grid{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-end;margin-bottom:18px}
.ff{display:flex;flex-direction:column;gap:5px}
.ff label{font-size:.6875rem;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.06em}
.form-row{display:flex;align-items:center;gap:12px}
.hint{font-size:.8125rem;color:#94a3b8}
.ok{color:#16a34a}.err{color:#dc2626}
/* ── Fotocheck ── */
.fc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;padding:4px 0}
.fc-card{display:flex;flex-direction:column;align-items:center;padding:16px 10px 12px;border-radius:10px;border:1px solid #e2e8f0;background:#f8fafc;text-align:center;gap:6px}
.fc-avatar{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.fc-m{background:#dbeafe}.fc-f{background:#fce7f3}.fc-n{background:#f1f5f9}
.fc-name{font-size:.8125rem;font-weight:700;color:#0f172a;line-height:1.2;word-break:break-word}
.fc-hora{font-size:.75rem;color:#94a3b8;font-variant-numeric:tabular-nums}
/* ── View transition ── */
@keyframes vistaEntrada{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.vista-activa{animation:vistaEntrada .22s ease both}
/* ── Asistencia update transition ── */
#tablaAsis{transition:opacity .25s ease}
#tablaAsis.updating{opacity:.3}
@keyframes fadeInUp{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.asis-fade{animation:fadeInUp .3s ease both}
/* ── Live dot pulse ── */
@keyframes livePulse{0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}70%{box-shadow:0 0 0 8px rgba(34,197,94,0)}}
.dot-live{animation:livePulse 2s ease-out infinite}
/* ── Empty ── */
.empty{text-align:center;padding:48px 16px;color:#94a3b8;font-size:.9375rem}
/* ── Toast ── */
#toast{position:fixed;bottom:20px;right:20px;background:#0f172a;color:#fff;padding:11px 16px;border-radius:9px;font-size:.875rem;font-weight:500;opacity:0;pointer-events:none;transition:opacity .18s;z-index:999;max-width:300px;box-shadow:0 8px 20px rgba(0,0,0,.2)}
#toast.show{opacity:1}
/* ── Login ── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b)}
.login-card{background:#fff;border-radius:14px;padding:36px;width:100%;max-width:360px;box-shadow:0 20px 40px rgba(0,0,0,.35)}
.login-brand{display:flex;align-items:center;gap:11px;margin-bottom:26px}
.login-icon{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,#2563eb,#7c3aed);display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:800;color:#fff;flex-shrink:0}
.login-name{font-size:1.0625rem;font-weight:800;color:#0f172a}
.login-sub{font-size:.8rem;color:#64748b}
.login-err{background:#fee2e2;color:#b91c1c;border-radius:7px;padding:9px 13px;font-size:.875rem;margin-bottom:14px;border:1px solid #fecaca}
.lf{margin-bottom:13px}
.lf label{font-size:.8125rem;font-weight:600;color:#374151;display:block;margin-bottom:5px}
.lf input{width:100%;padding:9px 12px;border:1px solid #d1d5db;border-radius:7px;font-size:.9375rem;outline:none;transition:border .12s,box-shadow .12s}
.lf input:focus{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.login-btn{width:100%;padding:10px;background:#2563eb;color:#fff;border:none;border-radius:7px;font-size:.9375rem;font-weight:700;cursor:pointer;margin-top:4px;transition:background .12s}
.login-btn:hover{background:#1d4ed8}
.btn-amber{background:#fef3c7;color:#b45309;border:1px solid #fde68a}
.btn-amber:hover{background:#fde68a}
@keyframes cardEntrada{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@keyframes cardSalida{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(8px)}}
.fc-card{animation:cardEntrada .25s ease both}
