/* Variables */

:root {
    /* Layout */
    --container-width: 1400px;
    --section-spacing: 120px;
    --navbar-height: 80px;
    --footer-height: 50px;

    /* Colors */
    --bg-primary: #050505;
    --bg-secondary: #0D0D0D;
    --text-primary: #FFFFFF;
    --text-secondary: #FFFFFFB2;
    --accent: #C33C54;
    --accent-hover: #ED5571;
    --border-subtle: #FFFFFF14;

    /* Animations */
    --transition-fast: 0.2s ease;
    --transition-medium: 0.35s cubic-bezier(0.22, 1, 0.36, 1);
    --transition-smooth: cubic-bezier(0.22, 1, 0.36, 1);
}

/* Font faces */

@font-face {
    font-family: 'MadimiOne-Regular';
    src: url('../assets/fonts/madimi/MadimiOne-Regular.ttf') format('truetype');
}

@font-face {
    font-family: 'Rubik-Light';
    src: url('../assets/fonts/rubik/static/Rubik-Light.ttf') format('truetype');
}

/* Scroll bar */

*::-webkit-scrollbar {
    display: none; /* Hide scrollbar for Chrome, Safari and Opera */
}

* {
    scrollbar-width: none; /* Hide scrollbar for Firefox */
    -ms-overflow-style: none; /* Hide scrollbar for IE and Edge */
}

/* Basic rules for all pages */

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    padding: 0;
    opacity: 0;
    width: 100vw;
    overflow-x: hidden;
    background-color: var(--bg-primary);
    color: var(--text-primary);
    font-family: 'Rubik-Light', sans-serif, Arial;
    text-rendering: optimizeLegibility;
    -webkit-font-smoothing: antialiased;
    animation: pageFade 0.5s ease forwards;
}

.section {
    position: relative;
    width: 100%;
}

h1 {
    font-family: 'MadimiOne-Regular', sans-serif, Arial;
    font-size: 4rem;
    line-height: 1;
    margin: 0;
}

h2 {
    font-family: 'MadimiOne-Regular', sans-serif, Arial;
    font-size: 3rem;
    line-height: 1;
    margin: 0;
}

h3 {
    font-family: 'MadimiOne-Regular', sans-serif, Arial;
    font-size: 2rem;
    line-height: 1;
    margin: 0;
}

p {
    font-family: 'Rubik-Light', sans-serif, Arial;
    font-size: 1.5rem;
    line-height: 1.6;
    margin: 0;
}

/* Animations */

@keyframes pageFade {
    to {
        opacity: 1;
    }
}

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