        :root {
            --wine: #5A0E24;
            --blush: #f49f8a;
            --white: #ff7e7e;
        }

        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
            -webkit-font-smoothing: antialiased;
        }


        /* Add to your existing styles */
#legal-modal {
    transition: opacity 0.3s ease;
}

#legal-modal:not(.hidden) {
    opacity: 1;
}

#legal-modal.hidden {
    opacity: 0;
    pointer-events: none;
}
        body {
            font-family: 'Source Sans 3', sans-serif;
            background-color: var(--blush);
            color: var(--wine);
            overflow: hidden; /* Prevent native scroll for our snap engine */
        }

        /* CHAPTER ENGINE */
        #viewport {
            height: 100vh;
            width: 100vw;
            overflow: hidden;
            position: relative;
        }

        .chapter-container {
            transition: transform 1.2s cubic-bezier(0.65, 0, 0.35, 1);
            height: 100%;
        }

        .chapter {
            height: 100vh;
            width: 100vw;
            position: relative;
            overflow: hidden;
            flex-shrink: 0;
        }

        /* NAVIGATION LUXURY */
        header {
            transition: background 0.6s ease, color 0.6s ease, transform 0.6s ease;
        }
        header.scrolled {
            background: var(--wine);
            color: var(--white);
            padding-top: 1rem;
            padding-bottom: 1rem;
        }

        /* MOBILE MENU */
        #mobile-nav-overlay {
            clip-path: circle(0% at 100% 0%);
            transition: clip-path 0.8s cubic-bezier(0.7, 0, 0.2, 1);
        }
        #mobile-nav-overlay.open {
            clip-path: circle(150% at 100% 0%);
        }

        /* ANIMATIONS */
        .zoom-bg {
            animation: kenBurns 20s infinite alternate linear;
        }
        @keyframes kenBurns {
            from { transform: scale(1); }
            to { transform: scale(1.15); }
        }

        .marquee-track {
            display: flex;
            width: 200%;
            animation: marquee 30s linear infinite;
        }
        @keyframes marquee {
            0% { transform: translateX(0); }
            100% { transform: translateX(-50%); }
        }

        /* CUSTOM UI */
        .btn-main {
            background: var(--wine);
            color: white;
            padding: 1.25rem 3.5rem;
            font-size: 0.75rem;
            font-weight: 800;
            letter-spacing: 0.3em;
            text-transform: uppercase;
            transition: all 0.4s;
        }
        .btn-main:hover {
            letter-spacing: 0.5em;
            opacity: 0.9;
        }

        .modal-overlay {
            background: rgba(90, 14, 36, 0.95);
            backdrop-filter: blur(10px);
        }

        /* TEXT STACK ANIMATION */
        .stack-item {
            opacity: 0;
            transform: translateY(20px);
            transition: all 1s ease;
        }
        .chapter.active .stack-item {
            opacity: 1;
            transform: translateY(0);
        }

        /* RESPONSIVE FONT SCALING */
        .hero-text { font-size: clamp(3rem, 12vw, 10rem); line-height: 0.85; font-weight: 900; }
        
        ::-webkit-scrollbar { display: none; }
    