
:root{
  --ok:#22c55e; --en-curso:#38bdf8; --en-curso-atrasado:#facc15;
  --no-iniciado-atrasado:#f97316; --atrasado-bloqueado:#ef4444;
  --por-iniciar:#94a3b8; --warning:#f59e0b;
  /* Paleta más clara: azul-pizarra medio (antes era muy oscuro) */
  --bg:#18253a;        /* antes #0f172a */
  --surface:#243448;   /* antes #1e293b */
  --surface2:#354d66;  /* antes #334155 */
  --border:#4e6882;    /* antes #475569 */
  --text:#f1f5f9; --text-muted:#a8bdd4; --accent:#3b82f6;
  --red-row:rgba(239,68,68,.22);
  --red-row-solid:#531f1f;
  --clave-row-solid:#342f14;  /* amber sólido para filas clave */
  --clave-replan-row-solid:#3d1c00; /* naranja oscuro para filas clave con (Replan) */
}
*{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}
/* Logo de proyecto — integrado en la barra izquierda junto a Inligo y nombre proyecto */

/* Overlay de cámara sobre logo de proyecto — visible solo al hacer hover */
.proj-logo-hover .proj-logo-cam{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  background:rgba(0,0,0,.6);
  font-size:14px;
  opacity:0;
  transition:opacity .2s;
  pointer-events:none; /* el click lo recibe el padre */
}
/* Solo mostrar la cámara si el admin puede editar (clase .admin-active en body o wrapper) */
.proj-logo-hover:hover .proj-logo-cam{opacity:1}
/* Cuando el usuario NO es admin, no se muestra cursor pointer ni overlay */
body.role-vista .proj-logo-hover{cursor:default;pointer-events:none}
body.role-vista #proj-logo-add-btn{display:none!important}
#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}
/* Dashboard: sin padding, ocupa todo el espacio bajo header+nav */
#tab-dashboard.active{padding:0;overflow:hidden}
/* Modo fullscreen nativo — el elemento llena toda la pantalla */
#tab-dashboard:fullscreen,#tab-dashboard:-webkit-full-screen{
  background:var(--bg);width:100vw;height:100vh;overflow:hidden}
#tab-dashboard:fullscreen #dashboard-content,
#tab-dashboard:-webkit-full-screen #dashboard-content{height:100vh}

/* 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;}
/* Body cells: separator via border-bottom (spans full row width including sticky cells) */
.gt th,.gt td{border:1px solid rgba(255,255,255,.07);padding:0;vertical-align:middle;text-align:center}
.gt tbody td{border:none;border-bottom:1px solid rgba(80,110,160,.35)}
/* 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 — z-index:15 so they always render ABOVE gantt header rows (z-index:11/12) */
.gt-warn  {width:28px;min-width:28px;max-width:28px;position:sticky;left:0;z-index:15;background:var(--surface)!important}
.gt-id    {width:60px;min-width:60px;max-width:60px;position:sticky;left:28px;z-index:15;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:15;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:15;background:var(--surface)!important;font-size:13px}
.gt-eq    {width:90px;min-width:90px;max-width:90px;position:sticky;left:468px;z-index:15;
  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 Agrupador — después de Equipo (left: 468+90=558) */
.gt-agr   {width:100px;min-width:100px;max-width:100px;position:sticky;left:558px;z-index:15;
  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}
.agr-inp  {width:100%;background:transparent;border:none;color:var(--text);font-size:12px;
  outline:none;cursor:text;font-family:inherit;padding:0}
/* Columna Responsable — sticky después de Agrupador (left: 558+100=658) */
.gt-resp  {width:140px;min-width:140px;max-width:140px;position:sticky;left:658px;z-index:15;
  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: 658+140=798) */
.gt-rrev  {width:140px;min-width:140px;max-width:140px;position:sticky;left:798px;z-index:15;
  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 Agrupador (100px), Responsable (140px), Resp. Revisión (140px) */
.gt-real  {width:65px;min-width:65px;max-width:65px;position:sticky;left:938px;z-index:15;background:var(--surface)!important;font-size:13px}
.gt-esp   {width:65px;min-width:65px;max-width:65px;position:sticky;left:1003px;z-index:15;background:var(--surface)!important;font-size:13px}
.gt-dep   {width:60px;min-width:60px;max-width:60px;position:sticky;left:1068px;z-index:15;background:var(--surface)!important;font-size:12px;text-align:left!important;padding:2px 4px!important}
.gt-inicio{width:155px;min-width:155px;max-width:155px;position:sticky;left:1128px;z-index:15;background:var(--surface)!important;font-size:12px;padding:2px 4px!important}
.gt-fin   {width:155px;min-width:155px;max-width:155px;position:sticky;left:1283px;z-index:15;background:var(--surface)!important;font-size:12px;padding:2px 4px!important}
/* Ctrl column (add/delete rows) — right-side shadow marks the boundary between fixed cols and gantt */
.gt-ctrl{width:52px;min-width:52px;max-width:52px;position:sticky;left:1438px;z-index:15;
  background:var(--surface)!important;text-align:center;padding:2px!important}
/* Right-shadow on ctrl column marks the boundary between fixed info cols and scrolling gantt */
.gt tbody td.gt-ctrl{box-shadow:3px 0 6px -1px rgba(0,0,0,.5)!important}
.gt thead th.gt-ctrl{box-shadow:3px 0 6px -1px rgba(0,0,0,.4)}
.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 display (24h text) in table — clicking opens the hidden datetime-local input */
.gt-dt-disp{display:inline-block;width:100%;font-size:11px;color:var(--text);padding:2px 4px;
  border-radius:4px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  border:1px solid transparent;transition:border-color .15s}
.gt-dt-disp:hover{border-color:var(--border);background:rgba(255,255,255,.05)}
.gt-dt-disp.empty{color:var(--text-muted);font-style:italic}
body.readonly-mode .gt-dt-disp{cursor:default;pointer-events:none;opacity:.75}
/* Datetime-local input in table — hidden by default, revealed on span click */
.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}
/* Hover — must beat nth-child rules above; using :nth-child(n) to raise specificity */
.gt tbody tr:nth-child(n):hover td.gt-warn,
.gt tbody tr:nth-child(n):hover td.gt-id,
.gt tbody tr:nth-child(n):hover td.gt-act,
.gt tbody tr:nth-child(n):hover td.gt-est,
.gt tbody tr:nth-child(n):hover td.gt-eq,
.gt tbody tr:nth-child(n):hover td.gt-agr,
.gt tbody tr:nth-child(n):hover td.gt-resp,
.gt tbody tr:nth-child(n):hover td.gt-rrev,
.gt tbody tr:nth-child(n):hover td.gt-esp,
.gt tbody tr:nth-child(n):hover td.gt-real,
.gt tbody tr:nth-child(n):hover td.gt-dep,
.gt tbody tr:nth-child(n):hover td.gt-inicio,
.gt tbody tr:nth-child(n):hover td.gt-fin,
.gt tbody tr:nth-child(n):hover td.gt-ctrl{background:#2a3f62!important;opacity:1!important}
.gt tbody tr:nth-child(n):hover .gt-gantt-cell{background:#1e3258!important}
.gt tbody tr.row-red:nth-child(n) td.gt-warn,
.gt tbody tr.row-red:nth-child(n) td.gt-id,
.gt tbody tr.row-red:nth-child(n) td.gt-act,
.gt tbody tr.row-red:nth-child(n) td.gt-est,
.gt tbody tr.row-red:nth-child(n) td.gt-eq,
.gt tbody tr.row-red:nth-child(n) td.gt-agr,
.gt tbody tr.row-red:nth-child(n) td.gt-resp,
.gt tbody tr.row-red:nth-child(n) td.gt-rrev,
.gt tbody tr.row-red:nth-child(n) td.gt-esp,
.gt tbody tr.row-red:nth-child(n) td.gt-real,
.gt tbody tr.row-red:nth-child(n) td.gt-dep,
.gt tbody tr.row-red:nth-child(n) td.gt-inicio,
.gt tbody tr.row-red:nth-child(n) td.gt-fin,
.gt tbody tr.row-red:nth-child(n) 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}
/* Row-red indicator: left border on the warn cell (outline on tr is not reliable in all browsers) */
.gt tbody tr.row-red td.gt-warn{border-left:3px solid rgba(239,68,68,.7)!important}

/* ── Checkpoint row highlight — usa CSS vars para permitir color custom por fila ── */
/* Los vars --row-clave-accent / --row-clave-bg / --row-clave-gantt se pueden
   definir inline en el <tr> para aplicar un color personalizado por actividad.
   Si no están definidos, se usa el color por defecto de la clase. */
.gt tbody tr.row-clave:nth-child(n) td.gt-warn,
.gt tbody tr.row-clave:nth-child(n) td.gt-id,
.gt tbody tr.row-clave:nth-child(n) td.gt-act,
.gt tbody tr.row-clave:nth-child(n) td.gt-est,
.gt tbody tr.row-clave:nth-child(n) td.gt-eq,
.gt tbody tr.row-clave:nth-child(n) td.gt-agr,
.gt tbody tr.row-clave:nth-child(n) td.gt-resp,
.gt tbody tr.row-clave:nth-child(n) td.gt-rrev,
.gt tbody tr.row-clave:nth-child(n) td.gt-esp,
.gt tbody tr.row-clave:nth-child(n) td.gt-real,
.gt tbody tr.row-clave:nth-child(n) td.gt-dep,
.gt tbody tr.row-clave:nth-child(n) td.gt-inicio,
.gt tbody tr.row-clave:nth-child(n) td.gt-fin,
.gt tbody tr.row-clave:nth-child(n) td.gt-ctrl{background:var(--row-clave-bg,var(--clave-row-solid))!important}
.gt tbody tr.row-clave .gt-gantt-cell{background:var(--row-clave-gantt,rgba(251,191,36,.15))!important}
.gt tbody tr.row-clave td.gt-warn{border-left:3px solid var(--row-clave-accent,#fbbf24)!important}
.gt tbody tr.row-clave td.gt-act{color:var(--row-clave-accent,#fbbf24)!important;font-weight:700!important}

/* Actividad Clave con "(Replan)" en el nombre — destaque naranja en vez de amarillo */
.gt tbody tr.row-clave-replan:nth-child(n) td.gt-warn,
.gt tbody tr.row-clave-replan:nth-child(n) td.gt-id,
.gt tbody tr.row-clave-replan:nth-child(n) td.gt-act,
.gt tbody tr.row-clave-replan:nth-child(n) td.gt-est,
.gt tbody tr.row-clave-replan:nth-child(n) td.gt-eq,
.gt tbody tr.row-clave-replan:nth-child(n) td.gt-agr,
.gt tbody tr.row-clave-replan:nth-child(n) td.gt-resp,
.gt tbody tr.row-clave-replan:nth-child(n) td.gt-rrev,
.gt tbody tr.row-clave-replan:nth-child(n) td.gt-esp,
.gt tbody tr.row-clave-replan:nth-child(n) td.gt-real,
.gt tbody tr.row-clave-replan:nth-child(n) td.gt-dep,
.gt tbody tr.row-clave-replan:nth-child(n) td.gt-inicio,
.gt tbody tr.row-clave-replan:nth-child(n) td.gt-fin,
.gt tbody tr.row-clave-replan:nth-child(n) td.gt-ctrl{background:var(--row-clave-bg,var(--clave-replan-row-solid))!important}
.gt tbody tr.row-clave-replan .gt-gantt-cell{background:var(--row-clave-gantt,rgba(249,115,22,.15))!important}
.gt tbody tr.row-clave-replan td.gt-warn{border-left:3px solid var(--row-clave-accent,#f97316)!important}
.gt tbody tr.row-clave-replan td.gt-act{color:var(--row-clave-accent,#f97316)!important;font-weight:700!important}

/* Padre con subtareas clave — mismo destaque que actividad clave directa */
.gt tbody tr.row-clave-child:nth-child(n) td.gt-warn,
.gt tbody tr.row-clave-child:nth-child(n) td.gt-id,
.gt tbody tr.row-clave-child:nth-child(n) td.gt-act,
.gt tbody tr.row-clave-child:nth-child(n) td.gt-est,
.gt tbody tr.row-clave-child:nth-child(n) td.gt-eq,
.gt tbody tr.row-clave-child:nth-child(n) td.gt-agr,
.gt tbody tr.row-clave-child:nth-child(n) td.gt-resp,
.gt tbody tr.row-clave-child:nth-child(n) td.gt-rrev,
.gt tbody tr.row-clave-child:nth-child(n) td.gt-esp,
.gt tbody tr.row-clave-child:nth-child(n) td.gt-real,
.gt tbody tr.row-clave-child:nth-child(n) td.gt-dep,
.gt tbody tr.row-clave-child:nth-child(n) td.gt-inicio,
.gt tbody tr.row-clave-child:nth-child(n) td.gt-fin,
.gt tbody tr.row-clave-child:nth-child(n) td.gt-ctrl{background:var(--row-clave-bg,var(--clave-row-solid))!important}
.gt tbody tr.row-clave-child .gt-gantt-cell{background:var(--row-clave-gantt,rgba(251,191,36,.15))!important}
.gt tbody tr.row-clave-child td.gt-warn{border-left:3px solid var(--row-clave-accent,#fbbf24)!important}
.gt tbody tr.row-clave-child td.gt-act{color:var(--row-clave-accent,#fbbf24)!important;font-weight:700!important}

/* ── Estado (Antiguo) — fila atenuada con tono gris ───────────────────────── */
.gt tbody tr.row-antiguo { opacity:0.5; }
.gt tbody tr.row-antiguo td.gt-warn { border-left:3px solid #78716c!important; }
.gt tbody tr.row-antiguo td.gt-act { color:#78716c!important; font-weight:400!important; }
.gt tbody tr.row-antiguo .gt-gantt-cell { filter:grayscale(1)!important; opacity:0.4!important; }

/* ── Gantt cell base ──────────────────────────────────────────────────────── */
.gt-gantt-cell{position:relative;padding:0;min-width:55px;
  border:none!important;border-bottom:1px solid rgba(80,110,160,.35)!important}

/* ── Nota de mantenimiento ────────────────────────────────────────────────────
   Las celdas sticky (gt-warn, gt-id, gt-act, etc.) DEBEN tener fondos opacos.
   La función _claveRowColorStyle en app.js produce --row-clave-bg como color
   hex sólido (blended con --surface) en lugar de rgba semitransparente.
   No usar rgba() para --row-clave-bg — causa que el Gantt se vea a través de
   las celdas sticky al hacer scroll horizontal. */

/* ── Alternating row colors — ODD rows (default) ─────────────────────────── */
/* Gantt area: slightly lighter blue-navy */
.gt tbody tr:nth-child(odd) .gt-gantt-cell{background:#1a2d48}
/* Info (sticky) columns: same tone, slightly brighter to separate from gantt */
.gt tbody tr:nth-child(odd) td.gt-warn,
.gt tbody tr:nth-child(odd) td.gt-id,
.gt tbody tr:nth-child(odd) td.gt-act,
.gt tbody tr:nth-child(odd) td.gt-est,
.gt tbody tr:nth-child(odd) td.gt-eq,
.gt tbody tr:nth-child(odd) td.gt-agr,
.gt tbody tr:nth-child(odd) td.gt-resp,
.gt tbody tr:nth-child(odd) td.gt-rrev,
.gt tbody tr:nth-child(odd) td.gt-real,
.gt tbody tr:nth-child(odd) td.gt-esp,
.gt tbody tr:nth-child(odd) td.gt-dep,
.gt tbody tr:nth-child(odd) td.gt-inicio,
.gt tbody tr:nth-child(odd) td.gt-fin,
.gt tbody tr:nth-child(odd) td.gt-ctrl{background:#1f3352!important}

/* ── Alternating row colors — EVEN rows (darker, clear contrast) ─────────── */
.gt tbody tr:nth-child(even) .gt-gantt-cell{background:#0e1e34}
.gt tbody tr:nth-child(even) td.gt-warn,
.gt tbody tr:nth-child(even) td.gt-id,
.gt tbody tr:nth-child(even) td.gt-act,
.gt tbody tr:nth-child(even) td.gt-est,
.gt tbody tr:nth-child(even) td.gt-eq,
.gt tbody tr:nth-child(even) td.gt-agr,
.gt tbody tr:nth-child(even) td.gt-resp,
.gt tbody tr:nth-child(even) td.gt-rrev,
.gt tbody tr:nth-child(even) td.gt-real,
.gt tbody tr:nth-child(even) td.gt-esp,
.gt tbody tr:nth-child(even) td.gt-dep,
.gt tbody tr:nth-child(even) td.gt-inicio,
.gt tbody tr:nth-child(even) td.gt-fin,
.gt tbody tr:nth-child(even) td.gt-ctrl{background:#142038!important}

/* Row-red overrides (preserves error highlighting) */
.gt tbody tr.row-red .gt-gantt-cell{background:var(--red-row)!important}
.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 — positioned with 'left' (no transform/will-change).
   Lives inside .gt-wrap (overflow:auto) so 'left:Npx' places it in table-
   coordinate space and it scrolls naturally with the content.
   Using transform would risk promoting this to a GPU layer and breaking
   position:sticky on the <thead> cells (vertical scroll stops working). */
#time-line{position:absolute;top:0;left:0;width:2px;background:rgba(239,68,68,.9);
  pointer-events:none;z-index:8;display:none}
#time-line-hdr{position:absolute;top:0;width:2px;background:rgba(239,68,68,.9);
  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:9000;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}

/* Fix tooltip visibility in subtask table — allow overflow without clipping the tooltip bubble */
#st-table tbody tr{position:relative}
#st-table tbody tr:hover{z-index:10}
#st-table .tooltip-wrap{overflow:visible}
#st-table td.st-col-name{overflow: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;}
body.readonly-mode #import-act-btn{display:none!important}
body.readonly-mode #import-status-btn{display:none!important}
body.readonly-mode #bulk-sub-import-btn{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)}

/* ── Column-mapping step inside import modals ── */
.col-map-step{border:1px solid var(--border);border-radius:8px;padding:12px 14px;
  margin-bottom:14px;background:var(--surface2)}
.col-map-step h4{font-size:12px;font-weight:700;color:var(--text);margin-bottom:10px}
.col-map-grid{display:grid;grid-template-columns:auto 1fr;gap:5px 10px;align-items:center}
.col-map-label{font-size:11px;font-weight:600;color:var(--text-muted);white-space:nowrap}
.col-map-label.req{color:var(--accent)}
.col-map-sel{background:#0f172a;border:1px solid var(--border);color:var(--text);
  border-radius:5px;padding:3px 6px;font-size:11px;outline:none;width:100%;max-width:280px;
  cursor:pointer}
.col-map-sel:focus{border-color:var(--accent)}

/* ═════════════════════ REPORTE DE ATRASOS ═════════════════════ */
.atrs-table{width:100%;border-collapse:collapse;font-size:12px}
.atrs-table th{background:var(--surface2);padding:6px 10px;text-align:left;font-size:11px;
  font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:2}
.atrs-table td{padding:5px 10px;border-bottom:1px solid rgba(71,85,105,.3);vertical-align:middle}
.atrs-row-delayed{background:rgba(239,68,68,.08)}
.atrs-row-delayed:hover{background:rgba(239,68,68,.14)}
.atrs-row-parent-only{background:transparent}
.atrs-row-parent-only:hover{background:rgba(255,255,255,.03)}
.atrs-sub-row{background:rgba(30,41,59,.5)}
.atrs-sub-row:hover{background:rgba(30,41,59,.8)}
.atrs-toggle{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:11px;padding:0;width:18px}
.atrs-id{font-size:11px;color:var(--text-muted);white-space:nowrap;font-family:monospace}
.atrs-name{font-weight:500;max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.atrs-agr,.atrs-eq{font-size:11px;color:var(--text-muted);white-space:nowrap;max-width:100px;overflow:hidden;text-overflow:ellipsis}
.atrs-estado{white-space:nowrap}
.atrs-dt{font-size:11px;white-space:nowrap;font-variant-numeric:tabular-nums}
.atrs-estado-sel{background:var(--surface2);border:1px solid var(--border);color:var(--text);
  border-radius:5px;padding:2px 6px;font-size:11px;outline:none;cursor:pointer}
.atrs-filters-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;
  margin-bottom:10px;padding:8px 10px;background:var(--surface2);border:1px solid var(--border);
  border-radius:8px}


/* ─── DRAG TO REORDER ─── */
.gt-row{cursor:grab}
.gt-row.dnd-dragging{opacity:.4;cursor:grabbing}
.gt-row.dnd-over{outline:2px solid var(--accent);outline-offset:-1px}

/* ─── EDITABLE ID INPUT ─── */
.gt-id-inp{width:88%;background:rgba(59,130,246,.12);border:1px solid var(--accent);color:var(--text);
  border-radius:4px;padding:1px 4px;font-size:11px;outline:none;font-family:inherit}

/* ─── DATA QUALITY REPORT ─── */
.dq-act-row{background:rgba(239,68,68,.05)}
.dq-act-row:hover{background:rgba(239,68,68,.1)}
.dq-sub-row{background:rgba(30,41,59,.5)}
.dq-sub-row:hover{background:rgba(30,41,59,.8)}
.dq-inp{width:100%;background:rgba(255,255,255,.05);border:1px solid var(--border);color:var(--text);
  border-radius:4px;padding:2px 5px;font-size:11px;outline:none;font-family:inherit}
.dq-inp:focus{border-color:var(--accent)}
.dq-dt{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;color-scheme:dark;width:100%}
.dq-sel{width:100%;background:var(--surface2);border:1px solid var(--border);color:var(--text);
  border-radius:4px;padding:2px 4px;font-size:11px;outline:none;cursor:pointer}

/* ── Dashboard pantalla completa ──────────────────────────────────── */
/* En fullscreen se ocultan nav tabs, avbox y countdown; se mantiene
   el header con logos y el selector de proyecto. */
body.dash-is-fullscreen .nav-tabs{display:none!important}
body.dash-is-fullscreen .avbox{display:none!important}
body.dash-is-fullscreen .cdbox{display:none!important}
body.dash-is-fullscreen main{padding:0!important}
/* Header ligeramente más compacto */
body.dash-is-fullscreen header{padding:4px 14px!important}
/* Ocultar otros paneles (ya tienen display:none pero por si acaso) */
body.dash-is-fullscreen .view-panel:not(#tab-dashboard){display:none!important}
/* El dashboard ocupa el alto restante; dashH inline se recalcula desde JS */
body.dash-is-fullscreen #tab-dashboard.active{height:calc(100dvh - 46px);overflow:hidden}
.atrs-resp{font-size:11px;color:var(--text-muted);white-space:nowrap;max-width:140px;overflow:hidden;text-overflow:ellipsis}
/* ─── Roadmap: ocultar scrollbar nativo en rm-body ──────────────────── */
/* La barra de scroll horizontal es funcional pero invisible (autoscroll y táctil la usan) */
#rm-body::-webkit-scrollbar{display:none}
#rm-body{scrollbar-width:none;-ms-overflow-style:none;overflow-y:hidden}
/* ─── Roadmap pantalla completa ─────────────────────────────────────── */
body.rm-is-fullscreen .view-panel:not(#tab-roadmap){display:none!important}
body.rm-is-fullscreen main{padding:0!important}
body.rm-is-fullscreen header{padding:4px 14px!important}
body.rm-is-fullscreen .nav-tabs{display:none!important}
body.rm-is-fullscreen .avbox{display:none!important}
body.rm-is-fullscreen .cdbox{display:none!important}
body.rm-is-fullscreen #tab-roadmap.active{height:calc(100dvh - 46px)!important;overflow:hidden}
/* ─── Pantalla Adicional – modo normal ───────────────────────── */
/* El inline style="display:flex" del tab tiene mayor especificidad que .view-panel{display:none}.
   Lo corregimos con !important para que el tab se oculte correctamente cuando no está activo. */
#tab-recursos-externos:not(.active){display:none!important}
/* Altura concreta en modo normal: viewport - header(~46px) - padding main(8px×2=16px) */
#tab-recursos-externos.active{
  display:flex!important;flex-direction:column!important;
  height:calc(100dvh - 62px)!important;overflow:hidden!important;
  padding:0!important;margin:0!important;
}
/* ─── Pantalla Adicional – fullscreen ────────────────────────── */
body.ext-is-fullscreen .view-panel:not(#tab-recursos-externos){display:none!important}
body.ext-is-fullscreen main{padding:0!important}
body.ext-is-fullscreen header{padding:4px 14px!important}
body.ext-is-fullscreen .nav-tabs{display:none!important}
body.ext-is-fullscreen .avbox{display:none!important}
body.ext-is-fullscreen .cdbox{display:none!important}
/* Sin barra superior en la pestaña: el contenido ocupa todo el alto disponible */
body.ext-is-fullscreen #tab-recursos-externos.active{height:calc(100dvh - 46px)!important;overflow:hidden!important}
body.ext-is-fullscreen #tab-recursos-externos.active #ext-content-area{height:100%!important}

/* ─── Post Go-Live ─────────────────────────────────────────── */
/*
 * MODO NORMAL: sin altura fija → el tab crece con el contenido y la página
 * hace scroll. Esto elimina completamente el solapamiento de tarjetas.
 * MODO FULLSCREEN: altura fija = viewport − header compacto (46px) para que
 * #pgl-charts sea el scroll container sin que la página haga scroll.
 */
#tab-postgolive:not(.active){display:none!important}
#tab-postgolive.active{
  display:flex!important;flex-direction:row!important;
  padding:0!important;margin:0!important;
  /* SIN height explícita → height:auto → tarjetas apiladas sin solapamiento */
}

/* Post Go-Live fullscreen */
body.pgl-is-fullscreen .view-panel:not(#tab-postgolive){display:none!important}
body.pgl-is-fullscreen main{padding:0!important}
body.pgl-is-fullscreen header{padding:4px 14px!important}
body.pgl-is-fullscreen .nav-tabs{display:none!important}
body.pgl-is-fullscreen .avbox{display:none!important}
body.pgl-is-fullscreen .cdbox{display:none!important}
body.pgl-is-fullscreen #tab-postgolive.active{
  height:calc(100dvh - 46px)!important;overflow:hidden!important;
}
/* En fullscreen: pgl-left y pgl-right se estiran via flex-stretch al alto del contenedor.
   pgl-charts (flex:1;min-height:0;overflow-y:auto) hace scroll de los gráficos. */

/* ═══════════════════════════════════════════════════════════
   PGL GROUP TABLE — vista tabla de grupo
   ══════════════════════════════════════════════════════════ */
#pgl-grp-table-overlay table { border-collapse: collapse; }
#pgl-grp-table-overlay thead th {
  position: sticky; top: 0; z-index: 2;
  background: var(--surface2); border-bottom: 1px solid var(--border);
  user-select: none;
}
#pgl-grp-table-overlay tbody tr:hover td { background: rgba(255,255,255,.04) !important; }
#pgl-grp-table-overlay td, #pgl-grp-table-overlay th {
  white-space: nowrap;
}
/* sticky first col in ticketera table */
#pgl-gt-body .sticky-col-l {
  position: sticky; left: 0; z-index: 1; background: var(--surface);
}
#pgl-gt-body .sticky-col-r {
  position: sticky; right: 0; z-index: 1; background: var(--surface);
}

/* ═══════════════════════════════════════════════════════════
   MENU BAR — barra de menú horizontal con dropdowns
   ══════════════════════════════════════════════════════════ */
.menu-bar{
  display:flex;align-items:center;gap:2px;
  padding:3px 8px;
  background:var(--surface2);border-bottom:1px solid var(--border);
  flex-shrink:0;
}
.menu-item{position:relative;}
.menu-btn{
  display:inline-flex;align-items:center;gap:4px;
  padding:4px 10px;background:none;border:none;
  color:var(--text);font-size:12px;cursor:pointer;
  border-radius:5px;white-space:nowrap;transition:background .12s;
}
.menu-btn:hover,.menu-item.open .menu-btn{background:rgba(255,255,255,.07);}
.menu-dropdown{
  display:none;position:absolute;top:100%;left:0;
  z-index:1500;background:var(--surface2);
  border:1px solid var(--border);border-radius:7px;
  padding:4px 0;min-width:195px;
  box-shadow:0 6px 18px rgba(0,0,0,.45);
  list-style:none;
}
.menu-item.open>.menu-dropdown{display:block;}
.menu-dropdown li{position:relative;}
.menu-dropdown li .md-btn,
.menu-dd-btn{
  display:flex;align-items:center;gap:7px;width:100%;
  padding:7px 14px;background:none;border:none;
  color:var(--text);font-size:12px;cursor:pointer;
  text-align:left;white-space:nowrap;transition:background .1s;
  box-sizing:border-box;
}
.menu-dropdown li .md-btn:hover,
.menu-dd-btn:hover{background:rgba(255,255,255,.06);}
.menu-dropdown li.menu-has-sub>.md-btn::after{content:'▸';margin-left:auto;opacity:.55;font-size:10px;}
.menu-separator{height:1px;background:var(--border);margin:4px 0;}
/* Sub-dropdown */
.menu-sub-dropdown{
  display:none;position:absolute;top:0;left:100%;
  z-index:1600;background:var(--surface2);
  border:1px solid var(--border);border-radius:7px;
  padding:4px 0;min-width:180px;
  box-shadow:0 6px 18px rgba(0,0,0,.45);
  list-style:none;
}
.menu-has-sub:hover>.menu-sub-dropdown{display:block;}
/* Ancho del menú de importación: más ancho por los textos */
#menu-import-sub>.menu-sub-dropdown{min-width:210px;}
/* Ocultar botones sueltos que ahora van en el menú */
.legend-btns-hidden{display:none!important;}

/* ─── Dashboard: thead fijo alineado con tbody scrollable ──────────────────── */
/* La clave: el contenedor del thead usa overflow:hidden + scrollbar-gutter:stable
   para reservar el mismo espacio que el div scrollable del tbody */
.dash-thead-fixed{
  flex-shrink:0;overflow:hidden;border-bottom:2px solid var(--border);
  overflow-y:scroll;scrollbar-width:none;   /* reserva gutter sin mostrar barra */
}
.dash-thead-fixed::-webkit-scrollbar{display:none;}
.dash-thead-fixed table{margin:0;}

/* ═══════════════════════════════════════════════════════
   POST GO-LIVE — KPI MODULE
══════════════════════════════════════════════════════════ */
.pgl-modulo { border-bottom: 1px solid rgba(255,255,255,.07); }
.pgl-mod-header {
  display: flex; align-items: center; gap: 8px; padding: 8px 12px;
  cursor: pointer; user-select: none;
  background: var(--surface);
  transition: background .15s;
}
.pgl-mod-header:hover { background: var(--surface2); }
.pgl-mod-body { background: var(--bg); }
.pgl-grupo { border-bottom: 1px solid rgba(255,255,255,.05); }
.pgl-grp-header {
  display: flex; align-items: center; gap: 7px; padding: 6px 12px 6px 24px;
  cursor: pointer; user-select: none;
  background: rgba(0,0,0,.12);
  transition: background .15s;
}
.pgl-grp-header:hover { background: rgba(59,130,246,.08); }
.pgl-grp-body {}
.pgl-chevron { font-size: 9px; color: var(--text-muted); flex-shrink: 0; width: 10px; }
.pgl-mod-icon, .pgl-grp-icon { font-size: 13px; flex-shrink: 0; }
.pgl-mod-name, .pgl-grp-name {
  font-size: 12px; font-weight: 700; color: var(--text);
  flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.pgl-grp-name { font-weight: 600; color: var(--text-muted); }

/* KPI row */
.pgl-kpi-row {
  display: flex; align-items: center; gap: 8px;
  padding: 5px 12px 5px 40px;
  border-bottom: 1px solid rgba(255,255,255,.04);
  transition: background .12s;
}
.pgl-kpi-row:hover { background: rgba(59,130,246,.06); }
.pgl-chart-check { display: flex; align-items: center; cursor: pointer; flex-shrink: 0; }
.pgl-chart-check input { display: none; }
.pgl-check-box {
  width: 16px; height: 16px; border: 1.5px solid var(--border); border-radius: 4px;
  background: var(--surface2); transition: all .15s; flex-shrink: 0;
}
.pgl-chart-check input:checked + .pgl-check-box {
  background: var(--accent); border-color: var(--accent);
  box-shadow: 0 0 6px rgba(59,130,246,.5);
}
.pgl-chart-check input:checked + .pgl-check-box::after {
  content: '✓'; display: block; text-align: center;
  font-size: 11px; font-weight: 800; color: #fff; line-height: 14px;
}
.pgl-kpi-info { flex: 1; min-width: 0; cursor: pointer; }
.pgl-kpi-title { font-size: 12px; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.pgl-kpi-meta { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; margin-top: 2px; }
.pgl-badge { font-size: 9px; font-weight: 600; padding: 1px 6px; border-radius: 9px; white-space: nowrap; }
.pgl-badge-period { background: rgba(59,130,246,.18); color: #93c5fd; border: 1px solid rgba(59,130,246,.3); }
.pgl-btn-sm {
  padding: 2px 7px; border-radius: 5px; font-size: 10px; font-weight: 600;
  cursor: pointer; border: 1px solid var(--border); background: var(--surface2); color: var(--text);
  white-space: nowrap; flex-shrink: 0;
}
.pgl-btn-add { background: rgba(34,197,94,.12); border-color: rgba(34,197,94,.3); color: #4ade80; }
.pgl-btn-del { background: rgba(239,68,68,.1); border-color: rgba(239,68,68,.25); color: #f87171; }
.pgl-btn-dato {
  padding: 2px 8px; border-radius: 5px; font-size: 11px;
  cursor: pointer; border: 1px solid rgba(59,130,246,.3);
  background: rgba(59,130,246,.12); color: #93c5fd; flex-shrink: 0;
}

/* Chart cards */
.pgl-chart-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 10px; overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.3);
  cursor: grab; user-select: none;
}
.pgl-chart-card:active { cursor: grabbing; }
.pgl-chart-card.dragging { opacity: .4; }
.pgl-chart-header {
  display: flex; align-items: center; gap: 10px; justify-content: space-between;
  padding: 8px 12px; border-bottom: 1px solid var(--border);
  background: var(--surface); cursor: grab;
}

/* PGL — campo legend */
.pgl-campo-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  padding: 4px 12px 6px;
  border-bottom: 1px solid var(--border);
  background: var(--surface);
}
.pgl-campo-legend label:hover {
  background: var(--surface2);
}
