{"js":"<!DOCTYPE html>
<html lang="en">
<head>
    <!-- ═══════════════════════════════════════════════════════════════════
         URL: tasn.handshake.africa/badges
         PURPOSE: Generate & Download shareable social media badges
         TYPES: Flourishing Fund Contributor, Birthday Club Winner, Wheel Winner
         ═══════════════════════════════════════════════════════════════════ -->
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>🏅 Get Your Badge! | TASN Badges | Handshake Africa</title>
    <meta name="description" content="Create your personalized TASN badge! Flourishing Fund contributors, Birthday Club members, and Wheel winners - share your achievement!">
    <link rel="canonical" href="https://tasn.handshake.africa/badges">
    <link href="https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600;700;800;900&family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=Nunito:wght@300;400;500;600;700;800&display=swap" rel="stylesheet">
    <!-- html2canvas for downloading -->
    <script src="https://cdnjs.cloudflare.com/ajax/libs/html2canvas/1.4.1/html2canvas.min.js"></script>
    <style>
        :root {
            --fuschia: #E91E8B;
            --orange: #FF6B35;
            --mint: #3EB489;
            --gold: #D4AF37;
            --ivory: #FFF9F5;
            --charcoal: #1a1a2e;
            --navy: #16213e;
            --deep: #0f0f23;
        }
        
        * { margin: 0; padding: 0; box-sizing: border-box; }
        html { scroll-behavior: smooth; font-size: 18px; }
        
        body {
            font-family: 'Nunito', sans-serif;
            background: var(--deep);
            color: var(--ivory);
            line-height: 1.8;
            overflow-x: hidden;
            font-size: 1.1rem;
        }
        
        /* BACKGROUND */
        .bg-master {
            position: fixed;
            top: 0; left: 0; width: 100%; height: 100%;
            pointer-events: none; z-index: 0;
            background: 
                radial-gradient(ellipse at 20% 20%, rgba(233, 30, 139, 0.15) 0%, transparent 50%),
                radial-gradient(ellipse at 80% 50%, rgba(212, 175, 55, 0.12) 0%, transparent 45%),
                radial-gradient(ellipse at 40% 80%, rgba(62, 180, 137, 0.1) 0%, transparent 50%),
                linear-gradient(180deg, var(--deep) 0%, var(--navy) 50%, var(--charcoal) 100%);
        }
        
        .content-wrapper {
            position: relative;
            z-index: 10;
        }
        
        /* HEADER */
        .header {
            padding: 25px;
            display: flex;
            justify-content: space-between;
            align-items: center;
            flex-wrap: wrap;
            gap: 15px;
        }
        .logo {
            font-family: 'Playfair Display', serif;
            font-size: 1.3rem;
            color: var(--gold);
            font-weight: 700;
        }
        .back-link {
            color: var(--fuschia);
            text-decoration: none;
            font-size: 0.95rem;
        }
        
        /* HERO */
        .hero {
            padding: 40px 25px;
            text-align: center;
            max-width: 700px;
            margin: 0 auto;
        }
        .hero h1 {
            font-family: 'Playfair Display', serif;
            font-size: clamp(1.8rem, 5vw, 2.5rem);
            font-weight: 800;
            margin-bottom: 15px;
            background: linear-gradient(135deg, var(--gold), var(--fuschia), var(--mint));
            background-size: 200% auto;
            -webkit-background-clip: text;
            -webkit-text-fill-color: transparent;
            animation: shimmer 4s linear infinite;
        }
        @keyframes shimmer {
            0% { background-position: 0% center; }
            100% { background-position: 200% center; }
        }
        .hero p {
            font-size: 1.05rem;
            color: rgba(255, 249, 245, 0.8);
        }
        
        /* BADGE SELECTOR */
        .badge-selector {
            padding: 30px 25px;
            max-width: 900px;
            margin: 0 auto;
        }
        .selector-title {
            font-family: 'Playfair Display', serif;
            font-size: 1.4rem;
            color: var(--gold);
            text-align: center;
            margin-bottom: 25px;
        }
        .badge-types {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
            gap: 20px;
            margin-bottom: 40px;
        }
        .badge-type-btn {
            background: rgba(0, 0, 0, 0.4);
            border: 2px solid rgba(255, 255, 255, 0.1);
            border-radius: 20px;
            padding: 25px 20px;
            text-align: center;
            cursor: pointer;
            transition: all 0.3s ease;
        }
        .badge-type-btn:hover, .badge-type-btn.active {
            border-color: var(--fuschia);
            transform: translateY(-5px);
        }
        .badge-type-btn.active {
            background: rgba(233, 30, 139, 0.15);
        }
        .badge-type-icon {
            font-size: 2.5rem;
            margin-bottom: 10px;
        }
        .badge-type-name {
            font-family: 'Playfair Display', serif;
            font-size: 1.05rem;
            color: var(--ivory);
        }
        
        /* CUSTOMIZER */
        .customizer {
            max-width: 800px;
            margin: 0 auto;
            padding: 0 25px 50px;
        }
        .customizer-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 40px;
            align-items: start;
        }
        
        /* FORM SIDE */
        .form-side {
            background: rgba(0, 0, 0, 0.4);
            border-radius: 25px;
            padding: 35px 30px;
            border: 2px solid rgba(233, 30, 139, 0.2);
        }
        .form-title {
            font-family: 'Playfair Display', serif;
            font-size: 1.3rem;
            color: var(--fuschia);
            margin-bottom: 25px;
        }
        .form-group {
            margin-bottom: 20px;
        }
        .form-group label {
            display: block;
            margin-bottom: 8px;
            font-size: 0.95rem;
            color: rgba(255, 249, 245, 0.85);
            font-weight: 600;
        }
        .form-group input,
        .form-group select {
            width: 100%;
            padding: 14px 18px;
            background: rgba(0, 0, 0, 0.4);
            border: 2px solid rgba(255, 255, 255, 0.1);
            border-radius: 12px;
            color: var(--ivory);
            font-size: 1rem;
            font-family: 'Nunito', sans-serif;
        }
        .form-group input:focus,
        .form-group select:focus {
            outline: none;
            border-color: var(--fuschia);
        }
        .form-group select option {
            background: var(--charcoal);
        }
        
        /* PREVIEW SIDE */
        .preview-side {
            text-align: center;
        }
        .preview-title {
            font-family: 'Playfair Display', serif;
            font-size: 1.3rem;
            color: var(--gold);
            margin-bottom: 20px;
        }
        
        /* BADGE CANVAS */
        .badge-canvas {
            width: 320px;
            height: 320px;
            margin: 0 auto 25px;
            border-radius: 20px;
            overflow: hidden;
            position: relative;
        }
        
        /* FLOURISHING BADGE */
        .badge-flourishing {
            width: 100%;
            height: 100%;
            background: linear-gradient(145deg, #0f0f23, #16213e);
            border: 4px solid var(--gold);
            border-radius: 20px;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            padding: 25px;
            position: relative;
            overflow: hidden;
        }
        .badge-flourishing::before {
            content: '';
            position: absolute;
            top: -50%;
            left: -50%;
            width: 200%;
            height: 200%;
            background: radial-gradient(circle, rgba(233, 30, 139, 0.1) 0%, transparent 50%);
            animation: rotate 20s linear infinite;
        }
        @keyframes rotate {
            0% { transform: rotate(0deg); }
            100% { transform: rotate(360deg); }
        }
        .badge-flourishing .badge-icon {
            font-size: 4rem;
            margin-bottom: 10px;
            position: relative;
            z-index: 2;
        }
        .badge-flourishing .badge-label {
            font-family: 'Playfair Display', serif;
            font-size: 0.8rem;
            color: var(--gold);
            text-transform: uppercase;
            letter-spacing: 3px;
            margin-bottom: 8px;
            position: relative;
            z-index: 2;
        }
        .badge-flourishing .badge-main-text {
            font-family: 'Playfair Display', serif;
            font-size: 1.1rem;
            color: var(--fuschia);
            margin-bottom: 5px;
            position: relative;
            z-index: 2;
        }
        .badge-flourishing .badge-name {
            font-size: 1.4rem;
            font-weight: 800;
            color: var(--ivory);
            margin-bottom: 5px;
            position: relative;
            z-index: 2;
        }
        .badge-flourishing .badge-business {
            font-size: 0.85rem;
            color: rgba(255, 249, 245, 0.6);
            margin-bottom: 10px;
            position: relative;
            z-index: 2;
        }
        .badge-flourishing .badge-category {
            background: var(--fuschia);
            color: white;
            padding: 6px 18px;
            border-radius: 20px;
            font-size: 0.75rem;
            font-weight: 700;
            position: relative;
            z-index: 2;
        }
        .badge-flourishing .badge-quarter {
            position: absolute;
            bottom: 15px;
            font-size: 0.7rem;
            color: var(--mint);
            z-index: 2;
        }
        
        /* BIRTHDAY BADGE */
        .badge-birthday {
            width: 100%;
            height: 100%;
            background: linear-gradient(145deg, #1a0a1a, #2d1230);
            border: 4px solid var(--fuschia);
            border-radius: 20px;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            padding: 25px;
            position: relative;
            overflow: hidden;
        }
        .badge-birthday::before {
            content: '🎂🎉🎈🎁✨🎊';
            position: absolute;
            font-size: 3rem;
            opacity: 0.1;
            top: 50%;
            left: 50%;
            transform: translate(-50%, -50%);
            white-space: nowrap;
        }
        .badge-birthday .badge-icon {
            font-size: 4rem;
            margin-bottom: 10px;
            position: relative;
            z-index: 2;
        }
        .badge-birthday .badge-label {
            font-family: 'Playfair Display', serif;
            font-size: 0.8rem;
            color: var(--gold);
            text-transform: uppercase;
            letter-spacing: 3px;
            margin-bottom: 8px;
            position: relative;
            z-index: 2;
        }
        .badge-birthday .badge-main-text {
            font-family: 'Playfair Display', serif;
            font-size: 1.2rem;
            color: var(--fuschia);
            margin-bottom: 5px;
            position: relative;
            z-index: 2;
        }
        .badge-birthday .badge-name {
            font-size: 1.4rem;
            font-weight: 800;
            color: var(--ivory);
            margin-bottom: 10px;
            position: relative;
            z-index: 2;
        }
        .badge-birthday .badge-prize {
            background: linear-gradient(135deg, var(--gold), var(--orange));
            color: white;
            padding: 8px 20px;
            border-radius: 20px;
            font-size: 0.8rem;
            font-weight: 700;
            position: relative;
            z-index: 2;
        }
        .badge-birthday .badge-year {
            position: absolute;
            bottom: 15px;
            font-size: 0.7rem;
            color: var(--mint);
            z-index: 2;
        }
        
        /* WHEEL WINNER BADGE */
        .badge-wheel {
            width: 100%;
            height: 100%;
            background: linear-gradient(145deg, #0a1a15, #0f2920);
            border: 4px solid var(--mint);
            border-radius: 20px;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            padding: 25px;
            position: relative;
            overflow: hidden;
        }
        .badge-wheel::before {
            content: '';
            position: absolute;
            top: 50%;
            left: 50%;
            width: 200px;
            height: 200px;
            background: conic-gradient(var(--mint), var(--gold), var(--fuschia), var(--orange), var(--mint));
            opacity: 0.1;
            border-radius: 50%;
            transform: translate(-50%, -50%);
            animation: rotate 15s linear infinite;
        }
        .badge-wheel .badge-icon {
            font-size: 4rem;
            margin-bottom: 10px;
            position: relative;
            z-index: 2;
        }
        .badge-wheel .badge-label {
            font-family: 'Playfair Display', serif;
            font-size: 0.8rem;
            color: var(--gold);
            text-transform: uppercase;
            letter-spacing: 3px;
            margin-bottom: 8px;
            position: relative;
            z-index: 2;
        }
        .badge-wheel .badge-main-text {
            font-family: 'Playfair Display', serif;
            font-size: 1.1rem;
            color: var(--mint);
            margin-bottom: 5px;
            position: relative;
            z-index: 2;
        }
        .badge-wheel .badge-name {
            font-size: 1.4rem;
            font-weight: 800;
            color: var(--ivory);
            margin-bottom: 10px;
            position: relative;
            z-index: 2;
        }
        .badge-wheel .badge-prize {
            background: var(--mint);
            color: white;
            padding: 8px 20px;
            border-radius: 20px;
            font-size: 0.8rem;
            font-weight: 700;
            position: relative;
            z-index: 2;
        }
        .badge-wheel .badge-year {
            position: absolute;
            bottom: 15px;
            font-size: 0.7rem;
            color: var(--gold);
            z-index: 2;
        }
        
        /* DOWNLOAD BUTTON */
        .download-btn {
            display: inline-block;
            padding: 16px 40px;
            background: linear-gradient(135deg, var(--fuschia), var(--orange));
            color: white;
            font-size: 1.1rem;
            font-weight: 800;
            border: none;
            border-radius: 50px;
            cursor: pointer;
            transition: all 0.3s ease;
        }
        .download-btn:hover {
            transform: translateY(-4px);
            box-shadow: 0 15px 40px rgba(233, 30, 139, 0.4);
        }
        
        .share-tip {
            margin-top: 20px;
            font-size: 0.9rem;
            color: rgba(255, 249, 245, 0.6);
        }
        
        /* FOOTER */
        footer {
            padding: 40px 25px;
            text-align: center;
            border-top: 1px solid rgba(233, 30, 139, 0.15);
        }
        .footer-links {
            display: flex;
            justify-content: center;
            gap: 25px;
            flex-wrap: wrap;
        }
        .footer-links a {
            color: rgba(255, 249, 245, 0.5);
            text-decoration: none;
            font-size: 0.95rem;
        }
        .footer-links a:hover { color: var(--gold); }
        
        /* RESPONSIVE */
        @media (max-width: 768px) {
            html { font-size: 16px; }
            .customizer-grid {
                grid-template-columns: 1fr;
            }
            .badge-canvas {
                width: 280px;
                height: 280px;
            }
        }
    </style>
</head>
<body>
    <div class="bg-master"></div>
    
    <div class="content-wrapper">
        <!-- HEADER -->
        <header class="header">
            <div class="logo">🏅 TASN Badges</div>
            <a href="https://tasn.handshake.africa" class="back-link">← Back to TASN</a>
        </header>
        
        <!-- HERO -->
        <section class="hero">
            <h1>Create Your Shareable Badge!</h1>
            <p>Celebrate your achievement! Create a personalized badge to share on social media, WhatsApp, or your website.</p>
        </section>
        
        <!-- BADGE TYPE SELECTOR -->
        <section class="badge-selector">
            <h2 class="selector-title">Choose Your Badge Type</h2>
            <div class="badge-types">
                <div class="badge-type-btn active" onclick="selectBadgeType('flourishing')">
                    <div class="badge-type-icon">🌸</div>
                    <div class="badge-type-name">Flourishing Fund<br>Contributor</div>
                </div>
                <div class="badge-type-btn" onclick="selectBadgeType('birthday')">
                    <div class="badge-type-icon">🎂</div>
                    <div class="badge-type-name">Birthday Club<br>Winner</div>
                </div>
                <div class="badge-type-btn" onclick="selectBadgeType('wheel')">
                    <div class="badge-type-icon">🎡</div>
                    <div class="badge-type-name">Wheel of Fortune<br>Winner</div>
                </div>
            </div>
        </section>
        
        <!-- CUSTOMIZER -->
        <section class="customizer">
            <div class="customizer-grid">
                <!-- FORM SIDE -->
                <div class="form-side">
                    <h3 class="form-title">Customize Your Badge</h3>
                    
                    <div class="form-group">
                        <label>Your Name</label>
                        <input type="text" id="badgeName" placeholder="Your name" oninput="updateBadge()">
                    </div>
                    
                    <div class="form-group" id="businessGroup">
                        <label>Business Name</label>
                        <input type="text" id="badgeBusiness" placeholder="Your business" oninput="updateBadge()">
                    </div>
                    
                    <div class="form-group" id="categoryGroup">
                        <label>Category</label>
                        <select id="badgeCategory" onchange="updateBadge()">
                            <option value="💆 Spa & Wellness">💆 Spa & Wellness</option>
                            <option value="💅 Nail & Beauty">💅 Nail & Beauty</option>
                            <option value="🎯 Coaching Sessions">🎯 Coaching Sessions</option>
                            <option value="📚 Books & Guides">📚 Books & Guides</option>
                            <option value="🎓 Courses & Training">🎓 Courses & Training</option>
                            <option value="📱 Digital Products">📱 Digital Products</option>
                            <option value="🎨 Design Services">🎨 Design Services</option>
                            <option value="✨ Something Unique!">✨ Something Unique!</option>
                        </select>
                    </div>
                    
                    <div class="form-group" id="prizeGroup" style="display: none;">
                        <label>Prize Won</label>
                        <select id="badgePrize" onchange="updateBadge()">
                            <option value="🏆 Grand Prize Winner!">🏆 Grand Prize Winner!</option>
                            <option value="💳 Digital Card Winner">💳 Digital Card Winner</option>
                            <option value="📰 Feature Article Winner">📰 Feature Article Winner</option>
                            <option value="🎁 Birthday Bundle Winner">🎁 Birthday Bundle Winner</option>
                            <option value="🌍 Directory VIP Winner">🌍 Directory VIP Winner</option>
                            <option value="📓 Strategy Journal Winner">📓 Strategy Journal Winner</option>
                        </select>
                    </div>
                </div>
                
                <!-- PREVIEW SIDE -->
                <div class="preview-side">
                    <h3 class="preview-title">Your Badge Preview</h3>
                    
                    <div class="badge-canvas" id="badgeCanvas">
                        <!-- FLOURISHING BADGE (default) -->
                        <div class="badge-flourishing" id="badgeFlourishing">
                            <div class="badge-icon">🌸</div>
                            <div class="badge-label">Flourishing Fund</div>
                            <div class="badge-main-text">Certified Contributor</div>
                            <div class="badge-name" id="displayName">Your Name</div>
                            <div class="badge-business" id="displayBusiness">Your Business</div>
                            <div class="badge-category" id="displayCategory">💆 Spa & Wellness</div>
                            <div class="badge-quarter">Q1 2026 • TASN</div>
                        </div>
                        
                        <!-- BIRTHDAY BADGE -->
                        <div class="badge-birthday" id="badgeBirthday" style="display: none;">
                            <div class="badge-icon">🎂</div>
                            <div class="badge-label">Birthday Club</div>
                            <div class="badge-main-text">Spin Winner!</div>
                            <div class="badge-name" id="displayNameBday">Your Name</div>
                            <div class="badge-prize" id="displayPrizeBday">🏆 Grand Prize Winner!</div>
                            <div class="badge-year">2026 • TASN Birthday Club</div>
                        </div>
                        
                        <!-- WHEEL BADGE -->
                        <div class="badge-wheel" id="badgeWheel" style="display: none;">
                            <div class="badge-icon">🎡</div>
                            <div class="badge-label">Wheel of Fortune</div>
                            <div class="badge-main-text">Lucky Winner!</div>
                            <div class="badge-name" id="displayNameWheel">Your Name</div>
                            <div class="badge-prize" id="displayPrizeWheel">💳 Digital Card Winner</div>
                            <div class="badge-year">2026 • TASN</div>
                        </div>
                    </div>
                    
                    <button class="download-btn" onclick="downloadBadge()">
                        📥 Download Badge
                    </button>
                    
                    <p class="share-tip">💡 Tip: Share on LinkedIn, Instagram Stories, WhatsApp Status, or your website!</p>
                </div>
            </div>
        </section>
        
        <!-- FOOTER -->
        <footer>
            <div class="footer-links">
                <a href="https://tasn.handshake.africa">TASN Wheel</a>
                <a href="https://tasn.handshake.africa/flourishing">Flourishing Fund</a>
                <a href="https://tasn.handshake.africa/birthday">Birthday Club</a>
            </div>
        </footer>
    </div>
    
    <script>
        let currentBadgeType = 'flourishing';
        
        // SELECT BADGE TYPE
        function selectBadgeType(type) {
            currentBadgeType = type;
            
            // Update buttons
            document.querySelectorAll('.badge-type-btn').forEach(btn => btn.classList.remove('active'));
            event.currentTarget.classList.add('active');
            
            // Show/hide form fields
            document.getElementById('businessGroup').style.display = type === 'flourishing' ? 'block' : 'none';
            document.getElementById('categoryGroup').style.display = type === 'flourishing' ? 'block' : 'none';
            document.getElementById('prizeGroup').style.display = type !== 'flourishing' ? 'block' : 'none';
            
            // Show correct badge
            document.getElementById('badgeFlourishing').style.display = type === 'flourishing' ? 'flex' : 'none';
            document.getElementById('badgeBirthday').style.display = type === 'birthday' ? 'flex' : 'none';
            document.getElementById('badgeWheel').style.display = type === 'wheel' ? 'flex' : 'none';
            
            updateBadge();
        }
        
        // UPDATE BADGE
        function updateBadge() {
            const name = document.getElementById('badgeName').value || 'Your Name';
            const business = document.getElementById('badgeBusiness').value || 'Your Business';
            const category = document.getElementById('badgeCategory').value;
            const prize = document.getElementById('badgePrize').value;
            
            if (currentBadgeType === 'flourishing') {
                document.getElementById('displayName').textContent = name;
                document.getElementById('displayBusiness').textContent = business;
                document.getElementById('displayCategory').textContent = category;
            } else if (currentBadgeType === 'birthday') {
                document.getElementById('displayNameBday').textContent = name;
                document.getElementById('displayPrizeBday').textContent = prize;
            } else {
                document.getElementById('displayNameWheel').textContent = name;
                document.getElementById('displayPrizeWheel').textContent = prize;
            }
        }
        
        // DOWNLOAD BADGE
        function downloadBadge() {
            const canvas = document.getElementById('badgeCanvas');
            
            html2canvas(canvas, {
                backgroundColor: null,
                scale: 2,
                useCORS: true
            }).then(function(canvas) {
                const link = document.createElement('a');
                link.download = `tasn-${currentBadgeType}-badge-2026.png`;
                link.href = canvas.toDataURL('image/png');
                link.click();
            });
        }
        
        // Initial update
        updateBadge();
    </script>
</body>
</html>","embed":""}
🏅 TASN Badges
← Back to TASN
Create Your Shareable Badge!
Celebrate your achievement! Create a personalized badge to share on social media, WhatsApp, or your website.
Choose Your Badge Type
🌸
Flourishing Fund
Contributor
Contributor
🎂
Birthday Club
Winner
Winner
🎡
Wheel of Fortune
Winner
Winner
Customize Your Badge
Your Badge Preview
🌸
Flourishing Fund
Certified Contributor
Your Name
Your Business
💆 Spa & Wellness
Q1 2026 • TASN
🎂
Birthday Club
Spin Winner!
Your Name
🏆 Grand Prize Winner!
2026 • TASN Birthday Club
🎡
Wheel of Fortune
Lucky Winner!
Your Name
💳 Digital Card Winner
2026 • TASN
💡 Tip: Share on LinkedIn, Instagram Stories, WhatsApp Status, or your website!