/* ============================================================
   DongCoin — Comic Styled Meme Site
   ============================================================ */

:root {
  --orange:   #ff8a00;
  --orange-2: #ffae42;
  --orange-3: #ffc874;
  --yellow:   #ffd23f;
  --ink:      #1a1208;
  --ink-2:    #0d0a06;
  --paper:    #fff7ec;
  --white:    #ffffff;
  --line:     #14110a;
  --glow:     0 0 22px rgba(255,138,0,.65), 0 0 60px rgba(255,138,0,.35);
  --comic-shadow: 6px 6px 0 var(--line);
  --comic-shadow-sm: 4px 4px 0 var(--line);
  --radius: 18px;
  --maxw: 1180px;
}

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

html { scroll-behavior: smooth; scroll-padding-top: 90px; }

body {
  font-family: 'Fredoka', system-ui, sans-serif;
  color: var(--paper);
  background: var(--ink-2);
  overflow-x: hidden;
  line-height: 1.6;
}

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

/* ============================================================
   Animated Background
   ============================================================ */
.bg-stack { position: fixed; inset: 0; z-index: -1; overflow: hidden;
  background:
    radial-gradient(900px 600px at 80% -10%, rgba(255,138,0,.22), transparent 60%),
    radial-gradient(700px 500px at 10% 110%, rgba(255,174,66,.16), transparent 60%),
    linear-gradient(180deg, #120c05 0%, #0d0a06 45%, #140d05 100%);
}

.bg-grid {
  position: absolute; inset: -2px;
  background-image:
    linear-gradient(rgba(255,138,0,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,138,0,.06) 1px, transparent 1px);
  background-size: 46px 46px;
  mask-image: radial-gradient(circle at 50% 30%, #000 30%, transparent 85%);
}

.bg-halftone {
  position: absolute; inset: 0;
  background-image: radial-gradient(rgba(255,174,66,.10) 1.4px, transparent 1.6px);
  background-size: 20px 20px;
  animation: halftoneDrift 22s linear infinite;
}
@keyframes halftoneDrift { to { background-position: 200px 200px; } }

.blob {
  position: absolute; border-radius: 50%; filter: blur(70px); opacity: .55;
  mix-blend-mode: screen; animation: floaty 16s ease-in-out infinite;
}
.blob--1 { width: 480px; height: 480px; top: -120px; right: -80px;
  background: radial-gradient(circle, #ff8a00, transparent 70%); }
.blob--2 { width: 420px; height: 420px; bottom: -140px; left: -100px;
  background: radial-gradient(circle, #ffae42, transparent 70%); animation-delay: -5s; }
.blob--3 { width: 360px; height: 360px; top: 45%; left: 55%;
  background: radial-gradient(circle, #ffd23f, transparent 70%); animation-delay: -9s; opacity:.35; }
@keyframes floaty {
  0%,100% { transform: translate(0,0) scale(1); }
  50% { transform: translate(40px,-30px) scale(1.12); }
}

#sparkles { position: absolute; inset: 0; width: 100%; height: 100%; }

/* ============================================================
   Navbar
   ============================================================ */
.nav {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  gap: 20px; padding: 12px clamp(16px, 4vw, 48px);
  backdrop-filter: blur(10px);
  background: rgba(13,10,6,.55);
  border-bottom: 3px solid var(--line);
  transition: background .3s, box-shadow .3s;
}
.nav.scrolled { background: rgba(13,10,6,.9); box-shadow: 0 6px 30px rgba(0,0,0,.5); }

.nav__brand { display: flex; align-items: center; gap: 12px; }
.nav__logo {
  width: 44px; height: 44px; border-radius: 50%;
  border: 3px solid var(--line); box-shadow: var(--glow);
  animation: spinGlow 6s ease-in-out infinite;
}
@keyframes spinGlow { 0%,100%{ transform: rotate(-4deg); } 50%{ transform: rotate(4deg); } }
.nav__name {
  font-family: 'Bangers', cursive; font-size: 1.7rem; letter-spacing: 1px;
  color: var(--orange-2);
  text-shadow: 2px 2px 0 var(--line);
}

.nav__links { display: flex; align-items: center; gap: 22px; }
.nav__links a:not(.btn) {
  font-weight: 600; font-size: 1rem; position: relative; color: var(--paper);
}
.nav__links a:not(.btn)::after {
  content: ''; position: absolute; left: 0; bottom: -6px; width: 0; height: 3px;
  background: var(--orange); transition: width .25s; border-radius: 3px;
}
.nav__links a:not(.btn):hover { color: var(--orange-2); }
.nav__links a:not(.btn):hover::after { width: 100%; }

.nav__burger { display: none; flex-direction: column; gap: 5px; background: none; border: 0; cursor: pointer; padding: 6px; }
.nav__burger span { width: 28px; height: 3px; background: var(--orange-2); border-radius: 3px; transition: .3s; }

/* ============================================================
   Buttons
   ============================================================ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: 'Fredoka', sans-serif; font-weight: 700; font-size: 1.05rem;
  padding: 14px 26px; border-radius: 999px; cursor: pointer;
  border: 3px solid var(--line); position: relative; overflow: hidden;
  transition: transform .15s, box-shadow .15s;
}
.btn:active { transform: translate(3px,3px); box-shadow: 2px 2px 0 var(--line) !important; }

.btn--primary {
  background: linear-gradient(135deg, var(--orange), var(--orange-2));
  color: var(--ink); box-shadow: var(--comic-shadow);
}
.btn--primary:hover { transform: translate(-2px,-2px); box-shadow: 8px 8px 0 var(--line); }

.btn--ghost {
  background: rgba(255,255,255,.06); color: var(--paper); box-shadow: var(--comic-shadow);
}
.btn--ghost:hover { background: rgba(255,138,0,.18); transform: translate(-2px,-2px); box-shadow: 8px 8px 0 var(--line); }

.btn--mini { padding: 9px 18px; font-size: .95rem;
  background: linear-gradient(135deg, var(--orange), var(--orange-2)); color: var(--ink);
  box-shadow: var(--comic-shadow-sm); }
.btn--mini:hover { transform: translate(-2px,-2px); box-shadow: 5px 5px 0 var(--line); }

.btn--lg { font-size: 1.25rem; padding: 18px 38px; }

/* shine sweep */
.shine::before {
  content: ''; position: absolute; top: 0; left: -120%; width: 60%; height: 100%;
  background: linear-gradient(120deg, transparent, rgba(255,255,255,.75), transparent);
  transform: skewX(-20deg); animation: sweep 3.2s ease-in-out infinite;
}
@keyframes sweep { 0%{ left:-120%; } 55%,100%{ left:160%; } }

/* ============================================================
   Ticker
   ============================================================ */
.ticker {
  background: linear-gradient(90deg, var(--orange), var(--orange-2));
  border-top: 3px solid var(--line); border-bottom: 3px solid var(--line);
  overflow: hidden; padding: 9px 0;
}
.ticker__track {
  display: flex; gap: 46px; white-space: nowrap; width: max-content;
  animation: scrollx 24s linear infinite;
}
.ticker__track span {
  font-family: 'Bangers', cursive; font-size: 1.15rem; letter-spacing: 1.5px;
  color: var(--ink); text-shadow: 1px 1px 0 rgba(255,255,255,.4);
}
@keyframes scrollx { to { transform: translateX(-50%); } }

/* ============================================================
   Layout helpers
   ============================================================ */
.section { max-width: var(--maxw); margin: 0 auto; padding: clamp(70px, 9vw, 120px) clamp(16px, 4vw, 32px); }
.section__head { text-align: center; margin-bottom: 54px; }
.section__lead { font-size: 1.2rem; color: var(--orange-3); font-weight: 500; margin-top: 6px; }

.title-burst {
  font-family: 'Luckiest Guy', cursive; font-size: clamp(2.2rem, 6vw, 3.8rem);
  letter-spacing: 1px; color: var(--paper); line-height: 1.05;
  text-shadow: 4px 4px 0 var(--line);
}
.title-burst span { color: var(--orange); -webkit-text-stroke: 1px var(--line); }

.badge {
  display: inline-block; font-family:'Bangers',cursive; letter-spacing:1px;
  background: var(--yellow); color: var(--ink); padding: 6px 16px;
  border: 3px solid var(--line); border-radius: 999px; box-shadow: var(--comic-shadow-sm);
  transform: rotate(-2deg);
}

/* ============================================================
   HERO
   ============================================================ */
.hero { position: relative; max-width: var(--maxw); margin: 0 auto;
  padding: clamp(40px,7vw,90px) clamp(16px,4vw,32px) 70px; }
.hero__inner {
  display: grid; grid-template-columns: 1.05fr .95fr; gap: 50px; align-items: center;
}
.hero__title {
  font-family: 'Luckiest Guy', cursive; line-height: .9; margin: 14px 0 10px;
  display: flex; flex-wrap: wrap; gap: 0 6px;
}
.pow {
  font-size: clamp(3.4rem, 11vw, 7rem); letter-spacing: 2px;
  color: var(--orange);
  text-shadow: 5px 5px 0 var(--line), 0 0 30px rgba(255,138,0,.5);
  animation: pop .6s cubic-bezier(.2,1.4,.4,1) both;
}
.pow--alt { color: var(--paper); -webkit-text-stroke: 2px var(--line); animation-delay: .12s; }
@keyframes pop { 0%{ transform: scale(.4) rotate(-8deg); opacity:0; } 100%{ transform: scale(1) rotate(0); opacity:1; } }

.hero__tag { font-size: clamp(1.3rem,2.6vw,1.7rem); font-weight: 700; margin-bottom: 12px; }
.hero__tag .hl { color: var(--orange-2); }
.hero__sub { font-size: 1.08rem; color: #f3e4cf; max-width: 520px; margin-bottom: 26px; }

.hero__cta { display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 30px; }

.hero__stats { display: flex; gap: 14px; flex-wrap: wrap; }
.stat {
  display: flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,.06); border: 3px solid var(--line);
  border-radius: 999px; padding: 8px 16px; box-shadow: var(--comic-shadow-sm);
  font-weight: 600;
}
.stat__pin { font-size: 1.2rem; }

/* hero art */
.hero__art { position: relative; }
.hero__frame {
  position: relative; border: 4px solid var(--line); border-radius: 22px;
  overflow: hidden; box-shadow: var(--comic-shadow), var(--glow);
  background: #000; transform: rotate(1.5deg);
  animation: bob 5s ease-in-out infinite;
}
.hero__frame img { width: 100%; }
@keyframes bob { 0%,100%{ transform: rotate(1.5deg) translateY(0); } 50%{ transform: rotate(1.5deg) translateY(-12px); } }
.hero__glow {
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(circle at 70% 50%, rgba(255,138,0,.25), transparent 60%);
  mix-blend-mode: screen;
}

.float-coin {
  position: absolute; font-family:'Bangers',cursive; font-size: 1.4rem;
  background: var(--yellow); color: var(--ink); border: 3px solid var(--line);
  border-radius: 999px; padding: 8px 16px; box-shadow: var(--comic-shadow-sm);
  animation: floaty 6s ease-in-out infinite;
}
.float-coin--1 { top: -18px; left: -22px; animation-delay: -1s; }
.float-coin--2 { bottom: 30px; left: -30px; font-size: 1.8rem; animation-delay: -3s; }
.float-coin--3 { top: 40%; right: -26px; font-size: 1.8rem; animation-delay: -2s; }

.scroll-cue {
  display: block; text-align: center; color: var(--orange-2); font-size: 1.6rem;
  margin-top: 40px; animation: bounce 1.8s infinite;
}
@keyframes bounce { 0%,100%{ transform: translateY(0); } 50%{ transform: translateY(10px); } }

/* ============================================================
   ABOUT
   ============================================================ */
.about__grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 26px; margin-bottom: 50px;
}
.panel {
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
  border: 4px solid var(--line); border-radius: var(--radius);
  padding: 30px 26px; box-shadow: var(--comic-shadow);
  transition: transform .2s, box-shadow .2s;
}
.panel:hover { transform: translateY(-6px) rotate(-1deg); box-shadow: 9px 12px 0 var(--line); }
.panel__icon {
  font-size: 2.6rem; width: 70px; height: 70px; display: grid; place-items: center;
  background: linear-gradient(135deg, var(--orange), var(--orange-2));
  border: 3px solid var(--line); border-radius: 16px; box-shadow: var(--comic-shadow-sm);
  margin-bottom: 16px;
}
.panel h3 { font-family:'Bangers',cursive; font-size: 1.6rem; letter-spacing:.5px; color: var(--orange-2); margin-bottom: 8px; }
.panel p { color: #ede0cd; }

.token-card {
  display: flex; align-items: center; gap: 30px; flex-wrap: wrap;
  justify-content: center; max-width: 720px; margin: 0 auto;
  background: linear-gradient(135deg, rgba(255,138,0,.16), rgba(255,210,63,.08));
  border: 4px solid var(--line); border-radius: 24px;
  padding: 30px; box-shadow: var(--comic-shadow);
}
.token-card__logo { width: 120px; height: 120px; border-radius: 50%;
  border: 4px solid var(--line); box-shadow: var(--glow); }
.token-card__rows { flex: 1; min-width: 260px; display: grid; gap: 10px; }
.trow {
  display: flex; justify-content: space-between; align-items: center;
  background: rgba(0,0,0,.25); border: 2px solid var(--line); border-radius: 12px;
  padding: 10px 16px;
}
.trow span { color: var(--orange-3); font-weight: 500; }
.trow b { font-family:'Bangers',cursive; font-size: 1.25rem; letter-spacing:.5px; color: var(--white); }

/* ============================================================
   HOW TO BUY
   ============================================================ */
.steps { display: grid; grid-template-columns: repeat(4,1fr); gap: 24px; }
.step {
  position: relative; background: rgba(255,255,255,.05);
  border: 4px solid var(--line); border-radius: var(--radius);
  padding: 38px 22px 26px; box-shadow: var(--comic-shadow);
  transition: transform .2s;
}
.step:hover { transform: translateY(-6px); }
.step__num {
  position: absolute; top: -26px; left: 50%; transform: translateX(-50%);
  width: 56px; height: 56px; display: grid; place-items: center;
  font-family:'Luckiest Guy',cursive; font-size: 1.8rem; color: var(--ink);
  background: linear-gradient(135deg, var(--yellow), var(--orange-2));
  border: 4px solid var(--line); border-radius: 50%; box-shadow: var(--comic-shadow-sm);
}
.step h3 { font-family:'Bangers',cursive; font-size: 1.4rem; color: var(--orange-2); text-align:center; margin-bottom: 8px; letter-spacing:.5px; }
.step p { color: #ede0cd; text-align: center; font-size: .98rem; }
.howtobuy__cta { text-align: center; margin-top: 54px; }

/* ============================================================
   CHART
   ============================================================ */
.chart__frame {
  border: 4px solid var(--line); border-radius: var(--radius); overflow: hidden;
  box-shadow: var(--comic-shadow), var(--glow); background: #0a0a0a;
}
#dexscreener-embed { position: relative; width: 100%; padding-bottom: 62%; }
#dexscreener-embed iframe {
  position: absolute; inset: 0; width: 100%; height: 100%; border: 0;
}
.chart__cta { text-align: center; margin-top: 30px; }
@media (min-width: 800px) { #dexscreener-embed { padding-bottom: 56%; } }

/* ============================================================
   JOIN US
   ============================================================ */
.joinus__banner {
  position: relative; max-width: 900px; margin: 0 auto 50px;
  border: 4px solid var(--line); border-radius: 22px; overflow: hidden;
  box-shadow: var(--comic-shadow), var(--glow);
}
.joinus__banner img { width: 100%; }
.joinus__banner-glow {
  position: absolute; inset: 0; pointer-events: none; mix-blend-mode: screen;
  background: radial-gradient(circle at 30% 50%, rgba(255,255,255,.15), transparent 55%);
  animation: shimmer 4s ease-in-out infinite;
}
@keyframes shimmer { 0%,100%{ opacity:.4; } 50%{ opacity:.9; } }

.joinus__cards {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; max-width: 980px; margin: 0 auto;
}
.social-card {
  display: flex; align-items: center; gap: 16px;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03));
  border: 4px solid var(--line); border-radius: var(--radius);
  padding: 22px; box-shadow: var(--comic-shadow);
  transition: transform .2s, box-shadow .2s; position: relative; overflow: hidden;
}
.social-card:hover { transform: translateY(-6px) rotate(-1deg); box-shadow: 9px 12px 0 var(--line); }
.social-card__icon {
  width: 56px; height: 56px; flex-shrink: 0; display: grid; place-items: center;
  font-size: 1.7rem; border: 3px solid var(--line); border-radius: 14px;
  background: linear-gradient(135deg, var(--orange), var(--orange-2)); color: var(--ink);
  box-shadow: var(--comic-shadow-sm);
}
.social-card--x .social-card__icon { background: linear-gradient(135deg,#fff,#cfcfcf); }
.social-card--tg .social-card__icon { background: linear-gradient(135deg,#34b6ff,#1f9be0); color:#fff; }
.social-card__text b { display: block; font-family:'Bangers',cursive; font-size: 1.3rem; letter-spacing:.5px; }
.social-card__text span { color: var(--orange-3); font-size: .92rem; }
.social-card__arrow { margin-left: auto; font-size: 1.4rem; color: var(--orange-2); transition: transform .2s; }
.social-card:hover .social-card__arrow { transform: translate(4px,-4px); }

/* ============================================================
   Footer
   ============================================================ */
.footer { border-top: 3px solid var(--line); background: rgba(0,0,0,.45); margin-top: 40px; }
.footer__inner { max-width: var(--maxw); margin: 0 auto; padding: 44px clamp(16px,4vw,32px); text-align: center; }
.footer__brand { display: inline-flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.footer__brand img { width: 46px; height: 46px; border-radius: 50%; border: 3px solid var(--line); box-shadow: var(--glow); }
.footer__brand span { font-family:'Bangers',cursive; font-size: 1.7rem; color: var(--orange-2); text-shadow: 2px 2px 0 var(--line); }
.footer__links { display: flex; flex-wrap: wrap; gap: 22px; justify-content: center; margin-bottom: 18px; }
.footer__links a { font-weight: 600; }
.footer__links a:hover { color: var(--orange-2); }
.footer__disclaim { color: #b8a890; font-size: .85rem; max-width: 720px; margin: 0 auto 12px; }
.footer__copy { color: var(--orange-3); font-weight: 600; }

/* ============================================================
   Scroll Reveal
   ============================================================ */
.reveal { opacity: 0; transform: translateY(34px); transition: opacity .7s ease, transform .7s cubic-bezier(.2,.8,.3,1); }
.reveal.in { opacity: 1; transform: none; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 900px) {
  .hero__inner { grid-template-columns: 1fr; text-align: center; }
  .hero__copy { order: 2; }
  .hero__art { order: 1; max-width: 460px; margin: 0 auto; }
  .hero__cta, .hero__stats { justify-content: center; }
  .about__grid { grid-template-columns: 1fr; }
  .steps { grid-template-columns: repeat(2,1fr); gap: 38px 22px; }
  .joinus__cards { grid-template-columns: 1fr; }
}

@media (max-width: 720px) {
  .nav__links {
    position: fixed; inset: 64px 0 auto 0; flex-direction: column; gap: 18px;
    background: rgba(13,10,6,.97); border-bottom: 3px solid var(--line);
    padding: 26px; transform: translateY(-130%); transition: transform .3s; z-index: 49;
  }
  .nav__links.open { transform: translateY(0); }
  .nav__burger { display: flex; }
  .steps { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
  .reveal { opacity: 1; transform: none; }
}
