Можно оставить как есть. 
Можно переписать так:
.parent__child {
  background: gray;
  @media (max-width: 777px) {
    background: orange;
    
    .parent--custom & {
    background: red;
  }
 }
}
можно так:
.parent__child {
  background: gray;
  @media (max-width: 777px) {
    background: orange;
  }
  .parent--custom & {
    @media (max-width: 777px) {
      background: red;
    }
  }
}
А 
совсем хорошо вот так:
.parent__child {
  --color: gray;
  background: var(--color);
  @media (max-width: 777px) {
    --color: orange;
  }
  .parent--custom & {
    @media (max-width: 777px) {
      --color: red;
    }
  }
}