.ratio-3x2 {
  aspect-ratio: 3/2;
}

.object-contain {
  object-fit: contain;
}

.text-md {
  font-size: 1rem!important;
}

.text-sm {
  font-size: .875rem!important;
}

.text-xs {
  font-size: .75rem!important;
}

.text-lg {
  font-size: 1.125rem!important;
}

.full-width {
  width: 100vw;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
}

.text-primary {
  color: var(--bs-primary)!important;
}

.text-dark {
  color: var(--bs-dark) !important;
}

.placeholder {
  background-color: initial !important;
}

.is-valid {
  border-color: var(--success);
}

.is-invalid {
  border-color: var(--danger);
}

@media (min-width: 768px) {
  .w-md-50 {
    width: 50% !important;
  }
}

@media (min-width: 992px) {
  .w-lg-50 {
    width: 50% !important;
  }
}
