.inoforest-mobile-menu-widget-wrap {
  position: relative;
}

.inoforest-mobile-trigger {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  background: transparent;
  border: 1px solid currentColor;
  --icon-size: 20px;
}

.inoforest-mobile-trigger i {
  font-size: var(--icon-size);
  line-height: 1;
}

.inoforest-mobile-trigger svg,
.inoforest-mobile-trigger .e-font-icon-svg,
.inoforest-mobile-trigger .elementor-icon svg {
  width: var(--icon-size);
  height: var(--icon-size);
  display: inline-block;
  flex: 0 0 var(--icon-size);
  fill: currentColor;
}

.inoforest-mobile-overlay-widget {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.5);
  opacity: 0;
  visibility: hidden;
  transition: opacity .25s ease, visibility .25s step-end;
  z-index: 9998;
}

.inoforest-mobile-menu-widget.offcanvas {
  position: fixed;
  top: 0;
  bottom: 0;
  width: 80vw;
  max-width: 360px;
  background: #fff;
  transform: translate3d(-100%,0,0);
  transition: transform .3s ease;
  z-index: 9999;
  outline: none;
}

.inoforest-mobile-menu-widget.offcanvas.from-right { left: auto; right: 0; transform: translate3d(100%,0,0); }
.inoforest-mobile-menu-widget.offcanvas.from-top { left: 0; right: 0; width: 100vw; height: 60vh; transform: translate3d(0,-100%,0); }
.inoforest-mobile-menu-widget.offcanvas.from-bottom { left: 0; right: 0; width: 100vw; height: 60vh; bottom: 0; top: auto; transform: translate3d(0,100%,0); }
.inoforest-mobile-menu-widget.offcanvas.from-left { left: 0; right: auto; }

.inoforest-mobile-menu-widget-wrap.is-open .inoforest-mobile-overlay-widget { opacity: 1; visibility: visible; transition-timing-function: ease, step-start; }
.inoforest-mobile-menu-widget-wrap.is-open .inoforest-mobile-menu-widget.offcanvas { transform: translate3d(0,0,0); }

.inoforest-offcanvas-header {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 10px;
  border-bottom: 1px solid rgba(0,0,0,.06);
}
.inoforest-offcanvas-header .inoforest-close-btn {
  background: transparent;
  border: 0;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
}

.inoforest-mobile-nav .menu { list-style: none; margin: 0; padding: 10px; }
.inoforest-mobile-nav .menu > li { border-bottom: 1px solid rgba(0,0,0,.06); }
.inoforest-mobile-nav .menu a { display: block; padding: 12px 10px; color: inherit; text-decoration: none; }
.inoforest-mobile-nav .menu .menu-item-has-children > a { position: relative; }
.inoforest-mobile-nav .menu .menu-item-has-children.submenu-open > .sub-menu { display: block; }
.inoforest-mobile-nav .menu .sub-menu { display: none; padding-left: 12px; }


