html { scroll-behavior: smooth; }
body { background: #06070d; color: #fff; font-family: 'Inter', sans-serif; }
.aurora { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.aurora::before, .aurora::after { content: ''; position: absolute; border-radius: 50%; filter: blur(80px); opacity: 0.6; }
.aurora::before { width: 720px; height: 720px; background: radial-gradient(circle, rgba(34,211,238,0.55) 0%, transparent 70%); top: -200px; left: -200px; animation: drift1 22s ease-in-out infinite alternate; }
.aurora::after { width: 720px; height: 720px; background: radial-gradient(circle, rgba(244,114,182,0.5) 0%, transparent 70%); bottom: -200px; right: -200px; animation: drift2 26s ease-in-out infinite alternate; }
.aurora-3 { position: absolute; width: 600px; height: 600px; border-radius: 50%; background: radial-gradient(circle, rgba(168,85,247,0.4) 0%, transparent 70%); top: 30%; left: 40%; filter: blur(70px); opacity: 0.55; animation: drift3 30s ease-in-out infinite alternate; }
@keyframes drift1 { 0% { transform: translate(0,0); } 100% { transform: translate(120px, 80px); } }
@keyframes drift2 { 0% { transform: translate(0,0); } 100% { transform: translate(-100px, -60px); } }
@keyframes drift3 { 0% { transform: translate(0,0) scale(1); } 100% { transform: translate(-160px, 100px) scale(1.1); } }
.grid-overlay { position: absolute; inset: 0; pointer-events: none; background-image: linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px); background-size: 56px 56px; mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%); }
.grad-text { background: linear-gradient(135deg, #22d3ee 0%, #a855f7 50%, #f472b6 100%); -webkit-background-clip: text; background-clip: text; color: transparent; }
.glass { background: rgba(255,255,255,0.035); border: 1px solid rgba(255,255,255,0.08); backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px); }
.glass-hover { transition: border-color .3s, transform .3s, box-shadow .3s; }
.glass-hover:hover { border-color: rgba(34,211,238,0.4); transform: translateY(-3px); box-shadow: 0 12px 32px rgba(34,211,238,0.15); }
.badge { background: linear-gradient(135deg, rgba(34,211,238,0.15), rgba(168,85,247,0.15)); border: 1px solid rgba(34,211,238,0.25); }
.btn-neon { background: linear-gradient(135deg, #22d3ee 0%, #a855f7 50%, #f472b6 100%); color: #0a0a0f; font-weight: 700; transition: transform .15s, box-shadow .2s, opacity .2s; box-shadow: 0 8px 32px rgba(34,211,238,0.35); }
.btn-neon:hover { transform: translateY(-2px); box-shadow: 0 12px 40px rgba(244,114,182,0.45); }
.btn-ghost { background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.15); color: #fff; transition: background .2s, border-color .2s, transform .15s; }
.btn-ghost:hover { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.3); }
.divider { height: 1px; background: linear-gradient(90deg, transparent, rgba(255,255,255,0.15), transparent); }
.chip { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border-radius: 999px; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1); font-size: 12px; font-weight: 500; color: rgba(255,255,255,0.75); }
.wordmark { font-family: 'Space Grotesk', sans-serif; font-weight: 700; letter-spacing: -0.02em; }
.icon-bubble { width: 44px; height: 44px; border-radius: 12px; display: inline-flex; align-items: center; justify-content: center; font-size: 22px; background: linear-gradient(135deg, rgba(34,211,238,0.15), rgba(168,85,247,0.15)); border: 1px solid rgba(255,255,255,0.08); }
.stat-num { font-family: 'Space Grotesk', sans-serif; font-weight: 700; background: linear-gradient(135deg, #22d3ee, #a855f7); -webkit-background-clip: text; background-clip: text; color: transparent; }
.reveal { opacity: 0; transform: translateY(16px); transition: opacity .8s ease, transform .8s ease; }
.reveal.in { opacity: 1; transform: translateY(0); }
.step-num { font-family: 'Space Grotesk', sans-serif; font-weight: 700; font-size: 56px; line-height: 1; background: linear-gradient(135deg, #22d3ee, #a855f7); -webkit-background-clip: text; background-clip: text; color: transparent; }
.live-dot { animation: livePulse 1.8s ease-out infinite; }
@keyframes livePulse { 0%, 100% { box-shadow: 0 0 0 0 rgba(34,211,238,0.6); } 50% { box-shadow: 0 0 0 8px rgba(34,211,238,0); } }
input, select, textarea { background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.12); color: #fff; }
input:focus, select:focus, textarea:focus { outline: none; border-color: rgba(34,211,238,0.6); box-shadow: 0 0 0 3px rgba(34,211,238,0.15); }
::placeholder { color: rgba(255,255,255,0.35); }

/* Page accent overrides (per-page colored buttons/dots) */
body.accent-gold .badge { background: linear-gradient(135deg, rgba(251,191,36,0.18), rgba(251,191,36,0.10)); border-color: rgba(251,191,36,0.30); }
body.accent-gold .live-dot { background: #fbbf24 !important; animation-name: livePulseGold; }
body.accent-gold .stat-num,
body.accent-gold .step-num { background: linear-gradient(135deg, #fbbf24, #f59e0b); -webkit-background-clip: text; background-clip: text; }
body.accent-gold .btn-neon { background: linear-gradient(135deg, #fbbf24 0%, #f59e0b 60%, #f472b6 100%); box-shadow: 0 8px 32px rgba(251,191,36,0.35); }
body.accent-gold .glass-hover:hover { border-color: rgba(251,191,36,0.4); box-shadow: 0 12px 32px rgba(251,191,36,0.15); }
body.accent-gold .icon-bubble { background: linear-gradient(135deg, rgba(251,191,36,0.18), rgba(244,114,182,0.12)); }
@keyframes livePulseGold { 0%,100% { box-shadow: 0 0 0 0 rgba(251,191,36,0.6); } 50% { box-shadow: 0 0 0 8px rgba(251,191,36,0); } }

body.accent-violet .badge { background: linear-gradient(135deg, rgba(168,85,247,0.20), rgba(168,85,247,0.10)); border-color: rgba(168,85,247,0.35); }
body.accent-violet .live-dot { background: #a855f7 !important; animation-name: livePulseViolet; }
body.accent-violet .stat-num,
body.accent-violet .step-num { background: linear-gradient(135deg, #a855f7, #8b5cf6); -webkit-background-clip: text; background-clip: text; }
body.accent-violet .btn-neon { background: linear-gradient(135deg, #a855f7 0%, #8b5cf6 60%, #22d3ee 100%); box-shadow: 0 8px 32px rgba(168,85,247,0.35); }
body.accent-violet .glass-hover:hover { border-color: rgba(168,85,247,0.4); box-shadow: 0 12px 32px rgba(168,85,247,0.15); }
body.accent-violet .icon-bubble { background: linear-gradient(135deg, rgba(168,85,247,0.18), rgba(34,211,238,0.12)); }
@keyframes livePulseViolet { 0%,100% { box-shadow: 0 0 0 0 rgba(168,85,247,0.6); } 50% { box-shadow: 0 0 0 8px rgba(168,85,247,0); } }

body.accent-magenta .badge { background: linear-gradient(135deg, rgba(244,114,182,0.18), rgba(168,85,247,0.15)); border-color: rgba(244,114,182,0.3); }
body.accent-magenta .live-dot { background: #f472b6 !important; animation-name: livePulseMagenta; }
body.accent-magenta .stat-num,
body.accent-magenta .step-num { background: linear-gradient(135deg, #f472b6, #a855f7); -webkit-background-clip: text; background-clip: text; }
body.accent-magenta .btn-neon { box-shadow: 0 8px 32px rgba(244,114,182,0.35); }
body.accent-magenta .glass-hover:hover { border-color: rgba(244,114,182,0.4); box-shadow: 0 12px 32px rgba(244,114,182,0.15); }
body.accent-magenta .icon-bubble { background: linear-gradient(135deg, rgba(244,114,182,0.15), rgba(168,85,247,0.15)); }
@keyframes livePulseMagenta { 0%,100% { box-shadow: 0 0 0 0 rgba(244,114,182,0.6); } 50% { box-shadow: 0 0 0 8px rgba(244,114,182,0); } }
