/*
 * ProfileMenu — responsive dropdown / bottom-sheet for profile switching.
 *
 * Mobile-first: defaults to a full-width bottom-sheet that slides up from
 * the bottom edge of the viewport. A semi-transparent backdrop covers the
 * page content behind it.
 *
 * Desktop (>= 768px): transforms into a compact dropdown card anchored near
 * the user-area element — no backdrop, positioned via JS inline styles.
 *
 * All colours, spacing, and typography consume design-system.css variables
 * so the component adapts to both light and dark themes automatically.
 */

/* ── Container (bottom-sheet by default) ───────────────────────────── */

.profile-menu {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 55;

  display: flex;
  flex-direction: column;

  max-height: 55vh;
  background-color: var(--color-bg);
  border: 2px solid var(--color-primary);
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  box-shadow: 0 -4px 0 0 var(--color-dark);

  opacity: 0;
  transition: opacity var(--duration-normal) var(--easing-default),
              transform var(--duration-slow) var(--easing-game);
  transform: translateY(100%);

  /* Ensure scroll doesn't leak behind the rounded top corners */
  overflow: hidden;
  pointer-events: auto;
}

.profile-menu--open {
  opacity: 1;
  transform: translateY(0);
}

.profile-menu--closing {
  opacity: 0;
  transform: translateY(100%);
  transition: opacity var(--duration-fast) var(--easing-default),
              transform var(--duration-normal) var(--easing-default);
}

/* ── Backdrop (mobile only) ────────────────────────────────────────── */

.profile-menu__backdrop {
  position: fixed;
  inset: 0;
  z-index: -1;

  background: var(--color-overlay);
  opacity: 0;
  transition: opacity var(--duration-normal) var(--easing-default);
  pointer-events: auto;
}

.profile-menu--open .profile-menu__backdrop {
  opacity: 1;
}

.profile-menu--closing .profile-menu__backdrop {
  opacity: 0;
  transition: opacity var(--duration-fast) var(--easing-default);
}

/* ── Search header ─────────────────────────────────────────────────── */

.profile-menu__header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-md) var(--space-md) var(--space-xs);
  border-bottom: 1px solid var(--color-border);
  flex-shrink: 0;
}

.profile-menu__search-icon {
  font-size: var(--icon-md);
  color: var(--color-text-muted);
  flex-shrink: 0;
}

.profile-menu__search {
  flex: 1;
  font-family: var(--font-body);
  font-size: var(--text-md);
  font-weight: var(--font-weight-body);
  color: var(--color-text);
  background-color: transparent;
  border: none;
  outline: none;
  padding: var(--space-xs) 0;
}

.profile-menu__search::placeholder {
  color: var(--color-text-muted);
  opacity: 0.6;
}

.profile-menu__search:focus {
  color: var(--color-text);
}

/* ── Profile list (scrollable) ─────────────────────────────────────── */

.profile-menu__list {
  flex: 1;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding: var(--space-xs) 0;
  -webkit-overflow-scrolling: touch;
}

.profile-menu__empty {
  padding: var(--space-lg) var(--space-md);
  text-align: center;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

/* ── Profile item ──────────────────────────────────────────────────── */

.profile-menu__item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  cursor: pointer;
  transition: background-color var(--duration-quick) var(--easing-default);
  min-height: var(--touch-target-min);
  user-select: none;
}

.profile-menu__item:hover {
  background-color: color-mix(in srgb, var(--color-primary) 10%, transparent);
}

.profile-menu__item:active {
  background-color: color-mix(in srgb, var(--color-primary) 18%, transparent);
}

.profile-menu__item--active {
  background-color: color-mix(in srgb, var(--color-accent) 12%, transparent);
}

.profile-menu__item--active:hover {
  background-color: color-mix(in srgb, var(--color-accent) 18%, transparent);
}

.profile-menu__item-icon {
  font-size: var(--icon-lg);
  color: var(--color-text-muted);
  flex-shrink: 0;
}

.profile-menu__item--active .profile-menu__item-icon {
  color: var(--color-accent);
}

.profile-menu__item-name {
  flex: 1;
  font-family: var(--font-headline);
  font-size: var(--text-md);
  font-weight: var(--font-weight-body-bold);
  color: var(--color-text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.profile-menu__item--active .profile-menu__item-name {
  font-weight: var(--font-weight-headline);
  color: var(--color-text);
}

.profile-menu__item-check {
  font-size: var(--icon-md);
  color: var(--color-accent);
  flex-shrink: 0;
}

/* Light mode: profile icons use dark navy instead of muted gray */
[data-theme="light"] .profile-menu__item-icon {
  color: var(--color-dark);
}

/* ── "+" Create button ─────────────────────────────────────────────── */

.profile-menu__actions {
  border-top: 1px solid var(--color-border);
  padding: var(--space-sm) var(--space-md);
  flex-shrink: 0;
}

.profile-menu__add-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  width: 100%;
  font-family: var(--font-headline);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-headline);
  color: var(--color-accent);
  background-color: transparent;
  border: 2px dashed color-mix(in srgb, var(--color-accent) 40%, transparent);
  border-radius: var(--radius-default);
  padding: var(--space-sm) var(--space-md);
  min-height: var(--touch-target-sm);
  cursor: pointer;
  transition: background-color var(--duration-quick) var(--easing-default),
              border-color var(--duration-quick) var(--easing-default);
}

.profile-menu__add-btn:hover {
  background-color: color-mix(in srgb, var(--color-accent) 10%, transparent);
  border-color: var(--color-accent);
}

.profile-menu__add-btn:active {
  transform: scale(0.98);
}

.profile-menu__add-btn .material-symbols-outlined {
  font-size: var(--icon-md);
}

/* ── Dropdown arrow on the user area (always visible) ──────────────── */

.top-app-bar__user-arrow {
  font-size: var(--icon-sm);
  color: var(--color-text-muted);
  transition: transform var(--duration-fast) var(--easing-default);
}

/* Rotate the arrow when the menu is open (will be toggled by a class) */
.top-app-bar__user[aria-expanded="true"] .top-app-bar__user-arrow {
  transform: rotate(180deg);
}

/* ── Desktop: compact dropdown ─────────────────────────────────────── */

@media (min-width: 768px) {
  .profile-menu {
    /*
     * Override mobile bottom-sheet: the menu becomes a compact card.
     * Inline styles from #positionMenu() set top/left/right/bottom;
     * this block provides the default card appearance.
     */
    position: fixed;
    bottom: auto;
    left: auto;
    right: auto;
    top: auto;

    width: 280px;
    max-height: 360px;
    border-radius: var(--radius-default);
    box-shadow: var(--shadow-hard);
    border: 2px solid var(--color-primary);

    /* Enter: subtle fade + slide-down from above */
    opacity: 0;
    transform: translateY(-8px);
    transition: opacity var(--duration-fast) var(--easing-default),
                transform var(--duration-fast) var(--easing-default);
  }

  .profile-menu--open {
    opacity: 1;
    transform: translateY(0);
  }

  .profile-menu--closing {
    opacity: 0;
    transform: translateY(-4px);
    transition: opacity var(--duration-quick) var(--easing-default),
                transform var(--duration-quick) var(--easing-default);
  }

  /* No backdrop on desktop */
  .profile-menu__backdrop {
    display: none;
  }
}
