@import url('https://fonts.googleapis.com/css2?family=Noto+Sans:ital,wght@0,100..900;1,100..900&family=Outfit:wght@100..900&display=swap');

body {
    margin: 0;
    background: linear-gradient(to bottom, #2b2b2b 0%, #000000 100%);
    background-repeat: no-repeat;
    background-attachment: fixed;
    /* ensure gradient covers the full viewport */
    min-height: 100vh;
    font-family: 'Noto Sans', 'Outfit', sans-serif;
}

/* Canvas-based snow sits in #snow-canvas */
#snow-canvas {
    position: fixed;
    inset: 0;
    /* top:0; right:0; bottom:0; left:0 */
    width: 100%;
    height: 100%;
    display: block;
    z-index: 0;
    /* behind content */
    pointer-events: none;
}

/* snow is drawn on a canvas; per-flake twinkle is computed in JS */

.centered-content,
.fade-in-scroll {
    position: relative;
    z-index: 2
}

/* Utility: softer UI text glow to match snow */
.centered-content h1 {
    margin: 0;
    text-shadow: 0 2px 10px rgba(255, 255, 255, 0.06)
}

/* hero */
.hero {
    position: relative;
    color: #fff;
    text-align: center;
    padding: 100px
}

.hero .centered-content {
    display: inline-block;
    text-align: left
}

.hero h1,
.hero h2 {
    margin: 0
}

.fade-in-scroll {
    display: block
}

.fade-in-scroll .fade-item,
.fade-in-scroll.fade-item {
    opacity: 0;
    transform: translateY(12px);
    transition: opacity 900ms cubic-bezier(.2, .8, .2, 1), transform 900ms cubic-bezier(.2, .8, .2, 1);
    transition-delay: var(--delay, 0s);
    will-change: opacity, transform
}

.fade-in-scroll.in-view .fade-item,
.fade-in-scroll.in-view.fade-item {
    opacity: 1;
    transform: translateY(0)
}

.fade-in-scroll[data-stagger="small"] .fade-item {
    transition-delay: calc(var(--index, 0)*0.16s)
}

.fade-in-scroll[data-stagger="medium"] .fade-item {
    transition-delay: calc(var(--index, 0)*0.20s)
}

.fade-in-scroll[data-stagger="large"] .fade-item {
    transition-delay: calc(var(--index, 0)*0.24s)
}