
:root{
  --ok:#22c55e; --en-curso:#38bdf8; --en-curso-atrasado:#facc15;
  --no-iniciado-atrasado:#f97316; --atrasado-bloqueado:#ef4444;
  --por-iniciar:#94a3b8; --warning:#f59e0b;
  --bg:#0f172a; --surface:#1e293b; --surface2:#334155;
  --border:#475569; --text:#f1f5f9; --text-muted:#94a3b8; --accent:#3b82f6;
  --red-row:rgba(239,68,68,.25);
  --red-row-solid:#4a1a1a;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:13px}

/* HEADER */
header{background:var(--surface);border-bottom:2px solid var(--border);padding:6px 14px;
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  position:sticky;top:0;z-index:300;flex-wrap:wrap}
.logo{font-size:14px;font-weight:700;color:var(--accent);white-space:nowrap}
.logo span{color:var(--accent);font-weight:700;font-size:14px;margin-left:0}
.header-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
#clock{font-size:10px;color:var(--text-muted);white-space:nowrap}

/* COUNTDOWN */
.cdbox{background:linear-gradient(135deg,rgba(59,130,246,.15),rgba(168,85,247,.15));
  border:1px solid rgba(59,130,246,.4);border-radius:8px;padding:4px 10px;
  display:flex;gap:6px;align-items:center}
.cd-title{font-size:7px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600;white-space:nowrap}
.cd-segs{display:flex;gap:4px;align-items:center}
.cd-seg{text-align:center}
.cd-num{font-size:14px;font-weight:700;color:var(--accent);line-height:1;font-variant-numeric:tabular-nums}
.cd-lbl{font-size:6px;color:var(--text-muted);text-transform:uppercase}
.cd-sep{font-size:12px;font-weight:700;color:var(--text-muted);margin-bottom:4px}

/* AVANCE BOX */
.avbox{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:4px 10px;display:flex;gap:10px;align-items:center}
.av-kpi{text-align:center}
.av-num{font-size:14px;font-weight:700;line-height:1}
.av-lbl{font-size:6px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;margin-top:1px}
.av-div{width:1px;background:var(--border);height:24px}

/* NAV */
.nav-tabs{display:flex;gap:2px;background:var(--bg);padding:2px;border-radius:7px}
.nav-tab{padding:5px 10px;border-radius:5px;cursor:pointer;font-weight:500;font-size:11px;
  border:none;background:transparent;color:var(--text-muted);transition:all .15s;white-space:nowrap}
.nav-tab:hover{background:var(--surface2);color:var(--text)}
.nav-tab.active{background:var(--accent);color:#fff}

main{padding:8px 14px}
.view-panel{display:none}.view-panel.active{display:block}

/* LEGEND */
.legend{display:flex;flex-wrap:wrap;gap:4px 10px;background:var(--surface);
  border:1px solid var(--border);border-radius:8px;padding:6px 10px;margin-bottom:8px}
.leg-title{font-size:7px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;width:100%;margin-bottom:1px}
.leg-item{display:flex;align-items:center;gap:3px;font-size:10px;color:var(--text-muted)}
.leg-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}

/* STATS */
.stats-bar{display:flex;gap:6px;margin-bottom:8px;flex-wrap:wrap}
.stat-card{flex:1;min-width:70px;background:var(--surface);border:1px solid var(--border);
  border-radius:8px;padding:6px 8px;text-align:center}
.stat-num{font-size:17px;font-weight:700}
.stat-lbl{font-size:7px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px}

/* FILTERS */
.filters{display:flex;gap:5px;margin-bottom:8px;flex-wrap:wrap;align-items:center}
.fsel,.finp{background:var(--surface);border:1px solid var(--border);color:var(--text);
  padding:4px 7px;border-radius:6px;font-size:11px;cursor:pointer;outline:none}
.fsel:focus,.finp:focus{border-color:var(--accent)}

/* WARN BUTTON (shared across sheets) */
.warn-btn{background:none;border:none;cursor:pointer;font-size:13px;padding:1px 2px;transition:transform .15s;line-height:1}
.warn-btn:hover{transform:scale(1.25)}

/* STATUS SELECTOR in cards */
.status-sel{background:transparent;border:none;color:inherit;font-size:9px;font-weight:600;
  cursor:pointer;outline:none;padding:2px 4px;border-radius:4px;text-transform:uppercase}
.status-sel:focus{border:1px solid var(--accent)}
.equipo-sel{width:100%;background:transparent;border:none;color:inherit;font-size:13px;
  cursor:pointer;outline:none;padding:1px 2px;border-radius:4px}
.equipo-sel:hover{background:rgba(255,255,255,.08)}
.equipo-sel:focus{border:1px solid var(--accent);background:var(--surface2)}
body.readonly-mode .equipo-sel{pointer-events:none;-webkit-appearance:none;appearance:none;border:none!important;padding-right:0!important}

/* ACTIVITY DETAIL MODAL */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:1000;
  align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.modal-overlay.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;
  width:min(520px,95vw);max-height:88vh;overflow-y:auto;
  box-shadow:0 25px 60px rgba(0,0,0,.6);animation:slideUp .2s ease}
@keyframes slideUp{from{transform:translateY(12px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-hdr{display:flex;align-items:flex-start;justify-content:space-between;
  padding:14px 18px 10px;border-bottom:1px solid var(--border)}
.modal-title{font-size:13px;font-weight:700;line-height:1.3}
.modal-id{font-size:9px;color:var(--text-muted);margin-top:2px;display:flex;align-items:center;gap:4px}
.modal-x{background:var(--surface2);border:none;cursor:pointer;width:25px;height:25px;
  border-radius:6px;display:flex;align-items:center;justify-content:center;
  color:var(--text);font-size:15px;flex-shrink:0;margin-left:7px}
.modal-x:hover{background:var(--border)}
.modal-body{padding:12px 18px 6px}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.detail-item.full{grid-column:1/-1}
.detail-label{font-size:8px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-weight:600;margin-bottom:2px}
.detail-value{font-size:12px;font-weight:500}
/* Modal editable inputs */
.mod-inp{width:100%;background:rgba(255,255,255,.07);border:1px solid var(--border);
  color:var(--text);border-radius:6px;padding:5px 8px;font-size:12px;outline:none;
  box-sizing:border-box;transition:border-color .15s}
.mod-inp:focus{border-color:var(--accent);background:rgba(255,255,255,.1)}
.mod-dt{font-size:11px;color-scheme:dark}
.mod-sel{width:100%;background:var(--surface2);border:1px solid var(--border);
  color:var(--text);border-radius:6px;padding:5px 8px;font-size:12px;outline:none;cursor:pointer}
.mod-sel:focus{border-color:var(--accent)}
.modal-legend-footer{border-top:1px solid var(--border);margin-top:10px;
  padding:7px 18px 10px;display:flex;flex-wrap:wrap;gap:4px 9px}
.mleg-title{font-size:8px;color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px;width:100%;margin-bottom:2px}
.mleg-item{display:flex;align-items:center;gap:3px;font-size:8px;color:var(--text-muted)}
.mleg-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}

/* INCIDENT MODAL */
.inc-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:2000;
  align-items:center;justify-content:center;backdrop-filter:blur(3px)}
.inc-overlay.open{display:flex}
.inc-popup{background:var(--surface);border:2px solid var(--warning);border-radius:12px;
  width:min(960px,96vw);max-height:90vh;overflow-y:auto;
  box-shadow:0 20px 60px rgba(0,0,0,.7);animation:slideUp .2s ease}
.inc-hdr{background:rgba(245,158,11,.1);padding:10px 16px;display:flex;align-items:center;
  gap:7px;border-bottom:1px solid rgba(245,158,11,.3)}
.inc-hdr-title{font-size:13px;font-weight:700;color:var(--warning);flex:1}
.inc-x{background:transparent;border:none;cursor:pointer;color:var(--text-muted);font-size:16px;padding:0 2px}
.inc-x:hover{color:var(--text)}
.inc-body{padding:14px 18px}

/* ── Incidencias panel (resumen global) ── */
.incpanel-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:3000;
  align-items:flex-start;justify-content:center;padding-top:40px;backdrop-filter:blur(4px)}
.incpanel-overlay.open{display:flex}
.incpanel-popup{background:var(--surface);border:1px solid var(--border);border-radius:14px;
  width:min(800px,96vw);max-height:84vh;display:flex;flex-direction:column;
  box-shadow:0 25px 70px rgba(0,0,0,.7);animation:slideUp .2s ease;overflow:hidden}
.incpanel-hdr{padding:14px 18px;display:flex;align-items:center;gap:8px;
  border-bottom:1px solid var(--border);background:rgba(180,83,9,.1);flex-shrink:0}
.incpanel-filters{padding:8px 18px;display:flex;align-items:center;gap:12px;
  border-bottom:1px solid var(--border);background:var(--surface2);flex-shrink:0}
.incpanel-body{padding:12px 18px;overflow-y:auto;flex:1}
/* Activity group */
.ip-act-group{margin-bottom:10px;border:1px solid var(--border);border-radius:8px;overflow:hidden}
.ip-act-hdr{background:var(--surface2);padding:8px 12px;display:flex;align-items:center;
  gap:8px;cursor:pointer;user-select:none;font-size:13px;font-weight:600}
.ip-act-hdr:hover{background:rgba(255,255,255,.07)}
.ip-act-hdr .ip-arrow{font-size:11px;transition:transform .2s;width:14px;flex-shrink:0}
.ip-act-hdr.collapsed .ip-arrow{transform:rotate(-90deg)}
.ip-act-body{padding:8px 12px;display:flex;flex-direction:column;gap:6px}
.ip-act-body.hidden{display:none}
/* Incident row (padre) */
.ip-inc{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:7px;overflow:hidden}
.ip-inc-hdr{padding:7px 10px;display:flex;align-items:flex-start;gap:8px;cursor:pointer;user-select:none}
.ip-inc-hdr:hover{background:rgba(255,255,255,.05)}
.ip-inc-arrow{font-size:10px;margin-top:2px;transition:transform .2s;flex-shrink:0}
.ip-inc.collapsed .ip-inc-arrow{transform:rotate(-90deg)}
.ip-inc-glosa{flex:1;font-size:12px;line-height:1.5}
.ip-inc-ts{font-size:10px;color:var(--text-muted);white-space:nowrap;flex-shrink:0}
/* Children */
.ip-inc-children{padding:0 10px 8px 28px;display:flex;flex-direction:column;gap:4px}
.ip-inc-children.hidden{display:none}
.ip-child{background:rgba(255,255,255,.03);border-left:2px solid var(--border);
  padding:5px 8px;border-radius:0 5px 5px 0;font-size:11px;color:var(--text-muted)}
.ip-child-ts{font-size:10px;opacity:.6}
/* Status badges */
.ip-badge{padding:2px 7px;border-radius:10px;font-size:10px;font-weight:700;text-transform:uppercase;flex-shrink:0}
.ip-badge.abierta{background:rgba(239,68,68,.2);color:#f87171}
.ip-badge.resuelta{background:rgba(250,204,21,.2);color:#fbbf24}
.ip-badge.cerrada{background:rgba(34,197,94,.2);color:#4ade80}
.ip-estado-sel{border:none;cursor:pointer;padding:2px 7px;border-radius:10px;font-size:10px;font-weight:700;text-transform:uppercase;flex-shrink:0;appearance:none;outline:none}
.ip-estado-sel.abierta{background:rgba(239,68,68,.2);color:#f87171}
.ip-estado-sel.resuelta{background:rgba(250,204,21,.2);color:#fbbf24}
.ip-estado-sel.cerrada{background:rgba(34,197,94,.2);color:#4ade80}
.ip-empty{color:var(--text-muted);font-size:13px;text-align:center;padding:30px}


.risk-badge.sin-asignar{background:rgba(148,163,184,.15);color:var(--text-muted)}

.risk-sel{border:none;cursor:pointer;padding:3px 8px;border-radius:8px;font-size:12px;font-weight:600;
  text-transform:uppercase;appearance:none;outline:none;min-width:110px;text-align:center}
.risk-sel.alto{background:rgba(239,68,68,.2);color:#f87171}
.risk-sel.medio{background:rgba(249,115,22,.2);color:#fb923c}
.risk-sel.bajo{background:rgba(250,204,21,.2);color:#fbbf24}
.risk-sel.inexistente{background:rgba(34,197,94,.2);color:#4ade80;cursor:not-allowed}
.risk-sel.sin-asignar{background:rgba(148,163,184,.15);color:var(--text-muted)}

.estado-pill{display:inline-block;padding:2px 8px;border-radius:8px;font-size:11px;font-weight:600}
.rt-filters{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap;align-items:center}

/* ── Padre (rama principal) ── */
.inc-item{background:linear-gradient(135deg,rgba(30,41,59,.95),rgba(30,41,59,.7));
  border-radius:10px;padding:12px 14px;margin-bottom:12px;
  border-left:4px solid var(--border);
  box-shadow:0 2px 10px rgba(0,0,0,.3)}
.inc-item.abierta{border-left-color:var(--atrasado-bloqueado)}
.inc-item.resuelta{border-left-color:var(--en-curso-atrasado)}
.inc-item.cerrada{border-left-color:var(--ok)}
.inc-item-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:8px}
.inc-num{font-size:10px;color:var(--text-muted);font-weight:700;letter-spacing:.3px}
.inc-estado-right{display:flex;align-items:center;gap:6px;flex-shrink:0}
.inc-glosa{font-size:12px;line-height:1.5;margin-bottom:6px;white-space:pre-wrap;word-break:break-word;
  color:var(--text)}
/* Fila edición con textarea y botón a la derecha */
.inc-edit-row{display:flex;gap:8px;align-items:flex-start;margin-bottom:6px}
.inc-edit-row .inc-textarea{flex:1;margin:0;min-height:55px}
.inc-edit-row .btn-save{flex-shrink:0;align-self:flex-end;white-space:nowrap}
.inc-sel{background:var(--surface);border:1px solid var(--border);color:var(--text);
  padding:3px 6px;border-radius:5px;font-size:11px;cursor:pointer;outline:none}
.inc-add{border-top:2px solid rgba(255,255,255,.08);padding-top:12px;margin-top:6px}
.inc-add-title{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:8px}
.inc-textarea{width:100%;background:rgba(255,255,255,.05);border:1px solid var(--border);color:var(--text);
  border-radius:7px;padding:7px 10px;font-size:12px;font-family:inherit;resize:vertical;min-height:60px;outline:none;box-sizing:border-box}
.inc-textarea:focus{border-color:var(--accent);background:rgba(255,255,255,.07)}
.inc-form-row{display:flex;gap:6px;align-items:center;margin-top:8px;flex-wrap:wrap}

/* ── Hijos (actualizaciones) ── */
.inc-updates{margin-top:12px;padding-top:10px;
  border-top:2px dashed rgba(255,255,255,.1)}
.inc-upd-header{font-size:10px;color:var(--accent);font-weight:700;text-transform:uppercase;
  letter-spacing:.7px;margin-bottom:8px;display:flex;align-items:center;gap:5px}
.inc-upd-item{background:rgba(59,130,246,.06);border:1px solid rgba(59,130,246,.15);
  border-left:3px solid var(--accent);
  border-radius:0 7px 7px 0;padding:8px 12px;margin-bottom:7px;margin-left:16px}
.inc-upd-ts{font-size:9px;color:var(--text-muted);margin-bottom:4px;font-weight:600}
.inc-upd-text{font-size:11px;line-height:1.5;white-space:pre-wrap;word-break:break-word;color:var(--text)}
/* Edición de hijo: textarea + botón a la derecha */
.inc-upd-edit-row{display:flex;gap:8px;align-items:flex-start}
.inc-upd-edit-row .inc-textarea{flex:1;min-height:45px;margin:0;font-size:11px}
.inc-upd-edit-row .btn-save{flex-shrink:0;align-self:flex-end;font-size:10px;padding:3px 9px;white-space:nowrap}
.inc-upd-add{margin-top:10px;margin-left:16px;background:rgba(59,130,246,.04);
  border:1px dashed rgba(59,130,246,.25);border-radius:7px;padding:10px}
.inc-upd-add-title{font-size:9px;color:var(--accent);font-weight:700;margin-bottom:6px;
  text-transform:uppercase;letter-spacing:.5px}
.inc-new-sel{background:var(--surface2);border:1px solid var(--border);color:var(--text);
  padding:4px 6px;border-radius:5px;font-size:11px;cursor:pointer;outline:none;flex:1}
.btn-save{padding:4px 12px;border-radius:6px;border:none;cursor:pointer;font-size:11px;font-weight:600;background:var(--accent);color:#fff}
.btn-save:hover{background:#2563eb}
.btn-cancel{padding:4px 10px;border-radius:6px;border:none;cursor:pointer;font-size:11px;background:var(--surface2);color:var(--text-muted)}
.inc-empty{font-size:11px;color:var(--text-muted);text-align:center;padding:6px 0 10px}

/* ─── TABLA GENERAL ─── */
.gt-container{position:relative;}
.gt-wrap{overflow:auto;border:1px solid var(--border);border-radius:10px;
  background:var(--surface);height:calc(100vh - 195px);position:relative}
.gt{border-collapse:separate;border-spacing:0;table-layout:fixed;font-size:14px;}
.gt th,.gt td{border:1px solid rgba(255,255,255,.07);padding:0;vertical-align:middle;text-align:center}
/* Sticky header rows */
.gt thead tr:nth-child(1) th{position:sticky;top:0;z-index:12;background:var(--surface2)!important;
  font-size:14px;padding:5px 3px;border-bottom:none!important;box-shadow:0 1px 0 var(--border);white-space:nowrap}
.gt thead tr:nth-child(2) th{position:sticky;top:37px;z-index:11;background:var(--surface2)!important;
  font-size:13px;font-weight:600;color:var(--text-muted);padding:2px 1px;white-space:nowrap;border-top:none!important}

/* Sticky left columns */
.gt-warn  {width:28px;min-width:28px;max-width:28px;position:sticky;left:0;z-index:10;background:var(--surface)!important}
.gt-id    {width:60px;min-width:60px;max-width:60px;position:sticky;left:28px;z-index:10;background:var(--surface)!important;font-size:12px;color:var(--text-muted)}
.gt-act   {font-size:14px;font-weight:500;width:300px;min-width:300px;max-width:300px;
  text-align:left!important;padding:2px 5px!important;white-space:nowrap;overflow:hidden;
  text-overflow:ellipsis;position:sticky;left:88px;z-index:10;background:var(--surface)!important;cursor:pointer}
.gt-act-inner{display:flex;align-items:center;gap:3px;width:100%;overflow:hidden}
.gt-act-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}
.gt-act-text:hover{text-decoration:underline;color:var(--accent)}
.gt-name-inp{flex:1;background:rgba(59,130,246,.12);border:1px solid var(--accent);color:var(--text);
  border-radius:4px;padding:1px 6px;font-size:13px;font-family:inherit;font-weight:inherit;
  outline:none;min-width:0}
.gt-name-save,.gt-name-cancel{flex-shrink:0;background:transparent;border:none;cursor:pointer;
  font-size:13px;padding:0 2px;line-height:1}
.gt-act.cp{font-weight:700}
body.readonly-mode .gt-act-text{cursor:default;pointer-events:none}
.gt-est   {width:80px;min-width:80px;max-width:80px;position:sticky;left:388px;z-index:10;background:var(--surface)!important;font-size:13px}
.gt-eq    {width:90px;min-width:90px;max-width:90px;position:sticky;left:468px;z-index:10;
  background:var(--surface)!important;font-size:13px;color:var(--text-muted);
  text-align:left!important;padding:2px 4px!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* Columna Responsable — sticky después de Equipo (left: 468+90=558) */
.gt-resp  {width:140px;min-width:140px;max-width:140px;position:sticky;left:558px;z-index:10;
  background:var(--surface)!important;font-size:12px;color:var(--text-muted);
  text-align:left!important;padding:2px 4px!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.resp-inp {width:100%;background:transparent;border:none;color:var(--text);font-size:12px;
  outline:none;cursor:text;font-family:inherit;padding:0}
/* Columna Resp. Revisión — después de Responsable (left: 558+140=698) */
.gt-rrev  {width:140px;min-width:140px;max-width:140px;position:sticky;left:698px;z-index:10;
  background:var(--surface)!important;font-size:12px;color:var(--text-muted);
  text-align:left!important;padding:2px 4px!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rrev-inp {width:100%;background:transparent;border:none;color:var(--text);font-size:12px;
  outline:none;cursor:text;font-family:inherit;padding:0}
/* Posiciones actualizadas tras insertar columnas Responsable y Resp. Revisión (140px cada una) */
.gt-real  {width:65px;min-width:65px;max-width:65px;position:sticky;left:838px;z-index:10;background:var(--surface)!important;font-size:13px}
.gt-esp   {width:65px;min-width:65px;max-width:65px;position:sticky;left:903px;z-index:10;background:var(--surface)!important;font-size:13px}
.gt-inicio{width:155px;min-width:155px;max-width:155px;position:sticky;left:968px;z-index:10;background:var(--surface)!important;font-size:12px;padding:2px 4px!important}
.gt-fin   {width:155px;min-width:155px;max-width:155px;position:sticky;left:1123px;z-index:10;background:var(--surface)!important;font-size:12px;padding:2px 4px!important}
/* Ctrl column (add/delete rows) */
.gt-ctrl{width:52px;min-width:52px;max-width:52px;position:sticky;left:1278px;z-index:10;
  background:var(--surface)!important;text-align:center;padding:2px!important;
  box-shadow:4px 0 8px -2px rgba(0,0,0,.5)}
.ctrl-btn{background:none;border:none;cursor:pointer;padding:2px 4px;border-radius:3px;
  font-size:13px;line-height:1;transition:background .15s}
.ctrl-btn:hover{background:rgba(255,255,255,.12)}
.ctrl-add{color:#4ade80}
.ctrl-del{color:#f87171}

/* Datetime-local input in table */
.gt-dt-inp{width:145px;background:rgba(255,255,255,.05);border:1px solid var(--border);
  color:var(--text);border-radius:4px;padding:1px 4px;font-size:11px;outline:none;cursor:pointer;
  color-scheme:dark}
.gt-dt-inp:focus{border-color:var(--accent)}

/* Sticky headers corner z-index */
.gt thead tr:nth-child(1) th.gt-warn,
.gt thead tr:nth-child(1) th.gt-id,
.gt thead tr:nth-child(1) th.gt-act,
.gt thead tr:nth-child(1) th.gt-est,
.gt thead tr:nth-child(1) th.gt-eq,
.gt thead tr:nth-child(1) th.gt-resp,
.gt thead tr:nth-child(1) th.gt-rrev,
.gt thead tr:nth-child(1) th.gt-esp,
.gt thead tr:nth-child(1) th.gt-real,
.gt thead tr:nth-child(1) th.gt-inicio,
.gt thead tr:nth-child(1) th.gt-fin,
.gt thead tr:nth-child(1) th.gt-ctrl{z-index:20}
.gt thead tr:nth-child(2) th.gt-warn,
.gt thead tr:nth-child(2) th.gt-id,
.gt thead tr:nth-child(2) th.gt-act,
.gt thead tr:nth-child(2) th.gt-est,
.gt thead tr:nth-child(2) th.gt-eq,
.gt thead tr:nth-child(2) th.gt-resp,
.gt thead tr:nth-child(2) th.gt-rrev,
.gt thead tr:nth-child(2) th.gt-esp,
.gt thead tr:nth-child(2) th.gt-real,
.gt thead tr:nth-child(2) th.gt-inicio,
.gt thead tr:nth-child(2) th.gt-fin,
.gt thead tr:nth-child(2) th.gt-ctrl{z-index:20}

/* Hour cells */
.gt-hr{width:55px;min-width:55px;max-width:55px;font-size:11px;color:var(--text-muted)}

/* Data rows */
.gt tbody tr{height:32px}
.gt tbody tr:hover td.gt-warn,
.gt tbody tr:hover td.gt-id,
.gt tbody tr:hover td.gt-act,
.gt tbody tr:hover td.gt-est,
.gt tbody tr:hover td.gt-eq,
.gt tbody tr:hover td.gt-resp,
.gt tbody tr:hover td.gt-rrev,
.gt tbody tr:hover td.gt-esp,
.gt tbody tr:hover td.gt-real,
.gt tbody tr:hover td.gt-inicio,
.gt tbody tr:hover td.gt-fin,
.gt tbody tr:hover td.gt-ctrl{background:var(--surface2)!important;opacity:1!important}
.gt tbody tr.row-red td.gt-warn,
.gt tbody tr.row-red td.gt-id,
.gt tbody tr.row-red td.gt-act,
.gt tbody tr.row-red td.gt-est,
.gt tbody tr.row-red td.gt-eq,
.gt tbody tr.row-red td.gt-resp,
.gt tbody tr.row-red td.gt-rrev,
.gt tbody tr.row-red td.gt-esp,
.gt tbody tr.row-red td.gt-real,
.gt tbody tr.row-red td.gt-inicio,
.gt tbody tr.row-red td.gt-fin,
.gt tbody tr.row-red td.gt-ctrl{background:var(--red-row-solid)!important}
.gt tbody tr.row-red .gt-gantt-cell{background:var(--red-row)!important}
.gt tbody tr.row-red .gt-real{color:#f87171!important;font-weight:700!important}
.gt tbody tr.row-red{outline:1px solid rgba(239,68,68,.35)}

/* Gantt bar cells */
.gt-gantt-cell{position:relative;padding:0;min-width:55px;background:var(--bg)}
.gt-gantt-cell.today-col{background:rgba(59,130,246,.06)}

/* Gantt bar */
.gantt-bar{position:absolute;top:6px;height:20px;border-radius:4px;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:600;color:#fff;overflow:hidden;
  white-space:nowrap;text-overflow:ellipsis;z-index:2;cursor:pointer;
  box-shadow:0 1px 4px rgba(0,0,0,.3);transition:opacity .15s}
.gantt-bar:hover{opacity:.85}

/* Current time red line */
#time-line{position:absolute;top:0;width:2px;background:rgba(239,68,68,.85);
  pointer-events:none;z-index:8;display:none;box-shadow:0 0 6px rgba(239,68,68,.5)}
#time-line-hdr{position:absolute;top:0;width:2px;background:rgba(239,68,68,.85);
  pointer-events:none;z-index:25;display:none}

/* Real progress input */
/* % Real: display text (same format as % Esp), click to edit */
.real-disp{display:inline-block;min-width:32px;text-align:center;font-size:13px}
.real-editable{cursor:pointer;border-bottom:1px dashed var(--text-muted)}
.real-editable:hover{color:var(--accent);border-bottom-color:var(--accent)}
/* small inline input that appears during real% edit */
.real-input{width:48px;background:var(--surface2);border:1px solid var(--accent);
  color:var(--text);border-radius:4px;padding:1px 4px;font-size:13px;outline:none;
  text-align:center;-moz-appearance:textfield}
.real-input::-webkit-outer-spin-button,.real-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}

/* day separator */
.day-sep{border-left:2px solid var(--border)!important}

/* ─── COLUMN RESIZE ─── */
.col-rh{position:absolute;right:-2px;top:0;bottom:0;width:6px;cursor:col-resize;z-index:15;background:transparent;user-select:none}
.col-rh:hover,.col-rh:active{background:rgba(59,130,246,.5)}
/* Los th sticky ya son contexto de posicionamiento; overflow:visible permite que el handle sobresalga */
.gt thead th{overflow:visible!important}
body.col-resizing *{cursor:col-resize!important;user-select:none!important;pointer-events:none!important}
body.col-resizing .col-rh{pointer-events:auto!important}

/* ─── COLUMN PICKER ─── */
.col-picker-wrap{position:relative;flex-shrink:0}
.col-picker-btn{display:flex;align-items:center;gap:6px;padding:5px 13px;
  background:#1e40af;color:#fff;border:none;border-radius:7px;
  font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;
  box-shadow:0 2px 6px rgba(0,0,0,.3)}
.col-picker-btn:hover{background:#1d4ed8}
.col-picker-panel{position:absolute;top:calc(100% + 6px);right:0;
  background:var(--surface);border:1px solid var(--border);border-radius:10px;
  padding:12px 14px;z-index:400;min-width:200px;box-shadow:0 8px 30px rgba(0,0,0,.5);
  display:none}
.col-picker-panel label{display:flex;align-items:center;gap:8px;padding:4px 0;
  cursor:pointer;font-size:13px;white-space:nowrap}
.col-picker-panel label:hover{color:var(--accent)}
.col-picker-panel label input[type=checkbox]{width:14px;height:14px;cursor:pointer;accent-color:var(--accent)}

/* Tooltip */
.tooltip-wrap{position:relative;display:inline-block;max-width:100%;overflow:hidden;
  white-space:nowrap;text-overflow:ellipsis}
.tooltip-wrap .tooltip-text{visibility:hidden;min-width:200px;max-width:380px;background:var(--surface2);
  border:1px solid var(--border);color:var(--text);font-size:12px;border-radius:6px;
  padding:5px 8px;position:absolute;z-index:500;left:0;top:calc(100% + 3px);
  white-space:normal;word-break:break-word;box-shadow:0 4px 15px rgba(0,0,0,.4)}
.tooltip-wrap:hover .tooltip-text{visibility:visible}

/* ─── TURNOS VIEW ─── */
.turnos-container{display:flex;flex-direction:column;gap:12px}
.turno-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.turno-header{display:flex;align-items:center;gap:10px;padding:9px 12px;
  background:linear-gradient(135deg,rgba(59,130,246,.15),rgba(168,85,247,.1));
  border-bottom:1px solid var(--border)}
.turno-name{font-size:13px;font-weight:700;color:var(--accent)}
.turno-dates{font-size:10px;color:var(--text-muted)}
.turno-body{padding:8px 10px;display:flex;flex-direction:column;gap:6px}
.turno-task-row{display:flex;align-items:center;gap:8px}
.turno-task-label{font-size:12px;min-width:220px;max-width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.turno-gantt-wrap{flex:1;background:var(--bg);border-radius:4px;height:28px;position:relative;overflow:hidden;min-width:400px}
.turno-bar{position:absolute;top:4px;height:20px;border-radius:3px;display:flex;align-items:center;
  justify-content:center;font-size:11px;font-weight:600;color:#fff;overflow:hidden;
  white-space:nowrap;text-overflow:ellipsis;padding:0 4px}
.turno-hr-labels{display:flex;font-size:9px;color:var(--text-muted);margin-top:2px;padding-left:228px}
.turno-hr-lbl{flex:1;text-align:center;min-width:0}

/* LOGIN */
#login-overlay{position:fixed;inset:0;background:#0f172a;z-index:9999;display:flex;align-items:center;justify-content:center}
.login-box{background:#1e293b;border:1px solid #334155;border-radius:16px;padding:36px 40px;width:340px;box-shadow:0 25px 60px rgba(0,0,0,.7);display:flex;flex-direction:column;gap:14px;align-items:center}
.login-logo{font-size:18px;font-weight:800;color:#f1f5f9;text-align:center}.login-logo span{color:#3b82f6;font-weight:400;font-size:13px;display:block;margin-top:2px}
.login-title{font-size:12px;color:#94a3b8;letter-spacing:.5px;text-transform:uppercase;font-weight:600}
.login-input{width:100%;background:#0f172a;border:1px solid #475569;color:#f1f5f9;border-radius:8px;padding:9px 12px;font-size:13px;outline:none}
.login-input:focus{border-color:#3b82f6}
.login-btn{width:100%;padding:10px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;letter-spacing:.3px}
.login-btn:hover{background:#2563eb}
.login-err{color:#ef4444;font-size:11px;text-align:center;display:none}
/* READONLY MODE */
body.readonly-mode .status-sel{pointer-events:none;-webkit-appearance:none;appearance:none;border:none!important;padding-right:0!important}
body.readonly-mode .real-editable{pointer-events:none;cursor:default;border-bottom:none}
body.readonly-mode .inc-sel{pointer-events:none;-webkit-appearance:none;appearance:none;border:none!important;background:transparent!important;cursor:default}
body.readonly-mode #hora-actual{pointer-events:none;opacity:.6;cursor:default}
body.readonly-mode .gt-dt-inp{pointer-events:none;background:transparent!important;border:none!important;cursor:default;opacity:.75}
body.readonly-mode .inc-add{display:none!important}
body.readonly-mode #shift-dates-btn{display:none!important}
body.readonly-mode #clear-obs-btn{display:none!important}
body.readonly-mode .btn-save{display:none!important}
body.readonly-mode .btn-cancel{display:none!important;}

/* ═══ PROJECTS ═══ */
.proj-sel-wrap{display:flex;align-items:center;gap:6px;background:var(--surface2);
  border:1px solid var(--border);border-radius:8px;padding:4px 10px;flex-shrink:0}
.proj-sel-lbl{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;white-space:nowrap}
.proj-sel{background:var(--surface);border:1px solid var(--border);color:var(--text);
  padding:4px 8px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;outline:none;min-width:160px}
.proj-sel:focus{border-color:var(--accent)}

/* New project modal */
.newproj-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:4000;
  align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.newproj-overlay.open{display:flex}
.newproj-popup{background:var(--surface);border:1px solid var(--border);border-radius:14px;
  width:min(480px,94vw);padding:24px;box-shadow:0 20px 60px rgba(0,0,0,.7)}
.newproj-title{font-size:16px;font-weight:700;margin-bottom:18px;color:var(--text)}
.newproj-field{margin-bottom:14px}
.newproj-field label{display:block;font-size:11px;color:var(--text-muted);text-transform:uppercase;
  letter-spacing:.4px;margin-bottom:5px}
.newproj-field input[type=text],.newproj-field select{width:100%;background:var(--surface2);
  border:1px solid var(--border);color:var(--text);border-radius:7px;padding:8px 10px;
  font-size:13px;outline:none}
.newproj-field input[type=text]:focus,.newproj-field select:focus{border-color:var(--accent)}
.newproj-radio-row{display:flex;gap:16px;margin-top:4px}
.newproj-radio-row label{display:flex;align-items:center;gap:6px;font-size:13px;
  color:var(--text);cursor:pointer;text-transform:none;letter-spacing:0}
.newproj-btns{display:flex;gap:8px;justify-content:flex-end;margin-top:20px}
.newproj-btns button{padding:8px 20px;border-radius:8px;font-size:13px;font-weight:600;
  cursor:pointer;border:none}
.newproj-btn-confirm{background:var(--accent);color:#fff}
.newproj-btn-confirm:hover{background:#2563eb}
.newproj-btn-cancel{background:var(--surface2);color:var(--text);border:1px solid var(--border)!important}
.newproj-btn-cancel:hover{background:var(--border)}

/* ═══ USER MANAGEMENT ═══ */
.umgmt-modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;
  padding:0;width:min(700px,96vw);max-height:88vh;display:flex;flex-direction:column;
  box-shadow:0 20px 60px rgba(0,0,0,.6)}
.umgmt-hdr{display:flex;justify-content:space-between;align-items:center;
  padding:16px 20px;border-bottom:1px solid var(--border)}
.umgmt-hdr-title{font-size:15px;font-weight:700}
.umgmt-body{overflow-y:auto;padding:16px 20px;flex:1}
.umgmt-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
  color:var(--text-muted);margin:14px 0 8px}
.umgmt-user-row{display:flex;align-items:center;gap:8px;padding:7px 10px;
  border-radius:8px;background:var(--surface2);margin-bottom:6px;flex-wrap:wrap}
.umgmt-user-badge{font-size:10px;padding:2px 7px;border-radius:10px;font-weight:600}
.umgmt-user-badge.admin{background:rgba(59,130,246,.2);color:#93c5fd}
.umgmt-user-badge.viz{background:rgba(148,163,184,.15);color:#94a3b8}
.umgmt-user-badge.builtin{background:rgba(99,102,241,.15);color:#a5b4fc;font-size:9px}
.umgmt-add-form{background:var(--surface2);border:1px solid var(--border);border-radius:10px;
  padding:14px;margin-top:10px}
.umgmt-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.umgmt-form-field label{display:block;font-size:10px;color:var(--text-muted);font-weight:600;
  text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px}
.umgmt-form-field input,.umgmt-form-field select{width:100%;background:#0f172a;
  border:1px solid var(--border);color:var(--text);border-radius:6px;padding:7px 9px;
  font-size:12px;outline:none;box-sizing:border-box}
.umgmt-form-field input:focus,.umgmt-form-field select:focus{border-color:var(--accent)}
.umgmt-proj-list{display:flex;flex-wrap:wrap;gap:5px;margin-top:4px}
.umgmt-proj-chip{display:flex;align-items:center;gap:4px;background:var(--surface);
  border:1px solid var(--border);border-radius:6px;padding:3px 8px;font-size:11px}
.umgmt-proj-chip input[type=checkbox]{margin:0;accent-color:var(--accent)}
