/* Escopo: não afetar o tema inteiro + blindagem contra CSS do tema */
#aga-control-wrap, #aga-control-wrap * { box-sizing: border-box; }
#aga-control-wrap * { margin: 0; padding: 0; }

/* Baseline tipográfico (evita herdar “fonte gigante” do tema WordPress) */
#aga-control-wrap{ font-size: 14px !important; line-height: 1.4 !important; }
#aga-control-wrap input,
#aga-control-wrap select,
#aga-control-wrap textarea,
#aga-control-wrap button,
#aga-control-wrap table,
#aga-control-wrap th,
#aga-control-wrap td{
  font-size: 14px !important;
  line-height: 1.35 !important;
}

/* Paleta (clara, moderna) */
#aga-control-wrap{
  --aga-bg-1: #f8fafc;
  --aga-bg-2: #eef2ff;
  --aga-surface: #ffffff;
  --aga-surface-2: #f1f5f9;
  --aga-border: #e2e8f0;
  --aga-text: #0f172a;
  --aga-muted: #475569;
  --aga-accent: #2563eb;
  --aga-accent-2: #7c3aed;
  --aga-shadow: 0 12px 36px rgba(15, 23, 42, 0.10);
}

#aga-control-wrap .aga-body{
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  background:
    radial-gradient(1200px circle at 10% 0%, rgba(124,58,237,0.12) 0%, transparent 55%),
    radial-gradient(1200px circle at 90% 0%, rgba(2,132,199,0.14) 0%, transparent 55%),
    linear-gradient(180deg, var(--aga-bg-1) 0%, var(--aga-bg-2) 100%);
  color: var(--aga-text);
  min-height: 80vh;
  padding: 20px;
  border-radius: 14px;
  border: 1px solid var(--aga-border);
  box-shadow: var(--aga-shadow);
}

#aga-control-wrap .header{
  text-align: center;
  margin-bottom: 14px;
  font-size: 24px !important;
  font-weight: 800;
  letter-spacing: 0.2px;
  background:
    linear-gradient(90deg, rgba(37,99,235,0.12) 0%, rgba(124,58,237,0.12) 100%);
  padding: 15px;
  border-radius: 12px;
  border: 1px solid var(--aga-border);
}

#aga-control-wrap .notice{
  max-width: 1300px;
  margin: 0 auto 12px auto;
  background: rgba(15,23,42,0.04);
  border: 1px solid var(--aga-border);
  padding: 10px 14px;
  border-radius: 10px;
  color: var(--aga-text);
}
#aga-control-wrap .notice strong{ color: var(--aga-text); }
#aga-control-wrap .notice:empty{ display:none; }

#aga-control-wrap .kpis{
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  margin-bottom: 16px;
  justify-content: center;
}
#aga-control-wrap .kpi{
  background: var(--aga-surface);
  border: 1px solid var(--aga-border);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
  padding: 12px 20px;
  border-radius: 8px;
  min-width: 160px;
  text-align: center;
  color: var(--aga-text);
}
#aga-control-wrap .kpi strong{ font-size: 18px !important; }
#aga-control-wrap .kpi.em_andamento { border-left: 6px solid #f59e0b; }
#aga-control-wrap .kpi.concluido { border-left: 6px solid #22c55e; }
#aga-control-wrap .kpi.atrasado { border-left: 6px solid #ef4444; }

#aga-control-wrap .filtros{
  display: flex;
  gap: 10px;
  margin-bottom: 10px;
  flex-wrap: wrap;
  justify-content: center;
}
#aga-control-wrap .filtros input,
#aga-control-wrap .filtros select{
  padding: 8px 12px;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  background: var(--aga-surface);
  color: var(--aga-text);
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.04);
}
#aga-control-wrap .filtros button{
  padding: 8px 16px;
  background: var(--aga-accent);
  color: #fff;
  border: 1px solid rgba(37, 99, 235, 0.25);
  border-radius: 6px;
  cursor: pointer;
  box-shadow: 0 10px 22px rgba(37, 99, 235, 0.16);
}

#aga-control-wrap .filtros button:hover{ filter: brightness(1.04); }
#aga-control-wrap #btnLimpar{
  background: rgba(15, 23, 42, 0.06);
  color: var(--aga-text);
  border: 1px solid var(--aga-border);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
}
#aga-control-wrap #btnLimpar:hover{ background: rgba(15, 23, 42, 0.08); }

#aga-control-wrap .tabela-container{
  width: 100%;
  /* Scroll vertical para manter o cabeçalho fixo */
  overflow: auto;
  max-height: 62vh;
  background: var(--aga-surface);
  border: 1px solid var(--aga-border);
  border-radius: 12px 12px 0 0;
  margin-bottom: 0;
}
#aga-control-wrap .btn-container{
  background: var(--aga-surface);
  border-radius: 0 0 12px 12px;
  padding: 16px;
  text-align: center;
  border: 1px solid var(--aga-border);
  border-top: none;
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

#aga-control-wrap table{
  width: 100%;
  border-collapse: collapse;
  font-size: 13px !important;
  color: var(--aga-text);
}
#aga-control-wrap th, #aga-control-wrap td{
  padding: 10px 8px;
  text-align: left;
  border-bottom: 1px solid var(--aga-border);
  word-wrap: break-word;
  max-width: 190px;
}
#aga-control-wrap th{
  /* Cabeçalho fixo precisa ser OPACO para não “vazar” as linhas por baixo ao rolar */
  background: linear-gradient(180deg, #f8fafc 0%, #eef2ff 100%) !important;
  background-color: #f8fafc !important;
  font-weight: 600;
  position: sticky;
  top: 0;
  z-index: 200;
  cursor: pointer;
  user-select: none;
  color: var(--aga-text);
  box-shadow: 0 2px 0 rgba(15, 23, 42, 0.08);
}

/* Título (somente a coluna Título) — +2px */
#aga-control-wrap td.title-cell{
  font-size: 15px !important;
  font-weight: 600;
}
#aga-control-wrap th:hover{ background: linear-gradient(180deg, #eef2ff 0%, #e0e7ff 100%) !important; }
#aga-control-wrap .sort-indicator{
  margin-left: 5px;
  font-size: 11px !important;
  line-height: 1 !important;
  font-weight: 800 !important;
  color: var(--aga-accent) !important;
  /* Blindagem: alguns temas aplicam “badge”/background em spans dentro de TH */
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
  display: inline !important;
}


/* Prioridade */
#aga-control-wrap .prio-cell{
  width: 84px;
  white-space: nowrap;
}
#aga-control-wrap .prio-badge{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 30px;
  height: 24px;
  padding: 0 8px;
  border-radius: 999px;
  font-weight: 800;
  font-size: 12px;
  border: 1px solid rgba(15,23,42,0.12);
  box-shadow: 0 1px 0 rgba(15,23,42,0.06);
}
#aga-control-wrap .prio-1{ background: #fee2e2; color: #991b1b; border-color: rgba(239,68,68,0.25); }
#aga-control-wrap .prio-2{ background: #ffedd5; color: #9a3412; border-color: rgba(249,115,22,0.25); }
#aga-control-wrap .prio-3{ background: #fef9c3; color: #854d0e; border-color: rgba(234,179,8,0.25); }
#aga-control-wrap .prio-4{ background: #dbeafe; color: #1e40af; border-color: rgba(59,130,246,0.25); }
#aga-control-wrap .prio-5{ background: #e2e8f0; color: #0f172a; border-color: rgba(100,116,139,0.25); }

#aga-control-wrap tbody tr:nth-child(even) td{ background: rgba(15, 23, 42, 0.02); }
#aga-control-wrap tbody tr:hover td{ background: rgba(2, 132, 199, 0.06); }

#aga-control-wrap .prazo-status{
  padding: 6px 12px;
  border-radius: 6px;
  font-weight: 500;
  display: inline-block;
  white-space: nowrap;
}
#aga-control-wrap .prazo-status.atrasado{
  background: #fee2e2;
  color: #b91c1c;
  border: 1px solid #fecaca;
}
#aga-control-wrap .prazo-status.vencendo{
  background: #ffedd5;
  color: #9a3412;
  border: 1px solid #fed7aa;
}
#aga-control-wrap .prazo-status.normal{
  background: #dcfce7;
  color: #166534;
  border: 1px solid #bbf7d0;
}

#aga-control-wrap .status{
  padding: 4px 8px;
  border-radius: 12px;
  font-size: 0.8em;
  font-weight: bold;
  white-space: nowrap;
  cursor: pointer;
  user-select: none;
  display: inline-block;
  border: 1px solid var(--aga-border);
}
#aga-control-wrap .status.em_andamento { background: #fef3c7; color: #92400e; border-color: #f59e0b; }
#aga-control-wrap .status.concluido { background: #dcfce7; color: #166534; border-color: #22c55e; }
#aga-control-wrap .status.atrasado { background: #fee2e2; color: #b91c1c; border-color: #ef4444; }
#aga-control-wrap .status.cancelado { background: #e2e8f0; color: #334155; border-color: #94a3b8; }
#aga-control-wrap .status:hover{ filter: brightness(0.98); }

/*
  IMPORTANTE:
  .edit-cell é aplicado no <td>. NÃO podemos mudar o display do <td> (ex.: inline-block),
  senão o browser perde o layout de “table-cell” e as colunas ficam desalinhadas.
*/
#aga-control-wrap td.edit-cell{
  cursor: pointer;
  text-decoration: underline;
  color: var(--aga-accent);
}
#aga-control-wrap td.edit-cell:hover{ color: #1d4ed8; }

#aga-control-wrap .observacoes-cell{
  cursor: pointer;
  text-decoration: underline;
  color: var(--aga-accent);
  position: relative;
  display: inline-block;
}
#aga-control-wrap .observacoes-cell:hover{ color: #1d4ed8; }

#aga-control-wrap .tooltip{
  visibility: hidden;
  position: absolute;
  z-index: 100;
  bottom: 125%;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(15, 23, 42, 0.98);
  color: white;
  text-align: left;
  border-radius: 8px;
  padding: 16px 18px;
  width: 520px;
  border: 2px solid var(--aga-accent);
  box-shadow: 0 18px 46px rgba(0, 0, 0, 0.28);
  white-space: pre-wrap;
  word-wrap: break-word;
  font-size: 0.95em;
  line-height: 1.6;
}
#aga-control-wrap .tooltip.tooltip-bottom{ bottom: auto; top: 125%; }
#aga-control-wrap .tooltip::after{
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -6px;
  border-width: 6px;
  border-style: solid;
  border-color: var(--aga-accent) transparent transparent transparent;
}
#aga-control-wrap .tooltip.tooltip-bottom::after{
  top:auto;
  bottom:100%;
  border-color: transparent transparent var(--aga-accent) transparent;
}
#aga-control-wrap .observacoes-cell:hover .tooltip{
  visibility: visible;
  animation: fadeIn 0.3s;
}
@keyframes fadeIn{
  from { opacity: 0; transform: translateX(-50%) translateY(8px); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}

#aga-control-wrap .acoes button{
  background: none;
  border: none;
  color: var(--aga-accent);
  cursor: pointer;
  margin-right: 8px;
  font-size: 1.2em;
}
#aga-control-wrap .acoes button:hover{ color: #1d4ed8; }
#aga-control-wrap .novo-btn{
  display: inline-block;
  padding: 12px 24px;
  background: linear-gradient(90deg, var(--aga-accent) 0%, var(--aga-accent-2) 100%);
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 1.1em;
  font-weight: bold;
  cursor: pointer;
  box-shadow: 0 12px 26px rgba(37,99,235,0.20);
}
#aga-control-wrap .novo-btn:hover{ transform: translateY(-1px); filter: brightness(1.02); }

#aga-control-wrap .modal{
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.8);
  z-index: 1000;
}
#aga-control-wrap .modal-content{
  background: var(--aga-surface);
  margin: 5% auto;
  padding: 30px;
  width: 90%;
  max-width: 600px;
  border-radius: 12px;
  max-height: 80vh;
  overflow-y: auto;
  border: 1px solid var(--aga-border);
  box-shadow: var(--aga-shadow);
}
#aga-control-wrap .meta-line{
  margin: 8px 0 18px 0;
  color: var(--aga-muted);
  font-size: 0.9em;
}
#aga-control-wrap .meta-line b{ color: var(--aga-text); }

#aga-control-wrap .form-group{ margin-bottom: 18px; }
#aga-control-wrap .form-group label{ display: block; margin-bottom: 5px; font-weight: 500; }
#aga-control-wrap .form-group input,
#aga-control-wrap .form-group select,
#aga-control-wrap .form-group textarea{
  width: 100%;
  padding: 12px;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  background: var(--aga-surface);
  color: var(--aga-text);
}
#aga-control-wrap .form-group textarea{ height: 120px; resize: vertical; }
#aga-control-wrap .btns{ display: flex; gap: 15px; justify-content: flex-end; }
#aga-control-wrap .btn-salvar{ background: #16a34a; color: #fff; padding: 12px 30px; border: none; border-radius: 8px; cursor: pointer; box-shadow: 0 10px 22px rgba(22,163,74,0.18); }
#aga-control-wrap .btn-salvar:hover{ filter: brightness(1.03); }
#aga-control-wrap .btn-cancelar{ background: rgba(15,23,42,0.06); color: var(--aga-text); padding: 12px 30px; border: 1px solid var(--aga-border); border-radius: 8px; cursor: pointer; }
#aga-control-wrap .btn-cancelar:hover{ background: rgba(15,23,42,0.08); }
#aga-control-wrap .char-count{ font-size: 0.8em; color: var(--aga-muted); margin-top: 5px; }

#aga-control-wrap .modal-obs-edit{
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.8);
  z-index: 1001;
}
#aga-control-wrap .modal-obs-edit-content{
  background: var(--aga-surface);
  margin: 5% auto;
  padding: 30px;
  width: 90%;
  max-width: 700px;
  border-radius: 12px;
  max-height: 80vh;
  overflow-y: auto;
  border: 1px solid var(--aga-border);
  box-shadow: var(--aga-shadow);
}
#aga-control-wrap .obs-edit-textarea{
  width: 100%;
  height: 250px;
  padding: 12px;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  background: var(--aga-surface);
  color: var(--aga-text);
  font-size: 1em;
  resize: vertical;
}
#aga-control-wrap .obs-edit-buttons{
  display: flex;
  gap: 15px;
  justify-content: flex-end;
  margin-top: 20px;
}
#aga-control-wrap .btn-save-obs{ background: #16a34a; color: #fff; padding: 10px 20px; border: none; border-radius: 8px; cursor: pointer; box-shadow: 0 10px 22px rgba(22,163,74,0.18); }
#aga-control-wrap .btn-cancel-obs{ background: rgba(15,23,42,0.06); color: var(--aga-text); padding: 10px 20px; border: 1px solid var(--aga-border); border-radius: 8px; cursor: pointer; }

#aga-control-wrap .modal-status{
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.8);
  z-index: 1002;
}
#aga-control-wrap .modal-status-content{
  background: var(--aga-surface);
  margin: 8% auto;
  padding: 26px;
  width: 92%;
  max-width: 520px;
  border-radius: 12px;
  border: 1px solid var(--aga-border);
  box-shadow: var(--aga-shadow);
}
#aga-control-wrap .status-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 14px;
}
#aga-control-wrap .status-opt{
  padding: 10px 12px;
  border-radius: 12px;
  font-weight: 700;
  text-align: center;
  cursor: pointer;
  user-select: none;
  border: 1px solid var(--aga-border);
}
#aga-control-wrap .status-opt:hover{ filter: brightness(0.98); }
#aga-control-wrap .status-opt.em_andamento { background: #fef3c7; color: #92400e; border-color: #f59e0b; }
#aga-control-wrap .status-opt.concluido { background: #dcfce7; color: #166534; border-color: #22c55e; }
#aga-control-wrap .status-opt.atrasado { background: #fee2e2; color: #b91c1c; border-color: #ef4444; }
#aga-control-wrap .status-opt.cancelado { background: #e2e8f0; color: #334155; border-color: #94a3b8; }
#aga-control-wrap .status-modal-footer{
  margin-top: 18px;
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}
#aga-control-wrap .btn-fechar-status{
  background: rgba(15,23,42,0.06);
  border: 1px solid var(--aga-border);
  color: var(--aga-text);
  padding: 10px 16px;
  border-radius: 10px;
  cursor: pointer;
}
#aga-control-wrap .btn-fechar-status:hover{ background: rgba(15,23,42,0.08); }

#aga-control-wrap .modal-field{
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.8);
  z-index: 1003;
}
#aga-control-wrap .modal-field-content{
  background: var(--aga-surface);
  margin: 8% auto;
  padding: 26px;
  width: 92%;
  max-width: 560px;
  border-radius: 12px;
  border: 1px solid var(--aga-border);
  box-shadow: var(--aga-shadow);
}
#aga-control-wrap .modal-field-content h2{ margin-bottom: 8px; }
#aga-control-wrap .field-sub{ color: var(--aga-muted); margin-bottom: 14px; line-height: 1.3; }
#aga-control-wrap .field-input{
  width: 100%;
  padding: 12px;
  border: 1px solid #cbd5e1;
  border-radius: 10px;
  background: var(--aga-surface);
  color: var(--aga-text);
  font-size: 1em;
  outline: none;
}
#aga-control-wrap .field-footer{
  margin-top: 16px;
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}
#aga-control-wrap .btn-field-cancel{
  background: rgba(15,23,42,0.06);
  border: 1px solid var(--aga-border);
  color: var(--aga-text);
  padding: 10px 16px;
  border-radius: 10px;
  cursor: pointer;
}
#aga-control-wrap .btn-field-cancel:hover{ background: rgba(15,23,42,0.08); }
#aga-control-wrap .btn-field-save{
  background: #16a34a;
  border: none;
  color: #fff;
  padding: 10px 16px;
  border-radius: 10px;
  cursor: pointer;
  font-weight: 700;
}

/* Password gate */
#aga-control-wrap .aga-gate{position:fixed;inset:0;background:rgba(15,23,42,0.72);backdrop-filter:blur(6px);z-index:9999;display:flex;align-items:center;justify-content:center;padding:20px}
#aga-control-wrap .aga-gate-card{width:100%;max-width:420px;background:linear-gradient(180deg,rgba(255,255,255,0.98),rgba(255,255,255,0.96));border:1px solid var(--aga-border);border-radius:16px;box-shadow:0 20px 60px rgba(2,6,23,0.30);padding:18px 18px 16px}
#aga-control-wrap .aga-gate-title{font-size:18px;font-weight:800;color:var(--aga-text);margin-bottom:6px}
#aga-control-wrap .aga-gate-sub{font-size:13px;color:var(--aga-muted);margin-bottom:12px}
#aga-control-wrap .aga-gate-row{display:flex;gap:10px;align-items:center}
#aga-control-wrap .aga-gate-input{flex:1;padding:10px 12px;border-radius:12px;border:1px solid var(--aga-border);background:#fff;color:var(--aga-text)}
#aga-control-wrap .aga-gate-btn{padding:10px 14px;border-radius:12px;border:none;background:var(--aga-accent);color:#fff;font-weight:800;cursor:pointer}
#aga-control-wrap .aga-gate-btn:hover{filter:brightness(0.97)}
#aga-control-wrap .aga-gate-error{margin-top:10px;font-size:13px;color:#b91c1c;background:rgba(239,68,68,0.10);border:1px solid rgba(239,68,68,0.25);padding:10px 12px;border-radius:12px}

/* KPI clickable */
#aga-control-wrap .kpi{cursor:pointer;user-select:none}
#aga-control-wrap .kpi:hover{transform:translateY(-1px)}

/* Pagination */
#aga-control-wrap .pagination{display:flex;align-items:center;justify-content:center;gap:10px;margin:12px 0 6px}
#aga-control-wrap .page-btn{width:38px;height:34px;border-radius:12px;border:1px solid var(--aga-border);background:rgba(255,255,255,0.96);cursor:pointer;font-size:18px;color:var(--aga-text)}
#aga-control-wrap .page-btn:disabled{opacity:0.4;cursor:not-allowed}
#aga-control-wrap .page-info{font-size:13px;color:var(--aga-muted)}

/* Notes icon */
#aga-control-wrap .note-btn{width:34px;height:30px;border-radius:10px;border:1px solid var(--aga-border);background:rgba(255,255,255,0.96);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
#aga-control-wrap .note-btn:hover{filter:brightness(0.98)}
#aga-control-wrap .note-dot{display:inline-block;width:8px;height:8px;border-radius:999px;background:var(--aga-accent);margin-left:6px;opacity:0.85}

/* Concluído badge in Dias Restantes */
#aga-control-wrap .prazo-status.concluido_ok{background:rgba(22,163,74,0.10);color:#0f7a35;border:1px solid rgba(22,163,74,0.35)}
#aga-control-wrap .prazo-status.concluido_atraso{background:rgba(239,68,68,0.10);color:#b91c1c;border:1px solid rgba(239,68,68,0.35)}

/* Blindagem extra contra temas WP que aplicam opacity/backdrop no thead */
#aga-control-wrap thead th{ opacity: 1 !important; backdrop-filter: none !important; }
