/* DS §05.08 — Tooltip / popover (web) · token-only */

.ds-tooltip-wrapper {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.ds-tooltip {
  position: absolute;
  z-index: var(--z-dropdown);
  bottom: calc(100% + var(--sp-2));
  left: 50%;
  transform: translateX(-50%);
  background: var(--fg1);
  color: var(--surface);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: 500;
  line-height: 1.4;
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--rad-sm);
  box-shadow: var(--shadow-md);
  white-space: nowrap;
  max-width: 260px;
  white-space: normal;
  text-align: center;
  pointer-events: none;
  opacity: 0;
  animation: ds-tooltip-in var(--dur-fast) var(--ease-smooth) forwards;
}

@keyframes ds-tooltip-in {
  from { opacity: 0; transform: translateX(-50%) translateY(var(--sp-1)); }
  to   { opacity: 1; transform: translateX(-50%) translateY(0); }
}

/* Arrow */
.ds-tooltip::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 5px solid transparent;
  border-top-color: var(--fg1);
}

/* Placement variants */
.ds-tooltip-bottom {
  top: calc(100% + var(--sp-2));
  bottom: auto;
  transform: translateX(-50%);
}
.ds-tooltip-bottom::after {
  top: auto;
  bottom: 100%;
  border-top-color: transparent;
  border-bottom-color: var(--fg1);
}

/* Popover (larger, with border) */
.ds-popover {
  position: absolute;
  z-index: var(--z-dropdown);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--rad-md);
  box-shadow: var(--shadow-lg);
  padding: var(--sp-4);
  min-width: 200px;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--fg1);
  animation: ds-tooltip-in var(--dur-fast) var(--ease-smooth) forwards;
}
