/*
 * CSS complementar ao Tailwind (carregado via CDN no base.html).
 * Estilos específicos que não são triviais com classes utilitárias.
 */

/* Esconde elementos com x-cloak até o Alpine.js inicializar (evita flash) */
[x-cloak] {
    display: none !important;
}

/* Fonte e suavização */
body {
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    -webkit-font-smoothing: antialiased;
}

/* Transição suave em elementos interativos */
button, a {
    transition: all 0.15s ease;
}

/* Scrollbar customizada para a tabela do dashboard */
.overflow-x-auto::-webkit-scrollbar {
    height: 8px;
}
.overflow-x-auto::-webkit-scrollbar-thumb {
    background: #cbd5e1;
    border-radius: 4px;
}

/* ───────────────────────────────────────────────────────────────────────────
 * MICROANIMAÇÕES — reveal no scroll (Intersection Observer, sem libs externas)
 * Elementos com [data-reveal] começam invisíveis e sobem suavemente ao entrar
 * na viewport. O atributo data-reveal recebe a classe .is-visible via JS.
 * ─────────────────────────────────────────────────────────────────────────── */
[data-reveal] {
    opacity: 0;
    transform: translateY(28px);
    transition:
        opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
    will-change: opacity, transform;
}
[data-reveal].is-visible {
    opacity: 1;
    transform: translateY(0);
}

/* Atraso escalonado para grupos de cards (stagger) */
[data-reveal-delay="1"] { transition-delay: 0.08s; }
[data-reveal-delay="2"] { transition-delay: 0.16s; }
[data-reveal-delay="3"] { transition-delay: 0.24s; }
[data-reveal-delay="4"] { transition-delay: 0.32s; }

/* Respeita usuários que preferem menos movimento (acessibilidade) */
@media (prefers-reduced-motion: reduce) {
    [data-reveal] {
        opacity: 1;
        transform: none;
        transition: none;
    }
}

/* Animação de entrada do hero (fade-up escalonado no carregamento) */
@keyframes heroFadeUp {
    from { opacity: 0; transform: translateY(20px); }
    to   { opacity: 1; transform: translateY(0); }
}
.hero-anim {
    opacity: 0;
    animation: heroFadeUp 0.8s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}
.hero-anim-1 { animation-delay: 0.1s; }
.hero-anim-2 { animation-delay: 0.25s; }
.hero-anim-3 { animation-delay: 0.4s; }
.hero-anim-4 { animation-delay: 0.55s; }

@media (prefers-reduced-motion: reduce) {
    .hero-anim { opacity: 1; animation: none; }
}
