/* Control del scrollbar en Firefox y en Chromium */
html{
    scrollbar-width: thin;
    scrollbar-color: var(--color-acid);
}

::-webkit-scrollbar {
    width: 10px;
}
::-webkit-scrollbar-track{
    background-color: var(--color-dark);
}
::-webkit-scrollbar-thumb{
    background-color: var(--color-acid);
}

body{
    display: flex;
    flex-direction: column;
    min-height: 100vh;
    background-color: var(--color-dark);
    color: var(--white);
    font-family: 'Space Mono', monospace;
    cursor: none;
    overflow-x: hidden;
}

main{
    flex: 1;
}


#hero{
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        overflow: hidden;
        pointer-events: none;
        z-index:-1;
    }

    .hero-bg-bubble{
        position:absolute;
        border-radius: 50%;
        opacity: 0.25;
        pointer-events: none;
        filter: blur(90px);
        
    }
    .bubble1 {
            background-color: var(--color-coral);
            width: 50vw;
            height: 50vw;
            top:0;
            right:0;
        }
    .bubble2 {
        background-color: var(--color-violet);
        width: 10vw;
        height: 10vw;
        top: 60vw;
        right: 60vw;
    }
    .bubble3 {
        background-color: var(--color-electric);
        width: 20vw;
        height: 20vw;
        top: 10vw;
        right: 70vw;
    }

#line{
    background-color: var(--color-acid);
    height: 0.2rem;
    width: 100%;
}

#cursor{
    height: 18px;
    width: 18px;
    border-radius: 50%;
    background-color: var(--color-acid);
    position: fixed;
    pointer-events: none;
    z-index: 99;
    transform: translate(-50%, -50%);
    transition: transform 0.1s ease, width 0.2s, height 0.2s;
    mix-blend-mode:exclusion;
}

#cursor.big{
    height: 52px;
    width: 52px;
}
header{
    position: relative;
    .to-projects{
        color: white;
        letter-spacing: 0.2rem;
        font-size: 0.5rem;
        text-align: end;
    }
}

header section#navbar{
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.5rem 3rem;
    z-index: 100;
    #menu-toggle{
        background-color: transparent;
        border: none;
        cursor: none;
        display: block;
        margin-left: auto;
    }

    #logo{
        width: 200px;
    }

    nav{
       pointer-events: none;
    }

    #menu{
       pointer-events: all;
    }
    
    svg{
        width: 40px;
        height: auto;
        fill:var(--color-acid);
    }

    #menu{
        display: none;
        position: fixed;
        top: 0;
        left: 0;
        height: 100vh;
        width: 100vw;
        gap: 3rem;
        z-index: 100;
        flex-direction: column;
        justify-content: center; 
        align-items: center;
        background-color: var(--color-dark); 
        cursor: none;
        a{
            color: var(--color-white);
        }
        span{
            color: var(--color-dark);
        }

        li:hover{
            a{
                color: var(--color-acid);
            }
            span{
                color:var(--color-coral);
            }
        }
        
    }

    @media (min-width: 768px) {
        
        .to-projects{
            font-size: 0.7rem;
        }
        #menu-toggle{
            display: none;
            margin-left: 0;
        }
        nav{
            position: static;
            width: auto;
            height: auto;
            top: auto;
            left: auto;
        }

        #menu{
            display: flex !important;
            position: static;
            flex-direction: row;
            background-color: transparent;
            gap: 2rem;
            width: fit-content;
            height: fit-content;
            & span{
                color: var(--color-dark);
            }
            & li a {
                color: var(--color-white);
                position: relative;
                transition: color 0.2s;
            
                &:hover{
                    color: var(--color-acid);
                }
            }
            & li a::after{
                content:'';
                position: absolute;
                bottom: -0.5rem;
                left: 0;
                width: 0;
                height: 3px;
                background-color: var(--color-acid);
                transition:width 0.3s;
            }
            & li a:hover::after{
                width: 100%;
            }
            & li.active {
                & a{
                    color: var(--color-acid);
                }
                & span{
                    color: var(--color-coral);
                }
            }
        }
    }
}

footer{
    padding: 1.5rem 3rem;
    font-size: 0.6rem;
    color: var(--color-white);
    background-color: var(--color-black);
    text-align: center;
    img{
        width: 120px;
    }
    @media (min-width: 768px) {
        font-size: 0.7rem;
    }
}


/* LIGHTBOX */

#lightbox{
    display: none;
    position: fixed;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.92);
    z-index: 1000;
    justify-content: center;
    align-items: center;
    cursor: zoom-out;
}

#lightbox.open{
    display: flex;
}

#lightbox img{
    max-width: 90vw;
    max-height: 90vh;
    object-fit: contain;
    cursor: default;
}

#lightbox-close{
    position: absolute;
    top: 1.5rem;
    right: 1.5rem;
    background: none;
    border: none;
    color: var(--color-acid);
    font-size: 2rem;
    line-height: 1;
    cursor: pointer;
    z-index: 1;
}