* { font-family: 'Inter', sans-serif; }

body { background: #f0f2f5; min-height: 100vh; }

.navbar-validar {
  background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
}

.card-grupo {
  border: none;
  border-radius: 16px;
  overflow: hidden;
  height: 100%;
}

.card-grupo-header {
  color: #fff;
  padding: 1rem 1.25rem;
}

.card-grupo-header h2 {
  font-size: 1rem;
  font-weight: 700;
  margin: 0;
}

.professor-tag {
  font-size: 0.8rem;
  opacity: 0.95;
}

.unidade-list {
  max-height: 420px;
  overflow-y: auto;
  padding: 0.5rem;
}

.unidade-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid #e5e7eb;
  margin-bottom: 6px;
  background: #fff;
  transition: background 0.15s, border-color 0.15s;
}

.unidade-item.validada {
  border-color: #86efac;
  background: #f0fdf4;
}

.unidade-item .num {
  font-weight: 700;
  font-size: 0.75rem;
  color: #6b7280;
  min-width: 42px;
}

.unidade-item .titulo {
  flex: 1;
  font-size: 0.82rem;
  line-height: 1.3;
}

.unidade-item input[type="text"] {
  font-size: 0.75rem;
  margin-top: 4px;
}

.grupo-footer {
  padding: 0.75rem 1rem;
  background: #f9fafb;
  border-top: 1px solid #e5e7eb;
}

.progress-grupo {
  height: 6px;
  border-radius: 3px;
}

.caps-talk {
  font-size: 0.72rem;
  color: rgba(255,255,255,0.85);
}

.card-aprovacao { border-radius: 12px; border: none; }

.extra-unit {
  font-size: 0.8rem;
  padding: 6px 10px;
  background: #fff;
  border: 1px dashed #d1d5db;
  border-radius: 8px;
}
