/* ============================================================
 * GcTooltip — Estilo global moderno animado
 * ============================================================ */
.gc-tooltip {
    position: fixed;
    display: none;
    align-items: center;
    gap: 8px;
    max-width: 320px;
    padding: 10px 14px;
    background: linear-gradient(135deg, #0f172a 0%, #1e293b 100%);
    color: #f8fafc;
    font-size: 12px;
    font-weight: 600;
    font-family: inherit;
    line-height: 1.5;
    letter-spacing: 0.15px;
    border-radius: 10px;
    box-shadow:
        0 10px 30px rgba(0, 0, 0, 0.35),
        0 0 0 1px rgba(148, 163, 184, 0.15),
        inset 0 1px 0 rgba(255, 255, 255, 0.06);
    pointer-events: none;
    z-index: 999999;
    white-space: normal;
    word-wrap: break-word;

    opacity: 0;
    transform: translateY(6px) scale(0.96);
    transition: opacity 0.18s ease, transform 0.22s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.gc-tooltip.ativo {
    opacity: 1;
    transform: translateY(0) scale(1);
}

/* Quando posicionado abaixo do alvo, a animacao vem de cima */
.gc-tooltip[data-posicao="abaixo"] {
    transform: translateY(-6px) scale(0.96);
}
.gc-tooltip[data-posicao="abaixo"].ativo {
    transform: translateY(0) scale(1);
}

/* Barra de acento colorido a esquerda — destaque vivo */
.gc-tooltip::before {
    content: '';
    position: absolute;
    left: 0;
    top: 8px;
    bottom: 8px;
    width: 3px;
    background: linear-gradient(180deg, #06b6d4, #8b5cf6, #ec4899);
    border-radius: 4px;
    box-shadow: 0 0 12px rgba(139, 92, 246, 0.55);
}

.gc-tooltip-texto {
    display: inline-block;
    padding-left: 6px;
}

/* Seta (triangulo) apontando pro alvo */
.gc-tooltip-seta {
    position: absolute;
    width: 10px;
    height: 10px;
    background: linear-gradient(135deg, #1e293b, #1e293b);
    transform: rotate(45deg);
    box-shadow: 0 0 0 1px rgba(148, 163, 184, 0.15);
}

/* Tooltip acima do alvo — seta embaixo */
.gc-tooltip[data-posicao="acima"] .gc-tooltip-seta {
    bottom: -5px;
    background: linear-gradient(135deg, #1e293b 0%, #1e293b 100%);
}

/* Tooltip abaixo do alvo — seta em cima */
.gc-tooltip[data-posicao="abaixo"] .gc-tooltip-seta {
    top: -5px;
    background: linear-gradient(135deg, #0f172a 0%, #0f172a 100%);
}

/* Brilho sutil pulsando quando ativo (bem discreto) */
.gc-tooltip.ativo::after {
    content: '';
    position: absolute;
    inset: -1px;
    border-radius: 11px;
    background: linear-gradient(135deg, rgba(6, 182, 212, 0.15), rgba(139, 92, 246, 0.15), rgba(236, 72, 153, 0.15));
    z-index: -1;
    filter: blur(8px);
    opacity: 0;
    animation: gcTooltipGlow 2.4s ease-in-out infinite;
}
@keyframes gcTooltipGlow {
    0%, 100% { opacity: 0.35; }
    50%      { opacity: 0.75; }
}

/* Mobile: tooltip mais compacto */
@media (max-width: 640px) {
    .gc-tooltip {
        font-size: 11px;
        padding: 8px 12px;
        max-width: 260px;
    }
}

/* Respeita prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
    .gc-tooltip { transition: opacity 0.15s ease; }
    .gc-tooltip,
    .gc-tooltip[data-posicao="abaixo"] { transform: none; }
    .gc-tooltip.ativo::after { animation: none; opacity: 0.4; }
}
