/* ── PROGRESS PAGE — RESPONSIVE FIX ── */

/* Stat cards no progresso: 2 colunas em mobile */
#page-progress .grid-4 {
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}

#page-progress .stat-card {
  padding: 14px;
  min-width: 0;
  overflow: hidden;
}

#page-progress .stat-value {
  font-size: clamp(1.2rem, 3vw, 2rem);
  line-height: 1.1;
  word-break: break-all;
}

#page-progress .stat-label {
  font-size: clamp(.65rem, 1.5vw, .85rem);
  line-height: 1.3;
  word-break: break-word;
}

#page-progress .stat-icon {
  width: 32px;
  height: 32px;
  font-size: 1rem;
  flex-shrink: 0;
}

/* Layout de progresso: 2 colunas */
#page-progress .grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

/* Heatmap responsivo */
.heatmap {
  overflow-x: auto;
  overflow-y: hidden;
}

/* Bar chart */
.bar-chart {
  min-height: 80px;
}

/* ── MOBILE ≤ 768px ── */
@media (max-width: 768px) {
  #page-progress .grid-4 {
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
  }

  #page-progress .grid-2 {
    grid-template-columns: 1fr !important;
  }

  #page-progress .stat-card {
    padding: 12px !important;
  }

  #page-progress .stat-value {
    font-size: 1.4rem !important;
  }

  #page-progress .stat-label {
    font-size: .72rem !important;
  }

  .heatmap {
    grid-template-columns: repeat(13, 1fr) !important;
    gap: 2px !important;
  }

  .bar-chart {
    gap: 2px !important;
  }
}

/* ── MOBILE ≤ 480px ── */
@media (max-width: 480px) {
  #page-progress .grid-4 {
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
  }

  #page-progress .stat-card {
    padding: 10px !important;
  }

  #page-progress .stat-value {
    font-size: 1.2rem !important;
  }

  #page-progress .stat-label {
    font-size: .68rem !important;
  }

  #page-progress .stat-icon {
    width: 28px !important;
    height: 28px !important;
    font-size: .85rem !important;
  }

  .heatmap {
    grid-template-columns: repeat(10, 1fr) !important;
  }

  /* Esconde texto desnecessário nos cards pequenos */
  #page-progress .stat-card > div:last-child {
    display: none;
  }
}

/* ── NOTEBOOK / TABLET ≤ 1024px ── */
@media (max-width: 1024px) and (min-width: 769px) {
  #page-progress .grid-4 {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  #page-progress .grid-2 {
    grid-template-columns: 1fr !important;
  }
}

@media(max-width:768px){
  #progress-grid{grid-template-columns:1fr!important;}
  #page-progress .grid-4{grid-template-columns:1fr 1fr!important;gap:8px!important;}
  .heatmap{grid-template-columns:repeat(10,1fr)!important;gap:2px!important;}
}

/* ── WIZARD TOPBAR MOBILE FIX ── */
@media(max-width:768px){
  .wiz-topbar { top: 0; padding: 0 16px; }
  .wiz-topbar-inner { height: 48px; gap: 12px; }
  .wizard-container { padding-top: 16px; }
}
