Brand Handshake

BRAND HANDSHAKE

  • Welcome
  • Invitation
  • Vault
  • Rewards
  • Bonus
  • Networks
  • Domains
  • Pricing
    • Thank You
  • Beta List
    • Beta Welcome
{"js":"<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>The Vault | BrandHandshake | Spin to Win</title>
    <meta name="description" content="Feeling lucky? Enter the BrandHandshake vault and spin for exclusive rewards, discounts, and surprises. Fortune favors the bold.">
    <meta name="robots" content="index, follow">
    <link rel="canonical" href="https://brandhandshake.com/vault">
    <link href="https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Montserrat:wght@300;400;500;600;700;800&display=swap" rel="stylesheet">
    <style>
        :root{--navy:#0D1B2A;--navy-light:#1B263B;--gold:#D4AF37;--gold-light:#E8C547;--gold-dark:#B8972E;--ivory:#F8F4EC;--charcoal:#0a0a12;--purple:#8b5cf6;--cyan:#06b6d4;--green:#10b981;--pink:#ec4899;--red:#ef4444;}
        *{margin:0;padding:0;box-sizing:border-box;}
        body{font-family:"Montserrat",sans-serif;background:var(--charcoal);color:var(--ivory);min-height:100vh;overflow-x:hidden;}
        .bg-master{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0;background:radial-gradient(ellipse at 50% 20%,rgba(139,92,246,0.15) 0%,transparent 50%),radial-gradient(ellipse at 20% 80%,rgba(212,175,55,0.1) 0%,transparent 40%),radial-gradient(ellipse at 80% 60%,rgba(6,182,212,0.08) 0%,transparent 50%),linear-gradient(180deg,#050508 0%,var(--charcoal) 30%,var(--navy) 100%);}
        .floating-star{position:fixed;color:var(--gold);opacity:0;pointer-events:none;z-index:2;text-shadow:0 0 10px var(--gold),0 0 20px rgba(212,175,55,0.5);animation:twinkleFloat 4s ease-in-out infinite;}
        .floating-star:nth-child(1){top:8%;left:5%;font-size:14px;animation-delay:0s;}
        .floating-star:nth-child(2){top:15%;left:90%;font-size:10px;animation-delay:0.5s;}
        .floating-star:nth-child(3){top:30%;left:3%;font-size:12px;animation-delay:1s;}
        .floating-star:nth-child(4){top:50%;left:95%;font-size:16px;animation-delay:1.5s;}
        .floating-star:nth-child(5){top:70%;left:8%;font-size:11px;animation-delay:2s;}
        .floating-star:nth-child(6){top:85%;left:88%;font-size:13px;animation-delay:0.8s;}
        @keyframes twinkleFloat{0%,100%{opacity:0.2;transform:translateY(0) scale(0.8);}50%{opacity:0.9;transform:translateY(-15px) scale(1.2);}}
        .main-container{position:relative;z-index:10;min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;}
        .logo{position:absolute;top:25px;left:50%;transform:translateX(-50%);font-family:"Cormorant Garamond",serif;font-size:1.2rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--gold);text-decoration:none;opacity:0.8;transition:opacity 0.3s ease;}
        .logo:hover{opacity:1;}
        .spin-counter{position:absolute;top:25px;right:25px;background:rgba(239,68,68,0.2);border:1px solid rgba(239,68,68,0.5);border-radius:50px;padding:8px 18px;font-size:0.75rem;font-weight:600;color:#fca5a5;}
        .spin-counter.warning{background:rgba(245,158,11,0.2);border-color:rgba(245,158,11,0.5);color:#fcd34d;}
        .spin-counter.depleted{background:rgba(239,68,68,0.3);border-color:var(--red);color:#fca5a5;}
        .vault-header{text-align:center;margin-bottom:25px;}
        .vault-badge{display:inline-block;padding:10px 25px;background:rgba(139,92,246,0.2);border:1px solid rgba(139,92,246,0.4);border-radius:50px;margin-bottom:15px;animation:fadeInDown 0.8s ease;}
        .vault-badge span{font-size:0.75rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--purple);}
        .vault-title{font-family:"Cormorant Garamond",serif;font-size:clamp(2.2rem,7vw,3.5rem);font-weight:600;margin-bottom:10px;animation:fadeInUp 0.8s ease 0.2s both;}
        .vault-title .gold{background:linear-gradient(135deg,var(--gold),var(--gold-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
        .vault-subtitle{font-size:0.95rem;color:rgba(248,244,236,0.6);animation:fadeInUp 0.8s ease 0.4s both;max-width:400px;margin:0 auto;line-height:1.5;}
        .vault-warning{display:inline-block;margin-top:12px;padding:8px 20px;background:rgba(239,68,68,0.15);border:1px solid rgba(239,68,68,0.3);border-radius:50px;font-size:0.7rem;font-weight:600;color:#fca5a5;letter-spacing:1px;animation:fadeInUp 0.8s ease 0.5s both;}
        @keyframes fadeInDown{from{opacity:0;transform:translateY(-20px);}to{opacity:1;transform:translateY(0);}}
        @keyframes fadeInUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
        .wheel-container{position:relative;width:320px;height:320px;margin:15px auto;animation:fadeInUp 0.8s ease 0.6s both;}
        .wheel-glow{position:absolute;top:-20px;left:-20px;right:-20px;bottom:-20px;border-radius:50%;background:conic-gradient(from 0deg,var(--purple),var(--gold),var(--cyan),var(--pink),var(--purple));opacity:0.3;filter:blur(20px);animation:glowRotate 8s linear infinite;}
        @keyframes glowRotate{to{transform:rotate(360deg);}}
        .wheel{position:relative;width:100%;height:100%;border-radius:50%;background:var(--navy);border:4px solid var(--gold);overflow:hidden;transition:transform 5s cubic-bezier(0.17,0.67,0.12,0.99);box-shadow:0 0 30px rgba(212,175,55,0.3),inset 0 0 50px rgba(0,0,0,0.5);}
        .segment{position:absolute;width:50%;height:50%;top:0;right:0;transform-origin:bottom left;display:flex;align-items:center;justify-content:center;clip-path:polygon(0 100%,100% 0,100% 100%);}
        .segment-content{position:absolute;top:30%;left:55%;transform:rotate(22.5deg);text-align:center;width:80px;}
        .segment-icon{font-size:1.4rem;display:block;margin-bottom:3px;}
        .segment-text{font-size:0.5rem;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;line-height:1.2;color:white;text-shadow:1px 1px 2px rgba(0,0,0,0.5);}
        .segment:nth-child(1){transform:rotate(0deg);background:linear-gradient(135deg,#8b5cf6,#7c3aed);}
        .segment:nth-child(2){transform:rotate(45deg);background:linear-gradient(135deg,#D4AF37,#B8972E);}
        .segment:nth-child(3){transform:rotate(90deg);background:linear-gradient(135deg,#06b6d4,#0891b2);}
        .segment:nth-child(4){transform:rotate(135deg);background:linear-gradient(135deg,#ec4899,#db2777);}
        .segment:nth-child(5){transform:rotate(180deg);background:linear-gradient(135deg,#10b981,#059669);}
        .segment:nth-child(6){transform:rotate(225deg);background:linear-gradient(135deg,#f59e0b,#d97706);}
        .segment:nth-child(7){transform:rotate(270deg);background:linear-gradient(135deg,#6366f1,#4f46e5);}
        .segment:nth-child(8){transform:rotate(315deg);background:linear-gradient(135deg,#ef4444,#dc2626);}
        .segment.rare::after{content:"✦";position:absolute;top:15%;right:15%;font-size:0.6rem;color:gold;animation:sparkle 1s ease-in-out infinite;}
        @keyframes sparkle{0%,100%{opacity:0.5;transform:scale(1);}50%{opacity:1;transform:scale(1.3);}}
        .wheel-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:70px;height:70px;background:linear-gradient(135deg,var(--navy),var(--navy-light));border:3px solid var(--gold);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;box-shadow:0 5px 20px rgba(0,0,0,0.4);z-index:10;}
        .wheel-pointer{position:absolute;top:-12px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:18px solid transparent;border-right:18px solid transparent;border-top:30px solid var(--gold);filter:drop-shadow(0 3px 5px rgba(0,0,0,0.4));z-index:20;}
        .spin-btn{display:inline-block;padding:16px 45px;background:linear-gradient(135deg,var(--purple),#7c3aed);border:none;border-radius:50px;color:white;font-family:"Montserrat",sans-serif;font-size:1rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all 0.3s ease;box-shadow:0 10px 30px rgba(139,92,246,0.4);margin-top:25px;animation:fadeInUp 0.8s ease 0.8s both;}
        .spin-btn:hover:not(:disabled){transform:translateY(-3px) scale(1.02);box-shadow:0 15px 40px rgba(139,92,246,0.5);}
        .spin-btn:disabled{opacity:0.4;cursor:not-allowed;transform:none;background:linear-gradient(135deg,#4b5563,#374151);}
        .no-spins{display:none;text-align:center;max-width:400px;padding:30px;background:rgba(239,68,68,0.1);border:1px solid rgba(239,68,68,0.3);border-radius:20px;margin-top:25px;}
        .no-spins.active{display:block;}
        .no-spins h3{font-family:"Cormorant Garamond",serif;font-size:1.5rem;color:#fca5a5;margin-bottom:10px;}
        .no-spins p{font-size:0.9rem;color:rgba(248,244,236,0.7);line-height:1.6;margin-bottom:20px;}
        .no-spins a{display:inline-block;padding:12px 30px;background:linear-gradient(135deg,var(--gold),var(--gold-dark));border-radius:50px;color:var(--navy);font-weight:700;text-decoration:none;transition:all 0.3s ease;}
        .no-spins a:hover{transform:scale(1.05);}
        .prize-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.85);backdrop-filter:blur(10px);display:none;align-items:center;justify-content:center;z-index:100;padding:20px;}
        .prize-overlay.active{display:flex;animation:fadeIn 0.3s ease;}
        @keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
        .prize-card{background:linear-gradient(135deg,var(--navy-light),var(--navy));border:2px solid var(--gold);border-radius:30px;padding:40px 30px;max-width:420px;text-align:center;animation:popIn 0.5s cubic-bezier(0.175,0.885,0.32,1.275);position:relative;}
        .prize-card.jackpot{border-color:var(--gold);box-shadow:0 0 50px rgba(212,175,55,0.5);}
        @keyframes popIn{from{opacity:0;transform:scale(0.8);}to{opacity:1;transform:scale(1);}}
        .prize-rarity{position:absolute;top:-12px;left:50%;transform:translateX(-50%);padding:6px 20px;border-radius:50px;font-size:0.65rem;font-weight:700;letter-spacing:2px;text-transform:uppercase;}
        .prize-rarity.common{background:var(--cyan);color:var(--navy);}
        .prize-rarity.rare{background:var(--purple);color:white;}
        .prize-rarity.epic{background:linear-gradient(135deg,var(--gold),var(--gold-light));color:var(--navy);}
        .prize-rarity.legendary{background:linear-gradient(135deg,#ef4444,#f97316);color:white;animation:pulse 1s ease-in-out infinite;}
        @keyframes pulse{0%,100%{box-shadow:0 0 10px rgba(239,68,68,0.5);}50%{box-shadow:0 0 25px rgba(239,68,68,0.8);}}
        .prize-icon{font-size:4rem;margin:20px 0 15px;animation:bounce 0.6s ease;}
        @keyframes bounce{0%,100%{transform:translateY(0);}50%{transform:translateY(-15px);}}
        .prize-title{font-family:"Cormorant Garamond",serif;font-size:1.7rem;color:var(--gold);margin-bottom:12px;}
        .prize-desc{font-size:0.9rem;color:rgba(248,244,236,0.8);line-height:1.6;margin-bottom:20px;}
        .prize-code{display:inline-block;background:rgba(212,175,55,0.1);border:2px dashed var(--gold);border-radius:10px;padding:12px 25px;margin-bottom:15px;}
        .prize-code span{font-family:monospace;font-size:1.3rem;font-weight:700;color:var(--gold);letter-spacing:3px;}
        .prize-timer{background:rgba(239,68,68,0.15);border:1px solid rgba(239,68,68,0.3);border-radius:10px;padding:12px 20px;margin-bottom:20px;}
        .prize-timer-label{font-size:0.65rem;font-weight:600;color:#fca5a5;letter-spacing:1px;text-transform:uppercase;margin-bottom:5px;}
        .prize-timer-countdown{font-family:monospace;font-size:1.4rem;font-weight:700;color:#fca5a5;letter-spacing:2px;}
        .prize-fine-print{font-size:0.7rem;color:rgba(248,244,236,0.5);margin-bottom:20px;line-height:1.5;}
        .prize-cta{display:inline-block;padding:14px 35px;background:linear-gradient(135deg,var(--gold),var(--gold-dark));border-radius:50px;color:var(--navy);font-weight:700;text-decoration:none;transition:all 0.3s ease;}
        .prize-cta:hover{transform:scale(1.05);box-shadow:0 10px 30px rgba(212,175,55,0.4);}
        .close-btn{position:absolute;top:15px;right:20px;background:none;border:none;color:rgba(248,244,236,0.4);font-size:1.8rem;cursor:pointer;transition:color 0.3s ease;}
        .close-btn:hover{color:var(--gold);}
        .back-link{position:absolute;bottom:25px;left:50%;transform:translateX(-50%);color:rgba(248,244,236,0.4);font-size:0.75rem;text-decoration:none;letter-spacing:1px;transition:color 0.3s ease;}
        .back-link:hover{color:var(--gold);}
        .confetti{position:fixed;width:10px;height:10px;top:-10px;opacity:0;pointer-events:none;z-index:200;}
        @keyframes confettiFall{0%{transform:translateY(0) rotate(0deg);opacity:1;}100%{transform:translateY(100vh) rotate(720deg);opacity:0;}}
        @media(max-width:500px){.wheel-container{width:270px;height:270px;}.segment-content{top:25%;}.segment-icon{font-size:1.1rem;}.segment-text{font-size:0.4rem;}.wheel-center{width:55px;height:55px;font-size:1.4rem;}.prize-card{padding:35px 20px;}.spin-counter{top:20px;right:15px;font-size:0.65rem;padding:6px 12px;}}
    </style>
</head>
<body>
    <div class="bg-master"></div>
    <div class="floating-star">✦</div>
    <div class="floating-star">✧</div>
    <div class="floating-star">✦</div>
    <div class="floating-star">✧</div>
    <div class="floating-star">✦</div>
    <div class="floating-star">✧</div>

    <div class="main-container">
        <a href="https://brandhandshake.com" class="logo">BrandHandshake</a>

        <div class="spin-counter" id="spinCounter">
            🎲 <span id="spinsLeft">2</span> SPINS LEFT
        </div>

        <div class="vault-header">
            <div class="vault-badge"><span>🎲 Feeling Lucky?</span></div>
            <h1 class="vault-title">The <span class="gold">Vault</span></h1>
            <p class="vault-subtitle">Spin the wheel for exclusive discounts and rare prizes. Every spin wins something!</p>
            <div class="vault-warning">⚠️ YOU ONLY GET 2 SPINS — MAKE THEM COUNT!</div>
        </div>

        <div class="wheel-container" id="wheelContainer">
            <div class="wheel-glow"></div>
            <div class="wheel-pointer"></div>
            <div class="wheel" id="wheel">
                <div class="segment">
                    <div class="segment-content"><span class="segment-icon">🎯</span><span class="segment-text">Free Rep<br>Audit</span></div>
                </div>
                <div class="segment">
                    <div class="segment-content"><span class="segment-icon">🔮</span><span class="segment-text">Almost<br>There...</span></div>
                </div>
                <div class="segment">
                    <div class="segment-content"><span class="segment-icon">📺</span><span class="segment-text">3-Channel<br>Banner Set</span></div>
                </div>
                <div class="segment">
                    <div class="segment-content"><span class="segment-icon">💎</span><span class="segment-text">25% Off<br>Any Plan</span></div>
                </div>
                <div class="segment rare">
                    <div class="segment-content"><span class="segment-icon">🎬</span><span class="segment-text">30-Sec<br>Video</span></div>
                </div>
                <div class="segment rare">
                    <div class="segment-content"><span class="segment-icon">📱</span><span class="segment-text">30-Day<br>Social Pack</span></div>
                </div>
                <div class="segment rare">
                    <div class="segment-content"><span class="segment-icon">📰</span><span class="segment-text">Expert<br>Feature</span></div>
                </div>
                <!-- FIX: "$50 Card FREE!" → "$50 Presence FREE!" ✅ -->
                <div class="segment rare">
                    <div class="segment-content"><span class="segment-icon">👑</span><span class="segment-text">$50<br>Presence<br>FREE!</span></div>
                </div>
                <div class="wheel-center">🎰</div>
            </div>
        </div>

        <button class="spin-btn" id="spinBtn" onclick="spinWheel()">✨ Spin to Win</button>

        <div class="no-spins" id="noSpins">
            <h3>🎲 No Spins Remaining</h3>
            <p>You've used both of your vault spins! But don't worry — you can still claim any prizes you won, or explore our premium plans at full value.</p>
            <a href="https://brandhandshake.com/pricing">View Plans →</a>
        </div>

        <a href="https://brandhandshake.com" class="back-link">← Back to Home</a>
    </div>

    <div class="prize-overlay" id="prizeOverlay">
        <div class="prize-card" id="prizeCard">
            <button class="close-btn" onclick="closePrize()">×</button>
            <div class="prize-rarity" id="prizeRarity">COMMON</div>
            <div class="prize-icon" id="prizeIcon">🎁</div>
            <h2 class="prize-title" id="prizeTitle">Congratulations!</h2>
            <p class="prize-desc" id="prizeDesc">You've won something amazing!</p>
            <div class="prize-code" id="prizeCodeBox"><span id="prizeCode">CODE</span></div>
            <div class="prize-timer" id="prizeTimer">
                <p class="prize-timer-label">⏰ Prize Expires In</p>
                <p class="prize-timer-countdown" id="timerCountdown">23:59:59</p>
            </div>
            <p class="prize-fine-print" id="prizeFine">*Must complete purchase within 24 hours to redeem. One prize per customer.</p>
            <a href="https://brandhandshake.com/pricing" class="prize-cta" id="prizeCta">Claim Your Prize →</a>
        </div>
    </div>

    <script>
        // ── PRIZES ── FIX: Jackpot language updated ✅
        const prizes = [
            {
                icon: '🎯',
                title: 'Free Reputation Audit!',
                desc: 'See how your online presence stacks up! Get a complimentary RepGrader audit to understand your digital footprint.',
                code: null,
                rarity: 'common',
                cta: 'Get Your Free Audit',
                link: 'https://top.repgrader.com',
                fine: '*Free audit. No purchase required.',
                isWin: true
            },
            {
                icon: '🔮',
                title: 'The Stars Are Aligning...',
                desc: 'So close! The universe is warming up to you. Your next spin might be THE one. Fortune favors persistence!',
                code: null,
                rarity: null,
                cta: 'Try Again',
                link: null,
                fine: '',
                isWin: false
            },
            {
                icon: '📺',
                title: '3-Channel Banner Set!',
                desc: 'Professional banner graphics for your top 3 social channels — yours FREE with any plan purchase!',
                code: 'BANNERS3',
                rarity: 'common',
                cta: 'Claim With Purchase',
                link: 'https://brandhandshake.com/pricing',
                fine: '*Redeemable with any plan purchase within 24 hours.',
                isWin: true
            },
            {
                icon: '💎',
                title: '25% Off Any Plan!',
                desc: 'NICE! You just unlocked 25% off any Brand Handshake plan. Premium quality at a premium discount.',
                code: 'VAULT25',
                rarity: 'common',
                cta: 'Shop Now',
                link: 'https://brandhandshake.com/pricing',
                fine: '*Must complete purchase within 24 hours. Cannot combine with other offers.',
                isWin: true
            },
            {
                icon: '🎬',
                title: '30-Second Video Upgrade!',
                desc: 'RARE FIND! Get a professional 30-second promotional video added to your package — a $150 value, FREE!',
                code: 'VIDEO30',
                rarity: 'rare',
                cta: 'Claim With Purchase',
                link: 'https://brandhandshake.com/pricing',
                fine: '*Redeemable with Professional or Premium plan purchase within 24 hours.',
                isWin: true
            },
            {
                icon: '📱',
                title: '30-Day Social Media Pack!',
                desc: 'EPIC WIN! 30 days of professionally designed social media content for your brand. Posts, stories, and more!',
                code: 'SOCIAL30',
                rarity: 'epic',
                cta: 'Claim With Purchase',
                link: 'https://brandhandshake.com/pricing',
                fine: '*Redeemable with any plan purchase within 24 hours. $500 value.',
                isWin: true
            },
            {
                icon: '📰',
                title: 'Expert Feature Article!',
                desc: 'LEGENDARY! Get featured as an industry expert on our news channel. Interviews, articles, and massive exposure!',
                code: 'FEATURED2026',
                rarity: 'legendary',
                cta: 'Claim This Prize',
                link: 'https://brandhandshake.com/pricing',
                fine: '*Redeemable with Premium plan purchase within 24 hours. Subject to editorial review.',
                isWin: true
            },
            {
                // FIX: "Virtual Business Card" → "Professional Presence" ✅
                icon: '👑',
                title: '$50 Professional Presence — FREE!',
                desc: '🎉 JACKPOT! You just won a complete Essential Professional Presence absolutely FREE! No purchase necessary!',
                code: 'FREEPRES50',
                rarity: 'legendary',
                cta: 'Claim Your Free Presence!',
                link: 'https://brandhandshake.com/pricing',
                fine: '*Must claim within 24 hours. One per person. Essential tier only.',
                isWin: true
            }
        ];

        // Weights: Higher = more likely
        const weights = [15, 25, 15, 18, 10, 8, 5, 4];

        let isSpinning = false;
        let currentRotation = 0;
        let spinsRemaining = 2;
        let timerInterval = null;

        function initSpins(){
            const stored = localStorage.getItem('vaultSpins');
            const storedTime = localStorage.getItem('vaultSpinTime');
            if(storedTime){
                const elapsed = Date.now() - parseInt(storedTime);
                if(elapsed > 24 * 60 * 60 * 1000){
                    localStorage.removeItem('vaultSpins');
                    localStorage.removeItem('vaultSpinTime');
                }
            }
            if(stored !== null) spinsRemaining = parseInt(stored);
            updateSpinCounter();
        }

        function updateSpinCounter(){
            const counter = document.getElementById('spinCounter');
            const spinsText = document.getElementById('spinsLeft');
            const spinBtn = document.getElementById('spinBtn');
            const noSpins = document.getElementById('noSpins');
            const wheelContainer = document.getElementById('wheelContainer');

            spinsText.textContent = spinsRemaining;

            if(spinsRemaining === 1){
                counter.classList.add('warning');
                counter.classList.remove('depleted');
            } else if(spinsRemaining === 0){
                counter.classList.add('depleted');
                counter.classList.remove('warning');
                spinBtn.style.display = 'none';
                noSpins.classList.add('active');
                wheelContainer.style.opacity = '0.5';
            }
        }

        function spinWheel(){
            if(isSpinning || spinsRemaining <= 0) return;

            isSpinning = true;
            spinsRemaining--;
            localStorage.setItem('vaultSpins', spinsRemaining);
            if(!localStorage.getItem('vaultSpinTime')) localStorage.setItem('vaultSpinTime', Date.now());

            updateSpinCounter();

            const wheel = document.getElementById('wheel');
            const spinBtn = document.getElementById('spinBtn');
            spinBtn.disabled = true;
            spinBtn.textContent = '🎰 Spinning...';

            const totalWeight = weights.reduce((a,b) => a+b, 0);
            let random = Math.random() * totalWeight;
            let prizeIndex = 0;
            for(let i = 0; i < weights.length; i++){
                random -= weights[i];
                if(random <= 0){ prizeIndex = i; break; }
            }

            const segmentAngle = 360 / 8;
            const targetAngle = (prizeIndex * segmentAngle) + (segmentAngle / 2);
            const spins = 5 + Math.random() * 3;
            const finalRotation = currentRotation + (360 * spins) + (360 - targetAngle) + 22.5;

            currentRotation = finalRotation;
            wheel.style.transform = `rotate(${finalRotation}deg)`;

            setTimeout(() => {
                showPrize(prizeIndex);
                isSpinning = false;
                if(spinsRemaining > 0){
                    spinBtn.disabled = false;
                    spinBtn.textContent = '✨ Last Spin!';
                }
            }, 5000);
        }

        function showPrize(index){
            const prize = prizes[index];
            const card = document.getElementById('prizeCard');

            document.getElementById('prizeIcon').textContent = prize.icon;
            document.getElementById('prizeTitle').textContent = prize.title;
            document.getElementById('prizeDesc').textContent = prize.desc;

            const codeBox = document.getElementById('prizeCodeBox');
            const ctaBtn = document.getElementById('prizeCta');
            const rarityBadge = document.getElementById('prizeRarity');
            const timerBox = document.getElementById('prizeTimer');
            const fineText = document.getElementById('prizeFine');

            if(prize.code){
                document.getElementById('prizeCode').textContent = prize.code;
                codeBox.style.display = 'inline-block';
            } else {
                codeBox.style.display = 'none';
            }

            if(prize.rarity){
                rarityBadge.textContent = prize.rarity.toUpperCase();
                rarityBadge.className = 'prize-rarity ' + prize.rarity;
                rarityBadge.style.display = 'block';
            } else {
                rarityBadge.style.display = 'none';
            }

            if(prize.isWin && prize.code){
                timerBox.style.display = 'block';
                startTimer();
            } else {
                timerBox.style.display = 'none';
            }

            fineText.textContent = prize.fine;
            ctaBtn.textContent = prize.cta + ' →';

            if(prize.link){
                ctaBtn.href = prize.link;
                ctaBtn.onclick = null;
            } else {
                ctaBtn.href = '#';
                ctaBtn.onclick = function(e){ e.preventDefault(); closePrize(); };
            }

            if(prize.rarity === 'legendary' || prize.rarity === 'epic'){
                card.classList.add('jackpot');
            } else {
                card.classList.remove('jackpot');
            }

            document.getElementById('prizeOverlay').classList.add('active');
            if(prize.isWin) launchConfetti();
        }

        function startTimer(){
            let timeLeft = 24 * 60 * 60;
            if(timerInterval) clearInterval(timerInterval);
            function updateTimer(){
                const h = Math.floor(timeLeft / 3600);
                const m = Math.floor((timeLeft % 3600) / 60);
                const s = timeLeft % 60;
                document.getElementById('timerCountdown').textContent =
                    String(h).padStart(2,'0')+':'+String(m).padStart(2,'0')+':'+String(s).padStart(2,'0');
                if(timeLeft > 0) timeLeft--;
            }
            updateTimer();
            timerInterval = setInterval(updateTimer, 1000);
        }

        function closePrize(){
            document.getElementById('prizeOverlay').classList.remove('active');
            if(timerInterval) clearInterval(timerInterval);
            updateSpinCounter();
        }

        function launchConfetti(){
            const colors = ['#D4AF37','#8b5cf6','#06b6d4','#ec4899','#10b981','#f59e0b'];
            for(let i = 0; i < 60; i++){
                const c = document.createElement('div');
                c.className = 'confetti';
                c.style.left = Math.random() * 100 + 'vw';
                c.style.background = colors[Math.floor(Math.random() * colors.length)];
                c.style.width = (Math.random() * 10 + 5) + 'px';
                c.style.height = (Math.random() * 10 + 5) + 'px';
                c.style.borderRadius = Math.random() > 0.5 ? '50%' : '0';
                c.style.animation = `confettiFall ${Math.random() * 2 + 2}s linear forwards`;
                c.style.animationDelay = Math.random() * 0.5 + 's';
                document.body.appendChild(c);
                setTimeout(() => c.remove(), 4000);
            }
        }

        document.getElementById('prizeOverlay').addEventListener('click', function(e){
            if(e.target === this) closePrize();
        });
        document.addEventListener('keydown', function(e){
            if(e.key === 'Escape') closePrize();
        });

        initSpins();
        console.log('%c© 2026 BrandHandshake · Mukasa Venture Partners LLC','color:#D4AF37;font-size:12px;');
    </script>
</body>
</html>","embed":""}
The Vault | BrandHandshake | Spin to Win
✦
✧
✦
✧
✦
✧
BrandHandshake
🎲 2 SPINS LEFT
🎲 Feeling Lucky?

The Vault

Spin the wheel for exclusive discounts and rare prizes. Every spin wins something!

⚠️ YOU ONLY GET 2 SPINS — MAKE THEM COUNT!
🎯Free Rep
Audit
🔮Almost
There...
📺3-Channel
Banner Set
💎25% Off
Any Plan
🎬30-Sec
Video
📱30-Day
Social Pack
📰Expert
Feature
👑$50
Presence
FREE!
🎰

🎲 No Spins Remaining

You've used both of your vault spins! But don't worry — you can still claim any prizes you won, or explore our premium plans at full value.

View Plans →
← Back to Home
COMMON
🎁

Congratulations!

You've won something amazing!

CODE

⏰ Prize Expires In

23:59:59

*Must complete purchase within 24 hours to redeem. One prize per customer.

Claim Your Prize →
Image Gallery Grid
T
Please Check Your Email
We Will Be Following Up Shortly
*
*
*

warning