:root {
  --bg: #14121d;
  --panel: #1c1928;
  --text: #f3f1ff;
  --muted: #b8b4ff;
  --gold: #c8a64b;
  --border: rgba(200, 166, 75, 0.25);
  --shadow: 0 12px 24px rgba(0, 0, 0, 0.5);
}

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

body {
  font-family: 'Asul', 'Inter', system-ui, sans-serif;
  color: var(--text);
  line-height: 1.6;
  image-rendering: pixelated;
  background: #0b0914;
  overflow: auto;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  background: linear-gradient(rgba(12,10,18,0.70), rgba(12,10,18,0.70)),
              url("images/map-bg.png") center/cover no-repeat;
  filter: grayscale(0.55) brightness(0.8);
  opacity: 0.4;
  z-index: -1;
  animation: mapFloat 40s ease-in-out infinite alternate;
}
@keyframes mapFloat { from { transform: translateY(0px); } to { transform: translateY(-40px); } }

@media (prefers-reduced-motion: reduce) {
  * { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; scroll-behavior: auto !important; }
  body::before { background-attachment: scroll; animation: none; }
}

h1, h2, h3, h4, h5, h6 { font-family: 'Asul', 'Press Start 2P', monospace; }
a { color: var(--gold); }

header {
  padding: 24px 32px 12px;
  border-bottom: 1px solid var(--border);
  background: rgba(8, 4, 20, 0.92);
  backdrop-filter: blur(6px);
  position: sticky;
  top: 0;
  z-index: 1000;
  text-align: center;
}
.brand { display: inline-flex; align-items: center; gap: 14px; margin-bottom: 18px; }
.brand img { width: 42px; height: 42px; border: 1px solid var(--gold); padding: 4px; background: var(--panel); border-radius: 6px; object-fit: contain; }
.brand h1 { font-size: 16px; color: var(--gold); letter-spacing: 1px; text-shadow: 0 0 4px rgba(200, 166, 75, 0.5); }

.main-nav { display: flex; justify-content: center; gap: 48px; flex-wrap: wrap; margin-bottom: 12px; }
.main-nav a {
  font-family: 'Asul', 'Press Start 2P', monospace;
  font-size: 14px;
  color: var(--muted);
  text-decoration: none;
  padding: 10px 14px;
  transition: all 0.25s ease;
  position: relative;
}
.main-nav a:hover, .main-nav a:focus-visible { color: var(--gold); text-shadow: 0 0 6px rgba(200, 166, 75, 0.7); }
.main-nav a::after {
  content: ""; position: absolute; left: 0; bottom: -6px; width: 100%; height: 2px;
  background: var(--gold); opacity: 0; transform: scaleX(0.5); transition: all 0.25s ease;
}
.main-nav a:hover::after, .main-nav a:focus-visible::after { opacity: 1; transform: scaleX(1); }
.main-nav a.active { color: var(--gold); }
.main-nav a.active::after { opacity: 1; transform: scaleX(1); }

.nav-dropdown { position: relative; display: inline-block; }
.nav-dropbtn {
  background: none; border: none; color: var(--muted);
  font-family: 'Asul', 'Press Start 2P', monospace;
  font-size: 14px; padding: 10px 14px; cursor: pointer;
}
.nav-dropbtn:hover, .nav-dropbtn:focus-visible { color: var(--gold); text-shadow: 0 0 6px rgba(200,166,75,0.7); }
.nav-dropdown-content {
  display: none; position: absolute; background: #151021;
  min-width: 160px; border: 1px solid var(--border); border-radius: 8px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.4); z-index: 1200; padding: 6px 0;
}
.nav-dropdown-content a {
  display: block; padding: 10px 14px; color: var(--text); text-decoration: none;
  font-family: 'Asul','Inter',sans-serif; font-size: 13px;
}
.nav-dropdown-content a:hover { background: rgba(200,166,75,0.12); color: var(--gold); }
.nav-dropdown:hover .nav-dropdown-content,
.nav-dropdown:focus-within .nav-dropdown-content { display: block; }

main { max-width: 1100px; margin: 0 auto; padding: 80px 24px; }
.hero { text-align: center; animation: fadeIn 0.5s ease-out; font-family: 'Asul','Inter',sans-serif; }
.hero-muted { text-align: center; color: var(--muted); margin-bottom: 24px; }

.cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 32px;
  margin-top: 32px;
}
.card {
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 26px;
  transition: all 0.3s ease;
  font-family: 'Asul','Inter',sans-serif;
  cursor: pointer;
  text-align: center;
}
.card:hover { border-color: var(--gold); transform: scale(1.03); box-shadow: var(--shadow); }
.card h3 { margin-bottom: 10px; font-size: 18px; color: var(--text); }
.card p { font-size: 14px; color: var(--muted); }

.filters {
  display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; margin-bottom: 24px;
}
.filters input, .filters select {
  padding: 10px 14px; background: #1c1928; color: var(--text);
  border: 1px solid var(--border); border-radius: 6px; font-size: 14px;
  max-width: 260px; width: 100%; text-align: center;
}

table { width: 100%; border-collapse: collapse; background: var(--panel); margin-top: 20px; }
th, td { padding: 12px 16px; border: 1px solid var(--border); }
th { background: #191622; color: var(--gold); }
tr:hover { background: #221c35; }

.leaderboard-panel { max-width: 800px; margin: 0 auto; background: #1a1a1a; border: 1px solid #333; padding: 24px; border-radius: 8px; color: #ddd; }

.page-title { font-size: 24px; margin-bottom: 16px; color: var(--text); }

.back-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin: 32px auto 0;
  padding: 10px 20px;
  background: var(--panel);
  border: 1px solid var(--gold);
  color: var(--gold);
  font-family: "Press Start 2P", monospace;
  font-size: 12px;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.25s ease;
  text-decoration: none;
}
.back-btn:hover, .back-btn:focus-visible { box-shadow: 0 0 0 3px rgba(200,166,75,0.25); transform: translateY(-1px); }

footer {
  margin-top: 96px;
  padding: 32px 16px;
  border-top: 1px solid var(--border);
  text-align: center;
  font-size: 13px;
  color: var(--muted);
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
}
.footer-links { display: flex; justify-content: center; align-items: center; gap: 12px; flex-wrap: wrap; text-align: center; }
.footer-links img { width: 24px; height: 24px; filter: brightness(0) invert(0.9); }
.footer-terms {
  max-width: 900px; max-height: 120px; overflow-y: auto; font-size: 11px; text-align: left;
  margin-top: 12px; line-height: 1.4; padding: 12px; background: rgba(255,255,255,0.02);
  border: 1px solid var(--border); border-radius: 6px;
}
footer img[alt="Footer Image"] { margin-top: 12px; max-width: 100%; height: auto; border-radius: 8px; box-shadow: 0 0 8px rgba(0,0,0,0.3); }

.spinner {
  border: 6px solid rgba(255, 255, 255, 0.1);
  border-top: 6px solid var(--gold);
  border-radius: 50%;
  width: 48px; height: 48px;
  animation: spin 1s linear infinite;
  margin: 0 auto;
}
@keyframes spin { to { transform: rotate(360deg); } }

.slot-column { display: flex; flex-direction: column; gap: 8px; }
.slot {
  background: #221c35;
  border: 1px solid var(--border);
  padding: 10px 12px;
  border-radius: 8px;
  cursor: pointer;
  min-width: 120px;
  text-align: center;
  transition: all 0.2s ease;
}
.slot:hover { border-color: var(--gold); }

.sticky-box {
  position: sticky;
  top: 32px;
  max-height: calc(90vh - 12px);
  overflow-y: auto;
  background: var(--panel);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px;
  color: var(--text);
  font-size: 14px;
  box-shadow: 0 0 8px rgba(0,0,0,0.3);
}
.sticky-box ul { list-style: none; padding-left: 0; margin: 0; }
.sticky-box li { margin-bottom: 12px; }
.sticky-box img { width: 32px; vertical-align: middle; margin-right: 6px; }

.classes-layout { display: flex; flex-wrap: wrap; gap: 24px; max-width: 1200px; margin: 0 auto; }
.class-cards {
  flex: 3 1 700px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 16px;
}
.class-card-tile {
  background: var(--panel); border:1px solid var(--border); border-radius:12px; padding:16px;
  text-align:center; box-shadow:0 0 8px rgba(0,0,0,0.3);
}
.class-card-tile img { width:48px; height:48px; margin-bottom:8px; }
.class-card-tile h3 { font-family:'Press Start 2P', monospace; font-size:14px; color:var(--gold); margin:4px 0; }
.class-meta { color: var(--muted); font-size:12px; }
.class-desc { color: var(--muted); font-size:11px; font-style:italic; }

.status-banner { text-align:center; margin:8px 0; color:#e6b800; font-size:13px; }

.centered { text-align: center; }
.class-grid { display:flex; flex-wrap:wrap; gap:16px; justify-content:center; max-width:1000px; margin:0 auto; }
.class-card img { width:48px; height:48px; }

.build-layout { display:flex; justify-content:center; gap:60px; align-items:center; flex-wrap:wrap; }
.build-preview img { width:200px; height:auto; opacity:0.9; }

.item-popup {
  position:absolute; z-index:1000; background:#1a1a1a; border:1px solid #444;
  padding:12px; border-radius:6px; width:200px;
}
.item-popup input { width:100%; padding:6px; margin-bottom:8px; }
.item-popup ul { list-style:none; padding:0; margin:0; max-height:150px; overflow-y:auto; }

.patch-notes { max-width: 900px; margin: 0 auto; }

@keyframes fadeIn { 0% { opacity: 0; transform: translateY(10px); } 100% { opacity: 1; transform: translateY(0); } }

@media (max-width: 640px) {
  .main-nav { gap: 20px; }
  .main-nav a { font-size: 11px; }
  .hero h2 { font-size: 20px; }
}