/* ============================================================
   config.css - Estilos módulo Configuración (<200 lin)
   Modal, cards, chips, grid, tabla — reutiliza componentes base
   ============================================================ */

/* ====== MODAL COMPARTIDO ====== */
.cfg-modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.4); z-index: 1000;
  display: flex; align-items: center; justify-content: center;
  animation: comFadeIn .2s;
}
.cfg-modal {
  background: var(--brand-surface); border-radius: 18px; width: 520px; max-width: 95vw;
  box-shadow: 0 20px 60px rgba(0,0,0,.2); animation: comFadeUp .3s ease;
  max-height: 90vh; overflow-y: auto;
}
.cfg-modal__head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 1.25rem 1.5rem; border-bottom: 1px solid var(--brand-border);
}
.cfg-modal__head h3 { margin: 0; font-size: 1.05rem; }
.cfg-modal__close {
  background: none; border: none; font-size: 1.1rem; cursor: pointer;
  color: var(--brand-text-muted); padding: .25rem;
}
.cfg-modal__close:hover { color: var(--brand-error); }
.cfg-modal__body { padding: 1.25rem 1.5rem; }
.cfg-modal__foot {
  display: flex; justify-content: flex-end; gap: .5rem;
  padding: 1rem 1.5rem; border-top: 1px solid var(--brand-border);
}

/* ====== FORM HELPERS ====== */
.cfg-form-group { margin-bottom: 1rem; }
.cfg-form-group .com-label { display: block; margin-bottom: .35rem; }
.cfg-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }

.cfg-checkbox {
  display: flex; align-items: center; gap: .5rem; cursor: pointer;
  font-size: .88rem; padding: .5rem 0;
}
.cfg-checkbox input[type="checkbox"] {
  width: 18px; height: 18px; accent-color: var(--brand-accent); cursor: pointer;
}

/* ====== ROLE CHIPS ====== */
.cfg-role-chip {
  display: inline-flex; align-items: center; padding: .2rem .6rem;
  border-radius: 8px; font-size: .72rem; font-weight: 700; letter-spacing: .3px;
}
.cfg-role-chip--admin { background: rgba(139,92,246,.12); color: #8B5CF6; }
.cfg-role-chip--vendedor { background: rgba(14,165,233,.12); color: #0EA5E9; }
.cfg-role-chip--bodega { background: rgba(245,158,11,.12); color: #D97706; }
.cfg-role-chip--compras { background: rgba(22,163,74,.12); color: #16A34A; }
.cfg-role-chip--contabilidad { background: rgba(107,114,128,.12); color: #6B7280; }
.cfg-role-chip--caja { background: rgba(236,72,153,.12); color: #EC4899; }

/* ====== TABLE ACTIONS ====== */
.cfg-actions { display: flex; gap: .35rem; justify-content: center; }
.cfg-btn-icon {
  width: 32px; height: 32px; border-radius: 8px; border: 1px solid var(--brand-border);
  background: var(--brand-surface); color: var(--brand-text-muted);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; font-size: .8rem; transition: all .2s;
}
.cfg-btn-icon:hover { border-color: var(--brand-accent); color: var(--brand-accent); background: var(--brand-bg); }
.cfg-btn-icon--danger:hover { border-color: var(--brand-error); color: var(--brand-error); }
.cfg-btn-icon--sm { width: 26px; height: 26px; font-size: .7rem; }
.cfg-sub { font-size: .72rem; color: var(--brand-text-muted); }

/* ====== BODEGAS GRID (Cards) ====== */
.cfg-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: .75rem;
}
.cfg-card {
  display: flex; align-items: center; gap: 1rem; padding: 1rem 1.25rem;
  background: var(--brand-surface); border: 1px solid var(--brand-border);
  border-radius: 14px; transition: box-shadow .2s;
  animation: comFadeUp .35s ease both;
}
.cfg-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.06); }
.cfg-card__icon {
  width: 44px; height: 44px; border-radius: 12px;
  background: var(--brand-bg); display: flex; align-items: center;
  justify-content: center; font-size: 1.2rem; color: var(--brand-accent);
  flex-shrink: 0;
}
.cfg-card__body { flex: 1; min-width: 0; }
.cfg-card__title { font-weight: 700; font-size: .95rem; }
.cfg-card__meta { display: flex; align-items: center; gap: .5rem; margin-top: .35rem; }
.cfg-card__id { font-size: .7rem; color: var(--brand-text-muted); }
.cfg-card__actions { display: flex; gap: .35rem; flex-shrink: 0; }

/* ====== CATEGORÍAS CHIP GRID ====== */
.cfg-chip-grid {
  display: flex; flex-wrap: wrap; gap: .5rem;
}
.cfg-chip {
  display: flex; align-items: center; gap: .5rem; padding: .5rem .85rem;
  background: var(--brand-surface); border: 1px solid var(--brand-border);
  border-radius: 10px; transition: all .2s;
  animation: comFadeUp .3s ease both;
}
.cfg-chip:hover { border-color: var(--brand-accent); box-shadow: 0 2px 8px rgba(0,0,0,.05); }
.cfg-chip__name { font-weight: 600; font-size: .84rem; }
.cfg-chip__id { font-size: .68rem; color: var(--brand-text-muted); }
.cfg-chip__actions { display: flex; gap: .2rem; margin-left: .25rem; }

/* ====== COUNT BAR ====== */
.cfg-count {
  margin-top: .75rem; font-size: .78rem; color: var(--brand-text-muted);
  text-align: right; padding-right: .5rem;
}

/* ====== RESPONSIVE ====== */
@media (max-width: 768px) {
  .cfg-form-row { grid-template-columns: 1fr; }
  .cfg-modal { width: 95vw; border-radius: 14px; }
  .cfg-grid { grid-template-columns: 1fr; }
}
