/* ==============================================================================
   style.css — Landing page Lumera Digital
   Complementa o Tailwind (via CDN) com as classes de assinatura visual da
   marca: glow ambiente, vidro escuro, texto em gradiente, e as animações
   de entrada usadas nos modais e cards. Mantém a mesma cor-base (#9333ea)
   usada em todo o resto do sistema (painel, cliente, cartão virtual).
   ============================================================================== */

:root {
    --cor-primaria: #9333ea;
    --cor-primaria-2: #6366f1;
    --cor-acento-jogo: #f59e0b;
    --cor-acento-resultado: #10b981;
}

* { -webkit-tap-highlight-color: transparent; }

html { scroll-behavior: smooth; }

/* Glow ambiente de fundo, fixo, abaixo de todo o conteúdo */
.bg-glow-landing {
    position: fixed;
    inset: 0;
    z-index: 0;
    pointer-events: none;
    background:
        radial-gradient(circle at 15% 10%, rgba(147, 51, 234, 0.18) 0%, transparent 45%),
        radial-gradient(circle at 85% 25%, rgba(99, 102, 241, 0.14) 0%, transparent 45%),
        radial-gradient(circle at 50% 90%, rgba(16, 185, 129, 0.08) 0%, transparent 50%);
}

/* Texto com gradiente de marca, usado nos destaques de headline */
.gradient-text {
    background-image: linear-gradient(90deg, #c084fc, #818cf8, #f472b6);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* Navegação fixa com efeito de vidro ao rolar a página */
.glass-nav {
    background: rgba(2, 6, 23, 0.7);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid rgba(148, 163, 184, 0.08);
}

/* Cards com efeito de vidro escuro, usados em toda a página */
.glass-card-dark {
    background: rgba(15, 23, 42, 0.55);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(148, 163, 184, 0.1);
}

/* Esconde a barra de rolagem do conteúdo do modal de onboarding, sem
   esconder a capacidade de rolar (acessibilidade preservada) */
.no-scrollbar::-webkit-scrollbar { display: none; }
.no-scrollbar { scrollbar-width: none; }

/* Toast de aviso: estado visível, alternado via JS */
#toast-aviso.show,
#toast-aviso:not(.opacity-0) {
    opacity: 1;
}

/* Notificação flutuante de prova social: entra suavemente, nunca grita */
#fake-notify {
    opacity: 0;
    transform: translateY(12px);
    transition: opacity 0.5s ease, transform 0.5s ease;
}
#fake-notify.show {
    opacity: 1;
    transform: translateY(0);
}

/* Pequeno movimento ambiente no badge "ao vivo" do topo do hero */
.floating-element {
    animation: flutuarSuave 4s ease-in-out infinite;
}
@keyframes flutuarSuave {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-4px); }
}

/* Entrada do modal de onboarding */
.fade-in { animation: fadeInOverlay 0.25s ease both; }
@keyframes fadeInOverlay {
    from { opacity: 0; }
    to { opacity: 1; }
}

.animate-bounce-in { animation: bounceInModal 0.35s cubic-bezier(0.16, 1, 0.3, 1) both; }
@keyframes bounceInModal {
    from { opacity: 0; transform: translateY(24px) scale(0.97); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}

/* Selo de nível do cartão-assinatura no hero (Bronze → Lenda) */
.selo-nivel-card {
    transition: transform 0.4s ease, opacity 0.4s ease;
}

/* Acessibilidade: respeita preferência do sistema por menos movimento */
@media (prefers-reduced-motion: reduce) {
    .floating-element,
    .fade-in,
    .animate-bounce-in,
    #fake-notify {
        animation: none !important;
        transition: none !important;
    }
}

/* Foco visível em todos os elementos navegáveis por teclado */
a:focus-visible,
button:focus-visible,
input:focus-visible,
summary:focus-visible {
    outline: 2px solid var(--cor-primaria-2);
    outline-offset: 2px;
}
