@layer components;

/* ========== STATISTICS / ICON GRID (desktop first) ========== */

.alpha_nova-icon-grid {
  display: flex;
  gap: var(--spacing-8);                 
  flex-wrap: wrap;
  width: 90%;                       
  margin: 0 auto;
  padding: var(--spacing-2) 0;           
}

.alpha_nova-icon-grid > * {
  flex: 1;
  min-width: 30%;                  
}

.alpha_nova-icon-box {
  padding: var(--spacing-4);            
  padding-top: var(--spacing-4);         
  border: 1px solid var(--x-ex-light-grey);
  border-radius: var(--radius-md);  
 box-shadow: var(--box-shadow);
  background: var(--white);
  transition: box-shadow var(--transition-medium);
}

.alpha_nova-icon-box:hover {
  box-shadow: var(--box-shadow-hover);
}

.alpha_nova-icon-box__icon {
  height: 70px;                    
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  margin: var(--spacing-4) 0;            
}

h2.alpha_nova-icon-box__title {
  font-size: var( --font-size-h3);          
  line-height: 1;
  margin-bottom: var(--spacing-4);      
  text-align: center;
}

.alpha_nova-icon-box__title span {
  font-size: 1.7rem;               
  line-height: 1;
  color: var(--accent-color);
  font-weight: var(--font-weight-semibold);
}

.alpha_nova-icon-box__title::after { display: none; }

.alpha_nova-icon-box__text {
  text-align: center;
  font-size: var( --font-size-body-sm);     
  line-height: 1.3;
}

/* ========== responsive down (desktop → tablet → mobile) ========== */

/* tablet */
@media (max-width: 900px) {  
  .alpha_nova-icon-grid {
    gap: var(--spacing-6);               
    width: 100%;
  }
  .alpha_nova-icon-box__icon { height: 50px; margin: var(--spacing-3) 0; }
  h2.alpha_nova-icon-box__title { font-size: var( --font-size-h5); }
  .alpha_nova-icon-box { padding-top: var(--spacing-4); } 
}

/* small tablets / phones landscape */
@media (max-width: 768px) {  
  .alpha_nova-icon-grid > * { min-width: 30%; } 
}

/* phones */
@media (max-width: 550px) {  
  .alpha_nova-icon-grid { gap: .75rem; padding: var(--spacing-2) 0; }
  .alpha_nova-icon-grid > * { min-width: 40%; }  
  .alpha_nova-icon-box__icon { height: 50px; }
  h2.alpha_nova-icon-box__title { font-size: 1.2rem; }
  .alpha_nova-icon-box__title span { font-size: 1.3rem; }
}

