/*
 * ══════════════════════════════════════════════
 *  HERO-TRANSITION.CSS — Estilos da Transição
 * ══════════════════════════════════════════════
 *
 *  Propósito : Efeitos premium de grade de pontos pulsante (ripple),
 *              glows interativos dos logos e 3D horizon divider.
 *  Dependências : tokens.css, global.css.
 */

/* ── Grade de Pontos de Fundo com Máscara Pulsante ───────────────── */
#hero-transition .dot-grid {
    background-image: radial-gradient(rgba(14, 165, 233, 0.12) 1.5px, transparent 1.5px);
    background-size: 28px 28px;
    mask-image: radial-gradient(circle 320px at 50% 50%, black 10%, transparent 90%);
    -webkit-mask-image: radial-gradient(circle 320px at 50% 50%, black 10%, transparent 90%);
    animation: dot-grid-ripple 10s ease-in-out infinite alternate;
}

@keyframes dot-grid-ripple {
    0% {
        mask-image: radial-gradient(circle 260px at 50% 50%, black 10%, transparent 80%);
        -webkit-mask-image: radial-gradient(circle 260px at 50% 50%, black 10%, transparent 80%);
        transform: scale(0.98);
        opacity: 0.7;
    }
    50% {
        mask-image: radial-gradient(circle 440px at 50% 50%, black 25%, transparent 95%);
        -webkit-mask-image: radial-gradient(circle 440px at 50% 50%, black 25%, transparent 95%);
        transform: scale(1.02);
        opacity: 1;
    }
    100% {
        mask-image: radial-gradient(circle 340px at 50% 50%, black 15%, transparent 85%);
        -webkit-mask-image: radial-gradient(circle 340px at 50% 50%, black 15%, transparent 85%);
        transform: scale(1);
        opacity: 0.85;
    }
}

/* ── Glow e Grayscale Oscilante para Logos (Sem Cards) ───────────── */
.logo-container {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 56px;
    height: 56px;
    flex-shrink: 0;
    will-change: transform, opacity, filter;
    cursor: pointer;
}

.logo-icon {
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

@keyframes subtle-glow {
    0%, 100% {
        opacity: 0.35;
        filter: grayscale(85%);
        transform: scale(0.92);
    }
    50% {
        opacity: 1;
        filter: grayscale(0%);
        transform: scale(1.08);
    }
}

/* ── Animação Marquee Horizontal Loop ───────────────────────────── */
@keyframes marquee {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

.animate-marquee {
    display: flex;
    width: max-content;
    animation: marquee 35s linear infinite;
}

/* Pausa o scroll do marquee ao passar o mouse sobre o contêiner */
.animate-marquee-container:hover .animate-marquee {
    animation-play-state: paused;
}

/* Efeito Hover do Logo */
.logo-container:hover {
    animation: none !important;
    transform: scale(1.22) !important;
    filter: grayscale(0%) !important;
    opacity: 1 !important;
}

.logo-container:hover .logo-icon {
    filter: drop-shadow(0 0 12px rgba(14, 165, 233, 0.5));
}

/* ── Ajustes Responsivos de Escala e Alinhamento ───────────────── */
@media (max-width: 640px) {
    #hero-transition {
        padding-top: 3rem;
    }
    .logo-container {
        width: 48px;
        height: 48px;
    }
}
