/* Shared hover tooltip — appended to body by js/tooltip.js.
   Positioned fixed so it escapes ALL parent overflow/z-index contexts. */

.gc-tip {
  position: fixed;
  z-index: 10000;
  background: var(--forest-dk, #143728);
  color: #fdfaf3;
  font-family: var(--sans, 'Inter', system-ui, sans-serif);
  font-size: 11.5px;
  font-weight: 500;
  line-height: 1.45;
  letter-spacing: -.002em;
  padding: 8px 12px;
  border-radius: var(--r-sm, 6px);
  max-width: 260px;
  width: max-content;
  white-space: normal;
  text-align: left;
  box-shadow: 0 6px 16px rgba(0,0,0,.18);
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transform: translateY(4px);
  transition: opacity .15s cubic-bezier(.22,.61,.36,1), transform .15s cubic-bezier(.22,.61,.36,1);
}
.gc-tip--visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

/* Arrow — positioned by JS based on placement */
.gc-tip::before {
  content: '';
  position: absolute;
  width: 0; height: 0;
  border: 5px solid transparent;
}
.gc-tip--top::before    { bottom: -10px; left: 50%; transform: translateX(-50%); border-top-color: var(--forest-dk, #143728); }
.gc-tip--bottom::before { top: -10px;    left: 50%; transform: translateX(-50%); border-bottom-color: var(--forest-dk, #143728); }
.gc-tip--left::before   { right: -10px;  top: 50%;  transform: translateY(-50%); border-left-color: var(--forest-dk, #143728); }
.gc-tip--right::before  { left: -10px;   top: 50%;  transform: translateY(-50%); border-right-color: var(--forest-dk, #143728); }

/* Popover variant — larger, supports title + body */
.gc-tip--popover {
  background: #fdfaf3;
  color: var(--ink-2, #57534E);
  border: 1px solid rgba(28,25,23,.14);
  max-width: 340px;
  padding: 14px 16px;
  font-size: 12px;
  line-height: 1.55;
  box-shadow: 0 12px 32px rgba(28,25,23,.14);
}
.gc-tip--popover::before { display: none; }
.gc-tip__title {
  display: block;
  font-family: var(--serif, 'Fraunces', Georgia, serif);
  font-size: 13px;
  font-weight: 600;
  color: var(--forest, #1B4332);
  margin: 0 0 8px;
}
.gc-tip__body { display: block; }
.gc-tip strong { color: #fdfaf3; font-weight: 600; }
.gc-tip--popover strong { color: var(--ink, #1c1917); font-weight: 600; }

/* Reduced motion — drop transitions */
@media (prefers-reduced-motion: reduce) {
  .gc-tip { transition: none; transform: none; }
  .gc-tip--visible { transform: none; }
}
