/* ============================================================
   Jaro Spark — Landing Page Styles
   ============================================================ */

:root{
  --void:#0a0322;
  --night:#1a0a4a;
  --deep:#2a0e5e;
  --plum:#3b1480;
  --grape:#5b2bb8;
  --magic:#7c4dff;
  --lilac:#a78bfa;
  --frost:#e9defc;
  --cream:#fbf7ff;
  --spark:#8de1ff;
  --fairy:#ff7ad1;
  --gold:#ffd86b;
  --mint:#7cf3c0;
  --green:#39d96e;
  --display:'Fredoka',ui-rounded,system-ui,sans-serif;
  --body:'Outfit',ui-sans-serif,system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-font-smoothing:antialiased}
html{scroll-behavior:smooth}
html,body{background:#0a0322;color:#f3ebff;font-family:var(--body);overflow-x:hidden}
body{min-height:100vh}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}

/* ============ NAV ============ */
nav.top{
  position:sticky;top:0;z-index:100;
  background:linear-gradient(180deg, rgba(10,3,34,.95), rgba(10,3,34,.7) 80%, transparent);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(167,139,250,.18);
}
.top {
  /* display: flex;
  justify-content:flex-start;
  align-items: center; */
  padding: 16px 24px;
}

.nav-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

.brand-logo {
  width: 40px;
  height: 40px;
}

.brand-name {
  font-size: 1.2rem;
  font-weight: 600;
}
.nav-row{
  /* display:contents;align-items:center; */
  /* gap:12px; */
  max-width:1280px;margin:0 auto;padding:12px 22px;
}
.brand-logo{
  width:42px;height:42px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #ffffff, #d8ecff 28%, #b29dff 60%, #4a1ea1 100%);
  box-shadow:0 0 18px rgba(167,139,250,.65);
  object-fit:cover;
  animation:bob 4s ease-in-out infinite;
  flex:0 0 auto;
}
.nav-links {
  display: flex;
  list-style: none;
  gap: 24px;
  margin-top: -3%;
  padding: 0px 0p 0px 0px;
  flex-direction: row;
  align-content: space-around;
  justify-content: flex-end;
}

.nav-links a {
  text-decoration: none;
  color: #333;
  font-weight: 500;
}

.nav-links a {
  text-decoration: none;
  color: #fafafa;
  padding: 10px 16px;
  border-radius: 999px;
  transition: all 0.25s ease;
}

.nav-links a:hover {
  background: #f3f4f6;
  color: #111;
}

.nav-links a.active {
  background: #e3080d;
  color: white;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}

.hamburger {
  display: none;
  font-size: 30px;
  color: #fafafa;
  background: transparent;
  border: none;
  cursor: pointer;
  z-index: 999;
}

@media (max-width: 768px) {

  .hamburger {
    display: block;
    font-size: 30px;
    color: #fff;
    background: transparent;
    border: none;
    cursor: pointer;
  }

  .brand-name,
  .brand-logo {
    display: none;
  }

  .nav-row {
    display: flex;
    justify-content: flex-end;
    align-items: center;
  }

  /* Mobile menu */
  .nav-links {
    display: none;
    position: absolute;
    top: 100%;
    right: 15px;

    flex-direction: column;
    gap: 10px;

    width: 220px;
    margin: 0;
    padding: 15px;

    list-style: none;

    background: rgba(10, 3, 34, 0.98);
    border-radius: 12px;
    box-shadow: 0 10px 25px rgba(0,0,0,.3);

    z-index: 999;
  }

  .nav-links.active {
    display: flex;
  }

  .nav-links li {
    width: 100%;
  }

  .nav-links a {
    display: block;
    width: 100%;
    padding: 12px;
    color: #fff;
    text-align: left;
    border-radius: 8px;
  }

  .nav-links a:hover {
    background: rgba(255,255,255,.1);
    color: #fff;
  }
}

@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
.brand-name{
  font-family:var(--display);font-weight:600;font-size:22px;letter-spacing:.5px;
  background:linear-gradient(180deg,#fff,#cfb6ff);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ============ HERO ============ */
.hero{
  position:relative;
  min-height:100vh;
  background:linear-gradient(180deg, #0a0322 0%, #1a0a4a 25%, #2a0e5e 55%, #3b1480 100%);
  overflow:hidden;
  padding:30px 0 0;
}

/* Background image (your night scene) — sits BEHIND all animations */
.hero-bg{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;
  z-index:0;
  filter:saturate(1.1) brightness(1.02);
  animation:bgPulse 16s ease-in-out infinite alternate;
  will-change:transform;
}
@keyframes bgPulse{
  0%{transform:scale(1.02)}
  100%{transform:scale(1.08)}
}

/* Soft vignette over bg so animations pop */
.hero::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(80% 60% at 50% 30%, transparent 35%, rgba(10,3,34,.4) 100%),
    linear-gradient(180deg, rgba(10,3,34,.2) 0%, transparent 25%, transparent 75%, rgba(10,3,34,.55) 100%);
}

/* twinkling stars — z-index 2 puts them ABOVE the hero-bg image */
.starfield{position:absolute;inset:0;pointer-events:none;overflow:hidden;z-index:2;mix-blend-mode:screen}
.stars,.stars2,.stars3{position:absolute;inset:-20%;background-repeat:repeat;will-change:transform}
.stars{background-image:
  radial-gradient(1.2px 1.2px at 30px 40px,#fff,transparent),
  radial-gradient(1px 1px at 110px 130px,#dcc8ff,transparent),
  radial-gradient(1.8px 1.8px at 200px 80px,#fff,transparent),
  radial-gradient(1px 1px at 280px 200px,#fff,transparent),
  radial-gradient(2.2px 2.2px at 360px 110px,#b9c8ff,transparent),
  radial-gradient(1px 1px at 440px 60px,#fff,transparent);
  background-size:500px 300px;
  animation:twinkle 4s ease-in-out infinite alternate, drift 200s linear infinite;
  opacity:1}
.stars2{background-image:
  radial-gradient(2px 2px at 60px 90px,#fff,transparent),
  radial-gradient(1.5px 1.5px at 220px 220px,#ffe3a8,transparent),
  radial-gradient(1px 1px at 380px 50px,#fff,transparent),
  radial-gradient(2.5px 2.5px at 480px 180px,#fff,transparent);
  background-size:540px 320px;
  animation:twinkle2 6s ease-in-out infinite alternate, drift 320s linear infinite reverse;
  opacity:.7}
.stars3{background-image:
  radial-gradient(1px 1px at 80px 30px,rgba(255,255,255,.6),transparent),
  radial-gradient(1.5px 1.5px at 180px 110px,#fff,transparent),
  radial-gradient(1px 1px at 300px 220px,#fff,transparent);
  background-size:400px 260px;
  animation:twinkle 3s ease-in-out infinite alternate;
  opacity:.55}
@keyframes twinkle{from{opacity:.3}to{opacity:.95}}
@keyframes twinkle2{from{opacity:.5}to{opacity:.2}}
@keyframes drift{from{transform:translateY(0)}to{transform:translateY(-300px)}}

/* shooting stars (above hero bg image) */
.shooting{
  position:absolute;width:4px;height:4px;background:#fff;border-radius:50%;
  box-shadow:0 0 8px #fff, 0 0 24px rgba(141,225,255,.9), 0 0 40px rgba(141,225,255,.5);
  opacity:0;
  animation:shoot 7s ease-in infinite;
}
.shooting::before{
  content:"";position:absolute;left:-140px;top:1.5px;width:140px;height:2px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,.95));
  filter:blur(.5px);
}
.shooting.s1{top:12%;left:-5%;animation-delay:2s}
.shooting.s2{top:24%;left:-5%;animation-delay:5s;animation-duration:9s}
.shooting.s3{top:34%;left:-5%;animation-delay:8s;animation-duration:8s}
@keyframes shoot{
  0%{transform:translateX(0) translateY(0);opacity:0}
  6%{opacity:1}
  35%{transform:translateX(70vw) translateY(22vw);opacity:0}
  100%{opacity:0}
}

/* ============ HERO CONTENT ============ */
.hero-content{
  position:relative;z-index:3;text-align:center;
  max-width:1100px;margin:0 auto;padding:40px 20px 60px;
}

/* Jaro Spark title logo (IMAGE) */
.title-logo{
  display:block;
  width:min(620px, 86vw);
  max-width:100%;
  height:auto;
  margin:30px auto 0;
  filter:drop-shadow(0 8px 30px rgba(124,77,255,.55)) drop-shadow(0 0 22px rgba(167,139,250,.45));
  animation:logoFloat 4s ease-in-out infinite;
  position:relative;z-index:2;
}
@keyframes logoFloat{
  0%,100%{transform:translateY(0) rotate(-.4deg)}
  50%{transform:translateY(-8px) rotate(.4deg)}
}

/* Aura glow behind logo */
.logo-aura{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:560px;height:240px;
  background:radial-gradient(50% 50% at 50% 50%, rgba(167,139,250,.55), transparent 70%);
  filter:blur(40px);
  z-index:1;pointer-events:none;
  animation:auraPulse 4s ease-in-out infinite alternate;
}
@keyframes auraPulse{
  0%{opacity:.5;transform:translate(-50%,-50%) scale(.95)}
  100%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}
}

.tagline{
  font-family:var(--display);font-weight:500;
  font-size:clamp(20px,3vw,32px);
  color:#fff;margin-top:18px;letter-spacing:.2px;
  text-shadow:0 2px 12px rgba(10,3,34,.6);
}
.tagline-accent{
  font-family:var(--display);font-weight:600;
  font-size:clamp(18px,2.6vw,28px);
  margin-top:6px;
  background:linear-gradient(120deg,#39d96e,#7cf3c0,#39d96e);
  background-size:200% 100%;
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 0 18px rgba(57,217,110,.5));
  animation:gradientShift 6s linear infinite;
}
@keyframes gradientShift{0%{background-position:0% 0}100%{background-position:200% 0}}

/* battle / hero illustration */
.battle-wrap{
  display:block;margin:40px auto 0;max-width:620px;
  perspective:1000px;
  transform-style:preserve-3d;
}
.battle-slot{
  display:block;width:100%;height:auto;
  aspect-ratio:16/9;object-fit:cover;
  border-radius:28px;
  background:linear-gradient(135deg, rgba(124,77,255,.18), rgba(255,122,209,.12));
  box-shadow:
    0 30px 70px rgba(10,3,34,.6),
    0 0 60px rgba(124,77,255,.3),
    inset 0 1px 0 rgba(255,255,255,.18);
  transition:transform .25s cubic-bezier(.2,.7,.3,1.1);
  will-change:transform;
}

.caption{
  margin-top:54px;font-family:var(--display);font-weight:500;
  font-size:clamp(20px,2.8vw,28px);line-height:1.45;
  color:#fff;
  max-width:720px;margin-left:auto;margin-right:auto;padding:0 20px;
  text-shadow:0 2px 12px rgba(10,3,34,.7);
}

/* scroll hint */
.scroll-hint{
  margin:50px auto 0;
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:#dcc8ff;opacity:.8;
}
.scroll-hint .arrow{
  width:18px;height:18px;margin:10px auto 0;
  border-right:2px solid #dcc8ff;border-bottom:2px solid #dcc8ff;
  transform:rotate(45deg);
  animation:bounceDown 1.8s ease-in-out infinite;
}
@keyframes bounceDown{
  0%,100%{transform:rotate(45deg) translate(0,0);opacity:.4}
  50%{transform:rotate(45deg) translate(4px,4px);opacity:1}
}

/* ============ CLOUD DIVIDERS ============ */
.cloud-divider{position:relative;width:100%;line-height:0;display:block;z-index:4}
.cloud-divider svg{width:100%;height:auto;display:block}
.cloud-divider.flip{transform:rotate(180deg)}

/* ============ WHITE SECTION ============ */
.white-section{
  background:linear-gradient(180deg, #fbf7ff 0%, #f3ecff 100%);
  color:#2a0e5e;
  padding:0 0 20px;
  position:relative;
}
.peek-bear{
  display:block;width:190px;height:auto;margin:-80px auto 18px;
  position:relative;z-index:5;
  filter:drop-shadow(0 10px 22px rgba(124,77,255,.5));
  animation:peek 4s ease-in-out infinite;
}
@keyframes peek{
  0%,100%{transform:translateY(0) rotate(-2deg)}
  50%{transform:translateY(-6px) rotate(2deg)}
}

.download-now{text-align:center;padding:18px 20px 4px;position:relative}
.download-now h2{
  font-family:var(--display);font-weight:700;
  font-size:clamp(48px,9vw,108px);
  letter-spacing:.5px;line-height:1;
  background:linear-gradient(180deg, #a78bfa 0%, #7c4dff 40%, #5b2bb8 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 4px 0 #c9b6ff) drop-shadow(0 10px 18px rgba(124,77,255,.4));
  -webkit-text-stroke:1.5px rgba(91,43,184,.18);
  position:relative;display:inline-block;
}
/* Shimmer sweep on hover */
.download-now h2::after{
  content:attr(data-text);
  position:absolute;inset:0;
  background:linear-gradient(110deg, transparent 35%, rgba(255,255,255,.9) 50%, transparent 65%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  background-size:200% 100%;
  animation:shimmerSweep 4s ease-in-out infinite;
  pointer-events:none;
}
@keyframes shimmerSweep{
  0%,30%{background-position:200% 0}
  60%,100%{background-position:-200% 0}
}

.stores{
  display:flex;flex-wrap:wrap;justify-content:center;gap:14px;
  padding:30px 20px 8px;
}
.store{
  display:inline-flex;align-items:center;gap:12px;
  padding:13px 22px;border-radius:14px;
  background:#0a0322;color:#fff;font-family:var(--body);
  min-width:200px;position:relative;overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease;
  box-shadow:0 6px 16px rgba(10,3,34,.25), 0 0 0 1px #a78bfa26
}
.store::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(110deg, transparent 30%, rgba(255,255,255,.18) 50%, transparent 70%);
  transform:translateX(-100%);
  transition:transform .6s ease;
}
.store:hover{transform:translateY(-4px) scale(1.03);box-shadow:0 16px 36px rgba(124,77,255,.45)}
.store:hover::before{transform:translateX(100%)}
.store .ico{width:30px;height:30px;flex:0 0 auto;position:relative;z-index:1}
.store .lbl{text-align:left;line-height:1.1;position:relative;z-index:1}
.store .top-l{font-size:10px;letter-spacing:.16em;text-transform:uppercase;opacity:.85}
.store .bot-l{font-family:var(--display);font-weight:600;font-size:17px;letter-spacing:.3px;margin-top:1px}
.store.huawei{background:#c8102e}

/* ============ FEATURES ============ */
.features-section{
  background:
    radial-gradient(700px 400px at 50% 0%, rgba(124,77,255,.4), transparent 60%),
    linear-gradient(180deg, #3b1480 0%, #2a0e5e 50%, #1a0a4a 100%);
  padding:30px 0 80px;
  position:relative;overflow:hidden;
}
.features-section::before{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(1px 1px at 60px 80px,#fff,transparent),
    radial-gradient(1.5px 1.5px at 220px 180px,#dcc8ff,transparent),
    radial-gradient(1px 1px at 400px 100px,#fff,transparent);
  background-size:480px 280px;
  opacity:.3;animation:twinkle 5s ease-in-out infinite alternate;
}
.features-inner{
  max-width:1180px;margin:0 auto;padding:30px 20px;
  text-align:center;position:relative;z-index:2;
}
.features-section h2{
  font-family:var(--display);font-weight:600;
  font-size:clamp(28px,4.5vw,44px);
  background:linear-gradient(180deg,#fff,#dcc8ff);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  margin-bottom:36px;letter-spacing:.3px;
}

.feat-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  max-width:1100px;margin:0 auto;
}
@media (max-width:900px){.feat-grid{grid-template-columns:repeat(2,1fr);gap:14px}}

.feat{
  position:relative;padding:18px 14px 16px;
  border-radius:22px;
  background:linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,.04));
  border:1.5px solid rgba(167,139,250,.4);
  backdrop-filter:blur(10px);
  box-shadow:0 12px 28px rgba(10,3,34,.4), inset 0 1px 0 rgba(255,255,255,.25);
  overflow:hidden;
  transition:transform .35s cubic-bezier(.2,.7,.3,1.2), box-shadow .35s;
}
.feat::after{
  content:"";position:absolute;inset:-2px;border-radius:24px;padding:2px;
  background:linear-gradient(135deg, rgba(255,255,255,.4), transparent 40%, transparent 60%, rgba(167,139,250,.5));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .3s;pointer-events:none;
}
.feat:hover{transform:translateY(-10px) rotate(-1deg);box-shadow:0 28px 60px rgba(124,77,255,.55)}
.feat:hover::after{opacity:1}
.feat .badge{
  width:62px;height:70px;margin:0 auto 4px;
  filter:drop-shadow(0 6px 14px rgba(0,0,0,.5));
  position:relative;
  animation:floaty 3.6s ease-in-out infinite;
}
.feat:nth-child(2) .badge{animation-delay:.3s}
.feat:nth-child(3) .badge{animation-delay:.6s}
.feat:nth-child(4) .badge{animation-delay:.9s}
@keyframes floaty{
  0%,100%{transform:translateY(0) rotate(0)}
  50%{transform:translateY(-6px) rotate(3deg)}
}

.feat h3{
  font-family:var(--display);font-weight:700;
  font-size:15.5px;letter-spacing:.6px;text-transform:uppercase;
  margin:6px 0 12px;
  text-shadow:0 2px 0 rgba(0,0,0,.3);
}
.feat.b1 h3{color:#c9b6ff}
.feat.b2 h3{color:#7cf3c0}
.feat.b3 h3{color:#8de1ff}
.feat.b4 h3{color:#ffd86b}

.feat-slot{
  display:block;width:100%;height:100%;border-radius:14px;
  object-fit:cover;
  background:linear-gradient(180deg, rgba(167,139,250,.22), rgba(45,17,102,.7));
  box-shadow:0 8px 18px rgba(10,3,34,.4);
  transition:transform .4s ease;
}
.feat:hover .feat-slot{transform:scale(1.04)}

/* Image-only feature card (b2) — image fills the WHOLE card edge-to-edge */
.feat.image-only{
  padding:0;overflow:hidden;
  display:block;
  border:none;
  background: white;
  height: 168%;
}
.feat.image-only .feat-slot{
  display:block;
  width:100%;height:100%;
  min-height:100%;
  border-radius:22px;
  box-shadow:none;
  background:transparent;
  object-fit:none;
}

/* ============ CHARACTERS ============ */
.chars-section{
  background:linear-gradient(180deg, #1a0a4a 0%, #0a0322 100%);
  padding:60px 0 100px;
  position:relative;overflow:hidden;
}
.chars-section::before{
  content:"";position:absolute;inset:0;
  background-image:
    radial-gradient(1px 1px at 80px 40px,rgba(255,255,255,.5),transparent),
    radial-gradient(1.5px 1.5px at 280px 220px,#fff,transparent),
    radial-gradient(1px 1px at 500px 80px,#dcc8ff,transparent);
  background-size:600px 320px;
  opacity:.4;animation:twinkle 6s ease-in-out infinite alternate;
}
.chars-grid{
  max-width:1100px;margin:0 auto;padding:0 20px;
  display:grid;grid-template-columns:repeat(2,1fr);gap:30px;
  position:relative;z-index:2;
}
@media (max-width:780px){.chars-grid{grid-template-columns:1fr;gap:24px}}

.char-card{
  position:relative;border-radius:28px;overflow:hidden;
  aspect-ratio:5/9;
  border:2px solid;
  box-shadow:0 30px 60px rgba(10,3,34,.55), inset 0 0 0 1px rgba(255,255,255,.08);
  transition:transform .4s cubic-bezier(.2,.7,.3,1.2), box-shadow .4s;
  transform-style:preserve-3d;
  will-change:transform;
}
.char-card.mirra{
  border-color:#ff7ad1;
  background:
    radial-gradient(70% 60% at 50% 30%, rgba(255,122,209,.4), transparent 70%),
    linear-gradient(180deg, #5b2bb8 0%, #3a1480 60%, #1a0a4a 100%);
  box-shadow:0 30px 60px rgba(10,3,34,.55), 0 0 50px rgba(255,122,209,.3);
}
.char-card.gluttok{
  border-color:#a78bfa;
  background:
    radial-gradient(70% 60% at 50% 30%, rgba(167,139,250,.4), transparent 70%),
    linear-gradient(180deg, #3a1066 0%, #2a0e5e 60%, #0a0322 100%);
  box-shadow:0 30px 60px rgba(10,3,34,.55), 0 0 50px rgba(167,139,250,.3);
}
.char-name{
  position:absolute;left:0;right:0;top:7%;
  text-align:center;
  font-family:var(--display);font-weight:700;
  font-size:clamp(48px,9vw,86px);
  letter-spacing:2px;line-height:.9;z-index:3;
}
.char-card.mirra .char-name{
  background:linear-gradient(180deg,#ffd1ec,#ff7ad1 50%,#c0379a);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 4px 0 rgba(91,43,184,.55)) drop-shadow(0 8px 16px rgba(255,122,209,.5));
  -webkit-text-stroke:1.5px rgba(255,255,255,.15);
}
.char-card.gluttok .char-name{
  background:linear-gradient(180deg,#e9defc,#a78bfa 50%,#5b2bb8);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 4px 0 rgba(10,3,34,.7)) drop-shadow(0 8px 16px rgba(167,139,250,.5));
  -webkit-text-stroke:1.5px rgba(255,255,255,.1);
}
.char-subtitle{
  position:absolute;left:0;right:0;top:19%;text-align:center;z-index:3;
  font-family:var(--display);font-weight:500;font-size:15px;letter-spacing:.5px;
  color:#fff;text-shadow:0 2px 6px rgba(0,0,0,.6);
}
.char-card.mirra .char-subtitle::before,
.char-card.mirra .char-subtitle::after{content:" ✦ ";color:var(--gold)}
.char-card.gluttok .char-subtitle::before,
.char-card.gluttok .char-subtitle::after{content:" ⚡ ";color:var(--gold)}

.char-portrait{
  position:absolute;left:8%;right:8%;top:27%;bottom:18%;
  border-radius:18px;display:block;
  object-fit:cover;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01));
  z-index:2;
}

/* Image-only character card — image fills the WHOLE card edge-to-edge */
.char-card.image-only{
  padding:0;
  overflow:hidden;
}
.char-card.image-only .char-portrait{
  position:absolute;
  inset:0;
  left:0;right:0;top:0;bottom:0;
  width:100%;height:100%;
  border-radius:inherit;
  background:transparent;
  object-fit:cover;
  z-index:1;
}
.char-aura{
  position:absolute;inset:30% 18% 40% 18%;border-radius:50%;
  border:2px solid;
  animation:rotate 12s linear infinite;
  pointer-events:none;z-index:1;
}
.char-card.mirra .char-aura{
  border-color:rgba(255,122,209,.45);
  box-shadow:0 0 30px rgba(255,122,209,.4) inset, 0 0 30px rgba(255,122,209,.4);
}
.char-card.gluttok .char-aura{
  border-color:rgba(167,139,250,.5);
  box-shadow:0 0 30px rgba(167,139,250,.4) inset, 0 0 30px rgba(167,139,250,.4);
}
@keyframes rotate{to{transform:rotate(360deg)}}

.power-ribbon{
  position:absolute;left:6%;right:6%;bottom:5%;
  padding:12px 14px;border-radius:14px;text-align:center;z-index:3;
  background:linear-gradient(180deg, rgba(10,3,34,.85), rgba(10,3,34,.65));
  border:1.5px solid;
  backdrop-filter:blur(6px);
}
.char-card.mirra .power-ribbon{border-color:rgba(255,122,209,.55);box-shadow:0 6px 22px rgba(255,122,209,.3)}
.char-card.gluttok .power-ribbon{border-color:rgba(167,139,250,.55);box-shadow:0 6px 22px rgba(167,139,250,.3)}
.power-label{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:#dcc8ff;font-weight:600}
.power-value{font-family:var(--display);font-weight:600;font-size:17px;color:#fff;margin-top:3px}
.char-card.mirra .power-value{background:linear-gradient(120deg,#ff7ad1,#ffd86b);-webkit-background-clip:text;background-clip:text;color:transparent}
.char-card.gluttok .power-value{background:linear-gradient(120deg,#a78bfa,#8de1ff);-webkit-background-clip:text;background-clip:text;color:transparent}

/* sleeping bear */
.sleeping{
  margin:50px auto 0;width:230px;text-align:center;
}
.sleeping .cloud-bed{
  width:100%;height:54px;
  background:radial-gradient(60% 100% at 50% 100%, #fbf7ff, transparent 70%);
  border-radius:50%;filter:blur(2px);margin-top:-28px;
}
.sleeping-slot{
  display:block;width:190px;height:auto;margin:0 auto;
  filter:drop-shadow(0 8px 18px rgba(10,3,34,.55));
  animation:snore 4s ease-in-out infinite;
}
@keyframes snore{
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.04)}
}
.zzz{
  display:inline-block;color:#dcc8ff;
  font-family:var(--display);font-weight:600;font-size:22px;
  animation:zzz 3s ease-in-out infinite;
  margin-left:10px;opacity:0;letter-spacing:2px;
}
@keyframes zzz{
  0%,100%{opacity:0;transform:translateY(6px)}
  50%{opacity:1;transform:translateY(-4px)}
}

/* ============ FOOTER ============ */
footer{
  padding:30px 20px;text-align:center;
  background:#0a0322;border-top:1px solid rgba(167,139,250,.18);
}
footer .copy{font-size:12px;color:#9d8ec9;letter-spacing:.06em}

/* ============ SPARKS OVERLAY ============ */
.sparks{position:fixed;inset:0;pointer-events:none;z-index:50}
.spk{
  position:absolute;width:5px;height:5px;border-radius:50%;background:#fff;
  box-shadow:0 0 10px 2px rgba(255,255,255,.9), 0 0 20px 5px rgba(141,225,255,.65);
  animation:rise 14s linear infinite;opacity:0;
}
.spk.gold{box-shadow:0 0 10px 2px rgba(255,216,107,.9), 0 0 22px 6px rgba(255,216,107,.45);background:#fff7d6}
.spk.pink{box-shadow:0 0 10px 2px rgba(255,122,209,.9), 0 0 22px 6px rgba(255,122,209,.45);background:#ffe2f3}
@keyframes rise{
  0%{transform:translateY(20vh) translateX(0) scale(.5);opacity:0}
  10%{opacity:1}
  50%{transform:translateY(-40vh) translateX(20px) scale(1)}
  100%{transform:translateY(-110vh) translateX(-12px) scale(.4);opacity:0}
}

/* ============ SCROLL REVEAL ============ */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .9s ease, transform .9s cubic-bezier(.2,.7,.3,1.1)}
.reveal.in{opacity:1;transform:none}
.reveal-scale{opacity:0;transform:scale(.85);transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.3,1.4)}
.reveal-scale.in{opacity:1;transform:none}
.reveal-left{opacity:0;transform:translateX(-50px);transition:opacity .9s ease, transform .9s cubic-bezier(.2,.7,.3,1.1)}
.reveal-left.in{opacity:1;transform:none}
.reveal-right{opacity:0;transform:translateX(50px);transition:opacity .9s ease, transform .9s cubic-bezier(.2,.7,.3,1.1)}
.reveal-right.in{opacity:1;transform:none}
.stag1{transition-delay:.08s}
.stag2{transition-delay:.18s}
.stag3{transition-delay:.28s}
.stag4{transition-delay:.38s}

/* ============ MOUSE SPARKLE TRAIL ============ */
.mouse-sparkle{
  position:fixed;width:14px;height:14px;
  pointer-events:none;z-index:9999;
  transform:translate(-50%,-50%) rotate(0deg);
  animation:mouseSparkleAnim .9s ease-out forwards;
  color:#a78bfa;
}
.mouse-sparkle::before,
.mouse-sparkle::after{
  content:"";position:absolute;left:50%;top:50%;
  background:#fff;border-radius:1px;
  box-shadow:0 0 8px #fff, 0 0 18px currentColor;
}
.mouse-sparkle::before{width:2px;height:100%;transform:translate(-50%,-50%)}
.mouse-sparkle::after{width:100%;height:2px;transform:translate(-50%,-50%)}
.mouse-sparkle.gold{color:#ffd86b}
.mouse-sparkle.pink{color:#ff7ad1}
.mouse-sparkle.cyan{color:#8de1ff}
.mouse-sparkle.mint{color:#7cf3c0}
@keyframes mouseSparkleAnim{
  0%{opacity:0;transform:translate(-50%,-50%) rotate(0) scale(.2)}
  20%{opacity:1;transform:translate(-50%,-50%) rotate(45deg) scale(1)}
  100%{opacity:0;transform:translate(calc(-50% + var(--dx,0px)),calc(-50% + var(--dy,0px))) rotate(180deg) scale(.3)}
}

/* ============ RESPONSIVE ============ */
@media (max-width:760px){
  .hero{min-height:auto;padding:20px 0 0}
  .hero-content{padding:30px 16px 40px}
  .title-logo{width:min(420px,90vw);margin-top:14px}
  .logo-aura{width:380px;height:180px}
  .tagline{font-size:18px;margin-top:14px}
  .tagline-accent{font-size:16px}
  .battle-wrap{margin-top:28px}
  .battle-slot{border-radius:20px}
  .caption{font-size:18px;margin-top:36px}
  .scroll-hint{margin-top:34px}

  .peek-bear{width:150px;margin-top:-60px}
  .download-now h2{font-size:54px}
  .stores{gap:10px;padding:24px 16px 4px}
  .store{min-width:0;width:100%;max-width:300px;padding:13px 18px}

  .features-section{padding:24px 0 60px}
  .features-inner{padding:24px 14px}
  .features-section h2{font-size:24px;margin-bottom:22px}
  .feat-grid{gap:12px}
  .feat{padding:14px 10px 12px;border-radius:18px}
  .feat .badge{width:50px;height:56px}
  .feat h3{font-size:13px;letter-spacing:.4px;margin:6px 0 10px}
  .feat-slot{height:100px;border-radius:11px}
  .feat.image-only .feat-slot{min-height:200px;border-radius:18px}

  .chars-section{padding:50px 0 80px}
  .chars-grid{padding:0 14px;gap:18px}
  .char-card{border-radius:24px}

  .sleeping{margin-top:36px;width:200px}
  .sleeping-slot{width:170px}
}

@media (max-width:480px){
  .nav-row{padding:10px 16px;gap:10px}
  .brand-logo{width:36px;height:36px}
  .brand-name{font-size:18px}

  .title-logo{width:min(340px,92vw)}
  .logo-aura{width:300px;height:140px;filter:blur(28px)}
  .battle-slot{border-radius:18px}

  .peek-bear{width:130px;margin-top:-52px}
  .download-now h2{font-size:44px;letter-spacing:0}

  .feat-grid{grid-template-columns:1fr 1fr;gap:10px}
  .feat-slot{height:100%}
  .feat.image-only .feat-slot{min-height:170px}

  .sleeping{width:180px}
  .sleeping-slot{width:160px}
}

@media (max-width:360px){
  .download-now h2{font-size:38px}
  .feat h3{font-size:11.5px;letter-spacing:.3px}
  .title-logo{width:280px}
}

/* respect reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
}
