/* ===== BASE CSS VARIABLES & RESET ===== */
:root {
    --primary: #4361ee;
    --primary-dark: #3a56d4;
    --secondary: #f97316;
    --accent: #10b981;
    --bg: #ffffff;
    --text: #1e293b;
    --text-light: #64748b;
    --dark: #0f172a;
    --gray: #94a3b8;
    --gray-light: #f1f5f9;
    --gray-border: #e2e8f0;
    --gradient: linear-gradient(135deg, #4361ee, #6c63ff);
    --gradient-secondary: linear-gradient(135deg, #f97316, #fb923c);
    --radius: 8px;
    --radius-lg: 12px;
    --shadow: 0 2px 10px rgba(0, 0, 0, 0.04);
    --shadow-hover: 0 8px 25px rgba(0, 0, 0, 0.08);
    --transition: all 0.3s ease;
}

* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

body {
    font-family: 'Inter', sans-serif;
    background: var(--bg);
    color: var(--text);
    line-height: 1.6;
    scroll-behavior: smooth;
    position: relative;
    min-height: 100vh;
}

/* Remove background patterns */
body::before {
    display: none;
}

a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }

section {
    scroll-snap-align: start;
}

html {
    scroll-behavior: smooth;
    scroll-snap-type: y mandatory;
    overflow-y: scroll;
}

.container {
    width: min(1200px, 92%);
    margin: auto;
}

/* ===== ANIMATIONS & UTILITIES ===== */
@keyframes bounceRight {
    0%, 20%, 50%, 80%, 100% {
        transform: translateX(0);
    }
    40% {
        transform: translateX(-10px);
    }
    60% {
        transform: translateX(-5px);
    }
}

@keyframes bounceDown {
    0%, 20%, 50%, 80%, 100% {
        transform: translate(-50%, 0);
    }
    40% {
        transform: translate(-50%, -10px);
    }
    60% {
        transform: translate(-50%, -5px);
    }
}

@keyframes spin {
    0% { transform: translate(-50%, -50%) rotate(0deg); }
    100% { transform: translate(-50%, -50%) rotate(360deg); }
}

@keyframes fadeIn {
    from { opacity: 0; transform: translateY(20px); }
    to { opacity: 1; transform: translateY(0); }
}

@keyframes bounce {
    0%, 20%, 50%, 80%, 100% {
        transform: translateX(0);
    }
    40% {
        transform: translateX(10px);
    }
    60% {
        transform: translateX(5px);
    }
}

.animate-fadeIn {
    animation: fadeIn 0.6s ease forwards;
}

.delay-1 { animation-delay: 0.1s; }
.delay-2 { animation-delay: 0.2s; }
.delay-3 { animation-delay: 0.3s; }

/* Loading state */
body:not(.loaded) .animate-fadeIn {
    opacity: 0;
    transform: translateY(20px);
}

.loaded .animate-fadeIn {
    transition: opacity 0.6s ease, transform 0.6s ease;
}

/* Disable snap scrolling on desktop for normal browsing */
@media (min-width: 1025px) {
    html {
        scroll-snap-type: none;
    }

    section {
        scroll-snap-align: none;
    }
}