.menu-wrap {
  position: relative;

  padding: 12px;              /* bigger interaction zone */
  padding-bottom: calc(6px + 0.5em);
}


.menu[hidden]  {
  display: none;
}

.menu {
  position: absolute;
  top: 100%;
  z-index: 1200;

  display: grid;
  gap: 0.5em;
  overflow: auto;
  touch-action: none;

  width: max-content;
  max-width: calc(100vw - 24px);
  max-height: calc(100dvh - var(--header-height) - 24px);

  padding: 0.5em;

  background-color: var(--panel-color);

  border-width: 1px;
  border-style: solid;
  border-color: var(--border-color);
  border-radius: 10px;
  box-shadow: 0 10px 30px rgba(0,0,0,.2); 

  opacity: 0;
  transform-origin: top right;
  transform: translateY(calc(-8px - 0.5em));
  transition:
    background-color var(--theme-transition),
    border-color var(--theme-transition),
    box-shadow var(--theme-transition),
    opacity var(--menu-transition-close),
    transform var(--menu-transition-close);
    
  pointer-events: none;
  touch-action: auto;

  scrollbar-gutter: stable;
  -webkit-overflow-scrolling: touch;
}

.menu.open{
  opacity: 1;
  transform: translateY(0);
  transition:
    background-color var(--theme-transition),
    border-color var(--theme-transition),
    box-shadow var(--theme-transition),
    opacity var(--menu-transition-open),
    transform var(--menu-transition-open);
    
  pointer-events: auto;
}

/* Left and right sides inside of .menu */
.left-side .menu {
  left: 0;
  right: auto;
}

.right-side .menu {
  right: 12px;
  left: auto;
}

/* Menu content styles */
.menu--spacer{
  width: calc(var(--bar-button-height) + 24px);
}

.menu--row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1em;

  padding: 0.25em 0.5em;
}

.menu--title{
  margin: 0;
  
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: 0.4px;
  white-space: nowrap;
}

.menu--buttons{
  display: flex;
  align-items: center;
  justify-content: flex-end;        /* right align */
  gap: 6px;
  flex-wrap: nowrap;          
}

@media (max-width:420px){
  .menu--buttons{ flex-wrap: wrap; }
}