/* Tablero público IA_TACO. Reusa la paleta de app.css (mismas variables :root). */
.p-header{padding:18px 24px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--bg);z-index:20}
.p-header h1{margin:0;font-size:20px;letter-spacing:.3px}
.p-header .sub{color:var(--muted);font-size:12px;margin-top:3px}
.p-header .sub a{color:var(--accent)}

.kpis{display:flex;gap:10px;flex-wrap:wrap;padding:14px 24px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:12px 16px;min-width:110px}
.kpi b{font-size:22px;display:block}
.kpi span{color:var(--muted);font-size:12px}
.kpi.kpi-toggle{cursor:pointer;user-select:none;transition:box-shadow .15s,border-color .15s}
.kpi.kpi-toggle:hover{border-color:var(--red)}
.kpi.kpi-toggle.active{border-color:var(--red);box-shadow:0 0 0 2px rgba(231,76,60,.35);background:#2a1a1a}

.controls{display:flex;flex-wrap:wrap;gap:10px;padding:6px 24px 14px;align-items:center}
.controls select,.controls input{background:var(--panel2);color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:13px;min-height:38px}
.controls input{min-width:220px;flex:1}

.legend{display:flex;gap:16px;padding:0 24px 12px;color:var(--muted);font-size:12px;flex-wrap:wrap;align-items:center}
.legend i{display:inline-block;width:12px;height:12px;border-radius:3px;margin-right:5px;vertical-align:-1px}
.legend .dot{border-radius:50%}

.count{color:var(--muted);font-size:12px;padding:0 24px 8px}
.p-wrap{padding:0 24px 60px;overflow-x:auto}
table{width:100%;border-collapse:collapse;min-width:1050px}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--line);vertical-align:middle}
th{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;user-select:none;position:sticky;top:0;background:var(--bg)}
th.num,td.num{text-align:right;font-variant-numeric:tabular-nums;white-space:nowrap}
tr.main{cursor:pointer}
tr.main:hover td{background:var(--panel)}

.sem{display:inline-block;width:13px;height:13px;border-radius:50%;vertical-align:-1px}
.sem.verde{background:var(--green)} .sem.amarillo{background:var(--amber)}
.sem.rojo{background:var(--red)} .sem.gris{background:var(--grey)}

.pill{display:inline-block;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.pill.verde{background:#1f3a2e;color:var(--green)} .pill.amarillo{background:#3a341f;color:var(--amber)}
.pill.rojo{background:#3a1f1f;color:var(--red)} .pill.gris{background:#2a2f3a;color:var(--muted)}

.pipe{display:flex;gap:3px;align-items:center}
.seg{width:13px;height:13px;border-radius:3px;background:var(--grey)}
.seg.done{background:var(--green)}
.seg.cur{background:var(--accent);box-shadow:0 0 0 2px rgba(61,169,252,.35)}
.seg.block{background:#34404e}
.seg.desvio{background:var(--red);box-shadow:0 0 0 2px rgba(231,76,60,.35)}

.lote{font-weight:700;font-family:ui-monospace,monospace}
.muted{color:var(--muted)}
.ext{font-size:10px;color:var(--accent);border:1px solid var(--line);border-radius:4px;padding:1px 5px;margin-left:6px}
.rend-bad{color:var(--red)} .rend-ok{color:var(--green)}
td.caret{width:18px;color:var(--muted);transition:transform .15s}
tr.main.open td.caret{transform:rotate(90deg);color:var(--accent)}
tr.detail>td{padding:0;border-bottom:1px solid var(--line);background:var(--panel)}
.detbox{display:none;padding:14px 18px 16px 40px}
tr.detail.open .detbox{display:block}
.detgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;max-width:920px}
.dcell{background:var(--panel2);border:1px solid var(--line);border-radius:9px;padding:8px 11px}
.dcell .lbl{color:var(--muted);font-size:10px;text-transform:uppercase;letter-spacing:.5px}
.dcell .val{font-size:14px;font-weight:600;margin-top:3px;font-variant-numeric:tabular-nums}
.dcell .val.na{color:var(--muted);font-weight:400}

/* Selección de lotes + pedido de informe */
td.sel,th.sel{width:34px;text-align:center}
input[type=checkbox].pick{width:17px;height:17px;cursor:pointer;accent-color:var(--accent);min-width:0}
tr.main.picked td{background:rgba(61,169,252,.10)}
.btn{border:1px solid var(--line);border-radius:8px;padding:9px 16px;font-size:13px;cursor:pointer;font-weight:600;background:var(--panel2);color:var(--txt)}
.btn.primary{background:var(--accent);color:#06223a;border-color:var(--accent)}
.btn.ghost{background:transparent;color:var(--muted)}
.btn:disabled{opacity:.4;cursor:not-allowed}
.cart{position:fixed;left:0;right:0;bottom:0;z-index:50;background:var(--panel2);border-top:1px solid var(--line);
  display:none;align-items:center;gap:14px;padding:12px 24px;box-shadow:0 -8px 24px rgba(0,0,0,.4)}
.cart.show{display:flex}
.cart b{font-size:16px}
.cart .grow{flex:1;color:var(--muted);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.modal{position:fixed;inset:0;z-index:60;background:rgba(0,0,0,.55);display:none;align-items:center;justify-content:center}
.modal.show{display:flex}
.modal .box{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px;width:min(900px,95vw);max-height:88vh;overflow:auto}
.modal h2{margin:0 0 4px;font-size:17px}
.modal .mut{color:var(--muted);font-size:12px;margin-bottom:14px}
.modal label{display:block;font-size:12px;color:var(--muted);margin:10px 0 4px}
.modal input[type=email]{width:100%;min-width:0;background:var(--panel2);color:var(--txt);border:1px solid var(--line);border-radius:8px;padding:9px 11px}
.modal .lots{background:#fff;color:#111;border-radius:9px;padding:8px;max-height:340px;overflow:auto;font-size:12px}
.modal .acts{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}

@media (max-width:560px){
  .p-header,.kpis,.controls,.legend,.count,.p-wrap{padding-left:12px;padding-right:12px}
  .cart{padding-left:12px;padding-right:12px}
}
