/* ===========================================================
   ETHGPU — Early Access  /  GPU mining theme
   =========================================================== */

@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 400 800;
  font-display: swap;
  src: url('/fonts/jetbrains-mono-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}
@font-face {
  font-family: 'Press Start 2P';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/press-start-2p.woff2') format('woff2');
  unicode-range: U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;
}

:root {
  --bg:      #08061A;
  --bg-2:    #0E0B22;
  --bg-3:    #15102E;
  --panel:   #0B0820;

  --ink:     #ECE7FF;
  --ink-2:   #B0A2D8;
  --muted:   #5A5078;
  --line:    #1A1535;
  --line-2:  #261F44;
  --line-3:  #34284E;

  --v:       #8B5CF6;
  --v2:      #A78BFA;
  --v3:      #C4B5FD;
  --v-dark:  #4C1D95;
  --v-deep:  #2D1464;
  --v-dim:   rgba(139,92,246,.1);
  --v-glow:  rgba(139,92,246,.28);

  --green:   #34D399;
  --green-dim:rgba(52,211,153,.1);
  --red:     #F87171;
  --amber:   #FBBF24;

  --mono:  "JetBrains Mono", ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  --pixel: "Press Start 2P", monospace;
}

*{box-sizing:border-box}
[hidden]{display:none !important}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%}

body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--mono);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  line-height:1.5;
  min-height:100dvh;
  -webkit-tap-highlight-color:rgba(139,92,246,.12);
}

input,textarea,select,button{font-size:16px}
input,textarea,select{-webkit-appearance:none;appearance:none;border-radius:0}
img,svg,canvas{display:block;max-width:100%}
button{font:inherit;cursor:pointer;color:inherit;background:none;border:0;padding:0}
a{color:inherit;text-decoration:none}
input{font:inherit;color:inherit}

/* =======================================================
   Animated background
   ======================================================= */
#bg-canvas{
  position:fixed;inset:0;width:100%;height:100%;
  z-index:0;pointer-events:none;opacity:.5;
}
.scanlines{
  position:fixed;inset:0;pointer-events:none;z-index:1;
  background:linear-gradient(
    to bottom,
    transparent 50%,
    rgba(139,92,246,.022) 50%,
    rgba(139,92,246,.022) 51%,
    transparent 51%
  );
  background-size:100% 3px;
  opacity:.65;
}
.bg-orb{position:fixed;border-radius:50%;pointer-events:none;z-index:0;filter:blur(100px)}
.bg-orb-1{width:600px;height:600px;top:-200px;left:-150px;background:radial-gradient(circle,#5B21B6,transparent 70%);opacity:.16;animation:drift 22s ease-in-out infinite alternate}
.bg-orb-2{width:480px;height:480px;bottom:-120px;right:-100px;background:radial-gradient(circle,#4C1D95,transparent 70%);opacity:.14;animation:drift 28s ease-in-out infinite alternate-reverse}
.bg-orb-3{width:380px;height:380px;top:40%;left:50%;background:radial-gradient(circle,#7C3AED,transparent 70%);opacity:.06;animation:drift 36s ease-in-out infinite alternate}
@keyframes drift{from{transform:translate(0,0) scale(1)}to{transform:translate(40px,28px) scale(1.1)}}

.ticker,header,.hero,.stats,.main-grid,.site-footer,.toast{position:relative;z-index:2}

/* =======================================================
   Ticker
   ======================================================= */
.ticker{
  overflow:hidden;
  border-bottom:1px solid var(--line);
  background:linear-gradient(90deg,rgba(139,92,246,.08),transparent 20%,transparent 80%,rgba(139,92,246,.08));
  font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.22em;
  color:var(--v3);text-transform:uppercase;
  padding:7px 0;
  white-space:nowrap;
}
.ticker-track{
  display:inline-flex;align-items:center;gap:24px;
  animation:tickerScroll 40s linear infinite;
  padding-left:24px;
}
.ticker-track span{display:inline-flex;align-items:center;gap:24px;flex-shrink:0}
.ticker-track em{font-style:normal;color:var(--v2);font-variant-numeric:tabular-nums}
.ticker-track .sep{color:var(--v);opacity:.5}
@keyframes tickerScroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* =======================================================
   Header
   ======================================================= */
.site-header{
  display:flex;justify-content:space-between;align-items:center;
  padding:
    14px
    max(clamp(20px,4vw,56px),env(safe-area-inset-right))
    14px
    max(clamp(20px,4vw,56px),env(safe-area-inset-left));
  border-bottom:1px solid var(--line);
  background:rgba(8,6,26,.78);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  position:sticky;top:0;z-index:30;
}
.brand{display:flex;align-items:center;gap:10px;min-width:0}
.brand-eth{width:14px;height:22px;flex-shrink:0;filter:drop-shadow(0 0 8px rgba(139,92,246,.7));animation:brandPulse 4s ease-in-out infinite}
@keyframes brandPulse{0%,100%{filter:drop-shadow(0 0 8px rgba(139,92,246,.7))}50%{filter:drop-shadow(0 0 14px rgba(139,92,246,1))}}
.brand-name{
  font-family:var(--mono);font-size:13px;font-weight:800;letter-spacing:.24em;
  background:linear-gradient(135deg,var(--v3),var(--v));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.brand-sep{color:var(--line-3);font-weight:300}
.brand-tag{
  font-size:9px;font-weight:700;letter-spacing:.22em;color:var(--green);
  padding:3px 7px;border:1px solid rgba(52,211,153,.35);border-radius:4px;
  background:var(--green-dim);
}
.header-nav{display:flex;align-items:center;gap:14px}
.header-stat{
  display:flex;align-items:center;gap:7px;
  font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.16em;
  color:var(--ink-2);text-transform:uppercase;
}
.header-stat-dot{
  width:6px;height:6px;border-radius:50%;background:var(--v);flex-shrink:0;
  box-shadow:0 0 8px rgba(139,92,246,.7);
  animation:miniPulse 1.6s ease-in-out infinite;
}
@keyframes miniPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}
.header-stat-text span{color:var(--v2);font-variant-numeric:tabular-nums}
.nav-x{
  display:flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:8px;
  border:1px solid var(--line-2);color:var(--ink-2);
  transition:all .18s;
}
.nav-x:hover{border-color:var(--v);color:var(--v2);background:var(--v-dim);box-shadow:0 0 14px var(--v-glow)}

/* =======================================================
   Hero
   ======================================================= */
.hero{
  display:grid;
  grid-template-columns:1fr 1fr;
  align-items:center;
  gap:48px;
  padding:
    clamp(40px,7vw,80px)
    max(clamp(20px,4vw,56px),env(safe-area-inset-right))
    clamp(36px,5vw,56px)
    max(clamp(20px,4vw,56px),env(safe-area-inset-left));
  max-width:1180px;
  margin:0 auto;
}
.hero-text{display:flex;flex-direction:column;gap:18px}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.26em;
  color:var(--v2);text-transform:uppercase;
  width:fit-content;
  padding:7px 14px 7px 12px;
  background:var(--v-dim);
  border:1px solid rgba(139,92,246,.3);
  border-radius:999px;
  box-shadow:0 0 18px rgba(139,92,246,.18);
}
.hero-eyebrow .he-label{flex-shrink:0}
.hero-eyebrow .he-cd{
  display:inline-flex;align-items:baseline;gap:1px;
  font-family:var(--mono);font-size:12px;font-weight:800;letter-spacing:.08em;
  color:var(--v3);font-variant-numeric:tabular-nums;
  padding-left:8px;border-left:1px solid rgba(139,92,246,.3);
}
.hero-eyebrow .he-cd .sep{color:var(--v);opacity:.6;animation:blink 1s steps(1,end) infinite;margin:0 1px}
.hero-eyebrow.live{border-color:rgba(52,211,153,.45);background:rgba(52,211,153,.08);color:var(--green)}
.hero-eyebrow.live .he-cd{color:var(--green);border-left-color:rgba(52,211,153,.3)}
.hero-eyebrow.live .he-cd .sep{color:var(--green);animation:none}
.hero-eyebrow.live .pulse-dot{background:var(--green);box-shadow:0 0 8px rgba(52,211,153,.7)}
.pulse-dot{
  width:7px;height:7px;border-radius:50%;background:var(--green);flex-shrink:0;
  box-shadow:0 0 0 0 rgba(52,211,153,.5);
  animation:pulse 2.2s ease-out infinite;
}
.pulse-dot.sm{width:6px;height:6px}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(52,211,153,.5)}
  70%{box-shadow:0 0 0 8px rgba(52,211,153,0)}
  100%{box-shadow:0 0 0 0 rgba(52,211,153,0)}
}
.hero-title{
  font-family:var(--pixel);
  font-size:clamp(22px,3.6vw,40px);
  line-height:1.35;
  letter-spacing:.04em;
  margin:0;
  color:var(--v3);
  text-shadow:
    2px 2px 0 var(--v),
    4px 4px 0 var(--v-dark),
    6px 6px 0 var(--v-deep),
    0 0 40px rgba(139,92,246,.4);
}
.hero-title .glitch{position:relative;display:inline-block}
.hero-title .glitch::before,
.hero-title .glitch::after{
  content:attr(data-text);
  position:absolute;left:0;top:0;
  width:100%;
  opacity:0;
}
.hero-title .glitch::before{
  color:#FF49B0;
  transform:translate(-2px,0);
  animation:glitch-1 6s infinite steps(1,end);
}
.hero-title .glitch::after{
  color:#4DD0E1;
  transform:translate(2px,0);
  animation:glitch-2 6s infinite steps(1,end);
}
@keyframes glitch-1{
  0%,98%,100%{opacity:0;transform:translate(-2px,0)}
  98.5%{opacity:.55;transform:translate(-3px,1px) skewX(-2deg)}
  99%{opacity:.4;transform:translate(2px,-1px)}
}
@keyframes glitch-2{
  0%,98%,100%{opacity:0;transform:translate(2px,0)}
  98.5%{opacity:.45;transform:translate(3px,-1px) skewX(2deg)}
  99%{opacity:.3;transform:translate(-2px,1px)}
}
.hero-desc{
  font-size:14px;color:var(--ink-2);margin:0;line-height:1.7;max-width:440px;
}
.hero-cta-row{display:flex;align-items:center;gap:24px;flex-wrap:wrap;margin-top:6px}
.hero-meta{display:flex;flex-direction:column;gap:1px;line-height:1}
.hero-meta-num{
  font-family:var(--pixel);font-size:18px;color:var(--v3);
  text-shadow:2px 2px 0 var(--v-dark);
  font-variant-numeric:tabular-nums;
}
.hero-meta-txt{
  font-size:10px;letter-spacing:.18em;color:var(--muted);
  text-transform:uppercase;font-weight:700;margin-top:4px;
}

/* Hero visual + GPU (3D floating stage) */
.hero-visual{
  position:relative;display:flex;align-items:center;justify-content:center;
  min-height:320px;
  perspective:1200px;
}
/* Floor glow — gives the GPU a "stage" to float above */
.hero-visual::before{
  content:'';
  position:absolute;left:50%;bottom:8%;
  width:62%;height:60px;
  background:radial-gradient(ellipse at center,rgba(139,92,246,.45),transparent 70%);
  filter:blur(22px);
  transform:translateX(-50%);
  z-index:0;
  animation:floorPulse 4s ease-in-out infinite;
}
@keyframes floorPulse{
  0%,100%{opacity:.7;width:62%}
  50%{opacity:1;width:70%}
}
.gpu-halo{
  position:absolute;inset:8%;
  background:
    radial-gradient(circle at 50% 45%,rgba(167,139,250,.45),transparent 55%),
    radial-gradient(circle at 50% 45%,rgba(139,92,246,.5),transparent 70%);
  filter:blur(60px);
  z-index:0;
  animation:haloPulse 4s ease-in-out infinite;
}
@keyframes haloPulse{
  0%,100%{opacity:.75;transform:scale(1)}
  50%{opacity:1;transform:scale(1.18)}
}
.gpu-ring{
  position:absolute;width:380px;height:380px;border-radius:50%;
  border:1px dashed rgba(139,92,246,.28);
  z-index:0;
  animation:ringSpin 24s linear infinite;
}
.gpu-ring::after{
  content:'';position:absolute;inset:-40px;
  border-radius:50%;border:1px solid rgba(139,92,246,.1);
  animation:ringSpin 36s linear infinite reverse;
}
.gpu-ring::before{
  content:'';position:absolute;inset:30px;
  border-radius:50%;border:1px dotted rgba(196,181,253,.15);
  animation:ringSpin 18s linear infinite reverse;
}
@keyframes ringSpin{from{transform:rotate(0)}to{transform:rotate(360deg)}}
/* GPU image now has transparent background (processed at file level).
   Wrapper handles the 3D float + glow shadow stack. */
.gpu-wrap{
  position:relative;z-index:2;
  display:flex;align-items:center;justify-content:center;
  width:100%;max-width:520px;
  filter:
    drop-shadow(0 30px 32px rgba(0,0,0,.6))
    drop-shadow(0 12px 18px rgba(0,0,0,.4))
    drop-shadow(0 0 70px rgba(139,92,246,.5))
    drop-shadow(0 0 30px rgba(167,139,250,.3));
  animation:gpuFloat 6s ease-in-out infinite;
  transform-style:preserve-3d;
  will-change:transform;
}
.gpu-img{
  width:100%;height:auto;
}
.gpu-shadow{
  position:absolute;left:50%;bottom:4%;
  width:55%;height:42px;
  background:radial-gradient(ellipse at center,rgba(0,0,0,.55),transparent 70%);
  filter:blur(18px);
  transform:translateX(-50%);
  z-index:0;
  pointer-events:none;
}
@keyframes gpuFloat{
  0%,100%{transform:translateY(0) rotateX(0) rotateY(0)}
  25%{transform:translateY(-8px) rotateX(.6deg) rotateY(-1deg)}
  50%{transform:translateY(-14px) rotateX(1.2deg) rotateY(0)}
  75%{transform:translateY(-8px) rotateX(.6deg) rotateY(1deg)}
}
.gpu-fallback{
  display:none;position:relative;z-index:2;width:100%;max-width:380px;
  filter:drop-shadow(0 8px 28px rgba(139,92,246,.35));
  animation:gpuFloat 6s ease-in-out infinite;
}

.hero-particles{position:absolute;inset:0;z-index:1;pointer-events:none}
.hero-particles span{
  position:absolute;width:4px;height:4px;border-radius:50%;
  background:var(--v2);
  box-shadow:0 0 8px var(--v);
  opacity:0;
  animation:particleFloat 6s ease-in-out infinite;
}
.hero-particles span:nth-child(1){top:20%;left:15%;animation-delay:0s}
.hero-particles span:nth-child(2){top:65%;left:80%;animation-delay:1s;width:3px;height:3px}
.hero-particles span:nth-child(3){top:35%;left:90%;animation-delay:2s}
.hero-particles span:nth-child(4){top:80%;left:25%;animation-delay:3s;width:5px;height:5px}
.hero-particles span:nth-child(5){top:50%;left:5%;animation-delay:4s}
.hero-particles span:nth-child(6){top:10%;left:60%;animation-delay:5s;width:3px;height:3px}
@keyframes particleFloat{
  0%{opacity:0;transform:translateY(0) scale(.5)}
  20%{opacity:.8;transform:translateY(-10px) scale(1)}
  80%{opacity:.6;transform:translateY(-60px) scale(.8)}
  100%{opacity:0;transform:translateY(-80px) scale(.3)}
}

/* =======================================================
   Stats banner
   ======================================================= */
.stats{
  max-width:1180px;
  margin:0 auto 8px;
  padding:0 max(clamp(20px,4vw,56px),env(safe-area-inset-right)) 24px max(clamp(20px,4vw,56px),env(safe-area-inset-left));
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:10px;
}
.stat-card{
  position:relative;
  padding:14px 16px;
  background:var(--panel);
  border:1px solid var(--line-2);
  border-radius:10px;
  overflow:hidden;
  transition:border-color .25s,box-shadow .25s;
}
.stat-card::before{
  content:'';position:absolute;left:0;top:0;bottom:0;width:2px;
  background:linear-gradient(180deg,var(--v),transparent);
  opacity:.6;
}
.stat-card:hover{border-color:rgba(139,92,246,.4);box-shadow:0 0 18px rgba(139,92,246,.1)}
.stat-card.highlight{border-color:rgba(251,191,36,.3)}
.stat-card.highlight::before{background:linear-gradient(180deg,var(--amber),transparent)}
.stat-head{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  margin-bottom:8px;
}
.stat-label{
  font-size:9px;font-weight:700;letter-spacing:.22em;color:var(--muted);
  text-transform:uppercase;
}
.stat-icon{color:var(--v2);flex-shrink:0;opacity:.7}
.stat-card.highlight .stat-icon{color:var(--amber)}
.stat-value{
  font-family:var(--mono);font-size:22px;font-weight:800;letter-spacing:.01em;
  color:var(--ink);font-variant-numeric:tabular-nums;
  display:flex;align-items:baseline;gap:5px;
}
.stat-unit{font-size:11px;color:var(--muted);font-weight:600;letter-spacing:.1em}
.stat-trend{
  font-size:10px;letter-spacing:.04em;color:var(--muted);margin-top:4px;
}
.stat-trend.up{color:var(--green)}
.stat-trend.warn{color:var(--amber)}

/* =======================================================
   Main grid (flow + feed)
   ======================================================= */
.main-grid{
  max-width:720px;margin:0 auto;
  padding:
    0
    max(clamp(20px,4vw,56px),env(safe-area-inset-right))
    max(64px,env(safe-area-inset-bottom))
    max(clamp(20px,4vw,56px),env(safe-area-inset-left));
}

/* =======================================================
   Progress bar
   ======================================================= */
.progress{
  margin-bottom:24px;
  padding:14px 18px;
  background:var(--panel);
  border:1px solid var(--line-2);
  border-radius:10px;
  position:relative;
  overflow:hidden;
}
.progress::after{
  content:'';position:absolute;top:0;right:0;bottom:0;width:120px;
  background:linear-gradient(90deg,transparent,rgba(139,92,246,.04));
  pointer-events:none;
}
.progress-meta{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:10px;
}
.progress-label{
  font-size:10px;font-weight:700;letter-spacing:.22em;color:var(--muted);
  text-transform:uppercase;
}
.progress-count{
  font-family:var(--mono);font-size:13px;font-weight:800;color:var(--v2);
  font-variant-numeric:tabular-nums;letter-spacing:.04em;
}
.progress-total{color:var(--muted);font-weight:600}
.progress-track{
  height:5px;background:var(--bg-3);border-radius:999px;
  overflow:hidden;position:relative;
}
.progress-fill{
  height:100%;width:0%;
  background:linear-gradient(90deg,var(--v-dark),var(--v),var(--v2));
  border-radius:999px;
  transition:width .8s cubic-bezier(.16,1,.3,1);
  box-shadow:0 0 14px rgba(139,92,246,.6);
  position:relative;
}
.progress-fill::after{
  content:'';position:absolute;top:0;right:-2px;bottom:0;width:6px;
  background:var(--v3);box-shadow:0 0 12px var(--v3);
  border-radius:999px;
}

/* =======================================================
   Flow step
   ======================================================= */
.flow{display:flex;flex-direction:column;gap:0}

.flow-step{position:relative;padding:0 0 28px;transition:opacity .3s}
.flow-step[data-state="locked"]{opacity:.35;pointer-events:none}

.flow-step-head{
  display:grid;
  grid-template-columns:56px 1fr;
  align-items:stretch;
}
.flow-num-wrap{display:flex;flex-direction:column;align-items:center;padding-top:4px}
.flow-num{
  font-family:var(--mono);font-size:11px;font-weight:800;letter-spacing:.2em;
  color:var(--muted);background:var(--bg-2);
  border:1px solid var(--line-2);
  border-radius:6px;
  padding:5px 8px;
  flex-shrink:0;
  width:42px;text-align:center;
  transition:all .3s;
}
.flow-step[data-state="active"] .flow-num{
  color:var(--v2);border-color:rgba(139,92,246,.5);background:var(--v-dim);
  box-shadow:0 0 14px rgba(139,92,246,.25);
}
.flow-step[data-state="done"] .flow-num{
  color:var(--green);border-color:rgba(52,211,153,.4);background:var(--green-dim);
}
.flow-line{
  flex:1;width:1px;background:var(--line-2);margin:8px auto 0;display:block;
  transition:background .3s;
}
.flow-step[data-state="active"] .flow-line{
  background:linear-gradient(180deg,rgba(139,92,246,.5),rgba(139,92,246,.05));
}
.flow-step[data-state="done"] .flow-line{background:rgba(52,211,153,.35)}

.flow-title-row{
  display:flex;align-items:center;gap:10px;
  padding:4px 0 18px 18px;
  border-bottom:1px solid var(--line);
}
.flow-title{
  font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.28em;
  text-transform:uppercase;color:var(--muted);margin:0;flex:1;
  transition:color .3s;
}
.flow-step[data-state="active"] .flow-title{color:var(--v2)}
.flow-step[data-state="done"] .flow-title{color:var(--green)}

.flow-badge{
  width:8px;height:8px;border-radius:50%;background:var(--line-2);
  transition:background .3s,box-shadow .3s;
}
.flow-step[data-state="active"] .flow-badge{
  background:var(--v);box-shadow:0 0 10px var(--v);
  animation:miniPulse 1.5s ease-in-out infinite;
}
.flow-step[data-state="done"] .flow-badge{
  background:var(--green);box-shadow:0 0 8px rgba(52,211,153,.6);
}

.flow-body{padding:18px 0 0 74px;display:flex;flex-direction:column;gap:12px}
.flow-hint{margin:0;font-size:12px;color:var(--muted);letter-spacing:.02em;line-height:1.65}

/* =======================================================
   Buttons
   ======================================================= */
.cta-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:11px 22px;
  font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:.2em;
  text-transform:uppercase;color:#fff;
  background:linear-gradient(135deg,var(--v),var(--v-dark));
  border:1px solid rgba(139,92,246,.6);
  border-radius:8px;
  box-shadow:0 0 22px rgba(139,92,246,.25),inset 0 1px 0 rgba(255,255,255,.1);
  transition:all .2s;
  white-space:nowrap;
  position:relative;overflow:hidden;
}
.cta-btn::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
  transform:translateX(-100%);
  transition:transform .6s;
}
.cta-btn:hover::after{transform:translateX(100%)}
.cta-btn:hover{
  background:linear-gradient(135deg,var(--v2),var(--v));
  box-shadow:0 0 32px rgba(139,92,246,.5);
  transform:translateY(-1px);
}
.cta-btn:active{transform:translateY(1px);box-shadow:none}
.cta-btn:disabled,.cta-btn[disabled]{opacity:.4;cursor:not-allowed;transform:none !important;box-shadow:none !important}
.cta-btn.lg{padding:14px 28px;font-size:13px}
.cta-btn.compact{padding:11px 18px;font-size:11px}

.ghost-btn{
  font-size:11px;letter-spacing:.1em;color:var(--muted);
  text-decoration:underline;text-underline-offset:3px;
  align-self:flex-start;padding:8px 0;min-height:36px;display:inline-flex;align-items:center;
}
.ghost-btn:hover{color:var(--v2)}

/* =======================================================
   Step 1 — Identity
   ======================================================= */
.identity-pill{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 16px;
  background:var(--bg-2);
  border:1px solid rgba(52,211,153,.35);
  border-radius:10px;
  width:fit-content;max-width:100%;
  box-shadow:0 0 16px rgba(52,211,153,.08);
}
.avatar{
  width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,var(--v),var(--v-dark));
  flex-shrink:0;border:2px solid rgba(139,92,246,.25);
  object-fit:cover;
}
.handle{font-weight:700;font-size:14px;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:55vw}

/* =======================================================
   Step 2 — Tasks
   ======================================================= */
.task-list{display:flex;flex-direction:column;gap:6px}
.task{
  position:relative;
  display:grid;
  grid-template-columns:38px 1fr auto;
  align-items:center;gap:14px;
  padding:14px 16px;
  background:var(--bg-2);
  border:1px solid var(--line-2);
  border-radius:10px;
  text-align:left;
  transition:all .18s;
  cursor:pointer;
}
.task::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:2px;height:0;background:var(--v);
  border-radius:0 2px 2px 0;
  transition:height .25s;
}
.task:hover:not(:disabled){
  border-color:rgba(139,92,246,.45);
  background:rgba(139,92,246,.06);
  box-shadow:0 0 20px rgba(139,92,246,.12);
}
.task:hover:not(:disabled)::before{height:60%}
.task:active:not(:disabled){transform:scale(.99)}
.task:disabled{opacity:.45;cursor:not-allowed}
.task[data-busy="1"]{cursor:progress}
.task[data-busy="1"] .task-icon{animation:spin .9s linear infinite}
@keyframes spin{from{transform:rotate(0)}to{transform:rotate(360deg)}}

.task-icon{
  display:flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:8px;
  background:var(--bg-3);border:1px solid var(--line-2);
  color:var(--v2);flex-shrink:0;
  transition:all .2s;
}
.task:hover:not(:disabled) .task-icon{border-color:rgba(139,92,246,.4);box-shadow:0 0 12px rgba(139,92,246,.2)}
.task-text{display:flex;flex-direction:column;gap:3px;min-width:0}
.task-name{font-size:13px;font-weight:600;color:var(--ink);letter-spacing:.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.task-sub{font-size:11px;color:var(--muted);letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.task-arrow{color:var(--muted);flex-shrink:0;display:flex;align-items:center;transition:transform .2s,color .2s}
.task:hover:not(:disabled) .task-arrow{color:var(--v2);transform:translateX(3px)}
.task-check{display:none;color:var(--green);flex-shrink:0}

.task[data-done="1"]{
  border-color:rgba(52,211,153,.4);
  background:rgba(52,211,153,.05);
}
.task[data-done="1"]::before{background:var(--green);height:60%}
.task[data-done="1"] .task-icon{color:var(--green);border-color:rgba(52,211,153,.35);background:var(--green-dim)}
.task[data-done="1"] .task-arrow{display:none}
.task[data-done="1"] .task-check{display:flex;animation:checkIn .4s cubic-bezier(.16,1,.3,1)}
.task[data-done="1"] .task-name{color:var(--green)}
@keyframes checkIn{from{opacity:0;transform:scale(.3)}to{opacity:1;transform:scale(1)}}

/* =======================================================
   Step 3 — Wallet
   ======================================================= */
.wallet-form{
  display:flex;align-items:stretch;
  border:1px solid var(--line-2);border-radius:8px;overflow:hidden;
  background:var(--bg-2);
  transition:border-color .18s,box-shadow .18s;
}
.wallet-form:focus-within{border-color:rgba(139,92,246,.55);box-shadow:0 0 0 3px rgba(139,92,246,.1)}
.wallet-form input{
  flex:1;padding:13px 14px;font-family:var(--mono);font-size:16px;
  background:transparent;border:0;outline:none;color:var(--ink);min-width:0;
  -webkit-appearance:none;
}
.wallet-form input::placeholder{color:var(--muted)}
.wallet-form button{
  padding:0 20px;font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.2em;
  background:linear-gradient(135deg,var(--v),var(--v-dark));color:#fff;border:0;
  border-left:1px solid rgba(139,92,246,.3);
  border-radius:0;cursor:pointer;white-space:nowrap;transition:background .18s;
}
.wallet-form button:hover{background:linear-gradient(135deg,var(--v2),var(--v))}

.form-msg{margin:8px 0 0;font-size:12px;min-height:16px;color:var(--green)}
.form-msg.error{color:var(--red)}

.wallet-chip{
  display:inline-flex;align-items:center;gap:10px;padding:10px 16px;
  background:var(--bg-2);border:1px solid rgba(52,211,153,.35);
  border-radius:10px;width:fit-content;max-width:100%;
  box-shadow:0 0 16px rgba(52,211,153,.08);
}
.chip-label{font-size:10px;font-weight:700;letter-spacing:.22em;color:var(--muted);text-transform:uppercase;flex-shrink:0}
.chip-addr{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}

/* =======================================================
   Step 4 — Confirmation
   ======================================================= */
.confirm-block{
  display:flex;flex-direction:column;align-items:flex-start;gap:14px;
  padding:24px;
  background:linear-gradient(135deg,rgba(139,92,246,.06),rgba(52,211,153,.04));
  border:1px solid rgba(52,211,153,.35);
  border-radius:12px;
  position:relative;overflow:hidden;
}
.confirm-block::before{
  content:'';position:absolute;top:-50%;right:-30%;width:300px;height:300px;
  background:radial-gradient(circle,rgba(52,211,153,.18),transparent 65%);
  filter:blur(40px);pointer-events:none;
}
.confirm-icon{filter:drop-shadow(0 0 18px rgba(52,211,153,.35));animation:gpuFloat 5s ease-in-out infinite;position:relative;z-index:1}
.confirm-label{
  font-family:var(--pixel);font-size:14px;letter-spacing:.1em;
  color:var(--green);margin:0;
  text-shadow:2px 2px 0 rgba(52,211,153,.3),0 0 20px rgba(52,211,153,.5);
  position:relative;z-index:1;
}
.confirm-sub{font-size:13px;color:var(--ink-2);margin:0;line-height:1.65;max-width:420px;position:relative;z-index:1}

.launching{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  padding:14px 18px;
  border:1px solid rgba(139,92,246,.3);
  border-radius:8px;
  background:rgba(139,92,246,.05);
  width:100%;position:relative;z-index:1;
}
.launch-label{
  font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.28em;
  text-transform:uppercase;color:var(--v2);
}
.countdown{
  display:inline-flex;align-items:center;gap:6px;
  font-family:var(--pixel);font-variant-numeric:tabular-nums;
}
.cd-cell{
  display:inline-flex;align-items:baseline;gap:3px;
  padding:5px 9px;
  background:var(--bg-2);border:1px solid var(--line-2);
  border-radius:5px;
}
.cd-cell span:first-child{font-size:12px;color:var(--ink)}
.cd-unit{font-size:8px;color:var(--muted);font-weight:400}
.countdown .sep{color:var(--v);font-size:10px;animation:blink 1s steps(1,end) infinite}
@keyframes blink{50%{opacity:.15}}
.launching.live{border-color:rgba(52,211,153,.4);background:rgba(52,211,153,.06)}
.launching.live .launch-label,.launching.live .cd-cell span:first-child{color:var(--green)}
.launching.live .countdown .sep{color:var(--green)}

/* =======================================================
   Live feed
   ======================================================= */
.live-feed{
  background:var(--panel);
  border:1px solid var(--line-2);
  border-radius:10px;
  padding:16px;
  font-family:var(--mono);font-size:11px;
  height:fit-content;
  position:sticky;
  top:80px;
  max-height:calc(100dvh - 120px);
  display:flex;flex-direction:column;
  overflow:hidden;
}
.feed-head{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:12px;padding-bottom:12px;
  border-bottom:1px solid var(--line);
  flex-shrink:0;
}
.feed-title{
  font-size:10px;font-weight:700;letter-spacing:.22em;color:var(--muted);
}
.feed-status{
  display:flex;align-items:center;gap:6px;
  font-size:9px;letter-spacing:.18em;color:var(--green);font-weight:700;
}
.feed-list{
  list-style:none;margin:0;padding:0 4px 0 0;
  display:flex;flex-direction:column;gap:5px;
  overflow-y:auto;flex:1;
  scrollbar-width:thin;scrollbar-color:var(--line-2) transparent;
}
.feed-list::-webkit-scrollbar{width:4px}
.feed-list::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:2px}
.feed-item{
  display:grid;grid-template-columns:auto 1fr;gap:8px;
  padding:6px 8px;border-radius:5px;
  border-left:2px solid var(--line-2);
  background:rgba(15,12,32,.4);
  color:var(--ink-2);
  font-size:11px;line-height:1.4;
  animation:feedIn .4s cubic-bezier(.16,1,.3,1);
}
@keyframes feedIn{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:translateX(0)}}
.feed-time{color:var(--muted);font-size:10px;font-variant-numeric:tabular-nums;letter-spacing:.04em}
.feed-text{font-size:11px;letter-spacing:.01em;overflow:hidden;text-overflow:ellipsis}
.feed-text .hex{color:var(--v2);font-family:var(--mono)}
.feed-text .num{color:var(--green);font-variant-numeric:tabular-nums}
.feed-text .at{color:var(--v3)}
.feed-item.block{border-left-color:var(--v)}
.feed-item.join{border-left-color:rgba(139,92,246,.4)}
.feed-item.mine{border-left-color:var(--green)}
.feed-item.spot{border-left-color:var(--amber)}
.feed-item.spot .feed-text .at{color:var(--amber)}
.feed-fade{
  position:absolute;left:16px;right:16px;bottom:16px;height:48px;
  background:linear-gradient(to bottom,transparent,var(--panel));
  pointer-events:none;
}

/* =======================================================
   Toast
   ======================================================= */
.toast{
  position:fixed;bottom:24px;left:50%;
  transform:translateX(-50%) translateY(20px);
  background:var(--bg-2);color:var(--ink);
  border:1px solid rgba(139,92,246,.4);
  border-radius:10px;padding:11px 20px;font-size:13px;
  z-index:300;box-shadow:0 4px 28px rgba(139,92,246,.25);
  opacity:0;transition:opacity .2s,transform .2s;pointer-events:none;white-space:nowrap;
}
.toast[hidden]{display:none}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.error{border-color:rgba(248,113,113,.5);box-shadow:0 4px 20px rgba(248,113,113,.18)}

/* =======================================================
   Footer
   ======================================================= */
.site-footer{
  display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;
  padding:
    16px
    max(clamp(20px,4vw,56px),env(safe-area-inset-right))
    max(16px,env(safe-area-inset-bottom))
    max(clamp(20px,4vw,56px),env(safe-area-inset-left));
  border-top:1px solid var(--line);
  font-size:11px;color:var(--muted);letter-spacing:.14em;
}
.foot-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.foot-sep{color:var(--line-3)}
.foot-mono{color:var(--v2);font-weight:700;letter-spacing:.08em}
.foot-status{display:flex;align-items:center;gap:7px}

/* =======================================================
   Responsive
   ======================================================= */
@media(max-width:1000px){
  .main-grid{grid-template-columns:1fr}
  .live-feed{position:relative;top:0;max-height:340px}
  .feed-fade{display:none}
}

@media(max-width:720px){
  .hero{grid-template-columns:1fr;gap:32px;padding-top:44px}
  .hero-visual{order:-1;min-height:240px}
  .gpu-ring{width:260px;height:260px}
  .hero-title{font-size:clamp(20px,6vw,32px)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .header-stat{display:none}
  .brand-sep,.brand-tag{display:none}
}

@media(max-width:540px){
  .flow-body{padding-left:56px}
  .flow-num{width:36px;font-size:10px;padding:4px 6px}
  .flow-step-head{grid-template-columns:48px 1fr}
  .task{gap:10px;padding:12px 12px}
  .task-sub{display:none}
  .cta-btn{padding:11px 18px}
  .cta-btn.lg{padding:12px 22px;font-size:12px}
  .hero-meta-num{font-size:16px}
  .stats{padding-bottom:16px;gap:8px}
  .stat-card{padding:12px 14px}
  .stat-value{font-size:18px}
  .ticker{font-size:9px}
  .ticker-track{gap:18px}
  .ticker-track span{gap:18px}
}

@media(max-width:360px){
  .hero-title{font-size:18px}
  .flow-body{padding-left:48px}
  .flow-step-head{grid-template-columns:42px 1fr}
}

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