/* ==========================================
   AIRDROPXI — MODERN UI v2 (FULL FIXED)
   ========================================== */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;700&display=swap');

/* ==========================================
   1. CSS VARIABLES
   ========================================== */
:root {
  --g: #00e87a;
  --c: #00c8f0;
  --accent: #7c6dfa;
  --bg: #080f0c;
  --bg2: #0d1a14;
  --bg3: #111f18;
  --surface: rgba(255,255,255,0.04);
  --surface-h: rgba(255,255,255,0.07);
  --border: rgba(255,255,255,0.08);
  --border-h: rgba(0,232,122,0.4);
  --text: #e6f2ec;
  --text2: #8aa898;
  --text3: #4d7060;
  --shadow: 0 4px 24px rgba(0,0,0,0.4);
  --shadow-lg: 0 16px 48px rgba(0,0,0,0.5);
  --glow: 0 0 32px rgba(0,232,122,0.15);
  --radius: 14px;
  --radius-sm: 8px;
  --radius-pill: 100px;
}

[data-theme="light"] {
  --bg: #f0f7f4;
  --bg2: #e4f0eb;
  --bg3: #ffffff;
  --surface: rgba(0,0,0,0.04);
  --surface-h: rgba(0,0,0,0.07);
  --border: rgba(0,0,0,0.1);
  --border-h: rgba(0,180,96,0.5);
  --text: #0d2018;
  --text2: #3d6652;
  --text3: #7aaa90;
  --shadow: 0 4px 24px rgba(0,0,0,0.1);
  --shadow-lg: 0 16px 48px rgba(0,0,0,0.15);
  --glow: 0 0 32px rgba(0,180,96,0.12);
}

/* ==========================================
   2. BASE RESET
   ========================================== */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }

html, body {
  max-width: 100%;
  overflow-x: hidden;
}

body {
  font-family: 'Plus Jakarta Sans', sans-serif;
  background: var(--bg);
  color: var(--text);
  min-height: 100vh;
  cursor: default;
  transition: background 0.4s, color 0.4s;
}

/* ==========================================
   3. BACKGROUND CANVAS
   ========================================== */
#bg-canvas {
  position: fixed; inset:0; z-index:0; pointer-events:none;
  opacity: 1;
  transition: opacity 0.4s;
}
[data-theme="light"] #bg-canvas { opacity: 0.35; }

body::after {
  content: '';
  position: fixed; inset:0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  opacity: .3; pointer-events:none; z-index:1;
}

.z1 { position: relative; z-index:2; }

/* ==========================================
   4. PRICE TICKER
   ========================================== */
.pticker-wrap {
  background: rgba(0,0,0,0.6);
  border-bottom: 1px solid var(--border);
  overflow: hidden; height:36px;
  display: flex; align-items:center;
  backdrop-filter: blur(20px);
  max-width: 100vw;
}
[data-theme="light"] .pticker-wrap { background: rgba(255,255,255,0.75); }
.pticker-inner {
  display: inline-flex;
  animation: scrollX 220s linear infinite;
  white-space: nowrap;
}
.pticker-inner:hover { animation-play-state: paused; }
.ptick {
  display: inline-flex; align-items:center; gap:7px;
  padding: 0 24px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  border-right: 1px solid var(--border);
}
.ptick img { width:14px; height:14px; border-radius:50%; }
.ptick-sym { color: var(--text2); font-weight:700; text-transform:uppercase; }
.ptick-price { color: var(--c); }
.ptick-up { color: var(--g); }
.ptick-dn { color: #ff4d6d; }

/* ==========================================
   5. NEWS TICKER
   ========================================== */
.nticker-wrap {
  background: var(--bg2);
  border-bottom: 1px solid rgba(0,200,240,0.12);
  overflow: hidden; height:32px;
  display: flex; align-items:stretch;
  backdrop-filter: blur(20px);
  max-width: 100vw;
}
[data-theme="light"] .nticker-wrap { background: rgba(255,255,255,0.8); }
.nticker-label {
  display: flex; align-items:center; gap:6px;
  padding: 0 14px;
  background: linear-gradient(90deg, #00c8f0, #00e87a);
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px; font-weight:700; letter-spacing:2px;
  color: #000; flex-shrink:0;
}
.ldot {
  width:5px; height:5px;
  background: #ff2d55; border-radius:50%;
  animation: ldot 1s infinite;
}
@keyframes ldot {
  0%,100% { opacity:1; transform:scale(1); }
  50% { opacity:.2; transform:scale(.6); }
}
.nticker-track {
  flex:1; overflow:hidden; position:relative;
  display:flex; align-items:center;
}
.nticker-track::after {
  content:''; position:absolute; right:0; top:0; bottom:0; width:60px;
  background: linear-gradient(90deg, transparent, var(--bg2));
  z-index:2; pointer-events:none;
}
.nticker-inner {
  display: inline-flex; align-items:center;
  animation: scrollX 38s linear infinite;
  white-space: nowrap;
}
.nticker-inner:hover { animation-play-state: paused; }
.ni {
  display: inline-flex; align-items:center; gap:7px;
  padding: 0 20px;
  border-right: 1px solid rgba(0,200,240,0.08);
  font-size: 11px; font-family: 'JetBrains Mono', monospace;
  color: var(--text2);
}
.ni-dot { color:#f0b429; font-size:8px; }
.ni-tag {
  font-size:8px; font-weight:700; padding:2px 6px;
  border-radius:3px; text-transform:uppercase; letter-spacing:.8px;
}
.tag-launch  { background:rgba(0,232,122,.1); color:var(--g); border:1px solid rgba(0,232,122,.2); }
.tag-snapshot{ background:rgba(0,200,240,.1); color:var(--c); border:1px solid rgba(0,200,240,.2); }
.tag-release { background:rgba(240,180,41,.1); color:#f0b429; border:1px solid rgba(240,180,41,.2); }
.tag-sale    { background:rgba(160,100,255,.1); color:#a064ff; border:1px solid rgba(160,100,255,.2); }
.tag-alert   { background:rgba(255,45,85,.1); color:#ff2d55; border:1px solid rgba(255,45,85,.2); }
.tag-news    { background:rgba(150,150,150,.06); color:var(--text2); border:1px solid var(--border); }

@keyframes scrollX {
  0%   { transform:translateX(0); }
  100% { transform:translateX(-50%); }
}

/* ==========================================
   6. NAVBAR
   ========================================== */
nav {
  display: flex; align-items:center; justify-content:space-between;
  padding: 0 40px; height:60px;
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(30px);
  background: rgba(8,15,12,0.75);
  position: sticky; top:0; z-index:100;
  transition: background 0.4s;
}
[data-theme="light"] nav { background: rgba(240,247,244,0.88); }

.nav-logo {
  display: flex; align-items:center; gap:10px;
  font-size: 18px; font-weight:800; letter-spacing:-0.5px;
  color: var(--text); text-decoration:none;
  flex-shrink: 0;
}
.nav-logo img { width:30px; height:30px; border-radius:8px; object-fit:contain; }

.nav-links { display:flex; gap:28px; }
.nav-links a {
  font-size:11px; font-weight:600; color:var(--text2);
  text-decoration:none; letter-spacing:1px;
  transition: color .2s;
  text-transform: uppercase;
  white-space: nowrap;
}
.nav-links a:hover { color:var(--g); }

.nav-right { display:flex; align-items:center; gap:10px; }
.nav-social { display:flex; gap:6px; }
.nav-social a {
  width:30px; height:30px;
  border: 1px solid var(--border); border-radius:var(--radius-sm);
  display:flex; align-items:center; justify-content:center;
  color:var(--text2); text-decoration:none;
  transition: all .2s; font-size:12px;
}
.nav-social a:hover { border-color:var(--g); color:var(--g); background:rgba(0,232,122,.06); }

.lang-toggle {
  display:flex; background:var(--surface);
  border: 1px solid var(--border); border-radius:var(--radius-sm);
  overflow:hidden;
}
.lang-btn {
  padding:6px 12px; font-size:10px; font-weight:700;
  text-transform:uppercase; letter-spacing:.5px;
  border:none; background:transparent; color:var(--text2);
  cursor:pointer; transition:all .2s;
  font-family: 'Plus Jakarta Sans', sans-serif;
}
.lang-btn.active { background:rgba(0,232,122,.12); color:var(--g); }

.theme-toggle {
  width:32px; height:32px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius:var(--radius-sm); color:var(--text2);
  cursor:pointer; font-size:15px;
  display:flex; align-items:center; justify-content:center;
  transition: all .2s;
}
.theme-toggle:hover { border-color:var(--g); color:var(--g); }

.ai-agent-btn {
  display:flex; align-items:center; gap:6px;
  background: rgba(0,232,122,.07);
  border: 1px solid rgba(0,232,122,.3);
  color: var(--g); padding:7px 14px;
  border-radius:var(--radius-sm); cursor:pointer;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; font-weight:700; letter-spacing:.5px;
  transition: all .2s;
}
.ai-agent-btn:hover { background:rgba(0,232,122,.14); box-shadow:0 0 16px rgba(0,232,122,.2); }
.ai-btn-dot { width:6px; height:6px; background:var(--g); border-radius:50%; animation:ldot 1.5s infinite; flex-shrink:0; }

/* ==========================================
   HAMBURGER BUTTON
   ========================================== */
.hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 36px;
  height: 36px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  padding: 8px;
  transition: all .2s;
  flex-shrink: 0;
}
.hamburger span {
  display: block;
  width: 18px;
  height: 2px;
  background: var(--text);
  border-radius: 2px;
  transition: all .3s ease;
  transform-origin: center;
}
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.hamburger:hover { border-color: var(--g); }

/* ==========================================
   MOBILE DROPDOWN MENU
   ========================================== */
.mobile-menu {
  display: none;
  position: sticky;
  top: 60px;
  left: 0;
  right: 0;
  width: 100%;
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
  flex-direction: column;
  z-index: 99;
  backdrop-filter: blur(30px);
  box-shadow: 0 16px 40px rgba(0,0,0,0.4);
  animation: dropDown .25s ease;
}
[data-theme="light"] .mobile-menu { background: rgba(228,240,235,0.98); }

.mobile-menu.open { display: flex; }

.mobile-menu a {
  padding: 14px 20px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text2);
  text-decoration: none;
  letter-spacing: .3px;
  border-bottom: 1px solid var(--border);
  transition: all .2s;
  display: flex;
  align-items: center;
  gap: 10px;
}
.mobile-menu a:hover {
  color: var(--g);
  background: rgba(0,232,122,0.04);
  padding-left: 28px;
}
.mobile-menu a:last-of-type { border-bottom: none; }

.mobile-menu-bottom {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 16px;
  border-top: 1px solid var(--border);
  background: rgba(0,0,0,0.15);
  flex-wrap: wrap;
}
[data-theme="light"] .mobile-menu-bottom { background: rgba(0,0,0,0.04); }

.mobile-menu-bottom .lang-btn {
  padding: 7px 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--surface);
}
.mobile-menu-bottom .ai-agent-btn { flex: 1; justify-content: center; }

@keyframes dropDown {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ==========================================
   7. HERO SECTION
   ========================================== */
.hero {
  min-height: 86vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items:center; gap:60px;
  padding: 80px 40px 60px;
  max-width: 1360px; margin:0 auto;
}
.hero-badge {
  display: inline-flex; align-items:center; gap:8px;
  background: rgba(0,232,122,.08);
  border: 1px solid rgba(0,232,122,.2);
  border-radius: var(--radius-pill);
  padding: 6px 14px;
  font-size: 11px; font-family:'JetBrains Mono',monospace;
  color: var(--g); margin-bottom:24px;
  animation: fadeUp .8s ease both;
}
.hero-badge-dot { width:6px; height:6px; background:var(--g); border-radius:50%; animation:ldot 2s infinite; }
.hero h1 {
  font-size: clamp(40px, 5vw, 68px);
  font-weight:800; line-height:1.05;
  letter-spacing:-2px; margin-bottom:20px;
  animation: fadeUp .8s .1s ease both;
}
.hero h1 span {
  background: linear-gradient(135deg, var(--g), var(--c));
  -webkit-background-clip: text; -webkit-text-fill-color:transparent;
  background-clip: text;
}
.hero-sub {
  font-size:15px; color:var(--text2); line-height:1.7;
  margin-bottom:36px; max-width:460px;
  font-family: 'JetBrains Mono', monospace;
  animation: fadeUp .8s .2s ease both;
}
.hero-btns { display:flex; gap:12px; animation:fadeUp .8s .3s ease both; }
.btn-primary {
  background: linear-gradient(135deg, var(--g), var(--c));
  color:#000; font-weight:700; font-size:12px;
  padding: 13px 26px; border-radius:var(--radius-sm);
  border:none; cursor:pointer; letter-spacing:.5px;
  text-transform:uppercase; transition:all .3s;
  font-family:'Plus Jakarta Sans',sans-serif;
  display:flex; align-items:center; gap:7px;
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 16px 40px rgba(0,232,122,.3); }
.btn-ghost {
  background:transparent; color:var(--text);
  font-weight:600; font-size:12px; padding:13px 26px;
  border-radius:var(--radius-sm); border:1px solid var(--border);
  cursor:pointer; letter-spacing:.5px; text-transform:uppercase;
  transition:all .3s; font-family:'Plus Jakarta Sans',sans-serif;
}
.btn-ghost:hover { border-color:var(--g); color:var(--g); background:rgba(0,232,122,.05); }
.hero-stats {
  display:flex; gap:28px; margin-top:44px;
  animation: fadeUp .8s .4s ease both;
}
.hstat { border-left:2px solid var(--border); padding-left:14px; }
.hstat-num {
  font-size:26px; font-weight:800; color:var(--g);
  letter-spacing:-1px; font-family:'JetBrains Mono',monospace;
}
.hstat-lbl { font-size:10px; color:var(--text2); text-transform:uppercase; letter-spacing:1px; margin-top:2px; }

/* ==========================================
   8. CRYPTO UNIVERSE
   ========================================== */
.hero-visual {
  position:relative; display:flex; justify-content:center;
  animation: fadeUp .8s .2s ease both;
}
.universe-container {
  position:relative; width:400px; height:400px;
  display:flex; align-items:center; justify-content:center;
}
.sun-btc {
  width:64px; height:64px; background:#f7931a;
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  box-shadow: 0 0 36px rgba(247,147,26,.4), inset 0 0 12px rgba(255,255,255,.3);
  z-index:10; animation:orbFloat 4s ease-in-out infinite;
}
.sun-btc img { width:38px; height:38px; }
.orbit-ring {
  position:absolute; border-radius:50%;
  border:1px dashed var(--border);
  top:50%; left:50%;
  transform:translate(-50%,-50%);
}
.ring-1 { width:190px; height:190px; animation:spin 16s linear infinite; }
.ring-2 { width:300px; height:300px; border:1px solid rgba(0,200,240,.12); animation:spinReverse 26s linear infinite; }
.ring-3 { width:420px; height:420px; animation:spin 36s linear infinite; }
.planet {
  position:absolute; width:32px; height:32px;
  background:var(--bg3); border-radius:50%;
  border:1px solid var(--border-h);
  display:flex; align-items:center; justify-content:center;
  top:0; left:50%; margin-left:-16px; margin-top:-16px;
}
.planet img { width:18px; height:18px; border-radius:50%; }
.planet-counter  { animation:spinReverse 16s linear infinite; }
.planet-counter-2{ animation:spin 26s linear infinite; }
.planet-counter-3{ animation:spinReverse 36s linear infinite; }
.float-card {
  position:absolute; background:var(--bg2);
  border:1px solid var(--border); border-radius:var(--radius);
  padding:12px 16px; backdrop-filter:blur(20px);
  font-size:12px; white-space:nowrap; z-index:20;
  box-shadow: var(--shadow);
}
.float-card-1 { top:5%; left:-18%; animation:fc1 7s ease-in-out infinite; }
.float-card-2 { bottom:10%; right:-12%; animation:fc2 8s ease-in-out infinite; }
.fc-title { font-weight:700; color:var(--g); font-family:'JetBrains Mono',monospace; font-size:10px; }
.fc-val { color:var(--text); font-weight:700; font-size:14px; margin-top:2px; }
.fc-sub { color:var(--text2); font-size:10px; margin-top:1px; }

@keyframes spin { to { transform:translate(-50%,-50%) rotate(360deg); } }
@keyframes spinReverse { to { transform:translate(-50%,-50%) rotate(-360deg); } }
@keyframes orbFloat { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-14px)} }
@keyframes fc1 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(6px,-10px)} }
@keyframes fc2 { 0%,100%{transform:translate(0,0)} 50%{transform:translate(-8px,8px)} }
@keyframes fadeUp { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }

/* ==========================================
   9. SECTIONS
   ========================================== */
section {
  padding: 72px 40px;
  max-width: 1360px; margin:0 auto;
}
.section-tag {
  display:inline-flex; align-items:center; gap:6px;
  font-family:'JetBrains Mono',monospace; font-size:10px;
  color:var(--g); letter-spacing:2px; text-transform:uppercase;
  margin-bottom:12px;
}
.section-tag::before { content:''; width:18px; height:1px; background:var(--g); }
.section-title { font-size:clamp(26px,3vw,42px); font-weight:800; letter-spacing:-1.5px; line-height:1.1; margin-bottom:10px; }
.section-sub { color:var(--text2); font-size:14px; font-family:'JetBrains Mono',monospace; line-height:1.65; max-width:480px; margin-bottom:36px; }

/* ==========================================
   10. DASHBOARD STATS
   ========================================== */
.dash-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:16px; margin-bottom:44px;
}
.dash-card {
  background:var(--surface);
  border:1px solid var(--border); border-radius:var(--radius);
  padding:24px; transition:all .3s; position:relative; overflow:hidden;
}
.dash-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,var(--g),var(--c));
  transform:scaleX(0); transform-origin:left; transition:transform .4s;
}
.dash-card:hover { border-color:var(--border-h); transform:translateY(-2px); box-shadow:var(--shadow); }
.dash-card:hover::after { transform:scaleX(1); }
.dash-label { font-size:10px; color:var(--text2); text-transform:uppercase; letter-spacing:1.5px; margin-bottom:10px; font-family:'JetBrains Mono',monospace; }
.dash-num { font-size:40px; font-weight:800; font-family:'JetBrains Mono',monospace; letter-spacing:-2px; }
.dash-num-g { background:linear-gradient(135deg,var(--g),var(--c)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.dash-num-c { color:var(--c); }
.dash-num-p { color:var(--accent); }
.dash-ico { position:absolute; right:18px; top:18px; width:36px; height:36px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:17px; }

/* ==========================================
   11. FILTER BAR
   ========================================== */
.filter-bar {
  display:flex; align-items:center; gap:10px;
  margin-bottom:28px; flex-wrap:wrap;
}
.search-box {
  flex:1; min-width:240px;
  display:flex; align-items:center; gap:8px;
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-sm); padding:9px 14px;
  transition:border .2s;
}
.search-box:focus-within { border-color:rgba(0,232,122,.4); }
.search-box input {
  background:transparent; border:none; outline:none;
  color:var(--text); font-size:13px; flex:1;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.search-box input::placeholder { color:var(--text3); }
.search-ico { color:var(--text2); font-size:13px; }
.filter-btns { display:flex; gap:7px; flex-wrap:wrap; }
.fbtn {
  background:transparent; border:1px solid var(--border);
  color:var(--text2); font-size:10px; font-weight:700;
  padding:8px 14px; border-radius:var(--radius-sm);
  cursor:pointer; letter-spacing:.5px; text-transform:uppercase;
  transition:all .2s; font-family:'Plus Jakarta Sans',sans-serif;
  display:flex; align-items:center; gap:5px;
}
.fbtn:hover, .fbtn.active { background:rgba(0,232,122,.08); border-color:var(--g); color:var(--g); }
.fbtn-dot { width:5px; height:5px; border-radius:50%; background:currentColor; }

/* ==========================================
   12. AIRDROP CARDS
   ========================================== */
#airdrop-container {
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(320px,1fr));
  gap:18px;
}
.acard {
  background:var(--surface);
  border:1px solid var(--border); border-radius:var(--radius);
  padding:22px; display:flex; flex-direction:column;
  position:relative; overflow:hidden;
  transition:all .35s cubic-bezier(.4,0,.2,1); cursor:pointer;
}
.acard::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(500px circle at var(--mx,50%) var(--my,50%), rgba(0,232,122,.04), transparent 40%);
  opacity:0; transition:opacity .4s; pointer-events:none;
}
.acard:hover {
  border-color:var(--border-h);
  transform:translateY(-3px);
  box-shadow:0 20px 44px rgba(0,0,0,.35), 0 0 0 1px rgba(0,232,122,.07);
}
.acard:hover::before { opacity:1; }
.acard-top { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:14px; }
.acard-name { font-size:18px; font-weight:800; letter-spacing:-.5px; color:var(--text); }
.acard-icon {
  width:40px; height:40px; border-radius:10px;
  background:linear-gradient(135deg,rgba(0,232,122,.12),rgba(0,200,240,.08));
  border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:18px; flex-shrink:0;
}
.acard-status {
  font-size:9px; font-weight:700; padding:3px 9px;
  border-radius:var(--radius-pill); text-transform:uppercase;
  letter-spacing:1px; font-family:'JetBrains Mono',monospace;
}
.st-active { background:rgba(0,232,122,.1); color:var(--g); border:1px solid rgba(0,232,122,.25); }
.st-waitlist{ background:rgba(245,158,11,.1); color:#f59e0b; border:1px solid rgba(245,158,11,.25); }
.st-mint { background:rgba(59,130,246,.1); color:#60a5fa; border:1px solid rgba(59,130,246,.25); }
.st-listing { background:rgba(124,109,250,.1); color:var(--accent); border:1px solid rgba(124,109,250,.25); }
.st-default { background:rgba(100,116,139,.1); color:#94a3b8; border:1px solid rgba(100,116,139,.2); }
.acard-tags { display:flex; flex-wrap:wrap; gap:5px; margin-bottom:14px; }
.atag {
  font-size:9px; font-weight:700; padding:3px 8px;
  border-radius:4px; text-transform:uppercase; letter-spacing:.5px;
  background:rgba(0,232,122,.06); color:rgba(0,232,122,.75);
  border:1px solid rgba(0,232,122,.12);
}
[data-theme="light"] .atag { background:rgba(0,180,96,.08); color:rgba(0,150,70,.9); border-color:rgba(0,180,96,.2); }
.acard-raised {
  display:flex; align-items:center; gap:10px;
  background:rgba(0,0,0,.2); border:1px solid rgba(0,232,122,.06);
  border-radius:10px; padding:10px 12px; margin-bottom:12px;
}
[data-theme="light"] .acard-raised { background:rgba(0,0,0,.04); }
.raised-ico { width:28px; height:28px; background:rgba(0,232,122,.1); border-radius:7px; display:flex; align-items:center; justify-content:center; color:var(--g); font-size:12px; flex-shrink:0; }
.raised-lbl { font-size:9px; color:var(--text2); text-transform:uppercase; letter-spacing:.5px; }
.raised-val { font-size:13px; font-weight:700; color:var(--g); font-family:'JetBrains Mono',monospace; }
.prog-wrap { margin-bottom:12px; }
.prog-meta { display:flex; justify-content:space-between; font-size:10px; font-family:'JetBrains Mono',monospace; color:var(--text2); margin-bottom:5px; }
.prog-bar { height:3px; background:rgba(255,255,255,.06); border-radius:2px; overflow:hidden; }
[data-theme="light"] .prog-bar { background:rgba(0,0,0,.08); }
.prog-fill { height:100%; border-radius:2px; background:linear-gradient(90deg,var(--g),var(--c)); transition:width 1s ease; }
.acard-tasks { flex:1; margin-bottom:18px; }
.tasks-lbl {
  font-size:9px; color:var(--text2); text-transform:uppercase;
  letter-spacing:1px; margin-bottom:7px;
  display:flex; align-items:center; gap:5px;
}
.tasks-lbl::after { content:''; flex:1; height:1px; background:var(--border); }
.tasks-body {
  font-size:12px; color:var(--text2); line-height:1.65;
  max-height:72px; overflow-y:auto;
  font-family:'JetBrains Mono',monospace;
}
.tasks-body::-webkit-scrollbar { width:3px; }
.tasks-body::-webkit-scrollbar-thumb { background:rgba(0,232,122,.3); border-radius:2px; }
.acard-btn {
  display:block; width:100%; text-align:center; padding:12px;
  border-radius:var(--radius-sm); font-weight:700; font-size:11px;
  letter-spacing:1px; text-transform:uppercase; text-decoration:none;
  transition:all .3s; font-family:'Plus Jakarta Sans',sans-serif;
  border:1px solid rgba(0,232,122,.3); color:var(--g);
  background:rgba(0,232,122,.04);
}
.acard-btn:hover { background:linear-gradient(135deg,var(--g),var(--c)); color:#000; border-color:transparent; box-shadow:0 0 28px rgba(0,232,122,.3); }

#loading-state {
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; padding:80px; gap:14px;
}
.spinner {
  width:40px; height:40px;
  border:2px solid rgba(0,232,122,.1);
  border-top-color:var(--g); border-radius:50%;
  animation:spinLoader .8s linear infinite;
}
@keyframes spinLoader { to { transform:rotate(360deg); } }
#error-state {
  display:none; text-align:center; padding:36px;
  background:rgba(255,45,85,.05); border:1px solid rgba(255,45,85,.2);
  border-radius:var(--radius); max-width:480px; margin:36px auto;
}

/* ==========================================
   13. GUIDE CARDS
   ========================================== */
.guide-grid { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:18px; }
.guide-card {
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius); padding:28px;
  transition:all .3s;
}
.guide-card:hover { border-color:var(--border-h); box-shadow:var(--shadow); }
.g-icon { width:44px; height:44px; background:rgba(0,232,122,.1); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:22px; margin-bottom:18px; }
.g-title { font-size:18px; font-weight:700; margin-bottom:10px; color:var(--text); }
.g-desc { font-size:13px; color:var(--text2); line-height:1.65; margin-bottom:18px; }
.g-list { list-style:none; display:flex; flex-direction:column; gap:10px; }
.g-list li { display:flex; align-items:flex-start; gap:8px; font-size:13px; color:var(--text2); line-height:1.5; }
.g-list li::before { content:'⚡'; font-size:11px; margin-top:2px; color:var(--c); flex-shrink:0; }
.st-badge-wrap { display:flex; flex-direction:column; gap:10px; margin-top:14px; }
.st-item {
  display:flex; align-items:center; gap:10px;
  background:var(--surface); padding:9px 12px;
  border-radius:var(--radius-sm); border:1px solid var(--border);
}
.st-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.st-item-text { font-size:12px; color:var(--text2); }
.st-item-text strong { color:var(--text); font-family:'JetBrains Mono',monospace; font-size:10px; text-transform:uppercase; letter-spacing:1px; display:block; margin-bottom:2px; }

/* ==========================================
   14. FOOTER
   ========================================== */
footer {
  background:var(--bg2);
  border-top:1px solid var(--border);
  padding:48px 40px 28px;
}
.footer-inner { max-width:1360px; margin:0 auto; }
.footer-top { display:grid; grid-template-columns:1fr 1fr 1fr; gap:44px; margin-bottom:36px; }
.footer-brand h3 { font-size:20px; font-weight:800; letter-spacing:-1px; margin-bottom:8px; }
.footer-brand h3 span { background:linear-gradient(135deg,var(--g),var(--c)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.footer-brand p { font-size:12px; color:var(--text2); font-family:'JetBrains Mono',monospace; line-height:1.65; margin-bottom:18px; }
.footer-socials { display:flex; gap:8px; }
.fsoc {
  width:34px; height:34px; border:1px solid var(--border);
  border-radius:var(--radius-sm); display:flex; align-items:center;
  justify-content:center; color:var(--text2); text-decoration:none;
  transition:all .25s; font-size:14px;
}
.fsoc:hover { border-color:var(--g); color:var(--g); background:rgba(0,232,122,.06); transform:translateY(-2px); }
.footer-links h4 { font-size:10px; text-transform:uppercase; letter-spacing:2px; color:var(--text2); margin-bottom:14px; font-family:'JetBrains Mono',monospace; }
.footer-links a { display:block; font-size:12px; color:var(--text2); text-decoration:none; margin-bottom:8px; transition:color .2s; font-family:'JetBrains Mono',monospace; }
.footer-links a:hover { color:var(--g); }
.footer-bottom { border-top:1px solid var(--border); padding-top:20px; display:flex; justify-content:space-between; align-items:center; font-size:11px; font-family:'JetBrains Mono',monospace; color:var(--text2); flex-wrap:wrap; gap:8px; }
.dyor-badge { background:rgba(245,158,11,.07); border:1px solid rgba(245,158,11,.2); border-radius:var(--radius-sm); padding:8px 14px; font-size:10px; color:#f0b429; font-family:'JetBrains Mono',monospace; max-width:600px; text-align:center; margin:0 auto 18px; }

/* ==========================================
   15. AI CHAT PANEL
   ========================================== */
.ai-panel {
  position: fixed;
  bottom: 20px; right: 20px;
  width: 360px;
  max-width: calc(100vw - 40px);
  height: 500px;
  max-height: calc(100vh - 120px);
  background: var(--bg2);
  border: 1px solid rgba(0,232,122,0.3);
  border-radius: var(--radius);
  display: flex; flex-direction: column;
  z-index: 10000;
  box-shadow: 0 24px 64px rgba(0,0,0,0.5);
  backdrop-filter: blur(28px);
  overflow: hidden;
  transform: scale(0.95) translateY(10px);
  opacity: 0; pointer-events: none;
  transition: all 0.25s ease;
}
.ai-panel.open { transform: scale(1) translateY(0); opacity: 1; pointer-events: all; }
.ai-panel-header {
  padding: 14px 16px; border-bottom: 1px solid rgba(0,232,122,0.1);
  display: flex; align-items: center; gap: 10px;
  background: var(--bg2); flex-shrink: 0;
}
.ai-panel-avatar {
  width: 34px; height: 34px;
  background: linear-gradient(135deg, var(--g), var(--c));
  border-radius: 9px; display: flex; align-items: center; justify-content: center;
  font-size: 15px; flex-shrink: 0;
}
.ai-panel-info { flex: 1; }
.ai-panel-name { font-weight: 700; font-size: 13px; color: var(--text); }
.ai-panel-status {
  font-family: 'JetBrains Mono', monospace; font-size: 9px; color: var(--g);
  display: flex; align-items: center; gap: 4px; margin-top: 2px;
}
.ai-status-dot { width: 5px; height: 5px; background: var(--g); border-radius: 50%; animation: ldot 1.5s infinite; }
.ai-panel-close { background: none; border: none; color: var(--text2); cursor: pointer; font-size: 14px; padding: 4px; transition: color .2s; }
.ai-panel-close:hover { color: var(--text); }
.ai-messages { flex: 1; overflow-y: auto; padding: 16px; display: flex; flex-direction: column; gap: 12px; scroll-behavior: smooth; }
.ai-messages::-webkit-scrollbar { width: 4px; }
.ai-messages::-webkit-scrollbar-thumb { background: rgba(0,232,122,0.3); border-radius: 4px; }
.ai-msg { display: flex; gap: 8px; align-items: flex-start; max-width: 100%; }
.ai-msg.ai-msg-user { flex-direction: row-reverse; }
.ai-msg-avatar { width: 26px; height: 26px; border-radius: 7px; display: flex; align-items: center; justify-content: center; font-size: 12px; flex-shrink: 0; }
.ai-msg-bot .ai-msg-avatar { background: linear-gradient(135deg, var(--g), var(--c)); }
.ai-msg-user .ai-msg-avatar { background: var(--surface); border: 1px solid var(--border); }
.ai-msg-bubble { max-width: 80%; padding: 10px 14px; border-radius: 16px; font-size: 12px; line-height: 1.5; word-wrap: break-word; overflow-wrap: break-word; white-space: normal; }
.ai-msg-bot .ai-msg-bubble { background: rgba(0,232,122,0.08); border: 1px solid rgba(0,232,122,0.15); border-top-left-radius: 4px; color: var(--text); }
.ai-msg-user .ai-msg-bubble { background: rgba(0,232,122,0.12); border: 1px solid rgba(0,232,122,0.25); border-top-right-radius: 4px; color: var(--text); }
.ai-typing { display: flex; gap: 4px; align-items: center; padding: 8px 12px; }
.ai-tdot { width: 5px; height: 5px; background: var(--g); border-radius: 50%; animation: aiTyping 1.2s infinite; }
.ai-tdot:nth-child(2) { animation-delay: .2s; }
.ai-tdot:nth-child(3) { animation-delay: .4s; }
@keyframes aiTyping { 0%,80%,100%{opacity:.2;transform:scale(.8)} 40%{opacity:1;transform:scale(1.1)} }
.ai-quick-btns { padding: 10px 12px; display: flex; gap: 8px; flex-wrap: wrap; border-top: 1px solid rgba(0,232,122,0.08); flex-shrink: 0; }
.ai-qbtn { background: rgba(0,232,122,0.08); border: 1px solid rgba(0,232,122,0.15); border-radius: 20px; padding: 5px 12px; font-size: 10px; cursor: pointer; color: var(--g); white-space: nowrap; transition: all .2s; font-family: 'JetBrains Mono', monospace; }
.ai-qbtn:hover { background: rgba(0,232,122,0.2); }
.ai-input-row { padding: 12px; border-top: 1px solid rgba(0,232,122,0.1); display: flex; gap: 8px; background: var(--bg2); flex-shrink: 0; }
.ai-input { flex: 1; background: rgba(0,232,122,0.05); border: 1px solid rgba(0,232,122,0.2); border-radius: 20px; padding: 10px 14px; font-size: 12px; font-family: inherit; color: var(--text); resize: none; outline: none; }
.ai-input:focus { border-color: var(--g); }
.ai-input::placeholder { color: var(--text3); }
.ai-send-btn { background: var(--g); border: none; border-radius: 20px; width: 38px; height: 38px; display: flex; align-items: center; justify-content: center; cursor: pointer; color: #000; font-size: 14px; transition: all .2s; flex-shrink: 0; }
.ai-send-btn:hover { background: var(--c); transform: scale(1.05); }
.ai-send-btn:disabled { opacity: 0.35; cursor: not-allowed; transform: none; }

/* ==========================================
   16. SCROLL REVEAL
   ========================================== */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.7s ease, transform 0.7s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ==========================================
   17. RESPONSIVE — TABLET
   ========================================== */
@media (max-width: 1024px) {
  .hero { grid-template-columns: 1fr; padding: 48px 24px; gap: 44px; min-height: auto; text-align: center; }
  .hero-sub { max-width: 100%; margin-left: auto; margin-right: auto; }
  .hero-btns { justify-content: center; }
  .hero-stats { justify-content: center; }
  .hero-visual { transform: scale(.88); }
  .dash-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ==========================================
   18. RESPONSIVE — MOBILE (≤768px)
   ========================================== */
@media (max-width: 768px) {
  /* Navbar mobile */
  nav {
    padding: 0 16px;
  }
  .nav-links { display: none; }
  .nav-right { display: none; }
  .hamburger { display: flex; }

  /* Sections */
  section { padding: 44px 16px; }

  /* Hero — fix text overflow */
  .hero {
    padding: 36px 16px 32px;
    overflow: hidden;
  }
  .hero h1 {
    font-size: clamp(28px, 8vw, 42px);
    letter-spacing: -1px;
    word-break: break-word;
    overflow-wrap: break-word;
  }
  .hero-sub {
    font-size: 13px;
    word-break: break-word;
    overflow-wrap: break-word;
  }
  .hero-btns {
    flex-direction: column;
    width: 100%;
  }
  .btn-primary, .btn-ghost {
    width: 100%;
    justify-content: center;
  }
  .hero-visual { transform: scale(.75); margin-top: -20px; }
  .float-card-1, .float-card-2 { display: none; }

  /* Fix untuk semua teks yang kepotong */
  .hero h1, 
  .hero-sub,
  .section-title,
  .section-sub,
  .acard-name,
  .acard-status,
  .atag,
  .tasks-body,
  .g-title,
  .g-desc,
  .g-list li,
  .dash-label,
  .nav-logo,
  .fc-title,
  .fc-val,
  .fc-sub,
  .st-item-text,
  .footer-brand p,
  .footer-links a {
    word-break: break-word;
    overflow-wrap: break-word;
    white-space: normal;
  }

  /* Fix untuk ticker yang kepotong */
  .pticker-wrap,
  .nticker-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  
  .pticker-inner,
  .nticker-inner {
    animation: none;
    white-space: nowrap;
  }
  
  /* Fix untuk badge dan tag */
  .atag,
  .st-badge-wrap .st-item {
    white-space: normal;
    word-break: break-word;
  }
  
  /* Fix untuk quick buttons AI */
  .ai-quick-btns {
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 8px;
  }
  
  .ai-qbtn {
    white-space: nowrap;
    flex-shrink: 0;
  }
  
  /* Fix untuk stat card */
  .dash-card {
    word-break: break-word;
  }
  
  .dash-num {
    font-size: 28px;
    word-break: break-word;
  }
  
  /* Fix untuk filter buttons */
  .filter-btns {
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 8px;
  }
  
  .fbtn {
    white-space: nowrap;
    flex-shrink: 0;
  }
  
  /* Fix untuk hero stats */
  .hero-stats {
    flex-wrap: wrap;
    justify-content: center;
  }
  
  .hstat {
    min-width: 80px;
  }
  
  .hstat-num {
    font-size: 20px;
    word-break: break-word;
  }
  
  /* Fix untuk guide card list */
  .g-list li {
    flex-wrap: wrap;
  }
  
  .g-list li strong {
    min-width: auto;
  }

  /* Grid adjustments */
  .dash-grid { grid-template-columns: 1fr 1fr; }
  .guide-grid { grid-template-columns: 1fr; }
  #airdrop-container { grid-template-columns: 1fr; }
  .filter-bar { flex-direction: column; align-items: stretch; }
  .search-box { min-width: unset; }

  /* Footer */
  .footer-top { grid-template-columns: 1fr; gap: 28px; }
  footer { padding: 32px 16px 20px; }
  .footer-bottom { flex-direction: column; text-align: center; gap: 6px; }

  /* AI Panel */
  .ai-panel { right: 10px; left: 10px; width: auto; bottom: 10px; }
}

/* ==========================================
   19. RESPONSIVE — SMALL MOBILE (≤480px)
   ========================================== */
@media (max-width: 480px) {
  .dash-grid { grid-template-columns: 1fr; }
  .hero h1 { font-size: 32px; letter-spacing: -1px; }
  .hero-btns { flex-direction: column; }
  .btn-primary, .btn-ghost { width: 100%; justify-content: center; }
  .hero-stats { gap: 16px; }
  
  /* Fix overflow untuk semua container */
  body, html {
    overflow-x: hidden;
    width: 100%;
  }
  
  .container, section, .hero, footer {
    overflow-x: hidden;
  }
  
  /* Fix untuk card airdrop */
  .acard {
    padding: 16px;
  }
  
  .acard-top {
    flex-wrap: wrap;
    gap: 10px;
  }
  
  .acard-status {
    white-space: normal;
    text-align: center;
  }
  
  .acard-tags {
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 6px;
  }
  
  /* Fix untuk raised info */
  .acard-raised {
    flex-wrap: wrap;
  }
  
  .raised-ico {
    flex-shrink: 0;
  }
  
  /* Fix untuk progress bar text */
  .prog-meta {
    flex-wrap: wrap;
    gap: 4px;
  }
  
  /* Fix untuk tasks */
  .tasks-body {
    max-height: 100px;
    overflow-y: auto;
  }
}
