/* Icone in pillole - Colorare le icone delle sezioni */
.icon-accent {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  margin-right: 0.6rem;
  flex: 0 0 36px;
  box-sizing: border-box;
  font-size: 1.05rem;
  color: rgba(var(--bs-white-rgb), 1);
  background: rgba(var(--bs-secondary-rgb), 1);
}

.icon-accent.primary {
  color: rgba(var(--bs-white-rgb), 1);
  background: rgba(var(--bs-primary-rgb), 1);
}

.icon-accent.success {
  color: rgba(var(--bs-white-rgb), 1);
  background: rgba(var(--bs-success-rgb), 1);
}

.icon-accent.warning {
  color: rgba(var(--bs-dark-rgb), 1);
  background: rgba(var(--bs-warning-rgb), 1);
}

.icon-accent.danger {
  color: rgba(var(--bs-white-rgb), 1);
  background: rgba(var(--bs-danger-rgb), 1);
}
.icon-accent i {
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.icon-header {
  font-size: 1.8rem; /* ingrandita */
  /* color: rgba(var(--bs-primary-rgb), 1);  colore gestibile */
  /* font-weight: 600;         più marcata  tolto perché non applicava la classe altrimenti.*/
  line-height: 1; /* centrata verticalmente */
}

/* Wrapper icona per card dashboard e hub */
.icon-wrapper {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: 18px;
  font-size: 1.3rem;
  background: rgba(var(--bs-primary-rgb), 0.1);
  color: var(--bs-primary);
  backdrop-filter: blur(4px);
  transition: all 0.2s ease;
}

.card:hover .icon-wrapper,
.hub-domain-card:hover .icon-wrapper {
  background: rgba(var(--bs-primary-rgb), 0.18);
}

/* Hover effect per i link nelle list-group delle card dashboard */
.list-group-item-action a.stretched-link {
  transition: color 0.15s ease;
}

.list-group-item-action a.stretched-link i {
  transition: transform 0.15s ease;
}

.list-group-item-action:hover a.stretched-link {
  color: var(--bs-primary) !important;
}

.list-group-item-action:hover a.stretched-link i {
  transform: translateX(2px);
}

/* Icona inline per list-group item: stessa filosofia di icon-header ma dimensionata per contesto riga */
.icon-detail {
  font-size: 1.05rem;
  line-height: 1;
  flex: 0 0 1.75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-right: 0.4rem;
}

/* Dimesione diversa per distinguere il sommario dagli accordion */
.icon-accent.small {
  width: 24px;
  height: 24px;
  font-size: 0.8rem;
  border-radius: 6px;
}
