/* ═══════════════════════════════════════════════════════════
   EVA SPACE PROGRAM — MAIN STYLESHEET
   Aesthetic: Retro-futuristic command terminal meets cosmic
   ═══════════════════════════════════════════════════════════ */

:root {
  --black: #010409;
  --deep: #060d18;
  --surface: #0a1628;
  --panel: #0d1e36;
  --border: #1a3a5c;
  --border-bright: #00f0ff44;
  --cyan: #00f0ff;
  --cyan-dim: #00c8d4;
  --cyan-glow: #00f0ff22;
  --orange: #ff6b35;
  --orange-dim: #cc4a1a;
  --white: #e8f4f8;
  --white-dim: #8ab8cc;
  --font-head: 'Orbitron', sans-serif;
  --font-mono: 'Share Tech Mono', monospace;
  --font-body: 'Exo 2', sans-serif;
}

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

html { scroll-behavior: smooth; }

body {
  background: var(--black);
  color: var(--white);
  font-family: var(--font-body);
  font-weight: 300;
  line-height: 1.7;
  overflow-x: hidden;
}

/* ── OVERLAYS ──────────────────────────────────────────────── */
.scanlines {
  position: fixed; inset: 0; z-index: 9999;
  pointer-events: none;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(0,0,0,0.08) 2px,
    rgba(0,0,0,0.08) 4px
  );
}
.noise-overlay {
  position: fixed; inset: 0; z-index: 9998;
  pointer-events: none; opacity: 0.025;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
}

/* ── TYPOGRAPHY ────────────────────────────────────────────── */
h1, h2, h3, h4 { font-family: var(--font-head); letter-spacing: 0.08em; line-height: 1.1; }

/* ── LAYOUT ─────────────────────────────────────────────────── */
.section { min-height: 100vh; display: flex; flex-direction: column; justify-content: center; padding: 120px 0 80px; position: relative; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 40px; width: 100%; }
.hidden { display: none !important; }
.full-width { width: 100%; }

/* ── NAV ─────────────────────────────────────────────────────── */
#nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  background: rgba(1, 4, 9, 0.85);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
}
.nav-inner {
  max-width: 1200px; margin: 0 auto; padding: 0 40px;
  display: flex; align-items: center; gap: 40px; height: 64px;
}
.nav-logo {
  font-family: var(--font-head); font-size: 1.4rem; font-weight: 900;
  color: var(--cyan); text-decoration: none; letter-spacing: 0.2em;
  text-shadow: 0 0 20px var(--cyan);
  transition: text-shadow 0.3s;
}
.nav-logo:hover { text-shadow: 0 0 40px var(--cyan), 0 0 80px var(--cyan); }
.nav-links { display: flex; gap: 24px; margin-left: auto; }
.nav-link {
  font-family: var(--font-mono); font-size: 0.75rem;
  color: var(--white-dim); text-decoration: none; letter-spacing: 0.15em;
  padding: 6px 0; border-bottom: 1px solid transparent;
  transition: all 0.2s;
}
.nav-link:hover, .nav-link.active {
  color: var(--cyan); border-color: var(--cyan);
}
.donate-cta {
  color: var(--orange) !important;
  border-color: var(--orange) !important;
}
.nav-actions { display: flex; align-items: center; gap: 12px; margin-left: 24px; }
.admin-badge {
  font-family: var(--font-mono); font-size: 0.7rem;
  color: var(--orange); letter-spacing: 0.1em;
  border: 1px solid var(--orange); padding: 3px 10px;
  text-shadow: 0 0 8px var(--orange);
}
.btn-edit {
  font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.1em;
  background: transparent; border: 1px solid var(--cyan); color: var(--cyan);
  padding: 5px 14px; cursor: pointer;
  transition: all 0.2s;
}
.btn-edit:hover, .btn-edit.active {
  background: var(--cyan); color: var(--black);
  box-shadow: 0 0 20px var(--cyan);
}

/* ── BUTTONS ─────────────────────────────────────────────────── */
.btn-primary {
  font-family: var(--font-head); font-size: 0.8rem; letter-spacing: 0.15em;
  background: var(--cyan); color: var(--black); border: none;
  padding: 12px 24px; cursor: pointer; font-weight: 700;
  transition: all 0.2s; width: 100%; margin-top: 8px;
}
.btn-primary:hover { box-shadow: 0 0 30px var(--cyan); }
.btn-primary-sm {
  font-family: var(--font-head); font-size: 0.7rem; letter-spacing: 0.1em;
  background: var(--cyan); color: var(--black); border: none;
  padding: 8px 16px; cursor: pointer; margin-top: 8px;
}
.btn-ghost {
  font-family: var(--font-mono); font-size: 0.75rem;
  background: transparent; border: 1px solid var(--border); color: var(--white-dim);
  padding: 8px 20px; cursor: pointer; width: 100%; margin-top: 8px;
  transition: all 0.2s;
}
.btn-ghost:hover { border-color: var(--white-dim); color: var(--white); }
.btn-ghost-sm {
  background: transparent; border: none; color: var(--white-dim);
  cursor: pointer; font-size: 1rem; padding: 4px 8px;
  transition: color 0.2s;
}
.btn-ghost-sm:hover { color: var(--white); }
.btn-danger {
  font-family: var(--font-mono); font-size: 0.75rem; letter-spacing: 0.1em;
  background: transparent; border: 1px solid #ff3355; color: #ff3355;
  padding: 8px 20px; cursor: pointer; width: 100%;
  transition: all 0.2s;
}
.btn-danger:hover { background: #ff3355; color: var(--black); }
.btn-launch {
  font-family: var(--font-head); font-size: 0.85rem; letter-spacing: 0.2em;
  background: transparent; border: 2px solid var(--orange);
  color: var(--orange); padding: 16px 40px; cursor: pointer; display: inline-flex;
  align-items: center; gap: 12px; text-decoration: none;
  position: relative; overflow: hidden; transition: all 0.3s;
}
.btn-launch:hover {
  background: var(--orange); color: var(--black);
  box-shadow: 0 0 40px var(--orange), 0 0 80px rgba(255,107,53,0.3);
}
.btn-trail {
  display: inline-block; width: 20px; height: 2px;
  background: currentColor; transition: width 0.3s;
}
.btn-launch:hover .btn-trail { width: 30px; }

/* ── ADMIN LOGIN OVERLAY ─────────────────────────────────────── */
.overlay {
  position: fixed; inset: 0; z-index: 2000;
  background: rgba(1,4,9,0.92); backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
}
.overlay-panel {
  background: var(--panel); border: 1px solid var(--cyan);
  padding: 48px 40px; max-width: 480px; width: 90%;
  box-shadow: 0 0 60px var(--cyan-glow);
  display: flex; flex-direction: column; gap: 16px;
}
.overlay-title {
  font-family: var(--font-head); font-size: 1rem; letter-spacing: 0.2em;
  color: var(--cyan); text-align: center;
  display: flex; align-items: center; justify-content: center; gap: 16px;
}
.glyph { opacity: 0.5; }
.overlay-sub { font-family: var(--font-mono); font-size: 0.8rem; color: var(--white-dim); text-align: center; }
.token-input {
  font-family: var(--font-mono); font-size: 0.9rem; letter-spacing: 0.1em;
  background: var(--surface); border: 1px solid var(--border);
  color: var(--cyan); padding: 14px 16px; width: 100%;
  outline: none; transition: border-color 0.2s;
}
.token-input:focus { border-color: var(--cyan); box-shadow: 0 0 20px var(--cyan-glow); }
.login-error {
  font-family: var(--font-mono); font-size: 0.8rem; color: #ff3355;
  text-align: center;
}

/* ── EDIT PANEL ──────────────────────────────────────────────── */
.edit-panel {
  position: fixed; right: 0; top: 64px; bottom: 0; z-index: 900;
  width: 360px; background: var(--panel); border-left: 1px solid var(--border);
  display: flex; flex-direction: column; overflow: hidden;
  box-shadow: -10px 0 40px rgba(0,0,0,0.5);
  transform: translateX(100%); transition: transform 0.3s ease;
}
.edit-panel:not(.hidden) { transform: translateX(0); display: flex; }
.edit-panel-header {
  padding: 16px 20px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--font-mono); font-size: 0.8rem; color: var(--cyan);
  background: var(--surface); flex-shrink: 0;
}
.edit-panel-body { overflow-y: auto; padding: 20px; flex: 1; }
.edit-section { margin-bottom: 28px; padding-bottom: 20px; border-bottom: 1px solid var(--border); }
.edit-section h4 {
  font-family: var(--font-mono); font-size: 0.7rem; color: var(--cyan);
  letter-spacing: 0.2em; margin-bottom: 12px;
}
.edit-section h5 {
  font-family: var(--font-mono); font-size: 0.65rem; color: var(--white-dim);
  letter-spacing: 0.15em; margin-bottom: 8px;
}
.edit-section label {
  display: block; font-family: var(--font-mono); font-size: 0.65rem;
  color: var(--white-dim); letter-spacing: 0.1em; margin-bottom: 12px;
}
.edit-input, .edit-textarea {
  display: block; width: 100%; margin-top: 4px;
  background: var(--surface); border: 1px solid var(--border);
  color: var(--white); padding: 8px 10px; font-family: var(--font-mono);
  font-size: 0.8rem; outline: none; transition: border-color 0.2s; resize: vertical;
}
.edit-input:focus, .edit-textarea:focus { border-color: var(--cyan); }
.edit-textarea { min-height: 80px; }
.upload-zone { background: var(--surface); border: 1px dashed var(--border); padding: 16px; display: flex; flex-direction: column; gap: 8px; }
.file-input { color: var(--white-dim); font-family: var(--font-mono); font-size: 0.7rem; }
.upload-status { font-family: var(--font-mono); font-size: 0.7rem; color: var(--cyan); min-height: 16px; margin-top: 4px; }
#save-status { color: var(--orange); }

/* ── SECTION COMMON ──────────────────────────────────────────── */
.section-header { display: flex; align-items: baseline; gap: 20px; margin-bottom: 40px; }
.section-number {
  font-family: var(--font-mono); font-size: 4rem; font-weight: 400;
  color: var(--border); line-height: 1; flex-shrink: 0;
}
.section-title {
  font-size: clamp(1.8rem, 4vw, 3rem); color: var(--white);
  letter-spacing: 0.1em;
}
.section-sub {
  font-family: var(--font-mono); font-size: 0.85rem; color: var(--white-dim);
  margin-bottom: 48px; max-width: 600px; line-height: 1.6;
}

/* ── HERO ─────────────────────────────────────────────────────── */
.hero-section {
  min-height: 100vh; position: relative; overflow: hidden;
  padding: 0; justify-content: center; align-items: center;
}
.hero-bg { position: absolute; inset: 0; overflow: hidden; }
#starfield { position: absolute; inset: 0; }
.hero-planet {
  position: absolute; right: -80px; top: 50%; transform: translateY(-50%);
  width: 500px; height: 500px; border-radius: 50%;
  background: radial-gradient(circle at 35% 35%,
    #1a3a5c 0%, #0a1628 40%, #060d18 70%, #010409 100%);
  box-shadow:
    inset -30px -30px 60px rgba(0,0,0,0.8),
    inset 20px 20px 40px rgba(0,240,255,0.05),
    0 0 100px rgba(0,240,255,0.08),
    0 0 200px rgba(0,240,255,0.04);
}
.hero-ring {
  position: absolute; right: -180px; top: 50%; transform: translateY(-50%) rotateX(70deg);
  width: 700px; height: 700px; border-radius: 50%;
  border: 2px solid rgba(0,240,255,0.15);
  box-shadow: 0 0 40px rgba(0,240,255,0.1);
}
.hero-content {
  position: relative; z-index: 2; max-width: 700px; padding: 0 40px 0 80px;
}
.hero-eyebrow {
  display: flex; align-items: center; gap: 16px; margin-bottom: 24px;
  font-family: var(--font-mono); font-size: 0.75rem; color: var(--cyan);
  letter-spacing: 0.2em;
}
.line { flex: 1; max-width: 60px; height: 1px; background: var(--cyan); opacity: 0.5; }
.hero-headline {
  font-size: clamp(3rem, 7vw, 6rem); font-weight: 900; line-height: 0.95;
  color: var(--white); letter-spacing: 0.05em; margin-bottom: 16px;
  text-shadow: 0 0 60px rgba(0,240,255,0.2);
}
.hero-sub {
  font-family: var(--font-mono); font-size: 1rem; color: var(--cyan-dim);
  letter-spacing: 0.1em; margin-bottom: 24px;
}
.hero-body {
  font-size: 1rem; color: var(--white-dim); margin-bottom: 40px; max-width: 520px;
}
.scroll-indicator {
  position: absolute; bottom: 40px; left: 80px;
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  font-family: var(--font-mono); font-size: 0.65rem; color: var(--border);
  letter-spacing: 0.2em;
}
.scroll-line {
  width: 1px; height: 60px;
  background: linear-gradient(to bottom, var(--border), transparent);
  animation: scrollPulse 2s ease-in-out infinite;
}
@keyframes scrollPulse {
  0%, 100% { opacity: 0.3; transform: scaleY(1); }
  50% { opacity: 1; transform: scaleY(1.2); }
}

/* ── MISSION ─────────────────────────────────────────────────── */
.mission-section { background: var(--deep); }
.mission-body {
  font-size: 1.15rem; color: var(--white-dim); max-width: 700px;
  margin-bottom: 60px; line-height: 1.8;
}
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px; }
.stat-card {
  background: var(--surface); border: 1px solid var(--border); padding: 32px 24px;
  text-align: center; transition: border-color 0.3s;
  position: relative; overflow: hidden;
}
.stat-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--cyan); transform: scaleX(0); transform-origin: left;
  transition: transform 0.4s;
}
.stat-card:hover { border-color: var(--cyan); }
.stat-card:hover::before { transform: scaleX(1); }
.stat-value {
  font-family: var(--font-head); font-size: 2.5rem; font-weight: 900;
  color: var(--cyan); display: block; margin-bottom: 8px;
}
.stat-label {
  font-family: var(--font-mono); font-size: 0.7rem; color: var(--white-dim);
  letter-spacing: 0.15em; text-transform: uppercase;
}

/* ── ABOUT ───────────────────────────────────────────────────── */
.about-section { background: var(--black); }
.about-grid { display: grid; grid-template-columns: 1fr 1.5fr; gap: 80px; align-items: center; }
.about-visual { position: relative; display: flex; justify-content: center; align-items: center; }
.about-diagram {
  width: 280px; height: 280px; position: relative;
  display: flex; align-items: center; justify-content: center;
}
.diagram-orbit {
  position: absolute; border-radius: 50%; border: 1px solid;
  animation: spin linear infinite;
}
.orbit-1 { width: 100%; height: 100%; border-color: rgba(0,240,255,0.1); animation-duration: 20s; }
.orbit-2 { width: 70%; height: 70%; border-color: rgba(0,240,255,0.15); animation-duration: 14s; animation-direction: reverse; }
.orbit-3 { width: 45%; height: 45%; border-color: rgba(0,240,255,0.2); animation-duration: 9s; }
.diagram-core {
  font-family: var(--font-head); font-size: 1rem; font-weight: 900;
  color: var(--cyan); letter-spacing: 0.2em;
  text-shadow: 0 0 20px var(--cyan);
  z-index: 2;
}
.diagram-dot {
  position: absolute; width: 8px; height: 8px; border-radius: 50%;
  background: var(--cyan); box-shadow: 0 0 12px var(--cyan);
}
.dot-1 { top: 0; left: 50%; transform: translateX(-50%); animation: spinDot 20s linear infinite; transform-origin: 0 140px; }
.dot-2 { top: 15%; left: 0; animation: spinDot 14s linear infinite reverse; transform-origin: 140px 0; }
.dot-3 { bottom: 25%; right: 25%; animation: spinDot 9s linear infinite; transform-origin: -30px -30px; }
@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes spinDot { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
.about-body {
  font-size: 1rem; color: var(--white-dim); line-height: 1.9;
  white-space: pre-line;
}

/* ── FORUM ───────────────────────────────────────────────────── */
.forum-section { background: var(--deep); }
.forum-compose {
  background: var(--surface); border: 1px solid var(--border); margin-bottom: 40px;
  transition: border-color 0.3s;
}
.forum-compose:focus-within { border-color: var(--cyan); }
.compose-header {
  padding: 12px 20px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 12px;
  font-family: var(--font-mono); font-size: 0.75rem;
}
.anon-tag { color: var(--cyan); letter-spacing: 0.1em; }
.compose-label { color: var(--white-dim); }
.forum-textarea {
  width: 100%; background: transparent; border: none; outline: none;
  color: var(--white); font-family: var(--font-mono); font-size: 0.9rem;
  padding: 20px; min-height: 120px; resize: vertical; line-height: 1.6;
}
.forum-textarea::placeholder { color: var(--border); }
.compose-footer {
  padding: 12px 20px; border-top: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
}
.char-count { font-family: var(--font-mono); font-size: 0.7rem; color: var(--border); }
.btn-transmit {
  font-family: var(--font-head); font-size: 0.75rem; letter-spacing: 0.15em;
  background: transparent; border: 1px solid var(--cyan); color: var(--cyan);
  padding: 8px 20px; cursor: pointer; transition: all 0.2s;
}
.btn-transmit:hover { background: var(--cyan); color: var(--black); box-shadow: 0 0 20px var(--cyan); }
.forum-posts { display: flex; flex-direction: column; gap: 2px; }
.loading-signal { font-family: var(--font-mono); font-size: 0.8rem; color: var(--border); padding: 20px; }
.post-card {
  background: var(--surface); border: 1px solid var(--border);
  transition: border-color 0.3s; overflow: hidden;
}
.post-card:hover { border-color: var(--border-bright); }
.post-header {
  padding: 14px 20px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--font-mono); font-size: 0.7rem;
}
.post-meta { color: var(--border); display: flex; gap: 16px; }
.post-anon { color: var(--cyan); }
.post-body { padding: 16px 20px; font-size: 0.95rem; line-height: 1.7; color: var(--white-dim); }
.post-actions {
  padding: 10px 20px; display: flex; align-items: center; gap: 16px;
  border-top: 1px solid var(--border);
}
.btn-reply {
  font-family: var(--font-mono); font-size: 0.7rem; color: var(--white-dim);
  background: none; border: none; cursor: pointer; letter-spacing: 0.1em;
  transition: color 0.2s; padding: 4px 0;
}
.btn-reply:hover { color: var(--cyan); }
.btn-delete-post {
  font-family: var(--font-mono); font-size: 0.65rem; color: #ff335566;
  background: none; border: none; cursor: pointer; margin-left: auto;
  transition: color 0.2s;
}
.btn-delete-post:hover { color: #ff3355; }
.replies { border-top: 1px solid var(--border); }
.reply-card {
  padding: 12px 20px 12px 36px; border-bottom: 1px solid var(--border);
  border-left: 2px solid var(--border);
}
.reply-card:last-child { border-bottom: none; }
.reply-meta { font-family: var(--font-mono); font-size: 0.65rem; color: var(--border); margin-bottom: 6px; }
.reply-body { font-size: 0.88rem; color: var(--white-dim); line-height: 1.6; }
.reply-compose { padding: 12px 20px; display: none; }
.reply-compose.open { display: block; }
.reply-input {
  width: 100%; background: var(--black); border: 1px solid var(--border);
  color: var(--white); font-family: var(--font-mono); font-size: 0.85rem;
  padding: 10px 14px; outline: none; margin-bottom: 8px; resize: none;
}
.reply-input:focus { border-color: var(--cyan); }
.btn-send-reply {
  font-family: var(--font-head); font-size: 0.7rem; letter-spacing: 0.1em;
  background: var(--cyan); color: var(--black); border: none;
  padding: 6px 16px; cursor: pointer;
}

/* ── DIY ─────────────────────────────────────────────────────── */
.diy-section { background: var(--black); }
.diy-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 2px; }
.diy-card {
  background: var(--surface); border: 1px solid var(--border);
  padding: 28px; display: flex; flex-direction: column; gap: 12px;
  transition: border-color 0.3s; position: relative; overflow: hidden;
}
.diy-card::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(to right, var(--cyan), transparent);
  transform: scaleX(0); transform-origin: left; transition: transform 0.4s;
}
.diy-card:hover { border-color: var(--cyan-dim); }
.diy-card:hover::after { transform: scaleX(1); }
.diy-category {
  font-family: var(--font-mono); font-size: 0.65rem; color: var(--orange);
  letter-spacing: 0.2em;
}
.diy-name { font-family: var(--font-head); font-size: 1rem; color: var(--white); letter-spacing: 0.05em; }
.diy-desc { font-size: 0.85rem; color: var(--white-dim); line-height: 1.6; flex: 1; }
.diy-footer { display: flex; align-items: center; justify-content: space-between; margin-top: 8px; }
.diy-size { font-family: var(--font-mono); font-size: 0.7rem; color: var(--border); }
.btn-download {
  font-family: var(--font-head); font-size: 0.7rem; letter-spacing: 0.1em;
  background: transparent; border: 1px solid var(--orange); color: var(--orange);
  padding: 6px 16px; cursor: pointer; text-decoration: none; display: inline-block;
  transition: all 0.2s;
}
.btn-download:hover { background: var(--orange); color: var(--black); }
.btn-delete-diy {
  font-family: var(--font-mono); font-size: 0.65rem; color: #ff335544;
  background: none; border: none; cursor: pointer; transition: color 0.2s;
}
.btn-delete-diy:hover { color: #ff3355; }
.diy-empty {
  font-family: var(--font-mono); font-size: 0.85rem; color: var(--border);
  grid-column: 1 / -1; padding: 40px; text-align: center; border: 1px dashed var(--border);
}

/* ── DONATE ──────────────────────────────────────────────────── */
.donate-section { background: var(--deep); }
.donate-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 60px; }
.donate-progress-panel, .donate-form-panel { display: flex; flex-direction: column; gap: 20px; }
.progress-header {
  font-family: var(--font-head); font-size: 1.5rem; letter-spacing: 0.05em;
  display: flex; align-items: baseline; gap: 12px;
}
.progress-raised { color: var(--cyan); font-size: 2.5rem; }
.progress-sep { color: var(--border); font-size: 1rem; }
.progress-goal { color: var(--white-dim); }
.progress-track {
  height: 8px; background: var(--surface); border: 1px solid var(--border);
  position: relative; overflow: hidden;
}
.progress-fill {
  height: 100%; background: linear-gradient(to right, var(--cyan-dim), var(--cyan));
  transition: width 1.5s cubic-bezier(0.25, 1, 0.5, 1);
  position: relative;
}
.progress-glow {
  position: absolute; top: -4px; width: 16px; height: 16px; border-radius: 50%;
  background: var(--cyan); filter: blur(6px); opacity: 0.8;
  transform: translateX(-50%); transition: left 1.5s cubic-bezier(0.25, 1, 0.5, 1);
}
.progress-pct {
  font-family: var(--font-mono); font-size: 0.8rem; color: var(--cyan);
  letter-spacing: 0.15em;
}
.donors-list { background: var(--surface); border: 1px solid var(--border); padding: 16px; flex: 1; max-height: 280px; overflow-y: auto; }
.donors-title { font-family: var(--font-mono); font-size: 0.65rem; color: var(--border); letter-spacing: 0.2em; margin-bottom: 12px; }
.donor-item { padding: 8px 0; border-bottom: 1px solid var(--border); display: flex; gap: 12px; align-items: baseline; }
.donor-item:last-child { border-bottom: none; }
.donor-amount { font-family: var(--font-head); font-size: 0.85rem; color: var(--cyan); min-width: 50px; }
.donor-name { font-family: var(--font-mono); font-size: 0.75rem; color: var(--white-dim); flex: 1; }
.donor-msg { font-size: 0.75rem; color: var(--border); font-style: italic; }
.no-donors { font-family: var(--font-mono); font-size: 0.75rem; color: var(--border); }
.donate-desc { font-size: 0.9rem; color: var(--white-dim); line-height: 1.7; }
.donate-label { font-family: var(--font-mono); font-size: 0.7rem; color: var(--white-dim); letter-spacing: 0.15em; display: block; margin-bottom: 12px; }
.amount-presets { display: flex; gap: 8px; margin-bottom: 16px; flex-wrap: wrap; }
.amt-btn {
  font-family: var(--font-head); font-size: 0.75rem; letter-spacing: 0.1em;
  background: var(--surface); border: 1px solid var(--border); color: var(--white-dim);
  padding: 8px 16px; cursor: pointer; transition: all 0.2s;
}
.amt-btn:hover, .amt-btn.selected {
  border-color: var(--cyan); color: var(--cyan); box-shadow: 0 0 12px var(--cyan-glow);
}
.donate-input {
  width: 100%; background: var(--surface); border: 1px solid var(--border);
  color: var(--white); padding: 14px 16px; font-family: var(--font-mono);
  font-size: 0.9rem; outline: none; margin-bottom: 12px; transition: border-color 0.2s;
}
.donate-input:focus { border-color: var(--cyan); }
.donate-form .btn-launch { width: 100%; justify-content: center; margin-top: 8px; }
.donate-status { font-family: var(--font-mono); font-size: 0.8rem; min-height: 20px; margin-top: 8px; }

/* ── FOOTER ──────────────────────────────────────────────────── */
.footer {
  background: var(--black); border-top: 1px solid var(--border); padding: 60px 0;
}
.footer-inner {
  max-width: 1200px; margin: 0 auto; padding: 0 40px; text-align: center;
  display: flex; flex-direction: column; gap: 16px; align-items: center;
}
.footer-logo {
  font-family: var(--font-head); font-size: 1.2rem; letter-spacing: 0.3em;
  color: var(--cyan); text-shadow: 0 0 20px var(--cyan-glow);
}
.footer-text { font-family: var(--font-mono); font-size: 0.8rem; color: var(--border); }
.footer-links { display: flex; gap: 24px; }
.footer-links a {
  font-family: var(--font-mono); font-size: 0.7rem; color: var(--white-dim);
  text-decoration: none; letter-spacing: 0.15em; transition: color 0.2s;
}
.footer-links a:hover { color: var(--cyan); }
.footer-copy { font-family: var(--font-mono); font-size: 0.65rem; color: var(--border); }

/* ── EDIT MODE HIGHLIGHTS ────────────────────────────────────── */
body.edit-mode [data-bind],
body.edit-mode [data-editable] {
  outline: 1px dashed rgba(0,240,255,0.4);
  cursor: text;
  position: relative;
}
body.edit-mode [data-bind]:hover,
body.edit-mode [data-editable]:hover {
  outline-color: var(--cyan);
  background: rgba(0,240,255,0.04);
}

/* ── ANIMATIONS ──────────────────────────────────────────────── */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}
.animate-in { animation: fadeUp 0.6s ease forwards; }

/* ── SCROLLBAR ───────────────────────────────────────────────── */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: var(--black); }
::-webkit-scrollbar-thumb { background: var(--border); }
::-webkit-scrollbar-thumb:hover { background: var(--cyan); }

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media (max-width: 900px) {
  .hero-content { padding: 0 24px; }
  .hero-planet { width: 300px; height: 300px; right: -60px; }
  .hero-ring { width: 420px; height: 420px; right: -120px; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); }
  .about-grid { grid-template-columns: 1fr; }
  .about-visual { display: none; }
  .donate-grid { grid-template-columns: 1fr; }
  .nav-links { display: none; }
  .edit-panel { width: 100%; }
}
@media (max-width: 600px) {
  .container { padding: 0 24px; }
  .section { padding: 80px 0 60px; }
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .diy-grid { grid-template-columns: 1fr; }
}
