/* ========================================
   CHILDREN VIEW - Visualização de Crianças
   Antares Kids Portal
   ======================================== */

/* ── Wrapper principal ── */
.children-view-wrapper {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

/* ══════════════════════════════════════
   TOOLBAR
══════════════════════════════════════ */
.children-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.children-search-area {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex: 1;
  min-width: 0;
}

/* Contador de crianças */
.children-view-count {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: var(--gray-50);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-lg);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-secondary);
  white-space: nowrap;
}
.children-view-count i        { color: var(--primary); }
.children-view-count span     { color: var(--primary); font-size: 1rem; }

/* Área de ações */
.children-actions-bar {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

/* ── Toggle de visualização ── */
.view-mode-toggle {
  display: flex;
  background: var(--gray-100);
  border-radius: var(--radius-lg);
  padding: 3px;
  gap: 2px;
}

.view-mode-btn {
  width: 36px;
  height: 36px;
  border: none;
  background: transparent;
  border-radius: var(--radius-md);
  color: var(--text-secondary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  transition: var(--transition-base);
}
.view-mode-btn:hover      { background: var(--white); color: var(--text-primary); }
.view-mode-btn.active     { background: var(--white); color: var(--primary); box-shadow: var(--shadow-xs); }

/* ── Botão exportar CSV ── */
.btn-csv-export {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  background: var(--white);
  border: 2px solid var(--success);
  color: var(--success);
  border-radius: var(--radius-lg);
  font-size: 0.875rem;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition-base);
  white-space: nowrap;
}
.btn-csv-export:hover {
  background: var(--success);
  color: var(--white);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(16, 185, 129, 0.25);
}

/* ══════════════════════════════════════
   FILTRO POR CLASSES (CHIPS)
══════════════════════════════════════ */
.class-filter-section {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-5);
  background: var(--white);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xs);
}

.class-filter-label {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: 0.8125rem;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  white-space: nowrap;
  padding-top: var(--space-2);
}
.class-filter-label i { color: var(--primary); }

.class-chips-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  flex: 1;
}

.chip-loading {
  color: var(--text-secondary);
  padding: var(--space-2);
}

/* ── Chip Base ── */
.class-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3) var(--space-2) var(--space-2);
  background: var(--gray-50);
  border: 2px solid var(--border-color);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-primary);
  user-select: none;
  line-height: 1;
}
.class-chip:hover {
  border-color: var(--primary);
  color: var(--primary);
  background: rgba(37, 99, 235, 0.05);
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}
.class-chip.active {
  background: var(--primary);
  border-color: var(--primary);
  color: var(--white);
  box-shadow: 0 2px 8px rgba(37, 99, 235, 0.35);
}

/* Chip "Todas" */
.class-chip-all { padding-left: var(--space-3); }
.class-chip-all i { font-size: 0.875rem; }

/* Emblema no chip */
.chip-emblem-wrap {
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.chip-emblem-img {
  width: 24px;
  height: 24px;
  object-fit: contain;
  border-radius: 3px;
}
.chip-color-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  display: block;
}

.chip-name {
  max-width: 130px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Badge de contagem no chip */
.chip-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 20px;
  padding: 0 6px;
  background: rgba(0, 0, 0, 0.1);
  border-radius: var(--radius-full);
  font-size: 0.75rem;
  font-weight: 700;
  line-height: 1;
}
.class-chip.active .chip-badge { background: rgba(255, 255, 255, 0.25); }

/* ══════════════════════════════════════
   CONTAINER DA LISTA DE CRIANÇAS
══════════════════════════════════════ */
.children-list-container {
  background: var(--white);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-xs);
  min-height: 200px;
}

.children-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  padding: var(--space-16);
  color: var(--text-secondary);
  font-size: 1rem;
}
.children-loading i { color: var(--primary); font-size: 1.25rem; }

/* ══════════════════════════════════════
   TABELA DE CRIANÇAS
══════════════════════════════════════ */
.children-table-container {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.children-data-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9375rem;
}

/* Cabeçalho */
.children-data-table thead {
  background: linear-gradient(to bottom, #f8fafc, #f1f5f9);
  border-bottom: 2px solid var(--primary);
  position: sticky;
  top: 0;
  z-index: 10;
}
.children-data-table th {
  padding: var(--space-4);
  text-align: left;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-primary);
  white-space: nowrap;
}
.children-data-table th i { color: var(--primary); margin-right: var(--space-2); }

/* Células */
.children-data-table td {
  padding: var(--space-4);
  border-bottom: 1px solid var(--gray-100);
  color: var(--text-primary);
  vertical-align: middle;
}
.children-data-table tbody tr { transition: background 0.15s ease; }
.children-data-table tbody tr:hover { background: rgba(37, 99, 235, 0.03); }
.children-data-table tbody tr:last-child td { border-bottom: none; }
.children-data-table tbody tr.row-inactive td { opacity: 0.6; }

/* Tamanho de colunas */
.tc-idx     { width: 40px; text-align: center; color: var(--text-secondary); font-size: 0.8125rem; }
.tc-age     { width: 75px; text-align: center; }
.tc-birth   { width: 115px; color: var(--text-secondary); font-size: 0.875rem; }
.tc-actions { width: 90px; text-align: right; }
.tc-phone   { white-space: nowrap; }

/* ── Célula de nome ── */
.name-cell {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.avatar-xs {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--white);
  flex-shrink: 0;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.15);
  text-transform: uppercase;
}
.child-full-name { font-weight: 600; }
.inactive-tag {
  font-size: 0.6875rem;
  font-weight: 700;
  color: var(--warning);
  background: rgba(245, 158, 11, 0.1);
  border: 1px solid rgba(245, 158, 11, 0.3);
  border-radius: var(--radius-full);
  padding: 1px 8px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-left: var(--space-2);
}

/* ── Badge de idade ── */
.age-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(37, 99, 235, 0.08);
  color: var(--primary);
  font-weight: 700;
  font-size: 0.8125rem;
  padding: 3px 8px;
  border-radius: var(--radius-full);
  border: 1px solid rgba(37, 99, 235, 0.15);
}

/* ── Célula de classe ── */
.class-cell-content {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.class-mini-emblem {
  width: 22px;
  height: 22px;
  object-fit: contain;
  flex-shrink: 0;
}
.class-color-indicator {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}
.class-name-text { font-weight: 600; font-size: 0.875rem; }

/* ── Link de telefone ── */
.phone-link {
  color: var(--text-primary);
  text-decoration: none;
  font-size: 0.875rem;
  transition: color var(--transition-fast);
}
.phone-link:hover { color: var(--primary); }
.phone-link i { color: var(--success); margin-right: 4px; font-size: 0.8rem; }

/* ── Ações na linha ── */
.row-actions { display: flex; gap: var(--space-1); justify-content: flex-end; }

.btn-row-edit,
.btn-row-delete {
  width: 32px;
  height: 32px;
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8125rem;
  transition: var(--transition-base);
}
.btn-row-edit   { background: rgba(245, 158, 11, 0.1); color: #d97706; }
.btn-row-edit:hover   { background: #f59e0b; color: var(--white); transform: scale(1.1); }
.btn-row-delete { background: rgba(239, 68, 68, 0.1); color: var(--danger); }
.btn-row-delete:hover { background: var(--danger); color: var(--white); transform: scale(1.1); }

/* ══════════════════════════════════════
   GRID DE CARDS
══════════════════════════════════════ */
.children-cards-grid {
  padding: var(--space-5);
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--space-4);
}

/* ── Card V2 ── */
.child-card-v2 {
  background: var(--white);
  border: 1px solid var(--border-color);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-xs);
  transition: var(--transition-base);
  display: flex;
  flex-direction: column;
}
.child-card-v2:hover {
  box-shadow: var(--shadow-md);
  border-color: rgba(37, 99, 235, 0.2);
  transform: translateY(-2px);
}
.child-card-v2.card-inactive { opacity: 0.65; }

/* Header do card */
.ccv2-header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4);
  background: var(--gray-50);
  border-bottom: 1px solid var(--border-color);
  position: relative;
}
.ccv2-avatar {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--white);
  flex-shrink: 0;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  text-transform: uppercase;
}
.ccv2-identity { flex: 1; min-width: 0; }
.ccv2-name     { font-weight: 700; font-size: 1rem; color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ccv2-meta     { display: flex; gap: var(--space-3); margin-top: 3px; font-size: 0.8rem; color: var(--text-secondary); }
.ccv2-meta span { display: flex; align-items: center; gap: 4px; }
.ccv2-meta i   { font-size: 0.75rem; color: var(--primary); }
.ccv2-inactive-badge { position: absolute; top: var(--space-3); right: var(--space-3); color: var(--warning); font-size: 1.125rem; }

/* Linha de classe */
.ccv2-class-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--gray-100);
}
.ccv2-emblem    { width: 28px; height: 28px; object-fit: contain; flex-shrink: 0; }
.ccv2-class-dot { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.ccv2-class-name { font-weight: 700; font-size: 0.875rem; }

/* Linha de responsável */
.ccv2-parent-row {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  flex: 1;
}
.ccv2-parent-row > i { color: var(--text-secondary); font-size: 1rem; margin-top: 2px; flex-shrink: 0; }
.ccv2-parent-name    { font-size: 0.875rem; font-weight: 600; color: var(--text-primary); }
.ccv2-parent-phone   { font-size: 0.8125rem; color: var(--text-secondary); margin-top: 3px; }
.ccv2-parent-phone i { color: var(--success); margin-right: 4px; font-size: 0.75rem; }

/* Footer do card */
.ccv2-footer {
  display: flex;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border-top: 1px solid var(--gray-100);
  background: var(--gray-50);
  margin-top: auto;
}
.btn-card-edit,
.btn-card-delete {
  flex: 1;
  padding: var(--space-2) var(--space-3);
  border: none;
  border-radius: var(--radius-md);
  font-size: 0.8125rem;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  transition: var(--transition-base);
}
.btn-card-edit   { background: rgba(245, 158, 11, 0.1); color: #d97706; }
.btn-card-edit:hover   { background: #f59e0b; color: var(--white); }
.btn-card-delete { background: rgba(239, 68, 68, 0.1); color: var(--danger); }
.btn-card-delete:hover { background: var(--danger); color: var(--white); }

/* ══════════════════════════════════════
   RESPONSIVO
══════════════════════════════════════ */
@media (max-width: 1024px) {
  .children-toolbar { flex-direction: column; align-items: stretch; }
  .children-actions-bar { flex-wrap: wrap; }
}

@media (max-width: 768px) {
  .children-search-area { flex-direction: column; align-items: stretch; }

  /* Ocultar colunas menos críticas na tabela em mobile */
  .tc-birth, .tc-phone { display: none; }

  .children-cards-grid { grid-template-columns: 1fr; }

  .class-filter-section { flex-direction: column; align-items: stretch; }
  .class-filter-label { padding-top: 0; }

  .btn-csv-export span { display: none; } /* Mostra apenas ícone em mobile */
}

@media (max-width: 480px) {
  .children-cards-grid { padding: var(--space-3); }
  .class-chips-row { gap: var(--space-1); }
}

/* ════════════════════════════════════════════════════════════════
   CHILDREN MANAGER v2  —  Prefixo: cm-
   Estilos exclusivos do ChildrenManager (página separada de admin)
   ════════════════════════════════════════════════════════════════ */

/* ── Layout da página ── */
.cm-page {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

/* ── Cabeçalho ── */
.cm-page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.cm-page-header-left {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.cm-page-title {
  font-size: 1.375rem;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0;
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.cm-page-title i { color: var(--primary); }

.cm-page-subtitle {
  font-size: 0.875rem;
  color: var(--text-secondary);
  margin: var(--space-1) 0 0;
}

/* ── Botão Adicionar ── */
.cm-btn-add {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  background: var(--primary);
  color: var(--white);
  border: none;
  border-radius: var(--radius-lg);
  font-size: 0.9375rem;
  font-weight: 600;
  cursor: pointer;
  transition: var(--transition-base);
  box-shadow: 0 2px 8px rgba(37,99,235,0.28);
  white-space: nowrap;
}
.cm-btn-add:hover {
  background: var(--primary-dark);
  transform: translateY(-1px);
  box-shadow: 0 4px 14px rgba(37,99,235,0.38);
}

/* ══════════════════════════════════════
   CARDS DE FILTRO POR CLASSE
══════════════════════════════════════ */
.cm-class-filter-row {
  display: flex;
  gap: var(--space-3);
  overflow-x: auto;
  padding-bottom: var(--space-1);
  scrollbar-width: thin;
  scrollbar-color: var(--gray-300) transparent;
}
.cm-class-filter-row::-webkit-scrollbar        { height: 4px; }
.cm-class-filter-row::-webkit-scrollbar-track  { background: transparent; }
.cm-class-filter-row::-webkit-scrollbar-thumb  { background: var(--gray-300); border-radius: 4px; }

.cm-filter-loading {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--text-secondary);
  font-size: 0.875rem;
  padding: var(--space-3) var(--space-4);
}

/* ── Card individual de classe ── */
.cm-class-card {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--white);
  border: 2px solid var(--border-color);
  border-radius: var(--radius-xl);
  cursor: pointer;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  white-space: nowrap;
  flex-shrink: 0;
  box-shadow: var(--shadow-xs);
  text-align: left;
  color: var(--text-primary);
}
.cm-class-card:hover {
  border-color: var(--primary);
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}
.cm-class-card.active {
  background: var(--cm-card-color, var(--primary));
  border-color: var(--cm-card-color, var(--primary));
  color: var(--white);
  box-shadow: 0 4px 14px rgba(37,99,235,0.28);
  transform: translateY(-1px);
}

/* Ícone do card */
.cm-card-icon {
  width: 42px;
  height: 42px;
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  flex-shrink: 0;
  overflow: hidden;
  transition: background var(--transition-base), color var(--transition-base);
}
.cm-card-icon--all {
  background: rgba(37,99,235,0.1);
  color: var(--primary);
}
.cm-class-card.active .cm-card-icon {
  background: rgba(255,255,255,0.22) !important;
  color: var(--white) !important;
}

/* Imagem do emblema dentro do card */
.cm-emblem-img {
  width: 30px;
  height: 30px;
  object-fit: contain;
}

/* Textos do card */
.cm-card-info {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.cm-card-name {
  font-size: 0.875rem;
  font-weight: 700;
  color: inherit;
  line-height: 1.2;
}
.cm-card-count {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--text-secondary);
  line-height: 1.2;
}
.cm-class-card.active .cm-card-count { color: rgba(255,255,255,0.8); }

/* ══════════════════════════════════════
   TOOLBAR (Busca + Contador)
══════════════════════════════════════ */
.cm-toolbar {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.cm-search-box {
  flex: 1;
  min-width: 240px;
  position: relative;
  display: flex;
  align-items: center;
}
.cm-search-box input {
  width: 100%;
  padding: var(--space-3) var(--space-4) var(--space-3) 2.75rem;
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-lg);
  font-size: 0.9375rem;
  color: var(--text-primary);
  background: var(--white);
  transition: var(--transition-base);
  outline: none;
}
.cm-search-box input:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(37,99,235,0.1);
}
.cm-search-icon {
  position: absolute;
  left: var(--space-4);
  color: var(--text-secondary);
  font-size: 0.875rem;
  pointer-events: none;
}

.cm-count-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: var(--gray-50);
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-lg);
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--text-secondary);
  white-space: nowrap;
}
.cm-count-badge i  { color: var(--primary); }
#cmCountNum        { color: var(--primary); font-size: 1rem; }

/* ══════════════════════════════════════
   CARD / CONTAINER DA TABELA
══════════════════════════════════════ */
.cm-table-card {
  background: var(--white);
  border: 1.5px solid var(--border-color);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.cm-table-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  padding: var(--space-16);
  color: var(--text-secondary);
  font-size: 1rem;
}
.cm-table-loading i { color: var(--primary); font-size: 1.25rem; }

.cm-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

/* ══════════════════════════════════════
   TABELA
══════════════════════════════════════ */
.cm-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9375rem;
}

/* Cabeçalho da tabela */
.cm-table thead {
  background: linear-gradient(to bottom, #f8fafc, #f1f5f9);
  border-bottom: 2px solid var(--primary);
  position: sticky;
  top: 0;
  z-index: 5;
}
.cm-table th {
  padding: var(--space-4);
  text-align: left;
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--text-primary);
  white-space: nowrap;
}
.cm-table th i { color: var(--primary); margin-right: 5px; }

/* Linhas do corpo */
.cm-row {
  cursor: pointer;
  transition: background 0.12s ease;
}
.cm-row td {
  padding: var(--space-4);
  border-bottom: 1px solid var(--gray-100);
  vertical-align: middle;
  color: var(--text-primary);
}
.cm-row:last-child td   { border-bottom: none; }
.cm-row:hover           { background: rgba(37,99,235,0.04); }
.cm-row:hover .cm-child-name { color: var(--primary); }
.cm-row-inactive        { opacity: 0.65; }
.cm-row-inactive:hover  { opacity: 0.85; }

/* Tamanhos de colunas */
.cm-th-idx, .cm-td-idx {
  width: 44px;
  text-align: center;
  color: var(--text-secondary);
  font-size: 0.8rem;
  font-weight: 600;
}
.cm-th-birth, .cm-td-birth { width: 155px; }
.cm-th-actions, .cm-td-actions {
  width: 84px;
  text-align: right;
}

/* ── Célula de nome ── */
.cm-name-cell {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.cm-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--white);
  flex-shrink: 0;
  box-shadow: 0 1px 4px rgba(0,0,0,0.15);
  text-transform: uppercase;
}
.cm-child-name {
  font-weight: 600;
  color: var(--text-primary);
  transition: color var(--transition-fast);
}
.cm-inactive-tag {
  font-size: 0.6875rem;
  font-weight: 700;
  color: var(--warning);
  background: rgba(245,158,11,0.1);
  border: 1px solid rgba(245,158,11,0.3);
  border-radius: var(--radius-full);
  padding: 2px 8px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-left: var(--space-2);
}

/* ── Célula de nascimento ── */
.cm-birth-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.cm-birth-date {
  font-size: 0.875rem;
  color: var(--text-secondary);
}
.cm-age-chip {
  display: inline-flex;
  align-items: center;
  background: rgba(37,99,235,0.08);
  color: var(--primary);
  font-size: 0.75rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: var(--radius-full);
  border: 1px solid rgba(37,99,235,0.15);
  white-space: nowrap;
}

/* ── Célula de classe ── */
.cm-class-cell {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.cm-class-emblem {
  width: 22px;
  height: 22px;
  object-fit: contain;
  flex-shrink: 0;
}
.cm-class-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.cm-class-text {
  font-weight: 600;
  font-size: 0.875rem;
}

/* ── Célula de telefone ── */
.cm-phone-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--text-primary);
  text-decoration: none;
  font-size: 0.875rem;
  transition: color var(--transition-fast);
  white-space: nowrap;
}
.cm-phone-link:hover   { color: var(--success); }
.cm-phone-link i       { color: var(--success); font-size: 0.8rem; }
.cm-no-data            { color: var(--text-secondary); }

/* ── Botões de ação na linha ── */
.cm-btn-row {
  width: 32px;
  height: 32px;
  border: none;
  border-radius: var(--radius-md);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8125rem;
  transition: var(--transition-base);
  margin-left: 4px;
}
.cm-btn-row--edit          { background: rgba(245,158,11,0.1); color: #d97706; }
.cm-btn-row--edit:hover    { background: #f59e0b; color: var(--white); transform: scale(1.1); }
.cm-btn-row--delete        { background: rgba(239,68,68,0.1); color: var(--danger); }
.cm-btn-row--delete:hover  { background: var(--danger); color: var(--white); transform: scale(1.1); }

/* ══════════════════════════════════════
   ESTADO VAZIO
══════════════════════════════════════ */
.cm-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-16) var(--space-8);
  gap: var(--space-4);
  text-align: center;
}
.cm-empty-state i {
  font-size: 3.5rem;
  color: var(--gray-300);
}
.cm-empty-state p {
  font-size: 1rem;
  color: var(--text-secondary);
  max-width: 320px;
  margin: 0;
}

/* ══════════════════════════════════════
   MODAL
══════════════════════════════════════ */
.cm-modal-content { max-width: 520px; }

.cm-form-hint {
  display: block;
  font-size: 0.8rem;
  color: var(--text-secondary);
  margin-top: var(--space-1);
}
.cm-req { color: var(--danger); margin-left: 2px; }

/* ══════════════════════════════════════
   RESPONSIVO
══════════════════════════════════════ */
@media (max-width: 768px) {
  .cm-page-header    { flex-direction: column; align-items: flex-start; }
  .cm-page-header-right { align-self: flex-end; margin-top: calc(-1 * var(--space-10)); }
  .cm-toolbar        { flex-direction: column; align-items: stretch; }
  .cm-search-box     { min-width: unset; }
  .cm-count-badge    { align-self: flex-end; }

  /* Ocultar colunas menos críticas */
  .cm-th-birth, .cm-td-birth   { display: none; }
}

@media (max-width: 480px) {
  .cm-page { gap: var(--space-4); }
  .cm-class-filter-row { gap: var(--space-2); }
  .cm-page-header-right { margin-top: 0; align-self: stretch; }
  .cm-btn-add { width: 100%; justify-content: center; }
}
