:host {
  /**
   * @prop --background: Background of the menu
   * @prop --border-radius: Border radius
   * @prop --overflow: Overflow
   *
   * @prop --padding-top: Top padding
   * @prop --padding-end: Right padding if direction is left-to-right, and left padding if direction is right-to-left
   * @prop --padding-bottom: Bottom padding
   * @prop --padding-start: Left padding if direction is left-to-right, and right padding if direction is right-to-left
   *
   * @prop --min-width: Minimum width of the menu
   * @prop --width: Width of the menu
   * @prop --max-width: Maximum width of the menu
   *
   * @prop --min-height: Minimum height of the menu
   * @prop --height: Height of the menu
   * @prop --max-height: Maximum height of the menu
   *
   * @prop --backdrop-opacity: Opacity of the backdrop
   */
  --width: 264px;
  --min-width: auto;
  --max-width: auto;
  --height: 100%;
  --background: var(--bkkr-background-color, #fff);
  --border-radius: 0;
  --box-shadow: 0 15px 25px 0 rgba(var(--box-shadow-color, 0, 0, 0), 0.1), 0 6px 20px 0 rgba(var(--box-shadow-color, 0, 0, 0), 0.12), 0 13.2px 40px 0 rgba(var(--box-shadow-color, 0, 0, 0), 0.08);
  --backdrop-opacity: var(--bkkr-backdrop-opacity, 0.3);
  --overflow: hidden;
  --padding-top: 0px;
  --padding-end: 0px;
  --padding-bottom: 0px;
  --padding-start: 0px;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  display: none;
  position: absolute;
  transform-style: preserve-3d;
  contain: size style;
}

:host(.show-menu) {
  display: block;
}

.menu-native {
  left: 0;
  right: auto;
  top: 0;
  bottom: 0;
  padding-left: var(--padding-start);
  padding-right: var(--padding-end);
  padding-top: var(--padding-top);
  padding-bottom: var(--padding-bottom);
  display: flex;
  position: absolute;
  flex-direction: column;
  justify-content: space-between;
  width: var(--width);
  min-width: var(--min-width);
  max-width: var(--max-width);
  height: var(--height);
  transform: translateX(-9999px);
  contain: size style;
  box-sizing: border-box;
  z-index: 1000;
}
[dir=rtl] .menu-native, :host-context([dir=rtl]) .menu-native {
  left: unset;
  right: unset;
  left: auto;
  right: 0;
}

@supports (margin-inline-start: 0) or (-webkit-margin-start: 0) {
  .menu-native {
    padding-left: unset;
    padding-right: unset;
    -webkit-padding-start: var(--padding-start);
    padding-inline-start: var(--padding-start);
    -webkit-padding-end: var(--padding-end);
    padding-inline-end: var(--padding-end);
  }
}

.menu-inner {
  border-radius: var(--border-radius);
  display: flex;
  position: relative;
  flex-direction: column;
  justify-content: space-between;
  width: 100%;
  height: 100%;
  background: var(--background);
  box-shadow: var(--box-shadow);
  contain: size style;
  overflow: var(--overflow);
}

:host(.menu-side-start) .menu-native {
  --safe-area-right: 0px;
  left: 0;
  right: auto;
}
:host-context([dir=rtl]):host(.menu-side-start) .menu-native, :host-context([dir=rtl]).menu-side-start .menu-native {
  left: unset;
  right: unset;
  left: auto;
  right: 0;
}

:host(.menu-side-end) .menu-native {
  --safe-area-left: 0px;
  left: auto;
  right: 0;
}
:host-context([dir=rtl]):host(.menu-side-end) .menu-native, :host-context([dir=rtl]).menu-side-end .menu-native {
  left: unset;
  right: unset;
  left: 0;
  right: auto;
}

bkkr-backdrop {
  display: none;
  z-index: -1;
}

:host(.menu-type-reveal) {
  z-index: 0;
}

:host(.menu-type-reveal.show-menu) .menu-native {
  transform: translate3d(0, 0, 0);
}

:host(.menu-type-overlay) {
  z-index: 100;
}

:host(.menu-type-overlay) .show-backdrop {
  display: block;
  cursor: pointer;
}

:host(.menu-fullscreen) {
  --width: 100%;
  --min-width: auto;
  --max-width: auto;
}

:host(.menu-pane-visible) {
  width: var(--width);
  min-width: var(--min-width);
  max-width: var(--max-width);
}

:host(.menu-pane-visible) .menu-native {
  top: 0;
  bottom: 0;
  width: 100%;
  /* stylelint-disable declaration-no-important */
  transform: none !important;
  box-shadow: none !important;
}

:host(.menu-pane-visible) bkkr-backdrop {
  display: hidden !important;
  /* stylelint-enable declaration-no-important */
}