/* =========================================================
   MoonPay - landing page styles
   Inspired by modern crypto fintech aesthetics
   ========================================================= */

:root{
  --bg:        #07070b;
  --bg-2:      #0d0d14;
  --surface:   #11111b;
  --surface-2: #161624;
  --line:      rgba(255,255,255,.08);
  --text:      #f4f4f7;
  --muted:     #9a9aae;
  --primary:   #7c4dff;       /* violet */
  --primary-2: #c79bff;       /* light lavender (was cyan) */
  --accent:    #ff5cf0;       /* pink   */
  --good:      #2ee6a6;
  --radius:    18px;
  --shadow:    0 30px 80px rgba(0,0,0,.45);
  --grad:      linear-gradient(135deg,#7c4dff 0%,#a87bff 50%,#ff5cf0 100%);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--text);font-family:'Inter',system-ui,-apple-system,sans-serif;line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
h1,h2,h3,h4{font-family:'Sora','Inter',sans-serif;line-height:1.08;letter-spacing:-.02em;font-weight:700}
h2{font-size:clamp(2rem,4.5vw,3.6rem)}
h3{font-size:1.35rem}
p{color:var(--muted)}

.gradient-text{
  background:var(--grad);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  background-size:200% 200%;
  animation:grad 8s ease infinite;
}
@keyframes grad{
  0%,100%{background-position:0% 50%}
  50%    {background-position:100% 50%}
}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.75rem 1.15rem;border-radius:999px;font-weight:600;font-size:.95rem;
  border:1px solid transparent;cursor:pointer;transition:transform .25s ease,box-shadow .25s ease,background .25s ease,color .25s;
  white-space:nowrap;
}
.btn-lg{padding:.85rem 1.4rem;font-size:.9rem}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 10px 30px rgba(124,77,255,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(124,77,255,.5)}
.btn-outline{border-color:var(--line);color:var(--text);background:rgba(255,255,255,.03);backdrop-filter:blur(8px)}
.btn-outline:hover{border-color:rgba(255,255,255,.25);background:rgba(255,255,255,.06)}
.btn-ghost{color:var(--text);background:transparent}
.btn-ghost:hover{color:var(--primary-2)}
.btn-light{background:#fff;color:#0a0a14;font-weight:600;transition:background .25s ease,color .25s ease,transform .25s ease,box-shadow .25s ease}
.btn-light:hover{
  background:#e9defc;          /* light lavender/purple */
  color:#5b2dd6;               /* deeper purple text on hover */
  transform:translateY(-2px);
  box-shadow:0 14px 30px rgba(124,77,255,.28);
}

/* ---- Reveal on scroll ---- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s ease,transform .9s ease}
.reveal.is-visible{opacity:1;transform:translateY(0)}

/* ---- Eyebrow / dot ---- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.82rem;font-weight:600;letter-spacing:.02em;
  color:var(--muted);text-transform:uppercase;
}
.eyebrow .dot{
  width:8px;height:8px;border-radius:50%;background:var(--grad);
  box-shadow:0 0 12px var(--primary);animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{50%{transform:scale(1.4);opacity:.6}}

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background .35s ease,backdrop-filter .35s,border-color .35s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(7,7,11,.7);
  backdrop-filter:saturate(180%) blur(16px);
  border-bottom-color:var(--line);
}
.nav-inner{
  max-width:1280px;margin:0 auto;padding:.85rem 2rem;
  display:flex;align-items:center;gap:2.4rem;
}

.logo{display:inline-flex;flex-direction:column;align-items:flex-start;gap:.08rem;font-family:'Sora';font-weight:700;font-size:.85rem;line-height:1;transition:transform .25s ease}
.logo:hover{transform:scale(1.03)}
.logo-tagline{
  font-family:'Sora','Inter',system-ui,sans-serif;
  font-size:.48rem;
  font-weight:600;
  letter-spacing:.3em;
  text-transform:uppercase;
  margin-left:2px;
  background:linear-gradient(90deg,#7c4dff,#a87bff,#ff5cf0);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  opacity:.95;
  line-height:1;
  transform:translateY(1px);
}
.footer .logo-tagline{
  font-size:.72rem;
  letter-spacing:.34em;
  margin-left:3px;
  transform:translateY(2px);
}
.logo-img{
  height:32px;width:auto;display:block;
  object-fit:contain;
  filter:drop-shadow(0 6px 18px rgba(124,77,255,.35));
  transition:filter .35s ease;
}
/* New logo is already white with a cyan moon - keep its native colors,
   only add a soft glow to lift it on the dark navbar */
.nav .logo-img{
  filter:drop-shadow(0 6px 18px rgba(124,77,255,.45));
}
.nav.scrolled .logo-img{
  filter:drop-shadow(0 6px 22px rgba(199,155,255,.55));
}
/* Footer also uses native logo colors */
.footer .logo-img{
  filter:drop-shadow(0 6px 18px rgba(124,77,255,.35));
}

.logo-mark{
  display:inline-grid;place-items:center;width:32px;height:32px;border-radius:10px;
  background:var(--grad);color:#fff;font-size:1.05rem;
  box-shadow:0 8px 22px rgba(124,77,255,.45);
}
.nav-links{display:flex;align-items:center;gap:2.6rem;margin-left:0}
.nav-links a{font-size:.92rem;color:#fff;font-weight:600;transition:color .2s,opacity .2s;opacity:.95}
.nav-links a:hover{color:#fff;opacity:1}
.nav-links .has-caret span{font-size:.7rem;opacity:.6;margin-left:.15rem}
.nav-group{display:flex;align-items:center;gap:1.6rem}
.nav-group-right{margin-left:0}        /* sit naturally next to first group */
.nav-cta{margin-left:auto}              /* push only globe + button to the far right */

.nav-grid{
  display:inline-grid;place-items:center;
  width:28px;height:28px;border-radius:8px;
  background:rgba(255,255,255,.06);border:1px solid var(--line);
  transition:background .2s ease,border-color .2s ease;
}
.nav-grid:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.2)}
.nav-grid svg{color:#fff}
button.nav-grid{cursor:pointer;font:inherit;padding:0;display:inline-grid;place-items:center;color:#fff}
.nav-grid.is-open{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.3)}

/* =========================================================
   MEGA MENU (opens from grid icon)
   ========================================================= */
.nav-mega{
  position:absolute;top:100%;left:0;right:0;
  padding:1.2rem 2rem 1.6rem;
  display:flex;justify-content:center;
  opacity:0;visibility:hidden;
  transform:translateY(-10px);
  transition:opacity .28s ease, transform .28s cubic-bezier(.34,1.56,.64,1), visibility .28s;
  z-index:55;
  pointer-events:none;
}
.nav-mega.is-open{
  opacity:1;visibility:visible;transform:translateY(0);
  pointer-events:auto;
}
.nav-mega-inner{
  display:grid;grid-template-columns:280px 1fr;gap:1rem;
  width:min(100%,1100px);
  align-items:start;
}
.nav-mega-side{
  background:#fff;border-radius:18px;
  padding:1.6rem 1.4rem;
  display:flex;flex-direction:column;gap:.4rem;
  box-shadow:0 24px 60px rgba(0,0,0,.45);
  min-height:340px;
}
.nm-side-item{
  display:block;padding:.95rem 1rem;border-radius:10px;
  font:600 1.05rem/1.1 'Sora','Inter',sans-serif;
  color:#0a0a14;letter-spacing:-.01em;
  transition:background .2s ease, transform .2s ease;
}
.nm-side-item:hover{background:#f4f4f5;transform:translateX(2px)}

.nav-mega-grid{
  background:#fff;border-radius:18px;
  padding:1.4rem;
  display:grid;grid-template-columns:1fr 1fr;gap:.75rem 1rem;
  box-shadow:0 24px 60px rgba(0,0,0,.45);
}
.nm-tile{
  position:relative;
  display:flex;align-items:center;gap:.85rem;
  padding:.85rem 1rem;border-radius:12px;
  background:transparent;color:#0a0a14;
  font:600 1rem 'Sora','Inter',sans-serif;
  letter-spacing:-.01em;
  transition:background .2s ease, transform .2s ease;
}
.nm-tile:hover{background:#f4f4f5;transform:translateX(2px)}
.nm-ico{
  display:inline-grid;place-items:center;
  width:38px;height:38px;border-radius:10px;
  background:#f4f4f5;color:#0a0a14;flex-shrink:0;
}
.nm-ico-newsroom{background:#dbe7ff;color:#1e3a8a}
.nm-ico-media{background:#f3d4ff;color:#7c3aed}
.nm-ico-careers{background:#ffe5b8;color:#a85c00}
.nm-ico-changelog{background:#e2d4ff;color:#5b21b6}
.nm-ico-affiliates{background:#d6f5e1;color:#15803d}
.nm-ico-discover{background:#ffe1cc;color:#c2410c}
.nm-label{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nm-badge{
  display:inline-flex;align-items:center;
  padding:.25rem .55rem;border-radius:6px;
  background:#7c4dff;color:#fff;
  font:700 .68rem/1 'Inter',sans-serif;
  letter-spacing:.02em;
}

.nav-mega-backdrop{
  position:fixed;inset:0;
  background:rgba(0,0,0,.45);
  backdrop-filter:blur(2px);
  opacity:0;visibility:hidden;
  transition:opacity .25s ease, visibility .25s;
  z-index:45;
}
.nav-mega-backdrop.is-open{opacity:1;visibility:visible}

@media(max-width:820px){
  .nav-mega{padding:.8rem 1rem 1.2rem}
  .nav-mega-inner{grid-template-columns:1fr;gap:.7rem}
  .nav-mega-side{min-height:0;padding:1rem}
  .nav-mega-grid{padding:1rem;gap:.4rem .6rem}
  .nm-side-item{padding:.7rem .8rem;font-size:.95rem}
  .nm-tile{padding:.7rem .8rem;font-size:.92rem;gap:.6rem}
  .nm-ico{width:32px;height:32px}
}
@media(max-width:520px){
  .nav-mega-grid{grid-template-columns:1fr}
}

.nav-cta{margin-left:auto;display:flex;gap:.6rem;align-items:center}
.nav-cta .btn{padding:.55rem 1.05rem;font-size:.85rem}
.nav-globe{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.4rem;
  /* Sizing only applies to the bare globe (footer / pre-init); the JS adds
     .lang-btn which gives it pill padding for header use. */
  min-width:34px;height:34px;
  padding:0 .35rem;
  border-radius:999px;
  color:#fff;
  transition:background .2s ease, border-color .2s ease;
}
.nav-globe:hover{background:rgba(255,255,255,.08)}
.nav-globe svg{width:18px;height:18px;flex-shrink:0;color:#fff}
/* Ensure the small "EN" badge after the icon is visible against dark nav */
.nav-globe .lang-current{
  font:600 .72rem 'Inter',sans-serif;
  color:#fff;
  letter-spacing:.04em;
  white-space:nowrap;
}

/* Animated burger */
.nav-burger{
  display:none;background:transparent;border:none;cursor:pointer;
  width:44px;height:44px;border-radius:12px;
  align-items:center;justify-content:center;flex-direction:column;gap:5px;
  border:1px solid var(--line);
  transition:background .25s,border-color .25s;
  z-index:60;
}
.nav-burger:hover{background:rgba(255,255,255,.05)}
.nav-burger span{
  display:block;width:20px;height:2px;border-radius:2px;background:#fff;
  transition:transform .35s ease,opacity .25s ease;
}
.nav-burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.is-open span:nth-child(2){opacity:0}
.nav-burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-cta{display:none}

/* Backdrop */
.nav-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);
  opacity:0;pointer-events:none;transition:opacity .35s ease;z-index:40;
}
.nav-backdrop.is-open{opacity:1;pointer-events:auto}

/* Lock scroll when menu open */
body.menu-open{overflow:hidden}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;min-height:100vh;
  padding:9rem 1.5rem 6rem;
  display:grid;grid-template-columns:1.1fr .9fr;gap:3rem;
  max-width:1100px;margin:0 auto;align-items:center;
  overflow:hidden;
}
.hero-bg{position:absolute;inset:0;z-index:-1;overflow:hidden}

/* ---- Fullscreen video hero (MoonPay style) ---- */
.hero-video{
  max-width:none;             /* go edge-to-edge */
  margin:0;
  padding:7rem 6vw 4rem;
  display:flex;align-items:center;
  min-height:78vh;
}
.hero-video .hero-bg{
  z-index:0;
  inset:0;
  position:absolute;
}
.hero-video .hero-bg .orb,
.hero-video .hero-bg .grid-overlay{display:none}

.hero-video-el{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;
  z-index:0;
  pointer-events:none;
}
.hero-video-overlay{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(180deg, rgba(0,0,0,.45) 0%, rgba(0,0,0,.15) 35%, rgba(0,0,0,.55) 100%),
    linear-gradient(90deg, rgba(0,0,0,.35) 0%, rgba(0,0,0,0) 60%);
}
.hero-video .hero-content{
  position:relative;z-index:2;
  max-width:560px;
  color:#fff;
  padding-left:.5rem;
}
.hero-video .hero-content .eyebrow{margin-bottom:1.6rem}
.hero-video .hero-content .eyebrow-pill{
  background:rgba(0,0,0,.42);
  border:1px solid rgba(255,255,255,.06);
  color:#fff;
  backdrop-filter:blur(10px);
  padding:.55rem 1.1rem;
  font-size:.78rem;
  font-weight:500;
  gap:.55rem;
  border-radius:999px;
}
.hero-video .hero-content .eyebrow-pill .eyebrow-sep{
  opacity:.55;
  font-size:.55rem;
  margin:0 .15rem;
}
.hero-video .hero-title{
  color:#fff;
  font-weight:600;
  font-size:clamp(1.9rem,3.6vw,3rem);
  line-height:1.08;
  letter-spacing:-.02em;
  text-shadow:0 4px 30px rgba(0,0,0,.3);
  margin-bottom:1.2rem;
}

/* Highlighted accent phrase ("Digital Wealth.") in the hero title */
.hero-title-accent{
  display:inline-block;
  /* Solid fallback so the text is visible even if background-clip:text
     doesn't kick in (older mobile browsers, print, etc.) */
  color:#c79bff;
  background:linear-gradient(90deg,#c79bff 0%,#ff5cf0 50%,#7c4dff 100%);
  background-size:200% 200%;
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  animation:grad 8s ease infinite;
  /* Don't let descenders ("p", "g", ".") get clipped by the text-fill mask */
  padding-bottom:.12em;
  line-height:1.1;
  /* Force the accent onto its own line so "Your Passport to" never crowds it
     out on narrower viewports - matches the screenshot mockup */
  width:100%;
}
/* When a <br> already breaks the line before the accent, we don't need to
   force width - keep this rule scoped only to the video hero variant where
   the <br> is present and width:100% won't overflow into the right column. */
.hero-video .hero-title .hero-title-accent{
  /* slightly stronger drop shadow doesn't apply to gradient text - use filter instead */
  filter:drop-shadow(0 4px 30px rgba(124,77,255,.35));
}
.hero-video .hero-sub{
  color:rgba(255,255,255,.95);
  font-size:.88rem;
  line-height:1.5;
  text-shadow:0 2px 16px rgba(0,0,0,.3);
  margin-bottom:1.6rem;
  max-width:380px;
}
.hero-video .hero-actions{margin-bottom:0}
.hero-video .btn-light{
  padding:.85rem 1.9rem;
  font-size:.85rem;
  font-weight:600;
  border-radius:999px;
}
.hero-video .hero-phone{display:none}      /* hide phone mockup when using video bg */

@media(max-width:820px){
  .hero-video{padding:6.5rem 1.2rem 3rem}
  .hero-video .hero-content{max-width:100%;padding-left:0}
  .hero-video .hero-title{font-size:2.2rem}
  .hero-video .hero-sub{font-size:.9rem}
}

@media(prefers-reduced-motion:reduce){
  .hero-video-el{display:none}
}
.orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:.55;animation:float 14s ease-in-out infinite}
.orb-1{width:520px;height:520px;background:#7c4dff;top:-120px;left:-120px}
.orb-2{width:460px;height:460px;background:#c79bff;bottom:-160px;right:-100px;animation-delay:-3s}
.orb-3{width:300px;height:300px;background:#ff5cf0;top:30%;right:30%;opacity:.35;animation-delay:-7s}
@keyframes float{
  0%,100%{transform:translate(0,0) scale(1)}
  50%    {transform:translate(40px,-30px) scale(1.08)}
}
.grid-overlay{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse at center,#000 30%,transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center,#000 30%,transparent 75%);
}

.hero-content .eyebrow{margin-bottom:1.2rem}
.eyebrow-pill{
  display:inline-flex;align-items:center;gap:.6rem;
  background:rgba(255,255,255,.08);border:1px solid var(--line);
  padding:.6rem 1.2rem;border-radius:999px;
  font-size:.9rem;font-weight:500;color:#bfbfd0;
  text-transform:none;letter-spacing:0;
  backdrop-filter:blur(8px);
}
.eyebrow-pill .eyebrow-sep{opacity:.5}
.hero-title{
  font-size:clamp(1.9rem,4.4vw,3.6rem);
  font-weight:500;line-height:1.08;margin-bottom:1.1rem;letter-spacing:-.02em;
}
.hero-sub{font-size:.98rem;line-height:1.55;max-width:460px;margin-bottom:1.6rem;color:#bfbfd0}
.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:3rem}
.hero-actions.center{justify-content:center}
.hero-stats{display:flex;gap:2.5rem;flex-wrap:wrap}
.hero-stats div{display:flex;flex-direction:column}
.hero-stats strong{font-family:'Sora';font-size:1.6rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero-stats span{font-size:.85rem;color:var(--muted)}

/* ---- Phone mockup ---- */
.hero-phone{
  position:relative;display:flex;justify-content:center;align-items:center;
  perspective:1200px;
}
.phone{
  position:relative;width:300px;height:600px;border-radius:48px;
  background:linear-gradient(160deg,#1a1a28 0%,#0d0d14 100%);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:var(--shadow),inset 0 0 0 8px #0a0a12;
  transform:rotateY(-12deg) rotateX(6deg);
  animation:hover 6s ease-in-out infinite;
}
@keyframes hover{50%{transform:rotateY(-12deg) rotateX(6deg) translateY(-14px)}}
.phone-notch{
  width:100px;height:24px;border-radius:0 0 16px 16px;
  background:#000;margin:0 auto;position:relative;z-index:2;
}
.phone-screen{
  position:absolute;inset:14px;border-radius:38px;
  background:radial-gradient(circle at 20% 0%,rgba(124,77,255,.4),transparent 50%),
             radial-gradient(circle at 100% 100%,rgba(255,92,240,.22),transparent 55%),
             #0a0a14;
  padding:2.6rem 1.1rem 1.1rem;display:flex;flex-direction:column;gap:.9rem;
}
.screen-top{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:.92rem}
.bell{font-size:.95rem}
.balance p{font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.balance h3{font-size:1.9rem;font-family:'Sora';font-weight:700;margin-top:.2rem}
.balance h3 small{font-size:1rem;color:var(--muted);font-weight:500}
.balance .up{color:var(--good);font-size:.82rem;font-weight:600}
.coins{list-style:none;display:flex;flex-direction:column;gap:.55rem;margin-top:.4rem}
.coins li{
  display:flex;align-items:center;gap:.7rem;
  background:rgba(255,255,255,.04);border:1px solid var(--line);
  padding:.55rem .65rem;border-radius:14px;font-size:.85rem;
}
.coins div{display:flex;flex-direction:column;line-height:1.1;flex:1}
.coins b{font-size:.85rem}
.coins i{font-style:normal;color:var(--muted);font-size:.72rem}
.coins .amt{font-size:.82rem;font-weight:600}
.coin{
  display:grid;place-items:center;width:30px;height:30px;border-radius:50%;
  font-weight:700;font-size:.95rem;color:#fff;
}
.coin.btc{background:linear-gradient(135deg,#f7931a,#ffb74d)}
.coin.eth{background:linear-gradient(135deg,#7c4dff,#c79bff)}
.coin.sol{background:linear-gradient(135deg,#9945ff,#ff5cf0)}
.coin.usdc{background:linear-gradient(135deg,#7c4dff,#ff5cf0)}
.screen-cta{
  margin-top:auto;border:none;border-radius:14px;padding:.85rem;
  background:var(--grad);color:#fff;font-weight:600;cursor:pointer;
  box-shadow:0 12px 24px rgba(124,77,255,.4);
}

.float-card{
  position:absolute;display:flex;align-items:center;gap:.5rem;
  background:rgba(20,20,30,.85);border:1px solid var(--line);backdrop-filter:blur(10px);
  padding:.6rem .85rem;border-radius:14px;font-size:.85rem;font-weight:600;
  box-shadow:var(--shadow);
}
.float-card span{
  display:grid;place-items:center;width:26px;height:26px;border-radius:50%;
  background:var(--grad);font-size:.85rem;
}
.card-1{top:14%;left:-10px;animation:floaty 5s ease-in-out infinite}
.card-2{bottom:18%;right:-10px;animation:floaty 6s ease-in-out infinite -2s}
@keyframes floaty{50%{transform:translateY(-12px)}}

/* =========================================================
   DASHBOARD PREVIEW (after hero)
   ========================================================= */
.dashboard-preview{
  position:relative;
  padding:7rem 1.5rem 8rem;
  overflow:hidden;
  isolation:isolate;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(124,77,255,.18) 0%, transparent 55%),
    linear-gradient(180deg,#07070b 0%,#0d0d14 60%,#07070b 100%);
}
.dp-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.dp-orb{
  position:absolute;border-radius:50%;filter:blur(110px);opacity:.45;
}
.dp-orb-1{width:520px;height:520px;background:#7c4dff;top:-180px;left:-160px;animation:float 16s ease-in-out infinite}
.dp-orb-2{width:460px;height:460px;background:#ff5cf0;bottom:-180px;right:-140px;opacity:.32;animation:float 18s ease-in-out infinite -4s}
.dp-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse at center,#000 30%,transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse at center,#000 30%,transparent 80%);
  opacity:.7;
}

.dp-inner{
  position:relative;z-index:1;
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:.85fr 1.15fr;gap:4rem;align-items:center;
}

/* Left writeup */
.dp-head{display:flex;flex-direction:column;gap:1.2rem;align-items:flex-start}
.dp-head .eyebrow-pill{
  display:inline-flex;align-items:center;gap:.55rem;
  padding:.45rem 1rem;border-radius:999px;
  background:rgba(255,255,255,.06);border:1px solid var(--line);
  font-size:.78rem;font-weight:600;color:#cfcfdb;
  letter-spacing:.02em;
  backdrop-filter:blur(8px);
}
.dp-head .eyebrow-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--grad);box-shadow:0 0 10px var(--primary);
  animation:pulse 2s ease-in-out infinite;
}
.dp-title{
  font-family:'Sora','Inter',sans-serif;
  font-size:clamp(2rem,3.6vw,3rem);
  font-weight:700;line-height:1.05;letter-spacing:-.025em;
  color:#fff;margin:.2rem 0 .4rem;
}
.dp-sub{
  font-size:1.02rem;line-height:1.6;color:#bfbfd0;
  max-width:480px;
}
.dp-bullets{
  list-style:none;padding:0;margin:.4rem 0 0;
  display:flex;flex-direction:column;gap:.65rem;
}
.dp-bullets li{
  display:flex;align-items:center;gap:.7rem;
  font-size:.95rem;color:#e3e3ea;font-weight:500;
}
.dp-check{
  display:inline-grid;place-items:center;
  width:22px;height:22px;border-radius:50%;
  background:linear-gradient(135deg,#7c4dff,#ff5cf0);
  color:#fff;font-size:.7rem;font-weight:800;
  box-shadow:0 4px 12px rgba(124,77,255,.4);
}

/* Get Started CTA inside dashboard preview */
.dp-cta{
  margin-top:1.4rem;
  align-self:flex-start;
  gap:.55rem;
}
.dp-cta svg{
  transition:transform .25s ease;
}
.dp-cta:hover svg{transform:translateX(4px)}

/* Right frame wrapper */
.dp-frame-wrap{
  position:relative;
  perspective:1600px;
}

/* Browser-style frame */
.dp-frame{
  position:relative;
  border-radius:16px;
  background:linear-gradient(160deg,#1c1c2a 0%,#0d0d14 100%);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:
    0 30px 80px rgba(0,0,0,.6),
    0 10px 30px rgba(124,77,255,.25),
    inset 0 0 0 1px rgba(255,255,255,.04);
  overflow:hidden;
  transform:rotateX(2deg) rotateY(-3deg);
  transition:transform .6s cubic-bezier(.2,.8,.2,1);
  animation:dpFloat 8s ease-in-out infinite;
}
.dp-frame-wrap:hover .dp-frame{transform:rotateX(0) rotateY(0)}
@keyframes dpFloat{
  0%,100%{transform:rotateX(2deg) rotateY(-3deg) translateY(0)}
  50%    {transform:rotateX(2deg) rotateY(-3deg) translateY(-10px)}
}

/* Animated gradient border (using ::before with mask) */
.dp-frame::before{
  content:"";position:absolute;inset:0;
  border-radius:inherit;padding:1.5px;
  background:linear-gradient(135deg,
    rgba(124,77,255,.7) 0%,
    rgba(255,92,240,.5) 35%,
    rgba(124,77,255,.1) 65%,
    rgba(199,155,255,.6) 100%);
  background-size:200% 200%;
  -webkit-mask:
    linear-gradient(#000,#000) content-box,
    linear-gradient(#000,#000);
  -webkit-mask-composite:xor;
          mask-composite:exclude;
  pointer-events:none;
  animation:dpBorder 6s linear infinite;
  z-index:2;
}
@keyframes dpBorder{
  0%  {background-position:0% 0%}
  50% {background-position:100% 100%}
  100%{background-position:0% 0%}
}

/* Browser chrome */
.dp-chrome{
  display:flex;align-items:center;gap:1rem;
  padding:.75rem 1rem;
  background:linear-gradient(180deg,#15151f 0%,#101019 100%);
  border-bottom:1px solid rgba(255,255,255,.06);
  position:relative;z-index:1;
}
.dp-dots{display:flex;gap:.45rem;flex-shrink:0}
.dp-dot{
  width:11px;height:11px;border-radius:50%;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.3);
}
.dp-dot-r{background:#ff5f57}
.dp-dot-y{background:#febc2e}
.dp-dot-g{background:#28c840}
.dp-url{
  flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);
  padding:.4rem 1rem;border-radius:8px;
  font-family:'Inter',monospace;
  font-size:.8rem;color:#9a9aae;font-weight:500;
  max-width:320px;margin:0 auto;
  letter-spacing:.01em;
}
.dp-lock{font-size:.7rem;opacity:.7}
.dp-chrome-spacer{width:60px;flex-shrink:0}

/* Screen / image */
.dp-screen{
  position:relative;
  background:#0a0a14;
  overflow:hidden;
}
.dp-img{
  display:block;width:100%;height:auto;
  /* keep image crisp + slightly zoomed for perspective effect */
  transform:scale(1.001);
}
/* Glossy diagonal sheen sweeping across */
.dp-shine{
  position:absolute;inset:0;
  background:linear-gradient(115deg,
    transparent 0%,
    transparent 35%,
    rgba(255,255,255,.08) 45%,
    rgba(255,255,255,.18) 50%,
    rgba(255,255,255,.08) 55%,
    transparent 65%,
    transparent 100%);
  background-size:200% 200%;
  background-position:-100% -100%;
  pointer-events:none;
  animation:dpShine 7s ease-in-out infinite;
  mix-blend-mode:overlay;
}
@keyframes dpShine{
  0%,100%{background-position:-150% -150%;opacity:0}
  40%    {opacity:.9}
  50%    {background-position:150% 150%;opacity:.9}
  60%    {opacity:0}
}

/* Decorative neon corner accents */
.dp-corner{
  position:absolute;width:40px;height:40px;z-index:3;pointer-events:none;
}
.dp-corner::before,.dp-corner::after{
  content:"";position:absolute;
  background:linear-gradient(90deg,#7c4dff,#ff5cf0);
  border-radius:2px;
  box-shadow:0 0 12px rgba(124,77,255,.6);
}
.dp-corner::before{width:24px;height:2px}
.dp-corner::after{width:2px;height:24px}
.dp-corner-tl{top:-12px;left:-12px}
.dp-corner-tl::before{top:0;left:0}
.dp-corner-tl::after{top:0;left:0}
.dp-corner-tr{top:-12px;right:-12px}
.dp-corner-tr::before{top:0;right:0}
.dp-corner-tr::after{top:0;right:0}
.dp-corner-bl{bottom:-12px;left:-12px}
.dp-corner-bl::before{bottom:0;left:0}
.dp-corner-bl::after{bottom:0;left:0}
.dp-corner-br{bottom:-12px;right:-12px}
.dp-corner-br::before{bottom:0;right:0}
.dp-corner-br::after{bottom:0;right:0}

/* Floating stat chips */
.dp-chip{
  position:absolute;z-index:4;
  display:flex;align-items:center;gap:.7rem;
  padding:.7rem 1rem;
  background:rgba(20,20,30,.85);
  border:1px solid var(--line);
  backdrop-filter:blur(14px) saturate(180%);
  border-radius:14px;
  box-shadow:0 18px 40px rgba(0,0,0,.5);
  animation:floaty 5s ease-in-out infinite;
}
.dp-chip-ico{
  display:inline-grid;place-items:center;
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,#7c4dff,#ff5cf0);
  font-size:1rem;flex-shrink:0;
  box-shadow:0 4px 12px rgba(124,77,255,.4);
}
.dp-chip div{display:flex;flex-direction:column;line-height:1.15}
.dp-chip small{font-size:.7rem;color:#9a9aae;font-weight:500}
.dp-chip strong{
  font-family:'Sora','Inter',sans-serif;
  font-size:.95rem;font-weight:700;color:#fff;
}
.dp-chip-1{top:8%;left:-3%;animation-delay:-1s}
.dp-chip-2{bottom:10%;right:-3%;animation-delay:-3s}

/* Responsive */
@media(max-width:980px){
  .dp-inner{grid-template-columns:1fr;gap:3rem}
  .dp-head{align-items:flex-start;text-align:left;max-width:600px}
  .dp-frame{transform:none;animation:none}
  .dp-frame-wrap:hover .dp-frame{transform:none}
  .dp-chip-1{left:auto;right:6%;top:-14px}
  .dp-chip-2{right:auto;left:6%;bottom:-14px}
}
@media(max-width:560px){
  .dashboard-preview{padding:5rem 1rem 6rem}
  .dp-chrome-spacer{display:none}
  .dp-url{font-size:.7rem;padding:.35rem .65rem;max-width:none}
  .dp-corner{width:28px;height:28px}
  .dp-corner-tl{top:-9px;left:-9px}
  .dp-corner-tr{top:-9px;right:-9px}
  .dp-corner-bl{bottom:-9px;left:-9px}
  .dp-corner-br{bottom:-9px;right:-9px}
  .dp-chip{padding:.55rem .8rem}
  .dp-chip-ico{width:28px;height:28px}
  .dp-chip strong{font-size:.85rem}
  .dp-chip small{font-size:.65rem}
}

/* =========================================================
   SHOWCASE - Buy / Sell / Send & Receive
   ========================================================= */
.showcase{
  background:#fff;color:#0a0a14;
  padding:6rem 1.5rem;
}
.showcase-grid{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;
  justify-content:center;
}
.show-card{
  background:#f4f4f5;border-radius:22px;overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .35s ease,box-shadow .35s ease;
}
.show-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px rgba(0,0,0,.12)}

/* Top art (gradient backdrop) */
.show-art{
  position:relative;height:300px;
  display:grid;place-items:center;padding:1.5rem;
  overflow:hidden;
}
.show-art::before{
  content:"";position:absolute;inset:0;
  background-size:cover;background-position:center;
  filter:saturate(1.05);
}
.show-art-buy::before{
  background:
    radial-gradient(60% 80% at 20% 30%,#5b3bff 0%,transparent 60%),
    radial-gradient(70% 90% at 80% 70%,#1c1554 0%,transparent 70%),
    linear-gradient(135deg,#0b0a26 0%,#1a1259 60%,#3b1f8a 100%);
}
.show-art-sell::before{
  background:
    radial-gradient(50% 70% at 30% 30%,#ffd2e2 0%,transparent 60%),
    radial-gradient(60% 80% at 80% 80%,#e9d8ff 0%,transparent 60%),
    linear-gradient(135deg,#fff5f8 0%,#f0e3ff 50%,#f6e6ff 100%);
}
.show-art-send::before{
  background:
    radial-gradient(50% 60% at 70% 30%,#cba6ff 0%,transparent 60%),
    radial-gradient(60% 80% at 20% 80%,#3b1c6b 0%,transparent 60%),
    linear-gradient(135deg,#1e0d3a 0%,#5a2dab 50%,#cdb1ff 100%);
}

/* Inner mini-cards (white pill cards over the art) */
.mini-card{
  position:relative;z-index:1;
  background:#fff;border-radius:14px;
  width:min(86%,330px);padding:1.2rem 1.1rem;
  box-shadow:0 24px 50px rgba(0,0,0,.18);
  display:flex;flex-direction:column;gap:.8rem;color:#0a0a14;
  font-family:'Inter',sans-serif;
}
.mc-amount{
  display:flex;align-items:flex-start;justify-content:center;gap:.15rem;
  font-family:'Sora','Inter',sans-serif;line-height:1;
}
.mc-amount .mc-cur{font-size:1.4rem;color:#9a9aa6;margin-top:.2rem}
.mc-amount .mc-cur.sup{font-size:.85rem;margin-top:.15rem;color:#9a9aa6;font-weight:700}
.mc-amount b{font-size:3rem;font-weight:800;letter-spacing:-.02em}
.mc-sub{
  display:flex;align-items:center;justify-content:flex-start;gap:.45rem;
  font-size:.78rem;color:#6a6a78;font-weight:500;
}
.mc-sub.center{justify-content:center}
.coin-dot{
  display:inline-grid;place-items:center;
  width:14px;height:14px;border-radius:50%;
  background:#000;color:#fff;font-size:.62rem;
}
.coin-dot.btc-dot{background:#f7931a}
.coin-dot.sol-dot{background:linear-gradient(135deg,#9945ff,#14f195)}

.mc-chips{
  display:flex;gap:.4rem;justify-content:center;flex-wrap:wrap;
}
.mc-chips span{
  padding:.35rem .7rem;border-radius:999px;
  background:#eef0f3;color:#0a0a14;font-size:.78rem;font-weight:600;
}
.mc-chips span.active{background:#0a0a14;color:#fff}

.mc-btn{
  margin-top:.2rem;padding:.85rem 1rem;border:none;cursor:pointer;
  background:#0a0a14;color:#fff;border-radius:999px;
  font-weight:600;font-size:.92rem;
  transition:background .25s ease,transform .25s ease;
}
.mc-btn:hover{background:#23232f;transform:translateY(-1px)}

/* Sell-specific account row */
.mc-account{
  background:#f4f4f5;border-radius:12px;padding:.65rem .8rem;
}
.mc-acc-row{display:flex;align-items:center;gap:.65rem}
.mc-avatar{
  width:30px;height:30px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,#7a8b6a,#3d4d2a);
  border:2px solid #fff;
}
.mc-acc-row > div{display:flex;flex-direction:column;line-height:1.1}
.mc-acc-row small{font-size:.65rem;color:#888;font-weight:500}
.mc-acc-row strong{font-size:.85rem;font-weight:700;color:#0a0a14}
.mc-balance{margin-left:auto;text-align:right}

/* Send-specific bits */
.mc-message{
  background:#eef0f3;border-radius:10px;padding:.7rem .85rem;
  color:#9a9aa6;font-size:.85rem;font-style:italic;
}
.mc-slide{
  position:relative;text-align:center;padding:.85rem;
  background:#eef0f3;color:#0a0a14;
}
.mc-slide:hover{background:#dde1e6}
.mc-slide-knob{
  position:absolute;left:.4rem;top:50%;transform:translateY(-50%);
  width:34px;height:34px;border-radius:50%;
  background:#0a0a14;color:#fff;
  display:grid;place-items:center;font-size:1rem;font-weight:700;
  animation:slideHint 2.4s ease-in-out infinite;
}
@keyframes slideHint{
  0%,100%{transform:translate(0,-50%)}
  50%    {transform:translate(8px,-50%)}
}
.mc-slide-text{font-weight:600}

/* Body copy */
.show-body{padding:1.6rem 1.6rem 2rem;display:flex;flex-direction:column;gap:1rem}
.show-body h3{font-size:1.6rem;color:#0a0a14;font-family:'Sora','Inter';font-weight:700}
.show-body p{color:#4a4a55;font-size:.98rem;line-height:1.55}
.show-body .btn-pill{align-self:flex-start;margin-top:.4rem}

/* =========================================================
   PAYMENTS LOGO STRIP (replaces old marquee)
   ========================================================= */
.payments-strip{
  background:#fff;color:#0a0a14;
  border-top:1px solid #ececef;border-bottom:1px solid #ececef;
  overflow:hidden;padding:2.2rem 0;
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.payments-track{
  display:flex;gap:3.5rem;width:max-content;align-items:center;
  animation:payScroll 40s linear infinite;
}
.payments-strip:hover .payments-track{animation-play-state:paused}
.pay-logo{
  display:inline-flex;align-items:center;justify-content:center;
  height:32px;color:#0a0a14;flex-shrink:0;
  opacity:.92;transition:opacity .25s ease,transform .25s ease;
}
.pay-logo:hover{opacity:1;transform:translateY(-2px)}
@keyframes payScroll{ to { transform:translateX(-50%); } }

/* keep .marquee classes for backwards compat (now hidden if any leftover) */
.marquee{display:none}

/* =========================================================
   TRUST STAT (huge animated number after sponsors marquee)
   ========================================================= */
.trust-stat{
  position:relative;
  background:#000;
  padding:7rem 1.5rem 8rem;
  overflow:hidden;
  text-align:center;
  isolation:isolate;
}
/* Soft purple glow at the top edge */
.trust-stat-glow{
  position:absolute;
  top:-220px;left:50%;
  transform:translateX(-50%);
  width:140%;height:380px;
  background:radial-gradient(ellipse at center,
    rgba(124,77,255,.55) 0%,
    rgba(124,77,255,.18) 35%,
    transparent 70%);
  filter:blur(40px);
  pointer-events:none;
  z-index:0;
}
.trust-stat-inner{
  position:relative;z-index:1;
  max-width:1100px;margin:0 auto;
  display:flex;flex-direction:column;align-items:center;gap:2.5rem;
}
.trust-stat-eyebrow{
  font:600 1.05rem/1.45 'Inter',sans-serif;
  color:#cfcfdb;
  letter-spacing:-.005em;
  margin:0;
}
.trust-stat-num{
  font-family:'Sora','Inter',sans-serif;
  font-weight:700;
  font-size:clamp(2rem,5vw,4rem);
  line-height:1;
  letter-spacing:-.02em;

  color:#fff;
  margin:0;
  /* a tiny gradient sheen on the digits */
  background:linear-gradient(180deg,#ffffff 0%,#dcdce8 100%);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
  /* prevent layout shift while the number ticks up */
  font-variant-numeric:tabular-nums;
  white-space:nowrap;
  text-shadow:0 0 30px rgba(124,77,255,.0);
  transition:text-shadow .8s ease;
}
.trust-stat.is-visible .trust-stat-num{
  text-shadow:0 0 60px rgba(124,77,255,.18);
}
.trust-stat-label{
  font:600 1.1rem 'Inter',sans-serif;
  color:#cfcfdb;
  letter-spacing:.01em;
  margin:0;
}
@media(max-width:560px){
  .trust-stat{padding:5rem 1rem 5.5rem}
  .trust-stat-num{font-size:clamp(1.6rem,7vw,2.4rem)}
}


/* ---- Spinning globe of image tiles -------------------------------- */
.globe-stage{
  position:relative;
  width:min(960px,100%);
  /* Tall enough to fit the hemisphere; tiles project forward */
  height:clamp(280px,46vw,520px);
  margin:.5rem auto 1rem;
  perspective:1400px;
  perspective-origin:50% 55%;
  pointer-events:none;
  /* Soft edge fade so tiles dissolve into the black bg at the rim */
  -webkit-mask-image:radial-gradient(ellipse 70% 80% at 50% 60%,
    #000 30%, #000 55%, transparent 88%);
          mask-image:radial-gradient(ellipse 70% 80% at 50% 60%,
    #000 30%, #000 55%, transparent 88%);
}
/* Optional dark vignette behind to deepen the rim */
.globe-fade{
  position:absolute;inset:0;
  background:radial-gradient(ellipse at 50% 60%,
    transparent 35%, rgba(0,0,0,.65) 75%, #000 100%);
  z-index:1;pointer-events:none;
}
/* The stage that establishes the 3D scene */
.globe-scene{
  position:absolute;inset:0;
  display:grid;place-items:center;
  transform-style:preserve-3d;
}
/* The actual rotating sphere */
.globe{
  position:relative;
  width:1px;height:1px;            /* zero-size pivot; tiles fan out from center */
  transform-style:preserve-3d;
  /* Gentle back-and-forth sway around Y, with a soft up/down tilt.
     Easing on both axes keeps the motion organic instead of mechanical. */
  animation:globeSwayY 22s ease-in-out infinite,
            globeSwayX 17s ease-in-out infinite;
  will-change:transform;
}
@keyframes globeSwayY{
  0%,100%{ transform:rotateY(-32deg); }
  50%    { transform:rotateY( 32deg); }
}
/* Layered animation: composes with the Y sway via CSS multiple-animations.
   We rotateX on the SCENE wrapper instead so they don't fight - simpler:
   put a single combined keyframe instead. */
@keyframes globeSwayX{
  0%,100%{ }
  50%    { }
}
/* Override: single combined keyframe (cleaner) */
.globe{
  animation:globeSway 22s ease-in-out infinite;
}
@keyframes globeSway{
  0%   { transform:rotateX(-10deg) rotateY(-30deg); }
  50%  { transform:rotateX(-14deg) rotateY( 30deg); }
  100% { transform:rotateX(-10deg) rotateY(-30deg); }
}

/* Each photo tile */
.globe-tile{
  position:absolute;
  left:50%;top:50%;
  width:96px;height:128px;          /* portrait ratio, like the screenshot */
  margin:-64px 0 0 -48px;           /* center on pivot before its 3D transform */
  border-radius:10px;
  overflow:hidden;
  background:#1a1a24;
  box-shadow:
    0 8px 22px rgba(0,0,0,.55),
    0 0 0 1px rgba(255,255,255,.04) inset;
  /* JS sets `transform: rotateY(..) rotateX(..) translateZ(R) rotateY(..)` */
  backface-visibility:hidden;
  transition:filter .4s ease;
}
.globe-tile::before{
  /* Subtle vignette on each tile so they read as photos, not flat blocks */
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,0) 60%,rgba(0,0,0,.45) 100%);
  z-index:2;pointer-events:none;
}
/* Tile "art" - a layered radial gradient lets us spawn ~8 distinct looks
   from one base class by varying CSS variables --c1/--c2/--c3 */
.globe-tile .gt-art{
  position:absolute;inset:0;
  background:
    radial-gradient(60% 80% at 30% 25%,var(--c1) 0%,transparent 60%),
    radial-gradient(70% 90% at 70% 80%,var(--c2) 0%,transparent 65%),
    linear-gradient(135deg,var(--c3) 0%,#0a0a14 100%);
}
/* A small "phone screen" decoration for some tiles, recreating the
   "person holding a phone" feel without using copyrighted images */
.globe-tile.gt-phone .gt-art::after{
  content:"";
  position:absolute;left:50%;top:55%;
  width:34px;height:54px;
  transform:translate(-50%,-50%) rotate(-8deg);
  border-radius:6px;
  background:linear-gradient(160deg,#fff 0%,#e6d5ff 60%,#7c4dff 100%);
  box-shadow:0 4px 14px rgba(124,77,255,.45);
}
/* "Silhouette" shape for portrait-style tiles */
.globe-tile.gt-portrait .gt-art::after{
  content:"";
  position:absolute;left:50%;bottom:0;
  width:64%;height:65%;
  transform:translateX(-50%);
  background:radial-gradient(circle at 50% 28%, rgba(0,0,0,0) 18%, rgba(0,0,0,.55) 19%, rgba(0,0,0,.85) 60%);
  border-radius:50% 50% 0 0 / 60% 60% 0 0;
}

/* Pause spin on hover for accessibility & focus */
.globe-stage:hover .globe{ animation-play-state:paused; }

@media(max-width:760px){
  .globe-tile{width:72px;height:96px;margin:-48px 0 0 -36px;border-radius:8px}
  .globe-tile.gt-phone .gt-art::after{width:26px;height:40px}
}
@media(prefers-reduced-motion:reduce){
  .globe{animation:none}
}


/* =========================================================
   FEATURES
   ========================================================= */
.features{max-width:1100px;margin:0 auto;padding:7rem 1.5rem}
.section-head{text-align:center;margin-bottom:3.5rem}
.section-head .eyebrow{margin-bottom:1rem}
.feature-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;
}
.feature{
  position:relative;padding:2rem 1.6rem;border-radius:var(--radius);
  background:linear-gradient(180deg,var(--surface) 0%,var(--surface-2) 100%);
  border:1px solid var(--line);overflow:hidden;
  transition:transform .35s ease,border-color .35s ease;
}
.feature::before{
  content:"";position:absolute;inset:0;background:var(--grad);
  opacity:0;transition:opacity .35s ease;z-index:-1;
}
.feature::after{
  content:"";position:absolute;top:-1px;left:-1px;right:-1px;height:1px;
  background:linear-gradient(90deg,transparent,var(--primary-2),transparent);
  opacity:0;transition:opacity .35s ease;
}
.feature:hover{transform:translateY(-6px);border-color:rgba(255,255,255,.18)}
.feature:hover::after{opacity:1}
.feature-ico{
  width:54px;height:54px;border-radius:14px;display:grid;place-items:center;
  font-size:1.6rem;margin-bottom:1.2rem;
  background:linear-gradient(135deg,rgba(124,77,255,.22),rgba(255,92,240,.14));
  border:1px solid var(--line);
}
.feature h3{margin-bottom:.6rem}
.feature p{font-size:.95rem;margin-bottom:1.2rem}
.feature b{color:var(--text)}
.link-arrow{
  font-weight:600;font-size:.92rem;color:var(--primary-2);
  display:inline-flex;align-items:center;gap:.3rem;
  transition:gap .25s ease;
}
.link-arrow:hover{gap:.6rem}

/* =========================================================
   BAND
   ========================================================= */
.band{position:relative;padding:7rem 1.5rem;overflow:hidden;background:var(--bg-2)}
.band-bg{position:absolute;inset:0;z-index:0}
.orb-4{width:500px;height:500px;background:#7c4dff;top:-100px;right:-100px;opacity:.35}
.orb-5{width:400px;height:400px;background:#ff5cf0;bottom:-150px;left:-100px;opacity:.3}
.band-inner{position:relative;z-index:1;max-width:1100px;margin:0 auto;text-align:center}
.band-inner p{max-width:640px;margin:1.2rem auto 3rem;font-size:1.1rem}
.band-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;
  padding:1.6rem;border-radius:var(--radius);
  background:rgba(255,255,255,.03);border:1px solid var(--line);
  backdrop-filter:blur(12px);
}
.band-stats div{display:flex;flex-direction:column;gap:.25rem}
.band-stats strong{
  font-family:'Sora';font-size:2rem;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
}
.band-stats span{color:var(--muted);font-size:.85rem}

/* =========================================================
   REVIEWS - light/Trustpilot-style with sliding carousel
   ========================================================= */
.reviews-light{
  background:#fff;color:#0a0a14;
  padding:7rem 0 8rem;position:relative;overflow:hidden;
}
.reviews-light-inner{max-width:1100px;margin:0 auto;padding:0 1.5rem}

.reviews-head{max-width:780px;margin-bottom:3.5rem}
.trustscore{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.92rem;color:#0a0a14;margin-bottom:1.4rem;
}
.trustscore .ts-stars{display:inline-flex;gap:2px}
.trustscore strong{font-weight:700}
.trustscore .ts-meta{color:#5a5a6a}
.reviews-title{
  font-weight:800;color:#0a0a14;margin-bottom:1.2rem;line-height:1.05;
  letter-spacing:-.02em;
}
.reviews-sub{
  font-size:1.1rem;color:#5a5a6a;max-width:560px;margin-bottom:2rem;
}
.btn-pill{
  display:inline-flex;align-items:center;justify-content:center;
  padding:.85rem 1.8rem;border-radius:999px;
  background:#0a0a14;color:#fff;font-weight:600;font-size:.95rem;
  transition:background .25s,transform .25s;
}
.btn-pill:hover{background:#23232f;transform:translateY(-2px)}

/* ---- Carousel (continuous marquee, opposite directions per row) ---- */
.reviews-carousel{position:relative}
.rc-viewport{
  overflow:hidden;
  /* feathered edges so cards fade in/out at the sides instead of hard-clipping */
  mask-image:linear-gradient(90deg,transparent 0,#000 4%,#000 96%,transparent 100%);
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 4%,#000 96%,transparent 100%);
}
.rc-track{
  display:flex;flex-direction:column;gap:1.2rem;
}
.rc-row{
  display:flex;gap:1.2rem;
  width:max-content;            /* expand to fit all (duplicated) cards */
  will-change:transform;
}
/* Row 1 scrolls left, Row 2 scrolls right - both continuous */
.rc-row.rc-row-ltr{ animation:rcMarqueeLTR 60s linear infinite; }
.rc-row.rc-row-rtl{ animation:rcMarqueeRTL 70s linear infinite; }

/* The trick: we render the cards twice in JS so translating exactly -50%
   lands on an identical frame -> seamless loop, no jump. */
@keyframes rcMarqueeLTR{
  from{ transform:translate3d(0,0,0); }
  to  { transform:translate3d(-50%,0,0); }
}
@keyframes rcMarqueeRTL{
  from{ transform:translate3d(-50%,0,0); }
  to  { transform:translate3d(0,0,0); }
}

/* Pause on hover only */
.reviews-carousel:hover .rc-row{ animation-play-state:paused; }

/* Lift a card without breaking the marquee */
.review-card{
  flex:0 0 320px;               /* fixed width keeps the loop math stable */
  background:#f4f4f5;border-radius:14px;
  padding:1.6rem 1.5rem;
  display:flex;flex-direction:column;gap:1rem;
  min-height:240px;
  transition:transform .3s ease,box-shadow .3s ease;
}
.review-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(0,0,0,.08)}
.rc-top{display:flex;align-items:center;gap:.65rem;flex-wrap:wrap}
.rc-stars{color:#0a0a14;letter-spacing:.1em;font-size:1rem;font-weight:600}
.verified{
  display:inline-flex;align-items:center;gap:.35rem;
  font-size:.78rem;font-weight:600;color:#0a0a14;
  background:#fff;border-radius:999px;padding:.3rem .65rem;
  border:1px solid rgba(0,0,0,.08);
}
.review-card p{
  flex:1;color:#1f1f29;font-size:.95rem;line-height:1.55;margin:0;
}
.review-card footer{
  font-size:.92rem;font-weight:600;color:#0a0a14;margin-top:auto;
}

/* Arrow controls */
.rc-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:48px;height:48px;border-radius:50%;
  background:#0a0a14;color:#fff;border:none;cursor:pointer;
  font-size:1.6rem;line-height:1;font-weight:600;
  display:grid;place-items:center;z-index:2;
  box-shadow:0 10px 30px rgba(0,0,0,.18);
  transition:transform .25s ease,background .25s ease,opacity .25s;
}
.rc-arrow:hover{background:#23232f;transform:translateY(-50%) scale(1.05)}
.rc-arrow.is-disabled{opacity:.35;pointer-events:none}
.rc-prev{left:-22px}
.rc-next{right:-22px}

@media(max-width:1024px){
  .review-card{flex:0 0 300px}
}
@media(max-width:760px){
  .review-card{flex:0 0 280px;min-height:220px}
  .rc-prev{left:8px}.rc-next{right:8px}
  .rc-arrow{width:40px;height:40px;font-size:1.3rem}
  /* Speed up a touch on small screens so motion stays lively */
  .rc-row.rc-row-ltr{ animation-duration:42s; }
  .rc-row.rc-row-rtl{ animation-duration:48s; }
}
@media(max-width:520px){
  .review-card{flex:0 0 260px;min-height:200px}
}
@media(prefers-reduced-motion:reduce){
  .rc-row{ animation:none !important; }
}

/* =========================================================
   FINAL CTA
   ========================================================= */
.final-cta{position:relative;padding:8rem 1.5rem;overflow:hidden;text-align:center}
.final-bg{position:absolute;inset:0;z-index:0}
.orb-6{width:600px;height:600px;background:#ff5cf0;top:-200px;left:50%;transform:translateX(-50%);opacity:.3}
.orb-7{width:500px;height:500px;background:#7c4dff;bottom:-200px;left:30%;opacity:.3}
.final-inner{position:relative;z-index:1;max-width:900px;margin:0 auto}
.final-inner h2{margin-bottom:1.2rem}
.final-inner p{font-size:1.15rem;margin-bottom:2.4rem}

/* =========================================================
   FOOTER (MoonPay-style)
   ========================================================= */
.footer{
  background:#000;border-top:1px solid var(--line);
  padding:2rem 1.5rem 1rem;color:#cfcfdb;
  font-size:.78rem;
}
.footer-wrap{max-width:1100px;margin:0 auto}

/* Brand row (logo top-left) */
.footer-brand-row{margin-bottom:1.4rem}
.footer-brand-row .logo-img{height:34px}

/* 5-column link grid, 2 rows */
.footer-grid{
  display:grid;grid-template-columns:repeat(5,1fr);
  gap:1rem 1.2rem;
}
.footer-col{display:flex;flex-direction:column;gap:.3rem}
.footer-col h4{
  font-family:'Sora','Inter',sans-serif;
  font-size:.78rem;font-weight:600;color:#fff;
  margin-bottom:.25rem;letter-spacing:0;
  text-transform:none;
}
.footer-col a{
  font-size:.72rem;color:#8c8c9a;font-weight:400;
  display:inline-flex;align-items:center;gap:.4rem;
  transition:color .2s ease;
}
.footer-col a:hover{color:#fff}

/* "New!" / "We're hiring" pill tags */
.tag{
  font-size:.55rem;font-weight:700;
  padding:.14rem .35rem;border-radius:5px;letter-spacing:.02em;
  display:inline-block;line-height:1;
}
.tag-purple{background:#7c4dff;color:#fff}
.tag-violet{background:#7c4dff;color:#fff}

/* Social row */
.footer-social-row{
  display:flex;align-items:center;justify-content:space-between;
  margin:1.4rem 0 .9rem;flex-wrap:wrap;gap:.8rem;
}
.socials{display:flex;gap:.9rem;align-items:center}
.soc-ico{
  color:#fff;display:inline-grid;place-items:center;
  width:26px;height:26px;border-radius:6px;
  transition:transform .25s ease,color .25s ease;
}
.soc-ico svg{width:16px;height:16px}
.soc-ico:hover{transform:translateY(-3px);color:var(--primary-2)}
.lang{
  display:inline-flex;align-items:center;gap:.45rem;
  font-size:.78rem;color:#cfcfdb;
}
.lang svg{width:16px;height:16px}

/* Footer language switcher (made clickable, opens upward via JS) */
.footer-globe.lang-btn{
  /* Reset inherited header .lang-btn pill styles so it looks like a footer link */
  padding:.45rem .8rem;
  height:auto;
  min-width:0;
  font-size:.78rem;
  font-weight:500;
  letter-spacing:0;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.10);
  border-radius:999px;
  color:#cfcfdb;
  text-decoration:none;
  cursor:pointer;
  transition:background .2s ease, border-color .2s ease, color .2s ease, transform .2s ease;
}
.footer-globe.lang-btn:hover{
  background:rgba(255,255,255,.08);
  border-color:rgba(255,255,255,.22);
  color:#fff;
}
.footer-globe.lang-btn .footer-globe-label{
  display:inline-block;
}
.footer-globe.lang-btn svg{width:16px;height:16px;flex-shrink:0}
.footer-globe.lang-btn.is-open{
  background:rgba(124,77,255,.16);
  border-color:rgba(124,77,255,.45);
  color:#fff;
}

/* Newsletter + stores row */
.footer-bottom-row{
  display:grid;grid-template-columns:1fr auto;gap:2.5rem;align-items:start;
  padding-top:2rem;border-top:1px solid var(--line);
}

.newsletter{display:flex;flex-direction:column;gap:.85rem;max-width:560px}
.newsletter .nl-row,
.newsletter{position:relative}
.newsletter input[type="email"]{
  width:100%;padding:1rem 7.5rem 1rem 1.1rem;
  background:#15151c;border:1px solid var(--line);border-radius:10px;
  color:#fff;font-family:inherit;font-size:.95rem;outline:none;
  transition:border-color .25s,background .25s;
}
.newsletter input[type="email"]::placeholder{color:#7d7d8e}
.newsletter input[type="email"]:focus{border-color:rgba(124,77,255,.55);background:#1a1a24}
.newsletter button{
  position:absolute;top:.4rem;right:.4rem;
  padding:.7rem 1.1rem;border:none;border-radius:8px;
  background:#2a2a36;color:#fff;font-weight:600;cursor:pointer;
  transition:background .25s,transform .25s;
}
.newsletter button:hover{background:var(--grad);transform:translateY(-1px)}
.newsletter button[disabled]{cursor:not-allowed;opacity:.85;transform:none}
.newsletter button[disabled]:hover{background:#2a2a36;transform:none}

/* Spinner inside the Subscribe button */
.nl-spinner{
  display:none;
  width:14px;height:14px;
  border:2px solid rgba(255,255,255,.35);
  border-top-color:#fff;
  border-radius:50%;
  margin-left:.5rem;
  vertical-align:middle;
  animation:nlSpin .7s linear infinite;
}
.newsletter button.is-loading .nl-spinner{display:inline-block}
.newsletter button.is-loading .nl-btn-label{opacity:.75}
@keyframes nlSpin{ to { transform:rotate(360deg); } }

/* Status message under the button */
.nl-status{
  margin:0;
  min-height:1em;
  font-size:.8rem;
  font-weight:500;
  color:#8c8c9a;
  transition:color .25s ease;
}
.nl-status.is-success{color:#2ee6a6}
.nl-status.is-error{color:#ff6b8a}
.nl-status.is-info{color:#c79bff}

/* Success state: green tinted button */
.newsletter button.is-success{
  background:linear-gradient(135deg,#1ec48a,#2ee6a6) !important;
  color:#04130c;
}
.newsletter button.is-success:hover{transform:none}

/* Restricted state: muted/disabled look */
.newsletter button.is-restricted{
  background:#3a1f2a !important;
  color:#ff8aa3;
}

.consent{
  display:flex;align-items:flex-start;gap:.65rem;
  font-size:.78rem;color:#8c8c9a;line-height:1.45;
  cursor:pointer;
}
.consent input[type="checkbox"]{
  appearance:none;-webkit-appearance:none;
  width:16px;height:16px;border:1px solid #555;border-radius:4px;
  flex-shrink:0;margin-top:2px;background:#15151c;cursor:pointer;
  display:grid;place-items:center;transition:background .2s,border-color .2s;
}
.consent input[type="checkbox"]:checked{background:var(--primary);border-color:var(--primary)}
.consent input[type="checkbox"]:checked::after{
  content:"\2713";color:#fff;font-size:.7rem;font-weight:700;
}

.consent a{color:#cfcfdb;text-decoration:underline}

/* Store buttons */
.stores{display:flex;gap:.75rem;align-items:center}
.store-btn{
  display:inline-flex;align-items:center;gap:.65rem;
  padding:.6rem 1rem;border-radius:10px;
  background:#fff;color:#000;
  transition:transform .25s ease,box-shadow .25s ease;
}
.store-btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(255,255,255,.08)}
.store-btn .store-text{display:flex;flex-direction:column;line-height:1.05;text-align:left}
.store-btn small{font-size:.65rem;text-transform:uppercase;letter-spacing:.04em;opacity:.85}
.store-btn strong{font-family:'Sora','Inter';font-size:1.05rem;font-weight:700}

/* Copyright */
.footer-copy{
  margin-top:1rem;padding-top:.8rem;border-top:1px solid var(--line);
  font-size:.65rem;color:#6c6c7a;text-align:center;
}
.footer .logo-tagline{font-size:.5rem;letter-spacing:.28em;margin-left:2px}

/* =========================================================
   LANGUAGE SWITCHER (nav globe + dropdown)
   ========================================================= */
.lang-switcher{
  position:relative;
  margin-left:auto;
  display:inline-flex;
  align-items:center;
}
/* Old nav-cta margin override removed - now handled in NAV section */

.lang-btn{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.45rem .75rem;
  /* Override the bare .nav-globe sizing so the pill grows to fit
     the globe icon + "EN" badge instead of being clipped to a 34px circle. */
  width:auto;
  min-width:0;
  height:auto;
  border-radius:999px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
  color:#fff;
  font:600 .82rem 'Inter',sans-serif;
  cursor:pointer;
  transition:background .25s ease,border-color .25s ease,transform .2s ease;
}
.lang-btn:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.22)}
.lang-btn:active{transform:scale(.97)}
.lang-btn .lang-current{
  max-width:7.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
}
.lang-btn .lang-caret{
  transition:transform .3s cubic-bezier(.4,0,.2,1);
  opacity:.85;
}
.lang-btn.is-open .lang-caret{transform:rotate(180deg)}
.lang-btn.is-open{
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.3);
}

/* Dropdown panel */
.lang-panel{
  position:absolute;top:calc(100% + .65rem);right:0;
  width:280px;
  background:#0f0f17;
  border:1px solid var(--line);
  border-radius:18px;
  padding:1.1rem 1rem 1rem;
  box-shadow:0 24px 60px rgba(0,0,0,.55),0 4px 16px rgba(0,0,0,.4);
  opacity:0;visibility:hidden;
  transform:translateY(-8px) scale(.97);
  transform-origin:top right;
  transition:opacity .22s ease,transform .25s cubic-bezier(.34,1.56,.64,1),visibility .22s;
  z-index:60;
}
.lang-panel.is-open{
  opacity:1;visibility:visible;
  transform:translateY(0) scale(1);
}
.lang-head{
  font:700 1.05rem 'Sora','Inter',sans-serif;
  color:#fff;
  margin:.1rem 0 .8rem .25rem;
  letter-spacing:-.01em;
}

/* Option rows (matches the "English  >" tile from MoonPay's panel) */
.lang-list{
  display:flex;flex-direction:column;gap:.4rem;
  max-height:18rem;overflow-y:auto;
  padding-right:.15rem;
}
.lang-list::-webkit-scrollbar{width:6px}
.lang-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:6px}

.lang-option{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;
  padding:.85rem 1rem;
  border-radius:12px;
  background:rgba(255,255,255,.05);
  border:1px solid transparent;
  color:#e8e8f0;
  font:600 .95rem 'Inter',sans-serif;
  text-align:left;cursor:pointer;
  transition:background .2s ease,border-color .2s ease,transform .15s ease,color .2s;
}
.lang-option:hover{
  background:rgba(255,255,255,.09);
  border-color:rgba(255,255,255,.14);
  transform:translateX(2px);
}
.lang-option:active{transform:translateX(2px) scale(.99)}
.lang-option svg{
  opacity:.55;transition:transform .25s ease,opacity .2s ease;
  color:#cfcfdb;
}
.lang-option:hover svg{transform:translateX(3px);opacity:1}
.lang-option.is-selected{
  background:linear-gradient(135deg,rgba(124,77,255,.22),rgba(255,92,240,.18));
  border-color:rgba(124,77,255,.55);
  color:#fff;
}
.lang-option.is-selected svg{opacity:1;color:#fff}

/* Mobile: hide nav switcher's text label, keep just the globe; panel slides up from bottom */
@media(max-width:820px){
  .lang-switcher{margin-left:0;order:2}
  .lang-btn .lang-current{display:none}
  .lang-btn{padding:.5rem}
  .lang-panel{
    position:fixed;
    top:auto;bottom:1rem;
    right:1rem;left:1rem;
    width:auto;
  }
}

/* Hide old language switcher in header since we replaced it with globe icon */
header .lang-switcher{display:none}

/* =========================================================
   FLOATING TELEGRAM SUPPORT BANNER (small + bouncy)
   ========================================================= */
.tg-support{
  position:fixed;
  right:1.1rem;
  bottom:1.1rem;
  z-index:90;
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  /* tighter padding -> overall pill is shorter */
  padding:.32rem .8rem .32rem .32rem;
  border-radius:999px;
  background:linear-gradient(135deg,#7c4dff 0%,#9d6bff 60%,#b58cff 100%);
  color:#fff;
  text-decoration:none;
  font-family:'Inter',sans-serif;
  box-shadow:
    0 10px 22px rgba(124,77,255,.42),
    0 3px 10px rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:saturate(180%) blur(8px);
  transition:transform .25s cubic-bezier(.34,1.56,.64,1),
             box-shadow .3s ease;
  /* Entry pop + continuous bounce loop after */
  animation:
    tgIn .65s cubic-bezier(.34,1.56,.64,1) .4s both,
    tgBounce 1.6s cubic-bezier(.5,0,.5,1) .4s infinite;
  transform-origin:50% 100%;
  isolation:isolate;
  will-change:transform;
}
.tg-support:hover{
  /* on hover, halt the loop and pop up a bit */
  animation:tgIn .45s cubic-bezier(.34,1.56,.64,1) both;
  transform:translateY(-4px) scale(1.06);
  box-shadow:
    0 16px 32px rgba(124,77,255,.55),
    0 5px 14px rgba(0,0,0,.3);
}
.tg-support:active{transform:translateY(-1px) scale(.96)}

/* Subtle ping/pulse ring sized to the smaller icon */
.tg-pulse{
  position:absolute;
  left:.32rem;top:50%;
  width:30px;height:30px;
  margin-top:-15px;
  border-radius:50%;
  background:#7c4dff;
  opacity:.55;
  z-index:-1;
  animation:tgPulse 1.8s ease-out infinite;
}
@keyframes tgPulse{
  0%  { transform:scale(.8);  opacity:.55; }
  70% { transform:scale(1.9); opacity:0;   }
  100%{ transform:scale(1.9); opacity:0;   }
}

/* Smaller icon disc */
.tg-icon{
  display:inline-grid;place-items:center;
  width:30px;height:30px;flex-shrink:0;
  border-radius:50%;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.26);
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
}
.tg-icon svg{
  width:16px;height:16px;
  transform:translateX(-.5px);
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
}
.tg-support:hover .tg-icon{transform:rotate(-12deg) scale(1.1)}
.tg-support:hover .tg-icon svg{transform:translate(2px,-1px)}

/* Smaller text block */
.tg-text{
  display:flex;flex-direction:column;line-height:1;
  padding-right:.15rem;
}
.tg-text strong{
  font-family:'Sora','Inter',sans-serif;
  font-weight:700;
  font-size:.78rem;
  letter-spacing:-.01em;
}
.tg-text small{
  font-size:.62rem;
  font-weight:500;
  opacity:.92;
  margin-top:2px;
}

/* Pop-in entry */
@keyframes tgIn{
  0%  { opacity:0; transform:translateY(24px) scale(.6); }
  60% { opacity:1; transform:translateY(-6px) scale(1.08); }
  100%{ opacity:1; transform:translateY(0)    scale(1);    }
}

/* Continuous bounce + tiny squash so it feels alive */
@keyframes tgBounce{
  0%,100% { transform:translateY(0)    scale(1,1);     }
  15%     { transform:translateY(0)    scale(1.06,.94);}  /* squash */
  35%     { transform:translateY(-10px) scale(.96,1.06);} /* stretch up */
  55%     { transform:translateY(0)    scale(1.04,.96);}  /* land squash */
  70%     { transform:translateY(-3px) scale(.99,1.01);}  /* small rebound */
  85%     { transform:translateY(0)    scale(1,1);     }
}

/* Mobile: shrink even more, icon-only chip */
@media(max-width:560px){
  .tg-support{
    right:.85rem;
    bottom:.85rem;
    padding:.28rem;
    gap:0;
  }
  .tg-text{
    max-width:0;
    overflow:hidden;
    opacity:0;
    transition:max-width .35s ease,opacity .25s ease,margin .35s ease;
    margin-left:0;
  }
  .tg-support:hover .tg-text,
  .tg-support:focus-visible .tg-text{
    max-width:140px;
    opacity:1;
    margin-left:.45rem;
    padding-right:.35rem;
  }
}

/* Reduced motion: kill bounce/pulse */
@media(prefers-reduced-motion:reduce){
  .tg-support,
  .tg-pulse,
  .tg-icon,
  .tg-icon svg{
    animation:none !important;
    transition:none !important;
  }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:1024px){
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .reviews-grid{grid-template-columns:repeat(2,1fr)}
  .band-stats{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(3,1fr)}
  .footer-bottom-row{grid-template-columns:1fr;gap:1.6rem}
  .stores{flex-wrap:wrap}
  .showcase-grid{grid-template-columns:1fr}
  .show-art{height:280px}
}
@media(max-width:820px){
  .nav-cta{display:none}
  .nav-burger{
    display:flex;
    margin-left:auto;        /* push burger to the far right on mobile */
  }
  .nav-links{display:none}

  /* Tighten the header on small screens so logo sits left, burger sits right */
  .nav-inner{
    padding:.7rem 1rem;
    gap:.75rem;
  }

  /* Slide-in mobile panel */
  .nav-links{
    position:fixed;top:0;right:0;height:100dvh;width:min(82vw,360px);
    flex-direction:column;align-items:flex-start;gap:0;
    background:linear-gradient(180deg,#0d0d14 0%,#07070b 100%);
    border-left:1px solid var(--line);
    padding:6rem 1.6rem 2rem;margin-left:0;z-index:55;
    transform:translateX(105%);transition:transform .4s cubic-bezier(.6,.05,.2,1);
    box-shadow:-30px 0 60px rgba(0,0,0,.5);
    overflow-y:auto;
  }
  .nav-links.is-open{display:flex;transform:translateX(0)}
  .nav-group,
  .nav-group-right{
    flex-direction:column;align-items:flex-start;
    gap:0;width:100%;margin-left:0;
  }
  .nav-links a{
    font-size:1.15rem;font-weight:600;padding:.85rem 0;width:100%;
    border-bottom:1px solid var(--line);color:#fff;
  }
  .nav-links a:last-of-type{border-bottom:none}
  /* The .mobile-cta items (Get Started + language pill) are pill-style
     buttons - undo the underline border applied to nav-links anchors. */
  .nav-links .mobile-cta a{border-bottom:none;padding:0;width:auto}
  .nav-links .mobile-cta .btn{padding:.75rem 1.15rem;width:100%}
  .nav-grid{
    width:100%;height:auto;border-radius:0;
    background:transparent;border:none;
    padding:.85rem 0;font-size:1.15rem;font-weight:600;
    justify-content:flex-start;
  }
  .mobile-cta{
    display:flex;flex-direction:column;gap:.6rem;width:100%;margin-top:1.4rem;
  }
  .mobile-cta .btn{width:100%}

  /* Translator pill in the slide-out mobile menu (sits under "Get Started") */
  .mobile-cta .mobile-lang-btn{
    /* Cancel the bare .nav-globe pill sizing */
    width:100%;
    height:auto;
    min-width:0;
    padding:.85rem 1.15rem;
    border-radius:999px;
    background:rgba(255,255,255,.04);
    border:1px solid var(--line);
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:.6rem;
    color:#fff;
    font:600 .95rem 'Inter',sans-serif;
    text-decoration:none;
    transition:background .25s ease,border-color .25s ease,transform .2s ease;
  }
  .mobile-cta .mobile-lang-btn:hover{
    background:rgba(255,255,255,.08);
    border-color:rgba(255,255,255,.22);
  }
  .mobile-cta .mobile-lang-btn:active{transform:scale(.98)}
  .mobile-cta .mobile-lang-btn svg{
    width:18px;height:18px;flex-shrink:0;color:#fff;
  }
  .mobile-cta .mobile-lang-btn .mobile-lang-label{
    color:#fff;letter-spacing:.01em;
  }
  .mobile-cta .mobile-lang-btn.is-open{
    background:rgba(124,77,255,.16);
    border-color:rgba(124,77,255,.45);
  }

  .hero{grid-template-columns:1fr;padding-top:7rem;text-align:left}
  .hero-phone{order:-1;margin-bottom:1rem;transform:scale(.85)}
  .hero-stats{gap:1.6rem}
}
@media(max-width:560px){
  .feature-grid,.reviews-grid,.band-stats{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero-title{font-size:1.9rem}
  .hero-sub{font-size:.92rem}
  h2{font-size:1.7rem}
  .footer-social-row{flex-direction:column;align-items:flex-start}
  .newsletter input[type="email"]{padding-right:1.1rem}
  .newsletter button{position:static;width:100%;margin-top:.5rem}
  .store-btn{flex:1;justify-content:center}
}
