/**
 * Context Menu Styles
 *
 * 우클릭 컨텍스트 메뉴
 */

/* Context Menu */
.context-menu {
  position: fixed;
  min-width: 180px;
  padding: var(--spacing-1);
  background-color: var(--color-bg-primary);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  z-index: var(--z-dropdown);
  opacity: 0;
  visibility: hidden;
  transform: scale(0.95);
  transform-origin: top left;
  transition: all var(--transition-fast);
}

.context-menu--open {
  opacity: 1;
  visibility: visible;
  transform: scale(1);
}

/* Menu Item */
.context-menu__item {
  display: flex;
  align-items: center;
  gap: var(--spacing-3);
  width: 100%;
  padding: var(--spacing-2) var(--spacing-3);
  font-size: var(--font-size-sm);
  color: var(--color-text-primary);
  border-radius: var(--radius-md);
  transition: background-color var(--transition-fast);
  text-align: left;
}

.context-menu__item:hover {
  background-color: var(--color-neutral-100);
}

.context-menu__item:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.context-menu__item:disabled:hover {
  background-color: transparent;
}

.context-menu__item--danger {
  color: var(--color-error);
}

.context-menu__item--danger:hover {
  background-color: rgba(244, 67, 54, 0.1);
}

/* Menu Icon */
.context-menu__icon {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
  color: var(--color-text-secondary);
}

.context-menu__item--danger .context-menu__icon {
  color: var(--color-error);
}

/* Menu Label */
.context-menu__label {
  flex: 1;
}

/* Menu Shortcut */
.context-menu__shortcut {
  font-size: var(--font-size-xs);
  color: var(--color-text-disabled);
  font-family: var(--font-family-mono);
}

/* Menu Divider */
.context-menu__divider {
  height: 1px;
  margin: var(--spacing-1) 0;
  background-color: var(--color-neutral-200);
}

/* Submenu */
.context-menu__submenu {
  position: relative;
}

.context-menu__submenu-arrow {
  width: 12px;
  height: 12px;
  color: var(--color-text-secondary);
}

.context-menu__submenu-content {
  position: absolute;
  top: -4px;
  left: 100%;
  margin-left: var(--spacing-1);
  min-width: 160px;
  padding: var(--spacing-1);
  background-color: var(--color-bg-primary);
  border: 1px solid var(--color-neutral-200);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
  opacity: 0;
  visibility: hidden;
  transform: translateX(-8px);
  transition: all var(--transition-fast);
}

.context-menu__submenu:hover .context-menu__submenu-content {
  opacity: 1;
  visibility: visible;
  transform: translateX(0);
}

/* Color Submenu */
.context-menu__colors {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--spacing-1);
  padding: var(--spacing-2);
}

.context-menu__color {
  width: 24px;
  height: 24px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  border: 2px solid transparent;
  transition: all var(--transition-fast);
}

.context-menu__color:hover {
  transform: scale(1.15);
}

.context-menu__color--selected {
  border-color: var(--color-neutral-800);
}
