:root{--purple:#7C3AED;--purple-dark:#5B21B6;--purple-light:#EDE9FE;--purple-mid:#A78BFA;--violet:#8B5CF6;--white:#FFF;--bg:#FAFAFA;--text:#111827;--muted:#6B7280;--border:#E5E7EB;--card:#FFF;--star:#F59E0B;--green:#10B981}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--white);color:var(--text);overflow-x:hidden}
h1,h2,h3,h4,.brand{font-family:'Bricolage Grotesque',sans-serif}
nav{position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(255,255,255,0.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 5%;height:64px;display:flex;align-items:center;justify-content:space-between;transition:box-shadow .3s}
nav.scrolled{box-shadow:0 2px 20px rgba(124,58,237,.1)}
.brand{font-size:1.3rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px;text-decoration:none}
.brand-icon{width:32px;height:32px;border-radius:8px;background:var(--purple);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1rem;font-family:'Bricolage Grotesque',sans-serif}
.nav-links{display:flex;align-items:center;gap:32px;list-style:none}
.nav-links a{color:var(--muted);text-decoration:none;font-size:.9rem;font-weight:500;transition:color .2s}
.nav-links a:hover{color:var(--purple)}
.nav-actions{display:flex;align-items:center;gap:12px}
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;border-radius:100px;font-family:'Bricolage Grotesque',sans-serif;font-size:.9rem;font-weight:600;cursor:pointer;border:none;text-decoration:none;transition:all .25s;white-space:nowrap}
.btn-primary{background:var(--purple);color:#fff;box-shadow:0 4px 16px rgba(124,58,237,.35)}
.btn-primary:hover{background:var(--purple-dark);transform:translateY(-1px);box-shadow:0 6px 24px rgba(124,58,237,.45)}
.btn-outline{background:transparent;color:var(--text);border:1.5px solid var(--border)}
.btn-outline:hover{border-color:var(--purple);color:var(--purple)}
.btn-ghost{background:transparent;color:var(--text);padding:10px 16px}
.btn-ghost:hover{color:var(--purple)}
.btn-lg{padding:14px 30px;font-size:1rem}
.btn-white{background:#fff;color:var(--purple);box-shadow:0 4px 20px rgba(0,0,0,.15)}
.btn-white:hover{background:#f5f3ff;transform:translateY(-1px)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mobile-menu{display:none;position:fixed;top:64px;left:0;right:0;background:#fff;border-bottom:1px solid var(--border);padding:20px 5%;z-index:99;flex-direction:column;gap:4px;box-shadow:0 8px 30px rgba(0,0,0,.08)}
.mobile-menu.open{display:flex}
.mobile-menu a{padding:12px 8px;color:var(--text);text-decoration:none;font-size:1rem;font-weight:500;border-radius:8px;transition:background .2s}
.mobile-menu a:hover{background:var(--purple-light);color:var(--purple)}
.mobile-menu .btn{width:100%;justify-content:center;margin-top:8px}
.hero{padding-top:120px;padding-bottom:80px;padding-left:5%;padding-right:5%;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:60px;max-width:1200px;margin:0 auto;position:relative}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:var(--purple-light);color:var(--purple);padding:6px 14px;border-radius:100px;font-size:.8rem;font-weight:600;margin-bottom:20px;font-family:'Bricolage Grotesque',sans-serif}
.hero-badge::before{content:'';width:6px;height:6px;background:var(--purple);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse {
0%,100%{opacity:1;transform:scale(1)}
50%{opacity:.5;transform:scale(1.4)}
}
.hero h1{font-size:clamp(2.2rem,4vw,3.4rem);line-height:1.15;color:var(--text);margin-bottom:4px}
.hero h1 span{color:var(--purple)}
.hero-sub{font-size:1.05rem;color:var(--muted);line-height:1.7;margin-bottom:32px;max-width:440px}
.hero-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.hero-trust{display:flex;align-items:center;gap:16px;margin-top:24px}
.trust-item{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--muted)}
.trust-item svg{color:var(--green)}
.hero-visual{position:relative;display:flex;justify-content:flex-end}
.phone-mockup{width:300px;max-width:100%;background:#fff;border-radius:36px;box-shadow:0 30px 80px rgba(0,0,0,.15),0 0 0 12px #f3f0ff,0 0 0 14px #e5e0fc;overflow:hidden;position:relative;transform:translateY(0);animation:float 5s ease-in-out infinite}
@keyframes float {
0%,100%{transform:translateY(0)}
50%{transform:translateY(-12px)}
}
.phone-screen{padding:24px 20px;background:linear-gradient(160deg,#f5f3ff 0%,#faf8ff 100%);min-height:420px}
.phone-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.phone-bar .p-label{font-size:.65rem;font-weight:700;color:var(--purple);font-family:'Bricolage Grotesque',sans-serif}
.phone-notif{background:var(--purple);color:#fff;font-size:.6rem;padding:3px 10px;border-radius:100px;font-weight:600}
.phone-card{background:#fff;border-radius:14px;padding:14px 16px;margin-bottom:10px;box-shadow:0 2px 12px rgba(0,0,0,.06)}
.phone-card-title{font-size:.72rem;font-weight:700;font-family:'Bricolage Grotesque',sans-serif;color:var(--text);margin-bottom:8px}
.phone-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid #f3f4f6}
.phone-row:last-child{border-bottom:none}
.phone-row-name{font-size:.65rem;color:var(--text)}
.phone-badge{font-size:.58rem;padding:2px 8px;border-radius:100px;font-weight:600}
.badge-confirmed{background:#d1fae5;color:#059669}
.badge-pending{background:#fef3c7;color:#d97706}
.phone-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:10px}
.stat-box{background:#fff;border-radius:10px;padding:10px 8px;text-align:center;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.stat-num{font-size:1rem;font-weight:800;font-family:'Bricolage Grotesque',sans-serif;color:var(--purple)}
.stat-lbl{font-size:.58rem;color:var(--muted);margin-top:2px}
.floating-chip{position:absolute;background:#fff;border-radius:12px;padding:10px 14px;box-shadow:0 8px 30px rgba(0,0,0,.12);font-size:.75rem;font-weight:600;font-family:'Bricolage Grotesque',sans-serif;display:flex;align-items:center;gap:6px;white-space:nowrap}
.chip-1{top:30px;right:-20px;animation:float 5s ease-in-out 1s infinite}
.chip-2{bottom:60px;left:-30px;animation:float 5s ease-in-out 2s infinite}
.chip-dot{width:8px;height:8px;border-radius:50%}
section{padding:80px 5%}
.section-inner{max-width:1200px;margin:0 auto}
.section-tag{text-align:center;font-family:'Bricolage Grotesque',sans-serif;font-size:.8rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--purple);margin-bottom:12px}
.section-title{text-align:center;font-size:clamp(1.8rem,3vw,2.6rem);font-weight:800;color:var(--text);margin-bottom:12px;line-height:1.2}
.section-sub{text-align:center;color:var(--muted);font-size:1rem;max-width:520px;margin:0 auto 56px;line-height:1.7}
.action-section{background:var(--bg)}
.phones-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:0}
.action-phone{text-align:center;opacity:0;transform:translateY(30px);transition:all .6s cubic-bezier(.22,1,.36,1)}
.action-phone.visible{opacity:1;transform:translateY(0)}
.action-phone:nth-child(2){transition-delay:.15s}
.action-phone:nth-child(3){transition-delay:.3s}
.action-phone-frame{width:180px;margin:0 auto 16px;background:#fff;border-radius:28px;box-shadow:0 16px 50px rgba(0,0,0,.12);overflow:hidden;border:6px solid #f3f0ff}
.action-phone-screen{background:linear-gradient(160deg,#f5f3ff 0%,#fafafa 100%);padding:16px 12px;min-height:280px;position:relative}
.ap-header{font-size:.6rem;font-weight:700;font-family:'Bricolage Grotesque',sans-serif;color:var(--text);margin-bottom:10px;display:flex;align-items:center;justify-content:space-between}
.ap-pill{background:var(--purple);color:#fff;border-radius:100px;padding:2px 8px;font-size:.55rem}
.ap-input{background:#fff;border-radius:8px;padding:7px 10px;font-size:.6rem;color:var(--muted);margin-bottom:6px;border:1.5px solid var(--border)}
.ap-input.focus{border-color:var(--purple)}
.ap-themes{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:8px}
.ap-theme{border-radius:8px;height:36px;display:flex;align-items:center;justify-content:center;font-size:.55rem;font-weight:700;color:#fff;font-family:'Bricolage Grotesque',sans-serif}
.t1{background:linear-gradient(135deg,#7C3AED,#A78BFA)}
.t2{background:linear-gradient(135deg,#EC4899,#F97316)}
.t3{background:linear-gradient(135deg,#0EA5E9,#10B981)}
.t4{background:linear-gradient(135deg,#1E293B,#475569)}
.ap-btn{background:var(--purple);color:#fff;border-radius:8px;padding:8px;font-size:.6rem;font-weight:700;text-align:center;margin-top:4px;font-family:'Bricolage Grotesque',sans-serif}
.ap-guest-row{display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:8px;padding:7px 10px;margin-bottom:5px;box-shadow:0 1px 4px rgba(0,0,0,.05)}
.ap-avatar{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.55rem;font-weight:700;color:#fff;flex-shrink:0}
.ap-guest-info{flex:1;margin-left:7px}
.ap-guest-name{font-size:.6rem;font-weight:600;color:var(--text)}
.ap-guest-plus{font-size:.52rem;color:var(--muted)}
.ap-stat-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;margin-bottom:8px}
.ap-stat{background:#fff;border-radius:8px;padding:8px 4px;text-align:center;box-shadow:0 1px 6px rgba(0,0,0,.06)}
.ap-stat-n{font-size:.85rem;font-weight:800;font-family:'Bricolage Grotesque',sans-serif;color:var(--purple)}
.ap-stat-l{font-size:.5rem;color:var(--muted)}
.ap-qr-wrap{display:flex;flex-direction:column;align-items:center;padding-top:10px}
.ap-qr{width:80px;height:80px;background:var(--text);border-radius:8px;margin-bottom:8px;display:grid;grid-template-columns:repeat(7,1fr);gap:2px;padding:8px}
.ap-qr-cell{background:#fff;border-radius:1px}
.ap-qr-cell.dark{background:var(--text)}
.ap-qr-cell.big{grid-column:span 2;grid-row:span 2}
.qr-label{font-size:.6rem;font-weight:700;color:var(--text);font-family:'Bricolage Grotesque',sans-serif;text-align:center}
.qr-sub{font-size:.55rem;color:var(--muted);text-align:center;margin-top:2px}
.action-caption{font-weight:700;font-size:.95rem;color:var(--text);margin-bottom:4px;font-family:'Bricolage Grotesque',sans-serif}
.action-caption-sub{font-size:.82rem;color:var(--muted)}
.features-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.feature-card{background:var(--white);border:1.5px solid var(--border);border-radius:20px;padding:28px;transition:border-color .2s;opacity:0;transform:translateY(20px)}
.feature-card.visible{opacity:1;transform:translateY(0)}
.feature-card:nth-child(2){transition-delay:.1s}
.feature-card:nth-child(3){transition-delay:.2s}
.feature-card:nth-child(4){transition-delay:.3s}
.feature-card:hover{border-color:var(--purple);box-shadow:none;transform:none}
.feature-icon{width:48px;height:48px;border-radius:14px;background:var(--purple-light);display:flex;align-items:center;justify-content:center;margin-bottom:16px;font-size:1.2rem}
.feature-card h3{font-size:1rem;font-weight:700;margin-bottom:8px}
.feature-card p{font-size:.88rem;color:var(--muted);line-height:1.6}
.steps-section{background:var(--bg)}
.steps-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.steps-list{display:flex;flex-direction:column;gap:28px}
.step{display:flex;gap:18px;opacity:0;transform:translateX(-20px);transition:all .5s cubic-bezier(.22,1,.36,1)}
.step.visible{opacity:1;transform:translateX(0)}
.step:nth-child(2){transition-delay:.15s}
.step:nth-child(3){transition-delay:.3s}
.step-num{width:42px;height:42px;border-radius:50%;background:var(--purple);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:1rem;flex-shrink:0}
.step-body h3{font-size:1rem;font-weight:700;margin-bottom:6px}
.step-body p{font-size:.88rem;color:var(--muted);line-height:1.6}
.steps-cta{margin-top:32px}
.steps-visual{position:relative;opacity:0;transform:scale(.95);transition:all .6s cubic-bezier(.22,1,.36,1)}
.steps-visual.visible{opacity:1;transform:scale(1)}
.steps-phone{width:260px;margin:0 auto;background:#fff;border-radius:36px;box-shadow:0 20px 60px rgba(0,0,0,.12);overflow:hidden;border:6px solid var(--purple-light)}
.steps-screen{background:linear-gradient(160deg,#f5f3ff 0%,#faf8ff 100%);padding:20px 16px;min-height:380px}
.sp-header{font-size:.7rem;font-weight:700;font-family:'Bricolage Grotesque',sans-serif;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.sp-event-card{background:var(--purple);border-radius:14px;padding:14px;color:#fff;margin-bottom:10px}
.sp-event-title{font-size:.75rem;font-weight:800;font-family:'Bricolage Grotesque',sans-serif;margin-bottom:4px}
.sp-event-date{font-size:.6rem;opacity:.85}
.sp-event-meta{display:flex;justify-content:space-between;margin-top:10px}
.sp-meta-item{font-size:.62rem;opacity:.9}
.sp-meta-label{font-size:.52rem;opacity:.7}
.sp-invite-row{display:flex;align-items:center;gap:8px;background:#fff;border-radius:10px;padding:10px;margin-bottom:8px;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.sp-invite-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:.75rem;background:var(--purple-light);flex-shrink:0}
.sp-invite-label{font-size:.62rem;color:var(--text);font-weight:600}
.sp-invite-sub{font-size:.55rem;color:var(--muted)}
/* ── Testimonial Slider ── */
.testi-slider-wrap{position:relative;display:flex;align-items:center;gap:14px;margin-top:40px}
.testi-viewport{overflow:hidden;width:100%}
.testi-track{display:flex;gap:15px;transition:transform .45s cubic-bezier(.4,0,.2,1);will-change:transform}
.testi-card{ margin:2px 0;flex:0 0 calc(25% - 15px);background:#fff;border:1px solid var(--border);border-radius:20px;padding:24px;box-sizing:border-box;display:flex;flex-direction:column}
.testi-card:hover{box-shadow:none;transform:none;border:1px solid #7C3AED;}
.testi-quote{font-size:1.8rem;line-height:1;color:var(--purple);opacity:.15;margin-bottom:4px;font-family:Georgia,serif}
.stars{color:var(--star);font-size:.85rem;margin-bottom:10px;letter-spacing:1px}
.testi-text{font-size:.84rem;color:var(--text);line-height:1.72;margin-bottom:16px;flex:1}
.testi-author{display:flex;align-items:center;gap:10px}
.testi-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#fff;flex-shrink:0}
.testi-name{font-weight:700;font-size:.87rem;font-family:'Bricolage Grotesque',sans-serif}
.testi-role{font-size:.74rem;color:var(--muted);margin-top:1px}
.testi-arrow{width:40px;height:40px;min-width:40px;border-radius:50%;border:1.5px solid var(--border);background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:var(--text)}
.testi-arrow:hover{background:var(--purple);border-color:var(--purple);color:#fff}
.testi-dots{display:flex;justify-content:center;gap:7px;margin-top:24px}
.testi-dot{width:8px;height:8px;border-radius:50%;border:none;background:var(--border);cursor:pointer;padding:0;transition:all .25s}
.testi-dot.active{background:var(--purple);width:22px;border-radius:99px}
.testi-rating-bar{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:28px;font-size:.9rem;color:var(--muted)}
.trb-stars{color:var(--star);font-size:1rem;letter-spacing:1px}
.trb-score{font-weight:800;color:var(--text);font-family:'Bricolage Grotesque',sans-serif;font-size:1.05rem}
.trb-sep{color:var(--border)}
.trb-count{font-weight:500}
.cta-section{background:linear-gradient(135deg,#5B21B6 0%,#7C3AED 50%,#8B5CF6 100%);border-radius:28px;margin:0 5% 80px;padding:72px 10%;text-align:center;position:relative;overflow:hidden}
.cta-section::before{content:'';position:absolute;top:-50%;left:-20%;width:500px;height:500px;background:rgba(255,255,255,.05);border-radius:50%}
.cta-section::after{content:'';position:absolute;bottom:-30%;right:-10%;width:350px;height:350px;background:rgba(255,255,255,.05);border-radius:50%}
.cta-section h2{font-size:clamp(1.8rem,3vw,2.6rem);color:#fff;margin-bottom:12px;position:relative;z-index:1}
.cta-section p{color:rgba(255,255,255,.8);font-size:1rem;margin-bottom:32px;position:relative;z-index:1}
.cta-actions{position:relative;z-index:1;display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
footer{background:var(--text);padding:60px 5% 30px}
.footer-inner{max-width:1200px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:40px;margin-bottom:40px}
.footer-brand .brand{color:#fff;text-decoration:none;margin-bottom:12px;display:inline-flex}
.footer-brand p{font-size:.85rem;color:#9CA3AF;line-height:1.7}
.footer-col h4{color:#fff;font-size:.9rem;font-weight:700;margin-bottom:16px}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:10px}
.footer-col a{color:#9CA3AF;text-decoration:none;font-size:.85rem;transition:color .2s}
.footer-col a:hover{color:var(--purple-mid)}
.footer-bottom{border-top:1px solid #374151;padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-bottom p{color:#6B7280;font-size:.8rem}
.footer-social{display:flex;gap:12px}
.social-icon{width:36px;height:36px;border-radius:50%;background:#374151;display:flex;align-items:center;justify-content:center;color:#9CA3AF;text-decoration:none;transition:all .2s;font-size:.85rem}
.social-icon:hover{background:var(--purple);color:#fff}
.reveal{opacity:0;transform:translateY(30px);transition:all .6s cubic-bezier(.22,1,.36,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
@media (max-width: 1024px) {
.footer-top{grid-template-columns:1fr 1fr;gap:30px}
}
@media (max-width: 768px) {
nav{padding:0 4%}
.nav-links,.nav-actions .btn-ghost{display:none}
.hamburger{display:flex}
nav .btn-primary{display:none}
.hero{grid-template-columns:1fr;padding-top:100px;padding-bottom:40px;text-align:center}
.hero-sub{margin:0 auto 32px}
.hero-actions{justify-content:center}
.hero-trust{justify-content:center;flex-wrap:wrap}
.hero-visual{justify-content:center;margin-top:40px}
.phone-mockup{width:240px}
.floating-chip{display:none}
.phones-grid{grid-template-columns:1fr;max-width:280px;margin:0 auto}
.action-phone-frame{width:200px}
.features-grid{grid-template-columns:1fr}
.steps-inner{grid-template-columns:1fr}
.steps-visual{display:none}
.testi-card{flex:0 0 calc(100% - 0px)}
.footer-top{grid-template-columns:1fr 1fr}
.cta-section{margin:0 4% 60px;padding:48px 6%}
section{padding:60px 4%}
}
@media (max-width: 480px) {
.hero h1{font-size:2rem}
.hero-actions .btn{width:100%;justify-content:center}
.footer-top{grid-template-columns:1fr}
.cta-section{border-radius:20px}
}

/* ── Avatar background gradients (bg1–bg20) ── */
.bg1{background:linear-gradient(135deg,#7C3AED,#A78BFA)}
.bg2{background:linear-gradient(135deg,#6366F1,#A5B4FC)}
.bg3{background:linear-gradient(135deg,#EC4899,#F9A8D4)}
.bg4{background:linear-gradient(135deg,#10B981,#6EE7B7)}
.bg5{background:linear-gradient(135deg,#F59E0B,#FCD34D)}
.bg6{background:linear-gradient(135deg,#3B82F6,#93C5FD)}
.bg7{background:linear-gradient(135deg,#8B5CF6,#C4B5FD)}
.bg8{background:linear-gradient(135deg,#14B8A6,#5EEAD4)}
.bg9{background:linear-gradient(135deg,#F43F5E,#FDA4AF)}
.bg10{background:linear-gradient(135deg,#22C55E,#86EFAC)}
.bg11{background:linear-gradient(135deg,#0EA5E9,#7DD3FC)}
.bg12{background:linear-gradient(135deg,#9333EA,#D8B4FE)}
.bg13{background:linear-gradient(135deg,#2563EB,#60A5FA)}
.bg14{background:linear-gradient(135deg,#DC2626,#FCA5A5)}
.bg15{background:linear-gradient(135deg,#059669,#6EE7B7)}
.bg16{background:linear-gradient(135deg,#DB2777,#F9A8D4)}
.bg17{background:linear-gradient(135deg,#0891B2,#67E8F9)}
.bg18{background:linear-gradient(135deg,#65A30D,#BEF264)}
.bg19{background:linear-gradient(135deg,#EA580C,#FDBA74)}
.bg20{background:linear-gradient(135deg,#4F46E5,#A5B4FC)}