/* Default base options ----------------- */
.productOptions {
  --options-space: 1.5rem;
  --options-size: 2.5rem;
  --options-values-space: .75rem;
  --options-values-font-size: var(--bs-body-font-size);
}

.productOption~.productOption {
  margin-top: var(--options-space);
}

.small-options .productOptions {
  --options-size: 2rem;
}

.productOptionValues {
  display: flex;
  gap: var(--options-values-space);
  flex-wrap: wrap;
  font-size: var(--options-values-font-size);
}

.productOptionPrompt {
  margin-bottom: .5rem;
  display: none;
}

.productOptionValueName {
  margin: 0;
}

:where(.productOptionRadioValue, .productOptionCheckboxValue) input {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

:where(.productOptionRadioValue, .productOptionCheckboxValue) {
  display: flex;
  width: 100%;
}

/* Radios text -------------------------- */
div.productOptionRadioValue:not(.productOptionImageValue) .productOptionValueName {
  border-radius: 2px;
  border: 2px solid #ddd;
  background-color: var(--tb-mono-white);
  color: #000;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out;
  height: var(--options-size);
  min-width: var(--options-size);
  padding: 0.5em 1.5rem;
  cursor: pointer;
  width: 100%;
  border-radius: 16px;
  height: 56px;
}

div.productOptionRadioValue:not(.productOptionImageValue) .productOptionValueName:hover {
  border-color: #3e3939;
}

div.productOptionRadioValue.productOptionSelected:not(.productOptionImageValue) .productOptionValueName {
  border-color: var(--acre-primary-blue);
  /* box-shadow: 0 0 0 1px var(--tb-primary-500) */
}

/* Radios img --------------------------- */
div.productOptionRadioValue.productOptionImageValue .productOptionValueName {
  border-radius: 50%;
  overflow: hidden;
  border: 1px solid #ddd;
  transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out;
  height: var(--options-size);
  width: var(--options-size);
  cursor: pointer;
}

div.productOptionRadioValue.productOptionImageValue .productOptionValueName img {
  max-width: 100%;
  height: auto;
  display: block;
}

div.productOptionRadioValue.productOptionImageValue .productOptionValueName:hover {
  border-color: #ababab;
}

div.productOptionRadioValue.productOptionSelected.productOptionImageValue .productOptionValueName {
  border-color: var(--tb-primary-500);
  box-shadow: 0 0 0 1px var(--tb-primary-500);
}

/* Radios bool -------------------------- */
div.productOptionBoolean .productOptionValue {
  margin-bottom: 0;
}

.productOptionBoolean .productOptionValues .productOptionValue+.productOptionValue {
  margin-left: 15px;
}

/* Selects ------------------------------ */
div.productOptionValue.productOptionSelectValue {
  width: 100%;
}

div.productOptionValue.productOptionSelectValue .form-select {
  min-height: var(--options-size);
  font-size: var(--options-values-font-size);
}

/* Texts -------------------------------- */
div.productOptionValue.productOptionTextValue {
  width: 100%;
}

div.productOptionValue.productOptionTextValue .form-control {
  min-height: var(--options-size);
  font-size: var(--options-values-font-size);
}

/* File --------------------------------- */
div.productOptionValue.lcProductOptionAttachment {
  width: 100%;
}

div.productOptionValue.lcProductOptionAttachment>label {
  display: none;
}

div.productOptionAttachmentButtons {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}

div.productOptionAttachmentButtons .view-attachment {
  font-size: small;
}

/* Checks text -------------------------- */
div.productOptionCheckboxValue:not(.productOptionImageValue) .productOptionValueName {
  border-radius: 2px;
  border: 1px solid #ddd;
  background-color: var(--tb-mono-white);
  color: #000;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out;
  height: var(--options-size);
  min-width: var(--options-size);
  padding: 0.5rem;
  cursor: pointer;
}

div.productOptionCheckboxValue:not(.productOptionImageValue) .productOptionValueName:hover {
  border-color: #ababab;
}

div.productOptionCheckboxValue.productOptionSelected:not(.productOptionImageValue) .productOptionValueName {
  border-color: var(--tb-primary-500);
  box-shadow: 0 0 0 1px var(--tb-primary-500)
}

/* Checks img --------------------------- */
div.productOptionCheckboxValue.productOptionImageValue .productOptionValueName {
  border-radius: 50%;
  overflow: hidden;
  border: 1px solid #ddd;
  transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out;
  height: var(--options-size);
  width: var(--options-size);
  cursor: pointer;
}

div.productOptionCheckboxValue.productOptionImageValue .productOptionValueName img {
  max-width: 100%;
  height: auto;
  display: block;
}

div.productOptionCheckboxValue.productOptionImageValue .productOptionValueName:hover {
  border-color: #ababab;
}

div.productOptionCheckboxValue.productOptionSelected.productOptionImageValue .productOptionValueName {
  border-color: var(--tb-primary-500);
  box-shadow: 0 0 0 1px var(--tb-primary-500)
}

/* Not available ------------------------ */
div.productOptionRadioValueNotAvailable:is(.productOptionRadioValue, .productOptionImageValue) .productOptionValueName {
  border-color: #ccc;
  background-color: #F0F0F0;
  color: #999;
}