/* Floating link editor surface. */

.link-menu-popover {
  position: fixed;
  z-index: calc(var(--z-toolbar) + 5);
  min-width: 304px;
  max-width: min(360px, calc(100vw - 24px));
  display: grid;
  gap: 12px;
  padding: 12px;
  background: var(--bg-card);
  border: 1px solid color-mix(in srgb, var(--border) 84%, transparent);
  border-radius: 12px;
  box-shadow: 0 10px 28px rgba(26,25,23,.08), 0 1px 2px rgba(26,25,23,.04);
}

.link-menu-popover[hidden] {
  display: none;
}

[data-theme="dark"] .link-menu-popover {
  border-color: color-mix(in srgb, var(--border) 74%, transparent);
  box-shadow: 0 14px 34px rgba(0,0,0,.26), 0 1px 2px rgba(0,0,0,.24);
}

.link-menu-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.link-menu-title-wrap {
  min-width: 0;
}

.link-menu-title {
  font-size: 13px;
  font-weight: 600;
  line-height: 1.2;
  color: var(--text);
}

.link-menu-close {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  padding: 0;
  border: 1px solid transparent;
  border-radius: 8px;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}

.link-menu-close:hover {
  background: var(--fill-muted);
  color: var(--text);
}

.link-menu-close:focus-visible {
  outline: none;
  border-color: var(--interactive-selected-border);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--interactive-selected-border) 40%, transparent);
}

.link-menu-close svg {
  width: 16px;
  height: 16px;
}

.link-menu-tabs {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 4px;
  padding: 3px;
  border-radius: 10px;
  background: var(--fill-muted);
}

.link-menu-tab {
  min-height: 30px;
  min-width: 0;
  padding: 0 10px;
  border-radius: 7px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--text-muted);
  font: inherit;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}

.link-menu-tab:hover {
  color: var(--text-sec);
}

.link-menu-tab.is-active {
  color: var(--interactive-selected-fg);
  border-color: var(--interactive-selected-border);
  background: var(--interactive-selected-bg);
}

.link-menu-tab:focus-visible,
.link-menu-input:focus-visible,
.link-menu-select:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--interactive-selected-border) 60%, transparent);
}

.link-menu-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.link-menu-input,
.link-menu-select {
  min-width: 0;
  width: 100%;
  border-radius: 8px;
}

.link-menu-heading-row {
  display: grid;
  gap: 6px;
}

.link-menu-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  justify-content: flex-end;
  padding-top: 10px;
  border-top: 1px solid color-mix(in srgb, var(--border) 68%, transparent);
}

.link-menu-actions .sp-action-btn {
  border-radius: 8px;
}

.link-menu-actions .sp-action-btn[disabled] {
  opacity: 0.58;
}

.link-menu-popover.is-coarse-pointer {
  min-width: min(420px, calc(100vw - 20px));
  max-width: calc(100vw - 20px);
  gap: 12px;
  padding: 14px;
}

.link-menu-popover.is-coarse-pointer .link-menu-tab,
.link-menu-popover.is-coarse-pointer .sp-action-btn,
.link-menu-popover.is-coarse-pointer .link-menu-input,
.link-menu-popover.is-coarse-pointer .link-menu-select,
.link-menu-popover.is-coarse-pointer .link-menu-close {
  min-height: 38px;
}

.link-menu-popover.is-coarse-pointer .link-menu-actions {
  flex-wrap: wrap;
}

@media (max-width: 767px) {
  .link-menu-popover {
    min-width: min(360px, calc(100vw - 16px));
    max-width: calc(100vw - 16px);
    gap: 11px;
    padding: 13px;
  }

  .link-menu-actions {
    flex-wrap: wrap;
    justify-content: stretch;
  }

  .link-menu-actions .sp-action-btn {
    flex: 1 1 96px;
  }

  .link-menu-tabs {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
