.contact-cards--form-container {
  width: 100%;
  background-color: white;
  outline: solid 1px var(--neutral-100);
  border-radius: var(--table-radius);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  padding: 1.5rem;
}

.contact-cards--header {
  width: 100%;
  padding-bottom: 1.5rem;
  border-bottom: solid 1px var(--neutral-100);
  display: flex;
  align-items: center;
  justify-content: space-between;

  span {
    font-variation-settings: 'wght' var(--text-medium);
    color: var(--neutral-900);
  }

  label {
    opacity: 40%;
    color: var(--neutral-950);
    font-size: var(--rem-14);
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: .5rem;

    &:has(input[type="checkbox"]:checked) {
      opacity: 100%;
    }
  }
}

.contact-cards--inline-new-container {
  width: 100%;
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  padding-top: 1.5rem;
  gap: 1rem;
}

#contact-cards-container {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 1.5rem;
}

.contact-cards--new-button-container {
  width: fit-content;
  margin: 1.5rem auto;
}

.contact-cards--extra-options-container {
  width: fit-content;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 1rem;

  button {
    font-size: var(--rem-14);
    font-variation-settings: 'wght' 400;
    color: #FF4747;
  }
}

.contact-cards--profile-cards-container {
  width: 100%;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 5.5rem;
  flex-wrap: wrap;
  margin-block: 1.5rem;

  &[data-disabled="true"] {
    opacity: 0.25;
    pointer-events: none;
  }
}

.contact-cards--profile-card {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  flex-grow: 1;
  padding-block: .75rem;

  &[data-disabled="true"] {
    opacity: 0.25;
    pointer-events: none;
  }
}

.contact-cards--profile-card-header {
  width: 100%;
  text-align: left;
  padding-bottom: 1rem;
  border-bottom: solid 1px var(--neutral-100);
  margin-bottom: 1.5rem;

  span {
    font-variation-settings: 'wght' var(--text-medium);
    color: var(--neutral-900);
  }
}

.contact-cards--form-container-new {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 0;

  turbo-frame {
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: .5rem;
    margin-top: 1rem;

    &:has(.contact-fields--component-container:not([hidden])) {
      margin-bottom: 1rem;
    }
  }
}


#related-contacts-container > .cards--card-content {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 1.5rem;
}

#related-contacts-cards:has(.contact-cards--related-contact-card:not([hidden])) {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 1.5rem;
}

#related-contacts-cards {
  display: none;
  width: 100%;
  max-width: var(--max-in-card-input-group-width);
}

.contact-cards--related-contact-card {
  width: 100%;
  max-width: var(--max-in-card-input-group-width);
  outline: solid 1px var(--neutral-100);
}

.contact-cards--related-contact-primary-information {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 1rem;
  padding-bottom: 1rem;
  margin-bottom: 1rem;
  border-bottom: solid 1px var(--neutral-100);
}

.contact-cards--related-contact-primary-information-label {
  width: 100%;
  margin-left: calc(var(--label-max-width) + 1rem);
}

.contact-cards--contact-information-cards-grid { 
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 2rem 12rem;
  width: 100%;
}

.contact-cards--contact-information-cards-grid-column {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 1rem;
}

.contact-cards--content {
  width: 100%;
}