/* ============================================================================
   Race Admin - Motor de dicas de onboarding (guia interativo)
   Compartilhado entre temas (web/default/copasp...). Carregar via
   themeSrc('assets/css/ra-onboarding.css', CONF_VIEW_THEME_WEB).
   Cor: cadeia de fallback resolve a cor do tema atual sem config por pagina.
   - 2026-06-28
   ============================================================================ */
:root { --ra-hint-color: var(--theme-primary, var(--kgv-blue, var(--d3-blue, #292C61))); }

/* Pulse da linha inteira (alvo grande): flash de fundo */
.ra-hint-pulse.rank-item,
.ra-hint-pulse.ra-pulse-bg { animation: raHintPulse 1s ease-in-out 3; }
@keyframes raHintPulse {
    0%, 100% { background: transparent; }
    50% { background: color-mix(in srgb, var(--ra-hint-color) 16%, transparent); }
}

/* Pulse de alvo pontual (foto, quadradinho, botao, estrela, aba): anel na cor
   do tema. Segue o border-radius do alvo. */
.ra-hint-pulse:not(.rank-item):not(.ra-pulse-bg) {
    position: relative; z-index: 2;
    animation: raHintPulseRing 1s ease-in-out 3;
}
@keyframes raHintPulseRing {
    0%, 100% { box-shadow: 0 0 0 0 transparent; }
    50% { box-shadow: 0 0 0 5px color-mix(in srgb, var(--ra-hint-color) 40%, transparent); }
}

/* Realce extra continuo: fica brilhando enquanto o balao estiver aberto
   (ex: destaca o item "Pontuacao" do menu de baixo junto com a dica da estrela) */
.ra-hint-spot { position: relative; z-index: 3; border-radius: 10px; animation: raHintSpot 1.1s ease-in-out infinite; }
@keyframes raHintSpot {
    0%, 100% { box-shadow: 0 0 0 0 transparent; }
    50% { box-shadow: 0 0 0 4px color-mix(in srgb, var(--ra-hint-color) 48%, transparent); }
}

/* Balaozinho */
.ra-hint-balloon {
    position: absolute; z-index: 99999; max-width: min(320px, 92vw);
    background: var(--ra-hint-color); color: #fff;
    font-size: 13px; line-height: 1.4; font-weight: 500;
    padding: 12px 14px 10px; border-radius: 12px; text-align: center;
    box-shadow: 0 8px 24px rgba(0,0,0,.22);
    opacity: 0; transform: translateY(-6px);
    transition: opacity .25s ease, transform .25s ease;
    font-family: inherit; -webkit-tap-highlight-color: transparent;
}
.ra-hint-balloon.above { transform: translateY(6px); }
.ra-hint-balloon.show { opacity: 1; transform: translateY(0); }

/* Seta (posicao horizontal vem do JS, pra apontar no alvo) */
.ra-hint-balloon .ra-hint-arrow {
    position: absolute; width: 0; height: 0; transform: translateX(-50%);
    border-left: 7px solid transparent; border-right: 7px solid transparent;
}
.ra-hint-balloon.below .ra-hint-arrow { top: -7px; border-bottom: 7px solid var(--ra-hint-color); }
.ra-hint-balloon.above .ra-hint-arrow { bottom: -7px; border-top: 7px solid var(--ra-hint-color); }

/* Acoes: "Fechar" (so fecha) + "nao mostrar esta dica" (grava no localStorage) */
.ra-hint-balloon .ra-hint-actions {
    display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; margin-top: 10px;
}
.ra-hint-balloon .ra-hint-actions button {
    font-family: inherit; font-size: 11px; font-weight: 700; cursor: pointer;
    border-radius: 999px; padding: 5px 13px; transition: background .15s, border-color .15s;
    -webkit-tap-highlight-color: transparent;
}
.ra-hint-balloon .ra-hint-close {
    background: #fff; color: var(--ra-hint-color); border: 1px solid #fff;
}
.ra-hint-balloon .ra-hint-close:hover { background: rgba(255,255,255,.85); }
.ra-hint-balloon .ra-hint-never {
    background: rgba(255,255,255,.10); color: #fff; border: 1px solid rgba(255,255,255,.5); font-weight: 600;
}
.ra-hint-balloon .ra-hint-never:hover { background: rgba(255,255,255,.22); border-color: #fff; }
