@layer components {
  [data-tooltip] {
    position: relative;
  }

  [data-tooltip]::before,
  [data-tooltip]::after {
    position: absolute;
    inset-inline-start: 50%;
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--transition-fast), transform var(--transition-fast), visibility var(--transition-fast);
    pointer-events: none;
    z-index: 1000;
  }

  /* Text */
  [data-tooltip]::after {
    content: attr(data-tooltip);
    inset-block-end: calc(100% + 10px);
    transform: translateX(-50%) translateY(4px);
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-7);
    line-height: 1;
    white-space: nowrap;
    background: var(--foreground);
    color: var(--background);
    border-radius: var(--radius-medium);
  }

  /* Arrow */
  [data-tooltip]::before {
    content: '';
    inset-block-end: calc(100% - 5px);
    transform: translateX(-50%) translateY(4px);
    border: 8px solid transparent;
    border-top-color: var(--foreground);
  }

  [data-tooltip]:is(:hover, :focus-visible)::before,
  [data-tooltip]:is(:hover, :focus-visible)::after {
    opacity: 1;
    visibility: visible;
    transition-delay: 700ms;
    transform: translateX(-50%) translateY(0);
  }
}
