        .lp {
            --lp-radius: 14px;
            overflow-x: hidden;
        }

        /* ---- Navbar ---- */
        .lp-nav.scrolled {
            box-shadow: 0 1px 24px rgba(0, 0, 0, 0.08);
        }

        /* ---- Hero ---- */

        .lp-hero {
            min-height: 100svh;
            padding-top: calc(var(--navbar-height) + 3rem);
            padding-bottom: 4rem;
            position: relative;
        }

        .lp-hero::before {
            content: '';
            position: absolute;
            inset: 0;
            background: radial-gradient(ellipse 80% 60% at 70% 20%, var(--os-teal-100), transparent 70%),
            radial-gradient(ellipse 50% 40% at 20% 80%, var(--os-teal-50), transparent 60%);
            opacity: 0.45;
            pointer-events: none;
            z-index: 0;
        }

        [data-bs-theme="dark"] .lp-hero::before {
            background: radial-gradient(ellipse 80% 60% at 70% 20%, var(--os-teal-950), transparent 70%),
            radial-gradient(ellipse 50% 40% at 20% 80%, rgba(13, 148, 136, 0.08), transparent 60%);
            opacity: 0.7;
        }

        .lp-hero-content {
            position: relative;
            z-index: 1;
        }

        .lp-hero h1 {
            font-size: clamp(2.5rem, 6vw, 4.25rem);
            font-weight: 700;
            line-height: 1.1;
            letter-spacing: 0;
        }

        .lp-hero h1 .text-teal {
            color: var(--os-primary-text);
        }

        .lp-hero-heading {
            font-size: clamp(1.25rem, 3vw, 1.75rem);
            font-weight: 700;
            line-height: 1.2;
            letter-spacing: 0;
        }

        .lp-hero-heading .text-teal {
            color: var(--os-primary-text);
        }

        .lp-hero-sub {
            font-size: 1.15rem;
            line-height: 1.7;
            max-width: 480px;
            margin-top: 1.5rem;
        }

        .lp-hero-cta .btn {
            padding: 0.75rem 1.75rem;
            font-weight: 600;
            font-size: 0.95rem;
            border-radius: 10px;
            transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
        }

        .lp-hero-cta .btn:hover {
            transform: translateY(-1px);
        }

        .lp-hero-cta .btn-primary {
            box-shadow: 0 4px 14px rgba(var(--bs-primary-rgb), 0.22);
        }

        .lp-hero-cta .btn-primary:hover {
            box-shadow: 0 8px 22px rgba(var(--bs-primary-rgb), 0.3);
        }

        .lp-hero-cta .btn-outline-secondary {
            border-color: rgba(var(--bs-body-color-rgb), 0.35);
        }

        .lp-hero-cta .btn-outline-secondary:hover {
            border-color: rgba(var(--bs-body-color-rgb), 0.5);
        }

        .lp-trust-row {
            font-size: 0.82rem;
            color: var(--bs-tertiary-color);
            letter-spacing: 0;
            opacity: 0.7;
        }

        .lp-trust-row span {
            display: flex;
            align-items: center;
            gap: 0.4rem;
        }

        /* ---- Floating Product Preview ---- */

        .lp-preview {
            position: relative;
            height: 480px;
        }

        @media (max-width: 991.98px) {
            .lp-preview {
                height: 440px;
                margin-top: 2rem;
            }
        }

        .lp-float-card {
            position: absolute;
            border-radius: var(--lp-radius);
            border: 1px solid var(--bs-border-color);
            background: var(--bs-body-bg);
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.04),
            0 12px 40px rgba(0, 0, 0, 0.06);
            overflow: hidden;
            opacity: 0;
        }

        [data-bs-theme="dark"] .lp-float-card {
            box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2),
            0 12px 40px rgba(0, 0, 0, 0.3);
            border-color: var(--bs-border-color);
        }

        .lp-float-card--leaderboard {
            top: 0;
            right: 0;
            width: 300px;
            animation: floatCardIn 0.8s ease-out 0.2s forwards, floatIdle1 6s ease-in-out 1.2s infinite;
            z-index: 2;
        }

        .lp-float-card--match {
            bottom: 40px;
            left: 0;
            width: 280px;
            animation: floatCardIn 0.8s ease-out 0.5s forwards, floatIdle2 8s ease-in-out 1.5s infinite;
            z-index: 3;
        }

        @media (max-width: 991.98px) {
            .lp-float-card--leaderboard {
                width: 240px;
                top: 0;
                right: 5%;
            }

            .lp-float-card--match {
                width: 230px;
                bottom: 20px;
                left: 5%;
            }
        }

        .lp-label {
            text-transform: uppercase;
            letter-spacing: 0;
            font-weight: 600;
        }

        .lp-card-header {
            padding: 12px 16px;
            font-size: 0.78rem;
            color: var(--os-primary-text);
            border-bottom: 1px solid var(--bs-border-color);
            background: var(--bs-tertiary-bg);
        }

        .lp-lb-row {
            display: flex;
            align-items: center;
            padding: 10px 16px;
            font-size: 0.85rem;
            border-bottom: 1px solid var(--bs-border-color);
            transition: background 0.15s;
        }

        .lp-lb-row:last-child {
            border-bottom: none;
        }

        .lp-lb-row--you {
            background: rgba(var(--bs-primary-rgb), 0.06);
        }

        .lp-lb-rank {
            width: 28px;
            font-weight: 700;
            font-size: 0.8rem;
            color: var(--bs-tertiary-color);
            flex-shrink: 0;
        }

        .lp-lb-name {
            flex: 1;
        }

        .lp-lb-rating {
            font-weight: 600;
            font-variant-numeric: tabular-nums;
            color: var(--os-primary-text);
        }

        .lp-match-body {
            padding: 16px;
        }

        .lp-match-sport {
            font-size: 0.72rem;
            color: var(--os-primary-text);
            margin-bottom: 10px;
        }

        .lp-match-score {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 16px;
            margin-bottom: 12px;
        }

        .lp-match-player {
            text-align: center;
            font-size: 0.82rem;
            font-weight: 400;
            line-height: 1.3;
        }

        .lp-match-player small {
            display: block;
            font-size: 0.72rem;
            font-weight: 600;
            margin-top: 2px;
        }

        .lp-match-vs {
            font-size: 1.35rem;
            font-weight: 700;
            font-variant-numeric: tabular-nums;
            letter-spacing: 0;
            color: var(--bs-body-color);
        }

        .lp-match-time {
            font-size: 0.72rem;
        }

        .lp-lb-streak-row {
            display: flex;
            align-items: center;
            gap: 6px;
            padding: 8px 16px;
            font-size: 0.78rem;
            font-weight: 600;
            color: var(--os-sport-accent);
            background: rgba(var(--os-sport-accent-rgb), 0.06);
            border-top: 1px solid rgba(var(--os-sport-accent-rgb), 0.15);
        }

        /* ---- Sections shared ---- */

        .lp-section {
            padding: 6rem 0;
            position: relative;
        }

        .lp-section-label {
            font-size: 0.78rem;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0;
            color: var(--os-primary-text);
            margin-bottom: 0.75rem;
        }

        .lp-section h2 {
            font-size: clamp(1.75rem, 3.5vw, 2.5rem);
            font-weight: 700;
            line-height: 1.15;
            letter-spacing: 0;
            margin-bottom: 1rem;
        }

        .lp-section-desc {
            font-size: 1.05rem;
            line-height: 1.7;
            color: var(--bs-secondary-color);
            max-width: 560px;
        }

        /* ---- Features ---- */

        .lp-feature-card {
            padding: 2rem 1.5rem;
            border-radius: var(--lp-radius);
            background: var(--bs-body-bg);
            border: 1px solid var(--bs-border-color);
            transition: transform 0.25s, box-shadow 0.25s;
        }

        .lp-feature-card:hover {
            transform: translateY(-4px);
            box-shadow: 0 8px 32px rgba(0, 0, 0, 0.06);
        }

        [data-bs-theme="dark"] .lp-feature-card:hover {
            box-shadow: 0 8px 32px rgba(0, 0, 0, 0.25);
        }

        .lp-feature-icon {
            width: 48px;
            height: 48px;
            border-radius: 12px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 1.3rem;
            margin-bottom: 1.25rem;
            background: rgba(var(--bs-primary-rgb), 0.1);
            color: var(--os-primary-text);
        }

        .lp-feature-card h3 {
            font-size: 1.05rem;
            font-weight: 700;
            margin-bottom: 0.5rem;
        }

        .lp-feature-card p {
            font-size: 0.9rem;
            line-height: 1.6;
        }

        /* ---- Audience ---- */

        .lp-audience-item {
            max-width: 340px;
        }

        .lp-audience-icon {
            width: 44px;
            height: 44px;
            border-radius: 12px;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            margin-bottom: 1rem;
            background: rgba(var(--bs-primary-rgb), 0.1);
            color: var(--os-primary-text);
            font-size: 1.2rem;
        }

        .lp-audience-item h3 {
            font-size: 1.05rem;
            font-weight: 700;
            margin-bottom: 0.5rem;
        }

        .lp-audience-item p {
            font-size: 0.92rem;
            line-height: 1.65;
        }

        /* ---- How It Works ---- */

        .lp-step {
            position: relative;
            text-align: center;
        }

        .lp-step-number {
            font-family: 'Bricolage Grotesque', var(--bs-body-font-family);
            font-size: 3.5rem;
            font-weight: 700;
            line-height: 1;
            color: var(--os-primary-text);
            opacity: 0.15;
            margin-bottom: 1rem;
        }

        .lp-step h3 {
            font-size: 1.15rem;
            font-weight: 700;
            margin-bottom: 0.5rem;
        }

        .lp-step p {
            font-size: 0.92rem;
            line-height: 1.65;
            max-width: 280px;
        }


        /* ---- Pricing ---- */

        .lp-price-card {
            border-radius: 16px;
            border: 1px solid var(--bs-border-color);
            background: var(--bs-body-bg);
            padding: 2.5rem 2rem;
            position: relative;
            transition: transform 0.25s, box-shadow 0.25s;
            box-shadow: 0 1px 4px rgba(0, 0, 0, 0.05), 0 4px 16px rgba(0, 0, 0, 0.04);
        }

        [data-bs-theme="dark"] .lp-price-card {
            box-shadow: 0 1px 4px rgba(0, 0, 0, 0.15), 0 4px 16px rgba(0, 0, 0, 0.12);
        }

        .lp-price-card:hover {
            transform: translateY(-4px);
        }

        .lp-price-card--featured {
            border-color: var(--bs-primary);
            box-shadow: 0 0 0 1px var(--bs-primary), 0 8px 32px rgba(var(--bs-primary-rgb), 0.12);
        }

        .lp-price-badge {
            position: absolute;
            top: -12px;
            left: 50%;
            transform: translateX(-50%);
            background: var(--bs-primary);
            color: #fff;
            font-size: 0.72rem;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0;
            padding: 4px 14px;
            border-radius: 20px;
            white-space: nowrap;
        }

        .lp-price-tier {
            font-size: 0.82rem;
            color: var(--bs-secondary-color);
            margin-bottom: 0.75rem;
        }

        .lp-price-features {
            margin: 0 0 2rem;
        }

        .lp-price-features li {
            padding: 0.45rem 0;
            font-size: 0.88rem;
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .lp-price-features li i {
            font-size: 0.9rem;
            flex-shrink: 0;
        }

        .lp-price-features .bi-check-lg {
            color: var(--bs-success);
        }

        .lp-price-features .bi-dash {
            color: var(--bs-tertiary-color);
        }

        .lp-price-card .btn {
            padding: 0.7rem;
            border-radius: 10px;
        }

        .lp-price-card--muted {
            opacity: 0.55;
        }

        /* ---- FAQ ---- */

        .lp-faq-list {
            max-width: 860px;
            margin: 0 auto;
        }

        .lp-faq-item {
            padding: 1.5rem 0;
            border-bottom: 1px solid var(--bs-border-color);
        }

        .lp-faq-item:first-child {
            border-top: 1px solid var(--bs-border-color);
        }

        .lp-faq-item summary {
            font-size: 1.05rem;
            font-weight: 700;
            cursor: pointer;
            display: flex;
            justify-content: space-between;
            align-items: center;
            gap: 1rem;
            list-style: none;
            user-select: none;
        }

        .lp-faq-item summary::-webkit-details-marker {
            display: none;
        }

        .lp-faq-item summary::after {
            content: '';
            display: inline-block;
            width: 0.45rem;
            height: 0.45rem;
            border-right: 2px solid currentColor;
            border-bottom: 2px solid currentColor;
            transform: rotate(45deg) translateY(-2px);
            transition: transform 0.2s ease;
            flex-shrink: 0;
            opacity: 0.45;
        }

        .lp-faq-item[open] summary::after {
            transform: rotate(-135deg) translateY(2px);
        }

        .lp-faq-item p {
            margin-top: 0.5rem;
            color: var(--bs-secondary-color);
            line-height: 1.65;
            margin-bottom: 0;
        }

        /* ---- CTA Band ---- */

        .lp-cta-band {
            background: var(--os-teal-900);
            color: #f0fdfa;
            padding: 5rem 0;
            position: relative;
            overflow: hidden;
        }

        .lp-cta-band::before {
            content: '';
            position: absolute;
            inset: 0;
            background: radial-gradient(ellipse 60% 80% at 80% 50%, rgba(45, 212, 191, 0.12), transparent);
            pointer-events: none;
        }

        [data-bs-theme="dark"] .lp-cta-band {
            background: var(--os-teal-950);
        }

        .lp-cta-band h2 {
            color: #f0fdfa;
        }

        .lp-cta-content {
            z-index: 1;
        }

        .lp-cta-content-title {
            font-size: clamp(1.75rem, 3.5vw, 2.5rem);
            font-weight: 700;
        }

        .lp-cta-band p {
            color: rgba(240, 253, 250, 0.7);
        }

        .lp-cta-band .btn-light {
            background: #f0fdfa;
            color: var(--os-teal-900);
            border: none;
            font-weight: 700;
            padding: 0.75rem 2rem;
            border-radius: 10px;
        }

        .lp-cta-band .btn-light:hover {
            background: #fff;
            transform: translateY(-1px);
            box-shadow: 0 4px 16px rgba(0, 0, 0, 0.15);
        }

        /* ---- Scroll Reveal ---- */

        .lp-reveal {
            transition: opacity 0.7s ease-out, transform 0.7s ease-out;
        }

        .lp-js .lp-reveal {
            opacity: 0;
            transform: translateY(24px);
        }

        .lp-js .lp-reveal.revealed {
            opacity: 1;
            transform: translateY(0);
        }

        /* ---- Animations ---- */

        @keyframes floatCardIn {
            from {
                opacity: 0;
                transform: translateY(30px) scale(0.96);
            }
            to {
                opacity: 1;
                transform: translateY(0) scale(1);
            }
        }

        @keyframes floatIdle1 {
            0%, 100% {
                transform: translateY(0);
            }
            50% {
                transform: translateY(-8px);
            }
        }

        @keyframes floatIdle2 {
            0%, 100% {
                transform: translateY(0);
            }
            50% {
                transform: translateY(-10px);
            }
        }


        /* ---- Responsive ---- */

        @media (max-width: 575.98px) {
            .lp-hero {
                padding-top: calc(var(--navbar-height) + 2rem);
                min-height: auto;
                padding-bottom: 3rem;
            }

            .lp-hero h1 {
                font-size: 2.25rem;
            }

            .lp-hero-sub {
                font-size: 1rem;
            }

            .lp-preview {
                height: 400px;
            }

            .lp-float-card--leaderboard {
                width: 200px;
                top: 0;
                right: 5%;
            }

            .lp-float-card--match {
                width: 190px;
                bottom: 0;
                left: 5%;
            }

            .lp-section {
                padding: 4rem 0;
            }
        }

        /* Smooth scroll */
        html {
            scroll-behavior: smooth;
            scroll-padding-top: var(--navbar-height);
        }
