:root{
  --rojo:#E30613; --rojo2:#C8102E; --tinta:#16181d; --gris:#6b7280;
  --linea:#e7e9ee; --bg:#f6f7f9; --card:#fff;
  --verde:#19a974; --ambar:#f0a202; --grisd:#c3c8d2;
  --fuente:"Helvetica Neue",Arial,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--fuente);color:var(--tinta);background:var(--bg);font-size:14px;line-height:1.45}
a{color:inherit}
h2{font-size:17px;margin:0 0 4px}
.muted{color:var(--gris);font-weight:400}

/* ---- topbar ---- */
.topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 22px;background:var(--tinta);color:#fff}
.brand{font-weight:800;letter-spacing:.3px}
.brand span{color:var(--rojo)}
.brand .back{margin-right:8px;text-decoration:none;opacity:.8}
.top-right{display:flex;gap:16px;align-items:center;font-size:13px}
.top-right .muted{color:#b9bdc7}
.btn-ghost{border:1px solid #3a3d45;border-radius:7px;padding:5px 12px;text-decoration:none;color:#fff;font-size:13px}
.btn-ghost:hover{background:#2a2d34}

.wrap{max-width:1180px;margin:22px auto;padding:0 18px}
.crumb{margin-bottom:14px;color:var(--gris);font-size:13px}
.crumb a{color:var(--rojo2);text-decoration:none}

/* ---- KPIs ---- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:18px}
.kpi{background:var(--card);border:1px solid var(--linea);border-radius:12px;padding:14px 16px}
.kpi .num{font-size:26px;font-weight:800;color:var(--rojo)}
.kpi .lbl{font-size:12px;color:var(--gris);margin-top:2px}

/* ---- cards ---- */
.card{background:var(--card);border:1px solid var(--linea);border-radius:14px;padding:18px 20px;margin-bottom:18px}
.table-scroll{overflow-x:auto}

/* ---- matriz ---- */
table{border-collapse:collapse;width:100%}
.matrix{font-size:14px;margin-top:8px}
.matrix th,.matrix td{border:1px solid var(--linea);text-align:center;padding:8px}
.matrix thead th{background:#fafbfc;font-weight:700}
.matrix .rowh{text-align:left;font-weight:700;background:#fafbfc;white-space:nowrap}
.matrix .empty{color:var(--grisd)}
.matrix .tot{font-weight:800;background:#fafbfc}
.matrix .cell a{display:inline-flex;align-items:center;gap:6px;text-decoration:none;font-weight:700;color:var(--tinta)}
.matrix .cell a:hover{color:var(--rojo)}

.dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:var(--grisd);vertical-align:middle}
.dot.verde{background:var(--verde)} .dot.ambar{background:var(--ambar)} .dot.gris{background:var(--grisd)}
.dot.na{background:transparent;border:1px dashed var(--grisd)}
.dot.conf{box-shadow:0 0 0 2px #fff,0 0 0 4px var(--verde)}

.legend{display:flex;gap:18px;flex-wrap:wrap;margin-top:12px;font-size:12px;color:var(--gris)}
.legend i{margin-right:5px}

/* ---- grupos chips ---- */
.grupos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin-top:8px}
.grupo-chip{display:flex;flex-direction:column;gap:2px;padding:10px 12px;border:1px solid var(--linea);border-radius:10px;text-decoration:none;border-left:4px solid var(--grisd)}
.grupo-chip:hover{background:#fafbfc}
.grupo-chip.verde{border-left-color:var(--verde)} .grupo-chip.ambar{border-left-color:var(--ambar)} .grupo-chip.gris{border-left-color:var(--grisd)}
.grupo-chip b{font-size:15px} .grupo-chip span{font-size:12px;color:var(--gris)}

/* ---- turno ---- */
.turno-head{display:flex;flex-wrap:wrap;align-items:center;gap:14px;margin-bottom:12px}
.grupo-status{font-size:13px;color:var(--gris)}
.grupo-status b{color:var(--tinta)}
.confirm-form{display:flex;gap:8px;margin-left:auto}
.confirm-form input{border:1px solid var(--linea);border-radius:8px;padding:7px 10px;font:inherit}
.btn-primary{background:var(--rojo);color:#fff;border:0;border-radius:8px;padding:8px 14px;font-weight:700;cursor:pointer}
.btn-primary:hover{background:var(--rojo2)}

.kids{font-size:13px}
.kids th,.kids td{border-bottom:1px solid var(--linea);padding:7px 9px;text-align:left;vertical-align:top}
.kids thead th{background:#fafbfc;position:sticky;top:0;font-size:12px;text-transform:uppercase;letter-spacing:.3px;color:var(--gris)}
.kids tbody tr:hover{background:#fcfcfd}
.kids .email{color:var(--rojo2)} .kids .obs{max-width:200px;color:var(--gris)}

.badge{display:inline-block;background:#eef0f4;border-radius:6px;padding:2px 8px;font-size:12px;font-weight:700}
.badge-ok{background:#e4f6ee;color:var(--verde)}

.flash{padding:10px 14px;border-radius:10px;margin-bottom:14px;font-weight:600}
.flash-ok{background:#e4f6ee;color:#0d7a51} .flash-err{background:#fde8e8;color:#b3261e}

/* ---- login ---- */
.login-body{display:flex;min-height:100vh;align-items:center;justify-content:center;background:var(--tinta)}
.login-card{background:#fff;padding:34px;border-radius:16px;width:300px;display:flex;flex-direction:column;gap:12px;text-align:center}
.login-card .brand{font-size:22px;color:var(--tinta)}
.login-card input{border:1px solid var(--linea);border-radius:9px;padding:11px;font:inherit}
.login-card button{background:var(--rojo);color:#fff;border:0;border-radius:9px;padding:11px;font-weight:700;cursor:pointer}
.login-card button:hover{background:var(--rojo2)}
.login-card .error{color:#b3261e;font-size:13px}
