/* ════════════════════════════════════════════════
   REPTIL — Toy Story style, professional execution
   No empty sections · Tight spacing · Full responsive
   ════════════════════════════════════════════════ */

/* ── TOKENS ─────────────────────────────────────── */
:root {
  /* Palette */
  --sky:       #5BC8F5;
  --sky-dark:  #1a9fd4;
  --sky-light: #d6f2fc;
  --sun:       #FFD832;
  --sun-dark:  #e6b800;
  --red:       #FF4E4E;
  --red-dark:  #d43333;
  --green:     #4CAF50;
  --green-dark:#388E3C;
  --ground:    #5cb85c;
  --ground-dk: #4a994a;
  --dark:      #1A1A2E;
  --text:      #2D2D3A;
  --muted:     #6B7280;
  --white:     #FFFFFF;
  --cream:     #FFFBF0;
  --demo-bg:   #111827;

  /* Typography */
  --font-display: 'Fredoka One', 'Arial Rounded MT Bold', sans-serif;
  --font-body:    'Nunito', system-ui, sans-serif;

  /* Spacing */
  --gutter: clamp(1.25rem, 5vw, 4rem);
  --section-py: clamp(4rem, 7vw, 7rem);
  --max-w: 1360px;

  /* Radii */
  --r-sm:  8px;
  --r-md:  14px;
  --r-lg:  22px;
  --r-xl:  32px;
  --r-pill: 9999px;

  /* Cartoon shadows — offset, no blur */
  --sh-sm:  3px 3px 0 rgba(0,0,0,0.18);
  --sh-md:  4px 4px 0 rgba(0,0,0,0.18);
  --sh-lg:  6px 6px 0 rgba(0,0,0,0.16);
  --sh-xl:  8px 8px 0 rgba(0,0,0,0.14);

  --border-w: 2.5px;
  --ti: 220ms cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ── RESET ─────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; scroll-padding-top: 74px; -webkit-font-smoothing: antialiased; }
body { font-family: var(--font-body); font-size: 1rem; color: var(--text); background: var(--cream); overflow-x: hidden; line-height: 1.65; }
img, svg { display: block; max-width: 100%; }
input, button, textarea, select { font: inherit; color: inherit; }
a { text-decoration: none; color: inherit; }
button { cursor: pointer; border: none; background: none; }
h1, h2, h3 { font-family: var(--font-display); line-height: 1.08; text-wrap: balance; }
p { max-width: 64ch; }
::selection { background: var(--sun); color: var(--dark); }
:focus-visible { outline: 3px solid var(--sky-dark); outline-offset: 3px; border-radius: var(--r-sm); }
@media (prefers-reduced-motion: reduce) { *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; } }

/* ── LAYOUT ─────────────────────────────────────── */
.wrap {
  width: 100%;
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: var(--gutter);
}
.section { padding-block: var(--section-py); }

/* ── BUTTONS ─────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .7rem 1.6rem;
  font-family: var(--font-display);
  font-size: 1rem;
  letter-spacing: .02em;
  border-radius: var(--r-pill);
  border: var(--border-w) solid rgba(0,0,0,.18);
  box-shadow: var(--sh-md);
  transition: transform var(--ti), box-shadow var(--ti);
  white-space: nowrap;
  cursor: pointer;
}
.btn:hover  { transform: translateY(-2px) scale(1.03); box-shadow: var(--sh-xl); }
.btn:active { transform: translateY(1px) scale(.98); box-shadow: var(--sh-sm); }

.btn-primary { background: var(--sun); color: var(--dark); }
.btn-outline  { background: transparent; color: var(--dark); border-color: rgba(0,0,0,.25); }
.btn-full     { width: 100%; justify-content: center; }
.btn-lg       { padding: .85rem 2rem; font-size: 1.05rem; }

/* ── NAV ─────────────────────────────────────── */
.site-nav {
  position: sticky; top: 0; z-index: 100;
  background: var(--sky);
  border-bottom: var(--border-w) solid var(--sky-dark);
  box-shadow: 0 2px 12px rgba(0,0,0,.12);
}
.nav-inner {
  display: flex; align-items: center; gap: 1.5rem;
  height: 70px;
  padding-inline: var(--gutter);
  max-width: var(--max-w); margin-inline: auto;
}
.nav-logo { display: flex; align-items: center; gap: .6rem; flex-shrink: 0; }
.nav-dino {
  width: 42px; height: 42px; object-fit: contain;
  filter: drop-shadow(2px 2px 0 rgba(0,0,0,.18));
  animation: dino-rock 3s ease-in-out infinite;
}
@keyframes dino-rock { 0%,100%{transform:rotate(-3deg);} 50%{transform:rotate(3deg);} }
.nav-wordmark { font-family: var(--font-display); font-size: 1.45rem; color: #fff; letter-spacing: .04em; }
.nav-links { display: flex; gap: .25rem; margin-left: auto; }
.nav-link {
  font-family: var(--font-display); font-size: .9rem;
  color: rgba(255,255,255,.9);
  padding: .35rem .9rem;
  border-radius: var(--r-pill);
  transition: background var(--ti), color var(--ti), transform var(--ti);
}
.nav-link:hover { background: rgba(255,255,255,.22); transform: translateY(-1px); }
.nav-toggle { display: none; color: #fff; padding: .25rem; }
.mobile-nav {
  display: none; flex-direction: column; gap: .25rem;
  padding: .75rem var(--gutter) 1rem;
  background: var(--sky); border-top: 1px solid var(--sky-dark);
}
.mobile-nav.open { display: flex; }
.mobile-link {
  font-family: var(--font-display); font-size: 1rem; color: #fff;
  padding: .6rem 1rem; border-radius: var(--r-md);
  transition: background var(--ti);
}
.mobile-link:hover { background: rgba(255,255,255,.2); }
@media (max-width: 900px) { .nav-links { display: none; } .nav-toggle { display: flex; } }
@media (max-width: 560px) { .nav-inner .btn { display: none; } }

/* ── HERO ─────────────────────────────────────── */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex; flex-direction: column;
  overflow: hidden;
  background: linear-gradient(180deg,
    #87CEEB 0%, #A8DFF0 35%,
    #C5EEB0 68%, #5cb85c 100%
  );
}

/* Clouds */
.hero-sky { position: absolute; inset: 0; pointer-events: none; }
.cloud {
  position: absolute; background: #fff;
  border-radius: var(--r-pill);
  box-shadow: 0 3px 10px rgba(0,0,0,.08);
}
.cloud::before, .cloud::after {
  content: ''; position: absolute; background: #fff; border-radius: 50%;
}
.c1 { width: 180px; height: 60px; top: 10%; left: 6%;  animation: cloud-drift 28s linear infinite; }
.c1::before { width: 80px; height: 80px; top:-42px; left:22px; }
.c1::after  { width: 58px; height: 58px; top:-30px; left:80px; }
.c2 { width: 260px; height: 82px; top: 7%; right: 8%; animation: cloud-drift 36s linear infinite reverse; animation-delay:-12s; }
.c2::before { width: 110px; height: 110px; top:-58px; left:36px; }
.c2::after  { width: 80px; height: 80px;   top:-44px; left:122px; }
.c3 { width: 140px; height: 46px; top: 28%; left: 52%; animation: cloud-drift 22s linear infinite; animation-delay:-6s; }
.c3::before { width: 62px; height: 62px; top:-33px; left:16px; }
.c3::after  { width: 44px; height: 44px; top:-24px; left:62px; }
@keyframes cloud-drift { from{transform:translateX(0)} to{transform:translateX(-140vw)} }

/* Ground */
.hero-ground {
  position: absolute; bottom: 0; left: 0; right: 0; height: 72px;
  background: var(--ground); border-top: 3px solid var(--ground-dk);
  z-index: 0;
}
.hero-ground::before {
  content: '';
  position: absolute; top: -16px; left: 0; right: 0; height: 22px;
  background: repeating-linear-gradient(
    90deg, var(--ground) 0,var(--ground) 26px,
    var(--ground-dk) 26px, var(--ground-dk) 30px
  );
  border-radius: 50% 50% 0 0 / 10px;
}

.hero-inner {
  position: relative; z-index: 1; flex: 1;
  display: grid; grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 2rem;
  padding: clamp(5rem,9vw,10rem) var(--gutter) 5.5rem;
  max-width: var(--max-w); width: 100%; margin-inline: auto;
}

.hero-text { display: flex; flex-direction: column; gap: 1.5rem; }

.hero-badge {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--font-display); font-size: .88rem;
  background: #fff; color: var(--sky-dark);
  border: var(--border-w) solid var(--sky-dark);
  padding: .3rem 1rem; border-radius: var(--r-pill);
  box-shadow: var(--sh-sm); width: fit-content;
}
.badge-live {
  width: 8px; height: 8px; border-radius: 50%; background: #22c55e;
  animation: blink 1.5s ease-in-out infinite; flex-shrink: 0;
}
@keyframes blink { 0%,100%{opacity:1;} 50%{opacity:.25;} }

.hero-headline {
  font-size: clamp(2.8rem,6.5vw,5.5rem);
  color: var(--dark); letter-spacing: -.025em;
  text-shadow: 2px 2px 0 rgba(255,255,255,.4);
}
.headline-accent { color: var(--sun-dark); }

.hero-sub {
  font-size: clamp(1rem,1.6vw,1.2rem);
  color: #333; font-weight: 700; max-width: 50ch; line-height: 1.65;
}

.hero-btns { display: flex; gap: .875rem; flex-wrap: wrap; }

.hero-stats {
  display: flex; align-items: center; gap: 1.25rem; flex-wrap: wrap;
  padding: 1rem 1.25rem;
  background: rgba(255,255,255,.55);
  border: var(--border-w) solid rgba(0,0,0,.12);
  border-radius: var(--r-lg);
  backdrop-filter: blur(8px);
  box-shadow: var(--sh-sm);
  width: fit-content;
}
.hstat { display: flex; flex-direction: column; align-items: center; gap: .15rem; }
.hstat-val { font-family: var(--font-display); font-size: 1.6rem; color: var(--dark); line-height: 1; }
.hstat-lbl { font-size: .72rem; font-weight: 800; color: var(--muted); letter-spacing: .06em; text-transform: uppercase; }
.hstat-sep { width: 1px; height: 36px; background: rgba(0,0,0,.12); flex-shrink: 0; }

/* Mascot */
.hero-mascot {
  position: relative; display: flex;
  justify-content: center; align-items: flex-end;
}
.mascot-shadow {
  position: absolute; bottom: -10px;
  width: 70%; height: 32px;
  background: rgba(0,0,0,.12);
  border-radius: 50%; filter: blur(18px);
}
.mascot-img {
  width: min(500px,90%); height: auto;
  filter: drop-shadow(4px 4px 0 rgba(0,0,0,.2));
  animation: dino-float 3s ease-in-out infinite;
  position: relative; z-index: 1;
}
@keyframes dino-float { 0%,100%{transform:translateY(0) rotate(-1.5deg);} 50%{transform:translateY(-14px) rotate(1.5deg);} }

.speech-bubble {
  position: absolute; top: 6%; right: 0;
  max-width: 200px;
  background: #fff; color: var(--dark);
  border: var(--border-w) solid var(--dark);
  border-radius: var(--r-xl) var(--r-xl) var(--r-xl) 0;
  padding: .75rem 1rem;
  font-family: var(--font-display); font-size: .88rem;
  box-shadow: var(--sh-lg); z-index: 5;
  animation: bubble-bob 4s ease-in-out infinite;
}
.speech-bubble::before {
  content: ''; position: absolute; bottom: -14px; left: 18px;
  border: 7px solid transparent; border-top-color: var(--dark);
}
.speech-bubble::after {
  content: ''; position: absolute; bottom: -9px; left: 20px;
  border: 6px solid transparent; border-top-color: #fff; z-index: 1;
}
@keyframes bubble-bob { 0%,100%{transform:rotate(-1.5deg);} 50%{transform:rotate(1deg) scale(1.02);} }

@media (max-width: 900px) {
  .hero-inner { grid-template-columns: 1fr; text-align: center; padding-top: 5rem; padding-bottom: 4.5rem; }
  .hero-text { align-items: center; }
  .hero-btns { justify-content: center; }
  .hero-stats { margin-inline: auto; }
  .hero-mascot { order: -1; }
  .mascot-img { width: min(280px,65%); }
  .speech-bubble { font-size: .8rem; max-width: 160px; right: 0; top: 0; }
}

/* ── TICKER ─────────────────────────────────────── */
.ticker-band {
  background: var(--red); overflow: hidden;
  border-top: var(--border-w) solid var(--red-dark);
  border-bottom: var(--border-w) solid var(--red-dark);
  padding-block: .7rem; z-index: 2; position: relative;
}
.ticker-track {
  display: flex; align-items: center; gap: 2.5rem;
  white-space: nowrap;
  animation: ticker 32s linear infinite;
}
.t-item {
  font-family: var(--font-display); font-size: .95rem;
  color: #fff; letter-spacing: .03em;
}
.t-item.up   { color: #bbf7d0; }
.t-item.down { color: #fecaca; }
.t-sep {
  width: 6px; height: 6px; border-radius: 50%;
  background: rgba(255,255,255,.4); flex-shrink: 0;
}
@keyframes ticker { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ── SECTION HEADER ────────────────────────────── */
.section-hd {
  display: flex; flex-direction: column; align-items: flex-start; gap: .75rem;
  margin-bottom: clamp(2.5rem,4vw,3.5rem);
}
.section-hd-center, .section-hd-light { align-items: center; text-align: center; }

.section-tag {
  display: inline-flex; align-items: center; gap: .4rem;
  font-family: var(--font-display); font-size: .85rem;
  color: var(--dark); background: var(--sun);
  padding: .3rem 1rem; border-radius: var(--r-pill);
  border: var(--border-w) solid rgba(0,0,0,.18);
  box-shadow: var(--sh-sm); letter-spacing: .04em;
}
.section-tag-dark { background: rgba(255,255,255,.12); color: rgba(255,255,255,.8); border-color: rgba(255,255,255,.15); }

.section-title {
  font-size: clamp(2rem,4.5vw,3.4rem);
  color: var(--dark); letter-spacing: -.02em;
}
.txt-accent       { color: var(--sky-dark); }
.txt-accent-light { color: var(--sun); }

.section-sub      { font-size: 1rem; font-weight: 700; color: var(--muted); max-width: 52ch; }
.section-sub-light{ color: rgba(255,255,255,.65); }

/* ── MEMECOINS ────────────────────────────────── */
.memecoins { background: #fff; }

.coins-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}

/* Skeleton */
.coin-card.skeleton {
  height: 220px;
  background: linear-gradient(90deg, #f0f0f0 25%, #e8e8e8 50%, #f0f0f0 75%);
  background-size: 200% 100%;
  animation: shimmer 1.4s infinite;
  border-radius: var(--r-lg);
  border: var(--border-w) solid #e5e7eb;
}
@keyframes shimmer { from{background-position:200% 0} to{background-position:-200% 0} }

/* Real coin cards */
.coin-card {
  background: #fff;
  border: var(--border-w) solid #e5e7eb;
  border-radius: var(--r-lg);
  padding: 1.25rem 1.4rem;
  display: flex; flex-direction: column; gap: .75rem;
  box-shadow: var(--sh-md);
  transition: transform var(--ti), box-shadow var(--ti);
  position: relative; overflow: hidden;
}
.coin-card:hover { transform: translateY(-4px) rotate(.5deg); box-shadow: var(--sh-xl); }
.coin-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px;
  border-radius: var(--r-lg) var(--r-lg) 0 0;
}
.coin-card.cc-sol::before   { background: linear-gradient(90deg,#9945FF,#14F195); }
.coin-card.cc-bonk::before  { background: linear-gradient(90deg,#FF8C00,#FFD700); }
.coin-card.cc-wif::before   { background: linear-gradient(90deg,#FF6B9D,#C44FFB); }
.coin-card.cc-pop::before   { background: linear-gradient(90deg,#00C9FF,#92FE9D); }
.coin-card.cc-bome::before  { background: linear-gradient(90deg,#F7971E,#FFD200); }
.coin-card.cc-pepe::before  { background: linear-gradient(90deg,#4CAF50,#8BC34A); }

.coin-top { display: flex; align-items: center; gap: .875rem; }
.coin-logo {
  width: 46px; height: 46px; border-radius: 50%;
  object-fit: cover; flex-shrink: 0;
  border: 2px solid #f0f0f0;
  background: #f5f5f5;
}
.coin-logo-fallback {
  width: 46px; height: 46px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-size: 1.1rem; font-weight: 700;
  background: #f0f4ff; color: var(--sky-dark);
  border: 2px solid #e0e8ff; flex-shrink: 0;
}
.coin-names { flex: 1; min-width: 0; }
.coin-name   { font-family: var(--font-display); font-size: 1.05rem; color: var(--dark); }
.coin-ticker { font-size: .78rem; font-weight: 800; color: var(--muted); letter-spacing: .06em; text-transform: uppercase; }

.coin-price { font-family: var(--font-display); font-size: 1.5rem; color: var(--dark); letter-spacing: -.01em; }

.coin-change {
  display: inline-flex; align-items: center; gap: .3rem;
  font-family: var(--font-display); font-size: .88rem;
  padding: .2rem .7rem; border-radius: var(--r-pill);
  width: fit-content; font-weight: 700;
}
.coin-change.up   { background: #dcfce7; color: #166534; }
.coin-change.down { background: #fee2e2; color: #991b1b; }

.coin-chain {
  display: inline-flex; align-items: center; gap: .35rem;
  font-size: .75rem; font-weight: 800; color: var(--muted);
  background: #f9fafb; padding: .2rem .65rem;
  border-radius: var(--r-pill); border: 1.5px solid #e5e7eb;
  width: fit-content; margin-top: auto;
}

.price-note {
  display: flex; align-items: center; gap: .4rem; flex-wrap: wrap;
  justify-content: space-between;
  margin-top: 1.5rem;
  font-size: .8rem; font-weight: 700; color: var(--muted);
  padding: .6rem .875rem;
  background: #f9fafb;
  border: 1.5px dashed #d1d5db;
  border-radius: var(--r-md);
}
#last-updated { margin-left: auto; font-family: 'Courier New', monospace; font-size: .75rem; }

@media (max-width: 960px)  { .coins-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 580px)  { .coins-grid { grid-template-columns: 1fr; } }

/* ── FEATURES ─────────────────────────────────── */
.features { background: #EEF8FF; }

.feat-grid {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 1.25rem;
}

.feat-card {
  display: flex; align-items: flex-start; gap: 1.25rem;
  padding: 1.75rem;
  border: var(--border-w) solid rgba(0,0,0,.14);
  border-radius: var(--r-xl);
  box-shadow: var(--sh-lg);
  transition: transform var(--ti), box-shadow var(--ti);
}
.feat-card:hover { transform: translateY(-4px) rotate(-.5deg); box-shadow: var(--sh-xl); }

.feat-blue   { background: var(--sky);   color: #fff; }
.feat-yellow { background: var(--sun);   color: var(--dark); }
.feat-red    { background: var(--red);   color: #fff; }
.feat-green  { background: var(--green); color: #fff; }

.feat-icon {
  flex-shrink: 0; margin-top: .2rem;
  width: 48px; height: 48px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.25); border-radius: var(--r-md);
  border: 1.5px solid rgba(255,255,255,.35);
}

.feat-body { display: flex; flex-direction: column; gap: .5rem; }
.feat-num  { font-family: var(--font-display); font-size: .78rem; opacity: .55; letter-spacing: .1em; }
.feat-body h3 { font-size: 1.2rem; }
.feat-body p  { font-size: .9rem; font-weight: 700; opacity: .88; line-height: 1.6; }
.feat-tag {
  display: inline-flex; width: fit-content;
  font-size: .72rem; font-weight: 800; letter-spacing: .08em;
  background: rgba(0,0,0,.15); border-radius: var(--r-pill);
  padding: .2rem .7rem; margin-top: .25rem;
}

@media (max-width: 760px) { .feat-grid { grid-template-columns: 1fr; } }
@media (max-width: 480px) { .feat-card { flex-direction: column; } }

/* ── HOW IT WORKS ─────────────────────────────── */
.how-it-works { background: #FFFDE8; }

.steps-row {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr;
  gap: .75rem;
  align-items: center;
}
.step-card {
  border: var(--border-w) solid rgba(0,0,0,.15);
  border-radius: var(--r-xl);
  padding: 1.5rem 1.25rem;
  display: flex; flex-direction: column; gap: .5rem;
  box-shadow: var(--sh-lg);
  transition: transform var(--ti), box-shadow var(--ti);
  height: 100%;
}
.step-card:hover { transform: translateY(-4px); box-shadow: var(--sh-xl); }

.step-sky    { background: var(--sky);   color: #fff; }
.step-yellow { background: var(--sun);   color: var(--dark); }
.step-red    { background: var(--red);   color: #fff; }
.step-green  { background: var(--green); color: #fff; }

.step-hd { display: flex; align-items: center; justify-content: space-between; }
.step-icon {
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.25); border-radius: var(--r-md);
  border: 1.5px solid rgba(255,255,255,.35);
}
.step-num { font-family: var(--font-display); font-size: .78rem; opacity: .55; letter-spacing: .1em; }
.step-card h3 { font-size: 1.2rem; }
.step-sub { font-size: .75rem; font-weight: 800; text-transform: uppercase; letter-spacing: .07em; opacity: .7; }
.step-card p  { font-size: .88rem; font-weight: 700; opacity: .88; line-height: 1.6; }

.step-arrow { display: flex; align-items: center; justify-content: center; opacity: .3; padding: 0 .25rem; }

@media (max-width: 1000px) {
  .steps-row { grid-template-columns: 1fr 1fr; gap: 1.25rem; }
  .step-arrow { display: none; }
}
@media (max-width: 540px) {
  .steps-row { grid-template-columns: 1fr; }
}

/* ── DEMO ─────────────────────────────────────── */
.demo { background: var(--demo-bg); }

.demo-layout {
  display: grid; grid-template-columns: 1fr 280px;
  gap: 1.25rem; align-items: start;
}

.terminal-wrapper {
  background: #0d1117;
  border: 2px solid #30363d;
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: 0 0 48px rgba(88,255,100,.06), var(--sh-xl);
}
.terminal-bar {
  display: flex; align-items: center; gap: 1rem;
  padding: .7rem 1.1rem;
  background: #161b22; border-bottom: 1.5px solid #30363d;
}
.term-dots { display: flex; gap: 6px; }
.td { width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0; }
.td-r { background: #ff5f57; } .td-y { background: #febc2e; } .td-g { background: #28c840; }
.term-title { font-family: 'Courier New', monospace; font-size: .75rem; color: #6e7681; flex: 1; }
.term-live {
  display: flex; align-items: center; gap: .35rem;
  font-family: 'Courier New', monospace; font-size: .72rem; font-weight: 700;
  color: #3fb950; letter-spacing: .06em;
}
.live-dot { width: 7px; height: 7px; border-radius: 50%; background: #3fb950; animation: blink 1.2s infinite; }

.terminal-body {
  padding: 1.1rem 1.25rem;
  font-family: 'Courier New', monospace;
  font-size: clamp(.65rem,.9vw,.76rem); line-height: 1.9;
  min-height: 360px; max-height: 400px;
  overflow-y: auto; color: #c9d1d9;
  scrollbar-width: thin; scrollbar-color: #30363d transparent;
}
.t-line { display: flex; gap: .75rem; }
.t-time { color: #484f58; min-width: 58px; flex-shrink: 0; }
.t-tag  { min-width: 72px; flex-shrink: 0; font-weight: 700; }
.t-tag.info { color: #58a6ff; } .t-tag.ok { color: #3fb950; }
.t-tag.warn { color: #d29922; } .t-tag.err { color: #f85149; }
.t-msg { color: #8b949e; }
.t-val { color: #3fb950; font-weight: 700; }
.t-pos { color: #3fb950; font-weight: 700; }
.t-cursor { display:inline-block; width:7px; height:13px; background:#3fb950; animation:blink 1s infinite; vertical-align:text-bottom; margin-left:2px; }

.demo-metrics { display: flex; flex-direction: column; gap: 1rem; }
.dm-card {
  border: var(--border-w) solid rgba(0,0,0,.15);
  border-radius: var(--r-lg); padding: 1.1rem 1.25rem;
  display: flex; flex-direction: column; gap: .3rem;
  box-shadow: var(--sh-md);
  transition: transform var(--ti);
}
.dm-card:hover { transform: translateX(4px); }
.dm-blue   { background: var(--sky);   color: #fff; }
.dm-yellow { background: var(--sun);   color: var(--dark); }
.dm-red    { background: var(--red);   color: #fff; }
.dm-green  { background: var(--green); color: #fff; }
.dm-label { font-size: .72rem; font-weight: 800; opacity: .8; text-transform: uppercase; letter-spacing: .07em; }
.dm-value { font-family: var(--font-display); font-size: 1.5rem; line-height: 1; }
.dm-sm    { font-size: 1.05rem; }
.dm-sub   { font-size: .72rem; opacity: .7; font-weight: 700; }
.dm-bar   { height: 4px; background: rgba(0,0,0,.2); border-radius: var(--r-pill); overflow: hidden; margin-top: .25rem; }
.dm-bar-fill { height: 100%; background: rgba(255,255,255,.7); border-radius: var(--r-pill); width: 0; transition: width .4s ease; }

@media (max-width: 860px) {
  .demo-layout { grid-template-columns: 1fr; }
  .demo-metrics { display: grid; grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) { .demo-metrics { grid-template-columns: 1fr; } }

/* ── GITHUB ─────────────────────────────────────── */
.github-section { background: #f0f4ff; }

.repos-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem;
  margin-bottom: 2rem;
}
.repo-card {
  background: #fff;
  border: var(--border-w) solid #e0e7ff;
  border-radius: var(--r-xl);
  padding: 1.5rem;
  display: flex; flex-direction: column; gap: .875rem;
  box-shadow: var(--sh-md);
  transition: transform var(--ti), box-shadow var(--ti);
  color: inherit;
}
.repo-card:hover { transform: translateY(-5px) rotate(-.5deg); box-shadow: var(--sh-xl); }
.repo-card:hover .repo-arrow { transform: translateX(5px); }

.repo-top { display: flex; align-items: center; gap: .75rem; }
.repo-gh  { color: var(--muted); flex-shrink: 0; }
.repo-name { font-family: var(--font-display); font-size: 1.05rem; color: var(--dark); flex: 1; }
.repo-badge {
  font-family: var(--font-display); font-size: .72rem; color: var(--muted);
  background: #f0f4ff; border: 1.5px solid #c7d2fe;
  padding: .15rem .65rem; border-radius: var(--r-pill); letter-spacing: .05em;
}
.repo-desc { font-size: .88rem; font-weight: 600; color: var(--muted); line-height: 1.6; flex: 1; }
.repo-foot {
  display: flex; align-items: center; gap: .75rem; flex-wrap: wrap;
  padding-top: .75rem; border-top: 1.5px solid #f0f0f0;
  font-size: .78rem; font-weight: 700; color: var(--muted);
}
.repo-lang { padding: .18rem .6rem; border-radius: var(--r-pill); border: 1.5px solid; font-size: .72rem; }
.lang-ts   { background: #eff6ff; color: #1d4ed8; border-color: #bfdbfe; }
.lang-rust { background: #fff7ed; color: #c2410c; border-color: #fed7aa; }
.repo-stars { margin-right: auto; }
.repo-arrow { color: var(--sky-dark); transition: transform var(--ti); }
.github-more { display: flex; justify-content: center; }

@media (max-width: 860px) { .repos-grid { grid-template-columns: 1fr; } }
@media (max-width: 560px) { .repos-grid { grid-template-columns: 1fr; } }

/* ── CONTACT ─────────────────────────────────────── */
.contact { background: #f0fff4; }

.contact-layout {
  display: grid; grid-template-columns: 1fr 1.1fr;
  gap: clamp(2rem,5vw,5rem); align-items: start;
}
.contact-info { display: flex; flex-direction: column; gap: 1.5rem; align-items: flex-start; }
.contact-desc { font-size: 1rem; font-weight: 700; color: var(--muted); max-width: 44ch; line-height: 1.7; }

.socials { display: flex; flex-direction: column; gap: .75rem; }
.social-row {
  display: flex; align-items: center; gap: 1rem;
  padding: .875rem 1.1rem;
  background: #fff; border: var(--border-w) solid #e5e7eb;
  border-radius: var(--r-xl); box-shadow: var(--sh-sm);
  transition: transform var(--ti), box-shadow var(--ti);
}
.social-row:hover { transform: translateX(6px) scale(1.01); box-shadow: var(--sh-md); }
.social-row:hover .social-arrow { transform: translateX(4px); }

.social-icon {
  width: 36px; height: 36px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.si-tg { background: #e0f2fe; color: #0284c7; }
.si-x  { background: #f3f4f6; color: #111; }
.si-dc { background: #ede9fe; color: #7c3aed; }

.social-row > div { display: flex; flex-direction: column; gap: .1rem; flex: 1; }
.social-row strong { font-family: var(--font-display); font-size: .95rem; color: var(--dark); }
.social-row span   { font-size: .78rem; font-weight: 700; color: var(--muted); }
.social-arrow { color: var(--muted); transition: transform var(--ti); flex-shrink: 0; }

.contact-mascot {
  margin-top: 1rem;
  animation: dino-rock 3s ease-in-out infinite;
}
.contact-mascot img {
  width: 180px;
  filter: drop-shadow(4px 4px 0 rgba(0,0,0,.15));
}

/* Form */
.contact-form {
  background: #fff;
  border: var(--border-w) solid #e5e7eb;
  border-radius: var(--r-xl); padding: 2rem;
  box-shadow: var(--sh-lg);
  display: flex; flex-direction: column; gap: 1.1rem;
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-group { display: flex; flex-direction: column; gap: .4rem; }
.form-group label {
  font-family: var(--font-display); font-size: .88rem; color: var(--dark);
}
.form-group input,
.form-group select,
.form-group textarea {
  background: #f9fafb;
  border: var(--border-w) solid #e5e7eb;
  border-radius: var(--r-md);
  padding: .7rem 1rem; font-size: .95rem; font-weight: 600; color: var(--text);
  transition: border-color .2s, box-shadow .2s; outline: none;
  -webkit-appearance: none; appearance: none; width: 100%;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--sky-dark); box-shadow: 0 0 0 3px rgba(27,162,212,.15);
}
.form-group input::placeholder, .form-group textarea::placeholder { color: #bbb; }
.form-group textarea { resize: vertical; min-height: 110px; }
select.form-group { cursor: pointer; }

.btn-loading { display: none; }
.contact-form.sending .btn-txt { display: none; }
.contact-form.sending .btn-loading { display: inline; }

.form-ok {
  display: none; align-items: center; gap: .5rem;
  font-family: var(--font-display); font-size: 1rem; color: #166534;
  padding: .875rem 1rem;
  background: #dcfce7; border: 2px solid #86efac; border-radius: var(--r-md);
  box-shadow: var(--sh-sm);
}
.form-ok.visible { display: flex; }

@media (max-width: 860px) { .contact-layout { grid-template-columns: 1fr; } .form-row { grid-template-columns: 1fr; } .contact-mascot { display: none; } }

/* ── FOOTER ─────────────────────────────────────── */
.site-footer { background: var(--dark); color: #fff; border-top: 3px solid var(--sun); }
.footer-inner {
  max-width: var(--max-w); margin-inline: auto;
  padding: 2.5rem var(--gutter) 1.75rem;
  display: flex; flex-direction: column; gap: 1.75rem;
}
.footer-top {
  display: flex; align-items: center; gap: 2rem; flex-wrap: wrap;
}
.footer-tagline { font-size: .95rem; font-weight: 700; color: rgba(255,255,255,.5); flex: 1; }
.footer-nav { display: flex; gap: 1.5rem; flex-wrap: wrap; }
.footer-nav a { font-family: var(--font-display); font-size: .88rem; color: rgba(255,255,255,.5); transition: color .2s; }
.footer-nav a:hover { color: var(--sun); }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.1);
  padding-top: 1.25rem;
  display: flex; flex-direction: column; gap: .35rem;
}
.footer-bottom p { font-family: var(--font-display); font-size: .85rem; color: rgba(255,255,255,.4); }
.footer-legal { font-size: .75rem; color: rgba(255,255,255,.3); max-width: 80ch; line-height: 1.7; }

/* ── SCROLL REVEAL (CSS + IntersectionObserver) ── */
/* Elements are visible by default — JS adds .animate class to body,
   then hidden/shown via IntersectionObserver */
.js-ready .reveal-on-scroll {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .55s cubic-bezier(.16,1,.3,1), transform .55s cubic-bezier(.16,1,.3,1);
  will-change: opacity, transform;
}
.js-ready .reveal-on-scroll.revealed {
  opacity: 1;
  transform: none;
}
/* Stagger delays for grid children */
.feat-grid .reveal-on-scroll:nth-child(2) { transition-delay: .07s; }
.feat-grid .reveal-on-scroll:nth-child(3) { transition-delay: .14s; }
.feat-grid .reveal-on-scroll:nth-child(4) { transition-delay: .21s; }
.steps-row .reveal-on-scroll:nth-child(3) { transition-delay: .1s; }
.steps-row .reveal-on-scroll:nth-child(5) { transition-delay: .2s; }
.steps-row .reveal-on-scroll:nth-child(7) { transition-delay: .3s; }
.repos-grid .reveal-on-scroll:nth-child(2){ transition-delay: .09s; }
.repos-grid .reveal-on-scroll:nth-child(3){ transition-delay: .18s; }
.dm-card.reveal-on-scroll:nth-child(2)    { transition-delay: .07s; }
.dm-card.reveal-on-scroll:nth-child(3)    { transition-delay: .14s; }
.dm-card.reveal-on-scroll:nth-child(4)    { transition-delay: .21s; }

/* ════════════════════════════════════════════════
   NEW ADDITIONS — DO NOT MODIFY EXISTING RULES
   ════════════════════════════════════════════════ */

/* ── MOONPAY BADGE ─────────────────────────────── */
.moonpay-badge {
  display: flex;
  align-items: center;
  opacity: 0.45;
  cursor: not-allowed;
  user-select: none;
  flex-shrink: 0;
}
.moonpay-inner {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  background: rgba(0,0,0,0.18);
  border: 1.5px solid rgba(255,255,255,0.18);
  border-radius: var(--r-pill);
  padding: 0.32rem 0.8rem;
  position: relative;
}
.moonpay-logo {
  flex-shrink: 0;
  filter: grayscale(0.4);
}
.moonpay-text {
  font-family: var(--font-display);
  font-size: 0.82rem;
  color: rgba(255,255,255,0.85);
  white-space: nowrap;
  letter-spacing: 0.02em;
}
.moonpay-soon {
  font-family: var(--font-display);
  font-size: 0.62rem;
  font-weight: 800;
  color: var(--sun);
  background: rgba(255,216,50,0.18);
  border: 1px solid rgba(255,216,50,0.35);
  border-radius: var(--r-pill);
  padding: 0.1rem 0.45rem;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}
@media (max-width: 1100px) { .moonpay-badge { display: none; } }

/* ── CONTACT CTA REPLACE ─────────────────────────── */
.contact-cta-wrap {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  justify-content: center;
  align-items: center;
  padding: 2.5rem 2rem;
  background: #fff;
  border: var(--border-w) solid #e5e7eb;
  border-radius: var(--r-xl);
  box-shadow: var(--sh-lg);
  min-height: 260px;
  text-align: center;
}
.contact-cta-desc {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--muted);
  max-width: 36ch;
  line-height: 1.65;
}

/* ── DEPOSIT VAULT MODAL ─────────────────────────── */
.dv-overlay {
  position: fixed;
  inset: 0;
  background: rgba(10,10,20,0.72);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 9000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.dv-overlay.open {
  opacity: 1;
  pointer-events: all;
}

.dv-modal {
  background: #fff;
  border-radius: var(--r-xl);
  width: 100%;
  max-width: 540px;
  box-shadow: 0 24px 80px rgba(0,0,0,0.4);
  overflow: hidden;
  position: relative;
  transform: scale(0.92) translateY(24px);
  transition: transform 0.35s cubic-bezier(0.34,1.56,0.64,1);
}
.dv-overlay.open .dv-modal {
  transform: scale(1) translateY(0);
}

/* ── Loading init ── */
.dv-loading-init {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.25rem;
  padding: 4rem 2rem;
  min-height: 280px;
}
.dv-loader-ring {
  width: 52px; height: 52px;
  border: 4px solid #f0f0f0;
  border-top-color: var(--sky);
  border-radius: 50%;
  animation: dv-spin 0.75s linear infinite;
}
.dv-loader-txt {
  font-family: var(--font-display);
  font-size: 1.05rem;
  color: var(--muted);
}
@keyframes dv-spin { to { transform: rotate(360deg); } }

/* ── Steps ── */
.dv-steps {
  padding: 2rem 2rem 1.5rem;
  min-height: 440px;
  display: flex;
  flex-direction: column;
}
.dv-close {
  position: absolute;
  top: 1rem; right: 1rem;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: #f5f5f5;
  border: none;
  font-size: 1rem;
  color: var(--muted);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.2s, color 0.2s;
  z-index: 2;
}
.dv-close:hover { background: #ffe0e0; color: var(--red); }

.dv-header { margin-bottom: 1.75rem; }
.dv-title {
  font-family: var(--font-display);
  font-size: 1.4rem;
  color: var(--dark);
  margin-bottom: 0.3rem;
}
.dv-subtitle {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--muted);
  margin-bottom: 1rem;
}
.dv-progress {
  height: 6px;
  background: #f0f0f0;
  border-radius: var(--r-pill);
  overflow: hidden;
  margin-bottom: 0.5rem;
}
.dv-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--sky), var(--sky-dark));
  border-radius: var(--r-pill);
  transition: width 0.4s cubic-bezier(0.34,1.56,0.64,1);
}
.dv-step-count {
  font-size: 0.78rem;
  font-weight: 800;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

/* ── Question wrap ── */
.dv-question-wrap {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.dv-q-label {
  font-family: var(--font-display);
  font-size: 1.15rem;
  color: var(--dark);
  margin-bottom: 0.5rem;
}
.dv-options {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}
.dv-option {
  padding: 0.875rem 1.25rem;
  border: 2px solid #e5e7eb;
  border-radius: var(--r-lg);
  font-family: var(--font-display);
  font-size: 1rem;
  color: var(--dark);
  cursor: pointer;
  background: #fafafa;
  transition: border-color 0.2s, background 0.2s, transform 0.15s, box-shadow 0.2s;
  text-align: left;
}
.dv-option:hover {
  border-color: var(--sky);
  background: #eef8ff;
  transform: translateX(4px);
}
.dv-option.selected {
  border-color: var(--sky-dark);
  background: #e0f4ff;
  box-shadow: var(--sh-sm);
  color: var(--sky-dark);
}

/* ── Nav buttons ── */
.dv-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 1.25rem;
  border-top: 1.5px solid #f0f0f0;
  margin-top: 1rem;
}
.dv-btn-prev {
  font-family: var(--font-display);
  font-size: 0.95rem;
  color: var(--muted);
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.5rem 0.75rem;
  border-radius: var(--r-md);
  transition: color 0.2s, background 0.2s;
}
.dv-btn-prev:hover { color: var(--dark); background: #f5f5f5; }
.dv-btn-prev[disabled] { opacity: 0.3; pointer-events: none; }
.dv-btn-next {
  font-family: var(--font-display);
  font-size: 0.95rem;
  background: var(--sun);
  color: var(--dark);
  border: 2px solid rgba(0,0,0,0.15);
  border-radius: var(--r-pill);
  padding: 0.65rem 1.5rem;
  cursor: pointer;
  box-shadow: var(--sh-md);
  transition: transform 0.2s, box-shadow 0.2s, background 0.2s;
}
.dv-btn-next:hover { transform: translateY(-2px) scale(1.04); box-shadow: var(--sh-lg); }
.dv-btn-next[disabled] { opacity: 0.45; pointer-events: none; }

/* ── Question slide transition ── */
.dv-q-enter { animation: dv-q-in 0.3s cubic-bezier(0.34,1.56,0.64,1) both; }
.dv-q-exit  { animation: dv-q-out 0.2s ease-in both; }
@keyframes dv-q-in  { from { opacity:0; transform:translateX(28px); } to { opacity:1; transform:translateX(0); } }
@keyframes dv-q-out { from { opacity:1; transform:translateX(0); }    to { opacity:0; transform:translateX(-28px); } }

/* ── Final loading screen ── */
.dv-final {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0;
  padding: 2rem 1.5rem;
  min-height: 440px;
  background: var(--dark);
  border-radius: var(--r-xl);
  overflow: hidden;
}
.dv-final-dino-wrap {
  position: relative;
  width: 240px;
  height: 180px;
  flex-shrink: 0;
}
#dv-laser-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}
.dv-final-dino {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 180px;
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 0 18px rgba(57,255,20,0.25));
  animation: dino-float 3s ease-in-out infinite;
}
.dv-final-loader {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  padding-top: 1.25rem;
}
.dv-final-ring {
  width: 40px; height: 40px;
  border: 3px solid rgba(255,255,255,0.1);
  border-top-color: var(--sky);
  border-radius: 50%;
  animation: dv-spin 0.8s linear infinite;
}
.dv-final-msg {
  font-family: var(--font-display);
  font-size: 1.05rem;
  color: rgba(255,255,255,0.85);
  text-align: center;
  min-height: 1.6em;
  transition: opacity 0.4s ease;
}
.dv-final-msg.fade-out { opacity: 0; }
