* { margin: 0; padding: 0; box-sizing: border-box; }
html, body { height: 100%; background: #05031a; overflow: hidden; }

.stage {
  position: relative;
  width: 100vw;
  height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: radial-gradient(1100px 760px at 50% 42%, #0a0830 0%, #05031a 48%, #020107 100%);
  font-family: 'Archivo', sans-serif;
  overflow: hidden;
}

/* ---- orbs ---- */
.orb { position: absolute; border-radius: 50%; mix-blend-mode: screen; pointer-events: none; }
.orb1 { top: 14%; left: 14%; width: 560px; height: 560px; background: radial-gradient(circle at 40% 36%, #143a90 0%, rgba(20,58,144,0) 68%); filter: blur(56px); opacity: 0.45; animation: drift1 16s ease-in-out infinite; }
.orb2 { bottom: 6%; right: 10%; width: 640px; height: 640px; background: radial-gradient(circle at 50% 50%, #341290 0%, rgba(52,18,144,0) 68%); filter: blur(64px); opacity: 0.42; animation: drift2 20s ease-in-out infinite; }
.orb3 { top: 28%; right: 22%; width: 420px; height: 420px; background: radial-gradient(circle at 50% 50%, #1c54a4 0%, rgba(28,84,164,0) 68%); filter: blur(52px); opacity: 0.36; animation: drift3 13s ease-in-out infinite; }
.orb4 { bottom: 22%; left: 20%; width: 380px; height: 380px; background: radial-gradient(circle at 50% 50%, #3f12a0 0%, rgba(63,18,160,0) 68%); filter: blur(50px); opacity: 0.34; animation: drift4 18s ease-in-out infinite; }

/* ---- particles ---- */
.particles { position: absolute; inset: 0; pointer-events: none; }
.particle { position: absolute; border-radius: 50%; }

/* ---- central scene ---- */
.scene { position: relative; display: flex; flex-direction: column; align-items: center; z-index: 2; }

.badge {
  display: flex; align-items: center; gap: 9px;
  padding: 8px 18px; margin-bottom: 40px;
  border-radius: 999px;
  background: rgba(123,99,255,0.08);
  border: 1px solid rgba(139,125,255,0.22);
  backdrop-filter: blur(8px);
  animation: rise 0.8s cubic-bezier(.2,.8,.2,1) both;
}
.badge-dot { display: block; width: 7px; height: 7px; border-radius: 50%; background: #8b7dff; box-shadow: 0 0 10px 2px #8b7dff; animation: dotPulse 2.2s ease-in-out infinite; }
.badge-label { font-family: 'Archivo', sans-serif; font-weight: 700; font-size: 11px; letter-spacing: 0.28em; text-transform: uppercase; white-space: nowrap; color: #b3a8ff; }

.bot { position: relative; margin-bottom: 44px; }
.bot-face {
  width: 128px; height: 128px; border-radius: 28px;
  background: linear-gradient(155deg, #4db5ff 0%, #2f7bf0 45%, #6320e8 100%);
  box-shadow: 0 0 70px rgba(99,32,232,0.5), 0 18px 0 0 rgba(47,123,240,0.16);
  display: flex; align-items: center; justify-content: center; gap: 18px;
  animation: bob 3.6s ease-in-out infinite;
}
.eye { display: block; width: 14px; height: 34px; border-radius: 8px; background: #ffffff; transform-origin: center; animation: wink 4.2s ease-in-out infinite; }
.eye2 { animation-delay: 0.08s; }
.bot-shadow { position: absolute; left: 50%; bottom: -30px; width: 96px; height: 14px; border-radius: 50%; background: #4a1bc4; filter: blur(2px); animation: shadowPulse 3.6s ease-in-out infinite; }

.title {
  font-family: 'JetBrains Mono', monospace; font-weight: 800;
  font-size: 72px; line-height: 1; min-height: 72px;
  white-space: nowrap; letter-spacing: 0.02em;
  color: #f4f1ff; text-shadow: 0 0 40px rgba(77,181,255,0.4);
  text-align: center; display: flex; align-items: center; justify-content: center;
  animation: rise 0.8s cubic-bezier(.2,.8,.2,1) both;
}
.cursor { display: inline-block; width: 36px; height: 9px; margin-left: 10px; align-self: flex-end; margin-bottom: 12px; border-radius: 3px; background: #e4e7ff; opacity: 0.85; animation: blink 1.1s step-end infinite; }

.subtitle {
  margin-top: 26px; font-family: 'JetBrains Mono', monospace;
  font-size: 14px; font-weight: 500; letter-spacing: 0.01em;
  color: rgba(222,216,255,0.88); text-align: center; max-width: 380px;
  animation: rise 0.8s cubic-bezier(.2,.8,.2,1) 0.15s both;
}

/* ---- keyframes ---- */
@keyframes bob { 0%,100% { transform: translateY(0) rotate(-3deg); } 50% { transform: translateY(-22px) rotate(3deg); } }
@keyframes shadowPulse { 0%,100% { transform: translateX(-50%) scaleX(1); opacity: 0.18; } 50% { transform: translateX(-50%) scaleX(0.7); opacity: 0.09; } }
@keyframes wink { 0%,42%,48%,100% { transform: scaleY(1); } 45% { transform: scaleY(0.1); } }
@keyframes rise { 0% { opacity: 0; transform: translateY(24px); } 100% { opacity: 1; transform: translateY(0); } }
@keyframes drift1 { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(60px,-40px) scale(1.15); } }
@keyframes drift2 { 0%,100% { transform: translate(0,0) scale(1.08); } 50% { transform: translate(-70px,50px) scale(0.9); } }
@keyframes drift3 { 0%,100% { transform: translate(0,0) scale(0.95); } 50% { transform: translate(50px,60px) scale(1.1); } }
@keyframes drift4 { 0%,100% { transform: translate(0,0) scale(1); } 50% { transform: translate(-55px,-55px) scale(1.12); } }
@keyframes dotPulse { 0%,100% { opacity: 0.4; transform: scale(0.8); } 50% { opacity: 1; transform: scale(1.2); } }
@keyframes wanderA { 0%{transform:translate(0,0)} 25%{transform:translate(34px,-26px)} 50%{transform:translate(14px,28px)} 75%{transform:translate(-30px,8px)} 100%{transform:translate(0,0)} }
@keyframes wanderB { 0%{transform:translate(0,0)} 25%{transform:translate(-28px,22px)} 50%{transform:translate(20px,30px)} 75%{transform:translate(26px,-18px)} 100%{transform:translate(0,0)} }
@keyframes wanderC { 0%{transform:translate(0,0)} 33%{transform:translate(40px,18px)} 66%{transform:translate(-22px,-30px)} 100%{transform:translate(0,0)} }
@keyframes wanderD { 0%{transform:translate(0,0)} 30%{transform:translate(-36px,-20px)} 60%{transform:translate(-10px,32px)} 100%{transform:translate(0,0)} }
@keyframes twinkle { 0%,100%{opacity:0.2} 50%{opacity:0.95} }
@keyframes blink { 0%,50%{opacity:1} 50.01%,100%{opacity:0} }
