.api-header { display:flex; align-items:flex-start; justify-content:space-between; margin-bottom:16px; gap:12px; flex-wrap:wrap; }
.api-actions { display:flex; gap:10px; flex-wrap:wrap; }
.btn-docs { padding:10px 14px; background: var(--card-bg); border:1px solid var(--border-color); color: var(--text-secondary); border-radius:10px; font-weight:600; font-size:14px; display:flex; align-items:center; gap:8px; cursor:pointer; text-decoration:none; }
.btn-docs:hover { background: rgba(255,255,255,0.06); color: var(--text-primary); text-decoration:none; }
.btn-create { padding:10px 16px; background: var(--teal-gradient); border: none; color:#000; border-radius:10px; font-weight:700; font-size:14px; display:flex; align-items:center; gap:8px; cursor:pointer; }

.table-section { padding:20px; background: var(--card-bg); border:1px solid var(--border-color); border-radius:20px; }
.table-container { overflow-x:auto; }
.transactions-table { width:100%; border-collapse:collapse; }
.transactions-table thead tr { border-bottom:1px solid var(--border-color); }
.transactions-table th { text-align:left; padding:16px 12px; font-size:11px; font-weight:700; color: var(--text-tertiary); text-transform:uppercase; letter-spacing:0.5px; }
.transactions-table tbody tr { border-bottom:1px solid var(--border-color); }
.transactions-table td { padding:18px 12px; font-size:14px; color: var(--text-primary); }
.td-e2e { font-family:'Courier New', monospace; font-size:12px; color: var(--text-secondary); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:220px; }

.perm-chips { display:flex; flex-wrap:wrap; gap:6px; }
.perm-chip { padding:6px 10px; border-radius:10px; font-size:12px; font-weight:600; background: rgba(245, 158, 11, 0.16); color:#f59e0b; white-space:nowrap; }
.status-chip { padding:6px 10px; border-radius:10px; font-size:12px; font-weight:700; background: rgba(43, 217, 185, 0.16); color: var(--primary-color); }
.btn-icon { padding:8px; background: transparent; border: none; color: var(--danger-color); border-radius:8px; cursor:pointer; }

.inline-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.perm-grid { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap:12px; }
.perm-item { display:flex; align-items:center; gap:12px; padding:12px 16px; background: var(--card-bg); border:1px solid var(--border-color); border-radius:10px; cursor:pointer; min-height:44px; overflow:hidden; }
.perm-item input { flex-shrink:0; margin-right:10px; }
.perm-item input { width:18px; height:18px; border-radius:6px; border:1px solid var(--border-color); background: var(--darker-bg); accent-color: var(--primary-color); }
.perm-item input:focus { outline:none; }
.perm-item:focus-within { border-color: var(--primary-color);  }
.perm-item span { font-size:14px; font-weight:600; color: var(--text-primary); flex:1; position: relative; top: -3px; }

.modal-footer { padding:18px 20px; border-top:1px solid var(--border-color); display:flex; justify-content:flex-end; }
.modal-actions { display:flex; gap:10px; flex-wrap:wrap; }
.btn-primary { padding:12px 18px; background: var(--teal-gradient); border: none; color:#000; border-radius:10px; font-weight:700; cursor:pointer; min-width:140px; }
.btn-secondary { padding:12px 18px; background: rgba(255,255,255,0.04); border:1px solid var(--border-color); color: var(--text-primary); border-radius:10px; font-weight:600; cursor:pointer; min-width:120px; }
.btn-secondary:hover { background: rgba(255,255,255,0.08); }
.btn-danger { padding:12px 18px; background: rgba(239, 68, 68, 0.16); border:1px solid rgba(239, 68, 68, 0.5); color:#ef4444; border-radius:10px; font-weight:700; cursor:pointer; }

@media (max-width: 968px) {
  .inline-grid { grid-template-columns: 1fr; }
  .perm-grid { grid-template-columns: 1fr; }
  .api-header { flex-direction: column; }
  .api-actions { width:100%; }
  .btn-docs, .btn-create { width:100%; justify-content:center; }
  .td-e2e { max-width:160px; }
}

@media (max-width: 640px) {
  .transactions-table th.col-perms, .transactions-table td.col-perms { display:none; }
  .transactions-table th { font-size:10px; padding:12px 6px; }
  .transactions-table td { font-size:12px; padding:12px 6px; }
  .table-section { padding:16px; border-radius:12px; }
  .td-e2e { max-width:120px; }
  .modal-actions { width:100%; }
  .btn-secondary, .btn-primary { width:100%; justify-content:center; }
}

/* Modal layout fixes (somente para modais da página API) */
#modalCriarChave .modal-container,
#modalEditarChave .modal-container,
#modalPermissoes .modal-container,
#modalChaveCriada .modal-container { display:flex; flex-direction:column; }

#modalCriarChave .modal-body,
#modalEditarChave .modal-body,
#modalPermissoes .modal-body,
#modalChaveCriada .modal-body { flex:1; overflow-y:auto; -webkit-overflow-scrolling: touch; }

#modalCriarChave .modal-footer,
#modalEditarChave .modal-footer,
#modalPermissoes .modal-footer,
#modalChaveCriada .modal-footer { background: rgba(26,26,26,0.92); }

/* Copiar credenciais */
.copy-row { display:flex; align-items:center; gap:10px; position:relative; }
.copy-row .filter-input { flex:1; min-width:0; padding:12px 14px; }
.copy-row .btn-icon { width:44px; height:44px; border:1px solid var(--border-color); border-radius:10px; background: rgba(255,255,255,0.06); color: var(--text-primary); display:flex; align-items:center; justify-content:center; }
.copy-row .btn-icon:hover { background: rgba(255,255,255,0.08); }

.copy-row .copy-feedback { position:absolute; right:0; top:-28px; background: rgba(43, 217, 185, 0.12); border:1px solid var(--border-color); color: var(--primary-color); font-size:12px; font-weight:700; padding:6px 10px; border-radius:10px;  display:flex; align-items:center; gap:6px; opacity:0; transform: translateY(-4px); transition: opacity 0.2s ease, transform 0.2s ease; }
.copy-row .copy-feedback.show { opacity:1; transform: translateY(0); }

@media (max-width: 640px) {
  #modalChaveCriada .modal-container { max-width:95vw; }
  .copy-row { flex-direction:column; gap:8px; }
  .copy-row .btn-icon { width:100%; height:44px; }
  .copy-row .copy-feedback { position:static; width:100%; margin-top:4px; justify-content:center; }
}
