﻿.hero-blob {
    position: absolute;
    inset: -40px -40px auto auto;
    width: 320px;
    height: 320px;
    background: radial-gradient(35% 35% at 30% 30%, var(--mud-palette-primary) 0%, transparent 60%), radial-gradient(40% 40% at 70% 60%, var(--mud-palette-secondary) 0%, transparent 60%);
    filter: blur(18px);
    opacity: .16;
    pointer-events: none;
    border-radius: 50%;
    animation: blobFloat 10s ease-in-out infinite;
}

@keyframes blobFloat {
    0%,100% {
        transform: translate(0,0) scale(1);
    }

    50% {
        transform: translate(-12px,8px) scale(1.06);
    }
}

.card-tilt {
    transition: transform .25s ease, box-shadow .25s ease;
    will-change: transform;
}

    .card-tilt:hover {
        transform: translateY(-3px) rotate(.2deg);
    }

.shine {
    position: relative;
    overflow: hidden;
}

    .shine::after {
        content: "";
        position: absolute;
        inset: 0;
        transform: translateX(-120%);
        background: linear-gradient(110deg, transparent 0%, rgba(255,255,255,.18) 40%, transparent 70%);
        transition: transform .6s ease;
    }

    .shine:hover::after {
        transform: translateX(120%);
    }

.chips-scroll {
    overflow: auto;
    white-space: nowrap;
}

.hero-glass {
    background: color-mix(in srgb, var(--mud-palette-surface) 30%, transparent);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    border-radius: 14px;
    padding: 1rem 1.25rem;
    box-shadow: 0 6px 24px rgba(0,0,0,.2);
}

.hero-title {
    line-height: 1.25;
}

.hero-lede {
    line-height: 1.6;
    max-width: 52ch;
}

.addons-scroll {
    display: grid;
    grid-auto-flow: column;
    grid-template-rows: repeat(2, 1fr); 
    gap: 1rem;
    overflow-x: auto;
    padding-bottom: 0.5rem;
}

.addons-frame {
    position: relative;
    margin: .5rem 0 1rem;
}

.addons-rail {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(280px, 1fr);
    grid-template-rows: repeat(2, 1fr);
    gap: 16px;
    padding: 8px 24px; 
    overflow-x: auto;
    overscroll-behavior-x: contain;
    scroll-snap-type: x mandatory;
    scroll-padding-inline: 24px;
    -webkit-overflow-scrolling: touch;
    -webkit-mask-image: linear-gradient(to right, transparent 0, black 24px, black calc(100% - 24px), transparent 100%);
    mask-image: linear-gradient(to right, transparent 0, black 24px, black calc(100% - 24px), transparent 100%);
}

    .addons-rail::-webkit-scrollbar {
        height: 0;
    }

.addons-rail {
    scrollbar-width: none;
}

    .addons-rail > .addon-card {
        scroll-snap-align: start;
    }

.addon-card {
    transform-style: preserve-3d;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
    border: 1px solid rgba(255,255,255,.06);
    will-change: transform;
    perspective: 800px;
}

    .addon-card:hover {
        transform: translateY(-4px) rotate3d(0, 1, 0, .6deg);
        box-shadow: 0 12px 36px rgba(0,0,0,.25);
        border-color: rgba(255,255,255,.18);
    }

.addon-glow {
    position: absolute;
    inset: -12%;
    background: radial-gradient(40% 40% at 50% 50%, var(--mud-palette-primary) 0%, transparent 70%);
    filter: blur(18px);
    opacity: .0;
    transition: opacity .25s ease, transform .25s ease;
    pointer-events: none;
}

.addon-card:hover .addon-glow {
    opacity: .25;
    transform: scale(1.03);
}

.addons-nav {
    position: absolute;
    inset: 0;
    pointer-events: none;
}

    .addons-nav .btn {
        position: absolute;
        top: 50%;
        translate: 0 -50%;
        pointer-events: auto;
        z-index: 2;
    }

        .addons-nav .btn.prev {
            left: 2px;
        }

        .addons-nav .btn.next {
            right: 2px;
        }

@keyframes addonIn {
    from {
        opacity: 0;
        transform: translateY(8px) scale(.985);
    }

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

.addons-rail > * {
    animation: addonIn .35s ease both;
}

    .addons-rail > *:nth-child(2) {
        animation-delay: .02s;
    }

    .addons-rail > *:nth-child(3) {
        animation-delay: .04s;
    }

    .addons-rail > *:nth-child(4) {
        animation-delay: .06s;
    }

.addons-rail {
    pointer-events: auto;
}
.addons-nav {
    pointer-events: none;
}
    .addons-nav .btn {
        pointer-events: auto;
    }


.login-wrap {
    min-height: 100dvh;
    position: relative;
    overflow: hidden;
}

.login-card {
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

.elevate-on-hover {
    transition: transform .12s ease, box-shadow .2s ease;
    will-change: transform;
}

    .elevate-on-hover:hover {
        transform: translateY(-1px);
        box-shadow: 0 8px 24px rgba(0,0,0,.18);
    }

.floating-badge {
    position: absolute;
    right: 12px;
    bottom: 12px;
    display: flex;
    gap: .35rem;
    align-items: center;
    font-size: .85rem;
    opacity: .7;
}

    .floating-badge .mud-icon-root {
        font-size: 18px;
    }

.chips-scroll {
    overflow: auto hidden;
    padding-bottom: .25rem;
}

    .chips-scroll::-webkit-scrollbar {
        height: 6px;
    }

.addon-glow {
    position: absolute;
    inset: -20%;
    background: radial-gradient(35% 35% at 30% 30%, var(--mud-palette-primary) 10%, transparent 60%), radial-gradient(40% 40% at 70% 60%, var(--mud-palette-secondary) 12%, transparent 60%);
    filter: blur(28px);
    opacity: .08;
    pointer-events: none;
}

.hero-glass {
    background: color-mix(in srgb, var(--mud-palette-drawer-background) 82%, transparent);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-radius: 14px;
    padding: 1rem 1.25rem;
    box-shadow: 0 6px 24px rgba(0,0,0,.18);
}

.hero-blob {
    position: absolute;
    inset: -40px -40px auto auto;
    width: 320px;
    height: 320px;
    background: radial-gradient(35% 35% at 30% 30%, var(--mud-palette-primary) 0%, transparent 60%), radial-gradient(40% 40% at 70% 60%, var(--mud-palette-secondary) 0%, transparent 60%);
    filter: blur(18px);
    opacity: .18;
    pointer-events: none;
    border-radius: 50%;
    animation: blobFloat 10s ease-in-out infinite;
}

@keyframes blobFloat {
    0%,100% {
        transform: translate(0,0) scale(1);
    }

    50% {
        transform: translate(-12px,8px) scale(1.06);
    }
}
