/* Popovers
******************************************************************************* */

.modal-open .popover {
  z-index: $zindex-modal + 1;
}
.popover:not(.custom-popover) {
  --#{$prefix}popover-header-bg: transparent;
  .popover-header {
    --#{$prefix}popover-border-width: 0;
    padding-block-end: 0;
  }
  .popover-arrow::after {
    --#{$prefix}popover-arrow-border: var(--#{$prefix}popover-bg);
  }
}
.popover:has([class^="popover-"]):not(.custom-popover) {
  --#{$prefix}popover-border-color: transparent;
  --#{$prefix}popover-header-bg: transparent;
  .popover-body {
    background-color: transparent;
  }
}
.popover:has([class^="popover-header-"]) {
  --#{$prefix}popover-border-color: #{$popover-border-color};
  --#{$prefix}popover-body-color: var(--#{$prefix}body-color);
  --#{$prefix}popover-header-bg: var(--#{$prefix}primary);
}

.popover {
  box-shadow: var(--#{$prefix}popover-box-shadow);

  // Popover header padding and font-size
  .popover-header {
    font-size: $h5-font-size;
    padding-block-end: 0;

  }

  // Popover body padding
  .popover-body {
    padding-block-start: $spacer;
  }
  .popover-arrow {
    z-index: 1;
  }

  &:not(.custom-popover).bs-popover-auto {
    > .popover-arrow::before {
      --#{$prefix}popover-bg: #{rgba(var(--#{$prefix}white-rgb), .1)};
    }
    &[data-popper-placement="bottom"] > {
      .popover-arrow {
        &::after {
          border-block-end-color: var(--#{$prefix}popover-arrow-border);
          inset-block-start: 1px;
        }
      }
      .popover-header::before {
        --#{$prefix}popover-border-width: 0;
      }
    }
  }
  [data-bs-theme="light"] & {
    &.popover-dark {
      --#{$prefix}popover-bg: color-mix(in sRGB, var(--#{$prefix}base-color) 90%, var(--#{$prefix}paper-bg));
    }
  }
}

/* custom popover
******************************************************************************* */
.custom-popover {
  --#{$prefix}popover-max-width: 200px;
  --#{$prefix}popover-header-color: var(--#{$prefix}white);
  --#{$prefix}popover-body-padding-x: 1rem;
  --#{$prefix}popover-body-padding-y: .5rem;
  .popover-header {
    --#{$prefix}popover-header-bg: var(--#{$prefix}primary);
  }
}

/* Dark
******************************************************************************* */

@if $enable-dark-mode {
  @include color-mode(dark) {
    .popover:not(.custom-popover) .popover-arrow::before {
      --#{$prefix}popover-arrow-border: #{rgba(var(--#{$prefix}white-rgb), .05)};
    }
  }
}


// scss-docs-start popover-modifiers
@each $state in map-keys($theme-colors) {
  .popover {
    &.popover-#{$state} {
      --#{$prefix}popover-bg: var(--#{$prefix}#{$state});
      --#{$prefix}popover-header-bg: var(--#{$prefix}#{$state});
      --#{$prefix}popover-header-color: var(--#{$prefix}#{$state}-contrast);
      --#{$prefix}popover-body-color: var(--#{$prefix}#{$state}-contrast);
      & > .popover-arrow::after {
        --#{$prefix}popover-arrow-border: var(--#{$prefix}#{$state});
      }
    }
    &.popover-header-#{$state} {
      .popover-header,
      &.bs-popover-auto[data-popper-placement="bottom"] > .popover-arrow::after {
        --#{$prefix}popover-header-bg: var(--#{$prefix}#{$state});
        --#{$prefix}popover-header-color: var(--#{$prefix}#{$state}-contrast);
      }
      & > .popover-arrow::after {
        --#{$prefix}popover-arrow-border: var(--#{$prefix}#{$state});
      }
    }
  }
}

// scss-docs-end popover-modifiers
