/* ============================================
   MINECRAFT WEBSITE - MAIN STYLESHEET
   Pixel / Retro Game Aesthetic
   ============================================ */

@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=VT323:wght@400&display=swap');

/* ---- CSS Variables ---- */
:root {
  --dirt: #8B6914;
  --grass-top: #5D9B3C;
  --grass-side: #7D9B4A;
  --stone: #7D7D7D;
  --wood: #A0742A;
  --leaves: #4E7A1E;
  --sky: #77C3EC;
  --night: #0D1B2A;
  --creeper: #4CAF50;
  --gold: #FFD700;
  --diamond: #5DE0E6;
  --redstone: #FF3333;
  --sand: #E8D59A;
  --obsidian: #1A0A2E;
  --snow: #F5F5F5;

  --pixel-border: 4px solid #000;
  --pixel-shadow: 4px 4px 0px #000;
  --pixel-shadow-gold: 4px 4px 0px #b8860b;

  --font-title: 'Press Start 2P', monospace;
  --font-body: 'VT323', monospace;
}

/* ---- Reset & Base ---- */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

body {
  background-color: var(--night);
  color: #e8e8e8;
  font-family: var(--font-body);
  font-size: 20px;
  line-height: 1.6;
  overflow-x: hidden;
  cursor: url("data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' width='16' height='16'><rect width='8' height='8' fill='%235D9B3C'/><rect x='8' y='8' width='8' height='8' fill='%235D9B3C'/></svg>") 0 0, crosshair;
}

/* ---- Pixel Pattern Background ---- */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 31px, rgba(255,255,255,0.015) 32px),
    repeating-linear-gradient(90deg, transparent, transparent 31px, rgba(255,255,255,0.015) 32px);
  pointer-events: none;
  z-index: 0;
}

/* ---- Stars background ---- */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  background-image:
    radial-gradient(1px 1px at 10% 20%, white 0%, transparent 100%),
    radial-gradient(1px 1px at 30% 70%, white 0%, transparent 100%),
    radial-gradient(1px 1px at 55% 15%, white 0%, transparent 100%),
    radial-gradient(1px 1px at 75% 45%, white 0%, transparent 100%),
    radial-gradient(1px 1px at 90% 80%, white 0%, transparent 100%),
    radial-gradient(1px 1px at 20% 90%, white 0%, transparent 100%),
    radial-gradient(1px 1px at 85% 10%, white 0%, transparent 100%),
    radial-gradient(1px 1px at 45% 55%, rgba(255,255,255,0.5) 0%, transparent 100%),
    radial-gradient(1px 1px at 65% 35%, rgba(255,255,255,0.5) 0%, transparent 100%);
  pointer-events: none;
  z-index: 0;
  animation: twinkle 4s ease-in-out infinite alternate;
}

@keyframes twinkle {
  0% { opacity: 0.6; }
  100% { opacity: 1; }
}

/* ---- Navigation ---- */
nav {
  position: sticky;
  top: 0;
  z-index: 1000;
  background: var(--obsidian);
  border-bottom: 4px solid var(--grass-top);
  box-shadow: 0 4px 0 #000, 0 8px 0 var(--leaves);
  padding: 0 2rem;
}

.nav-inner {
  max-width: 1300px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: 0.8rem 0;
}

.nav-logo {
  font-family: var(--font-title);
  font-size: 0.85rem;
  color: var(--grass-top);
  text-decoration: none;
  text-shadow: 2px 2px 0 #000, 0 0 20px rgba(93,155,60,0.5);
  letter-spacing: 1px;
  animation: logo-pulse 3s ease-in-out infinite;
}

@keyframes logo-pulse {
  0%, 100% { text-shadow: 2px 2px 0 #000, 0 0 10px rgba(93,155,60,0.3); }
  50% { text-shadow: 2px 2px 0 #000, 0 0 30px rgba(93,155,60,0.8); }
}

.nav-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  list-style: none;
}

.nav-links a {
  display: block;
  font-family: var(--font-title);
  font-size: 0.45rem;
  color: #ccc;
  text-decoration: none;
  padding: 6px 10px;
  border: 2px solid transparent;
  transition: all 0.1s;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  position: relative;
}

.nav-links a:hover,
.nav-links a.active {
  color: var(--gold);
  border-color: var(--gold);
  background: rgba(255,215,0,0.1);
  box-shadow: 0 0 10px rgba(255,215,0,0.3);
}

.nav-links a::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--gold);
  transition: width 0.2s;
}

.nav-links a:hover::after { width: 100%; }

/* ---- Page Wrapper ---- */
.page {
  display: none;
  min-height: calc(100vh - 80px);
  position: relative;
  z-index: 1;
  animation: fadeIn 0.3s ease;
}

.page.active {
  display: block;
}

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

/* ---- Hero Section ---- */
.hero {
  position: relative;
  min-height: 90vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 4rem 2rem;
  overflow: hidden;
}

.hero-bg {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to bottom, #77C3EC 0%, #77C3EC 50%, #5D9B3C 50%, #5D9B3C 56%, #8B6914 56%, #8B6914 100%);
  z-index: -1;
}

.hero-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(13,27,42,0.45);
}

.hero-clouds {
  position: absolute;
  top: 10%;
  left: 0;
  right: 0;
  height: 80px;
  z-index: 0;
}

.cloud {
  position: absolute;
  background: rgba(255,255,255,0.9);
  height: 20px;
  image-rendering: pixelated;
}
.cloud::before, .cloud::after {
  content: '';
  position: absolute;
  background: rgba(255,255,255,0.9);
}
.cloud-1 { width: 80px; top: 0; left: 10%; animation: float-cloud 20s linear infinite; }
.cloud-2 { width: 120px; top: 20px; left: 40%; animation: float-cloud 28s linear infinite; }
.cloud-3 { width: 60px; top: 5px; left: 70%; animation: float-cloud 16s linear infinite; }

@keyframes float-cloud {
  from { transform: translateX(-200px); }
  to { transform: translateX(calc(100vw + 200px)); }
}

/* Pixel trees */
.hero-trees {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 120px;
  z-index: 1;
}

.tree {
  position: absolute;
  bottom: 0;
}

.tree-trunk {
  width: 16px;
  height: 40px;
  background: var(--wood);
  margin: 0 auto;
  border: 2px solid #000;
}

.tree-leaves {
  width: 56px;
  height: 56px;
  background: var(--leaves);
  border: 2px solid #000;
  position: relative;
  left: -20px;
  image-rendering: pixelated;
}

.tree:nth-child(1) { left: 3%; }
.tree:nth-child(2) { left: 10%; transform: scale(0.75); }
.tree:nth-child(3) { left: 82%; }
.tree:nth-child(4) { left: 91%; transform: scale(0.85); }
.tree:nth-child(5) { left: 72%; transform: scale(0.6); }

.hero-content {
  position: relative;
  z-index: 2;
}

.hero-title {
  font-family: var(--font-title);
  font-size: clamp(1.2rem, 5vw, 3rem);
  color: #fff;
  text-shadow: 4px 4px 0 #000, 6px 6px 0 rgba(0,0,0,0.4);
  margin-bottom: 1rem;
  line-height: 1.4;
  letter-spacing: 2px;
  animation: title-drop 0.6s cubic-bezier(0.175,0.885,0.32,1.275) both;
}

.hero-title span {
  color: var(--grass-top);
  display: block;
  font-size: 1.2em;
  text-shadow: 4px 4px 0 #000, 0 0 40px rgba(93,155,60,0.8);
}

@keyframes title-drop {
  from { opacity: 0; transform: translateY(-40px) scale(0.9); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

.hero-sub {
  font-family: var(--font-body);
  font-size: 1.4rem;
  color: rgba(255,255,255,0.85);
  margin-bottom: 2.5rem;
  letter-spacing: 1px;
}

/* ---- Pixel Button ---- */
.btn {
  display: inline-block;
  font-family: var(--font-title);
  font-size: 0.55rem;
  color: #000;
  background: var(--grass-top);
  padding: 12px 24px;
  border: 3px solid #000;
  box-shadow: var(--pixel-shadow);
  cursor: pointer;
  text-decoration: none;
  text-transform: uppercase;
  transition: all 0.1s;
  letter-spacing: 1px;
}

.btn:hover {
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0px #000;
  background: #6ab845;
}

.btn:active {
  transform: translate(2px, 2px);
  box-shadow: 2px 2px 0px #000;
}

.btn-gold {
  background: var(--gold);
  box-shadow: var(--pixel-shadow-gold);
}
.btn-gold:hover { background: #ffe040; box-shadow: 6px 6px 0 #b8860b; }

.btn-diamond {
  background: var(--diamond);
  box-shadow: 4px 4px 0 #2a9098;
}
.btn-diamond:hover { background: #7dedf3; }

/* ---- Section ---- */
.section {
  max-width: 1200px;
  margin: 0 auto;
  padding: 4rem 2rem;
}

.section-title {
  font-family: var(--font-title);
  font-size: clamp(0.7rem, 2.5vw, 1.1rem);
  color: var(--gold);
  text-align: center;
  margin-bottom: 3rem;
  text-shadow: 3px 3px 0 #000;
  position: relative;
}

.section-title::before,
.section-title::after {
  content: '⛏️';
  font-size: 1.5rem;
  margin: 0 1rem;
  vertical-align: middle;
}

/* ---- Pixel Card ---- */
.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 2rem;
}

.card {
  background: #1a2a1a;
  border: 3px solid var(--grass-top);
  box-shadow: var(--pixel-shadow);
  padding: 1.5rem;
  position: relative;
  transition: transform 0.15s, box-shadow 0.15s;
  overflow: hidden;
}

.card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--grass-top), var(--leaves), var(--grass-top));
}

.card:hover {
  transform: translate(-4px, -4px);
  box-shadow: 8px 8px 0 #000;
  border-color: var(--gold);
}

.card-icon {
  font-size: 3rem;
  display: block;
  margin-bottom: 1rem;
  filter: drop-shadow(2px 2px 0 #000);
}

.card-title {
  font-family: var(--font-title);
  font-size: 0.6rem;
  color: var(--grass-top);
  margin-bottom: 0.8rem;
  letter-spacing: 1px;
}

.card p {
  font-size: 1.2rem;
  color: #c8c8c8;
  line-height: 1.7;
}

/* ---- Grass Divider ---- */
.grass-divider {
  width: 100%;
  height: 32px;
  background:
    linear-gradient(to bottom, var(--grass-top) 50%, var(--dirt) 50%);
  border-top: 3px solid #000;
  border-bottom: 3px solid #000;
  image-rendering: pixelated;
  position: relative;
  overflow: hidden;
}

.grass-divider::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 50%;
  background: repeating-linear-gradient(
    90deg,
    var(--grass-top) 0px, var(--grass-top) 16px,
    var(--leaves) 16px, var(--leaves) 32px
  );
  opacity: 0.4;
}

/* ---- Feature Strip ---- */
.feature-strip {
  background: linear-gradient(135deg, #0D1B2A 0%, #1a2e1a 50%, #0D1B2A 100%);
  border-top: 3px solid var(--dirt);
  border-bottom: 3px solid var(--dirt);
  padding: 3rem 2rem;
  text-align: center;
}

.feature-strip h2 {
  font-family: var(--font-title);
  font-size: 0.8rem;
  color: var(--diamond);
  margin-bottom: 2rem;
  text-shadow: 2px 2px 0 #000;
}

.strip-items {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 2rem;
  max-width: 1000px;
  margin: 0 auto;
}

.strip-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}

.strip-item span:first-child {
  font-size: 2.5rem;
  filter: drop-shadow(2px 2px 0 #000);
}

.strip-item span:last-child {
  font-family: var(--font-title);
  font-size: 0.45rem;
  color: var(--sand);
  text-align: center;
  max-width: 80px;
}

/* ---- Facts / Weetjes ---- */
.fact-list {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.fact-item {
  display: flex;
  align-items: flex-start;
  gap: 1.5rem;
  background: rgba(93,155,60,0.08);
  border: 2px solid var(--grass-side);
  border-left: 8px solid var(--grass-top);
  padding: 1.2rem 1.5rem;
  box-shadow: 3px 3px 0 #000;
  transition: all 0.15s;
}

.fact-item:hover {
  border-left-color: var(--gold);
  background: rgba(255,215,0,0.05);
  transform: translateX(4px);
}

.fact-number {
  font-family: var(--font-title);
  font-size: 1rem;
  color: var(--grass-top);
  min-width: 2.5rem;
  text-shadow: 2px 2px 0 #000;
}

.fact-text {
  font-size: 1.3rem;
  color: #d8d8d8;
  line-height: 1.6;
}

.fact-text strong {
  color: var(--gold);
  font-family: var(--font-title);
  font-size: 0.55rem;
}

/* ---- Trucjes / Tips ---- */
.tip-box {
  background: #0f1f0f;
  border: 3px solid var(--gold);
  box-shadow: var(--pixel-shadow-gold);
  padding: 1.5rem 2rem;
  margin-bottom: 1.5rem;
  position: relative;
}

.tip-box::before {
  content: attr(data-category);
  position: absolute;
  top: -14px;
  left: 16px;
  background: var(--gold);
  color: #000;
  font-family: var(--font-title);
  font-size: 0.4rem;
  padding: 3px 10px;
  border: 2px solid #000;
  box-shadow: 2px 2px 0 #000;
}

.tip-box h3 {
  font-family: var(--font-title);
  font-size: 0.55rem;
  color: var(--grass-top);
  margin-bottom: 0.8rem;
  letter-spacing: 1px;
}

.tip-box p {
  font-size: 1.25rem;
  color: #c8d8c8;
  line-height: 1.7;
}

.tip-box code {
  background: rgba(255,215,0,0.15);
  border: 1px solid var(--gold);
  color: var(--gold);
  font-family: var(--font-title);
  font-size: 0.4rem;
  padding: 2px 8px;
  display: inline-block;
  margin: 4px 2px;
}

/* ---- Blocks Grid ---- */
.blocks-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 1rem;
}

.block-item {
  background: #1a2a1a;
  border: 3px solid #444;
  box-shadow: var(--pixel-shadow);
  padding: 1rem 0.5rem;
  text-align: center;
  cursor: pointer;
  transition: all 0.1s;
  position: relative;
}

.block-item:hover {
  transform: translate(-3px, -3px);
  box-shadow: 7px 7px 0 #000;
  border-color: var(--gold);
  z-index: 2;
}

.block-emoji {
  font-size: 2.5rem;
  display: block;
  margin-bottom: 0.5rem;
  image-rendering: pixelated;
}

.block-name {
  font-family: var(--font-title);
  font-size: 0.35rem;
  color: #aaa;
  display: block;
  letter-spacing: 0.5px;
  line-height: 1.4;
}

.block-item:hover .block-name { color: var(--gold); }

.block-tooltip {
  display: none;
  position: absolute;
  bottom: 110%;
  left: 50%;
  transform: translateX(-50%);
  background: #000;
  color: #fff;
  font-size: 1rem;
  padding: 8px 12px;
  border: 2px solid var(--gold);
  white-space: nowrap;
  z-index: 100;
  box-shadow: 3px 3px 0 var(--gold);
  min-width: 160px;
  white-space: normal;
  text-align: left;
}

.block-item:hover .block-tooltip { display: block; }

/* ---- Mobs ---- */
.mobs-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 1.5rem;
}

.mob-card {
  background: #0d1a0d;
  border: 3px solid #333;
  box-shadow: var(--pixel-shadow);
  padding: 1.5rem;
  text-align: center;
  transition: all 0.15s;
  position: relative;
  overflow: hidden;
}

.mob-card.hostile { border-color: var(--redstone); }
.mob-card.passive { border-color: var(--grass-top); }
.mob-card.neutral { border-color: var(--gold); }
.mob-card.boss { border-color: var(--obsidian); border-width: 4px; }

.mob-card::after {
  content: attr(data-type);
  position: absolute;
  top: 8px;
  right: 8px;
  font-family: var(--font-title);
  font-size: 0.3rem;
  padding: 3px 7px;
  border: 2px solid currentColor;
}

.mob-card.hostile::after { color: var(--redstone); border-color: var(--redstone); }
.mob-card.passive::after { color: var(--grass-top); border-color: var(--grass-top); }
.mob-card.neutral::after { color: var(--gold); border-color: var(--gold); }
.mob-card.boss::after { color: var(--diamond); border-color: var(--diamond); }

.mob-card:hover {
  transform: translate(-3px, -3px);
  box-shadow: 7px 7px 0 #000;
}

.mob-emoji {
  font-size: 3.5rem;
  display: block;
  margin-bottom: 0.8rem;
  animation: mob-bounce 2s ease-in-out infinite;
}

.mob-card:hover .mob-emoji {
  animation: mob-bounce-fast 0.5s ease-in-out infinite;
}

@keyframes mob-bounce {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

@keyframes mob-bounce-fast {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

.mob-name {
  font-family: var(--font-title);
  font-size: 0.5rem;
  color: #e0e0e0;
  margin-bottom: 0.5rem;
  display: block;
}

.mob-desc {
  font-size: 1.1rem;
  color: #888;
  line-height: 1.5;
}

.mob-hp {
  display: flex;
  justify-content: center;
  gap: 2px;
  margin-top: 0.8rem;
  flex-wrap: wrap;
}

.heart {
  color: var(--redstone);
  font-size: 0.9rem;
}

/* ---- Over Ons ---- */
.team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 2rem;
}

.team-card {
  background: #0f1f2f;
  border: 3px solid var(--diamond);
  box-shadow: 4px 4px 0 #000;
  padding: 2rem 1.5rem;
  text-align: center;
  transition: all 0.15s;
}

.team-card:hover {
  transform: translate(-4px, -4px);
  box-shadow: 8px 8px 0 #000;
}

.team-avatar {
  font-size: 4rem;
  display: block;
  margin-bottom: 1rem;
  filter: drop-shadow(3px 3px 0 #000);
}

.team-name {
  font-family: var(--font-title);
  font-size: 0.55rem;
  color: var(--diamond);
  margin-bottom: 0.3rem;
  display: block;
}

.team-role {
  font-family: var(--font-title);
  font-size: 0.38rem;
  color: var(--grass-top);
  margin-bottom: 1rem;
  display: block;
}

.team-bio {
  font-size: 1.15rem;
  color: #aaa;
  line-height: 1.6;
}

.mission-box {
  background: linear-gradient(135deg, #0d1b2a, #1a2e1a);
  border: 4px solid var(--grass-top);
  box-shadow: var(--pixel-shadow);
  padding: 2.5rem;
  text-align: center;
  margin-top: 3rem;
}

.mission-box h2 {
  font-family: var(--font-title);
  font-size: 0.7rem;
  color: var(--gold);
  margin-bottom: 1.5rem;
  text-shadow: 2px 2px 0 #000;
}

.mission-box p {
  font-size: 1.3rem;
  color: #c0c0c0;
  max-width: 700px;
  margin: 0 auto;
  line-height: 1.8;
}

/* ---- Contact ---- */
.contact-wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
}

@media (max-width: 768px) {
  .contact-wrapper { grid-template-columns: 1fr; }
}

.contact-form {
  background: #0f1f0f;
  border: 3px solid var(--grass-top);
  box-shadow: var(--pixel-shadow);
  padding: 2rem;
}

.form-group {
  margin-bottom: 1.5rem;
}

.form-group label {
  display: block;
  font-family: var(--font-title);
  font-size: 0.45rem;
  color: var(--grass-top);
  margin-bottom: 0.6rem;
  letter-spacing: 1px;
}

.form-group input,
.form-group textarea,
.form-group select {
  width: 100%;
  background: #0d1a0d;
  border: 3px solid #444;
  color: #e0e0e0;
  font-family: var(--font-body);
  font-size: 1.2rem;
  padding: 10px 14px;
  transition: border-color 0.15s;
  outline: none;
}

.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  border-color: var(--grass-top);
  box-shadow: 0 0 0 2px rgba(93,155,60,0.3);
}

.form-group textarea {
  height: 120px;
  resize: vertical;
}

.form-group select option {
  background: #0d1a0d;
}

.contact-info {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.info-box {
  background: rgba(93,155,60,0.08);
  border: 2px solid var(--grass-side);
  padding: 1.2rem;
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}

.info-icon {
  font-size: 2rem;
  flex-shrink: 0;
}

.info-text h4 {
  font-family: var(--font-title);
  font-size: 0.45rem;
  color: var(--grass-top);
  margin-bottom: 0.3rem;
}

.info-text p {
  font-size: 1.1rem;
  color: #aaa;
}

.socials {
  display: flex;
  gap: 1rem;
  margin-top: 1rem;
  flex-wrap: wrap;
}

.social-btn {
  font-family: var(--font-title);
  font-size: 0.38rem;
  padding: 8px 14px;
  border: 2px solid currentColor;
  cursor: pointer;
  text-decoration: none;
  transition: all 0.15s;
  box-shadow: 3px 3px 0 #000;
}

.social-btn:hover {
  transform: translate(-2px, -2px);
  box-shadow: 5px 5px 0 #000;
}

.social-btn.youtube { color: #ff0000; }
.social-btn.discord { color: #7289da; }
.social-btn.twitter { color: var(--diamond); }

/* ---- Inventory Bar ---- */
.inventory-bar {
  position: fixed;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 4px;
  background: rgba(0,0,0,0.85);
  border: 3px solid #999;
  padding: 5px;
  z-index: 999;
  box-shadow: 0 0 20px rgba(0,0,0,0.8);
}

.inv-slot {
  width: 44px;
  height: 44px;
  background: #8B8B8B;
  border: 2px solid #555;
  border-right-color: #222;
  border-bottom-color: #222;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  cursor: pointer;
  position: relative;
  transition: all 0.1s;
}

.inv-slot:hover {
  background: #a0a0a0;
  border-color: #fff;
}

.inv-slot.selected {
  background: #a0a0a0;
  border-color: #fff;
  outline: 2px solid #fff;
  outline-offset: 1px;
}

.inv-slot-tooltip {
  display: none;
  position: absolute;
  bottom: 110%;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(0,0,0,0.95);
  color: #fff;
  font-family: var(--font-title);
  font-size: 0.3rem;
  padding: 5px 8px;
  border: 1px solid #555;
  white-space: nowrap;
  pointer-events: none;
}

.inv-slot:hover .inv-slot-tooltip { display: block; }

/* ---- XP Bar ---- */
.xp-bar-wrapper {
  max-width: 400px;
  margin: 2rem auto;
  text-align: center;
}

.xp-label {
  font-family: var(--font-title);
  font-size: 0.4rem;
  color: var(--grass-top);
  margin-bottom: 0.5rem;
}

.xp-bar {
  height: 12px;
  background: #1a1a1a;
  border: 2px solid #000;
  overflow: hidden;
}

.xp-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--creeper), #8bc34a);
  animation: xp-grow 2s ease-out both;
}

@keyframes xp-grow {
  from { width: 0; }
}

/* ---- Creeper Blink Animation ---- */
@keyframes creeper-eye {
  0%, 90%, 100% { opacity: 1; }
  95% { opacity: 0; }
}

/* ---- Scroll to top ---- */
.scroll-top {
  display: inline-block;
  background: var(--obsidian);
  color: var(--grass-top);
  border: 3px solid var(--grass-top);
  font-family: var(--font-title);
  font-size: 0.4rem;
  padding: 10px 16px;
  cursor: pointer;
  box-shadow: var(--pixel-shadow);
  transition: all 0.1s;
  text-decoration: none;
  margin: 2rem auto;
  display: block;
  width: fit-content;
}

.scroll-top:hover {
  background: var(--grass-top);
  color: #000;
  transform: translate(-2px, -2px);
  box-shadow: 6px 6px 0 #000;
}

/* ---- Footer ---- */
footer {
  background: #050d05;
  border-top: 4px solid var(--grass-top);
  padding: 2rem;
  text-align: center;
  position: relative;
  z-index: 1;
}

footer p {
  font-size: 1.1rem;
  color: #555;
}

footer span {
  color: var(--grass-top);
}

/* ---- Heading Styles ---- */
.page-hero {
  background: linear-gradient(135deg, #0d1a0d 0%, #1a2e1a 50%, #0d1a0d 100%);
  border-bottom: 4px solid var(--grass-top);
  padding: 4rem 2rem 2rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    -45deg,
    transparent,
    transparent 20px,
    rgba(93,155,60,0.03) 20px,
    rgba(93,155,60,0.03) 40px
  );
}

.page-hero h1 {
  font-family: var(--font-title);
  font-size: clamp(0.8rem, 3vw, 1.5rem);
  color: var(--gold);
  text-shadow: 3px 3px 0 #000, 0 0 20px rgba(255,215,0,0.3);
  position: relative;
  z-index: 1;
  line-height: 1.4;
}

.page-hero p {
  font-size: 1.3rem;
  color: #888;
  margin-top: 1rem;
  position: relative;
  z-index: 1;
}

/* ---- Notification ---- */
.notification {
  position: fixed;
  top: 100px;
  right: 20px;
  background: #0f1f0f;
  border: 3px solid var(--grass-top);
  box-shadow: var(--pixel-shadow);
  padding: 1rem 1.5rem;
  font-family: var(--font-title);
  font-size: 0.45rem;
  color: var(--grass-top);
  z-index: 9999;
  transform: translateX(200%);
  transition: transform 0.3s cubic-bezier(0.175,0.885,0.32,1.275);
  max-width: 280px;
}

.notification.show {
  transform: translateX(0);
}

.notification-icon {
  display: block;
  font-size: 2rem;
  margin-bottom: 0.5rem;
}

/* ---- Achievement Toast ---- */
.achievement {
  position: fixed;
  top: 90px;
  left: 50%;
  transform: translateX(-50%);
  background: #1a1a00;
  border: 3px solid var(--gold);
  box-shadow: var(--pixel-shadow-gold);
  padding: 1rem 2rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  z-index: 9999;
  transition: opacity 0.3s ease;
  opacity: 0;
  pointer-events: none;
}

.achievement.show {
  opacity: 1;
  pointer-events: auto;
}

/* Verberg hem helemaal als hij niet actief is */
.achievement:not(.show) {
  transform: translateX(-50%) translateY(-150px);
}

.achievement-title {
  font-family: var(--font-title);
  font-size: 0.35rem;
  color: var(--gold);
  display: block;
  margin-bottom: 0.3rem;
}

.achievement-text {
  font-family: var(--font-title);
  font-size: 0.45rem;
  color: #fff;
}

/* ---- Responsive ---- */
@media (max-width: 768px) {
  .nav-inner { flex-direction: column; gap: 0.8rem; }
  .nav-links a { font-size: 0.38rem; padding: 5px 8px; }
  .hero-title { font-size: 1rem; }
  .card-grid { grid-template-columns: 1fr; }
  .blocks-grid { grid-template-columns: repeat(auto-fill, minmax(90px, 1fr)); }
  .inventory-bar { bottom: 10px; }
  .inv-slot { width: 36px; height: 36px; font-size: 1.2rem; }
  .contact-wrapper { grid-template-columns: 1fr; }
}