/* =========================================================
   Ghost Dog — $GDOG  ·  Spectral meme token on Phantasma
   Dark "haunted" theme. Spectral-blue glow, violet mist, mono ticker.
   Vanilla CSS, zero build. Sibling-in-spirit to PoPi, its own beast.
   ========================================================= */
:root{
  --bg:#0a0712;             /* haunted near-black violet */
  --bg-2:#0e0a1a;
  --surface:#15102450;      /* glassy card fill */
  --surface-solid:#161024;
  --line:rgba(150,200,255,.12);
  --line-2:rgba(255,255,255,.08);

  --ink:#ece8f7;            /* primary text */
  --ink-2:#9a93b4;          /* muted text */

  --ecto:#5cb8ff;           /* primary ghost blue */
  --ecto-2:#3a9bff;         /* deeper blue */
  --ecto-soft:#122a48;
  --cyan:#57e8ff;
  --violet:#b69cff;
  --rose:#ff7fa8;           /* tiny warm accent (tongue/cheeks) */

  --radius:20px;
  --shadow-sm:0 8px 24px -14px rgba(0,0,0,.7);
  --shadow:0 30px 70px -30px rgba(0,0,0,.85), 0 0 0 1px var(--line);
  --glow:0 0 28px -2px rgba(92,184,255,.55);
  --glow-strong:0 0 50px -4px rgba(92,184,255,.75);

  --ease:cubic-bezier(.22,.61,.36,1);
  --maxw:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:"Plus Jakarta Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  line-height:1.65;overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
body.intro-active{overflow:hidden;height:100vh}
a{color:inherit;text-decoration:none}
h1,h2,h3{margin:0;line-height:1.04;font-family:"Space Grotesk",sans-serif;font-weight:700;letter-spacing:-.02em}
img{max-width:100%;display:block}
.mono{font-family:"Space Mono",monospace}
::selection{background:var(--ecto);color:#04111f}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  padding:.9rem 1.7rem;border-radius:999px;cursor:pointer;
  font-family:"Space Grotesk",sans-serif;font-weight:600;font-size:1rem;letter-spacing:.01em;
  border:1px solid transparent;transition:transform .25s var(--ease),box-shadow .3s,background .3s,border-color .3s,color .3s;
  will-change:transform;
}
.btn-primary{background:linear-gradient(120deg,var(--ecto),var(--ecto-2));color:#04111f;box-shadow:var(--glow)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--glow-strong)}
.btn-ghost{background:rgba(255,255,255,.03);color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{transform:translateY(-2px);border-color:var(--ecto);color:var(--ecto);box-shadow:0 0 24px -6px rgba(92,184,255,.4)}

/* =========================================================
   SUMMONING VEIL  (intro): sigil charges → eyes wake → veil implodes
   ========================================================= */
.veil{position:fixed;inset:0;z-index:1000;background:radial-gradient(120% 120% at 50% 40%,#120c22 0%,#070510 70%);overflow:hidden;
  clip-path:circle(150% at 50% 50%);transition:clip-path 1s var(--ease),opacity .55s ease,filter .8s ease;will-change:clip-path,opacity}
.veil.is-open{clip-path:circle(0% at 50% 50%);opacity:0;filter:blur(10px)}
.veil.is-gone{display:none}
.veil-fog{position:absolute;inset:-20%;pointer-events:none;opacity:.6;filter:blur(6px);
  background:
    radial-gradient(40% 50% at 20% 30%,rgba(92,184,255,.10),transparent 60%),
    radial-gradient(45% 55% at 82% 26%,rgba(182,156,255,.12),transparent 60%),
    radial-gradient(60% 60% at 50% 100%,rgba(87,232,255,.08),transparent 60%);
  animation:fog 16s ease-in-out infinite alternate}
@keyframes fog{to{transform:translate3d(0,-3%,0) scale(1.08)}}
.veil.is-flash{filter:brightness(1.9) saturate(1.3)}

/* low, rolling ground fog */
.veil-fog--low{inset:auto -25% -12% -25%;height:60%;opacity:.55;filter:blur(16px);
  background:
    radial-gradient(60% 120% at 28% 100%,rgba(150,200,255,.16),transparent 70%),
    radial-gradient(55% 120% at 72% 100%,rgba(182,156,255,.16),transparent 70%),
    radial-gradient(42% 110% at 50% 100%,rgba(87,232,255,.12),transparent 70%);
  animation:rollfog 20s ease-in-out infinite alternate}
@keyframes rollfog{0%{transform:translateX(-5%)}100%{transform:translateX(6%)}}

/* lightning flash overlay + bolt — triggered by .flash on the veil */
.veil-lightning{position:absolute;inset:0;z-index:2;pointer-events:none;opacity:0;mix-blend-mode:screen;
  background:
    radial-gradient(70% 55% at 50% -5%,rgba(206,234,255,.95),transparent 60%),
    linear-gradient(180deg,rgba(150,200,255,.45),transparent 45%)}
.veil-bolt{position:absolute;top:-2%;left:40%;width:min(160px,26vw);height:64%;z-index:2;opacity:0;pointer-events:none;
  fill:rgba(224,242,255,.96);filter:drop-shadow(0 0 14px rgba(150,200,255,.9)) drop-shadow(0 0 30px rgba(92,184,255,.7))}
.veil.flash .veil-lightning{animation:lightning .85s ease-out}
.veil.flash .veil-bolt{animation:bolt .85s ease-out}
.veil.flash .veil-ui{animation:shudder .85s ease}
@keyframes lightning{0%{opacity:0}3%{opacity:.95}8%{opacity:.2}13%{opacity:.8}22%{opacity:0}100%{opacity:0}}
@keyframes bolt{0%,100%{opacity:0}3%{opacity:1}9%{opacity:.15}13%{opacity:.85}24%{opacity:0}}
@keyframes shudder{0%,100%{filter:none;transform:none}4%{filter:blur(2px) brightness(1.5);transform:translate(2px,-1px)}9%{filter:blur(0);transform:translate(-2px,1px)}14%{filter:blur(1.5px)}20%{filter:none;transform:none}}

.veil-ui{position:absolute;inset:0;z-index:3;display:grid;place-content:center;justify-items:center;text-align:center;padding:1.5rem;
  transition:opacity .5s ease,transform .6s var(--ease)}
.veil.is-open .veil-ui{opacity:0;transform:scale(.94)}

.summon{position:relative;width:220px;height:220px;display:grid;place-items:center;margin-bottom:.4rem}
.summon-ring,.summon-sigil{position:absolute;inset:0;width:100%;height:100%}
.sr-track{fill:none;stroke:rgba(255,255,255,.07);stroke-width:3}
.sr-prog{fill:none;stroke:var(--ecto);stroke-width:3;stroke-linecap:round;
  stroke-dasharray:540;stroke-dashoffset:540;transform:rotate(-90deg);transform-origin:center;
  transition:stroke-dashoffset .15s linear;filter:drop-shadow(0 0 6px rgba(92,184,255,.8))}
.summon-sigil{fill:none;stroke:rgba(182,156,255,.5);stroke-width:1.2;animation:spin 26s linear infinite}
.summon-sigil .sigil-runes{fill:rgba(92,184,255,.55);stroke:none}
.summon-sigil .sigil-runes circle{fill:none;stroke:rgba(92,184,255,.25);stroke-width:1}
@keyframes spin{to{transform:rotate(360deg)}}
.summon-eyes{position:absolute;display:flex;gap:26px}
.summon-eyes span{width:16px;height:22px;border-radius:50%;background:var(--ecto);
  box-shadow:0 0 18px 3px rgba(92,184,255,.8);animation:wake 2.6s ease-in-out infinite}
.summon-eyes span:last-child{animation-delay:.15s}
@keyframes wake{0%,12%,100%{transform:scaleY(.08);opacity:.5}20%,90%{transform:scaleY(1);opacity:1}}

.veil-mark{width:46px;height:46px;margin:1.4rem 0 .6rem;filter:drop-shadow(0 0 14px rgba(92,184,255,.5))}
.veil-mark svg{width:100%;height:100%}
.veil-title{font-family:"Space Grotesk",sans-serif;font-weight:700;font-size:clamp(3rem,12vw,6.5rem);letter-spacing:-.03em;color:#fff;line-height:.95}
.veil-title b{color:var(--ecto)}
.veil-sub{margin:.5rem 0 0;letter-spacing:.34em;font-size:.7rem;color:var(--ink-2);text-transform:uppercase}
.veil-status{font-family:"Space Mono",monospace;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ecto);min-height:1em;margin:1.6rem 0 1.4rem;opacity:.85}
.veil-actions{display:flex;gap:.8rem;flex-wrap:wrap;justify-content:center}
.veil .btn-primary{opacity:.5;transform:translateY(2px);pointer-events:none;transition:opacity .4s,transform .4s,box-shadow .3s}
.veil.ready .btn-primary{opacity:1;transform:none;pointer-events:auto;animation:breathe 2.4s ease-in-out infinite}
@keyframes breathe{50%{box-shadow:var(--glow-strong)}}
.veil-skip{margin-top:1.1rem;background:none;border:0;color:var(--ink-2);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;opacity:.7;transition:.2s}
.veil-skip:hover{opacity:1;color:var(--ecto)}

/* =========================================================
   BACKDROP (drifting aurora + spirit motes + cursor)
   ========================================================= */
.aurora{position:fixed;inset:0;z-index:-4;pointer-events:none;
  background:
    radial-gradient(40% 44% at 12% 6%,rgba(92,184,255,.12),transparent 60%),
    radial-gradient(44% 48% at 88% 10%,rgba(182,156,255,.12),transparent 60%),
    radial-gradient(54% 52% at 50% 110%,rgba(87,232,255,.10),transparent 60%);
  animation:drift 26s ease-in-out infinite alternate}
@keyframes drift{to{transform:translate3d(0,-2.5%,0) scale(1.06)}}
.cursor-glow{position:fixed;top:0;left:0;z-index:-1;width:460px;height:460px;margin:-230px 0 0 -230px;border-radius:50%;
  pointer-events:none;opacity:0;transition:opacity .4s;
  background:radial-gradient(circle,rgba(92,184,255,.10),transparent 65%)}

/* =========================================================
   NAV
   ========================================================= */
.nav{position:fixed;top:0;left:0;right:0;z-index:80;display:flex;align-items:center;justify-content:space-between;
  padding:1.1rem clamp(1rem,4vw,2.4rem);transition:background .35s,backdrop-filter .35s,padding .35s,box-shadow .35s,border-color .35s;
  border-bottom:1px solid transparent}
.nav.scrolled{background:rgba(10,7,18,.72);backdrop-filter:blur(14px) saturate(1.3);border-bottom-color:var(--line);
  padding-top:.7rem;padding-bottom:.7rem;box-shadow:0 10px 40px -26px rgba(0,0,0,.9)}
.brand{display:inline-flex;align-items:center;gap:.6rem;font-family:"Space Grotesk",sans-serif;font-weight:700;font-size:1.22rem;letter-spacing:-.01em}
.brand-mark{width:30px;height:30px;filter:drop-shadow(0 0 10px rgba(92,184,255,.5))}
.brand-name{color:var(--ink)}.brand-name b{color:var(--ecto)}
.nav-links{display:flex;align-items:center;gap:1.7rem}
.nav-links a{position:relative;font-weight:600;color:var(--ink-2);transition:color .25s}
.nav-links a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;border-radius:2px;background:var(--ecto);transition:width .25s var(--ease);box-shadow:0 0 8px rgba(92,184,255,.8)}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{padding:.5rem 1.2rem;border-radius:999px;color:#04111f !important;background:linear-gradient(120deg,var(--ecto),var(--ecto-2));box-shadow:var(--glow);font-weight:700}
.nav-cta:hover{transform:translateY(-1px)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.nav-toggle span{width:26px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;padding:7rem clamp(1rem,4vw,2.4rem) 4rem;overflow:hidden}
.hero-grid{position:absolute;inset:auto 0 0 0;height:46%;pointer-events:none;opacity:.6;
  background:
    repeating-linear-gradient(90deg,transparent 0 64px,rgba(92,184,255,.10) 64px 65px),
    repeating-linear-gradient(0deg,transparent 0 64px,rgba(182,156,255,.06) 64px 65px);
  transform:perspective(440px) rotateX(66deg);transform-origin:bottom;
  -webkit-mask-image:linear-gradient(to top,#000,transparent);mask-image:linear-gradient(to top,#000,transparent)}
.hero-inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:.5rem;letter-spacing:.26em;font-size:.74rem;color:var(--ink-2);text-transform:uppercase;margin:0 0 1.2rem;font-weight:700}
.eyebrow span{color:var(--ecto)}
.hero-title{font-family:"Space Grotesk",sans-serif;font-weight:700;font-size:clamp(4rem,13vw,9rem);letter-spacing:-.04em;color:#fff;margin-bottom:.4rem}
.hero-title b{color:var(--ecto)}
.shimmer{position:relative;display:inline-block}
.shimmer::after{content:attr(data-text);position:absolute;inset:0;color:#fff;
  -webkit-mask:linear-gradient(110deg,transparent 38%,#000 50%,transparent 62%);mask:linear-gradient(110deg,transparent 38%,#000 50%,transparent 62%);
  -webkit-mask-size:220% 100%;mask-size:220% 100%;animation:shine 6s ease-in-out infinite;mix-blend-mode:overlay}
@keyframes shine{0%,55%{-webkit-mask-position:160% 0;mask-position:160% 0}100%{-webkit-mask-position:-60% 0;mask-position:-60% 0}}
.hero-tag{font-family:"Space Grotesk",sans-serif;font-size:clamp(1.3rem,3vw,2rem);font-weight:600;margin:.2rem 0 1rem;color:var(--ink)}
.hero-tag .grad{background:linear-gradient(100deg,var(--ecto),var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero-desc{color:var(--ink-2);max-width:48ch;font-size:1.06rem;margin:0 0 1.5rem}
.hero-desc strong{color:var(--ink)}.hero-desc b{color:var(--ecto)}

/* copyable contract chip */
.ca{display:inline-flex;align-items:center;gap:.7rem;max-width:100%;margin:0 0 1.6rem;padding:.55rem .55rem .55rem 1rem;
  border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.03);backdrop-filter:blur(6px)}
.ca-label{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ecto);font-weight:700;white-space:nowrap}
.ca-addr{font-family:"Space Mono",monospace;font-size:.82rem;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}
.ca-copy{display:grid;place-items:center;width:34px;height:34px;flex:none;border:0;border-radius:50%;cursor:pointer;
  background:linear-gradient(120deg,var(--ecto),var(--ecto-2));color:#04111f;transition:transform .2s,box-shadow .3s}
.ca-copy:hover{transform:scale(1.06);box-shadow:var(--glow)}
.ca-copy svg{width:16px;height:16px}
.ca.copied{border-color:var(--ecto);box-shadow:var(--glow)}

.hero-actions{display:flex;gap:.9rem;flex-wrap:wrap;margin-bottom:1.8rem}
.hero-platforms{display:flex;align-items:center;gap:1.1rem;flex-wrap:wrap;font-size:.85rem;color:var(--ink-2)}
.hero-platforms span{letter-spacing:.18em;text-transform:uppercase;opacity:.7;font-size:.7rem}
.hero-platforms a{position:relative;color:var(--ink);font-weight:600}
.hero-platforms a:hover{color:var(--ecto)}

/* ---- Hero mascot stage ---- */
.hero-stage{position:relative;justify-self:center;width:min(440px,84vw);aspect-ratio:1/1.06;display:grid;place-items:center}
.ghost-aura{position:absolute;inset:-6%;border-radius:50%;background:radial-gradient(circle at 50% 46%,rgba(92,184,255,.32),transparent 62%);filter:blur(20px);animation:pulse 6s ease-in-out infinite}
@keyframes pulse{50%{opacity:.6;transform:scale(1.07)}}
.ghost-ring{position:absolute;inset:4%;border-radius:50%;border:1.5px dashed rgba(92,184,255,.4);
  -webkit-mask-image:radial-gradient(circle,transparent 64%,#000 65%);mask-image:radial-gradient(circle,transparent 64%,#000 65%);animation:spin 30s linear infinite}
.ghostdog{position:relative;z-index:2;width:100%;height:100%;overflow:visible;cursor:pointer;object-fit:contain;
  filter:drop-shadow(0 18px 40px rgba(92,184,255,.28));animation:float 6s ease-in-out infinite}
@keyframes float{50%{transform:translateY(-14px)}}
.ghostdog.barking{animation:wiggle .5s ease}
@keyframes wiggle{0%,100%{transform:rotate(0)}25%{transform:rotate(-4deg)}75%{transform:rotate(4deg)}}

/* mascot internals (shared by hero + lore) — transform-box keeps SVG origins in viewBox units */
.gd-ear,.gd-eyes,.gd-tail,.gd-tongue,.gd-sparks path{transform-box:view-box}
.gd-ear{transform-origin:104px 100px;animation:earsway 4s ease-in-out infinite}
.gd-ear-r{transform-origin:216px 100px;animation-delay:.4s}
@keyframes earsway{50%{transform:rotate(4deg)}}
.gd-eyes{transform-origin:160px 176px;animation:blink 5.2s infinite}
@keyframes blink{0%,94%,100%{transform:scaleY(1)}97%{transform:scaleY(.08)}}
.gd-tail{transform-origin:240px 270px;animation:wag 1.1s ease-in-out infinite}
@keyframes wag{50%{transform:rotate(16deg)}}
.gd-tongue{transform-origin:160px 232px;animation:pant 1.6s ease-in-out infinite}
@keyframes pant{50%{transform:scaleY(1.18)}}
.gd-sparks path{transform-origin:center;animation:twinkle 3s ease-in-out infinite}
.gd-sparks path:nth-child(2){animation-delay:.7s}
.gd-sparks path:nth-child(3){animation-delay:1.3s}
@keyframes twinkle{0%,100%{opacity:.4;transform:scale(.8)}50%{opacity:1;transform:scale(1.15)}}

/* speech bubble */
.ghost-bubble{position:absolute;top:6%;right:2%;z-index:4;padding:.4rem .9rem;border-radius:14px 14px 14px 2px;
  font-family:"Space Grotesk",sans-serif;font-weight:700;color:#04111f;background:var(--ecto);box-shadow:var(--glow);
  opacity:0;transform:translateY(8px) scale(.8);transition:opacity .25s,transform .25s;pointer-events:none}
.ghost-bubble.show{opacity:1;transform:none}

.scroll-cue{position:absolute;left:50%;bottom:1.6rem;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--ink-2);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;z-index:3}
.scroll-cue span{width:22px;height:34px;border:2px solid var(--line);border-radius:12px;position:relative}
.scroll-cue span::before{content:"";position:absolute;left:50%;top:7px;width:4px;height:7px;margin-left:-2px;border-radius:2px;background:var(--ecto);box-shadow:0 0 8px var(--ecto);animation:wheel 1.6s infinite}
@keyframes wheel{0%{opacity:0;transform:translateY(0)}30%{opacity:1}100%{opacity:0;transform:translateY(12px)}}

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee{border-block:1px solid var(--line);background:linear-gradient(90deg,rgba(92,184,255,.05),rgba(182,156,255,.05));overflow:hidden;padding:.75rem 0}
.marquee-track{display:flex;width:max-content;animation:marq 32s linear infinite;font-family:"Space Grotesk",sans-serif;font-weight:700;letter-spacing:.06em;color:var(--ecto)}
.marquee-group{display:flex;gap:3rem;padding-right:3rem;white-space:nowrap;flex-shrink:0}
.marquee-track span{font-size:.95rem;display:inline-flex;align-items:center;gap:.6rem;flex-shrink:0}
@keyframes marq{to{transform:translateX(-50%)}}

/* =========================================================
   SECTIONS
   ========================================================= */
.section{max-width:var(--maxw);margin:0 auto;padding:clamp(4rem,9vw,7rem) clamp(1rem,4vw,2.4rem)}
.section-head{text-align:center;margin-bottom:3rem}
.kicker{font-family:"Space Mono",monospace;letter-spacing:.28em;font-size:.72rem;color:var(--ecto);text-transform:uppercase;margin:0 0 .8rem}
.section h2{font-size:clamp(2.4rem,6vw,3.8rem);color:#fff}
.section-sub{color:var(--ink-2);margin-top:.7rem;font-size:1.05rem}

/* ---------- Tokenomics ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.stat{position:relative;padding:1.8rem 1.4rem;border:1px solid var(--line);border-radius:18px;background:var(--surface);
  backdrop-filter:blur(8px);text-align:center;overflow:hidden;transition:transform .3s var(--ease),border-color .3s,box-shadow .3s}
.stat::before{content:"";position:absolute;inset:0;background:radial-gradient(80% 60% at 50% 0%,rgba(92,184,255,.10),transparent 70%);opacity:0;transition:opacity .3s}
.stat:hover{transform:translateY(-6px);border-color:var(--ecto);box-shadow:var(--glow)}
.stat:hover::before{opacity:1}
.stat-ico{font-size:1.6rem;display:block;margin-bottom:.6rem}
.stat-num{font-family:"Space Grotesk",sans-serif;font-weight:700;font-size:clamp(1.6rem,4vw,2.4rem);color:#fff;display:block;line-height:1}
.stat-text{color:var(--ecto)}
.stat-label{display:block;margin-top:.5rem;font-weight:700;color:var(--ecto);font-size:.92rem;letter-spacing:.02em}
.stat-note{display:block;margin-top:.35rem;font-size:.8rem;color:var(--ink-2)}
.token-disclaimer{text-align:center;color:var(--ink-2);font-size:.86rem;margin:1.8rem auto 0;max-width:60ch}
.token-disclaimer strong{color:var(--ink)}

/* ---------- How to buy ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.step{position:relative;padding:1.8rem 1.5rem;border:1px solid var(--line);border-radius:18px;background:var(--surface);backdrop-filter:blur(8px);
  transition:transform .3s var(--ease),border-color .3s,box-shadow .3s}
.step:hover{transform:translateY(-6px);border-color:var(--ecto);box-shadow:var(--glow)}
.step-no{font-family:"Space Mono",monospace;font-size:.95rem;color:var(--ecto);opacity:.85}
.step h3{font-size:1.18rem;margin:.5rem 0 .5rem;color:#fff}
.step p{margin:0 0 1rem;color:var(--ink-2);font-size:.94rem}
.step p strong{color:var(--ink)}
.step-link{font-family:"Space Grotesk",sans-serif;font-weight:600;color:var(--ecto);font-size:.92rem}
.step-link:hover{text-shadow:0 0 14px rgba(92,184,255,.7)}

/* ---------- Lore ---------- */
.lore{max-width:none;border-block:1px solid var(--line);background:linear-gradient(180deg,rgba(182,156,255,.05),transparent)}
.lore-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.15fr .85fr;gap:3rem;align-items:center}
.lore-copy h2{margin-bottom:1.1rem}
.lore-copy p{color:var(--ink-2);margin:0 0 1.05rem;max-width:56ch}
.lore-copy strong{color:var(--ink)}.lore-copy em{color:var(--ecto);font-style:normal}
.features{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}
.feature{display:flex;gap:1rem;align-items:flex-start;padding:1rem 1.2rem;border:1px solid var(--line);border-radius:16px;background:var(--surface);transition:.3s}
.feature:hover{border-color:var(--ecto);transform:translateX(6px);box-shadow:var(--glow)}
.f-ico{display:grid;place-items:center;width:42px;height:42px;flex:none;border-radius:12px;background:var(--ecto-soft);font-size:1.25rem}
.feature h3{font-size:1.05rem;margin-bottom:.15rem;color:#fff}
.feature p{margin:0;font-size:.9rem;color:var(--ink-2)}
.lore-visual{display:grid;place-items:center}
.lore-card{position:relative;width:100%;max-width:340px;aspect-ratio:1/1.05;display:grid;place-items:center;padding:1.5rem;
  border:1px solid var(--line);border-radius:26px;background:var(--surface);backdrop-filter:blur(8px);box-shadow:var(--shadow);overflow:hidden}
.lore-glow{position:absolute;inset:-20%;background:radial-gradient(circle at 50% 40%,rgba(92,184,255,.22),transparent 60%);filter:blur(20px)}
.ghostdog--mini{width:88%;height:88%;position:relative;z-index:1;overflow:visible;cursor:default;animation:float 6s ease-in-out infinite}
.lore-tags{position:absolute;bottom:1rem;left:0;right:0;z-index:2;display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center}
.lore-tags span{font-family:"Space Mono",monospace;font-size:.7rem;color:var(--ecto);padding:.2rem .6rem;border:1px solid var(--line);border-radius:999px;background:rgba(10,7,18,.5)}

/* ---------- Cause / Dogs in Need ---------- */
.cause{max-width:none;border-block:1px solid var(--line);background:linear-gradient(180deg,rgba(92,184,255,.05),transparent)}
.cause .section-head,.cause-inner{max-width:var(--maxw);margin-inline:auto}
.cause-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:3rem;align-items:center}
.cause-copy p{color:var(--ink-2);margin:0 0 1.05rem;max-width:58ch}
.cause-copy strong{color:var(--ink)}.cause-copy em{color:var(--ecto);font-style:normal}
.cause-actions{display:flex;gap:.9rem;flex-wrap:wrap;margin:1.6rem 0 1rem}
.cause-note{font-size:.8rem;color:var(--ink-2);opacity:.82;max-width:58ch;line-height:1.6}
.cause-note strong{color:var(--ink)}
.cause-cards{display:flex;flex-direction:column;gap:1rem}
.cause-card{display:flex;gap:1rem;align-items:flex-start;padding:1.2rem 1.3rem;border:1px solid var(--line);border-radius:16px;background:var(--surface);backdrop-filter:blur(8px);transition:.3s}
.cause-card:hover{border-color:var(--ecto);transform:translateX(6px);box-shadow:var(--glow)}
.cc-ico{display:grid;place-items:center;width:46px;height:46px;flex:none;border-radius:13px;background:var(--ecto-soft);font-size:1.4rem}
.cause-card h3{font-size:1.05rem;margin:0 0 .15rem;color:#fff}
.cause-card p{margin:0;font-size:.9rem;color:var(--ink-2)}

/* ---------- Roadmap ---------- */
.timeline{list-style:none;margin:0;padding:0;position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.timeline::before{content:"";position:absolute;top:6px;left:6%;right:6%;height:2px;background:linear-gradient(90deg,var(--ecto),var(--violet));opacity:.4}
.tl-item{position:relative;padding-top:2rem}
.tl-dot{position:absolute;top:0;left:50%;transform:translateX(-50%);width:14px;height:14px;border-radius:50%;background:var(--ecto);box-shadow:0 0 0 4px rgba(92,184,255,.15),var(--glow);animation:dotpulse 2.6s ease-in-out infinite}
.tl-item:nth-child(2) .tl-dot{animation-delay:.4s}.tl-item:nth-child(3) .tl-dot{animation-delay:.8s}.tl-item:nth-child(4) .tl-dot{animation-delay:1.2s}
@keyframes dotpulse{50%{box-shadow:0 0 0 8px rgba(92,184,255,.05),var(--glow-strong)}}
.tl-card{padding:1.4rem 1.3rem;border:1px solid var(--line);border-radius:16px;background:var(--surface);backdrop-filter:blur(8px);height:100%;transition:.3s}
.tl-card:hover{border-color:var(--ecto);transform:translateY(-4px);box-shadow:var(--glow)}
.tl-phase{font-family:"Space Mono",monospace;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--violet)}
.tl-card h3{font-size:1.18rem;margin:.3rem 0 .7rem;color:#fff}
.tl-card ul{margin:0;padding-left:1.1rem;color:var(--ink-2);font-size:.9rem}
.tl-card li{margin-bottom:.35rem}

/* ---------- FAQ ---------- */
.faq-list{max-width:760px;margin:0 auto;display:flex;flex-direction:column;gap:.8rem}
.faq-item{border:1px solid var(--line);border-radius:14px;background:var(--surface);backdrop-filter:blur(8px);overflow:hidden;transition:border-color .25s,box-shadow .25s}
.faq-item[open]{border-color:var(--ecto);box-shadow:var(--glow)}
.faq-item summary{cursor:pointer;list-style:none;padding:1.1rem 1.3rem;font-family:"Space Grotesk",sans-serif;font-weight:600;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:var(--ecto);font-size:1.5rem;line-height:1;transition:transform .25s var(--ease)}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item summary:hover{color:var(--ecto)}
.faq-item p{margin:0;padding:0 1.3rem 1.2rem;color:var(--ink-2)}
.faq-item a{color:var(--ecto);font-weight:600}.faq-item strong{color:var(--ink)}.faq-item em{color:var(--ecto);font-style:normal}

/* ---------- Connect ---------- */
.links-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;max-width:880px;margin:0 auto}
.link-card{position:relative;display:flex;align-items:center;gap:1rem;padding:1.2rem 1.4rem;border-radius:18px;overflow:hidden;
  border:1px solid var(--line);background:var(--surface);backdrop-filter:blur(8px);transition:transform .3s var(--ease),border-color .3s,box-shadow .3s}
.link-card:hover{transform:translateY(-4px);border-color:var(--ecto);box-shadow:var(--glow)}
.lc-ico{display:grid;place-items:center;width:46px;height:46px;flex:none;border-radius:13px;background:var(--ecto-soft);color:var(--ecto);transition:.3s}
.link-card:hover .lc-ico{background:linear-gradient(120deg,var(--ecto),var(--ecto-2));color:#04111f}
.lc-ico svg{width:22px;height:22px}
.lc-name{font-weight:700;flex:1;font-family:"Space Grotesk",sans-serif;color:var(--ink)}
.lc-arrow{color:var(--ink-2);transition:transform .25s var(--ease),color .25s}
.link-card:hover .lc-arrow{transform:translate(3px,-3px);color:var(--ecto)}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{position:relative;border-top:1px solid var(--line);background:var(--bg-2);margin-top:2rem}
.footer-inner{max-width:var(--maxw);margin:0 auto;padding:3rem clamp(1rem,4vw,2.4rem);text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}
.footer-tag{color:var(--ink-2);margin:0}
.footer-links{display:flex;gap:1.6rem;flex-wrap:wrap;justify-content:center}
.footer-links a{color:var(--ink-2);transition:color .2s}
.footer-links a:hover{color:var(--ecto)}
.disclaimer{max-width:70ch;font-size:.78rem;color:var(--ink-2);opacity:.8;margin:.4rem auto 0;line-height:1.6}
.copy{color:var(--ink-2);opacity:.7;font-size:.85rem;margin:.2rem 0 0}
.to-top{position:absolute;right:clamp(1rem,4vw,2.4rem);top:-22px;width:44px;height:44px;border-radius:50%;border:0;background:linear-gradient(120deg,var(--ecto),var(--ecto-2));color:#04111f;font-size:1.1rem;cursor:pointer;box-shadow:var(--glow);transition:transform .25s}
.to-top:hover{transform:translateY(-3px)}

/* ---------- Toast ---------- */
.toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%,20px);z-index:200;
  padding:.7rem 1.2rem;border-radius:999px;background:var(--surface-solid);border:1px solid var(--ecto);color:var(--ink);
  font-family:"Space Grotesk",sans-serif;font-weight:600;font-size:.9rem;box-shadow:var(--glow);
  opacity:0;pointer-events:none;transition:opacity .3s,transform .3s}
.toast.show{opacity:1;transform:translate(-50%,0)}

/* =========================================================
   REVEAL
   ========================================================= */
.reveal{opacity:0;transform:translateY(32px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:980px){
  .stats,.steps,.timeline{grid-template-columns:repeat(2,1fr)}
  .timeline::before{display:none}
  .links-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:900px){
  .hero-inner{grid-template-columns:1fr;text-align:center;gap:1.5rem}
  .hero-copy{order:2}
  .hero-stage{order:1;width:min(320px,72vw)}
  .hero-actions,.hero-platforms,.ca{justify-self:center;justify-content:center}
  .hero-desc{margin-inline:auto}
  .lore-inner{grid-template-columns:1fr;text-align:center}
  .lore-copy p{margin-inline:auto}
  .lore-visual{order:-1}
  .feature{text-align:left}
  .cause-inner{grid-template-columns:1fr}
  /* collapse the (now 6-item) nav into the menu early so it never overflows */
  .nav-links{position:fixed;inset:0 0 auto 0;flex-direction:column;gap:1.4rem;padding:6rem 2rem 2.4rem;
    background:rgba(10,7,18,.97);backdrop-filter:blur(16px);transform:translateY(-110%);
    transition:transform .4s var(--ease);border-bottom:1px solid var(--line)}
  .nav-links.open{transform:none}
  .nav-toggle{display:flex;z-index:90}
  .nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-toggle.open span:nth-child(2){opacity:0}
  .nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
}
@media (max-width:680px){
  .stats,.steps,.timeline,.links-grid{grid-template-columns:1fr}
  .ca{flex-wrap:wrap}
  .veil-actions{flex-direction:column;align-items:stretch;width:min(280px,80vw)}
}

/* =========================================================
   REDUCED MOTION
   ========================================================= */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto}
  .hero-grid,.aurora,.veil-fog,.veil-fog--low,.veil-lightning,.veil-bolt{display:none}
  .reveal{opacity:1;transform:none}
  .veil{clip-path:none}
  .veil.is-open{filter:none}
}
