@view-transition {
    navigation: auto;
}

html {
    scroll-behavior: smooth;
}

body {
    background: #0a0a0a;
    min-height: 100vh;
    position: relative;
}

/* Grain overlay */
body::before {
    content: "";
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
    opacity: 0.03;
    pointer-events: none;
    z-index: 1000;
}

::selection {
    background: #ea580c;
    color: #0a0a0a;
}

::view-transition-old(main-content) {
    animation: slide-out 0.25s ease-out forwards;
}

::view-transition-new(main-content) {
    animation: slide-in 0.3s ease-out forwards;
}

@keyframes fade-in {
    from {
        opacity: 0;
    }

    to {
        opacity: 1;
    }
}

@keyframes slide-out {
    to {
        opacity: 0;
        transform: translateY(-10px);
    }
}

@keyframes slide-in {
    from {
        opacity: 0;
        transform: translateY(10px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes slide-up {
    from {
        opacity: 0;
        transform: translateY(30px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.fade-in {
    animation: fade-in 0.8s ease-out forwards;
    opacity: 0;
}

.slide-up {
    animation: slide-up 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards;
    opacity: 0;
}

.delay-1 {
    animation-delay: 0.1s;
}

.delay-2 {
    animation-delay: 0.2s;
}

.delay-3 {
    animation-delay: 0.4s;
}

.delay-4 {
    animation-delay: 0.6s;
}

.delay-5 {
    animation-delay: 0.8s;
}

.hero-name {
    font-size: clamp(4rem, 15vw, 12rem);
    line-height: 0.85;
    letter-spacing: -0.03em;
    margin-left: -0.05em;
}

a {
    text-decoration-thickness: 1px;
    text-underline-offset: 3px;
}

.project:hover .project-arrow {
    transform: translateX(4px);
}

.project-arrow {
    transition: transform 0.2s ease;
}

[data-view] {
    view-transition-name: main-content;
}

.view-hidden {
    display: none;
}

.back-link {
    transition: transform 0.2s ease;
}

.back-link:hover {
    transform: translateX(-4px);
}

.ember-line {
    width: 3rem;
    height: 3px;
    background: #ea580c;
}
