/* ===== STONHUB shared stylesheet ===== */
:root{
  --bg:#04070e;
  --bg-2:#070d1a;
  --navy:#0c1a33;
  --navy-deep:#060b16;
  --blue:#2f7dff;
  --blue-bright:#4f9dff;
  --blue-glow:#1e63e0;
  --cyan:#5fd0ff;
  --ink:#e8eefc;
  --muted:#8896b5;
  --muted-2:#566488;
  --line:rgba(120,160,255,.12);
  --line-2:rgba(120,160,255,.22);
  --card:rgba(16,28,52,.5);
  --good:#4fe39a;
  --warn:#ffb84f;
  --bad:#ff6b6b;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',sans-serif;background:var(--bg);color:var(--ink);
  overflow-x:hidden;-webkit-font-smoothing:antialiased;line-height:1.5;
}
::selection{background:var(--blue);color:#fff}
a{color:inherit}
img{display:block;max-width:100%}

/* ===== ambient bg: soft gradient, NO grid ===== */
.ambient{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.ambient .g1,.ambient .g2,.ambient .g3{position:absolute;border-radius:50%;filter:blur(60px)}
.ambient .g1{top:-15%;left:50%;transform:translateX(-50%);width:1100px;height:850px;
  background:radial-gradient(ellipse at center,rgba(47,125,255,.20),transparent 62%);
  animation:drift1 22s ease-in-out infinite alternate}
.ambient .g2{bottom:-25%;right:-12%;width:820px;height:820px;
  background:radial-gradient(ellipse at center,rgba(95,208,255,.12),transparent 60%);
  animation:drift2 28s ease-in-out infinite alternate}
.ambient .g3{top:35%;left:-15%;width:700px;height:700px;
  background:radial-gradient(ellipse at center,rgba(30,99,224,.14),transparent 60%);
  animation:drift3 26s ease-in-out infinite alternate}
@keyframes drift1{to{transform:translateX(-50%) translateY(60px) scale(1.08)}}
@keyframes drift2{to{transform:translate(-50px,-40px) scale(1.12)}}
@keyframes drift3{to{transform:translate(60px,30px) scale(1.1)}}

/* ===== particles (lebih hidup) ===== */
#particles{position:fixed;inset:0;z-index:0;pointer-events:none}

.wrap{position:relative;z-index:2;max-width:1180px;margin:0 auto;padding:0 28px}

/* ===== nav ===== */
nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;
  justify-content:space-between;padding:18px 36px;backdrop-filter:blur(14px);
  background:linear-gradient(180deg,rgba(4,7,14,.85),rgba(4,7,14,0));
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s}
nav.scrolled{border-bottom:1px solid var(--line);background:rgba(4,7,14,.94)}
.brand{display:flex;align-items:center;gap:10px;font-family:'Space Grotesk';font-weight:700;
  font-size:19px;letter-spacing:-.02em;text-decoration:none;color:var(--ink)}
.brand .mark svg{width:26px;height:26px;display:block}
.brand b{color:var(--blue-bright)}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{color:var(--muted);text-decoration:none;font-size:14px;font-weight:500;transition:color .2s}
.nav-links a:hover{color:var(--ink)}
.nav-cta{background:var(--blue);color:#fff;padding:9px 18px;border-radius:100px;font-size:13.5px;
  font-weight:600;text-decoration:none;box-shadow:0 0 0 1px rgba(95,157,255,.4),0 8px 24px -8px var(--blue-glow);
  transition:transform .2s,box-shadow .2s}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 0 0 1px rgba(95,157,255,.6),0 12px 32px -8px var(--blue-glow)}
.nav-toggle{display:none;background:none;border:none;color:var(--ink);font-size:22px;cursor:pointer}
@media(max-width:880px){.nav-links{position:fixed;inset:64px 0 auto 0;flex-direction:column;gap:0;
  background:rgba(4,7,14,.98);border-bottom:1px solid var(--line);padding:8px 0;transform:translateY(-120%);
  transition:transform .3s}.nav-links.open{transform:none}.nav-links a{padding:14px 36px;width:100%}
  .nav-links .nav-cta{margin:8px 36px;text-align:center}.nav-toggle{display:block}}

/* ===== buttons ===== */
.btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--blue);color:#fff;
  text-decoration:none;padding:14px 24px;border-radius:100px;font-weight:600;font-size:15px;border:none;cursor:pointer;
  box-shadow:0 0 0 1px rgba(95,157,255,.4),0 14px 40px -12px var(--blue-glow);transition:transform .2s,box-shadow .2s}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 0 1px rgba(95,157,255,.7),0 20px 50px -12px var(--blue-glow)}
.btn-primary .arrow{width:24px;height:24px;border-radius:50%;background:#fff;color:var(--blue);
  display:grid;place-items:center;font-size:13px}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;color:var(--ink);text-decoration:none;
  padding:14px 22px;border-radius:100px;font-weight:500;font-size:15px;border:1px solid var(--line);
  background:rgba(255,255,255,.02);cursor:pointer;transition:border-color .2s,background .2s}
.btn-ghost:hover{border-color:var(--line-2);background:rgba(47,125,255,.08)}

/* ===== section heads ===== */
section.block{position:relative;padding:110px 0}
.sec-eyebrow{font-family:'JetBrains Mono';font-size:12px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--blue-bright);margin-bottom:16px}
.sec-head{max-width:62ch;margin-bottom:52px}
.sec-head h2{font-family:'Space Grotesk';font-weight:700;font-size:clamp(32px,5vw,52px);
  line-height:1.05;letter-spacing:-.03em}
.sec-head h2 .em{color:var(--blue-bright)}
.sec-head p{margin-top:18px;color:var(--muted);font-size:16.5px;line-height:1.6;max-width:54ch}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:'JetBrains Mono';font-size:12px;
  letter-spacing:.08em;text-transform:uppercase;color:var(--cyan);border:1px solid var(--line);
  border-radius:100px;padding:6px 14px;width:fit-content;background:rgba(47,125,255,.06)}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--cyan);
  box-shadow:0 0 10px var(--cyan);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ===== reveal ===== */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:none}

.tag{display:inline-block;padding:3px 10px;border-radius:100px;font-size:11.5px;font-family:'JetBrains Mono';
  background:rgba(47,125,255,.14);color:var(--cyan);border:1px solid var(--line)}

/* ===== footer ===== */
footer{border-top:1px solid var(--line);padding:50px 0 40px;margin-top:40px;position:relative;z-index:2}
.foot{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:30px}
.foot-col h5{font-family:'Space Grotesk';font-size:14px;margin-bottom:14px;color:var(--ink)}
.foot-col a{display:block;color:var(--muted);text-decoration:none;font-size:14px;margin-bottom:9px;transition:color .2s}
.foot-col a:hover{color:var(--ink)}
.foot-copy{color:var(--muted-2);font-size:12.5px;font-family:'JetBrains Mono';margin-top:36px;
  border-top:1px solid var(--line);padding-top:24px}

@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* ============ FUTURISTIC UPGRADE ============ */

/* scanline overlay */
.scanline{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.5;
  background:repeating-linear-gradient(0deg,rgba(95,208,255,.025) 0 1px,transparent 1px 3px)}
.scanbeam{position:fixed;left:0;right:0;height:140px;z-index:1;pointer-events:none;
  background:linear-gradient(180deg,transparent,rgba(47,125,255,.06),transparent);
  animation:beam 7s linear infinite}
@keyframes beam{0%{top:-140px}100%{top:100%}}

/* hex grid faint texture (NOT square grid) */
.hexfield{position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.06;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='56' height='100' viewBox='0 0 56 100'%3E%3Cg fill='none' stroke='%235fd0ff' stroke-width='1'%3E%3Cpath d='M28 0 L56 16 V50 L28 66 L0 50 V16 Z'/%3E%3Cpath d='M28 66 L56 82 V116 M28 66 L0 82 V116'/%3E%3C/g%3E%3C/svg%3E");
  mask-image:radial-gradient(ellipse at 50% 40%,#000,transparent 75%)}

/* nav: CA pill + pumpfun btn */
.nav-meta{display:flex;align-items:center;gap:10px}
.ca-pill{display:inline-flex;align-items:center;gap:8px;font-family:'JetBrains Mono';font-size:12px;
  border:1px solid var(--line);border-radius:100px;padding:7px 12px;background:rgba(8,16,32,.6);
  color:var(--muted);cursor:pointer;transition:border-color .2s,color .2s}
.ca-pill:hover{border-color:var(--line-2);color:var(--ink)}
.ca-pill .lbl{color:var(--muted-2)}
.ca-pill .val{color:var(--cyan)}
.ca-pill .cp{opacity:.6}
.pump-btn{display:inline-flex;align-items:center;gap:8px;text-decoration:none;font-size:13px;font-weight:700;
  font-family:'Space Grotesk';padding:9px 16px;border-radius:100px;color:#0a1426;
  background:linear-gradient(135deg,#7afcc6,#3fe39a);box-shadow:0 0 0 1px rgba(79,227,154,.4),0 8px 24px -8px rgba(63,227,154,.6);
  transition:transform .2s,box-shadow .2s;white-space:nowrap}
.pump-btn:hover{transform:translateY(-1px);box-shadow:0 0 0 1px rgba(79,227,154,.7),0 12px 32px -8px rgba(63,227,154,.8)}
.pump-btn[aria-disabled="true"]{background:rgba(120,160,255,.1);color:var(--muted);box-shadow:0 0 0 1px var(--line);cursor:not-allowed}
.pump-btn svg{width:15px;height:15px}
@media(max-width:1100px){.nav-meta .ca-pill{display:none}}
@media(max-width:880px){.nav-meta{position:fixed;inset:auto 0 0 0;flex-direction:column;display:none}}

/* corner brackets for framed elements */
.framed{position:relative}
.framed::before,.framed::after{content:"";position:absolute;width:18px;height:18px;border:1.5px solid var(--cyan);opacity:.6}
.framed::before{top:-1px;left:-1px;border-right:none;border-bottom:none}
.framed::after{bottom:-1px;right:-1px;border-left:none;border-top:none}

/* glowing data nodes (decorative) */
.node-deco{position:absolute;width:7px;height:7px;border-radius:50%;background:var(--cyan);
  box-shadow:0 0 12px var(--cyan);animation:pulse 2.4s infinite}

/* marquee ticker */
.ticker{overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:rgba(8,16,32,.4);padding:14px 0;position:relative;z-index:2}
.ticker-track{display:flex;gap:48px;width:max-content;animation:scroll 26s linear infinite;
  font-family:'JetBrains Mono';font-size:13px;color:var(--muted);white-space:nowrap}
.ticker-track span b{color:var(--cyan)}
.ticker:hover .ticker-track{animation-play-state:paused}
@keyframes scroll{to{transform:translateX(-50%)}}

/* animated stat counter glow */
.hstat .num{position:relative}

/* HUD rotating ring (hero) */
.hud-ring{position:absolute;width:340px;height:340px;border-radius:50%;
  border:1px dashed rgba(95,208,255,.25);animation:spinslow 40s linear infinite;pointer-events:none}
.hud-ring::before{content:"";position:absolute;inset:26px;border-radius:50%;border:1px solid rgba(47,125,255,.18);}
.hud-ring .tick{position:absolute;top:-1px;left:50%;width:2px;height:10px;background:var(--cyan);box-shadow:0 0 8px var(--cyan)}
@keyframes spinslow{to{transform:rotate(360deg)}}

/* gradient text shimmer for em */
.sec-head h2 .em,h1.hero-title .glow{background-size:200% auto;animation:shimmer 6s linear infinite}
@keyframes shimmer{to{background-position:200% center}}

/* glass reflection sweep on cards */
.feat,.util,.panel,.tm{position:relative}
.feat::before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(120deg,transparent 40%,rgba(255,255,255,.04) 50%,transparent 60%);
  background-size:250% 100%;background-position:200% 0;transition:none}
.feat:hover::before{animation:sweep 1s ease}
@keyframes sweep{to{background-position:-50% 0}}
