/* Popup Menu Component */
.menu-container {
  position: relative;
}

.menu-popup {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 8px;
  background: #fff;
  border-radius: 4px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  min-width: 240px;
  z-index: 1000;
  border: 1px solid #e0e0e0;
  box-sizing: border-box;
}

.menu-popup.right-aligned {
  left: auto;
  right: 0;
}

.menu-popup.hidden {
  display: none !important;
}

.menu-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 12px 16px;
  border: none;
  background: transparent;
  text-align: left;
  font-size: 14px;
  color: #333;
  cursor: pointer;
  border-bottom: 1px solid #f0f0f0;
  box-sizing: border-box;
  text-decoration: none;
}

.menu-item:last-child {
  border-bottom: none;
}

.menu-item:not(.toggle-item):hover {
  background: #f5f5f5;
}

.menu-item.danger {
  display: flex;
  align-items: center;
  color: #f44336;
}

.menu-item.danger:hover {
  background: #ffebee;
}

/* Toggle item inside menu */
.menu-item.toggle-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: default;
}

/* ── Mobile Responsive ── */
@media (max-width: 768px) {
  .export-menu {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    top: auto;
    min-width: unset;
    width: 100%;
    border-top-left-radius: 18px;
    border-top-right-radius: 18px;
    box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.18);
    z-index: 1100;

    /* Slide animation */
    transform: translateY(100%);
    transition: transform 0.3s ease, opacity 0.3s ease;
    opacity: 0;
    display: block !important; /* override hidden so transition works */
    pointer-events: none;
  }

  .export-menu:not(.hidden) {
    transform: translateY(0);
    opacity: 1;
    pointer-events: all;
  }
}