/* ==========================================================
   THE BINANCE BULL — $BULLBNB
   Binance black & gold · anime energy · presale-first
   ========================================================== */

:root{
  --ink:        #0B0E11;   /* Binance page black */
  --panel:      #181A20;   /* Binance card */
  --panel-2:    #1E2329;
  --gold:       #F0B90B;   /* BNB gold */
  --gold-hi:    #FCD535;   /* bright gold */
  --red:        #C6353F;   /* coat-trim red, sparingly */
  --text:       #EAECEF;
  --muted:      #848E9C;
  --line:       rgba(240,185,11,.16);
  --font-display:'Chakra Petch', sans-serif;
  --font-body:  'IBM Plex Sans', sans-serif;
  --font-mono:  'IBM Plex Mono', monospace;
  --radius: 14px;
  --max: 1180px;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  background:var(--ink);
  color:var(--text);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.65;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

h1,h2,h3{ font-family:var(--font-display); line-height:1.1; letter-spacing:.01em; }
h2{ font-size:clamp(1.7rem, 3.4vw, 2.6rem); font-weight:700; }
h3{ font-size:1.15rem; font-weight:600; }
.gold{ color:var(--gold); }
.gold-link{ color:var(--gold); border-bottom:1px dashed rgba(240,185,11,.4); transition:color .2s, border-color .2s; }
.gold-link:hover{ color:var(--gold-hi); border-color:var(--gold-hi); }
.mono{ font-family:var(--font-mono); font-size:.9em; }

.eyebrow{
  font-family:var(--font-mono);
  font-size:.78rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
  margin-bottom:1rem;
  display:flex; align-items:center; gap:.55rem;
}
.eyebrow.gold{ color:var(--gold); }
.eyebrow .dot{
  width:8px; height:8px; border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 8px var(--gold);
  animation:pulse 1.8s ease-in-out infinite;
}
@keyframes pulse{ 0%,100%{opacity:1; transform:scale(1);} 50%{opacity:.45; transform:scale(.75);} }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:700;
  padding:.75rem 1.5rem; border-radius:10px;
  border:1px solid transparent;
  cursor:pointer; transition:transform .18s ease, box-shadow .18s ease, background .18s ease, color .18s ease;
  letter-spacing:.03em;
}
.btn-lg{ padding:.95rem 2rem; font-size:1.02rem; }
.btn-gold{
  background:linear-gradient(180deg, var(--gold-hi), var(--gold));
  color:#111;
  box-shadow:0 6px 24px rgba(240,185,11,.28);
}
.btn-gold:hover{ transform:translateY(-2px); box-shadow:0 10px 32px rgba(240,185,11,.42); }
.btn-ghost{
  border-color:var(--line); color:var(--text);
  background:rgba(255,255,255,.02);
}
.btn-ghost:hover{ border-color:var(--gold); color:var(--gold); }

/* ---------- Nav ---------- */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:100;
  background:rgba(11,14,17,.82);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(240,185,11,.10);
}
.nav-inner{
  max-width:var(--max); margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:.65rem 1.25rem;
}
.brand{ display:flex; align-items:center; gap:.7rem; }
.brand-logo{ width:42px; height:42px; border-radius:50%; }
.brand-name{
  font-family:var(--font-display); font-weight:700; font-size:.95rem;
  letter-spacing:.08em;
}
.brand-kanji{ color:var(--gold); }
.nav-links{ display:flex; align-items:center; gap:1.6rem; font-size:.92rem; }
.nav-links a:not(.btn){
  color:var(--muted); position:relative; transition:color .2s;
}
.nav-links a:not(.btn)::after{
  content:""; position:absolute; left:0; bottom:-6px;
  width:0; height:2px; background:var(--gold); transition:width .22s ease;
}
.nav-links a:not(.btn):hover{ color:var(--text); }
.nav-links a:not(.btn):hover::after{ width:100%; }
.btn-nav{ padding:.55rem 1.15rem; font-size:.88rem; }
.nav-toggle{ display:none; background:none; border:none; cursor:pointer; }
.nav-toggle span{
  display:block; width:24px; height:2px; background:var(--gold);
  margin:5px 0; transition:transform .25s ease, opacity .25s ease;
}
.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); }

/* ---------- Hero ---------- */
.hero{
  position:relative;
  min-height:100vh;
  display:flex; align-items:center;
  padding:7.5rem 1.25rem 4rem;
  background:
    radial-gradient(1000px 600px at 78% 30%, rgba(240,185,11,.10), transparent 60%),
    radial-gradient(700px 500px at 12% 85%, rgba(240,185,11,.05), transparent 60%),
    var(--ink);
  overflow:hidden;
}
#sparks{ position:absolute; inset:0; width:100%; height:100%; pointer-events:none; }
.hero-kanji{
  position:absolute; right:-3rem; top:50%; transform:translateY(-50%);
  font-size:clamp(20rem, 42vw, 38rem);
  font-weight:700; line-height:1;
  color:transparent;
  -webkit-text-stroke:1.5px rgba(240,185,11,.07);
  user-select:none; pointer-events:none;
  font-family:serif;
}
.hero-inner{
  position:relative; z-index:2;
  max-width:var(--max); margin:0 auto; width:100%;
  display:grid; grid-template-columns:1.05fr .95fr; gap:3rem; align-items:center;
}
.hero-title{
  font-size:clamp(3rem, 7.5vw, 5.6rem);
  font-weight:700;
  letter-spacing:.02em;
  text-transform:uppercase;
  margin:0 0 1.25rem;
}
.hero-title .gold{
  background:linear-gradient(180deg, var(--gold-hi) 20%, var(--gold) 60%, #b8860b);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
  text-shadow:0 0 60px rgba(240,185,11,.25);
}
.hero-sub{ color:var(--muted); font-size:1.08rem; max-width:34rem; margin-bottom:2rem; }
.hero-sub strong{ font-weight:600; }
.hero-cta{ display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:1.8rem; }

.contract-box{
  display:inline-flex; align-items:center; gap:.7rem;
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:10px;
  padding:.6rem .95rem;
  font-family:var(--font-mono); font-size:.82rem;
  cursor:pointer;
  transition:border-color .2s;
  max-width:100%;
}
.contract-box:hover{ border-color:var(--gold); }
.contract-label{
  background:var(--gold); color:#111;
  font-weight:700; border-radius:6px;
  padding:.1rem .45rem; font-size:.75rem;
}
.contract-value{ color:var(--muted); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.contract-copy{ color:var(--gold); }

.hero-art{ position:relative; }
.hero-art img{
  border-radius:var(--radius);
  border:1px solid rgba(240,185,11,.28);
  box-shadow:0 20px 80px rgba(0,0,0,.6), 0 0 60px rgba(240,185,11,.12);
  animation:float 6s ease-in-out infinite;
}
.hero-art-glow{
  position:absolute; inset:-12%;
  background:radial-gradient(circle, rgba(240,185,11,.16), transparent 65%);
  filter:blur(10px);
  z-index:-1;
}
@keyframes float{ 0%,100%{ transform:translateY(0);} 50%{ transform:translateY(-12px);} }

/* ---------- Ticker ---------- */
.ticker{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  background:linear-gradient(90deg, rgba(240,185,11,.06), rgba(240,185,11,.10), rgba(240,185,11,.06));
  overflow:hidden;
  padding:.7rem 0;
}
.ticker-track{
  display:flex; width:max-content;
  animation:ticker 28s linear infinite;
  font-family:var(--font-display); font-weight:600;
  font-size:.95rem; letter-spacing:.16em;
  color:var(--gold);
  white-space:nowrap;
}
@keyframes ticker{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }

/* ---------- Sections ---------- */
.section{ position:relative; padding:6rem 1.25rem; overflow:hidden; }
.section-dark{ background:var(--panel); border-top:1px solid rgba(255,255,255,.03); border-bottom:1px solid rgba(255,255,255,.03); }
.section-inner{ max-width:var(--max); margin:0 auto; position:relative; z-index:2; }
.section-kanji{
  position:absolute; left:-2rem; top:1rem;
  font-size:16rem; font-family:serif; font-weight:700; line-height:1;
  color:transparent;
  -webkit-text-stroke:1.5px rgba(240,185,11,.06);
  user-select:none; pointer-events:none;
}
.section-head{ max-width:44rem; margin-bottom:3rem; }
.section-sub{ color:var(--muted); margin-top:.9rem; }

/* ---------- Lore split ---------- */
.split{ display:grid; grid-template-columns:.9fr 1.1fr; gap:3.5rem; align-items:center; }
.split-copy h2{ margin-bottom:1.2rem; }
.split-copy p{ color:var(--muted); margin-bottom:1.1rem; }
.split-copy strong{ color:var(--text); }
.framed{
  border-radius:var(--radius);
  border:1px solid rgba(240,185,11,.25);
  box-shadow:0 16px 60px rgba(0,0,0,.55);
}
.lore-points{ list-style:none; margin-top:1.4rem; }
.lore-points li{
  display:flex; gap:.75rem; align-items:baseline;
  padding:.55rem 0; border-top:1px solid rgba(255,255,255,.05);
  color:var(--text); font-size:.98rem;
}

/* ---------- Gallery ---------- */
.gallery-grid{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:1.2rem;
}
.g-item{
  position:relative; border-radius:var(--radius); overflow:hidden;
  border:1px solid rgba(255,255,255,.06);
  background:var(--panel-2);
}
.g-item img{
  aspect-ratio:1/1; object-fit:cover; width:100%;
  transition:transform .5s ease, filter .5s ease;
}
.g-item:hover img{ transform:scale(1.05); filter:brightness(1.08); }
.g-item figcaption{
  position:absolute; inset:auto 0 0 0;
  padding:2.2rem .9rem .8rem;
  background:linear-gradient(transparent, rgba(11,14,17,.92));
  font-family:var(--font-display); font-weight:600; font-size:.9rem;
  letter-spacing:.06em; color:var(--gold);
}

/* ---------- Tokenomics ---------- */
.tok-grid{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:1.2rem;
  margin-bottom:2rem;
}
.tok-card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.8rem 1.4rem;
  text-align:center;
  transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}
.tok-card:hover{
  transform:translateY(-4px);
  border-color:rgba(240,185,11,.45);
  box-shadow:0 12px 40px rgba(0,0,0,.4);
}
.tok-value{
  font-family:var(--font-display); font-weight:700;
  font-size:clamp(1.4rem, 2.4vw, 1.9rem);
  margin-bottom:.4rem;
  white-space:nowrap;
}
.tok-label{ color:var(--muted); font-size:.88rem; }
.tok-meta{
  background:var(--panel);
  border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius);
  padding:.4rem 1.4rem;
}
.tok-meta-row{
  display:flex; justify-content:space-between; align-items:center; gap:1rem;
  padding:.85rem 0;
  border-bottom:1px solid rgba(255,255,255,.05);
  font-size:.95rem;
}
.tok-meta-row:last-child{ border-bottom:none; }
.tok-meta-row > span:first-child{ color:var(--muted); }
.tok-meta-row .mono{ text-align:right; word-break:break-all; }

/* ---------- Steps ---------- */
.steps{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:1.2rem;
}
.step{
  background:var(--ink);
  border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius);
  padding:1.8rem 1.5rem;
  position:relative;
  transition:border-color .2s ease, transform .2s ease;
}
.step:hover{ border-color:rgba(240,185,11,.4); transform:translateY(-4px); }
.step-num{
  font-family:var(--font-display); font-weight:700;
  font-size:2.2rem; color:transparent;
  -webkit-text-stroke:1.5px var(--gold);
  margin-bottom:.9rem;
}
.step h3{ margin-bottom:.6rem; }
.step p{ color:var(--muted); font-size:.92rem; }

/* ---------- CTA band ---------- */
.cta-band{
  position:relative; text-align:center;
  padding:7rem 1.25rem;
  overflow:hidden;
}
.cta-bg{
  position:absolute; inset:0;
  background:url('../images/battle-wide.jpg') center 30%/cover no-repeat;
  filter:brightness(.34) saturate(1.05);
  transform:scale(1.06);
}
.cta-band::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, var(--ink) 0%, transparent 25%, transparent 75%, var(--ink) 100%);
}
.cta-inner{ position:relative; z-index:2; max-width:44rem; margin:0 auto; }
.cta-logo{
  width:84px; height:84px; border-radius:50%;
  margin:0 auto 1.4rem;
  box-shadow:0 0 40px rgba(240,185,11,.4);
}
.cta-inner h2{ font-size:clamp(1.9rem, 4vw, 3rem); margin-bottom:1rem; }
.cta-inner p{ color:var(--muted); margin-bottom:2rem; font-size:1.05rem; }

/* ---------- Community ---------- */
.socials{
  display:grid; grid-template-columns:repeat(4, 1fr); gap:1.2rem;
}
.social-card{
  background:var(--panel);
  border:1px solid rgba(255,255,255,.06);
  border-radius:var(--radius);
  padding:1.7rem 1.4rem;
  display:flex; flex-direction:column; gap:.3rem;
  transition:border-color .2s ease, transform .2s ease;
}
.social-card:hover{ border-color:rgba(240,185,11,.5); transform:translateY(-4px); }
.social-icon{ font-size:1.6rem; color:var(--gold); margin-bottom:.4rem; }
.social-name{ font-family:var(--font-display); font-weight:600; }
.social-sub{ color:var(--muted); font-size:.85rem; font-family:var(--font-mono); }

/* ---------- Footer ---------- */
.footer{
  border-top:1px solid var(--line);
  padding:3.5rem 1.25rem 2.5rem;
  text-align:center;
  background:#08090b;
}
.footer-inner{ max-width:46rem; margin:0 auto; }
.footer-logo{ width:56px; height:56px; border-radius:50%; margin:0 auto 1rem; opacity:.9; }
.footer-name{ font-family:var(--font-display); font-weight:700; letter-spacing:.1em; margin-bottom:1.2rem; }
.footer-disclaimer{ color:var(--muted); font-size:.78rem; line-height:1.7; margin-bottom:1.4rem; }
.footer-copy{ color:var(--muted); font-size:.8rem; font-family:var(--font-mono); }

/* ---------- Reveal on scroll ---------- */
.reveal{
  opacity:0; transform:translateY(26px);
  transition:opacity .7s ease, transform .7s ease;
}
.reveal-delay{ transition-delay:.15s; }
.reveal.in{ opacity:1; transform:none; }

/* ---------- Responsive ---------- */
@media (max-width: 1020px){
  .hero-inner{ grid-template-columns:1fr; gap:2.5rem; }
  .hero-art{ max-width:520px; }
  .gallery-grid{ grid-template-columns:repeat(2, 1fr); }
  .tok-grid{ grid-template-columns:repeat(2, 1fr); }
  .steps{ grid-template-columns:repeat(2, 1fr); }
  .split{ grid-template-columns:1fr; gap:2.5rem; }
  .socials{ grid-template-columns:repeat(2, 1fr); }
  .split-media{ max-width:520px; }
}
@media (max-width: 760px){
  body{ font-size:16px; }
  .nav-links{
    position:fixed; top:59px; right:0; left:0;
    background:rgba(11,14,17,.98);
    border-bottom:1px solid var(--line);
    flex-direction:column; align-items:flex-start;
    padding:1.4rem 1.5rem;
    gap:1.15rem;
    transform:translateY(-130%);
    transition:transform .3s ease;
  }
  .nav-links.open{ transform:translateY(0); }
  .nav-toggle{ display:block; }
  .brand-name{ font-size:.8rem; }
  .hero{ padding-top:6.2rem; min-height:auto; }
  .hero-kanji{ right:-6rem; opacity:.7; }
  .section{ padding:4.2rem 1.25rem; }
  .socials{ grid-template-columns:1fr; }
  .contract-box{ width:100%; }
}
@media (max-width: 480px){
  .gallery-grid{ grid-template-columns:1fr; }
  .tok-grid{ grid-template-columns:1fr; }
  .steps{ grid-template-columns:1fr; }
  .hero-cta .btn{ width:100%; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *,*::before,*::after{ animation-duration:.001s !important; animation-iteration-count:1 !important; transition-duration:.001s !important; }
  .reveal{ opacity:1; transform:none; }
  .ticker-track{ animation:none; }
  .hero-art img{ animation:none; }
}

/* ---------- Focus visibility ---------- */
a:focus-visible, button:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:3px;
  border-radius:6px;
}
