.menu {
  position: relative;
  display: inline-flex;
}

.menu__trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-body);
  font-weight: var(--fw-bold);
  font-size: var(--fs-body-s);
  padding: 9px 12px;
  border: var(--border-w) solid var(--border);
  border-radius: var(--radius-md);
  background: var(--surface-raised);
  color: var(--text);
  cursor: pointer;
  transition: var(--transition-press);
}
.menu__trigger:active {
  transform: var(--press-nudge);
}
.menu__trigger--on {
  background: var(--secondary);
  color: var(--on-color);
}

.menu__popover {
  position: absolute;
  z-index: 30;
  top: calc(100% + 10px);
  right: 0;
  width: 210px;
  background: var(--surface-raised);
  border: var(--border-w-bold) solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-1);
  display: none;
}
.menu__popover--left {
  right: auto;
  left: 0;
}
.menu__popover--up {
  top: auto;
  bottom: calc(100% + 10px);
}
.menu--open .menu__popover {
  display: block;
}

.menu__popover::after {
  content: "";
  position: absolute;
  right: 16px;
  width: 14px;
  height: 14px;
  background: var(--surface-raised);
  border-right: var(--border-w-bold) solid var(--border);
  border-bottom: var(--border-w-bold) solid var(--border);
  top: -9px;
  transform: rotate(225deg); /* points up (popover below) */
}
.menu__popover--left::after {
  right: auto;
  left: 16px;
}
.menu__popover--up::after {
  top: auto;
  bottom: -9px;
  transform: rotate(45deg); /* points down (popover above) */
}

.menu__item {
  display: flex;
  align-items: center;
  gap: 11px;
  width: 100%;
  padding: 9px 10px;
  background: transparent;
  border: none;
  font-family: var(--font-body);
  font-size: 14.5px;
  color: var(--text);
  cursor: pointer;
  border-radius: var(--radius-sm);
  text-align: left;
  text-decoration: none;
}
.menu__item:hover {
  background: rgba(74, 47, 26, 0.07);
}
.menu__item--danger {
  color: var(--danger);
}
.menu__item--upgrade {
  color: var(--secondary);
  font-weight: var(--fw-bold);
}
.menu__item[hidden] {
  display: none;
}

.menu__item-icon {
  width: 24px;
  height: 24px;
  flex: none;
  border: 2px solid var(--border);
  border-radius: 7px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 12px;
}

.menu__sep {
  border: none;
  border-top: 2px dashed rgba(74, 47, 26, 0.2);
  margin: 6px 4px;
}

.menu__note {
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--text-muted);
  text-align: center;
  padding: 8px 0 4px;
  margin: 0;
}
