/* App: fintech landing + shared (no Vite; load from public) */

.text-left {
    text-align: left;
}
.text-right {
    text-align: right;
}
.text-center {
    text-align: center;
}
.text-justify {
    text-align: justify;
}

.fintech-body {
    background: linear-gradient(135deg, #050508 0%, #0a0a12 30%, #0d0d18 60%, #080810 100%);
    min-height: 100vh;
    font-family: 'Space Grotesk', ui-sans-serif, system-ui, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol', 'Noto Color Emoji';
}

.glass-card {
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(12px);
}

.glass-card-glow {
    box-shadow: 0 0 40px -10px rgba(59, 130, 246, 0.15);
}

.border-glow {
    border-color: rgba(96, 165, 250, 0.2);
    box-shadow: 0 0 30px -5px rgba(59, 130, 246, 0.2);
}

.section-reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.section-reveal.revealed {
    opacity: 1;
    transform: translateY(0);
}

@keyframes glow-pulse {
    0%, 100% { opacity: 0.4; transform: scale(1); }
    50% { opacity: 0.7; transform: scale(1.05); }
}

.animate-glow-pulse {
    animation: glow-pulse 4s ease-in-out infinite;
}

@keyframes float {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-6px); }
}

.animate-float {
    animation: float 3s ease-in-out infinite;
}

@keyframes fade-in-up {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

.portfolio-bar {
    animation: fade-in-up 0.6s ease-out forwards;
    opacity: 0;
}
