/* ============================================================
   VICE CITY COIN ($VICE) — comic / neon Vice City theme
   Horizontal-scroll layout
   ============================================================ */

:root{
  --pink:   #ff2d95;
  --hot:    #ff5cc8;
  --purple: #7b2ff7;
  --cyan:   #18f0ff;
  --blue:   #2b6bff;
  --yellow: #ffd23f;
  --ink:    #0a0418;
  --ink-2:  #160a2e;
  --paper:  #fef7ff;

  --glow-pink: 0 0 18px rgba(255,45,149,.65);
  --glow-cyan: 0 0 18px rgba(24,240,255,.6);
  --edge: 4px;

  --font-comic: 'Bangers', cursive;
  --font-disp:  'Bungee', sans-serif;
  --font-head:  'Anton', sans-serif;
  --font-body:  'Poppins', sans-serif;
}

*{ box-sizing: border-box; margin:0; padding:0; }

html, body{ height:100%; }

body{
  font-family: var(--font-body);
  color: var(--paper);
  background: var(--ink);
  overflow: hidden;            /* page itself never scrolls */
  -webkit-font-smoothing: antialiased;
}

a{ color: inherit; text-decoration: none; }
img{ display:block; max-width:100%; }

/* ============================================================
   BACKGROUND LAYERS  (GTA + neon)
   ============================================================ */
.bg-layers{ position:fixed; inset:0; z-index:0; overflow:hidden; pointer-events:none;
  background:
    radial-gradient(120% 120% at 80% -10%, #3a0d5e 0%, #1a0833 45%, #0a0418 100%),
    linear-gradient(180deg, #1b0a3a 0%, #0a0418 100%);
}

/* perspective neon grid (Miami synthwave floor) */
.bg-grid{
  position:absolute; left:-25%; right:-25%; bottom:-10%; height:55%;
  background-image:
    linear-gradient(to right, rgba(24,240,255,.35) 1px, transparent 1px),
    linear-gradient(to top,   rgba(255,45,149,.35) 1px, transparent 1px);
  background-size: 70px 70px;
  transform: perspective(420px) rotateX(62deg);
  transform-origin: bottom center;
  mask-image: linear-gradient(to top, #000 5%, transparent 75%);
  -webkit-mask-image: linear-gradient(to top, #000 5%, transparent 75%);
  animation: gridMove 6s linear infinite;
  opacity:.7;
}
@keyframes gridMove{ from{ background-position:0 0; } to{ background-position:0 70px; } }

/* neon sun glow */
.bg-sun{
  position:absolute; top:-12vh; left:50%; transform:translateX(-50%);
  width:60vh; height:60vh; border-radius:50%;
  background: radial-gradient(circle, rgba(255,92,200,.55), rgba(123,47,247,.25) 45%, transparent 70%);
  filter: blur(6px);
  animation: pulse 7s ease-in-out infinite;
}
@keyframes pulse{ 50%{ transform:translateX(-50%) scale(1.08); opacity:.85; } }

/* GTA-style silhouette imagery driven into the bg via the asset art,
   plus faded full-scene washes */
.bg-gta{
  position:absolute; inset:0;
  background-repeat:no-repeat;
  background-size: cover;
  opacity:.10;
  mix-blend-mode: luminosity;
}
.bg-gta--1{ background-image:url('hero.png'); background-position: left center; filter: saturate(1.3) contrast(1.1); }
.bg-gta--2{ background-image:url('main.png'); background-position: right center; opacity:.08; }

/* comic halftone dots */
.bg-halftone{
  position:absolute; inset:0;
  background-image: radial-gradient(rgba(255,255,255,.10) 1.2px, transparent 1.3px);
  background-size: 14px 14px;
  mix-blend-mode: overlay;
}

/* subtle CRT scanlines */
.bg-scanlines{
  position:absolute; inset:0;
  background-image: repeating-linear-gradient(to bottom, rgba(0,0,0,.18) 0 2px, transparent 2px 4px);
  opacity:.4;
}
.bg-vignette{
  position:absolute; inset:0;
  box-shadow: inset 0 0 220px 60px rgba(0,0,0,.75);
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; gap:1rem;
  padding:.6rem 1.4rem;
  background: linear-gradient(180deg, rgba(10,4,24,.92), rgba(10,4,24,.35));
  border-bottom:2px solid rgba(255,45,149,.4);
  backdrop-filter: blur(8px);
}
.nav__brand{ display:flex; align-items:center; }
.nav__logo{ height:54px; width:auto; filter: drop-shadow(var(--glow-pink)); }

.nav__links{ display:flex; gap:1.4rem; margin-left:1.2rem; }
.nav__links a{
  font-family: var(--font-disp); font-size:.82rem; letter-spacing:.5px;
  text-transform:uppercase; color:#e9d6ff; position:relative; padding:.3rem 0;
  transition: color .2s;
}
.nav__links a::after{
  content:""; position:absolute; left:0; right:100%; bottom:-2px; height:2px;
  background: var(--cyan); box-shadow: var(--glow-cyan); transition: right .25s;
}
.nav__links a:hover{ color:#fff; }
.nav__links a:hover::after,
.nav__links a.is-active::after{ right:0; }
.nav__links a.is-active{ color:var(--cyan); }

.nav__right{ margin-left:auto; display:flex; align-items:center; gap:.8rem; }
.nav__social{
  display:grid; place-items:center; width:38px; height:38px; border-radius:50%;
  color:#fff; border:2px solid rgba(24,240,255,.5); background:rgba(123,47,247,.2);
  transition: transform .15s, box-shadow .2s, background .2s;
}
.nav__social:hover{ transform:translateY(-2px); background:var(--pink); box-shadow:var(--glow-pink); border-color:var(--pink); }

.nav__burger{ display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:6px; }
.nav__burger span{ width:26px; height:3px; background:var(--cyan); border-radius:2px; box-shadow:var(--glow-cyan); }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  font-family: var(--font-disp); text-transform:uppercase; letter-spacing:.5px;
  font-size:.82rem; padding:.7rem 1.25rem; border-radius:10px; cursor:pointer;
  border:var(--edge) solid #000; position:relative;
  transition: transform .12s ease, box-shadow .2s ease, filter .2s;
  white-space:nowrap;
}
.btn:active{ transform: translateY(2px); }
.btn--buy{
  color:#1a0024; background: linear-gradient(180deg,var(--yellow),#ffb300);
  box-shadow: 0 5px 0 #000, var(--glow-pink);
}
.btn--buy:hover{ filter:brightness(1.08); box-shadow:0 5px 0 #000, 0 0 26px rgba(255,210,63,.8); transform:translateY(-2px); }
.btn--ghost{
  color:#fff; background: rgba(123,47,247,.25);
  border-color: var(--cyan); box-shadow: 0 5px 0 rgba(0,0,0,.6), var(--glow-cyan);
}
.btn--ghost:hover{ background: var(--cyan); color:#04222a; transform:translateY(-2px); }
.btn--lg{ font-size:1rem; padding:.95rem 1.8rem; }
.btn--sm{ font-size:.7rem; padding:.45rem .8rem; box-shadow:0 3px 0 rgba(0,0,0,.6); }

/* ============================================================
   HORIZONTAL TRACK + PANELS
   ============================================================ */
.track{
  position:relative; z-index:10;
  display:flex; flex-wrap:nowrap;
  height:100vh; width:100%;
  overflow-x:auto; overflow-y:hidden;
  scroll-snap-type: x mandatory;
  scroll-behavior:smooth;
  scrollbar-width:none;
}
.track::-webkit-scrollbar{ display:none; }

.panel{
  flex:0 0 100vw; width:100vw; height:100vh;
  scroll-snap-align:start;
  display:flex; align-items:center; justify-content:center;
  gap:clamp(1rem,4vw,4rem);
  padding: 90px clamp(1.2rem,5vw,5rem) 70px;
  position:relative;
}

/* shared headings */
.kicker{
  display:inline-block; font-family:var(--font-disp); font-size:.78rem; letter-spacing:2px;
  color:var(--cyan); text-shadow:var(--glow-cyan); margin-bottom:.6rem;
}
.comic-outline{
  font-family: var(--font-comic);
  text-shadow:
    3px 3px 0 #000, -2px -2px 0 #000, 2px -2px 0 #000, -2px 2px 0 #000,
    0 0 26px rgba(255,45,149,.7);
  line-height:.95;
}
.section-title{
  font-size: clamp(2.4rem, 5vw, 4.4rem); color:#fff; letter-spacing:2px; margin-bottom:1rem;
}
.section-title span{ color:var(--cyan); }

/* ---------- HERO ---------- */
.panel--hero{ }
.hero__art{ flex:0 1 44%; max-width:540px; }
.hero__art img{
  width:100%; border-radius:18px;
  border:5px solid #000;
  box-shadow: 10px 10px 0 var(--pink), 0 0 50px rgba(123,47,247,.6);
  animation: floaty 6s ease-in-out infinite;
}
@keyframes floaty{ 50%{ transform: translateY(-12px) rotate(-.6deg); } }

.hero__content{ flex:1 1 46%; max-width:620px; }
.hero__title{
  font-size: clamp(3.4rem, 8vw, 7rem);
  color:#fff;
  -webkit-text-stroke: 2px #000;
  text-shadow:
    4px 4px 0 #000, -3px -3px 0 #000, 3px -3px 0 #000, -3px 3px 0 #000,
    0 0 22px rgba(255,45,149,.85), 0 0 44px rgba(123,47,247,.6);
  margin-bottom:.6rem;
}
.hero__title span{ color:var(--cyan); }
.hero__bio{ font-size:clamp(1rem,1.6vw,1.3rem); font-weight:500; color:#ffd9f3; max-width:34ch; margin-bottom:1.4rem; }
.hero__cta{ display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:1.4rem; }
.hero__chips{ display:flex; gap:.6rem; flex-wrap:wrap; }
.chip{
  font-family:var(--font-disp); font-size:.66rem; letter-spacing:.5px;
  padding:.4rem .7rem; border-radius:999px;
  border:2px solid rgba(24,240,255,.5); background:rgba(255,255,255,.05); color:#dff;
}

.scroll-hint{
  position:absolute; bottom:24px; left:50%; transform:translateX(-50%);
  display:flex; align-items:center; gap:.5rem;
  font-family:var(--font-disp); font-size:.7rem; letter-spacing:2px; color:#ffb3e6;
}
.scroll-hint em{ font-style:normal; font-size:1.3rem; color:var(--cyan); animation: nudge 1.2s ease-in-out infinite; }
@keyframes nudge{ 50%{ transform: translateX(8px); } }

/* ---------- ABOUT ---------- */
.about__art{ position:relative; flex:0 1 42%; max-width:520px; }
.about__art img{
  width:100%; border-radius:18px; border:5px solid #000;
  box-shadow: -10px 10px 0 var(--cyan), 0 0 50px rgba(255,45,149,.5);
}
.burst--pow{
  position:absolute; top:-26px; right:-18px;
  display:grid; place-items:center; width:104px; height:104px; rotate:-12deg;
  font-family:var(--font-comic); font-size:1.7rem; color:#1a0024;
  background:var(--yellow);
  clip-path: polygon(50% 0,61% 18%,82% 12%,77% 33%,98% 38%,82% 52%,98% 66%,77% 70%,82% 90%,61% 82%,50% 100%,39% 82%,18% 90%,23% 70%,2% 66%,18% 52%,2% 38%,23% 33%,18% 12%,39% 18%);
  text-shadow:1px 1px 0 #fff; border:none;
  animation: pop 2.4s ease-in-out infinite;
}
@keyframes pop{ 50%{ transform: scale(1.08) rotate(-8deg); } }

.about__content{ flex:1 1 48%; max-width:640px; }
.bubble{
  position:relative; background:var(--paper); color:#1a0024; border:4px solid #000;
  border-radius:16px; padding:1rem 1.2rem; margin-bottom:1.1rem; font-weight:600;
  box-shadow: 6px 6px 0 rgba(0,0,0,.5);
}
.bubble::after{
  content:""; position:absolute; left:36px; bottom:-22px;
  border:12px solid transparent; border-top-color:#000;
}
.bubble::before{
  content:""; position:absolute; left:40px; bottom:-13px; z-index:1;
  border:9px solid transparent; border-top-color:var(--paper);
}
.about__text{ color:#e9d6ff; line-height:1.55; margin-bottom:1.4rem; }
.stats{ display:flex; gap:1rem; flex-wrap:wrap; }
.stat{
  flex:1 1 120px; text-align:center; padding:.9rem .6rem; border-radius:14px;
  border:3px solid #000; background:linear-gradient(180deg, rgba(123,47,247,.4), rgba(255,45,149,.25));
  box-shadow:0 5px 0 rgba(0,0,0,.5);
}
.stat strong{ display:block; font-family:var(--font-comic); font-size:2rem; color:var(--cyan); text-shadow:2px 2px 0 #000; }
.stat span{ font-family:var(--font-disp); font-size:.7rem; letter-spacing:1px; color:#ffd9f3; }

/* ---------- HOW TO BUY ---------- */
.panel--buy{ flex-direction:column; }
.buy__inner{ width:100%; max-width:1100px; text-align:center; }
.buy__inner .section-title{ margin-bottom:1.6rem; }
.steps{ display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; margin-bottom:1.6rem; }
.step{
  text-align:left; padding:1.2rem; border-radius:16px; border:4px solid #000;
  background:linear-gradient(180deg, rgba(22,10,46,.95), rgba(123,47,247,.18));
  box-shadow:0 6px 0 rgba(0,0,0,.5), inset 0 0 30px rgba(24,240,255,.07);
  position:relative; overflow:hidden;
  transition: transform .15s, box-shadow .2s;
}
.step:hover{ transform:translateY(-4px); box-shadow:0 10px 0 rgba(0,0,0,.5), 0 0 26px rgba(255,45,149,.35); }
.step__num{
  font-family:var(--font-comic); font-size:2.4rem; color:var(--pink);
  text-shadow:2px 2px 0 #000, var(--glow-pink); display:block; margin-bottom:.3rem;
}
.step h3{ font-family:var(--font-disp); font-size:.95rem; margin-bottom:.4rem; color:#fff; }
.step p{ font-size:.85rem; color:#d9c9f5; line-height:1.45; }

.contract{
  display:inline-flex; align-items:center; gap:.7rem; flex-wrap:wrap; justify-content:center;
  padding:.6rem .9rem; border-radius:12px; border:3px dashed rgba(24,240,255,.6);
  background:rgba(255,255,255,.04); margin-bottom:1.4rem;
}
.contract__label{ font-family:var(--font-disp); font-size:.7rem; color:var(--cyan); letter-spacing:1px; }
.contract code{ font-family:monospace; color:#fff; font-size:.85rem; word-break:break-all; }

/* ---------- CHART ---------- */
.panel--chart{ flex-direction:column; }
.chart__inner{ width:100%; max-width:1000px; height:100%; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:1rem; }
.chart__inner .section-title{ margin-bottom:.2rem; }
.chart__frame{
  width:100%; flex:1 1 auto; max-height:62vh; min-height:320px;
  border:5px solid #000; border-radius:16px; overflow:hidden;
  box-shadow:10px 10px 0 var(--purple), 0 0 50px rgba(24,240,255,.4);
  background:#0a0418;
}
.chart__frame iframe{ width:100%; height:100%; border:0; display:block; }

/* ---------- JOIN US ---------- */
.panel--join{ flex-direction:column; gap:1.6rem; }
.join__banner{ width:100%; max-width:1000px; }
.join__banner img{
  width:100%; border-radius:18px; border:5px solid #000;
  box-shadow:0 10px 0 rgba(0,0,0,.5), 0 0 50px rgba(255,45,149,.6);
}
.join__content{ width:100%; max-width:920px; text-align:center; }
.join__content .section-title{ margin-bottom:.4rem; }
.join__text{ color:#e9d6ff; max-width:60ch; margin:0 auto 1.4rem; line-height:1.5; }
.join__socials{ display:flex; gap:1.2rem; justify-content:center; flex-wrap:wrap; margin-bottom:1.2rem; }
.social-card{
  display:flex; flex-direction:column; align-items:center; gap:.3rem;
  width:230px; padding:1.1rem; border-radius:16px; border:4px solid #000;
  box-shadow:0 6px 0 rgba(0,0,0,.5); transition: transform .15s, box-shadow .2s;
}
.social-card:hover{ transform:translateY(-4px); }
.social-card span{ font-family:var(--font-disp); font-size:.95rem; color:#fff; }
.social-card em{ font-style:normal; font-size:.78rem; color:#eee; opacity:.9; }
.social-card--x{ background:linear-gradient(180deg,#15101f,#000); box-shadow:0 6px 0 rgba(0,0,0,.6), var(--glow-cyan); }
.social-card--x:hover{ box-shadow:0 10px 0 rgba(0,0,0,.6), 0 0 26px var(--cyan); }
.social-card--tg{ background:linear-gradient(180deg,#229ed9,#1b7fb0); box-shadow:0 6px 0 rgba(0,0,0,.6); }
.social-card--tg:hover{ box-shadow:0 10px 0 rgba(0,0,0,.6), 0 0 26px rgba(34,158,217,.8); }
.join__foot{ font-size:.78rem; color:#b79fd6; letter-spacing:.3px; }

/* ============================================================
   DOTS + PROGRESS
   ============================================================ */
.dots{
  position:fixed; right:18px; top:50%; transform:translateY(-50%);
  z-index:50; display:flex; flex-direction:column; gap:.7rem;
}
.dots button{
  width:14px; height:14px; border-radius:50%; cursor:pointer;
  background:transparent; border:2px solid var(--cyan); box-shadow:var(--glow-cyan);
  transition: all .2s;
}
.dots button.is-active{ background:var(--pink); border-color:var(--pink); box-shadow:var(--glow-pink); transform:scale(1.3); }

.progress{ position:fixed; left:0; right:0; bottom:0; height:5px; z-index:50; background:rgba(255,255,255,.08); }
.progress span{ display:block; height:100%; width:0; background:linear-gradient(90deg,var(--cyan),var(--pink),var(--yellow)); box-shadow:var(--glow-pink); transition: width .15s ease; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 900px){
  .nav__links{ display:none; }
  .nav__burger{ display:flex; }
  .nav__links.is-open{
    display:flex; flex-direction:column; gap:1rem; position:absolute; top:100%; left:0; right:0;
    background:rgba(10,4,24,.97); padding:1.2rem 1.4rem; border-bottom:2px solid var(--pink);
  }
  .nav__buy{ display:none; }

  .panel{ flex-direction:column; justify-content:center; text-align:center; gap:1.4rem; padding:84px 1.2rem 60px; }
  .hero__art, .about__art{ max-width:min(78vw, 360px); }
  .hero__content, .about__content{ max-width:90vw; }
  .hero__bio, .about__text{ margin-left:auto; margin-right:auto; }
  .hero__cta, .hero__chips, .stats{ justify-content:center; }
  .bubble::after, .bubble::before{ left:50%; transform:translateX(-50%); }

  .steps{ grid-template-columns:repeat(2,1fr); }
  .step{ text-align:center; }

  .chart__frame{ max-height:48vh; }
  .about__art{ order:-1; }
}

@media (max-width: 540px){
  .steps{ grid-template-columns:1fr; }
  .nav__logo{ height:42px; }
  .hero__title{ font-size:3.2rem; }
  .dots{ right:10px; }
  .social-card{ width:100%; max-width:280px; }
}

@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; }
  .track{ scroll-behavior:auto; }
}
