/* Iconos corporativos MPG — trazo fino, monocromáticos */
.ic {
  display: inline-block;
  vertical-align: -0.125em;
  flex-shrink: 0;
  stroke: currentColor;
}

.ic--sm { width: 16px; height: 16px; }
.ic--md { width: 20px; height: 20px; }
.ic--lg { width: 24px; height: 24px; }
.ic--xl { width: 32px; height: 32px; }

.ic.me-1, .ic.me-2 { margin-right: 0.35em; }

/* Contenedor en tarjetas de servicio */
.service-icon-wrap {
  width: 48px; height: 48px; border-radius: 10px;
  background: var(--cream);
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 1.15rem;
  color: var(--blue-dark);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.9);
}
.service-icon-wrap .ic { width: 22px; height: 22px; stroke-width: 1.65; }

/* Franja regional */
.regional-strip-label .ic { color: var(--gold-dark); stroke-width: 1.65; }

/* Dashboard stats */
.stat-icon {
  width: 44px; height: 44px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
}
.stat-icon .ic { width: 22px; height: 22px; }

/* Sidebar / nav */
.sidebar-mpg .nav-link .ic,
.bottom-nav .ic {
  width: 20px; height: 20px;
  margin-bottom: 2px;
  opacity: 0.85;
}
.sidebar-mpg .nav-link.active .ic,
.bottom-nav a.active .ic { opacity: 1; }

.bottom-nav a {
  display: flex; flex-direction: column; align-items: center;
  font-size: 0.65rem; gap: 2px;
}

/* Botones con icono */
.btn .ic { vertical-align: -0.2em; }

/* WhatsApp — logo de marca en botones verdes */
.ic-whatsapp { stroke: none; }
.btn-success .ic-whatsapp,
.whatsapp-float .ic-whatsapp { color: #fff; }

.whatsapp-float {
  display: flex; align-items: center; justify-content: center;
}
.whatsapp-float .ic-whatsapp { width: 26px; height: 26px; }

/* Vacante tags */
.vacante-tag .ic {
  width: 14px; height: 14px;
  margin-right: 0.25rem;
  vertical-align: -0.15em;
  opacity: 0.7;
}

/* Favoritos — bookmark corporativo */
.fav-btn {
  background: none; border: none; padding: 0.35rem;
  color: var(--text-muted); line-height: 1;
  transition: color 0.2s ease;
}
.fav-btn .ic { width: 18px; height: 18px; }
.fav-btn.active { color: var(--blue); }
.fav-btn.active .ic { fill: rgba(11, 78, 150, 0.12); stroke: var(--blue); }

/* Estado vacío */
.empty-state .ic {
  width: 48px; height: 48px;
  color: var(--gray);
  margin-bottom: 0.75rem;
}

/* PWA banner */
.pwa-icon-wrap .ic { width: 28px; height: 28px; color: var(--blue); }
