

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;600;800&display=swap');

:root{
  --bg0:#0e1224; --bg1:#11162a;
  --grad-a:#7a5cff; --grad-b:#4ed2ff; --accent:#ff74e1;
  --text:#eef0ff; --muted:#a5add6; --ring:rgba(255,255,255,.12);
  --glass:rgba(255,255,255,.06); --shadow:0 10px 30px rgba(0,0,0,.35);

  --loader-a: var(--grad-a);
  --loader-b: var(--accent);
  --loader-bar-bg: rgba(255,255,255,.12);
  --loader-bar-fill: #ffffff;
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0; font-family:Outfit,system-ui,Segoe UI,Arial,sans-serif; color:var(--text);
  background:
    radial-gradient(1200px 700px at 10% -10%, rgba(122,92,255,.25), transparent 70%),
    radial-gradient(1000px 600px at 90% 110%, rgba(78,210,255,.20), transparent 70%),
    var(--bg0);
  overflow-x:hidden;
  scroll-snap-type:y proximity;
}

/* starfield */
canvas.stars{position:fixed; inset:0; z-index:0; pointer-events:none; opacity:.25}

/* NAV */
.nav{
  position:sticky; top:0; z-index:20;
  backdrop-filter:saturate(140%) blur(10px);
  background:linear-gradient(180deg, rgba(17,22,42,.90), rgba(17,22,42,.60));
  border-bottom:1px solid var(--ring);
}
.nav-inner{
  max-width:1150px; margin:0 auto; padding:10px 16px;
  display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:14px;
}
.logo{justify-self:start; display:flex; gap:10px; align-items:center; text-decoration:none; color:var(--text); font-weight:800}
.cta{justify-self:end; padding:10px 16px; border-radius:12px; font-weight:800; text-decoration:none;
  background:linear-gradient(90deg, var(--grad-a), var(--grad-b)); color:#0a0a12;
  box-shadow:0 6px 18px rgba(122,92,255,.25), 0 6px 18px rgba(78,210,255,.2)}

 .logo { display:flex; align-items:center; text-decoration:none; }
.logo-img{
  height:70px;             /* adjust if you want it larger/smaller */
  width:auto;
  display:block;
  filter: drop-shadow(0 0 6px rgba(186,122,255,.7));
  transition: transform .2s ease, filter .2s ease;
}
.logo-img:hover{
  transform: scale(1.06);
  filter: drop-shadow(0 0 12px rgba(186,122,255,1));
}



.pill-nav{
  justify-self:center;
  display:flex; gap:8px; padding:6px; border-radius:999px;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)); border:1px solid var(--ring);
}
.pill{
  position:relative; padding:10px 14px; border-radius:999px; text-decoration:none; font-weight:700;
  color:var(--text); transition:color .25s ease, background .25s ease, box-shadow .25s ease;
}
.pill::after{
  content:""; position:absolute; inset:0; border-radius:999px; opacity:0; pointer-events:none;
  background:linear-gradient(90deg, var(--grad-a), var(--grad-b));
  box-shadow:0 0 0 1px rgba(255,255,255,.15) inset;
  transition:opacity .25s ease;
}
.pill:hover{ background:var(--glass) }
.pill:hover::after{ opacity:.35 }
.pill.active{ background:var(--glass); box-shadow:inset 0 0 0 2px var(--ring) }

/* SCENES */
main{position:relative; z-index:1}
.scene{
  min-height:100vh; display:grid; place-items:center; padding:80px 16px;
  scroll-snap-align:start;
}
.scene:nth-child(odd){
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.00));
}
.scene:nth-child(even){
  background:radial-gradient(1000px 500px at 80% 10%, rgba(122,92,255,.12), transparent 60%);
}
.container{max-width:1150px; margin:0 auto}

/* cards */
.card{
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid var(--ring); border-radius:18px; box-shadow:var(--shadow); padding:22px;
}

/* HERO */
.hero-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:22px; align-items:center}
@media (max-width:900px){ .hero-grid{grid-template-columns:1fr} }

.headline{font-size:clamp(32px,5vw,64px); margin:.2rem 0 .6rem}
.headline .accent{background:linear-gradient(90deg,var(--grad-a),var(--accent)); -webkit-background-clip:text; background-clip:text; color:transparent}
.muted{color:var(--muted)}
.badges{display:flex; flex-wrap:wrap; gap:8px; margin:16px 0 14px}
.badge{font-weight:700; font-size:.95rem; padding:10px 14px; border-radius:999px; background:rgba(255,255,255,.06); border:1px solid var(--ring)}
.cta-row{display:flex; gap:12px; flex-wrap:wrap; margin-top:12px}
.btn{padding:12px 16px; border-radius:12px; font-weight:800; border:1px solid var(--ring); background:var(--bg1); color:var(--text); cursor:pointer; text-decoration:none; display:inline-block}
.btn:hover{box-shadow:0 6px 16px rgba(0,0,0,.35)}
.btn.primary{background:linear-gradient(90deg, var(--grad-a), var(--grad-b)); color:#0a0a12; border:none}

/* right card + chart */
.hero-art{ display:flex; flex-direction:column; gap:10px; min-height:380px; }
.chart-head, .chart-foot { display:flex; align-items:center; gap:8px; }
.chart-head { margin-bottom:6px }
.chart-foot { margin-top:4px; justify-content:space-between }
.chip{
  padding:8px 10px; border-radius:999px; font-weight:800; font-size:.9rem;
  background:rgba(255,255,255,.06); border:1px solid var(--ring); color:var(--text);
}
.chip.live{ background:linear-gradient(90deg, var(--grad-a), var(--grad-b)); color:#0a0a12; border:none }
.chip.sym{ opacity:.9 }
.chip.tf{ cursor:pointer; background:rgba(255,255,255,.05) }
.chip.tf.active{ box-shadow:inset 0 0 0 2px var(--ring) }
.spacer{ flex:1 }

.chart-wrap{
  position:relative; width:100%; height:320px; overflow:hidden; border-radius:12px;
}
#memeChart{
  position:absolute; inset:0;
  width:100% !important; height:100% !important; display:block;
}

.price{ font-weight:800; font-size:1.05rem }
.delta{ font-weight:800; padding:6px 10px; border-radius:999px; border:1px solid var(--ring) }
.delta.up{ color:#6BFF9D; background:rgba(0,255,170,.08) }
.delta.down{ color:#ff7f7f; background:rgba(255,127,127,.10) }

/* overlaid GET $BARA (behind cards, clipped at section bottom) */
.hero-scene{ position:relative; overflow:hidden; }
.hero-grid .card{ position:relative; z-index:2; }
.hero-floater{
  position:absolute; right:clamp(12px,6vw,60px); bottom:-60px;
  width:min(420px, 48vw); max-height:120%; object-fit:contain; pointer-events:none;
  filter: drop-shadow(0 12px 28px rgba(0,0,0,.5));
  will-change: transform, opacity;
  transform:translateY(0); opacity:1; transition:transform .2s linear, opacity .2s linear;
  z-index:0;
}

/* ABOUT */
.section-title{font-size:clamp(22px,3.2vw,36px); margin:0 0 16px}
.about{display:grid; grid-template-columns:1fr 1fr; gap:18px}
@media (max-width:900px){ .about{grid-template-columns:1fr} }
.about .page{border-radius:16px; background:linear-gradient(180deg, #1a2142, #151a34); border:1px solid var(--ring); padding:20px}
.about h3{margin:.2rem 0 .4rem; color:#d6dbff}

/* ARCADE */
.carousel{display:flex; gap:14px; overflow-x:auto; padding:6px; scroll-snap-type:x mandatory}
.game{min-width:260px; scroll-snap-align:start; border-radius:14px; background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)); border:1px solid var(--ring); padding:14px}
.game .thumb{height:140px; border-radius:10px; background:linear-gradient(135deg, #212a53, #1a2042)}
.game h4{margin:.6rem 0 .2rem}
.play{margin-top:8px; padding:10px 14px; border:none; border-radius:10px; font-weight:800; color:#0a0a12; cursor:pointer;
  background:linear-gradient(90deg, var(--accent), var(--grad-b))}

/* HOW */
.steps{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
@media (max-width:900px){ .steps{grid-template-columns:1fr} }
.step{padding:16px; border-radius:14px; border:1px solid var(--ring); background:rgba(255,255,255,.04)}
.step b{color:#dfe3ff}

/* FAQ */
.faq .item{margin:10px 0; border-radius:12px; overflow:hidden; border:1px solid var(--ring); background:rgba(255,255,255,.04)}
.faq summary{list-style:none; cursor:pointer; padding:14px 16px; font-weight:800;
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02))}
.faq summary::-webkit-details-marker{display:none}
.faq .content{padding:14px 16px; color:var(--muted)}

/* SOCIALS */
.scene-tight{ min-height:70vh; }
.socials{ text-align:center }
.ring{
  position:relative; margin:20px auto; width:320px; height:320px; border-radius:50%;
  background:radial-gradient(circle at center, rgba(122,92,255,.14), transparent 60%);
}
.icon{
  --count:8;
  position:absolute; top:50%; left:50%;
  width:58px; height:58px; margin:-29px; border-radius:50%;
  display:grid; place-items:center; font-weight:800; color:#9ecbff; text-decoration:none;
  background:linear-gradient(180deg, #202646, #171d35); border:1px solid var(--ring); box-shadow:var(--shadow);
  transform:
    rotate(calc(var(--i) * (360deg / var(--count))))
    translate(120px)
    rotate(calc(var(--i) * (-360deg / var(--count))));
  transition:transform .2s ease, box-shadow .2s ease;
}
.icon:hover{ transform:
    rotate(calc(var(--i) * (360deg / var(--count))))
    translate(120px) translateY(-4px)
    rotate(calc(var(--i) * (-360deg / var(--count))));
}

/* footer */
footer{ text-align:center; color:var(--muted); padding:36px 0 60px }

/* reveal */
.reveal{opacity:0; transform:translateY(18px); transition:opacity .6s ease, transform .6s ease}
.reveal.show{opacity:1; transform:none}

.load-card{ text-align:center; padding:16px }
.load-gif{ width:min(220px, 42vw); height:auto; margin:0 auto 18px; display:block }

/* Bar frame */
.load-bar{
  --h: 12px;
  position: relative;
  width: min(640px, 86vw);
  height: var(--h);
  margin: 6px auto 10px;
  border-radius: 10px;
  background: rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
  overflow: hidden;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08), 0 10px 24px rgba(0,0,0,.35);
}

/* Neon gradient fill */
.load-fill{
  position:absolute; inset:0 auto 0 0;
  width: 0%;
  background: linear-gradient(90deg, #86b6ff 0%, #7a5cff 55%, #ff74e1 100%);
  filter: saturate(130%);
  transition: width .18s linear;
}

/* Pixel “steps” mask to make it feel retro */
.load-bar .load-mask{
  position:absolute; inset:0;
  -webkit-mask: repeating-linear-gradient(90deg, #000 0 18px, transparent 18px 20px);
  mask: repeating-linear-gradient(90deg, #000 0 18px, transparent 18px 20px);
  background: rgba(0,0,0,.0);
  pointer-events:none;
}

/* Texts */
.load-text{ font-weight:800; letter-spacing:.4px; opacity:.95; margin-top:2px }
.load-tip{ margin-top:4px; color:#a5add6; font-size:.95rem; min-height:1.4em; opacity:.85 }

/* Subtle sparks along the bar */
.load-bar::after{
  content:"";
  position:absolute; top:-6px; left:0; right:0; height:var(--h);
  background:
    radial-gradient(6px 6px at 0% 50%, rgba(255,255,255,.9), transparent 60%),
    radial-gradient(6px 6px at 25% 50%, rgba(255,255,255,.6), transparent 60%),
    radial-gradient(6px 6px at 50% 50%, rgba(255,255,255,.8), transparent 60%),
    radial-gradient(6px 6px at 75% 50%, rgba(255,255,255,.55), transparent 60%),
    radial-gradient(6px 6px at 100% 50%, rgba(255,255,255,.9), transparent 60%);
  mix-blend-mode: screen;
  animation: sparks 1.6s linear infinite;
  pointer-events:none;
}
@keyframes sparks{
  0%   { transform: translateX(-10%); opacity:.6 }
  100% { transform: translateX(110%); opacity:.6 }
}

/* Hide animation when done (we add .is-done via JS) */
.loader.is-done{
  animation: loaderFade .35s ease forwards;
}
@keyframes loaderFade{
  to { opacity:0; visibility:hidden; }
}


/* === HERO: make both cards even + keep chart filled === */
.hero-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 22px;
  align-items: stretch;                 /* ← equalize heights */
}

.hero-grid .card{
  min-height: 420px;                    /* target height for both */
  display: flex;
  flex-direction: column;
}

/* chart card pieces */
.hero-art .chart-head{ margin-bottom: 10px; display:flex; gap:8px; align-items:center; }
.hero-art .chart-wrap{
  position: relative;
  flex: 1;                              /* chart fills remaining space */
  min-height: 300px;
  border-radius: 14px;
  overflow: hidden;
}
.hero-art .chart-wrap canvas{
  position: absolute; inset: 0;
  width: 100% !important;
  height: 100% !important;              /* Chart.js stretches to card */
}
.hero-art .chart-foot{ margin-top: 10px; display:flex; justify-content:space-between; align-items:center; }

/* small “demo” pill */
.chart-note{
  position: absolute; left: 12px; bottom: 12px;
  padding: 6px 10px; border-radius: 10px;
  font-size: 12px; color: #cbd5ff;
  background: rgba(20,24,38,.72);
  border: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(6px);
  pointer-events: none;
}
.chart-note::before{ content:"ⓘ"; margin-right:6px; opacity:.85; }

/* keep GET $BARA behind the cards so it never overlaps the chart */
.hero-scene{ position: relative; overflow: hidden; }
.hero-floater{
  position: absolute; right: 24px; bottom: -56px;
  width: clamp(260px, 28vw, 420px);
  z-index: 0;           /* cards are above */
  pointer-events: none;
}
.hero-grid .card, .hero-art{ position: relative; z-index: 2; }

/* --- Arcade cards: image header + ribbon --- */
.arcade-row{
  display:grid;
  grid-template-columns:repeat(3,minmax(260px,1fr));
  gap:22px;
}

.game-card{
  position:relative;
  background:rgba(8,12,24,.72);
  border:1px solid rgba(255,255,255,.06);
  border-radius:16px;
  padding:14px;
  box-shadow:0 6px 28px rgba(0,0,0,.35);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.game-card:hover{
  transform:translateY(-3px);
  box-shadow:0 10px 36px rgba(0,0,0,.45);
  border-color:rgba(120,140,255,.18);
}

.game-card .thumb{
  position:relative;
  height:200px;               /* header image height (like your screenshot) */
  border-radius:12px;
  overflow:hidden;
  background:radial-gradient(120% 120% at 20% 10%,
              rgba(120,140,255,.10), rgba(20,28,52,.6));
  border:1px solid rgba(255,255,255,.06);
  margin-bottom:10px;
}
.game-card .thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform:scale(1.02);
  transition:transform .35s ease, filter .35s ease;
}
.game-card:hover .thumb img{ transform:scale(1.06); }

/* Coming-soon diagonal ribbon (not clipped) */
.game-card .ribbon{
  position:absolute;
  top:12px;
  right:-56px;            /* push outside so it doesn’t get cut */
  transform:rotate(30deg);
  padding:6px 72px;
  border-radius:10px;
  font:700 12px/1 Outfit,system-ui,sans-serif;
  letter-spacing:.06em;
  color:#0b1120;
  background:linear-gradient(90deg,#7aa7ff,#86e1ff);
  box-shadow:0 6px 16px rgba(0,0,0,.35);
  pointer-events:none;
  z-index:5;
}

/* Titles / actions */
.game-head{ padding:12px 4px 0; }
.game-title{ font-weight:700; letter-spacing:.2px; }
.game-title .emoji{ margin-left:.25rem; opacity:.9; }
.game-actions{ padding:10px 4px 4px; }

/* Coming soon variant dims header subtly */
.game-card.soon .thumb{
  background:
    repeating-linear-gradient(45deg, rgba(255,255,255,.05) 0 12px, transparent 12px 24px),
    linear-gradient(180deg, rgba(20,24,40,.6), rgba(12,16,28,.6));
}

/* Responsive stacking */
@media (max-width:1100px){ .arcade-row{ grid-template-columns:repeat(2,minmax(260px,1fr)); } }
@media (max-width:640px){  .arcade-row{ grid-template-columns:1fr; } }

/* Center medallion */
.ring { position: relative; }

.ring-center {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 120px; height: 120px;
  border-radius: 50%;
  display: flex;                /* was grid */
  flex-direction: column;
  align-items: center;
  justify-content: center;      /* ensures vertical centering */
  gap: 2px;                     /* reduce space between items */
  background:
    radial-gradient(60% 60% at 50% 45%, rgba(122,92,255,.22), transparent 70%),
    radial-gradient(100% 100% at 50% 50%, rgba(78,210,255,.14), rgba(10,14,26,.75));
  border: 1px solid var(--ring);
  box-shadow: 0 12px 28px rgba(0,0,0,.35), inset 0 0 40px rgba(122,92,255,.12);
}

.ring-center .brand {
  font-weight: 900; letter-spacing: .6px;
  background: linear-gradient(90deg, var(--grad-a), var(--accent));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  font-size: 18px;
}

.ring-center .tag {
  font-size: 11px; font-weight: 700; color: #cfe0ff; opacity: .9;
  padding: 2px 6px;               /* tighter padding */
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--ring);
}

/* Make index 0 land at the TOP of the ring */
.ring { --offset: -90deg; } /* rotate the whole orbit so 0 = top */

.icon{
  --count:8;
  position:absolute; top:50%; left:50%;
  width:58px; height:58px; margin:-29px; border-radius:50%;
  display:grid; place-items:center; font-weight:800; color:#9ecbff; text-decoration:none;
  background:linear-gradient(180deg, #202646, #171d35); border:1px solid var(--ring);
  box-shadow:var(--shadow);
  transform:
    rotate(calc(var(--offset) + var(--i) * (360deg / var(--count))))
    translate(120px)
    rotate(calc(-1 * (var(--offset) + var(--i) * (360deg / var(--count)))));
  transition:transform .2s ease, box-shadow .2s ease;
}
.icon:hover{
  transform:
    rotate(calc(var(--offset) + var(--i) * (360deg / var(--count))))
    translate(120px) translateY(-4px)
    rotate(calc(-1 * (var(--offset) + var(--i) * (360deg / var(--count)))));
}


/* A tiny, tasteful motion */
@keyframes orb-breathe{
  0%,100%{ transform:
    rotate(calc(var(--i) * (360deg / var(--count))))
    translate(120px)
    rotate(calc(var(--i) * (-360deg / var(--count))));
    filter:brightness(1);
    box-shadow: 0 8px 18px rgba(0,0,0,.35), inset 0 0 16px rgba(122,92,255,.18);
  }
  50%{
    transform:
      rotate(calc(var(--i) * (360deg / var(--count))))
      translate(120px) translateY(-2px)
      rotate(calc(var(--i) * (-360deg / var(--count))));
    filter:brightness(1.08);
    box-shadow: 0 10px 24px rgba(0,0,0,.38), inset 0 0 26px rgba(122,92,255,.26);
  }
}

canvas.stars{
  position:fixed;
  inset:0;
  z-index:0;            /* behind site content */
  pointer-events:none;
  opacity:.28;          /* tweak brightness */
}
main, .scene, .nav, footer { position:relative; z-index:1; } /* content above stars */

/* Loader: fully opaque, sits above everything */
canvas.stars { z-index: 0; }

/* ================== LOADER (single source of truth) ================== */
.loader{
  position:fixed; inset:0; z-index:99999; display:grid; place-items:center;
  background:
    radial-gradient(1100px 600px at 20% -10%, #1a1f3a 0%, #0b1021 55%),
    radial-gradient(1000px 650px at 80% 110%, rgba(78,210,255,.18), transparent 70%),
    linear-gradient(160deg, #0f1428 0%, #0b1021 100%);
  color:#fff;
}

.load-card{ text-align:center; padding:20px }

.load-gif{
  width:min(220px, 42vw); height:auto; display:block; margin:0 auto 16px;
  filter: drop-shadow(0 10px 22px rgba(0,0,0,.35));
}

/* Gradient frame around the bar */
.load-frame{
  padding:14px;
  border-radius:16px;
  background: linear-gradient(135deg, #7a5cff44, #4ed2ff44, #ff74e144);
  box-shadow: 0 12px 32px rgba(0,0,0,.45);
  margin: 0 auto 14px;
  max-width: min(680px, 90vw);
}

/* Bar */
.load-bar{
  --h: 14px;
  position: relative;
  width: 100%;
  height: var(--h);
  border-radius: 10px;
  background: rgba(12,18,32,.85);
  border:1px solid rgba(255,255,255,.18);
  overflow: hidden;
}

/* Neon gradient fill */
.load-fill{
  position:absolute; inset:0 auto 0 0;
  width: 0%;                          /* JS grows this 0 → 100 */
  background: linear-gradient(90deg, #86b6ff 0%, #7a5cff 55%, #ff74e1 100%);
  background-size: 200% 100%;
  transition: width .18s linear;
  animation: barflow 1.2s linear infinite;
}

/* Pixel steps mask (retro vibe) */
.load-mask{
  position:absolute; inset:0;
  -webkit-mask: repeating-linear-gradient(90deg, #000 0 18px, transparent 18px 20px);
  mask: repeating-linear-gradient(90deg, #000 0 18px, transparent 18px 20px);
  background: rgba(255,255,255,.12);
  pointer-events:none;
}

/* Texts */
.load-text{ font-weight:800; letter-spacing:.4px; opacity:.95; margin-top:6px }
.load-tip{ margin-top:6px; color:#a5add6; font-size:.95rem; min-height:1.4em; opacity:.85 }

/* Spark sweep */
.load-bar::after{
  content:"";
  position:absolute; top:-6px; left:0; right:0; height:var(--h);
  background:
    radial-gradient(6px 6px at 0% 50%, rgba(255,255,255,.9), transparent 60%),
    radial-gradient(6px 6px at 25% 50%, rgba(255,255,255,.6), transparent 60%),
    radial-gradient(6px 6px at 50% 50%, rgba(255,255,255,.8), transparent 60%),
    radial-gradient(6px 6px at 75% 50%, rgba(255,255,255,.55), transparent 60%),
    radial-gradient(6px 6px at 100% 50%, rgba(255,255,255,.9), transparent 60%);
  mix-blend-mode: screen;
  animation: sparks 1.6s linear infinite;
  pointer-events:none;
}

/* Fade out when JS adds .is-done OR .hidden */
.loader.is-done,
.loader.hidden{
  animation: loaderFade .35s ease forwards;
}

/* keyframes */
@keyframes sparks{
  0%   { transform: translateX(-10%); opacity:.6 }
  100% { transform: translateX(110%); opacity:.6 }
}
@keyframes barflow{
  0%{ background-position:0% 0 }
  100%{ background-position:200% 0 }
}
@keyframes loaderFade{
  to { opacity:0; visibility:hidden; }
}


/* keyframes */
@keyframes loader-spin { to { transform: rotate(360deg); } }
@keyframes dot-spin     { to { transform: rotate(360deg) translateY(-140px) rotate(-360deg); } }
@keyframes floaty       { 0%,100%{ transform: translateY(-2px); } 50%{ transform: translateY(2px); } }
@keyframes sparkle-run  { 0%{ left: -30px; } 100%{ left: calc(100% - 10px); } }
@keyframes barflow      { 0%{ background-position:0% 0 } 100%{ background-position:200% 0 } }
@keyframes breathe      { 0%,100% { transform: translateY(0) scale(1); } 50% { transform: translateY(-2px) scale(1.02); } }
