/* ============================================================
   GREEN EMPIRE — Voxel Botanical site system
   Two-accent dark: deep green soil + amber grow-light bloom.
   Type: Chakra Petch (display) / Space Grotesk (body) / Space Mono (data).
   ============================================================ */

:root {
  --void: #0a120a;
  --soil: #0c150b;
  --panel: #111a0e;
  --panel-2: #16240e;
  --ground: #1a2e12;
  --border: #2a4a1e;
  --border-soft: #1c331492;

  --bloom: #ff6040;
  --bloom-core: #ff4020;
  --lime: #a0f050;
  --spark: #c8ff60;
  --leaf: #6dc940;
  --leaf-deep: #3a9020;

  --text: #c2e8a0;
  --text-2: #8fc266;
  --muted: #5d8a42;
  --label: #436a2c;

  /* rarity ramp */
  --r-common: #5c8a44;
  --r-uncommon: #6dc940;
  --r-rare: #a0f050;
  --r-legendary: #f0c850;
  --r-mythic: #c060e0;

  --maxw: 1180px;
  --radius: 0px;                 /* pixel look: hard square edges everywhere */
  --pxsh: #05230b;               /* hard drop-shadow colour for the 8-bit offset */
  --display: 'Press Start 2P', 'Chakra Petch', system-ui, sans-serif;
  --display-soft: 'Chakra Petch', system-ui, sans-serif;
  --body: 'Space Grotesk', system-ui, sans-serif;
  --mono: 'Space Mono', ui-monospace, 'SF Mono', Menlo, monospace;
  --pixel: 'Press Start 2P', 'Space Mono', monospace;
}

/* Pixel art must stay crisp — never smooth on upscale. */
img { image-rendering: pixelated; image-rendering: crisp-edges; }

*, *::before, *::after { box-sizing: border-box; }

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

body {
  margin: 0;
  font-family: var(--body);
  color: var(--text);
  background: var(--void);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  /* faint isometric ground grid */
  background-image:
    linear-gradient(120deg, #15240d18 1px, transparent 1px),
    linear-gradient(240deg, #15240d18 1px, transparent 1px);
  background-size: 56px 96px;
}

img { max-width: 100%; display: block; }
a { color: var(--leaf); text-decoration: none; }

::selection { background: var(--bloom); color: #1a0a06; }

/* ---------- type ---------- */
h1, h2, h3, h4 { font-family: var(--display); font-weight: 700; line-height: 1.05; margin: 0; letter-spacing: -0.01em; text-wrap: balance; }
.eyebrow {
  font-family: var(--mono);
  font-size: 0.72rem; letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--leaf); margin: 0 0 14px;
}
.eyebrow::before { content: '▟ '; color: var(--bloom); }

p { margin: 0 0 1em; }
.lead { font-size: 1.15rem; color: var(--text); max-width: 60ch; }
.muted { color: var(--muted); }

/* ---------- layout ---------- */
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
section { padding: 100px 0; position: relative; }
.section-head { max-width: 64ch; margin-bottom: 52px; }
.section-head h2 { font-size: clamp(1.9rem, 4vw, 3rem); text-transform: uppercase; }
.section-head p { margin-top: 16px; color: var(--text-2); font-size: 1.05rem; }

/* ---------- nav ---------- */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: #0a120ad9; backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border-soft);
}
.nav .wrap { display: flex; align-items: center; gap: 32px; height: 64px; }
.brand { display: flex; align-items: center; gap: 10px; font-family: var(--display); font-weight: 700; letter-spacing: 0.04em; color: var(--text); font-size: 1.05rem; }
.brand .glyph { width: 26px; height: 26px; display: grid; place-items: center; background: var(--panel-2); border: 1px solid var(--border); border-radius: 5px; box-shadow: 0 0 14px #6dc94033; }
.nav-links { display: flex; gap: 26px; margin-left: auto; font-family: var(--mono); font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.08em; }
.nav-links a { color: var(--text-2); }
.nav-links a:hover { color: var(--spark); }

/* ---------- buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 0.8rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.08em;
  padding: 13px 22px; border-radius: var(--radius); cursor: pointer;
  border: 1px solid transparent; transition: transform .12s, box-shadow .2s, background .2s;
}
.btn-primary { background: linear-gradient(180deg, #2a5a1a, #1a3c0e); color: var(--spark); border-color: var(--lime); box-shadow: 0 0 0 1px #a0f05022, 0 8px 24px #00000055; }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 0 24px #a0f05044, 0 10px 28px #000000aa; }
.btn-ghost { background: transparent; color: var(--bloom); border-color: #ff604066; }
.btn-ghost:hover { background: #ff60400f; border-color: var(--bloom); transform: translateY(-2px); }
.btn[aria-disabled="true"] { opacity: .6; pointer-events: none; }

/* ---------- hero ---------- */
.hero { padding: 84px 0 70px; overflow: hidden; }
.hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 48px; align-items: center; }
.hero h1 { font-size: clamp(2.6rem, 6vw, 4.6rem); text-transform: uppercase; }
.hero h1 .glow { color: var(--spark); text-shadow: 0 0 30px #a0f05055; }
.hero h1 .bloomword { color: var(--bloom); text-shadow: 0 0 34px #ff604066; }
.hero .lead { margin-top: 22px; font-size: 1.2rem; }
.hero-cta { display: flex; gap: 14px; margin-top: 30px; flex-wrap: wrap; }
.hero-tags { display: flex; gap: 18px; margin-top: 26px; font-family: var(--mono); font-size: 0.72rem; color: var(--muted); text-transform: uppercase; letter-spacing: 0.1em; flex-wrap: wrap; }
.hero-tags span::before { content: '◆ '; color: var(--leaf-deep); }

.scene-frame { position: relative; border: 1px solid var(--border); border-radius: 10px; background: radial-gradient(120% 120% at 50% 30%, #16240e, #0a120a 70%); padding: 18px; box-shadow: inset 0 0 60px #00000080, 0 30px 80px #00000099; }
.scene-frame::before { content: ''; position: absolute; inset: -1px; border-radius: 10px; background: radial-gradient(60% 50% at 52% 38%, #ff604033, transparent 70%); pointer-events: none; z-index: 0; animation: bloom 5s ease-in-out infinite; }
.scene-frame img { position: relative; z-index: 1; width: 100%; image-rendering: auto; }
.scene-cap { position: relative; z-index: 1; margin-top: 12px; font-family: var(--mono); font-size: 0.68rem; text-transform: uppercase; letter-spacing: 0.14em; color: var(--label); text-align: center; }
@keyframes bloom { 0%,100% { opacity: .55; } 50% { opacity: .95; } }

/* ---------- ticker ---------- */
.ticker { border-top: 1px solid var(--border-soft); border-bottom: 1px solid var(--border-soft); background: linear-gradient(180deg, #0e1709, #0a120a); overflow: hidden; padding: 0; }
.ticker-track { display: flex; gap: 0; width: max-content; animation: scroll 38s linear infinite; }
.ticker:hover .ticker-track { animation-play-state: paused; }
.ticker-item { font-family: var(--mono); font-size: 0.82rem; padding: 14px 26px; white-space: nowrap; color: var(--text-2); border-right: 1px solid var(--border-soft); letter-spacing: 0.04em; }
.ticker-item b { color: var(--spark); font-weight: 700; }
.ticker-item .up { color: var(--leaf); }
.ticker-item .flag { color: var(--bloom); }
@keyframes scroll { to { transform: translateX(-50%); } }

/* ---------- panels / cards ---------- */
.panel { background: var(--panel); border: 1px solid var(--border); border-radius: 8px; }

.stat-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 8px; }
.stat { padding: 26px; text-align: center; }
.stat .num { font-family: var(--display); font-size: 2.6rem; color: var(--spark); line-height: 1; }
.stat .lbl { font-family: var(--mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.14em; color: var(--muted); margin-top: 10px; }

.features { display: grid; grid-template-columns: repeat(6, 1fr); gap: 18px; }
.feature { grid-column: span 2; padding: 28px; display: flex; flex-direction: column; gap: 14px; transition: border-color .2s, transform .2s; }
.feature:hover { border-color: var(--lime); transform: translateY(-3px); }
.feature.wide { grid-column: span 3; }
.feature .tag { font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--bloom); }
.feature h3 { font-size: 1.35rem; text-transform: uppercase; color: var(--text); }
.feature p { color: var(--text-2); font-size: 0.96rem; margin: 0; }

/* rarity chips */
.rarities { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 4px; }
.chip { font-family: var(--mono); font-size: 0.66rem; text-transform: uppercase; letter-spacing: 0.08em; padding: 4px 9px; border-radius: 4px; border: 1px solid currentColor; }
.chip.common { color: var(--r-common); }
.chip.uncommon { color: var(--r-uncommon); }
.chip.rare { color: var(--r-rare); }
.chip.legendary { color: var(--r-legendary); box-shadow: 0 0 12px #f0c85033; }
.chip.mythic { color: var(--r-mythic); box-shadow: 0 0 12px #c060e033; }

/* trait bars */
.traits { display: grid; gap: 7px; margin-top: 2px; }
.trait { display: grid; grid-template-columns: 64px 1fr; align-items: center; gap: 10px; font-family: var(--mono); font-size: 0.64rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); }
.trait .bar { height: 7px; background: #0c160a; border: 1px solid var(--border-soft); border-radius: 3px; overflow: hidden; }
.trait .bar i { display: block; height: 100%; background: linear-gradient(90deg, var(--leaf-deep), var(--lime)); }

/* multiplier chips */
.mults { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 4px; }
.mult { font-family: var(--mono); font-size: 0.8rem; padding: 6px 12px; border: 1px solid var(--border); border-radius: 5px; color: var(--text-2); }
.mult b { color: var(--spark); }

/* ---------- how it plays (loop) ---------- */
.loop-grid { display: grid; grid-template-columns: 1fr 360px; gap: 56px; align-items: center; }
.steps { display: grid; gap: 0; }
.step { display: grid; grid-template-columns: 56px 1fr; gap: 20px; padding: 24px 0; border-bottom: 1px solid var(--border-soft); }
.step:last-child { border-bottom: 0; }
.step .n { font-family: var(--mono); font-size: 1.5rem; color: var(--bloom); font-weight: 700; }
.step h3 { font-size: 1.15rem; text-transform: uppercase; color: var(--text); margin-bottom: 6px; }
.step p { color: var(--text-2); margin: 0; font-size: 0.95rem; }

/* ---------- progression ---------- */
.arc { display: flex; gap: 0; flex-wrap: wrap; border: 1px solid var(--border); border-radius: 8px; overflow: hidden; }
.arc .stage { flex: 1 1 12.5%; min-width: 130px; padding: 22px 16px; border-right: 1px solid var(--border-soft); background: linear-gradient(180deg, transparent, #0e170980); }
.arc .stage:last-child { border-right: 0; }
.arc .stage .s-n { font-family: var(--mono); font-size: 0.66rem; color: var(--label); letter-spacing: 0.12em; }
.arc .stage .s-t { font-family: var(--display); text-transform: uppercase; font-size: 1rem; margin: 8px 0 4px; color: var(--text); }
.arc .stage .s-h { font-family: var(--mono); font-size: 0.66rem; color: var(--muted); }
.arc .stage:hover { background: linear-gradient(180deg, #16240e, #0e1709); }

/* ---------- crypto stance ---------- */
.stance { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
.stance > div { padding: 40px; }
.stance .a { background: linear-gradient(160deg, #16240e, #0e1709); border-right: 1px solid var(--border); }
.stance h3 { font-size: 1.6rem; text-transform: uppercase; margin-bottom: 14px; }
.stance .big { font-family: var(--display); font-size: 2rem; color: var(--spark); text-transform: uppercase; }
.stance .big span { color: var(--bloom); }
.stance ul { list-style: none; padding: 0; margin: 14px 0 0; display: grid; gap: 10px; }
.stance li { font-size: 0.95rem; color: var(--text-2); padding-left: 22px; position: relative; }
.stance li::before { content: '▸'; position: absolute; left: 0; color: var(--leaf); }

/* ---------- cta band ---------- */
.cta-band { text-align: center; border: 1px solid var(--border); border-radius: 12px; padding: 64px 24px; background: radial-gradient(80% 140% at 50% 0%, #16240e, #0a120a); position: relative; overflow: hidden; }
.cta-band::after { content: ''; position: absolute; inset: 0; background: radial-gradient(50% 60% at 50% -10%, #ff604022, transparent 70%); pointer-events: none; }
.cta-band h2 { font-size: clamp(2rem, 5vw, 3.4rem); text-transform: uppercase; position: relative; }
.cta-band p { color: var(--text-2); margin: 16px auto 28px; max-width: 48ch; position: relative; }
.cta-band .hero-cta { justify-content: center; position: relative; }

/* ---------- footer ---------- */
footer { border-top: 1px solid var(--border-soft); padding: 56px 0 40px; }
.foot-grid { display: flex; justify-content: space-between; gap: 40px; flex-wrap: wrap; }
.foot-col h4 { font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); margin-bottom: 14px; }
.foot-col a { display: block; color: var(--text-2); font-size: 0.9rem; padding: 4px 0; }
.foot-col a:hover { color: var(--spark); }
.foot-bottom { margin-top: 44px; padding-top: 22px; border-top: 1px solid var(--border-soft); display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; font-family: var(--mono); font-size: 0.72rem; color: var(--label); letter-spacing: 0.06em; }
.badge18 { border: 1px solid var(--border); border-radius: 4px; padding: 2px 8px; color: var(--bloom); }

/* ---------- docs ---------- */
.docs-layout { display: grid; grid-template-columns: 230px 1fr; gap: 48px; align-items: start; padding-top: 56px; }
.docs-nav { position: sticky; top: 88px; font-family: var(--mono); font-size: 0.82rem; }
.docs-nav .g { color: var(--label); text-transform: uppercase; letter-spacing: 0.14em; font-size: 0.66rem; margin: 22px 0 8px; }
.docs-nav a { display: block; color: var(--text-2); padding: 6px 0 6px 14px; border-left: 1px solid var(--border-soft); }
.docs-nav a:hover { color: var(--spark); border-left-color: var(--lime); }
.docs-body { max-width: 72ch; }
.docs-body h1 { font-size: clamp(2rem, 4vw, 3rem); text-transform: uppercase; margin-bottom: 10px; }
.docs-body .doc-sec { padding: 36px 0; border-bottom: 1px solid var(--border-soft); scroll-margin-top: 84px; }
.docs-body h2 { font-size: 1.6rem; text-transform: uppercase; color: var(--text); margin-bottom: 14px; }
.docs-body h2 .num { font-family: var(--mono); color: var(--bloom); font-size: 1rem; margin-right: 10px; }
.docs-body h3 { font-size: 1.05rem; color: var(--lime); margin: 22px 0 8px; }
.docs-body p, .docs-body li { color: var(--text-2); }
.docs-body ul { padding-left: 20px; }
.docs-body li { margin: 6px 0; }
.docs-body code { font-family: var(--mono); font-size: 0.85em; background: #0e1709; border: 1px solid var(--border-soft); border-radius: 4px; padding: 1px 6px; color: var(--spark); }
.callout { border: 1px solid var(--border); border-left: 3px solid var(--bloom); border-radius: 6px; background: #0e170980; padding: 16px 20px; margin: 18px 0; }
.callout b { color: var(--spark); }
.faq dt { font-family: var(--display); text-transform: uppercase; color: var(--text); margin-top: 18px; font-size: 1rem; }
.faq dd { margin: 6px 0 0; color: var(--text-2); }

/* ---------- responsive ---------- */
@media (max-width: 900px) {
  .hero-grid, .loop-grid, .stance, .docs-layout { grid-template-columns: 1fr; }
  .features { grid-template-columns: repeat(2, 1fr); }
  .feature, .feature.wide { grid-column: span 2; }
  .stat-row { grid-template-columns: 1fr; }
  .docs-nav { position: static; margin-bottom: 24px; }
  .nav-links { display: none; }
  section { padding: 70px 0; }
}
@media (max-width: 560px) {
  .features { grid-template-columns: 1fr; }
  .feature, .feature.wide { grid-column: span 1; }
}

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

:focus-visible { outline: 2px solid var(--spark); outline-offset: 3px; }

/* ============================================================
   PIXEL LAYER — 8-bit / degen skin over the base system.
   Press Start 2P for headings; hard square edges + offset shadows;
   crisp pixel images; scanline hero texture. Body stays readable.
   ============================================================ */

/* Pixel fonts render big & wide — retune sizes, kill negative tracking,
   give breathing line-height so they don't clip. */
h1, h2, h3, h4, .brand, .stance .big, .stat .num, .btn, .eyebrow,
.section-head h2, .cta-band h2, .arc .stage .s-t, .docs-body h1, .docs-body h2 {
  font-family: var(--display);
  letter-spacing: 0 !important;
  line-height: 1.5 !important;
  text-wrap: balance;
}
.hero h1 { font-size: clamp(1.5rem, 4.4vw, 2.9rem) !important; line-height: 1.4 !important; }
.section-head h2, .docs-body h1 { font-size: clamp(1.1rem, 2.8vw, 1.75rem) !important; }
.cta-band h2 { font-size: clamp(1.25rem, 3.4vw, 2.1rem) !important; }
.feature h3, .stance h3, .step h3, .arc .stage .s-t, .docs-body h2 { font-size: 0.95rem !important; line-height: 1.5 !important; }
.docs-body h3 { font-family: var(--pixel); font-size: 0.8rem !important; letter-spacing: 0 !important; }
.stat .num { font-size: 1.7rem !important; }
.stance .big { font-size: 1.15rem !important; line-height: 1.6 !important; }
.brand { font-size: 0.78rem !important; gap: 12px !important; }
.btn { font-family: var(--pixel); font-size: 0.62rem !important; letter-spacing: 0 !important; }
.eyebrow { font-family: var(--pixel); font-size: 0.6rem; letter-spacing: 0.08em; }
h1 .glow, h1 .bloomword { text-shadow: 3px 3px 0 var(--pxsh) !important; }

/* Hard square edges + chunky borders + hard offset shadows on every surface. */
.panel, .scene-frame, .arc, .stance, .cta-band, .callout,
.trait .bar, .chip, .mult, .badge18, .brand .glyph, .stat, .feature {
  border-radius: 0 !important;
}
.panel, .feature, .stat, .scene-frame, .arc, .stance, .cta-band {
  border-width: 2px !important;
  box-shadow: 6px 6px 0 var(--pxsh) !important;
}
.feature:hover { transform: translate(-2px, -2px); box-shadow: 8px 8px 0 var(--pxsh) !important; }

/* Pixel buttons: square, 2px border, hard shadow, satisfying press. */
.btn {
  border-radius: 0 !important;
  border-width: 2px !important;
  box-shadow: 4px 4px 0 var(--pxsh) !important;
  transition: transform .06s steps(2), box-shadow .06s steps(2), background .1s !important;
}
.btn:hover { transform: translate(-1px, -1px); box-shadow: 5px 5px 0 var(--pxsh) !important; }
.btn:active { transform: translate(4px, 4px); box-shadow: 0 0 0 var(--pxsh) !important; }
.btn-primary { border-color: var(--lime) !important; }

/* Nav/footer leaf logo — the pixel mark, crisp with a green glow. */
.brand .glyph {
  width: 30px; height: 30px; padding: 0;
  background: transparent !important; border: 0 !important;
  image-rendering: pixelated; object-fit: contain;
  filter: drop-shadow(0 0 6px #6dc94066);
  box-shadow: none !important;
}

/* Chips/mults keep a 2px hard edge. */
.chip, .mult, .badge18 { border-width: 2px !important; }

/* Scanline + dither texture on the hero for that CRT-degen feel. */
.hero { position: relative; }
.hero::after {
  content: ''; position: absolute; inset: 0; pointer-events: none; z-index: 0; opacity: 0.5;
  background:
    repeating-linear-gradient(0deg, #00000022 0 2px, transparent 2px 4px),
    radial-gradient(60% 50% at 55% 30%, #a0f0500e, transparent 70%);
  mix-blend-mode: overlay;
}
.hero .wrap { position: relative; z-index: 1; }

/* Pixelated game renders + a hard frame. */
.scene-frame img, .feature img, .docs-body img { image-rendering: pixelated; image-rendering: crisp-edges; }
.scene-frame { background: #0c150b !important; }
.scene-frame::before { animation: none !important; opacity: .5 !important; }

/* Hero tag / ticker keep the mono pixel vibe. */
.hero-tags, .scene-cap, .ticker-item { font-family: var(--mono); }
